/* ============================================================
   DEFNE RESTAURANT — Design System
   Editorial fine-dining · warm dark · gold + laurel
   Fonts: Playfair Display (display) · Karla (body)
   ============================================================ */

:root{
  /* — surfaces — */
  --ink:        #100C07;   /* page background (warm near-black) */
  --ink-2:      #0A0704;   /* deepest sections */
  --ink-soft:   #1A140D;   /* cards / raised */
  --ink-line:   #241B12;

  /* — text — */
  --cream:      #ECE3D1;   /* primary text */
  --cream-hi:   #F6F0E2;   /* bright headings */
  --muted:      #A2937A;   /* secondary */
  --muted-d:    #6E6450;   /* tertiary / captions */

  /* — accents — */
  --gold:       #C99A4E;   /* primary accent / CTA */
  --gold-hi:    #E3BE73;   /* hover / highlight */
  --laurel:     #6E8A55;   /* "defne" green secondary */
  --laurel-hi:  #8BA66F;

  --line:       rgba(236,227,209,.12);
  --line-soft:  rgba(236,227,209,.07);

  /* — type — */
  --display: 'Playfair Display', Georgia, serif;
  --body: 'Karla', system-ui, -apple-system, sans-serif;

  --wrap: 1280px;
  --gut: clamp(20px, 5vw, 64px);

  --ease: cubic-bezier(.22,1,.36,1);
  --ease-in-out: cubic-bezier(.76,0,.24,1);
}

/* ---------- reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--ink);
  color:var(--cream);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
.no-scroll{overflow:hidden;height:100vh}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--gold);color:var(--ink)}

h1,h2,h3,h4{font-family:var(--display);font-weight:500;line-height:1.04;letter-spacing:-.01em}
.serif-it{font-style:italic;font-weight:400;color:var(--gold)}

/* ============================================================
   ACCESS GATE
   ============================================================ */
