/* ============================================================
   ОСТАННЯ БАРИКАДА — Last Barricade
   Editorial restaurant site · dark, warm, revolutionary
   ============================================================ */

:root{
  --ink:        #0e0d0c;   /* near-black graphite        */
  --ink-2:      #16140f;   /* raised panel               */
  --ink-3:      #1f1c16;   /* card                        */
  --paper:      #f3ece0;   /* warm off-white text         */
  --paper-dim:  #c9bfae;   /* dimmed warm paper           */
  --muted:      #a59c8c;   /* muted warm grey             */
  --line:       rgba(243,236,224,.14);
  --poppy:      #b4231f;   /* embroidered-poppy red       */
  --poppy-2:    #d24a3a;
  --gold:       #c9a25a;   /* muted brass                 */
  --gold-soft:  #e3c98f;
  --stencil:    #5d6b80;   /* the bluish ОБ wall          */

  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Manrope", system-ui, -apple-system, sans-serif;
  --stencilf: "Oswald", "Manrope", sans-serif;

  --maxw: 1280px;
  --pad: clamp(20px, 5vw, 80px);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } *{ animation:none!important; transition:none!important; } }

body{
  font-family:var(--sans);
  background:var(--ink);
  color:var(--paper);
  line-height:1.6;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--poppy); color:#fff; }

