/* =========================================================
   CLAUDIO TROVATO — Chef Portfolio
   Light luxury: ivory white + navy (trust) + green + gold
   ========================================================= */

:root{
  /* palette — light */
  --bg:#FBF9F4;
  --bg-2:#F2EEE3;
  --bg-3:#EAF1EC;
  --ink:#1B2A40;
  --ink-soft:#46586E;
  --ink-faint:#8593A2;
  --navy:#173353;
  --navy-deep:#0F2336;
  --green:#2E5E4E;
  --green-deep:#214A3D;
  --gold:#C7A24E;        /* bright gold — fills, lines, accents on dark */
  --gold-ink:#8C6A22;    /* dark gold — text on light */
  --cream:#F4EFE4;
  --cream-dim:rgba(244,239,228,.76);
  --cream-faint:rgba(244,239,228,.52);
  --line:rgba(23,51,83,.14);
  --line-strong:rgba(23,51,83,.24);
  --line-cream:rgba(244,239,228,.16);
  --line-cream-strong:rgba(244,239,228,.32);

  /* type */
  --display:"Playfair Display",Georgia,"Times New Roman",serif;
  --body:"Source Serif 4",Georgia,serif;
  --sans:"Jost",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --script:"Caveat","Segoe Script",cursive;

  /* metrics */
  --maxw:1280px;
  --gut:clamp(20px,5vw,72px);
  --nav-h:74px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--navy-deep)}

h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.04;margin:0;letter-spacing:-.01em;color:var(--navy);text-wrap:balance}
p{margin:0 0 1.1em;text-wrap:pretty}
p:last-child{margin-bottom:0}

/* ---------- shared atoms ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--gold-ink);
  display:inline-flex;align-items:center;gap:.7em;
  margin:0 0 1.4rem;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--gold)}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--gold)}

.script-note{
  font-family:var(--script);
  font-size:clamp(1.5rem,2.4vw,2.1rem);
  line-height:1.15;
  color:var(--gold-ink);
}

.lead{font-size:clamp(1.15rem,1.7vw,1.45rem);line-height:1.65;color:var(--ink-soft)}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);font-size:.82rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  padding:1.05em 1.9em;border-radius:2px;cursor:pointer;
  transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease),transform .35s var(--ease);
}
.btn svg{width:1.05em;height:1.05em;transition:transform .35s var(--ease)}
.btn-primary{background:var(--gold);color:var(--navy-deep);border:1px solid var(--gold)}
.btn-primary:hover{background:#b78f3c;border-color:#b78f3c}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-strong)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-ghost:hover svg{transform:translateX(4px)}
.btn:focus-visible,a:focus-visible,button:focus-visible{outline:2px solid var(--gold-ink);outline-offset:3px}

/* ---------- header / nav ---------- */
.site-head{
  position:fixed;inset:0 0 auto 0;z-index:100;height:var(--nav-h);
  display:flex;align-items:center;
  background:rgba(251,249,244,.82);
  backdrop-filter:blur(12px) saturate(120%);
  -webkit-backdrop-filter:blur(12px) saturate(120%);
  border-bottom:1px solid transparent;
  transition:background .4s var(--ease),border-color .4s var(--ease),height .4s var(--ease),box-shadow .4s var(--ease);
}
.site-head.scrolled{
  background:rgba(251,249,244,.94);
  border-bottom-color:var(--line);
  box-shadow:0 14px 36px -26px rgba(15,35,54,.5);
  height:64px;
}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
.brand{display:flex;align-items:baseline;gap:.6rem;font-family:var(--display);font-size:1.18rem;letter-spacing:.02em;color:var(--navy)}
.brand .mono{
  font-family:var(--sans);font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold-ink);font-weight:600;transform:translateY(-1px)
}
.nav{display:flex;align-items:center;gap:clamp(1.1rem,2.4vw,2.4rem)}
.nav a{
  font-family:var(--sans);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:400;position:relative;padding:.4em 0;transition:color .3s
}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:width .35s var(--ease)}
.nav a:hover{color:var(--navy)}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.nav a[aria-current="page"]{color:var(--gold-ink);font-weight:500}

