/* =========================================================
   Gasthaus Barthels Hof — Stylesheet
   Traditionell · warm · sächsische Gastlichkeit
   ========================================================= */

/* ---------- Design tokens ---------- */
:root{
  --gold:        #F5C518;
  --gold-deep:   #E1A80C;
  --gold-soft:   #FBE9A8;
  --crimson:     #A81D49;
  --crimson-br:  #C21E56;
  --crimson-dk:  #7C1435;

  --cream:       #FBF5E9;
  --cream-2:     #F5EAD4;
  --paper:       #FFFDF8;
  --ink:         #2A211C;
  --ink-soft:    #5F5147;
  --ink-mute:    #8A7A6C;

  --line:        rgba(42,33,28,.14);
  --line-soft:   rgba(42,33,28,.08);

  --serif: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:  'Mulish', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  --wrap: 1180px;
  --shadow-sm: 0 2px 12px rgba(42,33,28,.08);
  --shadow-md: 0 14px 40px rgba(42,33,28,.14);
  --shadow-lg: 0 30px 70px rgba(42,33,28,.22);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  font-size:1.0625rem;
  line-height:1.7;
  color:var(--ink);
  background-color:var(--cream);
  background-image:
    radial-gradient(1200px 600px at 15% -10%, rgba(245,197,24,.10), transparent 60%),
    radial-gradient(1000px 700px at 100% 0%, rgba(168,29,73,.05), transparent 55%);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:var(--crimson); text-decoration:none; transition:color .25s var(--ease); }
a:hover{ color:var(--crimson-dk); }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; line-height:1.08; color:var(--ink); margin:0 0 .4em; letter-spacing:.005em; }
p{ margin:0 0 1.1em; }
ul{ margin:0; padding:0; }
:focus-visible{ outline:3px solid var(--crimson-br); outline-offset:3px; border-radius:3px; }

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:clamp(1.15rem,4vw,2.5rem); }
.section{ padding-block:clamp(3.75rem,8vw,7rem); position:relative; }
.section--alt{ background:var(--cream-2); }
.section--dark{ background:#241a18; color:#f3e7d8; }
.center{ text-align:center; }
.narrow{ max-width:760px; margin-inline:auto; }

/* ---------- Eyebrow + section heads ---------- */
.eyebrow{
  font-family:var(--sans); font-weight:800;
  font-size:.72rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--crimson); display:inline-flex; align-items:center; gap:.85rem; margin-bottom:1rem;
}
.eyebrow::before,.eyebrow::after{ content:""; width:26px; height:2px; background:var(--gold-deep); display:inline-block; }
.eyebrow.solo::after{ display:none; }
.section-title{ font-size:clamp(2.1rem,5vw,3.4rem); margin-bottom:.35em; }
.section-lead{ font-family:var(--serif); font-size:clamp(1.25rem,2.4vw,1.6rem); color:var(--ink-soft); line-height:1.5; font-weight:500; }