html.auth-locked,html.auth-locked body{overflow:hidden;height:100%}
.auth-gate{display:none}
html.auth-locked .auth-gate{
  position:fixed;inset:0;z-index:11000;display:grid;place-items:center;
  padding:clamp(20px,4vw,52px);isolation:isolate;background:var(--ink-2);
}
.auth-gate-bg{
  position:absolute;inset:0;z-index:-3;background:url('../img/hero-mezze.jpg') center/cover no-repeat;
  filter:saturate(.7);transform:scale(1.03);
}
.auth-gate-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,rgba(10,7,4,.96) 8%,rgba(10,7,4,.78) 53%,rgba(10,7,4,.9) 100%);
}
.auth-gate-glow{
  position:absolute;z-index:-2;width:min(760px,86vw);height:min(760px,86vw);border-radius:50%;
  background:radial-gradient(circle,rgba(201,154,78,.14),transparent 68%);filter:blur(12px);
}
.auth-card{
  position:relative;width:min(100%,520px);padding:clamp(34px,6vw,58px);
  background:linear-gradient(145deg,rgba(26,20,13,.94),rgba(10,7,4,.96));
  border:1px solid rgba(201,154,78,.28);box-shadow:0 32px 90px rgba(0,0,0,.58);
  text-align:center;overflow:hidden;animation:auth-card-in .8s var(--ease) both;
}
.auth-card::before,.auth-card::after{content:"";position:absolute;width:56px;height:56px;pointer-events:none}
.auth-card::before{top:14px;left:14px;border-top:1px solid var(--gold);border-left:1px solid var(--gold)}
.auth-card::after{right:14px;bottom:14px;border-right:1px solid var(--gold);border-bottom:1px solid var(--gold)}
.auth-leaf{width:42px;height:42px;margin:0 auto 17px;stroke:var(--gold);fill:none;stroke-width:1.15}
.auth-kicker{font-size:10px;font-weight:600;letter-spacing:.31em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.auth-card h1{font-size:clamp(34px,6vw,52px);color:var(--cream-hi)}
.auth-copy{max-width:390px;margin:18px auto 30px;color:var(--muted);font-size:16px;line-height:1.65}
.auth-label{display:block;margin-bottom:8px;text-align:left;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--cream)}
.auth-input-wrap{position:relative}
.auth-input-wrap input{
  width:100%;height:56px;padding:0 100px 0 17px;border:1px solid rgba(236,227,209,.2);border-radius:0;
  outline:none;background:rgba(255,255,255,.035);color:var(--cream-hi);font:500 16px var(--body);
  transition:border-color .25s,box-shadow .25s,background .25s;
}
.auth-input-wrap input::placeholder{color:var(--muted-d)}
.auth-input-wrap input:hover{border-color:rgba(236,227,209,.36)}
.auth-input-wrap input:focus{border-color:var(--gold);background:rgba(255,255,255,.055);box-shadow:0 0 0 3px rgba(201,154,78,.12)}
.auth-input-wrap input[aria-invalid="true"]{border-color:#D57A6C}
.auth-toggle{
  position:absolute;right:15px;top:50%;transform:translateY(-50%);padding:6px 0;
  font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-hi);
}
.auth-toggle:focus-visible{outline:1px solid var(--gold);outline-offset:4px}
.auth-error{min-height:24px;margin:7px 0 3px;text-align:left;font-size:13px;line-height:1.45;color:#E4A095}
.auth-submit{
  width:100%;min-height:56px;display:flex;align-items:center;justify-content:center;gap:14px;
  background:var(--gold);color:var(--ink);font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  transition:background .3s var(--ease),transform .3s var(--ease),box-shadow .3s var(--ease);
}
.auth-submit span{font-size:19px;line-height:1;transition:transform .3s var(--ease)}
.auth-submit:hover{background:var(--gold-hi);transform:translateY(-2px);box-shadow:0 14px 32px -14px rgba(201,154,78,.75)}
.auth-submit:hover span{transform:translateX(4px)}
.auth-submit:focus-visible{outline:2px solid var(--cream-hi);outline-offset:4px}
.auth-note{margin-top:20px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-d)}
.auth-card.is-error{animation:auth-shake .42s ease}
.auth-gate.is-leaving{animation:auth-gate-out .65s var(--ease) forwards;pointer-events:none}
@keyframes auth-card-in{from{opacity:0;transform:translateY(24px) scale(.985)}to{opacity:1;transform:none}}
@keyframes auth-gate-out{to{opacity:0;visibility:hidden}}
@keyframes auth-shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-8px)}50%{transform:translateX(7px)}75%{transform:translateX(-4px)}}

/* lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}

/* ---------- layout ---------- */
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}
.section{position:relative;padding:clamp(80px,12vh,160px) 0}
.section.tight{padding:clamp(56px,8vh,96px) 0}
.eyebrow{
  font-family:var(--body);font-size:12px;font-weight:600;letter-spacing:.34em;
  text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);opacity:.7}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--gold);opacity:.7}

/* film grain overlay */
.grain{
  position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%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");
}

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{
  position:fixed;inset:0;z-index:9999;background:var(--ink-2);
  display:grid;place-items:center;
}
.preloader .pl-inner{text-align:center;overflow:hidden}
.preloader .pl-leaf{width:46px;height:46px;margin:0 auto 18px;stroke:var(--gold);fill:none;stroke-width:1.2;opacity:0}
.preloader .pl-word{
  font-family:var(--display);font-size:clamp(42px,9vw,86px);color:var(--cream-hi);
  letter-spacing:.04em;display:flex;gap:.02em;overflow:hidden;
}
.preloader .pl-word span{display:inline-block;transform:translateY(110%)}
.preloader .pl-sub{
  margin-top:14px;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted-d);
  opacity:0;
}
.preloader .pl-bar{
  position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--gold);
}

/* ============================================================
   PAGE TRANSITION (curtain)
   ============================================================ */