.nav-toggle{display:none;background:none;border:0;color:var(--navy);cursor:pointer;padding:.4rem;width:42px;height:42px}
.nav-toggle svg{width:26px;height:26px}

/* language switcher (pill) */
.nav .lang{display:inline-flex;align-items:center;margin-left:.7rem;border:1px solid var(--line-strong);border-radius:999px;overflow:hidden;flex:0 0 auto}
.nav .lang a{padding:.42em .85em;font-family:var(--sans);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);transition:background .3s,color .3s}
.nav .lang a::after{display:none}
.nav .lang a.is-active{background:var(--navy);color:var(--cream)}
.nav .lang a:not(.is-active):hover{color:var(--navy)}

/* ---------- generic section ---------- */
.section{padding:clamp(80px,11vw,150px) 0;position:relative}
.section--paper{background:var(--bg-2)}
.section--tint{background:var(--bg-3)}
.section-title{font-size:clamp(2.1rem,5vw,3.8rem);margin-bottom:.5em;color:var(--navy)}
.section-title em{font-style:italic;color:var(--green)}

/* reveal animation */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
}

/* =========================================================
   HERO (home) — dark photo, light text
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;color:var(--cream)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:50% 26%;
  animation:kenburns 18s var(--ease) both}
@media (prefers-reduced-motion:reduce){.hero__media img{animation:none}}
@keyframes kenburns{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg,rgba(13,28,44,.82) 0%,rgba(13,28,44,.5) 36%,rgba(13,28,44,.12) 62%,transparent 100%),
    linear-gradient(180deg,rgba(13,28,44,.5) 0%,transparent 26%,transparent 52%,rgba(13,28,44,.88) 100%)}
.hero__inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(48px,8vh,96px);padding-top:calc(var(--nav-h) + 30px)}
.hero .eyebrow{color:var(--gold)}
.hero .eyebrow::before{background:var(--gold)}
.hero__name{
  font-size:clamp(3.2rem,12vw,10rem);line-height:.9;font-weight:900;letter-spacing:-.02em;
  margin:0;text-wrap:balance;color:var(--cream)
}
.hero__name span{display:block}
.hero__name .it{font-style:italic;font-weight:400;color:var(--gold)}
.hero__sub{
  max-width:46ch;margin-top:1.6rem;font-size:clamp(1.05rem,1.6vw,1.35rem);
  color:var(--cream-dim);line-height:1.6
}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem}
.hero .btn-ghost{color:var(--cream);border-color:var(--line-cream-strong)}
.hero .btn-ghost:hover{color:var(--gold);border-color:var(--gold)}
.hero__scroll{
  position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;
  font-family:var(--sans);font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cream-faint);
  display:flex;flex-direction:column;align-items:center;gap:.7rem
}
.hero__scroll .line{width:1px;height:46px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.hero__scroll .line::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold);animation:scrolldot 2.2s var(--ease) infinite}
@keyframes scrolldot{0%{top:-50%}60%,100%{top:120%}}
@media (prefers-reduced-motion:reduce){.hero__scroll .line::after{animation:none;top:0;height:100%;opacity:.4}}

/* hero meta strip — white, navy numbers */
.hero-meta{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg)}
.hero-meta .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.hero-meta .cell{padding:clamp(20px,3vw,34px) clamp(8px,2vw,22px);background:var(--bg)}
.hero-meta .num{font-family:var(--display);font-size:clamp(1.8rem,3.4vw,2.8rem);color:var(--navy);line-height:1}
.hero-meta .num em{font-style:italic;color:var(--gold-ink)}
.hero-meta .lab{font-family:var(--sans);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-top:.6rem;display:block}

/* =========================================================
   SPLIT / IDEA blocks
   ========================================================= */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,6vw,90px);align-items:center}
.split--rev .split__media{order:2}
.split__media{position:relative}
.split__media .frame{position:relative;overflow:hidden;border-radius:3px;box-shadow:0 36px 70px -44px rgba(15,35,54,.5)}
.split__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.split__media .frame:hover img{transform:scale(1.04)}
.split__media .tag{
  position:absolute;left:-10px;bottom:24px;background:var(--gold);color:var(--navy-deep);
  font-family:var(--sans);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  padding:.7em 1.3em;box-shadow:0 14px 30px -16px rgba(15,35,54,.5)
}
.split__body .section-title{margin-bottom:.6em}
.pull{font-family:var(--display);font-style:italic;font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.3;color:var(--navy);
  border-left:2px solid var(--green);padding-left:1.2rem;margin:1.6rem 0}