/* ---------- Reusable section bits ---------- */
.sec__kicker{
  font-family:var(--stencilf);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  font-weight:600;
  color:var(--gold);
  margin-bottom:1.1rem;
}
.sec__title{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2rem, 4.6vw, 3.7rem);
  line-height:1.05;
  letter-spacing:-.01em;
  max-width:16ch;
}
.sec__title--c{ margin-inline:auto; text-align:center; max-width:20ch; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--stencilf);
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:.78rem;
  font-weight:500;
  padding:.95em 1.7em;
  border-radius:2px;
  cursor:pointer;
  border:1px solid transparent;
  transition:all .35s var(--ease);
  white-space:nowrap;
}
.btn--solid{ background:var(--poppy); color:#fff; }
.btn--solid:hover{ background:var(--poppy-2); transform:translateY(-2px); box-shadow:0 12px 30px -12px var(--poppy); }
.btn--line{ border-color:var(--line); color:var(--paper); }
.btn--line:hover{ border-color:var(--gold); color:var(--gold-soft); }
.btn--ghost{ border-color:var(--line); color:var(--paper); background:transparent; }
.btn--ghost:hover{ border-color:var(--gold); color:var(--gold-soft); }

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{
  position:fixed; inset:0; z-index:1000;
  background:var(--ink);
  display:grid; place-items:center;
  transition:opacity .8s var(--ease), visibility .8s;
}
.preloader.is-done{ opacity:0; visibility:hidden; }
.preloader__inner{ text-align:center; padding:0 24px; }
.preloader__mark{
  width:clamp(96px,22vw,132px); height:auto; display:block; margin:0 auto;
  animation:markpulse 2.2s ease-in-out infinite;
}
@keyframes markpulse{ 0%,100%{ opacity:.45; transform:scale(.97);} 50%{ opacity:1; transform:scale(1);} }
.preloader__word{
  display:block; margin-top:1rem;
  font-family:var(--serif); font-style:italic;
  font-size:clamp(1rem,3vw,1.3rem);
  color:var(--muted); letter-spacing:.04em;
}
.preloader__bar{
  margin:1.6rem auto 0; width:min(220px,60vw); height:1px;
  background:var(--line); overflow:hidden;
}
.preloader__bar i{
  display:block; height:100%; width:40%;
  background:var(--gold);
  animation:load 1.4s var(--ease) infinite;
}
@keyframes load{ 0%{transform:translateX(-110%);} 100%{transform:translateX(360%);} }

/* ============================================================
   GRAIN + global texture
   ============================================================ */
.grain{
  position:fixed; inset:-50%; z-index:1; 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='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 8s steps(6) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)} 20%{transform:translate(-4%,3%)}
  40%{transform:translate(3%,-5%)} 60%{transform:translate(-3%,2%)} 80%{transform:translate(4%,4%)}
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
  padding:18px var(--pad);
  transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(14,13,12,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  padding-top:12px; padding-bottom:12px;
  border-bottom-color:var(--line);
}
.nav__brand{ display:flex; align-items:center; gap:13px; }
.nav__mark{ height:42px; width:auto; flex:none; object-fit:contain; display:block; }
.nav__name{ display:flex; flex-direction:column; line-height:1.1; }
.nav__name b{ font-family:var(--serif); font-weight:600; font-size:1.12rem; letter-spacing:.01em; }
.nav__name i{ font-style:normal; font-size:.62rem; letter-spacing:.24em; text-transform:uppercase; color:var(--muted); }

.nav__links{ display:flex; gap:30px; margin-left:auto; }
.nav__links a{
  position:relative; font-size:.82rem; letter-spacing:.05em;
  color:var(--paper-dim); padding:4px 0; transition:color .3s;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0;
  background:var(--gold); transition:width .35s var(--ease);
}
.nav__links a:hover, .nav__links a.is-active{ color:var(--paper); }
.nav__links a.is-active::after{ width:100%; }

.nav__actions{ display:flex; align-items:center; gap:16px; }
.lang{
  background:none; border:none; cursor:pointer; color:var(--muted);
  font-family:var(--stencilf); font-size:.78rem; letter-spacing:.1em;
  display:flex; gap:3px; align-items:center;
}
.lang .is-active{ color:var(--gold-soft); }
.lang__sep{ opacity:.4; }
.burger{ display:none; background:none; border:none; cursor:pointer; width:30px; height:22px; position:relative; }
.burger span{ position:absolute; left:0; right:0; height:1.5px; background:var(--paper); transition:.35s var(--ease); }
.burger span:nth-child(1){ top:2px; } .burger span:nth-child(2){ top:10px; } .burger span:nth-child(3){ top:18px; }
body.menu-open .burger span:nth-child(1){ top:10px; transform:rotate(45deg); }
body.menu-open .burger span:nth-child(2){ opacity:0; }
body.menu-open .burger span:nth-child(3){ top:10px; transform:rotate(-45deg); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:0 var(--pad) clamp(28px,5vh,56px);
  overflow:hidden;
}
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__img{
  width:100%; height:100%; object-fit:cover; object-position:center 38%;
  transform:scale(1.08); transition:transform 1.2s var(--ease);
  filter:saturate(.92) contrast(1.02) brightness(.62);
  will-change:transform;
}
.is-loaded .hero__img{ transform:scale(1.0); }
.hero__veil{
  position:absolute; inset:0;
  background:
    radial-gradient(120% 80% at 20% 30%, rgba(14,13,12,.15), transparent 60%),
    linear-gradient(180deg, rgba(14,13,12,.55) 0%, rgba(14,13,12,.15) 35%, rgba(14,13,12,.78) 78%, var(--ink) 100%);
}
.hero__content{ position:relative; z-index:2; max-width:var(--maxw); width:100%; margin:0 auto; }
.hero__eyebrow{
  font-family:var(--stencilf); text-transform:uppercase;
  letter-spacing:.34em; font-size:.74rem; color:var(--gold);
  margin-bottom:1.1rem;
}
.hero__title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(3.4rem, 13vw, 11rem);
  line-height:.86; letter-spacing:-.02em;
  display:flex; flex-direction:column;
}
.hero__title span{ display:block; }
.hero__title--accent{ color:var(--poppy-2); font-style:italic; }
.hero__lede{
  margin-top:1.6rem; max-width:46ch;
  font-size:clamp(1rem,1.5vw,1.18rem); color:var(--paper-dim);
  line-height:1.65;
}
.hero__cta{ margin-top:2.2rem; display:flex; gap:14px; flex-wrap:wrap; }

.hero__foot{
  position:relative; z-index:2;
  max-width:var(--maxw); width:100%; margin:clamp(36px,6vh,72px) auto 0;
  display:flex; align-items:flex-end; justify-content:space-between; gap:20px;
  border-top:1px solid var(--line); padding-top:18px;
}
.hero__scroll{ display:flex; align-items:center; gap:10px; font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.2em; font-size:.7rem; color:var(--muted); }
.hero__scroll i{ width:46px; height:1px; background:var(--muted); position:relative; overflow:hidden; }
.hero__scroll i::after{ content:""; position:absolute; inset:0; width:40%; background:var(--gold); animation:scrolll 2s var(--ease) infinite; }
@keyframes scrolll{ 0%{transform:translateX(-120%)} 100%{transform:translateX(280%)} }
.hero__where{ text-align:right; display:flex; flex-direction:column; gap:2px; font-size:.78rem; color:var(--muted); letter-spacing:.06em; }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:var(--ink-2);
  overflow:hidden; padding:18px 0;
}
.marquee__track{
  display:flex; gap:34px; align-items:center; white-space:nowrap;
  width:max-content; animation:march 38s linear infinite;
  font-family:var(--serif); font-style:italic; font-size:clamp(1.1rem,2vw,1.7rem);
  color:var(--paper-dim);
}
.marquee__track .dot{ color:var(--poppy-2); font-style:normal; font-size:.7em; }
@keyframes march{ to{ transform:translateX(-50%); } }

