/* ============================================================
   NOTTE — Cucina Italiana, Tokyo
   Shared stylesheet. Dark, editorial, video-forward.
   Variation axes (set on <html>):
     data-accent = gold | terracotta | sage | ivory
     data-hero   = center | left | split        (home hero only)
     data-type   = editorial | modern | mincho
     data-motion = subtle | cinematic
   ============================================================ */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Jost:wght@300;400;500&family=Shippori+Mincho:wght@500;600;700&family=Zen+Kaku+Gothic+New:wght@400;500;700&display=swap');

/* ---------- Tokens ---------- */
:root{
  --ink:        #0c0a08;
  --ink-1:      #110e0b;
  --ink-2:      #17130f;
  --ink-3:      #201a14;
  --paper:      #f3ebdd;
  --paper-2:    #e7dcc9;
  --dim:        rgba(243,235,221,.62);
  --faint:      rgba(243,235,221,.40);
  --line:       rgba(243,235,221,.14);
  --line-2:     rgba(243,235,221,.08);

  /* accent (overridden per data-accent) */
  --accent:     #c2a161;
  --accent-2:   #d8bd83;
  --accent-ink: #0c0a08;

  --font-disp:    "Cormorant Garamond", "Shippori Mincho", serif;
  --font-disp-jp: "Shippori Mincho", serif;
  --font-ui:      "Jost", "Zen Kaku Gothic New", sans-serif;
  --font-body-jp: "Zen Kaku Gothic New", sans-serif;

  --disp-case: none;
  --disp-spacing: 0;

  --ease: cubic-bezier(.22,.61,.36,1);
  --rt: .9s;            /* reveal time */
  --maxw: 1320px;
}

html[data-accent="terracotta"]{ --accent:#c2693f; --accent-2:#dd8a5d; }
html[data-accent="sage"]{       --accent:#9cab78; --accent-2:#bcc79a; }
html[data-accent="ivory"]{      --accent:#e3d6bd; --accent-2:#f1e8d6; --accent-ink:#1a150f; }

html[data-type="modern"]{
  --font-disp: "Jost", "Zen Kaku Gothic New", sans-serif;
  --font-disp-jp: "Zen Kaku Gothic New", sans-serif;
  --disp-case: uppercase;
  --disp-spacing: .04em;
}
html[data-type="mincho"]{
  --font-disp: "Shippori Mincho", serif;
  --font-disp-jp: "Shippori Mincho", serif;
}
html[data-motion="cinematic"]{ --rt: 1.3s; }

/* ---------- Reset / base ---------- */
*{ margin:0; padding:0; box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--font-body-jp);
  font-weight:400;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--accent); color:var(--accent-ink); }

/* subtle film grain over everything */
body::after{
  content:""; position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,64px); }
.section{ position:relative; padding-block:clamp(80px,12vw,168px); }
.section--tight{ padding-block:clamp(56px,8vw,104px); }

/* ---------- Type helpers ---------- */
.eyebrow{
  font-family:var(--font-ui); font-weight:400; text-transform:uppercase;
  letter-spacing:.34em; font-size:clamp(10px,.78vw,12px); color:var(--accent);
  display:inline-flex; align-items:center; gap:.85em;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--accent); opacity:.8; }
.eyebrow--center::after{ content:""; width:26px; height:1px; background:var(--accent); opacity:.8; }
.eyebrow--center{ justify-content:center; }

.display{
  font-family:var(--font-disp); font-weight:500; line-height:1.02;
  letter-spacing:var(--disp-spacing); text-transform:var(--disp-case);
  font-size:clamp(2.6rem,7vw,6.4rem); text-wrap:balance;
}
.display--jp{ font-family:var(--font-disp-jp); font-weight:600; line-height:1.3; letter-spacing:.04em; text-transform:none; }
.display em{ font-style:italic; color:var(--accent-2); }