.curtain{position:fixed;inset:0;z-index:9000;display:flex;pointer-events:none}
.curtain span{flex:1;background:var(--ink-2);transform:scaleY(0);transform-origin:bottom}
.curtain-logo{
  position:fixed;z-index:9001;inset:0;display:grid;place-items:center;pointer-events:none;opacity:0;
}
.curtain-logo b{font-family:var(--display);font-size:clamp(40px,8vw,72px);color:var(--gold)}

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor{
  position:fixed;top:0;left:0;width:9px;height:9px;border-radius:50%;background:var(--gold);
  z-index:9500;pointer-events:none;transform:translate(-50%,-50%);mix-blend-mode:difference;
}
.cursor-follow{
  position:fixed;top:0;left:0;width:48px;height:48px;border:1px solid var(--gold);border-radius:50%;
  z-index:9499;pointer-events:none;transform:translate(-50%,-50%);
  transition:width .35s var(--ease),height .35s var(--ease),background .35s,border-color .35s,opacity .3s;
}
.cursor-follow.grow{width:84px;height:84px;background:rgba(201,154,78,.12);border-color:transparent}
.cursor-follow.grow.lbl::after{content:attr(data-label);font-family:var(--body);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-hi)}
body.touch .cursor,body.touch .cursor-follow{display:none}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;width:100%;z-index:200;padding:22px 0;
  transition:padding .4s var(--ease),background .4s var(--ease);}
.nav.scrolled{padding:13px 0;background:rgba(16,12,7,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{display:flex;align-items:center;gap:11px;line-height:1}
.logo svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:1.3}
.logo b{font-family:var(--display);font-size:23px;font-weight:600;color:var(--cream-hi);letter-spacing:.06em}
.logo .tag{display:block;font-family:var(--body);font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted-d);margin-top:3px}
.nav-menu{display:flex;align-items:center;gap:34px}
.nav-menu a{position:relative;font-size:14px;font-weight:500;letter-spacing:.02em;color:var(--cream);padding:4px 0}
.nav-menu a .lbl{position:relative;display:inline-block}
.nav-menu a .lbl::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--gold);transition:width .4s var(--ease)}
.nav-menu a:hover .lbl::after,.nav-menu a.active .lbl::after{width:100%}
.nav-menu a.active{color:var(--gold-hi)}
.nav .nav-cta{
  font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);
  background:var(--gold);padding:12px 22px;border-radius:100px;
  transition:background .35s var(--ease),transform .35s var(--ease),box-shadow .35s;
}
.nav .nav-cta::after{display:none}
.nav .nav-cta:hover{background:var(--gold-hi);transform:translateY(-2px);box-shadow:0 12px 30px -12px rgba(201,154,78,.6)}

.burger{display:none;width:42px;height:42px;position:relative;z-index:210}
.burger span{position:absolute;left:9px;right:9px;height:1.6px;background:var(--cream);transition:.35s var(--ease)}
.burger span:nth-child(1){top:15px}
.burger span:nth-child(2){top:21px}
.burger span:nth-child(3){top:27px}
.burger.open span:nth-child(1){top:21px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:21px;transform:rotate(-45deg)}

.m-menu{position:fixed;inset:0;z-index:205;background:var(--ink-2);display:flex;flex-direction:column;
  justify-content:center;padding:0 var(--gut);clip-path:circle(0% at 100% 0);transition:clip-path .7s var(--ease-in-out);}
.m-menu.open{clip-path:circle(150% at 100% 0)}
.m-menu a{font-family:var(--display);font-size:clamp(34px,9vw,58px);color:var(--cream-hi);padding:10px 0;
  display:flex;align-items:baseline;gap:16px;opacity:0;transform:translateY(24px);transition:.6s var(--ease)}
.m-menu.open a{opacity:1;transform:none}
.m-menu a span{font-family:var(--body);font-size:13px;color:var(--gold);letter-spacing:.2em}
.m-foot{margin-top:42px;display:flex;flex-direction:column;gap:6px;font-size:15px;color:var(--muted)}
.m-foot a{font-family:var(--body);font-size:15px;color:var(--muted)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:120%;object-fit:cover;will-change:transform}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,7,4,.55) 0%,rgba(10,7,4,.25) 35%,rgba(10,7,4,.7) 78%,var(--ink) 100%)}
.hero-bg::before{content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(120% 80% at 50% 120%,rgba(201,154,78,.16),transparent 60%)}
.hero-inner{position:relative;z-index:3;width:100%;max-width:var(--wrap);margin:0 auto;
  padding:0 var(--gut) clamp(54px,10vh,110px)}
