/* JING · Shanghai · Neo-tonal modern Chinese minimalism
   Mobile-first 390x844 baseline.
*/

:root{
  --cement:#E8E5E0;
  --cream:#F2EBDD;
  --paper:#F8F2E5;
  --paper-2:#EFE7D4;
  --ink:#1A1814;
  --ink-soft:#2A2620;
  --walnut:#5C4533;
  --walnut-soft:#7A5E48;
  --jade:#6B8E7F;
  --jade-soft:#9DB7AB;
  --clay:#B88A6A;
  --hairline:rgba(26,24,20,0.12);
  --hairline-soft:rgba(26,24,20,0.07);
  --shadow-soft:0 1px 2px rgba(26,24,20,.04), 0 8px 24px rgba(26,24,20,.06);
  --shadow-card:0 2px 4px rgba(26,24,20,.05), 0 24px 60px rgba(26,24,20,.08);
  --ease:cubic-bezier(.16,1,.3,1);
  --serif:"Noto Serif SC", "Songti SC", "STSong", serif;
  --sans-cn:"Noto Sans SC", "PingFang SC", system-ui, sans-serif;
  --sans-en:"Inter Tight", system-ui, -apple-system, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, monospace;
}

*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--sans-en);
  font-weight:400;
  color:var(--ink);
  background:var(--cement);
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
em{font-style:italic;font-family:var(--sans-en)}

/* ==========================================================================
   PRIMITIVES
   ========================================================================== */
.mono{
  font-family:var(--mono);
  font-weight:400;
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.mono--dot{opacity:.4}
.cn{font-family:var(--sans-cn);font-weight:400}
.ji{font-family:var(--serif);font-weight:300}
.ji-accent{font-family:var(--serif);font-weight:500;color:var(--jade)}

.glass{
  background:rgba(248,242,229,0.55);
  -webkit-backdrop-filter:blur(20px) saturate(120%);
  backdrop-filter:blur(20px) saturate(120%);
  border:1px solid rgba(255,255,255,0.4);
  box-shadow:var(--shadow-soft);
}

/* Reveal */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .9s var(--ease), transform .9s var(--ease)}
.reveal.is-in{opacity:1;transform:none}

