/* =========================================================
   Trattoria La Stazione — Design System
   ========================================================= */

:root{
  /* Colors */
  --cream:      #F6EFE2;
  --cream-2:    #FBF7EF;
  --paper:      #EFE5D3;
  --dark:       #1A1512;   /* espresso — dark sections */
  --dark-2:     #241D18;
  --ink:        #211C18;   /* body text */
  --muted:      #6B5E51;
  --muted-2:    #8A7C6C;
  --terra:      #A23B2B;   /* terracotta / Italian red */
  --terra-deep: #7C2A20;
  --wine:       #611C27;   /* bordeaux */
  --gold:       #B08A4F;
  --gold-2:     #C9A96A;
  --line:       rgba(33,28,24,.14);
  --line-light: rgba(255,255,255,.16);

  /* Type */
  --serif: "Cormorant Garamond", "Times New Roman", Georgia, serif;
  --sans:  "Jost", "Helvetica Neue", Arial, sans-serif;

  /* Metrics */
  --wrap: 1220px;
  --gutter: clamp(20px, 5vw, 72px);
  --radius: 3px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ 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; } }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-weight:300;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,video{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }

/* ---------- Typography helpers ---------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.05; letter-spacing:.01em; }
.eyebrow{
  font-family:var(--sans);
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:12px;
  color:var(--terra);
  display:inline-flex;
  align-items:center;
  gap:.75em;
}
.eyebrow::before{
  content:""; width:34px; height:1px; background:var(--gold); display:inline-block;
}
.eyebrow.center::after{
  content:""; width:34px; height:1px; background:var(--gold); display:inline-block;
}
.eyebrow.center{ justify-content:center; }
.sec-num{
  font-family:var(--serif);
  font-style:italic;
  font-size:15px;
  color:var(--gold);
  letter-spacing:.05em;
}
.display{
  font-size:clamp(2.6rem, 6vw, 5rem);
  line-height:1.02;
  font-weight:500;
}
.display em{ font-style:italic; color:var(--terra); }
.lead{
  font-size:clamp(1.05rem,1.4vw,1.22rem);
  color:var(--muted);
  font-weight:300;
}
.serif-accent{ font-family:var(--serif); font-style:italic; }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(72px,10vw,140px); position:relative; }
.section-head{ max-width:720px; margin-bottom:clamp(38px,5vw,64px); }
.section-head .display{ margin-top:.28em; }
.center-head{ margin-inline:auto; text-align:center; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.7em;
  font-family:var(--sans); font-weight:500; font-size:13px;
  letter-spacing:.18em; text-transform:uppercase;
  padding:16px 30px; border-radius:2px;
  transition:all .4s var(--ease);
  position:relative; cursor:pointer; white-space:nowrap;
}
.btn-primary{ background:var(--terra); color:#fff; }
.btn-primary:hover{ background:var(--terra-deep); transform:translateY(-2px); box-shadow:0 12px 30px -12px rgba(124,42,32,.7); }
.btn-outline{ border:1px solid currentColor; color:var(--ink); }
.btn-outline:hover{ background:var(--ink); color:var(--cream); }
.btn-ghost-light{ border:1px solid rgba(255,255,255,.5); color:#fff; }
.btn-ghost-light:hover{ background:#fff; color:var(--ink); }
.btn-gold{ background:var(--gold); color:var(--dark); }
.btn-gold:hover{ background:var(--gold-2); transform:translateY(-2px); }
.link-underline{
  position:relative; font-size:13px; letter-spacing:.18em; text-transform:uppercase;
  font-weight:500; padding-bottom:4px; display:inline-flex; gap:.6em; align-items:center;
}
.link-underline::after{
  content:""; position:absolute; left:0; bottom:0; width:100%; height:1px;
  background:currentColor; transform:scaleX(.35); transform-origin:left; transition:transform .45s var(--ease); opacity:.5;
}
.link-underline:hover::after{ transform:scaleX(1); opacity:1; }

/* =========================================================
   Header / Navigation
   ========================================================= */