.h2{
  font-family:var(--font-disp); font-weight:500; line-height:1.06;
  letter-spacing:var(--disp-spacing); text-transform:var(--disp-case);
  font-size:clamp(2rem,4.6vw,3.9rem); text-wrap:balance;
}
.h2-jp{ font-family:var(--font-disp-jp); font-weight:600; font-size:clamp(1.05rem,2vw,1.5rem); letter-spacing:.06em; line-height:1.5; }
.lede{ font-size:clamp(1rem,1.3vw,1.18rem); color:var(--dim); line-height:2; font-weight:400; max-width:46ch; }
.small{ font-family:var(--font-ui); font-size:13px; letter-spacing:.04em; color:var(--dim); }
.kicker-num{ font-family:var(--font-ui); font-size:12px; letter-spacing:.2em; color:var(--faint); }

/* ---------- Buttons ---------- */
.btn{
  --pad:1.05em 2.1em;
  font-family:var(--font-ui); font-size:13px; letter-spacing:.22em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:.9em; padding:var(--pad);
  border:1px solid var(--accent); color:var(--accent); background:transparent;
  cursor:pointer; position:relative; overflow:hidden; transition:color .5s var(--ease);
  border-radius:0;
}
.btn span{ position:relative; z-index:1; }
.btn::before{
  content:""; position:absolute; inset:0; background:var(--accent);
  transform:translateY(101%); transition:transform .5s var(--ease); z-index:0;
}
.btn:hover{ color:var(--accent-ink); }
.btn:hover::before{ transform:translateY(0); }
.btn--solid{ background:var(--accent); color:var(--accent-ink); }
.btn--solid::before{ background:var(--paper); }
.btn--solid:hover{ color:var(--ink); }
.btn--ghost{ border-color:var(--line); color:var(--paper); }
.btn--ghost::before{ background:var(--paper); }
.btn--ghost:hover{ color:var(--ink); border-color:var(--paper); }
.btn__arrow{ font-size:1.1em; line-height:0; }

/* link with animated underline */
.ulink{ font-family:var(--font-ui); font-size:13px; letter-spacing:.2em; text-transform:uppercase; color:var(--paper);
  display:inline-flex; align-items:center; gap:.7em; padding-bottom:.35em; position:relative; }
.ulink::after{ content:""; position:absolute; left:0; bottom:0; width:100%; height:1px; background:var(--accent);
  transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.ulink:hover::after{ transform:scaleX(1); }
.ulink .a{ color:var(--accent); transition:transform .45s var(--ease); }
.ulink:hover .a{ transform:translateX(5px); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:clamp(18px,2.4vw,30px) clamp(20px,5vw,64px);
  transition:background .6s var(--ease), padding .6s var(--ease), border-color .6s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:color-mix(in srgb, var(--ink) 86%, transparent);
  backdrop-filter:blur(14px) saturate(1.2);
  padding-block:clamp(12px,1.5vw,18px);
  border-bottom:1px solid var(--line-2);
}
.brand{ font-family:var(--font-disp); font-weight:600; font-size:clamp(1.35rem,2vw,1.7rem);
  letter-spacing:.28em; text-transform:uppercase; padding-left:.28em; }
html[data-type="modern"] .brand{ letter-spacing:.4em; }
.brand .dot{ color:var(--accent); }
.nav-links{ display:flex; align-items:center; gap:clamp(20px,2.4vw,40px); }
.nav-links a{ font-family:var(--font-ui); font-size:12.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--dim);
  transition:color .4s var(--ease); position:relative; }
.nav-links a .jp{ display:block; font-family:var(--font-body-jp); font-size:9.5px; letter-spacing:.18em; color:var(--faint); margin-top:3px; text-align:center; }
.nav-links a:hover{ color:var(--paper); }
.nav-links a.active{ color:var(--accent); }
.nav-cta{ display:flex; align-items:center; gap:18px; }
.nav-burger{ display:none; flex-direction:column; gap:5px; width:30px; cursor:pointer; background:none; border:none; }
.nav-burger span{ height:1px; background:var(--paper); width:100%; transition:.4s var(--ease); }

/* mobile drawer */
.drawer{ position:fixed; inset:0; z-index:199; background:var(--ink-1);
  display:flex; flex-direction:column; justify-content:center; align-items:center; gap:26px;
  opacity:0; visibility:hidden; transition:opacity .5s var(--ease), visibility .5s; }
.drawer.open{ opacity:1; visibility:visible; }
.drawer a{ font-family:var(--font-disp); font-size:2.2rem; letter-spacing:.06em; text-transform:var(--disp-case); }
.drawer a .jp{ display:block; font-family:var(--font-body-jp); font-size:.8rem; color:var(--faint); text-align:center; letter-spacing:.2em; margin-top:4px; }