.hero .eyebrow{margin-bottom:26px}
.hero h1{font-size:clamp(56px,13vw,184px);color:var(--cream-hi);font-weight:500;letter-spacing:-.02em;line-height:.92}
.hero h1 .row{display:block;overflow:hidden}
.hero-lead{margin-top:30px;max-width:42ch;font-size:clamp(16px,2vw,20px);color:var(--cream);opacity:.92}
.hero-actions{margin-top:40px;display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.scroll-cue{position:absolute;right:var(--gut);bottom:clamp(54px,10vh,110px);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--muted)}
.scroll-cue .line{width:1px;height:54px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.scroll-cue .line::after{content:"";position:absolute;top:-54px;left:0;width:1px;height:54px;background:var(--gold);animation:cue 2.2s var(--ease) infinite}
.scroll-cue span{font-size:10px;letter-spacing:.3em;text-transform:uppercase;writing-mode:vertical-rl}
@keyframes cue{0%{top:-54px}60%,100%{top:54px}}

/* ---------- buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:12px;font-size:14px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;padding:17px 32px;border-radius:100px;overflow:hidden;
  transition:transform .4s var(--ease),color .4s var(--ease)}
.btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.8;transition:transform .4s var(--ease)}
.btn-primary{background:var(--gold);color:var(--ink)}
.btn-primary::before{content:"";position:absolute;inset:0;background:var(--gold-hi);transform:translateY(101%);transition:transform .45s var(--ease);z-index:-1}
.btn-primary:hover::before{transform:translateY(0)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-ghost{border:1px solid var(--line);color:var(--cream)}
.btn-ghost::before{content:"";position:absolute;inset:0;background:var(--cream);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease);z-index:-1}
.btn-ghost:hover{color:var(--ink);border-color:transparent}
.btn-ghost:hover::before{transform:scaleX(1)}

/* link with arrow */
.link-arrow{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:14px;letter-spacing:.04em;color:var(--gold-hi)}
.link-arrow svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;transition:transform .35s var(--ease)}
.link-arrow:hover svg{transform:translateX(6px)}

/* ============================================================
   INTRO / ABOUT
   ============================================================ */
.statement{font-family:var(--display);font-weight:500;font-size:clamp(30px,4.6vw,62px);line-height:1.1;
  color:var(--cream-hi);letter-spacing:-.01em}
.statement .mute{color:var(--muted-d)}
.split .line{overflow:hidden;padding-bottom:.16em;margin-bottom:-.16em}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,92px);align-items:center}
.prose p{color:var(--muted);font-size:17px;margin-bottom:20px;max-width:54ch}
.prose p strong{color:var(--cream);font-weight:600}
.lead-p{font-size:clamp(19px,2.3vw,23px)!important;color:var(--cream)!important;line-height:1.5}

.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:clamp(40px,6vh,72px);flex-wrap:wrap}
.sec-head h2{font-size:clamp(34px,6vw,80px);color:var(--cream-hi)}
.sec-head .eyebrow{margin-bottom:18px}