.header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  padding:22px 0;
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.header.scrolled{
  background:var(--cream);
  padding:12px 0;
  box-shadow:0 1px 0 var(--line), 0 10px 40px -24px rgba(0,0,0,.4);
}
.brand{ display:flex; align-items:center; gap:14px; color:#fff; transition:color .5s var(--ease); }
.header.scrolled .brand{ color:var(--ink); }
.brand-mark{ width:40px; height:40px; flex:none; }
.brand-mark path, .brand-mark circle, .brand-mark line, .brand-mark rect{ stroke:currentColor; }
.brand-txt{ display:flex; flex-direction:column; line-height:1; }
.brand-txt .t1{ font-family:var(--serif); font-size:20px; letter-spacing:.04em; }
.brand-txt .t2{ font-family:var(--sans); font-size:9.5px; letter-spacing:.42em; text-transform:uppercase; margin-top:4px; opacity:.85; }

.nav{ display:flex; align-items:center; gap:34px; }
.nav a{
  font-size:13px; letter-spacing:.12em; text-transform:uppercase; font-weight:400;
  color:rgba(255,255,255,.9); transition:color .3s; position:relative; padding:4px 0;
}
.header.scrolled .nav a{ color:var(--ink); }
.nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; width:100%; height:1px;
  background:var(--terra); transform:scaleX(0); transform-origin:center; transition:transform .35s var(--ease);
}
.nav a:hover::after, .nav a.active::after{ transform:scaleX(1); }
.header.scrolled .nav a:hover{ color:var(--terra); }

.header-actions{ display:flex; align-items:center; gap:18px; }
.header-tel{ display:flex; align-items:center; gap:8px; color:#fff; font-size:14px; letter-spacing:.04em; transition:color .5s; white-space:nowrap; }
.header.scrolled .header-tel{ color:var(--ink); }
.header-tel svg{ width:15px; height:15px; }

/* burger */
.burger{ display:none; width:30px; height:20px; position:relative; z-index:110; }
.burger span{ position:absolute; left:0; height:2px; width:100%; background:#fff; transition:.4s var(--ease); }
.header.scrolled .burger span, .nav-open .burger span{ background:var(--ink); }
.burger span:nth-child(1){ top:0; }
.burger span:nth-child(2){ top:9px; }
.burger span:nth-child(3){ top:18px; }
.nav-open .burger span:nth-child(1){ top:9px; transform:rotate(45deg); }
.nav-open .burger span:nth-child(2){ opacity:0; }
.nav-open .burger span:nth-child(3){ top:9px; transform:rotate(-45deg); }

/* =========================================================
   Hero
   ========================================================= */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; }
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(15,11,9,.55) 0%, rgba(15,11,9,.25) 35%, rgba(15,11,9,.55) 75%, rgba(15,11,9,.85) 100%);
}
.hero-media img{
  width:100%; height:100%; object-fit:cover;
  animation:kenburns 22s ease-out infinite alternate;
}
@keyframes kenburns{ from{ transform:scale(1.04) translate(0,0);} to{ transform:scale(1.16) translate(-1.5%,-1.5%);} }
@media (prefers-reduced-motion: reduce){ .hero-media img{ animation:none; } }