/* ==========================================================================
   NAV
   ========================================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(232,229,224,0.7);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--hairline-soft);
  transition:background .4s var(--ease), border-color .4s var(--ease);
}
.nav.is-scrolled{background:rgba(232,229,224,0.85);border-bottom-color:var(--hairline)}
.nav__inner{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:10px;
  padding:11px 18px;
  max-width:1200px;
  margin:0 auto;
}
.nav__brand{
  display:inline-flex;align-items:baseline;gap:6px;
  text-decoration:none;color:var(--ink);
}
.nav__brand-en{
  font-family:var(--sans-en);
  font-weight:500;font-size:13px;letter-spacing:.18em;
}
.nav__brand-cn{
  font-family:var(--serif);font-weight:400;font-size:18px;line-height:1;
}
.nav__center{
  display:none;
  text-align:center;
  flex-direction:column;
  gap:1px;
}
.nav__center-cn{font-family:var(--sans-cn);font-size:11px;letter-spacing:.32em;color:var(--ink-soft)}
.nav__center-en{font-family:var(--mono);font-size:9px;letter-spacing:.28em;color:var(--ink-soft);opacity:.6;text-transform:uppercase}
.nav__lang{display:flex;align-items:center;gap:8px;justify-self:end}
.nav__lang-btn{
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;
  color:var(--ink-soft);opacity:.55;text-transform:uppercase;
  padding:4px 2px;transition:opacity .3s var(--ease), color .3s var(--ease);
}
.nav__lang-btn.is-active{opacity:1;color:var(--ink)}
.nav__lang-sep{color:var(--ink-soft);opacity:.3;font-size:11px}

@media (min-width:640px){
  .nav__center{display:flex}
  .nav__inner{padding:14px 28px}
}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position:relative;
  min-height:100svh;
  padding:88px 22px 36px;
  display:flex;flex-direction:column;
  overflow:hidden;
  isolation:isolate;
}
.hero__bg{
  position:absolute;inset:-10% -10% -10% -10%;z-index:-2;
  background:
    radial-gradient(60% 50% at 85% 15%, rgba(107,142,127,0.18) 0%, rgba(107,142,127,0) 70%),
    radial-gradient(70% 60% at 10% 90%, rgba(184,138,106,0.12) 0%, rgba(184,138,106,0) 70%),
    linear-gradient(180deg, var(--cream) 0%, var(--cement) 100%);
}
.hero__grain{
  position:absolute;inset:0;z-index:-1;opacity:.35;
  mix-blend-mode:multiply;pointer-events:none;
  background-image:
    radial-gradient(rgba(26,24,20,0.05) 1px, transparent 1px),
    radial-gradient(rgba(26,24,20,0.03) 1px, transparent 1px);
  background-size:3px 3px, 7px 7px;
  background-position:0 0, 1px 1px;
}
.hero__eyebrow{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  margin-top:8px;
}
.hero__glyph-wrap{
  flex:1;
  position:relative;
  display:flex;align-items:center;justify-content:flex-start;
  margin:8px 0 0 -10px;
  will-change:transform;
}
.hero__glyph{
  font-family:var(--serif);
  font-weight:200;
  font-size:clamp(280px, 72vw, 560px);
  line-height:.85;
  color:var(--walnut);
  letter-spacing:-.02em;
  display:block;
  background:linear-gradient(180deg, var(--walnut) 0%, var(--ink) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  position:relative;z-index:2;
}
.hero__glyph-shadow{
  position:absolute;left:8px;top:8px;z-index:1;
  font-family:var(--serif);font-weight:200;
  font-size:clamp(280px, 72vw, 560px);
  line-height:.85;letter-spacing:-.02em;
  color:rgba(107,142,127,0.18);
  pointer-events:none;
  filter:blur(6px);
}
.hero__caption{
  margin-top:auto;
  padding-top:24px;
  max-width:520px;
}
.hero__cn{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(28px, 8vw, 44px);
  line-height:1.15;
  letter-spacing:-.005em;
  color:var(--ink);
}
.hero__en{
  margin-top:6px;
  font-family:var(--sans-en);
  font-size:14px;font-weight:300;
  color:var(--ink-soft);
  opacity:.75;
}
.hero__scroll{
  position:absolute;
  right:22px;bottom:22px;
  display:flex;align-items:center;gap:10px;
  color:var(--ink-soft);
}
.hero__scroll-line{
  display:block;width:40px;height:1px;background:var(--ink-soft);opacity:.5;
  animation:scrollLine 2.4s var(--ease) infinite;
}
@keyframes scrollLine{
  0%{transform:scaleX(0);transform-origin:left}
  50%{transform:scaleX(1);transform-origin:left}
  51%{transform:scaleX(1);transform-origin:right}
  100%{transform:scaleX(0);transform-origin:right}
}

/* ==========================================================================
   OPENING
   ========================================================================== */
.opening{
  position:relative;
  padding:64px 22px 80px;
  background:var(--cement);
}
.opening__card{
  position:relative;
  border-radius:18px;
  padding:32px 26px 30px;
  max-width:680px;margin:0 auto;
}
.opening__index{
  display:flex;justify-content:space-between;
  margin-bottom:24px;
  padding-bottom:14px;
  border-bottom:1px solid var(--hairline);
}
.opening__cn{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(20px, 5.4vw, 28px);
  line-height:1.55;
  color:var(--ink);
  letter-spacing:.01em;
}
.opening__cn .ji{font-weight:500;color:var(--jade);font-size:1.05em}
.opening__en{
  margin-top:20px;
  font-family:var(--sans-en);
  font-size:14px;font-weight:300;line-height:1.6;
  color:var(--ink-soft);
}
.opening__en em{color:var(--jade);font-style:italic}
.opening__rule{
  margin:24px 0 14px;
  width:36px;height:1px;background:var(--jade);
}
.opening__meta{
  display:flex;gap:10px;align-items:center;
}

/* ==========================================================================
   THE OBJECT
   ========================================================================== */