/* laurel divider */
.laurel-div{display:flex;align-items:center;justify-content:center;gap:18px;color:var(--gold);opacity:.8}
.laurel-div svg{width:30px;height:30px;stroke:currentColor;fill:none;stroke-width:1.2}
.laurel-div .ln{width:min(90px,18vw);height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.laurel-div .ln.r{background:linear-gradient(90deg,var(--gold),transparent)}

/* figure / image reveal */
.figure{position:relative;overflow:hidden;border-radius:4px}
.figure img{width:100%;height:100%;object-fit:cover;will-change:transform}
.figure .mask{position:absolute;inset:0;background:var(--ink);z-index:2;transform-origin:top}
.fig-cap{position:absolute;left:18px;bottom:18px;z-index:3;background:rgba(10,7,4,.55);backdrop-filter:blur(8px);
  border:1px solid var(--line);padding:9px 15px;border-radius:100px;font-size:12px;letter-spacing:.06em;color:var(--cream)}
.fig-cap b{color:var(--gold);font-family:var(--body);font-weight:700}

/* ============================================================
   DISH SHOWCASE — horizontal pinned
   ============================================================ */
.showcase{position:relative;overflow:hidden;background:var(--ink-2)}
.pin-wrap{height:100svh;display:flex;align-items:center;overflow:hidden}
.pin-track{display:flex;gap:clamp(20px,3vw,42px);padding:0 var(--gut);will-change:transform}
.dish{position:relative;flex:0 0 auto;width:min(78vw,440px);}
.dish-img{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:6px}
.dish-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(.55) brightness(.85);transition:filter .6s var(--ease),transform .9s var(--ease);will-change:transform}
.dish:hover .dish-img img{filter:grayscale(0) brightness(1);transform:scale(1.05)}
.dish-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(10,7,4,.7));opacity:.7}
.dish-num{position:absolute;top:16px;left:18px;z-index:2;font-size:12px;letter-spacing:.2em;color:var(--gold)}
.dish-meta{position:absolute;left:18px;right:18px;bottom:18px;z-index:2}
.dish-meta h3{font-size:clamp(22px,2.4vw,30px);color:var(--cream-hi)}
.dish-meta .k{display:block;font-family:var(--body);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--laurel-hi);margin-top:8px}
.showcase-head{padding:clamp(70px,10vh,120px) 0 0}
.showcase-foot{padding:clamp(40px,6vh,70px) 0 clamp(70px,10vh,120px)}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{padding:clamp(40px,7vh,80px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;white-space:nowrap}
.marquee-row{display:inline-flex;align-items:center;gap:40px;will-change:transform}
.marquee-row span{font-family:var(--display);font-size:clamp(34px,6vw,76px);color:var(--cream-hi);font-style:italic}
.marquee-row svg{width:34px;height:34px;stroke:var(--gold);fill:none;stroke-width:1.2;flex:0 0 auto}
.marquee-row .o{color:transparent;-webkit-text-stroke:1px var(--muted-d);font-style:normal}

/* ============================================================
   FEATURE (mezze) — sticky split
   ============================================================ */
.feature{position:relative}
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center}
.feature .figure{aspect-ratio:3/4}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.chip{font-size:13px;letter-spacing:.04em;color:var(--cream);border:1px solid var(--line);
  padding:8px 16px;border-radius:100px;background:var(--ink-soft)}
.chip b{color:var(--gold);font-weight:700}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px);border-top:1px solid var(--line);padding-top:clamp(36px,5vh,56px)}
.stat b{font-family:var(--display);font-size:clamp(34px,5vw,60px);color:var(--gold);display:block;line-height:1}
.stat span{display:block;margin-top:10px;font-size:13px;letter-spacing:.04em;color:var(--muted)}

/* ============================================================
   GALLERY
   ============================================================ */
.gal-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(12px,1.6vw,20px)}
.gal-item{position:relative;overflow:hidden;border-radius:4px}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);will-change:transform}
.gal-item:hover img{transform:scale(1.06)}
.gal-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(10,7,4,.4));opacity:0;transition:opacity .5s}
.gal-item:hover::after{opacity:1}
.gal-item .gtag{position:absolute;left:16px;bottom:14px;z-index:2;font-size:12px;letter-spacing:.06em;color:var(--cream-hi);
  opacity:0;transform:translateY(10px);transition:.5s var(--ease)}
.gal-item:hover .gtag{opacity:1;transform:none}
.g-a{grid-column:span 7;aspect-ratio:16/11}
.g-b{grid-column:span 5;aspect-ratio:4/5}
.g-c{grid-column:span 4;aspect-ratio:1}
.g-d{grid-column:span 4;aspect-ratio:1}
.g-e{grid-column:span 4;aspect-ratio:1}
.g-f{grid-column:span 5;aspect-ratio:4/5}
.g-g{grid-column:span 7;aspect-ratio:16/11}