/* ============================================================
   HERO  (home)
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media video, .hero__media img{ width:100%; height:100%; object-fit:cover; }
.hero__media::after{ content:""; position:absolute; inset:0;
  background:
    linear-gradient(to top, var(--ink) 2%, transparent 42%),
    linear-gradient(to right, rgba(8,6,4,.66), rgba(8,6,4,.18) 60%, rgba(8,6,4,.42)),
    radial-gradient(120% 90% at 50% 30%, transparent 40%, rgba(8,6,4,.5)); }
.hero__inner{ position:relative; z-index:2; width:100%; max-width:var(--maxw); margin-inline:auto;
  padding-inline:clamp(20px,5vw,64px); display:flex; flex-direction:column; }

/* layout: center (default) */
.hero{ align-items:center; }
.hero__inner{ align-items:center; text-align:center; padding-top:14vh; padding-bottom:16vh; gap:30px; }
.hero__wordmark{ font-family:var(--font-disp); font-weight:500; line-height:.92;
  font-size:clamp(4rem,17vw,15rem); letter-spacing:var(--disp-spacing); text-transform:var(--disp-case); }
.hero__wordmark .dot{ color:var(--accent); }
.hero__tagline{ font-family:var(--font-disp-jp); font-weight:600; font-size:clamp(1.1rem,2.3vw,1.7rem); letter-spacing:.2em; }
.hero__sub{ font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.42em; font-size:clamp(10px,1vw,13px); color:var(--dim); }
.hero__actions{ display:flex; gap:18px; flex-wrap:wrap; justify-content:center; margin-top:8px; }

/* layout: left */
html[data-hero="left"] .hero{ align-items:flex-end; }
html[data-hero="left"] .hero__inner{ align-items:flex-start; text-align:left; padding-bottom:11vh; padding-top:0; max-width:var(--maxw); }
html[data-hero="left"] .hero__wordmark{ font-size:clamp(3.4rem,13vw,11rem); }
html[data-hero="left"] .hero__actions{ justify-content:flex-start; }
html[data-hero="left"] .hero__media::after{
  background:linear-gradient(to top, var(--ink) 4%, transparent 50%),
    linear-gradient(60deg, rgba(8,6,4,.7), rgba(8,6,4,.05) 55%); }

/* layout: split */
html[data-hero="split"] .hero{ align-items:stretch; }
html[data-hero="split"] .hero__media{ left:auto; width:48vw; }
html[data-hero="split"] .hero__media::after{ background:linear-gradient(to right, var(--ink), transparent 22%), linear-gradient(to top, var(--ink) 3%, transparent 30%); }
html[data-hero="split"] .hero__inner{ align-items:flex-start; text-align:left; justify-content:center; max-width:var(--maxw); padding-block:18vh; }
html[data-hero="split"] .hero__copy-wrap{ max-width:46%; }
@media(max-width:880px){
  html[data-hero="split"] .hero__media{ width:100%; }
  html[data-hero="split"] .hero__inner{ align-items:center; text-align:center; }
  html[data-hero="split"] .hero__copy-wrap{ max-width:100%; }
}

.hero__copy-wrap{ display:flex; flex-direction:column; gap:26px; align-items:inherit; }

/* scroll cue */
.scroll-cue{ position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:3;
  display:flex; flex-direction:column; align-items:center; gap:12px; color:var(--faint);
  font-family:var(--font-ui); font-size:10px; letter-spacing:.3em; text-transform:uppercase; }
.scroll-cue .bar{ width:1px; height:54px; background:linear-gradient(var(--accent),transparent); position:relative; overflow:hidden; }
.scroll-cue .bar::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background:var(--paper); animation:cue 2.4s var(--ease) infinite; }
@keyframes cue{ 0%{ transform:translateY(-100%);} 60%,100%{ transform:translateY(300%);} }

/* ============================================================
   CONCEPT
   ============================================================ */