/* ornament divider (echoes the logo) */
.ornament{ display:flex; align-items:center; justify-content:center; gap:6px; margin:1.1rem 0; }
.ornament i{ height:4px; border-radius:2px; display:block; }
.ornament .l{ width:46px; background:var(--crimson); }
.ornament .a{ width:16px; background:var(--gold-deep); }
.ornament .b{ width:16px; background:#93A05A; }
.ornament .c{ width:16px; background:#3E8E9D; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--crimson); --fg:#fff;
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--sans); font-weight:800; font-size:.82rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--fg); background:var(--bg);
  padding:.95rem 1.7rem; border-radius:999px; border:2px solid var(--bg);
  cursor:pointer; transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
  box-shadow:0 8px 22px rgba(168,29,73,.28);
}
.btn:hover{ transform:translateY(-3px); box-shadow:0 14px 30px rgba(168,29,73,.36); color:#fff; background:var(--crimson-dk); border-color:var(--crimson-dk); }
.btn--gold{ --bg:var(--gold); --fg:var(--ink); box-shadow:0 8px 22px rgba(225,168,12,.34); }
.btn--gold:hover{ background:var(--gold-deep); border-color:var(--gold-deep); color:var(--ink); }
.btn--ghost{ background:transparent; color:var(--crimson); border-color:currentColor; box-shadow:none; }
.btn--ghost:hover{ background:var(--crimson); color:#fff; border-color:var(--crimson); }
.btn--light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.6); box-shadow:none; }
.btn--light:hover{ background:#fff; color:var(--ink); border-color:#fff; }

/* =========================================================
   Header / Navigation
   ========================================================= */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .35s var(--ease), box-shadow .35s var(--ease), padding .35s var(--ease);
  padding-block:.55rem;
}
.site-header::before{
  content:""; position:absolute; inset:0; background:var(--cream);
  opacity:0; transition:opacity .35s var(--ease); box-shadow:var(--shadow-sm); z-index:-1;
}
.site-header.scrolled::before{ opacity:.97; }
.site-header.scrolled{ box-shadow:var(--shadow-sm); }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand img{ width:52px; height:52px; border-radius:11px; box-shadow:0 4px 14px rgba(42,33,28,.18); transition:width .35s var(--ease), height .35s var(--ease); }
.brand-txt{ display:flex; flex-direction:column; line-height:1; }
.brand-txt b{ font-family:var(--serif); font-weight:600; font-size:1.5rem; color:var(--crimson); letter-spacing:.01em; }
.brand-txt span{ font-family:var(--sans); font-weight:800; font-size:.6rem; letter-spacing:.34em; color:var(--ink-soft); text-transform:uppercase; margin-top:2px; }
/* header text color when transparent (over hero) */
.site-header:not(.scrolled) .brand-txt b{ color:#fff; }
.site-header:not(.scrolled) .brand-txt span{ color:rgba(255,255,255,.82); }
.site-header:not(.scrolled) .nav-links a{ color:#fff; }
.site-header:not(.scrolled) .nav-links a::after{ background:var(--gold); }

.nav-links{ display:flex; align-items:center; gap:1.7rem; list-style:none; }
.nav-links a{
  font-family:var(--sans); font-weight:700; font-size:.9rem; color:var(--ink);
  letter-spacing:.02em; position:relative; padding:.2rem 0;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-3px; height:2px; width:0; background:var(--crimson);
  transition:width .3s var(--ease);
}
.nav-links a:hover::after,.nav-links a.active::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:.9rem; }
.nav-tel{ display:inline-flex; align-items:center; gap:.5rem; font-weight:800; font-size:.9rem; color:inherit; white-space:nowrap; }
.site-header:not(.scrolled) .nav-tel{ color:#fff; }

.nav-toggle{ display:none; }
.only-mobile{ display:none; }

/* =========================================================
   Hero
   ========================================================= */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center; justify-content:center;
  text-align:center; color:#fff; overflow:hidden; padding:7rem 1.25rem 5rem;
}
.hero__bg{ position:absolute; inset:0; z-index:-2; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; transform:scale(1.05); }
.hero__bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(30,18,16,.62) 0%, rgba(30,18,16,.34) 38%, rgba(30,18,16,.55) 72%, rgba(30,18,16,.82) 100%),
    radial-gradient(120% 80% at 50% 40%, transparent 40%, rgba(20,12,10,.55) 100%);
}
.hero__inner{ position:relative; max-width:920px; }
.hero__logo{ width:clamp(150px,20vw,220px); margin:0 auto 1.6rem; filter:drop-shadow(0 12px 26px rgba(0,0,0,.35)); }
.hero__logo svg,.hero__logo img{ width:100%; height:auto; border-radius:22px; }
.hero h1{
  color:#fff; font-size:clamp(2.6rem,7vw,5.2rem); line-height:1; margin-bottom:.2em;
  text-shadow:0 4px 30px rgba(0,0,0,.4);
}
.hero__tag{
  font-family:var(--serif); font-style:italic; font-weight:500;
  font-size:clamp(1.3rem,3.4vw,2rem); color:var(--gold-soft); margin-bottom:.5em;
}
.hero__sub{ font-size:clamp(1rem,1.7vw,1.2rem); color:rgba(255,255,255,.9); max-width:620px; margin:0 auto 2rem; }
.hero__cta{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.hero__ornament i{ height:4px; }
.hero__ornament{ margin-bottom:1.4rem; }
.hero__ornament .l{ background:var(--gold); }

/* opening-hours ribbon under hero */
.ribbon{
  background:var(--crimson); color:#fff; position:relative; z-index:2;
}
.ribbon .wrap{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:.6rem 2.4rem; padding-block:1.05rem; text-align:center; }
.ribbon strong{ font-family:var(--serif); font-size:1.35rem; font-weight:600; }
.ribbon span{ font-weight:700; letter-spacing:.02em; font-size:.98rem; }
.ribbon .dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); display:inline-block; }
.ribbon a{ color:var(--gold-soft); font-weight:800; }
.ribbon a:hover{ color:#fff; }

/* scroll cue */
.scroll-cue{
  position:absolute; left:50%; bottom:1.6rem; transform:translateX(-50%); z-index:2;
  color:rgba(255,255,255,.8); font-size:.7rem; letter-spacing:.25em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:.5rem;
}
.scroll-cue::after{ content:""; width:1px; height:34px; background:linear-gradient(rgba(255,255,255,.8),transparent); animation:cue 1.8s var(--ease) infinite; }
@keyframes cue{ 0%{ transform:scaleY(.3); transform-origin:top; opacity:.4 } 50%{ transform:scaleY(1); opacity:1 } 100%{ transform:scaleY(.3); transform-origin:bottom; opacity:.4 } }

/* =========================================================
   Welcome / About  (split)
   ========================================================= */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.split.reverse .split__media{ order:2; }
.split__media{ position:relative; }
.frame{
  position:relative; border-radius:6px; overflow:hidden; box-shadow:var(--shadow-md);
  border:1px solid rgba(255,255,255,.5);
}
.frame img{ width:100%; height:100%; object-fit:cover; }
.frame--tall img{ aspect-ratio:4/5; }
/* decorative gold corner ticks */
.media-deco{ position:absolute; inset:0; pointer-events:none; }
.media-deco::before,.media-deco::after{
  content:""; position:absolute; width:64px; height:64px; border:3px solid var(--gold-deep);
}
.media-deco::before{ top:-14px; left:-14px; border-right:0; border-bottom:0; }
.media-deco::after{ bottom:-14px; right:-14px; border-left:0; border-top:0; }
.badge-est{
  position:absolute; bottom:-26px; right:24px; width:104px; height:104px; border-radius:50%;
  background:var(--crimson); color:#fff; display:grid; place-content:center; text-align:center;
  box-shadow:var(--shadow-md); border:3px solid var(--gold);
}
.badge-est b{ font-family:var(--serif); font-size:1.7rem; line-height:1; color:#fff; }
.badge-est small{ display:block; font-size:.52rem; letter-spacing:.18em; text-transform:uppercase; margin-top:3px; color:var(--gold-soft); }

.stats{ display:flex; gap:2.2rem; flex-wrap:wrap; margin-top:1.8rem; }
.stat b{ font-family:var(--serif); font-size:2.5rem; color:var(--crimson); display:block; line-height:1; }
.stat span{ font-size:.85rem; color:var(--ink-soft); font-weight:600; }

/* pull quote */
.pullquote{ font-family:var(--serif); font-style:italic; font-size:clamp(1.5rem,3.5vw,2.3rem); line-height:1.4; color:var(--crimson-dk); }
.pullquote .mark{ color:var(--gold-deep); }

/* =========================================================
   History timeline
   ========================================================= */
.timeline{ position:relative; margin-top:3rem; }
.timeline::before{ content:""; position:absolute; left:50%; top:0; bottom:0; width:2px; background:linear-gradient(var(--gold-deep),var(--line)); transform:translateX(-50%); }
.tl-item{ position:relative; width:50%; padding:0 3rem 2.6rem; }
.tl-item:nth-child(odd){ left:0; text-align:right; }
.tl-item:nth-child(even){ left:50%; text-align:left; }
.tl-item::before{
  content:""; position:absolute; top:.35rem; width:18px; height:18px; border-radius:50%;
  background:var(--gold); border:4px solid var(--crimson); box-shadow:0 0 0 5px var(--cream);
}
.tl-item:nth-child(odd)::before{ right:-9px; }
.tl-item:nth-child(even)::before{ left:-9px; }
.tl-year{ font-family:var(--serif); font-size:1.9rem; font-weight:600; color:var(--crimson); line-height:1; }
.tl-item h3{ font-size:1.25rem; margin:.35rem 0 .3rem; }
.tl-item p{ color:var(--ink-soft); font-size:.98rem; margin:0; }

/* =========================================================
   Cuisine / specialties cards
   ========================================================= */
.dish-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; margin-top:2.8rem; }
.dish{
  background:var(--paper); border-radius:8px; overflow:hidden; box-shadow:var(--shadow-sm);
  border:1px solid var(--line-soft); transition:transform .35s var(--ease), box-shadow .35s var(--ease);
  display:flex; flex-direction:column;
}
.dish:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); }
.dish__img{ aspect-ratio:3/2; overflow:hidden; }
.dish__img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.dish:hover .dish__img img{ transform:scale(1.07); }
.dish__body{ padding:1.35rem 1.5rem 1.6rem; flex:1; display:flex; flex-direction:column; }
.dish__body h3{ font-size:1.5rem; margin-bottom:.15em; }
.dish__body p{ font-size:.95rem; color:var(--ink-soft); margin-bottom:1rem; flex:1; }
.dish__price{ font-family:var(--serif); font-weight:600; font-size:1.35rem; color:var(--crimson); }
.dish__tag{ font-size:.68rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); }