.object{
  position:relative;
  padding:80px 22px 100px;
  background:
    radial-gradient(70% 60% at 50% 40%, rgba(248,242,229,1) 0%, rgba(232,229,224,1) 80%);
}
.object__index{
  display:flex;justify-content:space-between;
  max-width:680px;margin:0 auto 36px;
  padding-bottom:14px;
  border-bottom:1px solid var(--hairline);
}
.object__stage{
  position:relative;
  display:flex;justify-content:center;align-items:center;
  height:60vw;max-height:420px;min-height:280px;
  margin:0 auto;
  max-width:520px;
}
.object__caption{
  text-align:center;
  margin-top:28px;
}
.object__caption .mono{display:block;margin-bottom:14px}
.object__line{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(22px, 5.8vw, 30px);
  line-height:1.35;
  color:var(--ink);
}
.object__line .cn{display:block}
.object__line .en{
  display:block;
  font-family:var(--sans-en);
  font-weight:300;font-size:14px;
  color:var(--ink-soft);margin-top:6px;
}

/* ==========================================================================
   BALL (CSS-rendered)
   ========================================================================== */
.ball{
  position:relative;
  border-radius:50%;
  --c1:#FFFFFF;
  --c2:#F8F2E5;
  --c3:#D9D2C2;
  --c4:#8A8275;
  background:
    radial-gradient(circle at 32% 28%, var(--c1) 0%, var(--c2) 24%, var(--c3) 68%, var(--c4) 100%);
  box-shadow:
    inset -18px -22px 44px rgba(26,24,20,0.18),
    inset 8px 10px 22px rgba(255,255,255,0.5),
    0 24px 36px -10px rgba(26,24,20,0.32),
    0 2px 4px rgba(26,24,20,0.18);
  isolation:isolate;
  transform:translateZ(0);
}
.ball--xl{width:74vw;max-width:340px;aspect-ratio:1;animation:ballFloat 7s ease-in-out infinite}
.ball--sm{width:42%;max-width:140px;aspect-ratio:1}
.ball__highlight{
  position:absolute;
  top:8%;left:18%;
  width:42%;height:30%;
  background:radial-gradient(ellipse at center, rgba(255,255,255,0.65) 0%, rgba(255,255,255,0) 70%);
  border-radius:50%;
  pointer-events:none;
  filter:blur(4px);
}
.ball__ambient{
  position:absolute;
  bottom:14%;right:18%;
  width:32%;height:22%;
  background:radial-gradient(ellipse at center, rgba(107,142,127,0.22) 0%, rgba(107,142,127,0) 70%);
  border-radius:50%;
  pointer-events:none;
  filter:blur(8px);
}
.ball__panels{position:absolute;inset:0;border-radius:50%;overflow:hidden;pointer-events:none;opacity:.18}
.ball__seam{position:absolute;background:rgba(26,24,20,1);}
.ball__seam--a{
  top:50%;left:6%;right:6%;height:1px;
  transform:translateY(-50%) rotate(-14deg);
}
.ball__seam--b{
  top:6%;bottom:6%;left:50%;width:1px;
  transform:translateX(-50%) rotate(72deg);
}
.ball__floor{
  position:absolute;
  left:-6%;right:-6%;
  bottom:-14%;
  height:14%;
  background:radial-gradient(ellipse at center, rgba(26,24,20,0.32) 0%, rgba(26,24,20,0) 70%);
  filter:blur(6px);
  z-index:-1;
}
@keyframes ballFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}