.concept{ background:var(--ink-1); }
.concept__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,96px); align-items:center; }
.concept__media{ position:relative; aspect-ratio:3/4; overflow:hidden; }
.concept__media video,.concept__media img{ width:100%; height:100%; object-fit:cover; }
.concept__media::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 1px var(--line); }
.concept__tag{ position:absolute; left:18px; bottom:18px; z-index:2; font-family:var(--font-ui);
  font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--paper);
  background:color-mix(in srgb, var(--ink) 50%, transparent); backdrop-filter:blur(6px);
  padding:8px 14px; border:1px solid var(--line); display:flex; align-items:center; gap:8px; }
.concept__tag .live{ width:7px; height:7px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 0 var(--accent); animation:pulse 2.2s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 70%,transparent);} 70%{ box-shadow:0 0 0 9px transparent;} 100%{ box-shadow:0 0 0 0 transparent;} }
.concept__body{ display:flex; flex-direction:column; gap:26px; }
.concept__quote{ font-family:var(--font-disp); font-style:italic; font-weight:400;
  font-size:clamp(1.5rem,3vw,2.4rem); line-height:1.4; color:var(--paper); }
.stat-row{ display:flex; gap:clamp(24px,4vw,56px); margin-top:8px; flex-wrap:wrap; }
.stat{ display:flex; flex-direction:column; gap:4px; }
.stat b{ font-family:var(--font-disp); font-weight:500; font-size:clamp(1.8rem,3vw,2.6rem); color:var(--accent-2); line-height:1; }
.stat span{ font-family:var(--font-ui); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); }

/* ============================================================
   SECTION HEADER
   ============================================================ */
.shead{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:clamp(38px,5vw,68px); flex-wrap:wrap; }
.shead__left{ display:flex; flex-direction:column; gap:16px; }
.shead__title{ display:flex; flex-direction:column; gap:6px; }

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(10px,1.2vw,18px); grid-auto-flow:dense; }
.tile{ position:relative; overflow:hidden; background:var(--ink-2); }
.tile img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease), filter 1.1s var(--ease); filter:saturate(.92) brightness(.92); }
.tile::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(8,6,4,.6), transparent 55%); opacity:.5; transition:opacity .6s; }
.tile:hover img{ transform:scale(1.06); filter:saturate(1.05) brightness(1); }
.tile:hover::after{ opacity:.85; }
.tile__cap{ position:absolute; left:16px; bottom:14px; z-index:2; opacity:0; transform:translateY(8px); transition:.6s var(--ease); }
.tile:hover .tile__cap{ opacity:1; transform:none; }
.tile__cap b{ font-family:var(--font-disp); font-style:italic; font-weight:500; font-size:1.25rem; display:block; }
.tile__cap span{ font-family:var(--font-ui); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--dim); }
.tile--tall{ grid-column:span 4; aspect-ratio:3/4.1; }
.tile--wide{ grid-column:span 8; aspect-ratio:16/9.4; }
.tile--sq{ grid-column:span 4; aspect-ratio:1/1; }
.tile--half{ grid-column:span 6; aspect-ratio:4/3; }
@media(max-width:880px){
  .tile--tall,.tile--wide,.tile--sq,.tile--half{ grid-column:span 6; aspect-ratio:4/3.4; }
}
@media(max-width:560px){ .tile--tall,.tile--wide,.tile--sq,.tile--half{ grid-column:span 12; } }

/* ============================================================
   MENU PREVIEW (signature dishes)
   ============================================================ */
.dishes{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,30px); }
.dish{ position:relative; }
.dish__img{ aspect-ratio:4/5; overflow:hidden; margin-bottom:20px; background:var(--ink-2); }
.dish__img img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); filter:saturate(.95); }
.dish:hover .dish__img img{ transform:scale(1.05); }
.dish__head{ display:flex; justify-content:space-between; align-items:baseline; gap:14px; border-top:1px solid var(--line); padding-top:16px; }
.dish__name{ font-family:var(--font-disp); font-size:1.5rem; font-weight:500; font-style:italic; }
.dish__price{ font-family:var(--font-ui); font-size:13px; letter-spacing:.1em; color:var(--accent-2); white-space:nowrap; }
.dish__jp{ font-family:var(--font-body-jp); font-size:13px; color:var(--dim); margin-top:6px; line-height:1.7; }
@media(max-width:780px){ .dishes{ grid-template-columns:1fr; max-width:440px; margin-inline:auto; } }