.hero-inner{ position:relative; z-index:2; width:100%; color:#fff; padding-top:80px; }
.hero-eyebrow{ color:var(--gold-2); }
.hero-eyebrow::before{ background:var(--gold-2); }
.hero h1{
  font-size:clamp(3rem, 8.5vw, 7rem);
  line-height:.98; margin:.18em 0 .32em;
  font-weight:500; letter-spacing:.005em;
  text-shadow:0 2px 40px rgba(0,0,0,.35);
}
.hero h1 em{ font-style:italic; color:var(--gold-2); display:block; }
.hero p.lead{ color:rgba(255,255,255,.9); max-width:540px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:16px; margin-top:38px; }

/* Google badge */
.gbadge{
  display:inline-flex; align-items:center; gap:14px;
  background:rgba(255,255,255,.10); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.22);
  padding:12px 20px; border-radius:100px; margin-top:34px;
}
.gbadge .g-logo{ width:22px; height:22px; flex:none; }
.gbadge .g-score{ font-family:var(--serif); font-size:22px; font-weight:600; line-height:1; }
.gbadge .g-stars{ display:flex; gap:2px; color:#F5B301; }
.gbadge .g-stars svg{ width:13px; height:13px; }
.gbadge .g-txt{ font-size:12px; letter-spacing:.03em; color:rgba(255,255,255,.82); line-height:1.3; }
.gbadge .g-txt b{ font-weight:500; color:#fff; }

.hero-scroll{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:3;
  color:rgba(255,255,255,.7); font-size:10px; letter-spacing:.3em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.hero-scroll .line{ width:1px; height:46px; background:linear-gradient(#fff,transparent); animation:scrolldot 2.2s infinite; }
@keyframes scrolldot{ 0%{ transform:scaleY(0); transform-origin:top;} 45%{ transform:scaleY(1); transform-origin:top;} 55%{ transform:scaleY(1); transform-origin:bottom;} 100%{ transform:scaleY(0); transform-origin:bottom;} }

/* =========================================================
   Marquee strip
   ========================================================= */
.marquee{ background:var(--dark); color:var(--cream); padding:16px 0; overflow:hidden; white-space:nowrap; }
.marquee-track{ display:inline-flex; gap:0; animation:marq 34s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ font-family:var(--serif); font-style:italic; font-size:20px; padding:0 32px; display:inline-flex; align-items:center; gap:32px; color:var(--cream); }
.marquee-track span::after{ content:"✦"; color:var(--gold); font-size:12px; font-style:normal; }
@keyframes marq{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* =========================================================
   About
   ========================================================= */
.about{ background:var(--cream); }
.about-grid{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(36px,6vw,90px); align-items:center; }
.about-copy p{ margin-bottom:1.1em; color:var(--muted); }
.about-copy p:first-of-type{ font-family:var(--serif); font-size:clamp(1.4rem,2.2vw,1.9rem); line-height:1.4; color:var(--ink); font-style:italic; font-weight:400; }
.about-sign{ margin-top:26px; display:flex; align-items:center; gap:18px; }
.about-sign .name{ font-family:var(--serif); font-size:26px; font-style:italic; }
.about-sign .role{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted-2); }

.about-visual{ position:relative; }
.about-visual .img-main{ aspect-ratio:4/5; overflow:hidden; border-radius:2px; }
.about-visual .img-main img{ width:100%; height:100%; object-fit:cover; }
.about-badge{
  position:absolute; bottom:-28px; left:-28px;
  background:var(--terra); color:#fff; width:150px; height:150px; border-radius:50%;
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  box-shadow:0 20px 50px -18px rgba(124,42,32,.7);
}
.about-badge .n{ font-family:var(--serif); font-size:44px; line-height:1; }
.about-badge .l{ font-size:10px; letter-spacing:.2em; text-transform:uppercase; margin-top:6px; max-width:100px; }

/* stat row */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:44px; border-top:1px solid var(--line); padding-top:32px; }
.stat .n{ font-family:var(--serif); font-size:clamp(2.2rem,4vw,3rem); color:var(--terra); line-height:1; }
.stat .l{ font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-top:8px; }

/* =========================================================
   Reel (Instagram-style video)
   ========================================================= */
.reel{ position:relative; border-radius:26px; overflow:hidden; background:#000; box-shadow:0 30px 70px -30px rgba(0,0,0,.6); }
.reel::before{ content:""; position:absolute; inset:0; border:1px solid rgba(255,255,255,.12); border-radius:26px; z-index:3; pointer-events:none; }
.reel video{ width:100%; aspect-ratio:9/16; object-fit:cover; display:block; }
.reel-tag{
  position:absolute; top:14px; left:14px; z-index:4;
  display:flex; align-items:center; gap:8px; color:#fff; font-size:12px; letter-spacing:.05em;
  background:rgba(0,0,0,.35); backdrop-filter:blur(6px); padding:7px 12px; border-radius:100px;
}
.reel-tag svg{ width:15px; height:15px; }
.reel-mute{
  position:absolute; bottom:14px; right:14px; z-index:4; width:38px; height:38px; border-radius:50%;
  background:rgba(0,0,0,.4); backdrop-filter:blur(6px); display:flex; align-items:center; justify-content:center; color:#fff;
  border:1px solid rgba(255,255,255,.2); transition:background .3s;
}
.reel-mute:hover{ background:rgba(0,0,0,.65); }
.reel-mute svg{ width:16px; height:16px; }

/* =========================================================
   Kulinarik / Dishes
   ========================================================= */
.cuisine{ background:var(--cream-2); }
.cuisine-lead{ display:grid; grid-template-columns:1fr auto; gap:30px; align-items:end; }
.menu-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,30px); margin-top:14px; }
.dish{ position:relative; }
.dish-img{ aspect-ratio:3/4; overflow:hidden; border-radius:2px; position:relative; }
.dish-img img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.dish:hover .dish-img img{ transform:scale(1.07); }
.dish-img::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 45%, rgba(20,15,12,.72)); }
.dish-cap{ position:absolute; left:22px; right:22px; bottom:20px; z-index:2; color:#fff; }
.dish-cap .k{ font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-2); }
.dish-cap .t{ font-family:var(--serif); font-size:1.55rem; line-height:1.1; margin-top:4px; }
.dish-cap .d{ font-size:13.5px; color:rgba(255,255,255,.78); margin-top:6px; font-weight:300; }

.menu-cta{ display:flex; flex-wrap:wrap; gap:16px; justify-content:center; margin-top:52px; }

/* two-up feature (reel + text) */
.feature-split{ display:grid; grid-template-columns:340px 1fr; gap:clamp(30px,5vw,72px); align-items:center; }
.feature-split .txt h3{ font-size:clamp(1.9rem,3vw,2.6rem); margin:.2em 0 .5em; }
.feature-split .txt p{ color:var(--muted); margin-bottom:1em; }

/* =========================================================
   Wine (dark section)
   ========================================================= */
.wine-sec{ background:var(--dark); color:var(--cream); position:relative; overflow:hidden; }
.wine-sec .eyebrow{ color:var(--gold-2); }
.wine-sec .eyebrow::before{ background:var(--gold); }
.wine-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,90px); align-items:center; }
.wine-copy .display{ color:var(--cream); }
.wine-copy .display em{ color:var(--gold-2); }
.wine-copy p{ color:rgba(246,239,226,.72); margin:1.2em 0 1.6em; }
.wine-quote{
  font-family:var(--serif); font-style:italic; font-size:clamp(1.5rem,2.6vw,2.1rem);
  color:var(--cream); line-height:1.4; border-left:2px solid var(--gold); padding-left:26px; margin:8px 0 30px;
}
.wine-quote span{ display:block; font-size:12px; font-style:normal; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-2); margin-top:14px; font-family:var(--sans); }
.wine-visual{ position:relative; }
.wine-visual img{ aspect-ratio:4/5; object-fit:cover; width:100%; border-radius:2px; }
.wine-visual .frame{ position:absolute; inset:16px; border:1px solid var(--line-light); pointer-events:none; }