/* feature cards (home preview) */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px);margin-top:clamp(40px,6vw,72px)}
.fcard{position:relative;overflow:hidden;border-radius:3px;aspect-ratio:3/4;display:flex;align-items:flex-end;
  color:var(--cream);isolation:isolate;box-shadow:0 30px 60px -40px rgba(15,35,54,.55)}
.fcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform 1s var(--ease)}
.fcard::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(13,28,44,.18) 0%,rgba(13,28,44,.5) 42%,rgba(13,28,44,.96) 100%)}
.fcard:hover img{transform:scale(1.06)}
.fcard__in{padding:clamp(22px,2.4vw,32px);text-shadow:0 1px 14px rgba(13,28,44,.5)}
.fcard h3{font-size:clamp(1.4rem,2.2vw,1.9rem);color:var(--cream)}
.fcard .k{font-family:var(--sans);font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.7rem}
.fcard p{font-size:.95rem;color:var(--cream-dim);margin-top:.5rem}
.fcard .go{display:inline-flex;align-items:center;gap:.5em;margin-top:1rem;font-family:var(--sans);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cream)}
.fcard .go svg{width:1em;height:1em;transition:transform .35s var(--ease)}
.fcard:hover .go svg{transform:translateX(5px)}

/* =========================================================
   PIATTI (dishes gallery)
   ========================================================= */
.dish-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(14px,1.6vw,22px)}
.dish{
  position:relative;overflow:hidden;border-radius:3px;background:var(--bg-2);
  grid-column:span 4;aspect-ratio:1/1;cursor:pointer;isolation:isolate;
  box-shadow:0 26px 54px -40px rgba(15,35,54,.5)
}
.dish.tall{aspect-ratio:3/4}
.dish.wide{grid-column:span 6;aspect-ratio:3/2}
.dish.feat{grid-column:span 6;aspect-ratio:3/4}
.dish img,.dish video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  transition:transform 1.1s var(--ease),filter .6s var(--ease)}
.dish__scrim{position:absolute;inset:0;z-index:1;opacity:0;transition:opacity .5s var(--ease);
  background:linear-gradient(180deg,rgba(11,24,38,.08) 0%,rgba(11,24,38,.62) 55%,rgba(11,24,38,.93) 100%)}
.dish__corner{position:absolute;top:14px;left:14px;z-index:2;width:34px;height:34px;opacity:0;transition:opacity .5s var(--ease) .05s,transform .6s var(--ease)}
.dish__corner::before,.dish__corner::after{content:"";position:absolute;background:var(--gold)}
.dish__corner::before{top:0;left:0;width:100%;height:1px}
.dish__corner::after{top:0;left:0;width:1px;height:100%}
.dish__body{
  position:absolute;left:0;right:0;bottom:0;z-index:2;padding:clamp(20px,2vw,30px);
  transform:translateY(14px);opacity:0;transition:transform .55s var(--ease),opacity .55s var(--ease);color:var(--cream)
}
.dish__num{font-family:var(--sans);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.5rem}
.dish__name{font-size:clamp(1.25rem,1.9vw,1.7rem);line-height:1.08;margin-bottom:.5rem;color:var(--cream)}
.dish__name em{font-style:italic;color:var(--gold);font-weight:400;font-size:.8em;display:block;margin-top:.25rem}
.dish__desc{font-size:.94rem;line-height:1.55;color:var(--cream-dim);max-width:42ch}
.dish__hint{position:absolute;bottom:16px;right:16px;z-index:2;font-family:var(--sans);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cream);
  background:rgba(15,35,54,.5);backdrop-filter:blur(4px);padding:.5em .8em;border:1px solid var(--line-cream-strong);transition:opacity .4s}