/* ============================================================
   CHEF
   ============================================================ */
.chef{ background:var(--ink-1); }
.chef__grid{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(36px,6vw,90px); align-items:center; }
.chef__media{ position:relative; aspect-ratio:4/5; overflow:hidden; }
.chef__media img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.25) contrast(1.03); }
.chef__media::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 1px var(--line); }
.chef__sign{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:2.2rem; color:var(--accent-2); }
.chef__name{ display:flex; align-items:baseline; gap:14px; flex-wrap:wrap; }
.chef__name b{ font-family:var(--font-disp); font-weight:500; font-size:clamp(1.6rem,2.6vw,2.3rem); }
.chef__name span{ font-family:var(--font-body-jp); font-size:14px; color:var(--dim); letter-spacing:.1em; }
@media(max-width:820px){ .chef__grid,.concept__grid{ grid-template-columns:1fr; } .concept__media,.chef__media{ aspect-ratio:4/3; max-height:62vh; } }

/* ============================================================
   NEWS
   ============================================================ */
.news{ display:flex; flex-direction:column; }
.news__item{ display:grid; grid-template-columns:160px 1fr auto; gap:clamp(18px,3vw,48px); align-items:center;
  padding:clamp(22px,2.6vw,34px) 0; border-top:1px solid var(--line); transition:padding-left .5s var(--ease); }
.news__item:last-child{ border-bottom:1px solid var(--line); }
.news__item:hover{ padding-left:14px; }
.news__meta{ display:flex; flex-direction:column; gap:6px; }
.news__date{ font-family:var(--font-disp); font-size:1.3rem; font-style:italic; color:var(--accent-2); }
.news__cat{ font-family:var(--font-ui); font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--faint); }
.news__title{ font-family:var(--font-disp-jp); font-weight:600; font-size:clamp(1.05rem,1.6vw,1.35rem); }
.news__title .en{ display:block; font-family:var(--font-ui); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); margin-top:6px; font-weight:400; }
.news__go{ color:var(--accent); font-size:1.4rem; opacity:0; transform:translateX(-8px); transition:.5s var(--ease); }
.news__item:hover .news__go{ opacity:1; transform:none; }
@media(max-width:680px){ .news__item{ grid-template-columns:1fr; gap:10px; } .news__go{ display:none; } }

/* ============================================================
   INSTAGRAM
   ============================================================ */
.ig__grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:clamp(8px,1vw,14px); }
.ig__cell{ position:relative; aspect-ratio:1/1; overflow:hidden; }
.ig__cell img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); filter:saturate(.95); }
.ig__cell:hover img{ transform:scale(1.07); }
.ig__cell::after{ content:"◎"; position:absolute; inset:0; display:grid; place-items:center; color:var(--paper);
  background:color-mix(in srgb,var(--ink) 40%,transparent); opacity:0; transition:.45s; font-size:1.3rem; }
.ig__cell:hover::after{ opacity:1; }
@media(max-width:880px){ .ig__grid{ grid-template-columns:repeat(3,1fr); } }

/* ============================================================
   RESERVE CTA band
   ============================================================ */
.cta{ position:relative; overflow:hidden; }
.cta__media{ position:absolute; inset:0; z-index:0; }
.cta__media img{ width:100%; height:100%; object-fit:cover; filter:brightness(.4) saturate(.8); }
.cta__media::after{ content:""; position:absolute; inset:0; background:radial-gradient(80% 120% at 50% 50%, transparent, var(--ink) 92%); }
.cta__inner{ position:relative; z-index:2; text-align:center; display:flex; flex-direction:column; align-items:center; gap:30px; }
.cta__title{ font-family:var(--font-disp); font-weight:500; font-style:italic; font-size:clamp(2.4rem,6vw,5rem); line-height:1.05; }
.cta__row{ display:flex; gap:18px; flex-wrap:wrap; justify-content:center; }
.cta__phone{ font-family:var(--font-disp); font-size:clamp(1.6rem,3vw,2.4rem); letter-spacing:.05em; color:var(--paper); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink-1); border-top:1px solid var(--line); padding-top:clamp(60px,8vw,110px); }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:clamp(30px,5vw,70px); padding-bottom:clamp(48px,6vw,80px); }
.footer__brand{ font-family:var(--font-disp); font-weight:600; font-size:2.6rem; letter-spacing:.24em; text-transform:uppercase; }
.footer__brand .dot{ color:var(--accent); }
.footer__col h4{ font-family:var(--font-ui); font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--faint); margin-bottom:18px; }
.footer__col p,.footer__col a{ display:block; color:var(--dim); font-size:14px; line-height:2; }
.footer__col a:hover{ color:var(--accent); }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; padding:26px 0; border-top:1px solid var(--line-2); font-family:var(--font-ui); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); flex-wrap:wrap; gap:12px; }
@media(max-width:780px){ .footer__top{ grid-template-columns:1fr; gap:30px; } }