/* feature strip: Familienessen */
.feature{
  margin-top:3.5rem; display:grid; grid-template-columns:1.1fr 1fr; align-items:stretch;
  border-radius:10px; overflow:hidden; box-shadow:var(--shadow-md); background:var(--crimson);
}
.feature__img{ min-height:340px; }
.feature__img img{ width:100%; height:100%; object-fit:cover; }
.feature__body{ color:#fff; padding:clamp(2rem,4vw,3.4rem); display:flex; flex-direction:column; justify-content:center; }
.feature__body .eyebrow{ color:var(--gold); }
.feature__body .eyebrow::before,.feature__body .eyebrow::after{ background:var(--gold); }
.feature__body h3{ color:#fff; font-size:clamp(1.9rem,3.5vw,2.7rem); }
.feature__body p{ color:rgba(255,255,255,.9); }
.feature__price{ display:flex; align-items:baseline; gap:.5rem; margin:.4rem 0 1.4rem; }
.feature__price b{ font-family:var(--serif); font-size:2.6rem; color:var(--gold); line-height:1; }
.feature__price span{ color:rgba(255,255,255,.8); font-size:.9rem; }

.menu-note{ margin-top:2.5rem; text-align:center; color:var(--ink-soft); }

/* =========================================================
   Gallery
   ========================================================= */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:1rem; margin-top:2.8rem; }
.g-item{ position:relative; overflow:hidden; border-radius:6px; cursor:pointer; box-shadow:var(--shadow-sm); }
.g-item img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.g-item:hover img{ transform:scale(1.08); }
.g-item::after{
  content:""; position:absolute; inset:0; background:linear-gradient(0deg,rgba(124,20,53,.45),transparent 55%);
  opacity:0; transition:opacity .3s var(--ease);
}
.g-item:hover::after{ opacity:1; }
.g-item figcaption{
  position:absolute; left:0; right:0; bottom:0; padding:.9rem 1rem; color:#fff; font-family:var(--serif);
  font-size:1.05rem; z-index:2; transform:translateY(8px); opacity:0; transition:.3s var(--ease);
}
.g-item:hover figcaption{ transform:none; opacity:1; }
.g-wide{ grid-column:span 2; }
.g-tall{ grid-row:span 2; }

/* lightbox */
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(20,12,10,.92); display:none; align-items:center; justify-content:center; padding:2rem; }
.lightbox.open{ display:flex; }
.lightbox img{ max-width:92vw; max-height:82vh; border-radius:6px; box-shadow:var(--shadow-lg); }
.lightbox figcaption{ position:absolute; bottom:1.4rem; left:0; right:0; text-align:center; color:#fff; font-family:var(--serif); font-size:1.15rem; }
.lb-close,.lb-nav{ position:absolute; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.3); color:#fff; width:52px; height:52px; border-radius:50%; font-size:1.5rem; cursor:pointer; display:grid; place-content:center; transition:background .25s; }
.lb-close:hover,.lb-nav:hover{ background:var(--crimson); }
.lb-close{ top:1.4rem; right:1.4rem; }
.lb-nav{ top:50%; transform:translateY(-50%); }
.lb-prev{ left:1.4rem; } .lb-next{ right:1.4rem; }

/* =========================================================
   Visit: hours · google · map
   ========================================================= */
.visit-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,3vw,2.5rem); align-items:stretch; }
.info-card{ background:var(--paper); border-radius:10px; padding:clamp(1.8rem,3vw,2.6rem); box-shadow:var(--shadow-sm); border:1px solid var(--line-soft); }
.info-card h3{ font-size:1.7rem; display:flex; align-items:center; gap:.6rem; margin-bottom:.9rem; }
.hours-list{ list-style:none; }
.hours-list li{ display:flex; justify-content:space-between; gap:1rem; padding:.6rem 0; border-bottom:1px dashed var(--line); font-size:1rem; }
.hours-list li:last-child{ border-bottom:0; }
.hours-list .day{ font-weight:700; color:var(--ink); }
.hours-list .open{ color:var(--crimson); font-weight:800; }
.info-line{ display:flex; align-items:flex-start; gap:.8rem; margin-bottom:.9rem; }
.info-line svg{ flex:none; width:22px; height:22px; color:var(--crimson); margin-top:3px; }
.info-line b{ display:block; font-family:var(--serif); font-size:1.15rem; }
.info-line span{ color:var(--ink-soft); font-size:.95rem; }