.dish:hover img,.dish:focus-within img,.dish.open img{transform:scale(1.05)}
.dish:hover .dish__scrim,.dish:focus-within .dish__scrim,.dish.open .dish__scrim{opacity:1}
.dish:hover .dish__body,.dish:focus-within .dish__body,.dish.open .dish__body{transform:none;opacity:1}
.dish:hover .dish__corner,.dish:focus-within .dish__corner,.dish.open .dish__corner{opacity:1}
.dish:hover .dish__hint,.dish:focus-within .dish__hint,.dish.open .dish__hint{opacity:0}
.dish .badge{position:absolute;top:14px;right:14px;z-index:2;background:var(--gold);color:var(--navy-deep);
  font-family:var(--sans);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;padding:.45em .8em}

/* =========================================================
   STORIA — horizontal pinned timeline
   ========================================================= */
.story-intro{padding-top:calc(var(--nav-h) + clamp(48px,9vw,110px))}
.timeline{position:relative;background:var(--bg)}
.timeline__sticky{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;align-items:center;
  padding:calc(var(--nav-h) + 10px) 0 78px}
.timeline__rail{position:absolute;left:0;right:0;top:calc(50% + var(--nav-h)/2 - 34px);height:1px;background:var(--line-strong);z-index:0}
.timeline__track{display:flex;align-items:stretch;height:auto;will-change:transform}
.t-panel{
  flex:0 0 auto;width:min(86vw,540px);padding:0 clamp(18px,2.4vw,40px);
  display:flex;flex-direction:column;justify-content:center;position:relative
}
.t-node{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.t-node .dot{width:13px;height:13px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 6px rgba(199,162,78,.2);flex:0 0 auto}
.t-node .yr{font-family:var(--display);font-weight:900;font-size:clamp(2.4rem,4.6vw,3.6rem);line-height:.85;color:var(--navy)}
.t-node .yr.small{font-size:clamp(1.5rem,2.8vw,2.2rem)}
.t-place{font-family:var(--sans);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-ink);margin-bottom:.9rem;font-weight:600}
.t-card{background:#fff;border:1px solid var(--line);border-radius:5px;overflow:hidden;box-shadow:0 30px 60px -42px rgba(15,35,54,.55)}
.t-card .pic{height:clamp(168px,28vh,300px);overflow:hidden}
.t-card .pic img{width:100%;height:100%;object-fit:cover;object-position:50% 22%}
.t-card .txt{padding:clamp(18px,1.8vw,28px)}
.t-card h3{font-size:clamp(1.4rem,2.2vw,1.95rem);margin-bottom:.55rem;color:var(--navy)}
.t-card h3 em{font-style:italic;color:var(--green)}
.t-card p{font-size:.95rem;line-height:1.58;color:var(--ink-soft)}
.t-card .aside{font-family:var(--script);font-size:1.45rem;color:var(--gold-ink);margin-top:.7rem;line-height:1.1}

/* intro & end panels */
.t-open .big{font-size:clamp(2.6rem,6vw,5rem);line-height:.98;color:var(--navy)}
.t-open .big em{font-style:italic;color:var(--gold-ink)}
.t-end{align-items:flex-start}
.t-end .big{font-size:clamp(2.4rem,5vw,4rem);line-height:1;margin-bottom:1.3rem;color:var(--navy)}
.t-end .big em{font-style:italic;color:var(--gold-ink)}

/* progress hud */
.timeline__hud{position:absolute;left:var(--gut);right:var(--gut);bottom:clamp(20px,4vh,38px);z-index:5;
  display:flex;align-items:center;gap:1.2rem}
.timeline__bar{flex:1;height:2px;background:var(--line-strong);position:relative;overflow:hidden;border-radius:2px}
.timeline__bar i{position:absolute;left:0;top:0;height:100%;width:0;background:var(--gold)}
.timeline__hint{font-family:var(--sans);font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft);display:flex;align-items:center;gap:.6em}
.timeline__hint svg{width:1.1em;height:1.1em}

/* fallback (mobile + reduced motion): native horizontal swipe */
.timeline.is-static .timeline__sticky{position:static;height:auto;display:block;overflow:visible;padding:0}
.timeline.is-static .timeline__rail{display:none}
.timeline.is-static .timeline__track{
  overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  transform:none!important;padding-bottom:1.4rem;scrollbar-width:thin;scrollbar-color:var(--gold) transparent
}
.timeline.is-static .t-panel{scroll-snap-align:center;width:min(85vw,430px)}
.timeline.is-static .timeline__hud{position:static;margin:.4rem var(--gut) 0}
.timeline.is-static .timeline__bar{display:none}