/* light-sweep hover (shared) */
.sweep{position:relative}
.sweep::before{content:"";position:absolute;top:0;left:-30%;width:18%;height:100%;z-index:4;pointer-events:none;
  background:linear-gradient(105deg,transparent,rgba(255,245,225,.18),transparent);
  transform:skewX(-18deg) translateX(-120%);transition:transform .9s var(--ease)}
.sweep:hover::before{transform:skewX(-18deg) translateX(720%)}

/* ============================================================
   RESERVATION CTA
   ============================================================ */
.reserve{position:relative;text-align:center;background:var(--ink-2);overflow:hidden}
.reserve::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 50% 40%,rgba(201,154,78,.12),transparent 70%)}
.reserve-inner{position:relative;z-index:2;max-width:880px;margin:0 auto}
.reserve h2{font-size:clamp(40px,8vw,108px);color:var(--cream-hi);line-height:.98}
.reserve p{margin:26px auto 38px;max-width:48ch;color:var(--muted);font-size:18px}
.reserve .laurel-div{margin-bottom:30px}

/* ============================================================
   CONTACT / HOURS
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,6vw,80px);align-items:start}
.info-block{margin-bottom:34px}
.info-block .k{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;display:block}
.c-line{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
.c-line:last-child{border-bottom:none}
.c-ic{flex:0 0 40px;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  background:var(--ink-soft);border:1px solid var(--line)}
.c-ic svg{width:18px;height:18px;stroke:var(--gold);fill:none;stroke-width:1.7}
.c-line small{display:block;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-d);margin-bottom:3px}
.c-line b{font-family:var(--display);font-size:20px;font-weight:500;color:var(--cream-hi)}
.c-line b a:hover{color:var(--gold)}
.hours-row{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0;border-bottom:1px solid var(--line)}
.hours-row:last-child{border-bottom:none}
.hours-row .d{font-size:15px;color:var(--cream)}
.hours-row .t{font-family:var(--display);font-size:18px;color:var(--gold)}
.hours-row .t.closed{color:var(--muted-d)}
.map-figure{aspect-ratio:16/13;border-radius:6px;overflow:hidden;border:1px solid var(--line)}
.map-figure iframe{width:100%;height:100%;border:0;filter:grayscale(1) invert(.9) contrast(.85)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{position:relative;background:var(--ink-2);border-top:1px solid var(--line);padding:clamp(60px,9vh,110px) 0 36px}
.foot-cta{display:block;margin-bottom:clamp(50px,8vh,90px)}
.foot-cta a{font-family:var(--display);font-size:clamp(44px,10vw,150px);line-height:.92;color:var(--cream-hi);
  display:inline-flex;align-items:flex-start;gap:.1em;transition:color .4s var(--ease)}
.foot-cta a:hover{color:var(--gold)}
.foot-cta svg{width:clamp(28px,5vw,64px);height:clamp(28px,5vw,64px);stroke:var(--gold);fill:none;stroke-width:1.6;margin-top:.15em}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:40px;padding-top:clamp(40px,6vh,64px);border-top:1px solid var(--line)}
.foot-brand b{font-family:var(--display);font-size:26px;color:var(--cream-hi);letter-spacing:.05em;display:flex;align-items:center;gap:10px}
.foot-brand svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:1.3}
.foot-brand p{margin-top:16px;color:var(--muted);font-size:14px;max-width:34ch}
.foot-col h4{font-family:var(--body);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;font-weight:700}
.foot-col a,.foot-col p{display:block;color:var(--muted);font-size:15px;margin-bottom:11px;transition:color .3s}
.foot-col a:hover{color:var(--cream)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-top:clamp(40px,6vh,64px);
  padding-top:26px;border-top:1px solid var(--line);flex-wrap:wrap}
.foot-bottom p{font-size:13px;color:var(--muted-d)}
.foot-bottom .lg{display:flex;gap:22px}
.foot-bottom .lg a{font-size:13px;color:var(--muted-d)}
.foot-bottom .lg a:hover{color:var(--gold)}

/* ============================================================
   MENU PAGE
   ============================================================ */