/* ============================================================
   SUBPAGE HERO (menu / story / access)
   ============================================================ */
.phero{ position:relative; min-height:62svh; display:flex; align-items:flex-end; overflow:hidden; }
.phero__media{ position:absolute; inset:0; z-index:0; }
.phero__media img{ width:100%; height:100%; object-fit:cover; filter:brightness(.6) saturate(.9); }
.phero__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, var(--ink), transparent 60%); }
.phero__inner{ position:relative; z-index:2; padding-bottom:clamp(36px,6vw,72px); display:flex; flex-direction:column; gap:16px; }
.phero__title{ font-family:var(--font-disp); font-weight:500; font-size:clamp(3rem,9vw,7rem); line-height:1; letter-spacing:var(--disp-spacing); text-transform:var(--disp-case); }
.phero__jp{ font-family:var(--font-disp-jp); font-weight:600; letter-spacing:.2em; font-size:clamp(1rem,2vw,1.4rem); color:var(--dim); }

/* breadcrumb */
.crumb{ font-family:var(--font-ui); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--faint); display:flex; gap:10px; align-items:center; }
.crumb a:hover{ color:var(--accent); }

/* ============================================================
   MENU PAGE
   ============================================================ */
.menu-wrap{ display:grid; grid-template-columns:1fr; gap:clamp(56px,8vw,104px); }
.mcourse__head{ display:flex; align-items:baseline; gap:18px; margin-bottom:34px; border-bottom:1px solid var(--line); padding-bottom:18px; }
.mcourse__num{ font-family:var(--font-ui); font-size:12px; letter-spacing:.2em; color:var(--accent); }
.mcourse__title{ font-family:var(--font-disp); font-weight:500; font-style:italic; font-size:clamp(1.8rem,3.4vw,2.8rem); }
.mcourse__jp{ font-family:var(--font-body-jp); font-size:13px; color:var(--dim); letter-spacing:.1em; }
.mrow{ display:grid; grid-template-columns:1fr auto; gap:16px 30px; padding:18px 0; border-bottom:1px solid var(--line-2); align-items:baseline; }
.mrow__main{ display:flex; flex-direction:column; gap:7px; }
.mrow__name{ font-family:var(--font-disp); font-weight:500; font-size:1.45rem; }
.mrow__name .jp{ font-family:var(--font-body-jp); font-weight:500; font-size:.92rem; color:var(--paper); margin-left:12px; letter-spacing:.04em; }
.mrow__desc{ color:var(--dim); font-size:13.5px; line-height:1.7; max-width:60ch; }
.mrow__price{ font-family:var(--font-disp); font-size:1.4rem; color:var(--accent-2); white-space:nowrap; }
.mrow__price small{ font-family:var(--font-ui); font-size:11px; letter-spacing:.05em; }
.tag-new{ font-family:var(--font-ui); font-size:9px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent-ink); background:var(--accent); padding:2px 7px; margin-left:10px; vertical-align:middle; }

/* course menu callout */
.callout{ border:1px solid var(--line); padding:clamp(28px,4vw,52px); display:grid; grid-template-columns:1fr auto; gap:30px; align-items:center; background:var(--ink-1); }
.callout__price{ text-align:right; }
.callout__price b{ font-family:var(--font-disp); font-size:clamp(2.4rem,5vw,3.6rem); color:var(--accent-2); display:block; line-height:1; }
@media(max-width:680px){ .callout{ grid-template-columns:1fr; } .callout__price{ text-align:left; } .mrow{ grid-template-columns:1fr; } }

/* ============================================================
   STORY PAGE
   ============================================================ */