/* ============================================================
   STORY
   ============================================================ */
.story{ padding:clamp(70px,11vh,150px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.story__grid{ display:grid; grid-template-columns:1.04fr .96fr; gap:clamp(40px,6vw,84px); align-items:stretch; }
.story__text{ display:flex; flex-direction:column; }
.story__p{ margin-top:1.4rem; color:var(--paper-dim); font-size:1.05rem; max-width:46ch; }
.story__p--lead{ color:var(--paper); font-size:clamp(1.12rem,1.5vw,1.32rem); line-height:1.6; font-weight:300; }

/* unified facts grid */
.facts{ margin-top:clamp(2.2rem,4vh,3.4rem); border:1px solid var(--line); border-radius:5px; overflow:hidden; }
.facts__row{ display:grid; grid-template-columns:repeat(3,1fr); }
.facts__row + .facts__row{ border-top:1px solid var(--line); }
.fact{ padding:clamp(16px,2vw,24px) 12px; text-align:center; transition:background .35s var(--ease); }
.fact + .fact{ border-left:1px solid var(--line); }
.fact:hover{ background:rgba(201,162,90,.05); }
.fact b{ display:block; font-family:var(--serif); font-weight:500; font-size:clamp(1.7rem,2.3vw,2.25rem); line-height:1; color:var(--gold-soft); font-variant-numeric:lining-nums; font-feature-settings:"lnum" 1; }
.fact span{ display:block; margin-top:.55rem; font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.11em; font-size:.6rem; line-height:1.5; color:var(--muted); }

/* editorial photo diptych */
.story__shots{ display:grid; grid-template-rows:1.42fr 1fr; gap:12px; height:100%; min-height:540px; }
.story__shot{ position:relative; margin:0; overflow:hidden; border-radius:4px; }
.story__shot::after{ content:""; position:absolute; inset:0; pointer-events:none; box-shadow:inset 0 0 0 1px rgba(243,236,224,.08); border-radius:4px; z-index:3; }
.story__shot img{ width:100%; height:100%; object-fit:cover; filter:saturate(.96) contrast(1.04) brightness(.92); transition:transform 1.1s var(--ease), filter .5s; }
.story__shot:hover img{ transform:scale(1.045); filter:saturate(1) contrast(1.04) brightness(1); }
.story__shot--main img{ object-position:center 42%; }
.story__shot--sub img{ object-position:center 58%; }

.story__cap{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:30px 22px 18px;
  display:flex; flex-direction:column; gap:.25rem;
  background:linear-gradient(transparent, rgba(11,10,9,.82)); }
.story__cap-k{ font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.16em; font-size:.64rem; color:var(--gold-soft); position:relative; padding-left:30px; }
.story__cap-k::before{ content:""; position:absolute; left:0; top:50%; width:20px; height:1px; background:var(--gold); }
.story__cap-t{ font-family:var(--serif); font-style:italic; font-size:1.04rem; color:var(--paper); }
.story__cap--min{ padding:22px 22px 16px; }

.story__ob{ position:absolute; right:16px; top:10px; z-index:2; font-family:var(--stencilf); font-weight:700; font-size:clamp(2.6rem,5vw,4rem); line-height:1; letter-spacing:.04em; color:rgba(243,236,224,.14); pointer-events:none; }
.story__est{ position:absolute; z-index:2; left:14px; top:18px; writing-mode:vertical-rl; transform:rotate(180deg); transform-origin:center;
  font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.28em; font-size:.6rem; color:rgba(243,236,224,.6); }


/* ============================================================
   RITUAL
   ============================================================ */
.ritual{
  position:relative; padding:clamp(70px,12vh,160px) var(--pad);
  background:
    linear-gradient(180deg, var(--ink) 0%, var(--ink-2) 30%, var(--ink-2) 70%, var(--ink) 100%);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  overflow:hidden;
}
.ritual::before{
  content:"72"; position:absolute; right:-2vw; top:50%; transform:translateY(-50%);
  font-family:var(--stencilf); font-weight:700; font-size:42vw; line-height:1;
  color:rgba(180,35,31,.045); z-index:0; pointer-events:none;
}
.ritual__head{ text-align:center; position:relative; z-index:1; max-width:var(--maxw); margin:0 auto; }
.ritual__head .sec__kicker{ color:var(--gold); }
.ritual__steps{
  list-style:none; max-width:var(--maxw); margin:clamp(40px,6vh,72px) auto 0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,40px);
  position:relative; z-index:1;
}
.rstep{
  background:rgba(31,28,22,.5); border:1px solid var(--line);
  border-radius:4px; padding:34px 28px;
  backdrop-filter:blur(4px);
  transition:border-color .4s, transform .4s var(--ease);
}
.rstep:hover{ border-color:var(--gold); transform:translateY(-4px); }
.rstep__no{ font-family:var(--serif); font-size:2.6rem; color:var(--poppy-2); line-height:1; }
.rstep h3{ font-family:var(--serif); font-weight:600; font-size:1.4rem; margin:.8rem 0 .6rem; }
.rstep p{ color:var(--paper-dim); font-size:.96rem; }

.ritual__pass{
  position:relative; z-index:1; text-align:center;
  margin:clamp(46px,7vh,80px) auto 0; max-width:760px;
  display:flex; flex-direction:column; gap:.7rem;
}
.ritual__quote{
  font-family:var(--serif); font-style:italic; font-weight:500;
  font-size:clamp(1.8rem,5vw,3.4rem); line-height:1.1; color:var(--gold-soft);
}
.ritual__by{ font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.18em; font-size:.74rem; color:var(--muted); }

/* ============================================================
   MENU
   ============================================================ */
.menu{ padding:clamp(70px,11vh,150px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.menu__head{ max-width:60ch; }
.menu__intro{ margin-top:1.5rem; color:var(--paper-dim); font-size:1.02rem; max-width:48ch; }

/* signature dishes */
.menu__siglabel{ margin-top:clamp(42px,6vh,68px); display:flex; align-items:center; gap:18px;
  font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.22em; font-size:.72rem; color:var(--gold); }
.menu__siglabel::after{ content:""; flex:1; height:1px; background:var(--line); }
.menu__signature{ margin-top:clamp(20px,3vh,30px); display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,1.6vw,24px); }
.sig{ position:relative; border:1px solid var(--line); border-radius:6px; overflow:hidden;
  display:flex; flex-direction:column;
  transition:border-color .4s var(--ease), transform .4s var(--ease); }
.sig:hover{ border-color:rgba(201,162,90,.5); transform:translateY(-5px); }
.sig__img{ aspect-ratio:3/2; overflow:hidden; }
.sig__img img{ width:100%; height:100%; object-fit:cover; filter:saturate(.98) brightness(.94); transition:transform .9s var(--ease), filter .5s; }
.sig:hover .sig__img img{ transform:scale(1.06); filter:saturate(1.03) brightness(1); }
.sig__body{ padding:24px 26px 26px; display:flex; flex-direction:column; gap:.5rem; flex:1; }
.sig__no{ font-family:var(--stencilf); font-size:.76rem; letter-spacing:.12em; color:var(--poppy-2); }
.sig__name{ font-family:var(--serif); font-weight:500; font-size:clamp(1.3rem,1.6vw,1.6rem); line-height:1.15; color:var(--paper); }
.sig__desc{ font-size:.86rem; color:var(--muted); flex:1; line-height:1.55; }
.sig__price{ font-family:var(--stencilf); font-size:1.14rem; color:var(--gold-soft); letter-spacing:.03em; margin-top:.6rem; }

/* tabbed menu */
.menu__tabs{ margin-top:clamp(48px,7vh,80px); display:flex; flex-wrap:wrap; gap:10px; }
.mtab{ font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.1em; font-size:.74rem;
  color:var(--muted); background:transparent; border:1px solid var(--line); border-radius:50px;
  padding:.72em 1.25em; cursor:pointer; white-space:nowrap; transition:color .3s var(--ease), background .3s var(--ease), border-color .3s var(--ease); }
.mtab:hover{ color:var(--paper); border-color:var(--muted); }
.mtab.is-active{ color:var(--ink); background:var(--gold-soft); border-color:var(--gold-soft); }

.menu__panels{ margin-top:clamp(30px,4vh,44px); min-height:240px; }
.mpanel{ display:none; }
.mpanel.is-active{ display:block; animation:mpanelin .5s var(--ease); }
@keyframes mpanelin{ from{ opacity:0; transform:translateY(12px);} to{ opacity:1; transform:none;} }
.mpanel .mlist{ display:block; columns:2; column-gap:clamp(40px,5vw,80px); }
.mpanel .mlist li{ break-inside:avoid; -webkit-column-break-inside:avoid; margin-bottom:1.2rem; }
.mpanel .mlist li:last-child{ margin-bottom:0; }
.mcol__title{
  font-family:var(--stencilf); text-transform:uppercase;
  letter-spacing:.16em; font-size:.86rem; font-weight:600; color:var(--gold);
  padding-bottom:.9rem; margin-bottom:1.1rem; border-bottom:1px solid var(--line);
}
.mlist{ list-style:none; display:flex; flex-direction:column; gap:1.15rem; }
.mlist li{ display:flex; flex-wrap:wrap; align-items:baseline; }
.mi__name{ order:1; font-family:var(--serif); font-size:1.22rem; font-weight:500; color:var(--paper); transition:color .3s; }
.mlist li:hover .mi__name{ color:var(--gold-soft); }
.mi__dots{ order:2; flex:1 1 auto; min-width:16px; margin:0 12px; border-bottom:1px dotted rgba(243,236,224,.24); transform:translateY(-5px); }
.mi__price{ order:3; font-family:var(--stencilf); font-size:1.02rem; color:var(--gold-soft); white-space:nowrap; }
.mi__price::after{ content:" ₴"; font-size:.7em; color:var(--muted); }
.mi__desc{ order:4; flex:0 0 100%; font-style:normal; font-size:.85rem; color:var(--muted); margin-top:.3rem; }

/* Обіди на Майдані */
.lunch{ margin-top:clamp(50px,7vh,84px); border:1px solid var(--line); border-radius:8px; overflow:hidden; }
.lunch__head{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
  padding:clamp(26px,3vw,38px);
  background:linear-gradient(135deg, rgba(180,35,31,.12), rgba(31,28,22,.5)); border-bottom:1px solid var(--line); }
.lunch__badge{ display:inline-block; font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.16em;
  font-size:.62rem; color:var(--poppy-2); border:1px solid rgba(180,35,31,.45); border-radius:50px; padding:.42em .95em; margin-bottom:1rem; }
.lunch__title{ font-family:var(--serif); font-weight:500; font-size:clamp(1.9rem,3.2vw,2.7rem); line-height:1; }
.lunch__when{ margin-top:.7rem; font-size:.92rem; color:var(--muted); letter-spacing:.02em; }
.lunch__price{ display:flex; align-items:baseline; gap:.45rem; }
.lunch__price b{ font-family:var(--serif); font-weight:500; font-size:clamp(2.8rem,5vw,3.8rem); line-height:1; color:var(--gold-soft); font-variant-numeric:lining-nums; font-feature-settings:"lnum" 1; }
.lunch__price span{ font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.1em; font-size:.72rem; color:var(--muted); }
.lunch__week{ display:grid; grid-template-columns:repeat(5,1fr); gap:1px; background:var(--line); }
.day{ background:var(--ink-2); padding:clamp(20px,1.5vw,26px); }
.day__d{ display:block; font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.14em; font-size:.72rem; color:var(--gold);
  padding-bottom:.9rem; margin-bottom:1rem; border-bottom:1px solid var(--line); }
.day ul{ list-style:none; display:flex; flex-direction:column; gap:.65rem; }
.day li{ font-size:.88rem; color:var(--paper-dim); line-height:1.4; position:relative; padding-left:15px; }
.day li::before{ content:""; position:absolute; left:0; top:.6em; width:6px; height:1px; background:var(--poppy-2); }

.menu__cta{ margin-top:clamp(46px,6vh,68px); display:flex; align-items:center; gap:22px; flex-wrap:wrap; padding-top:36px; border-top:1px solid var(--line); }
.menu__note{ font-size:.8rem; color:var(--muted); letter-spacing:.04em; }

/* ============================================================
   CULTURE
   ============================================================ */
.culture{ padding:clamp(70px,11vh,150px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.culture__head{ max-width:60ch; }
.culture__intro{ margin-top:1.4rem; color:var(--paper-dim); font-size:1.05rem; max-width:52ch; }
.culture__mosaic{
  margin-top:clamp(36px,5vh,60px);
  display:grid; gap:14px;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;
}
.cm{ position:relative; overflow:hidden; border-radius:3px; }
.cm--tall{ grid-row:span 2; }
.cm--wide{ grid-column:span 2; }
.cm img{ width:100%; height:100%; object-fit:cover; filter:saturate(.92) brightness(.8); transition:transform .9s var(--ease), filter .5s; }
.cm:hover img{ transform:scale(1.06); filter:saturate(1) brightness(.95); }
.cm figcaption{
  position:absolute; left:0; right:0; bottom:0; padding:16px;
  font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.12em; font-size:.72rem;
  color:var(--paper);
  background:linear-gradient(transparent, rgba(14,13,12,.85));
  transform:translateY(8px); opacity:.85; transition:.4s var(--ease);
}
.cm:hover figcaption{ transform:translateY(0); opacity:1; }

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{ padding:clamp(60px,9vh,120px) var(--pad); max-width:1500px; margin:0 auto; }
.gallery__head{ text-align:center; margin-bottom:clamp(32px,5vh,52px); }
.gallery__head .sec__title{ margin-inline:auto; }
.gallery__grid{ columns:4 260px; column-gap:14px; }
.gitem{
  display:block; width:100%; margin:0 0 14px; padding:0; border:none; cursor:pointer;
  background:none; overflow:hidden; border-radius:3px; position:relative;
  break-inside:avoid;
}
.gitem img{ width:100%; filter:saturate(.9) brightness(.82); transition:transform .8s var(--ease), filter .5s; }
.gitem::after{ content:"+"; position:absolute; inset:0; display:grid; place-items:center; font-size:2rem; color:#fff; opacity:0; background:rgba(14,13,12,.3); transition:opacity .4s; }
.gitem:hover img{ transform:scale(1.05); filter:saturate(1) brightness(1); }
.gitem:hover::after{ opacity:1; }

/* ============================================================
   PRESS
   ============================================================ */
.press{
  padding:clamp(54px,8vh,96px) var(--pad);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:var(--ink-2); text-align:center;
}
.press__kicker{ font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.28em; font-size:.7rem; color:var(--muted); }
.press__row{
  display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:18px;
  margin:1.4rem auto 0; font-family:var(--serif); font-size:clamp(1.1rem,2vw,1.5rem); color:var(--paper-dim);
}
.press__row i{ color:var(--poppy-2); font-style:normal; }
.press__quote{
  margin:2.2rem auto 0; max-width:50ch;
  font-family:var(--serif); font-style:italic; font-size:clamp(1.3rem,2.6vw,2rem);
  line-height:1.35; color:var(--gold-soft); border:none;
}

/* ============================================================
   VISIT
   ============================================================ */
.visit{ padding:clamp(70px,11vh,150px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.visit__head{ text-align:center; margin-bottom:clamp(36px,5vh,60px); }
.visit__head .sec__title{ margin-inline:auto; }
.visit__grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(40px,6vw,80px); align-items:stretch; }
.visit__map{ position:relative; min-height:360px; border-radius:5px; overflow:hidden; border:1px solid var(--line); }
.visit__map iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; filter:invert(.91) hue-rotate(185deg) saturate(.7) brightness(.95) contrast(.92); transition:filter .5s var(--ease); }
.visit__map:hover iframe{ filter:invert(.91) hue-rotate(185deg) saturate(.85) brightness(1.02) contrast(.95); }
.visit__maplink{
  position:absolute; left:14px; bottom:14px; z-index:2;
  background:rgba(14,13,12,.82); backdrop-filter:blur(6px);
  border:1px solid var(--line); color:var(--paper);
  font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.08em;
  font-size:.66rem; padding:.6em 1em; border-radius:3px;
  transition:border-color .3s, color .3s;
}
.visit__maplink:hover{ border-color:var(--gold); color:var(--gold-soft); }
.vlist{ list-style:none; margin-top:0; display:flex; flex-direction:column; }
.vlist li{ display:grid; grid-template-columns:120px 1fr; gap:18px; padding:18px 0; border-top:1px solid var(--line); }
.vlist li:last-child{ border-bottom:1px solid var(--line); }
.vlist__k{ font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.16em; font-size:.72rem; color:var(--gold); padding-top:3px; }
.vlist__v{ font-size:1.02rem; color:var(--paper); }
.vlist__v i{ font-style:normal; color:var(--muted); font-size:.9rem; }
.vlist__v a{ border-bottom:1px solid var(--line); transition:border-color .3s, color .3s; }
.vlist__v a:hover{ color:var(--gold-soft); border-color:var(--gold); }
.visit__btns{ margin-top:2.2rem; display:flex; gap:14px; flex-wrap:wrap; }

.book{
  background:var(--ink-3); border:1px solid var(--line); border-radius:5px;
  padding:clamp(26px,3vw,42px);
}
.book__title{ font-family:var(--serif); font-weight:600; font-size:1.7rem; margin-bottom:1.6rem; }
.book__row{ display:flex; gap:16px; }
.field{ display:flex; flex-direction:column; gap:.5rem; margin-bottom:16px; flex:1; }
.field--sm{ max-width:96px; }
.field span{ font-family:var(--stencilf); text-transform:uppercase; letter-spacing:.12em; font-size:.68rem; color:var(--muted); }
.field input, .field textarea{
  font-family:var(--sans); font-size:.96rem; color:var(--paper);
  background:rgba(14,13,12,.5); border:1px solid var(--line); border-radius:3px;
  padding:.8em .9em; transition:border-color .3s, background .3s; width:100%;
  resize:vertical;
}
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--gold); background:rgba(14,13,12,.8); }
.field input::placeholder, .field textarea::placeholder{ color:rgba(165,156,140,.5); }
.field input[type=date], .field input[type=time]{ color-scheme:dark; }
.book__submit{ width:100%; justify-content:center; margin-top:8px; }
.book__hint{ font-size:.78rem; color:var(--muted); margin-top:1rem; text-align:center; }
.book__ok{
  margin-top:1rem; text-align:center; font-family:var(--serif); font-style:italic;
  font-size:1.1rem; color:var(--gold-soft);
  border:1px solid var(--gold); border-radius:3px; padding:14px;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ padding:clamp(50px,7vh,80px) var(--pad) 32px; border-top:1px solid var(--line); }
.footer__top{ max-width:var(--maxw); margin:0 auto; display:flex; justify-content:space-between; align-items:flex-start; gap:40px; flex-wrap:wrap; }
.footer__brand{ display:flex; gap:18px; align-items:center; max-width:34ch; }
.footer__mark{ height:56px; width:auto; flex:none; object-fit:contain; display:block; }
.footer__tag{ font-family:var(--serif); font-style:italic; font-size:1.2rem; color:var(--paper-dim); }
.footer__nav{ display:flex; flex-wrap:wrap; gap:14px 26px; }
.footer__nav a{ font-size:.82rem; color:var(--muted); letter-spacing:.05em; transition:color .3s; }
.footer__nav a:hover{ color:var(--gold-soft); }
.footer__bottom{
  max-width:var(--maxw); margin:36px auto 0; padding-top:22px; border-top:1px solid var(--line);
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-size:.76rem; color:var(--muted); letter-spacing:.05em;
}
.footer__pass{ font-family:var(--serif); font-style:italic; color:var(--poppy-2); }

/* Built by West Tech */
.westtech{
  display:inline-flex; align-items:center; gap:.42rem;
  background:rgba(55,48,231,.1);
  border:1px solid rgba(55,48,231,.22);
  border-radius:50px;
  padding:.38rem .9rem .38rem .5rem;
  font-family:var(--sans); font-size:.78rem; line-height:1;
  transition:background .3s var(--ease), border-color .3s var(--ease), transform .3s var(--ease);
}
.westtech:hover{ background:rgba(55,48,231,.17); border-color:rgba(55,48,231,.45); transform:translateY(-1px); }
.westtech__logo{ display:block; flex:none; }
.westtech__by{ color:var(--muted); letter-spacing:.01em; }
.westtech__name{ color:#6366f1; font-weight:600; letter-spacing:.01em; }

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{
  position:fixed; inset:0; z-index:200; background:rgba(8,7,6,.95);
  display:grid; place-items:center; padding:5vw;
  backdrop-filter:blur(6px);
}
.lightbox[hidden]{ display:none; }
.lightbox img{ max-width:90vw; max-height:86vh; object-fit:contain; border-radius:3px; box-shadow:0 30px 80px -20px #000; }
.lightbox__close{ position:absolute; top:22px; right:26px; font-size:1.6rem; color:var(--paper); background:none; border:none; cursor:pointer; }
.lightbox__nav{ position:absolute; top:50%; transform:translateY(-50%); font-size:2.6rem; line-height:1; color:var(--paper); background:none; border:none; cursor:pointer; padding:10px 18px; opacity:.7; transition:opacity .3s; }
.lightbox__nav:hover{ opacity:1; color:var(--gold-soft); }
.lightbox__nav--prev{ left:1vw; } .lightbox__nav--next{ right:1vw; }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); transition-delay:var(--d,0s); }
.reveal.is-in{ opacity:1; transform:none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .nav__links{
    position:fixed; inset:0 0 0 auto; width:min(78vw,340px);
    flex-direction:column; gap:26px; justify-content:center; align-items:flex-start;
    background:rgba(14,13,12,.96); backdrop-filter:blur(18px);
    padding:0 12vw; transform:translateX(100%); transition:transform .5s var(--ease);
    border-left:1px solid var(--line);
  }
  body.menu-open .nav__links{ transform:translateX(0); }
  .nav__links a{ font-size:1.3rem; font-family:var(--serif); color:var(--paper); }
  .burger{ display:block; }
  .nav__cta{ display:none; }
  .story__grid{ grid-template-columns:1fr; gap:42px; }
  .story__shots{ order:-1; height:auto; min-height:0; grid-template-rows:300px 200px; }
  .menu__head{ grid-template-columns:1fr; gap:18px; }
  .lunch__week{ grid-template-columns:repeat(2,1fr); }
  .visit__grid{ grid-template-columns:1fr; }
  .visit__map{ min-height:300px; }
  .culture__mosaic{ grid-template-columns:repeat(2,1fr); grid-auto-rows:160px; }
  .cm--wide{ grid-column:span 2; }
}
@media (max-width:680px){
  .ritual__steps{ grid-template-columns:1fr; }
  .menu__signature{ grid-template-columns:1fr; }
  .menu__tabs{ flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; margin-inline:calc(-1 * var(--pad)); padding-inline:var(--pad); }
  .menu__tabs::-webkit-scrollbar{ display:none; }
  .mpanel .mlist{ columns:1; }
  .lunch__week{ grid-template-columns:1fr; }
  .mi__dots{ display:none; }
  .mlist li{ column-gap:14px; }
  .mi__name{ flex:1 1 auto; }
  .mi__price{ margin-left:auto; }
  .gallery__grid{ columns:2 150px; }
  .hero__where{ display:none; }
  .hero__foot{ justify-content:center; }
  .book__row{ flex-direction:column; gap:0; }
  .field--sm{ max-width:none; }
  .footer__top{ flex-direction:column; gap:28px; }
  .vlist li{ grid-template-columns:1fr; gap:6px; }
}