.page-hero{padding:clamp(150px,22vh,260px) 0 clamp(50px,8vh,90px);position:relative}
.page-hero .crumb{font-size:13px;letter-spacing:.06em;color:var(--muted);margin-bottom:24px}
.page-hero .crumb a:hover{color:var(--gold)}
.page-hero h1{font-size:clamp(50px,11vw,150px);color:var(--cream-hi);line-height:.92}
.menu-cat{margin-bottom:clamp(50px,8vh,90px)}
.menu-cat-head{display:flex;align-items:baseline;gap:18px;margin-bottom:34px}
.menu-cat-head h2{font-size:clamp(28px,4vw,46px);color:var(--cream-hi)}
.menu-cat-head .ln{flex:1;height:1px;background:var(--line)}
.menu-cat-head .pill{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--laurel-hi)}
.menu-item{display:grid;grid-template-columns:1fr auto;gap:8px 20px;padding:20px 0;border-bottom:1px solid var(--line-soft);align-items:baseline}
.menu-item:hover .mi-name{color:var(--gold-hi)}
.mi-name{font-family:var(--display);font-size:clamp(19px,2.2vw,24px);color:var(--cream-hi);transition:color .3s;display:flex;align-items:center;gap:10px}
.mi-name .v{font-family:var(--body);font-size:10px;letter-spacing:.1em;color:var(--laurel-hi);border:1px solid var(--laurel);border-radius:100px;padding:2px 8px}
.mi-price{font-family:var(--display);font-size:20px;color:var(--gold);font-variant-numeric:tabular-nums}
.mi-desc{grid-column:1/2;color:var(--muted);font-size:15px;margin-top:4px;max-width:60ch}

/* ============================================================
   DEMO BAR (optional)
   ============================================================ */
.demo-bar{position:fixed;top:0;left:0;width:100%;z-index:9998;background:var(--gold);color:var(--ink);
  font-size:12.5px;font-weight:600;letter-spacing:.02em;display:flex;align-items:center;justify-content:center;gap:10px;
  padding:7px 16px;text-align:center}
.demo-bar svg{width:15px;height:15px;stroke:var(--ink);fill:none;stroke-width:2;flex:0 0 auto}
body.has-demo .nav{top:32px}

/* ============================================================
   REVEAL utilities (GSAP toggles)
   ============================================================ */
.reveal-up{opacity:0;transform:translateY(36px)}
.fade-in{opacity:0}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .foot-grid{grid-template-columns:1fr 1fr;gap:34px}
  .foot-brand{grid-column:1/-1}
}
@media(max-width:880px){
  body{font-size:16px}
  .nav-menu{display:none}
  .burger{display:block}
  .nav .nav-cta{display:none}
  .two-col,.feature-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .feature .figure{aspect-ratio:4/3}
  .stats{grid-template-columns:1fr 1fr;gap:30px 20px}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .g-a,.g-b,.g-c,.g-d,.g-e,.g-f,.g-g{grid-column:span 1;aspect-ratio:1}
  .g-a,.g-g{grid-column:span 2;aspect-ratio:16/10}
  .scroll-cue{display:none}
  .hero{align-items:flex-end}
}
@media(max-width:560px){
  :root{--gut:20px}
  html.auth-locked .auth-gate{padding:14px}
  .auth-card{padding:34px 24px 30px}
  .auth-card::before,.auth-card::after{width:38px;height:38px}
  .auth-copy{margin:14px auto 24px;font-size:15px}
  .auth-note{font-size:9px;letter-spacing:.14em}
  .foot-grid{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:14px}
  .menu-item{grid-template-columns:1fr;gap:4px}
  .mi-price{grid-row:1;justify-self:start}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal-up,.fade-in{opacity:1!important;transform:none!important}
  .hero-bg img{height:100%}
  .scroll-cue .line::after{display:none}
}