/* Colorways */
.ball--paper{--c1:#FFFFFF;--c2:#F8F2E5;--c3:#D9D2C2;--c4:#8A8275}
.ball--jade{
  --c1:#C9DCD2;--c2:#9DB7AB;--c3:#6B8E7F;--c4:#3D5448;
}
.ball--clay{
  --c1:#E5C9B2;--c2:#C9A289;--c3:#B88A6A;--c4:#6E4F38;
}
.ball--walnut{
  --c1:#A0846A;--c2:#7A5E48;--c3:#5C4533;--c4:#2E2018;
}
.ball--ink{
  --c1:#3A352E;--c2:#2A2620;--c3:#1A1814;--c4:#070605;
}

/* ==========================================================================
   ROOMS
   ========================================================================== */
.rooms{
  padding:88px 0 100px;
  background:var(--cream);
  position:relative;
}
.rooms__head{
  padding:0 22px;
  max-width:680px;margin:0 auto 28px;
}
.rooms__head .mono{display:block;margin-bottom:18px}
.rooms__title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(28px, 7vw, 40px);
  line-height:1.2;
  color:var(--ink);
}
.rooms__title .cn{display:block}
.rooms__title .en{
  display:block;margin-top:6px;
  font-family:var(--sans-en);font-size:15px;font-weight:300;
  color:var(--ink-soft);
}
.rooms__scroll{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:82%;
  gap:14px;
  padding:8px 22px 24px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.rooms__scroll::-webkit-scrollbar{display:none}

.room{
  position:relative;
  scroll-snap-align:start;
  border-radius:20px;
  padding:24px 22px 28px;
  min-height:440px;
  display:flex;flex-direction:column;
  overflow:hidden;
  isolation:isolate;
  border:1px solid var(--hairline-soft);
  box-shadow:var(--shadow-card);
  transition:transform .8s var(--ease), box-shadow .8s var(--ease);
}
.room:hover{transform:translateY(-4px)}
.room__bg{position:absolute;inset:0;z-index:-1}
.room--paper{background:var(--paper)}
.room--paper .room__bg{
  background:radial-gradient(80% 60% at 80% 20%, rgba(255,255,255,0.7) 0%, transparent 70%);
}
.room--jade{background:#E4ECE7;color:var(--ink)}
.room--jade .room__bg{
  background:radial-gradient(80% 60% at 80% 20%, rgba(107,142,127,0.25) 0%, transparent 70%);
}
.room--clay{background:#EFDECB}
.room--clay .room__bg{
  background:radial-gradient(80% 60% at 80% 20%, rgba(184,138,106,0.25) 0%, transparent 70%);
}
.room--walnut{background:#2A2018;color:var(--paper)}
.room--walnut .room__bg{
  background:radial-gradient(80% 60% at 80% 20%, rgba(122,94,72,0.45) 0%, transparent 70%);
}
.room--walnut .mono{color:rgba(248,242,229,0.6)}
.room__index{margin-bottom:24px}
.room__cn{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(56px, 16vw, 96px);
  line-height:.9;
  letter-spacing:-.02em;
}
.room__en{
  margin-top:8px;
  font-family:var(--mono);
  font-size:11px;letter-spacing:.28em;
  color:inherit;opacity:.7;
}
.room__line{
  margin-top:16px;
  font-family:var(--sans-en);font-style:italic;font-weight:300;
  font-size:17px;line-height:1.4;
  max-width:240px;
}
.room__sub{
  margin-top:6px;
  font-family:var(--sans-cn);
  font-size:13px;color:inherit;opacity:.75;
}
.room__ball{
  position:absolute;
  right:-8%;bottom:-6%;
  width:54%;
}
.room--walnut .room__ball,
.room--paper .room__ball{
  filter:drop-shadow(0 12px 18px rgba(26,24,20,0.25));
}

@media (min-width:760px){
  .rooms__scroll{
    grid-auto-columns:minmax(0, 1fr);
    grid-template-columns:repeat(4, 1fr);
    grid-auto-flow:initial;
    overflow:visible;
  }
}

/* ==========================================================================
   QUIET (Ink section)
   ========================================================================== */
.quiet{
  background:var(--ink);
  color:var(--paper);
  padding:96px 22px 104px;
  position:relative;
}
.quiet__index{
  display:flex;justify-content:space-between;
  max-width:680px;margin:0 auto 36px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(248,242,229,0.15);
}
.quiet__index .mono{color:rgba(248,242,229,0.55)}
.quiet__quote{
  max-width:680px;margin:0 auto;
  font-family:var(--serif);font-weight:300;
  font-size:clamp(40px, 12vw, 80px);
  line-height:1;
  letter-spacing:-.01em;
  display:flex;flex-direction:column;gap:14px;
  color:var(--paper);
}
.quiet__cn{display:block}
.quiet__rule{display:block;width:48px;height:1px;background:var(--jade);margin:6px 0}
.quiet__en{
  display:block;
  font-family:var(--sans-en);font-style:italic;font-weight:300;
  font-size:clamp(18px, 4.4vw, 26px);
  color:var(--jade-soft);
  letter-spacing:0;
}
.quiet__essay{
  max-width:600px;margin:48px auto 0;
}
.quiet__essay p{
  margin-top:18px;
  font-size:15px;line-height:1.65;
  color:rgba(248,242,229,0.78);
}
.quiet__essay p.cn{font-family:var(--sans-cn);font-size:16px}
.quiet__essay p.en{font-family:var(--sans-en);font-style:italic;font-weight:300;color:rgba(157,183,171,0.85)}

/* ==========================================================================
   COLOURWAYS
   ========================================================================== */
.colourways{
  padding:96px 22px 100px;
  background:var(--cement);
}
.colourways__head{
  max-width:680px;margin:0 auto 36px;
}
.colourways__head .mono{display:block;margin-bottom:18px}
.colourways__title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(26px, 6.4vw, 36px);
  line-height:1.2;
}
.colourways__title .cn{display:block}
.colourways__title .en{
  display:block;margin-top:6px;
  font-family:var(--sans-en);font-size:14px;font-weight:300;color:var(--ink-soft);
}
.colourways__grid{
  max-width:680px;margin:0 auto;
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:14px;
}
@media (min-width:560px){
  .colourways__grid{grid-template-columns:repeat(5, 1fr)}
}
.cw{
  background:var(--paper);
  border-radius:14px;
  padding:18px 16px 16px;
  border:1px solid var(--hairline-soft);
  box-shadow:var(--shadow-soft);
  display:flex;flex-direction:column;gap:12px;
  transition:transform .6s var(--ease);
}
.cw:hover{transform:translateY(-3px)}
.cw__swatch{
  width:100%;aspect-ratio:1;
  border-radius:10px;
  position:relative;
  overflow:hidden;
}
.cw__swatch:after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 60% at 30% 25%, rgba(255,255,255,0.35) 0%, transparent 70%);
}
.cw__swatch--paper{background:#F8F2E5;border:1px solid var(--hairline)}
.cw__swatch--jade{background:#6B8E7F}
.cw__swatch--clay{background:#B88A6A}
.cw__swatch--walnut{background:#5C4533}
.cw__swatch--ink{background:#1A1814}
.cw figcaption{display:flex;flex-direction:column;gap:4px}
.cw__cn{
  font-family:var(--serif);font-weight:400;
  font-size:22px;line-height:1;color:var(--ink);
}
.cw__en{
  font-family:var(--mono);font-size:10px;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-soft);
}

/* ==========================================================================
   LAB
   ========================================================================== */
.lab{
  padding:96px 22px 100px;
  background:var(--cream);
}
.lab__index{
  max-width:680px;margin:0 auto 36px;
  padding-bottom:14px;
  border-bottom:1px solid var(--hairline);
}
.lab__inner{
  max-width:680px;margin:0 auto;
  display:grid;gap:36px;
}
.lab__diagram{
  position:relative;
  display:grid;gap:18px;
}
.lab__diagram svg{
  width:80%;max-width:320px;margin:0 auto;
}
.lab__labels{
  list-style:none;
  display:grid;grid-template-columns:1fr 1fr;gap:10px 18px;
  font-size:11px;
}
.lab__labels li{
  display:flex;flex-direction:column;gap:2px;
  padding:8px 0;
  border-top:1px solid var(--hairline-soft);
}
.lab__labels .mono{color:var(--jade)}
.lab__labels .cn{font-family:var(--sans-cn);font-size:13px;color:var(--ink)}
.lab__labels .en{font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:var(--ink-soft);text-transform:uppercase}
.lab__title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(24px, 6vw, 32px);line-height:1.25;
}
.lab__title .cn{display:block}
.lab__title .en{
  display:block;margin-top:6px;
  font-family:var(--sans-en);font-style:italic;font-weight:300;
  font-size:15px;color:var(--ink-soft);
}
.lab__text p{
  margin-top:14px;
  font-size:14px;line-height:1.65;
  color:var(--ink-soft);
}
.lab__text p.cn{font-family:var(--sans-cn);font-size:15px;color:var(--ink)}
.lab__text p.en{font-family:var(--sans-en);font-style:italic}
.lab__foot{margin-top:24px !important;color:var(--jade) !important}

@media (min-width:760px){
  .lab__inner{grid-template-columns:1fr 1fr;align-items:center;gap:48px}
}

/* ==========================================================================
   SPECS
   ========================================================================== */
.specs{
  padding:96px 22px 100px;
  background:var(--cement);
}
.specs__index{
  max-width:680px;margin:0 auto 28px;
  padding-bottom:14px;
  border-bottom:1px solid var(--hairline);
}
.specs__table{
  max-width:680px;margin:0 auto;
  width:100%;
  border-collapse:collapse;
}
.specs__table tr{
  border-bottom:1px solid var(--hairline-soft);
}
.specs__table tr:last-child{border-bottom:0}
.specs__table td{
  padding:18px 0;
  vertical-align:baseline;
}
.specs__cn{
  width:28%;
  font-family:var(--serif);font-weight:400;
  font-size:17px;color:var(--ink);
}
.specs__en{
  width:24%;
  font-size:10px;letter-spacing:.2em;
  color:var(--ink-soft);
}
.specs__val{
  font-family:var(--sans-en);font-weight:400;
  font-size:14px;color:var(--ink);
  text-align:right;
}

/* ==========================================================================
   RESERVE
   ========================================================================== */
.reserve{
  position:relative;
  padding:104px 22px 110px;
  background:linear-gradient(180deg, var(--cream) 0%, var(--cement) 100%);
  overflow:hidden;
}
.reserve__bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(60% 50% at 15% 80%, rgba(107,142,127,0.18) 0%, transparent 70%),
    radial-gradient(70% 60% at 90% 10%, rgba(184,138,106,0.12) 0%, transparent 70%);
}
.reserve__index, .reserve__title, .reserve__form, .reserve__caption{position:relative;z-index:1}
.reserve__index{
  max-width:560px;margin:0 auto 28px;
  padding-bottom:14px;
  border-bottom:1px solid var(--hairline);
}
.reserve__title{
  max-width:560px;margin:0 auto 36px;
  font-family:var(--serif);font-weight:300;
  font-size:clamp(38px, 11vw, 64px);
  line-height:1;letter-spacing:-.015em;
}
.reserve__cn{display:block;color:var(--ink)}
.reserve__en{
  display:block;margin-top:14px;
  font-family:var(--sans-en);font-style:italic;font-weight:300;
  font-size:clamp(18px, 4.6vw, 26px);
  color:var(--jade);
}
.reserve__form{
  max-width:560px;margin:0 auto;
  border-radius:16px;
  padding:22px 20px 20px;
  position:relative;
}
.reserve__label{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:12px;
}
.reserve__label .cn{font-family:var(--serif);font-weight:400;font-size:14px;color:var(--ink)}
.reserve__row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:stretch;
}
.reserve__row input{
  font:inherit;font-family:var(--sans-en);font-size:15px;
  padding:13px 14px;
  border-radius:10px;
  border:1px solid var(--hairline);
  background:rgba(255,255,255,0.7);
  color:var(--ink);
  outline:none;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.reserve__row input:focus{
  border-color:var(--jade);
  background:#fff;
}
.reserve__row button{
  padding:13px 18px;
  border-radius:10px;
  background:var(--ink);
  color:var(--paper);
  display:inline-flex;align-items:center;gap:8px;
  transition:background .3s var(--ease), transform .3s var(--ease);
}
.reserve__row button:hover{background:var(--walnut);transform:translateY(-1px)}
.reserve__row button .cn{font-family:var(--sans-cn);font-size:13px}
.reserve__row button .en{font-family:var(--mono);font-size:10px;letter-spacing:.2em}
.reserve__sent{
  margin-top:14px;
  color:var(--jade);
  opacity:0;transform:translateY(4px);
  transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.reserve__form.is-sent .reserve__sent{opacity:1;transform:none}
.reserve__form.is-sent input,
.reserve__form.is-sent button{opacity:.55;pointer-events:none}
.reserve__caption{
  max-width:560px;margin:20px auto 0;
  text-align:center;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.foot{
  background:var(--ink);
  color:var(--paper);
  padding:36px 22px 40px;
}
.foot__row{
  max-width:680px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:baseline;
  flex-wrap:wrap;gap:8px;
}
.foot__row + .foot__row{margin-top:18px;padding-top:16px;border-top:1px solid rgba(248,242,229,0.12)}
.foot__brand{
  font-family:var(--sans-en);font-weight:500;
  font-size:14px;letter-spacing:.18em;
}
.foot__brand .ji{font-family:var(--serif);font-weight:300;font-size:18px}
.foot__row--small .mono{color:rgba(248,242,229,0.45)}

/* ==========================================================================
   REDUCED MOTION
   ========================================================================== */
@media (prefers-reduced-motion: reduce){
  *,*:before,*:after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .hero__glyph-wrap{transform:none !important}
}