.story-block{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,90px); align-items:center; }
.story-block--rev .story-block__media{ order:2; }
.story-block__media{ position:relative; aspect-ratio:4/5; overflow:hidden; }
.story-block__media img{ width:100%; height:100%; object-fit:cover; }
.story-block__media::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 1px var(--line); }
.story-block__body{ display:flex; flex-direction:column; gap:22px; }
.bignum{ font-family:var(--font-disp); font-size:clamp(3rem,6vw,5rem); font-style:italic; color:var(--ink-3); -webkit-text-stroke:1px var(--accent); line-height:1; }
@media(max-width:820px){ .story-block{ grid-template-columns:1fr; } .story-block--rev .story-block__media{ order:0; } }

.pullquote{ text-align:center; max-width:24ch; margin-inline:auto; font-family:var(--font-disp); font-style:italic; font-weight:400; font-size:clamp(2rem,5vw,3.6rem); line-height:1.3; text-wrap:balance; }
.pullquote .accent{ color:var(--accent-2); }

/* ============================================================
   ACCESS PAGE
   ============================================================ */
.access-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); }
.info-list{ display:flex; flex-direction:column; }
.info-row{ display:grid; grid-template-columns:130px 1fr; gap:24px; padding:22px 0; border-top:1px solid var(--line); }
.info-row:last-child{ border-bottom:1px solid var(--line); }
.info-row dt{ font-family:var(--font-ui); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--accent); padding-top:4px; }
.info-row dd{ line-height:1.9; }
.info-row dd .en{ color:var(--faint); font-size:13px; }
.map{ position:relative; min-height:340px; overflow:hidden; border:1px solid var(--line); background:
  repeating-linear-gradient(0deg, transparent, transparent 38px, var(--line-2) 38px, var(--line-2) 39px),
  repeating-linear-gradient(90deg, transparent, transparent 38px, var(--line-2) 38px, var(--line-2) 39px), var(--ink-2); }
.map__pin{ position:absolute; top:50%; left:50%; transform:translate(-50%,-100%); display:flex; flex-direction:column; align-items:center; gap:8px; }
.map__pin .dot{ width:16px; height:16px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 6px color-mix(in srgb,var(--accent) 22%,transparent), 0 0 30px var(--accent); }
.map__pin b{ font-family:var(--font-disp); font-style:italic; font-size:1.3rem; }
.map__road{ position:absolute; background:var(--line); }
.map__label{ position:absolute; font-family:var(--font-ui); font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--faint); }

/* reservation form */
.resv{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.resv .full{ grid-column:1/-1; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-family:var(--font-ui); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--dim); }
.field input,.field select,.field textarea{ background:var(--ink-2); border:1px solid var(--line); color:var(--paper);
  padding:14px 16px; font-family:var(--font-body-jp); font-size:15px; border-radius:0; transition:border-color .4s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--accent); }
.field select{ appearance:none; background-image:linear-gradient(45deg,transparent 50%,var(--accent) 50%),linear-gradient(135deg,var(--accent) 50%,transparent 50%); background-position:calc(100% - 20px) center,calc(100% - 14px) center; background-size:6px 6px; background-repeat:no-repeat; }
@media(max-width:780px){ .access-grid,.resv{ grid-template-columns:1fr; } }

/* ============================================================
   REVEAL animation
   ============================================================ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity var(--rt) var(--ease), transform var(--rt) var(--ease); will-change:opacity,transform; }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.09s; }
.reveal[data-d="2"]{ transition-delay:.18s; }
.reveal[data-d="3"]{ transition-delay:.27s; }
.reveal[data-d="4"]{ transition-delay:.36s; }
html[data-motion="cinematic"] .reveal{ transform:translateY(60px) scale(.985); }
html[data-motion="cinematic"] .clip{ clip-path:inset(0 0 100% 0); transition:clip-path 1.3s var(--ease); }
html[data-motion="cinematic"] .clip.in{ clip-path:inset(0 0 0 0); }

@media(prefers-reduced-motion:reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
  .scroll-cue .bar::after{ animation:none; }
}

/* ---------- responsive nav ---------- */
@media(max-width:920px){
  .nav-links{ display:none; }
  .nav-burger{ display:flex; }
}