/* google review badge */
.google-badge{
  display:flex; align-items:center; gap:1.1rem; background:var(--paper); border:1px solid var(--line);
  border-radius:14px; padding:1.1rem 1.4rem; box-shadow:var(--shadow-sm); text-decoration:none; color:var(--ink);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.google-badge:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); color:var(--ink); }
.google-badge .g-logo{ width:42px; height:42px; flex:none; }
.google-badge .gb-score{ font-family:var(--serif); font-size:2.2rem; font-weight:700; line-height:1; color:var(--ink); }
.gb-main{ display:flex; align-items:center; gap:.9rem; }
.gb-meta{ display:flex; flex-direction:column; }
.stars{ --pct:86%; position:relative; display:inline-block; font-size:1.05rem; line-height:1; letter-spacing:2px; font-family:Arial,sans-serif; }
.stars::before{ content:"★★★★★"; color:#dcdce0; }
.stars::after{ content:"★★★★★"; color:#F5B400; position:absolute; left:0; top:0; width:var(--pct); overflow:hidden; }
.gb-count{ font-size:.86rem; color:var(--ink-soft); font-weight:600; }
.gb-cta{ margin-left:auto; font-size:.78rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--crimson); white-space:nowrap; }

.map-wrap{ border-radius:10px; overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line-soft); min-height:340px; }
.map-wrap iframe{ width:100%; height:100%; min-height:340px; border:0; display:block; filter:saturate(.92) contrast(1.02); }