/* =========================================================
   ADESSO
   ========================================================= */
.now-hero{padding-top:calc(var(--nav-h) + clamp(60px,10vw,130px))}
.place{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,80px);align-items:center;margin-top:clamp(50px,8vw,110px)}
.place--rev .place__media{order:2}
.place__media{position:relative;overflow:hidden;border-radius:3px;box-shadow:0 36px 70px -46px rgba(15,35,54,.5)}
.place__media img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:50% 22%;transition:transform 1.2s var(--ease)}
.place__media:hover img{transform:scale(1.04)}
.place__loc{font-family:var(--sans);font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-ink);font-weight:600;display:flex;align-items:center;gap:.6em;margin-bottom:1.1rem}
.place__loc svg{width:1.1em;height:1.1em}
.place h2{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:.4em;color:var(--navy)}
.place h2 em{font-style:italic;color:var(--green)}
.place .sub{font-family:var(--display);font-style:italic;color:var(--gold-ink);font-size:clamp(1.1rem,1.6vw,1.3rem);margin-bottom:1.2rem}
.place p{color:var(--ink-soft)}
.place p em{font-style:italic;color:var(--green)}

/* cinematic ambient video band */
.vband{position:relative;height:clamp(260px,44vw,540px);overflow:hidden;background:var(--navy-deep)}
.vband video{width:100%;height:100%;object-fit:cover;opacity:.62}
.vband__cap{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.6rem;
  background:linear-gradient(rgba(15,35,54,.42),rgba(15,35,54,.66))}
.vband__cap .e{font-family:var(--sans);font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold)}
.vband__cap .t{font-family:var(--display);font-style:italic;font-size:clamp(1.8rem,4.2vw,3.4rem);color:var(--cream);line-height:1.1;max-width:20ch}

/* book feature */
.book{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(28px,5vw,70px);align-items:center}
.book__media{overflow:hidden;border-radius:3px;border:1px solid var(--line);box-shadow:0 30px 60px -44px rgba(15,35,54,.45)}
.book__media img{width:100%}
.book .award{display:flex;gap:1.4rem;flex-wrap:wrap;margin-top:1.6rem}
.book .award .a{border-top:2px solid var(--green);padding-top:.9rem;flex:1;min-width:160px}
.book .award .a b{font-family:var(--display);display:block;font-size:1.05rem;color:var(--navy)}
.book .award .a span{font-family:var(--sans);font-size:.74rem;letter-spacing:.04em;color:var(--ink-soft)}

/* =========================================================
   CTA band + footer (dark navy anchors)
   ========================================================= */
.cta-band{background:var(--navy-deep);text-align:center;color:var(--cream)}
.cta-band .eyebrow{color:var(--gold)}
.cta-band .eyebrow::before,.cta-band .eyebrow.center::after{background:var(--gold)}
.cta-band .section-title{color:var(--cream);max-width:18ch;margin:0 auto .8em}
.cta-band .section-title em{color:var(--gold)}
.cta-band .lead{color:var(--cream-dim);max-width:52ch;margin:0 auto 2.2rem}
.cta-band .btn-ghost{color:var(--cream);border-color:var(--line-cream-strong)}
.cta-band .btn-ghost:hover{color:var(--gold);border-color:var(--gold)}

.site-foot{background:var(--navy-deep);color:var(--cream);border-top:1px solid var(--line-cream);padding:clamp(50px,7vw,80px) 0 36px}
.site-foot .top{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-start}
.site-foot .brand{font-size:1.6rem;color:var(--cream)}
.foot-nav{display:flex;gap:1.6rem;flex-wrap:wrap}
.foot-nav a{font-family:var(--sans);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-dim);transition:color .3s}
.foot-nav a:hover{color:var(--gold)}
.foot-contact{font-family:var(--sans);font-size:.86rem;letter-spacing:.04em;color:var(--cream-dim)}
.foot-contact a{color:var(--gold)}
.foot-links{display:flex;flex-direction:column;gap:.65rem;margin-top:1.1rem}
.foot-links a{display:inline-flex;align-items:center;gap:.65em;font-family:var(--sans);font-size:.92rem;letter-spacing:.02em;color:var(--cream-dim);transition:color .3s}
.foot-links a:hover{color:var(--gold)}
.foot-links svg{width:1.15em;height:1.15em;flex:0 0 auto;color:var(--gold)}
.site-foot .rule{height:1px;background:var(--line-cream);margin:clamp(34px,5vw,52px) 0 22px}
.site-foot .legal{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  font-family:var(--sans);font-size:.72rem;letter-spacing:.08em;color:var(--cream-faint)}