/* =========================================================
   Events
   ========================================================= */
.events{ background:var(--paper); }
.events-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(18px,2.4vw,28px); }
.event-card{
  position:relative; overflow:hidden; border-radius:2px; min-height:300px;
  display:flex; align-items:flex-end; padding:32px; color:#fff;
}
.event-card.tall{ grid-column:1; grid-row:1 / span 2; min-height:auto; }
.event-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); z-index:0; }
.event-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,15,12,.15) 30%,rgba(20,15,12,.8)); z-index:1; }
.event-card:hover img{ transform:scale(1.06); }
.event-card .ec-body{ position:relative; z-index:2; }
.event-card .ec-k{ font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-2); }
.event-card .ec-t{ font-family:var(--serif); font-size:clamp(1.6rem,2.4vw,2.1rem); margin:6px 0 8px; line-height:1.05; overflow-wrap:break-word; hyphens:auto; }
.event-card .ec-d{ font-size:14px; color:rgba(255,255,255,.82); max-width:44ch; font-weight:300; }
.events-cols{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(18px,2.4vw,28px); }

/* =========================================================
   Gallery
   ========================================================= */
.gallery{ background:var(--cream); }
.gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:210px; gap:12px; grid-auto-flow:dense; }
.gal-item{ overflow:hidden; border-radius:2px; position:relative; cursor:pointer; }
.gal-item img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.gal-item:hover img{ transform:scale(1.08); }
.gal-item::after{ content:"+"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:34px; color:#fff; background:rgba(20,15,12,.28); opacity:0; transition:opacity .4s; }
.gal-item:hover::after{ opacity:1; }
.gal-item.wide{ grid-column:span 2; }
.gal-item.tall{ grid-row:span 2; }

/* lightbox */
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(12,9,7,.94); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .4s; padding:30px; }
.lightbox.open{ opacity:1; pointer-events:auto; }
.lightbox img{ max-width:min(1000px,92vw); max-height:88vh; object-fit:contain; border-radius:2px; }
.lb-close,.lb-nav{ position:absolute; color:#fff; width:52px; height:52px; display:flex; align-items:center; justify-content:center; font-size:26px; opacity:.8; transition:opacity .3s; }
.lb-close{ top:22px; right:26px; }
.lb-nav.prev{ left:16px; top:50%; transform:translateY(-50%); font-family:var(--serif); }
.lb-nav.next{ right:16px; top:50%; transform:translateY(-50%); font-family:var(--serif); }
.lb-close:hover,.lb-nav:hover{ opacity:1; }

/* =========================================================
   Reviews
   ========================================================= */
.reviews{ background:var(--dark-2); color:var(--cream); text-align:center; }
.reviews .eyebrow{ color:var(--gold-2); }
.reviews .eyebrow::before,.reviews .eyebrow.center::after{ background:var(--gold); }
.rev-score{ display:flex; align-items:center; justify-content:center; gap:20px; margin:26px 0 8px; flex-wrap:wrap; }
.rev-score .num{ font-family:var(--serif); font-size:clamp(3.4rem,7vw,5rem); line-height:1; color:var(--gold-2); }
.rev-score .meta{ text-align:left; }
.rev-score .stars{ display:flex; gap:3px; color:#F5B301; }
.rev-score .stars svg{ width:20px; height:20px; }
.rev-score .cnt{ font-size:13px; color:rgba(246,239,226,.7); letter-spacing:.04em; margin-top:6px; }
.rev-track{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; text-align:left; }
.rev-card{ background:rgba(255,255,255,.04); border:1px solid var(--line-light); padding:32px; border-radius:3px; }
.rev-card .q{ font-family:var(--serif); font-style:italic; font-size:1.28rem; line-height:1.45; color:var(--cream); }
.rev-card .stars{ display:flex; gap:2px; color:#F5B301; margin-bottom:16px; }
.rev-card .stars svg{ width:15px; height:15px; }
.rev-card .who{ margin-top:20px; font-size:13px; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-2); }
.rev-cta{ margin-top:46px; }

/* =========================================================
   Reservation CTA
   ========================================================= */
.reserve{ position:relative; color:#fff; overflow:hidden; }
.reserve-bg{ position:absolute; inset:0; z-index:0; }
.reserve-bg img{ width:100%; height:100%; object-fit:cover; }
.reserve-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(16,11,9,.78),rgba(16,11,9,.88)); }
.reserve .wrap{ position:relative; z-index:2; text-align:center; }
.reserve .display{ color:#fff; }
.reserve .display em{ color:var(--gold-2); }
.reserve p{ color:rgba(255,255,255,.82); max-width:560px; margin:20px auto 0; }
.reserve-info{ display:flex; flex-wrap:wrap; justify-content:center; gap:14px 46px; margin:40px 0 8px; }
.reserve-info .ri{ display:flex; flex-direction:column; align-items:center; gap:4px; }
.reserve-info .ri .k{ font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-2); }
.reserve-info .ri .v{ font-family:var(--serif); font-size:1.3rem; }
.reserve-info .ri a.v:hover{ color:var(--gold-2); }
.reserve-cta{ display:flex; flex-wrap:wrap; gap:16px; justify-content:center; margin-top:38px; }

/* =========================================================
   Footer
   ========================================================= */
.footer{ background:var(--dark); color:rgba(246,239,226,.72); padding-top:clamp(64px,8vw,96px); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:44px; padding-bottom:56px; border-bottom:1px solid var(--line-light); }
.footer h4{ font-family:var(--sans); font-size:12px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-2); margin-bottom:22px; font-weight:500; }
.footer .f-brand .brand-txt .t1{ color:var(--cream); }
.footer .f-brand{ color:var(--cream); }
.footer .f-about{ margin-top:20px; font-size:14.5px; line-height:1.7; max-width:34ch; }
.footer address{ font-style:normal; line-height:2; font-size:15px; }
.footer address a:hover{ color:var(--gold-2); }
.footer .hours-row{ display:flex; justify-content:space-between; gap:16px; font-size:14.5px; padding:5px 0; border-bottom:1px dashed rgba(255,255,255,.08); }
.footer .hours-row span:last-child{ color:var(--cream); white-space:nowrap; }
.f-social{ display:flex; gap:12px; margin-top:22px; }
.f-social a{ width:40px; height:40px; border:1px solid var(--line-light); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--cream); transition:all .35s var(--ease); }
.f-social a:hover{ background:var(--terra); border-color:var(--terra); transform:translateY(-3px); }
.f-social svg{ width:17px; height:17px; }
.f-map{ margin-top:0; }
.f-map iframe{ width:100%; height:170px; border:0; border-radius:3px; filter:grayscale(1) contrast(1.05) brightness(.9); transition:filter .5s; }
.f-map iframe:hover{ filter:grayscale(0); }
.footer-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:14px; padding:26px 0 34px; font-size:13px; }
.footer-bottom .links{ display:flex; gap:22px; }
.footer-bottom a:hover{ color:var(--gold-2); }