.transit{ margin-top:1.4rem; display:grid; gap:.6rem; }
.transit li{ list-style:none; display:flex; gap:.7rem; align-items:flex-start; font-size:.95rem; color:var(--ink-soft); }
.transit b{ color:var(--ink); }
.pin{ color:var(--crimson); font-weight:900; }

/* =========================================================
   Footer
   ========================================================= */
.site-footer{ background:#1f1613; color:#e7d9c8; padding-block:clamp(3rem,6vw,4.5rem) 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.1fr; gap:2.4rem; }
.site-footer h4{ color:#fff; font-size:1.15rem; letter-spacing:.02em; margin-bottom:1rem; font-family:var(--sans); font-weight:800; text-transform:uppercase; font-size:.8rem; letter-spacing:.2em; }
.site-footer a{ color:#e7d9c8; }
.site-footer a:hover{ color:var(--gold); }
.footer-brand img{ width:88px; border-radius:14px; margin-bottom:1rem; }
.footer-brand p{ color:#bda893; font-size:.95rem; max-width:34ch; }
.footer-list{ list-style:none; display:grid; gap:.55rem; font-size:.95rem; }
.footer-contact{ display:grid; gap:.7rem; font-size:.95rem; color:#cbb8a4; }
.footer-contact b{ color:#fff; }
.footer-bottom{ margin-top:3rem; border-top:1px solid rgba(255,255,255,.12); padding-block:1.4rem; display:flex; flex-wrap:wrap; gap:.6rem 1.5rem; align-items:center; justify-content:space-between; font-size:.85rem; color:#9d8b79; }
.footer-bottom a{ color:#9d8b79; }
.footer-bottom nav{ display:flex; gap:1.4rem; flex-wrap:wrap; }

/* =========================================================
   Legal pages (Impressum / Datenschutz)
   ========================================================= */
/* keep header solid (no hero to sit over) */
body.legal-page .site-header::before{ opacity:.97; }
body.legal-page .site-header{ box-shadow:var(--shadow-sm); }
body.legal-page .site-header .brand-txt b{ color:var(--crimson); }
body.legal-page .site-header .brand-txt span,
body.legal-page .site-header .nav-links a,
body.legal-page .site-header .nav-tel{ color:var(--ink); }
body.legal-page .site-header .nav-links a::after{ background:var(--crimson); }
body.legal-page .site-header .nav-toggle span{ background:var(--ink); }

.legal{ padding-top:9rem; padding-bottom:5rem; }
.legal .wrap{ max-width:820px; }
.legal h1{ font-size:clamp(2.2rem,5vw,3.2rem); }
.legal h2{ font-size:1.5rem; color:var(--crimson); margin-top:2.2rem; padding-top:1.4rem; border-top:1px solid var(--line); }
.legal h3{ font-size:1.15rem; margin-top:1.4rem; }
.legal p,.legal li{ color:var(--ink-soft); }
.legal address{ font-style:normal; }
.back-link{ display:inline-flex; align-items:center; gap:.4rem; font-weight:700; margin-bottom:1.5rem; }

/* =========================================================
   Reveal on scroll
   ========================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s } .reveal.d2{ transition-delay:.16s } .reveal.d3{ transition-delay:.24s }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:960px){
  .nav-links, .nav-tel{ display:none; }
  .nav-cta > .btn{ display:none; }
  .only-mobile{ display:list-item; }
  .nav-links .only-mobile .btn{ display:inline-flex; margin-top:.4rem; }
  .nav-links .only-mobile a{ font-size:1rem; }
  .nav-toggle{
    display:inline-flex; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:.4rem; z-index:110;
  }
  .nav-toggle span{ width:26px; height:2.5px; background:var(--ink); border-radius:2px; transition:.3s var(--ease); }
  .site-header:not(.scrolled) .nav-toggle span{ background:#fff; }
  .site-header.menu-open .nav-toggle span{ background:var(--ink); }
  .site-header.menu-open .nav-toggle span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
  .site-header.menu-open .nav-toggle span:nth-child(2){ opacity:0; }
  .site-header.menu-open .nav-toggle span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }

  .nav-links{
    position:fixed; inset:0 0 0 auto; width:min(84vw,340px); background:var(--cream);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:1.6rem;
    padding:2rem 2.4rem; box-shadow:var(--shadow-lg); transform:translateX(100%); transition:transform .4s var(--ease);
  }
  .site-header.menu-open .nav-links{ display:flex; transform:none; }
  .site-header.menu-open .nav-links a:not(.btn),
  .site-header:not(.scrolled).menu-open .nav-links a:not(.btn){ color:var(--ink); font-size:1.2rem; }
  .site-header.menu-open .nav-links a.btn{ color:#fff; font-size:.82rem; }
  .nav-links li{ list-style:none; }
  .menu-open::before{ } /* placeholder */

  .split{ grid-template-columns:1fr; }
  .split.reverse .split__media{ order:0; }
  .dish-grid{ grid-template-columns:repeat(2,1fr); }
  .feature{ grid-template-columns:1fr; }
  .visit-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }

  .timeline::before{ left:9px; }
  .tl-item{ width:100%; left:0 !important; text-align:left !important; padding:0 0 2.4rem 2.6rem; }
  .tl-item::before{ left:0 !important; right:auto !important; }
}

@media (max-width:600px){
  body{ font-size:1rem; }
  .dish-grid{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:150px; }
  .g-wide{ grid-column:span 2; }
  .g-tall{ grid-row:span 1; }
  .footer-grid{ grid-template-columns:1fr; }
  .ribbon .wrap{ gap:.4rem 1.2rem; }
  .stats{ gap:1.4rem; }
  .badge-est{ width:84px; height:84px; right:14px; }
  .google-badge{ flex-wrap:wrap; }
  .gb-cta{ margin-left:0; width:100%; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}