/* =========================================================
   LEGAL PAGES + COOKIE BANNER
   ========================================================= */
.legal-doc{padding-top:calc(var(--nav-h) + clamp(40px,8vw,90px))}
.legal-doc .doc{max-width:760px}
.legal-doc h2{font-size:clamp(1.25rem,2.3vw,1.65rem);color:var(--navy);margin:2.3rem 0 .7rem}
.legal-doc h2:first-of-type{margin-top:1.4rem}
.legal-doc p,.legal-doc li{color:var(--ink-soft);font-size:1rem;line-height:1.7}
.legal-doc ul{padding-left:1.2rem;margin:0 0 1.1em}
.legal-doc li{margin-bottom:.45rem}
.legal-doc a{color:var(--gold-ink);text-decoration:underline;text-underline-offset:2px}
.legal-doc strong{color:var(--navy)}
.legal-doc .updated{font-family:var(--sans);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:2.6rem}
.legal-note{background:var(--bg-2);border-left:3px solid var(--gold);padding:1rem 1.2rem;border-radius:3px;margin:1.4rem 0;font-size:.92rem;color:var(--ink-soft)}

.site-foot .legal-links a{color:var(--cream-dim);transition:color .3s}
.site-foot .legal-links a:hover{color:var(--gold)}

.cookie-banner{position:fixed;left:clamp(14px,3vw,28px);right:clamp(14px,3vw,28px);bottom:clamp(14px,3vw,24px);z-index:200;
  max-width:560px;background:rgba(251,249,244,.97);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line);border-radius:6px;box-shadow:0 26px 60px -24px rgba(15,35,54,.55);
  padding:clamp(16px,2vw,22px);display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.cookie-banner p{margin:0;flex:1;min-width:220px;font-family:var(--sans);font-size:.86rem;line-height:1.5;color:var(--ink-soft)}
.cookie-banner a{color:var(--gold-ink);text-decoration:underline}
.cookie-banner .btn{padding:.7em 1.4em;font-size:.72rem}
@media (max-width:480px){.cookie-banner{flex-direction:column;align-items:stretch}.cookie-banner .btn{justify-content:center}}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .dish.feat,.dish.wide{grid-column:span 6}
  .dish{grid-column:span 6}
}
@media (max-width:820px){
  :root{--nav-h:64px}
  .nav{position:fixed;inset:var(--nav-h) 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;
    background:rgba(251,249,244,.98);backdrop-filter:blur(16px);padding:10px var(--gut) 24px;
    border-bottom:1px solid var(--line);box-shadow:0 20px 40px -24px rgba(15,35,54,.4);
    transform:translateY(-130%);transition:transform .45s var(--ease);height:auto}
  .nav.open{transform:none}
  .nav a{padding:1rem 0;width:100%;border-bottom:1px solid var(--line);font-size:1rem;color:var(--navy)}
  .nav a::after{display:none}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  .site-head.scrolled{height:var(--nav-h)}
  .hero__scroll{display:none}
  .split,.place,.place--rev .place__media,.book{grid-template-columns:1fr}
  .split--rev .split__media{order:0}
  .place--rev .place__media{order:0}
  .cards3{grid-template-columns:1fr;gap:14px}
  .fcard{aspect-ratio:16/10}
  .hero-meta .wrap{grid-template-columns:repeat(2,1fr)}
  .dish,.dish.feat,.dish.wide{grid-column:span 12;aspect-ratio:4/3}
  .dish.tall{aspect-ratio:4/3}
  .dish__hint{display:none}
}
@media (max-width:480px){
  .hero-meta .wrap{grid-template-columns:1fr 1fr}
  .foot-nav{gap:1rem}
}