/* =========================================================
   Scroll reveal
   ========================================================= */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.1s; } .reveal.d2{ transition-delay:.2s; } .reveal.d3{ transition-delay:.3s; } .reveal.d4{ transition-delay:.4s; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* =========================================================
   Legal pages
   ========================================================= */
.legal{ padding-top:clamp(120px,16vw,180px); padding-bottom:100px; background:var(--cream); }
.legal .wrap{ max-width:820px; }
.legal h1{ font-size:clamp(2.4rem,5vw,3.6rem); margin-bottom:.5em; }
.legal h2{ font-size:1.5rem; margin:1.6em 0 .5em; color:var(--terra); }
.legal h3{ font-size:1.15rem; margin:1.2em 0 .4em; font-family:var(--sans); font-weight:600; }
.legal p, .legal li{ color:var(--muted); margin-bottom:1em; font-size:16px; }
.legal ul{ list-style:disc; padding-left:22px; margin-bottom:1em; }
.legal a{ color:var(--terra); text-decoration:underline; text-underline-offset:3px; }
.legal .back{ margin-bottom:2em; display:inline-flex; }
.legal strong{ color:var(--ink); font-weight:600; }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:1020px){
  .about-grid,.wine-grid,.feature-split{ grid-template-columns:1fr; }
  .feature-split .reel{ max-width:320px; margin-inline:auto; }
  .menu-grid{ grid-template-columns:repeat(2,1fr); }
  .gallery-grid{ grid-template-columns:repeat(3,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:36px; }
  .about-visual{ max-width:460px; margin-inline:auto; width:100%; }
}
@media (max-width:760px){
  body{ font-size:16px; }
  .nav{
    position:fixed; inset:0; background:var(--cream); flex-direction:column; justify-content:center;
    align-items:center; text-align:center;
    gap:28px; transform:translateX(100%); transition:transform .5s var(--ease); z-index:105;
  }
  .nav-open .nav{ transform:translateX(0); }
  .nav a{ color:var(--ink) !important; font-size:20px; font-family:var(--serif); text-transform:none; letter-spacing:.02em; }
  .nav a::after{ display:none; }
  .burger{ display:block; }
  .header-tel span{ display:none; }
  .header-actions .btn{ display:none; }
  .cuisine-lead{ grid-template-columns:1fr; }
  .events-grid,.events-cols{ grid-template-columns:1fr; }
  .event-card.tall{ grid-row:auto; }
  .rev-track{ grid-template-columns:1fr; }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:150px; }
  .stats{ grid-template-columns:1fr 1fr; gap:24px 16px; }
  .about-badge{ width:120px; height:120px; left:auto; right:-12px; bottom:-24px; }
  .footer-grid{ grid-template-columns:1fr; }
  .marquee-track span{ font-size:17px; }
}
@media (max-width:460px){
  .menu-grid{ grid-template-columns:1fr; }
  .hero-cta{ flex-direction:column; align-items:flex-start; }
  .hero-cta .btn{ width:100%; }
}
