/* =========================================================================
   La Cantine de Marius — Refonte
   Design system : "La table corse de Saint-Germain"
   Dark editorial · teal de marque (#5097A8) + ambre lampe · Fraunces/Hanken
   ========================================================================= */

/* ---------- Tokens ---------- */
:root{
  /* color */
  --ink:        #14110D;   /* warm near-black, base */
  --ink-2:      #1C1813;   /* raised dark surface */
  --ink-3:      #272118;   /* hairline / borders on dark */
  --paper:      #F4EDDE;   /* warm parchment, reading sections */
  --paper-2:    #EAE0CB;   /* deeper parchment */
  --paper-line: #D9CDB2;

  --teal:       #4E97A6;   /* brand mid */
  --teal-light: #8CC4CE;   /* on dark */
  --teal-deep:  #0E3A41;   /* deep petrol section */

  --amber:      #D89A4E;   /* candlelight / pietra accent */
  --amber-deep: #985717;   /* burnt ochre — text on parchment (AA) */
  --maquis:     #6E7748;   /* olive / herbs */

  --cream-70:   rgba(244,237,222,.70);
  --cream-55:   rgba(244,237,222,.55);
  --ink-70:     rgba(20,17,13,.70);
  --ink-55:     rgba(20,17,13,.55);

  /* type */
  --display: "Fraunces", Georgia, "Times New Roman", serif;
  --body: "Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  --chalk: "Caveat", "Bradley Hand", cursive;

  --fs-eyebrow: .78rem;
  --fs-small: .9rem;
  --fs-body: 1.06rem;
  --fs-lead: clamp(1.12rem, 1.6vw, 1.3rem);
  --fs-h3: clamp(1.3rem, 2vw, 1.6rem);
  --fs-h2: clamp(1.9rem, 3.6vw, 3rem);
  --fs-h1: clamp(2.6rem, 6.2vw, 5.6rem);

  /* space */
  --gut: clamp(1.25rem, 4vw, 4rem);
  --maxw: 1280px;
  --sec-y: clamp(4rem, 9vw, 8rem);

  --radius: 4px;
  --radius-lg: 10px;
  --shadow: 0 18px 50px -20px rgba(0,0,0,.55);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--body);
  font-size:var(--fs-body);
  line-height:1.7;
  color:var(--paper);
  background:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,picture,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
ul{list-style:none;padding:0}
h1,h2,h3,h4{font-family:var(--display);font-weight:400;line-height:1.04;letter-spacing:-.01em}
:focus-visible{outline:2.5px solid var(--amber);outline-offset:3px;border-radius:2px}

.skip{position:absolute;left:-999px;top:0;background:var(--amber);color:var(--ink);
  padding:.7rem 1.1rem;z-index:200;font-weight:600}
.skip:focus{left:.5rem;top:.5rem}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:var(--sec-y)}
.eyebrow{font-family:var(--body);font-size:var(--fs-eyebrow);font-weight:600;
  text-transform:uppercase;letter-spacing:.22em;color:var(--teal-light)}
.eyebrow--ink{color:var(--amber-deep)}
.lead{font-size:var(--fs-lead);line-height:1.6;color:var(--cream-70)}
.serif-it{font-family:var(--display);font-style:italic}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6em;padding:.95em 1.6em;
  font-weight:600;font-size:.98rem;letter-spacing:.01em;border-radius:var(--radius);
  transition:transform .3s var(--ease), background .3s var(--ease), color .3s var(--ease), box-shadow .3s var(--ease);
  will-change:transform}
.btn svg{width:1em;height:1em;transition:transform .3s var(--ease)}
.btn--primary{background:var(--amber);color:#231708}
.btn--primary:hover{background:#e7ac61;transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(216,154,78,.8)}
.btn--primary:hover svg{transform:translateX(3px)}
.btn--ghost{border:1px solid rgba(244,237,222,.35);color:var(--paper)}
.btn--ghost:hover{border-color:var(--teal-light);color:var(--teal-light);transform:translateY(-2px)}
.btn--ink{border:1px solid rgba(20,17,13,.3);color:var(--ink)}
.btn--ink:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}

/* ---------- Header ---------- */
.site-header{position:fixed;inset:0 0 auto 0;z-index:100;
  transition:background .4s var(--ease), backdrop-filter .4s var(--ease), border-color .4s var(--ease);
  border-bottom:1px solid transparent}
.site-header.scrolled{background:rgba(20,17,13,.82);backdrop-filter:blur(14px) saturate(1.2);
  border-bottom-color:var(--ink-3)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:nowrap;
  max-width:var(--maxw);margin-inline:auto;padding:.95rem var(--gut)}
.brand{display:flex;align-items:baseline;gap:.5rem;font-family:var(--display);flex-shrink:0;
  font-size:1.4rem;letter-spacing:-.01em;line-height:1;white-space:nowrap}
.brand b{font-weight:600;letter-spacing:.02em}
.brand .brand-sm{font-size:.82rem;font-style:italic;color:var(--teal-light)}
.nav-links{display:flex;align-items:center;gap:1.4rem;flex-wrap:nowrap}
.nav-links a{font-size:.92rem;color:var(--cream-70);position:relative;padding:.2rem 0;white-space:nowrap;
  transition:color .25s var(--ease)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:0;
  background:var(--teal-light);transition:width .3s var(--ease)}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--paper)}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1rem;flex-shrink:0}
.nav-tel{font-size:.92rem;color:var(--cream-70);transition:color .25s;white-space:nowrap}
.nav-tel:hover{color:var(--teal-light)}
.burger{display:none;width:44px;height:44px;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.burger span{display:block;width:24px;height:2px;background:var(--paper);transition:transform .3s var(--ease),opacity .3s}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:99;background:var(--ink);
  display:flex;flex-direction:column;justify-content:center;gap:.2rem;padding:var(--gut);
  transform:translateY(-100%);transition:transform .5s var(--ease);visibility:hidden}
.drawer.open{transform:translateY(0);visibility:visible}
.drawer a{font-family:var(--display);font-size:clamp(1.8rem,7vw,2.6rem);color:var(--paper);
  padding:.35rem 0;border-bottom:1px solid var(--ink-3)}
.drawer a:last-of-type{border:none}
.drawer .drawer-foot{margin-top:1.5rem;display:flex;gap:1rem;flex-wrap:wrap}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding-top:clamp(5.5rem,11vh,7.5rem);padding-bottom:clamp(2.5rem,6vh,5rem);overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:-2}
.hero-media img{width:100%;height:100%;object-fit:cover;
  animation:kenburns 22s var(--ease) infinite alternate}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.14) translate(-1%,-1.5%)}}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(20,17,13,.55) 0%,rgba(20,17,13,.2) 35%,rgba(20,17,13,.78) 88%)}
.hero-inner{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut);width:100%}
.hero h1{font-size:var(--fs-h1);color:#fff;max-width:14ch;
  text-shadow:0 2px 40px rgba(0,0,0,.4)}
.hero h1 em{font-style:italic;color:var(--teal-light)}
.hero .hero-eyebrow{margin-bottom:1.4rem;display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}
.hero .hero-eyebrow .rule{width:46px;height:1px;background:var(--teal-light);opacity:.7}
.hero p{max-width:46ch;margin-top:1.4rem;color:rgba(255,255,255,.86);font-size:var(--fs-lead)}
.hero-actions{margin-top:2.2rem;display:flex;gap:1rem;flex-wrap:wrap}
.hero-meta{margin-top:2.6rem;display:flex;gap:2.2rem;flex-wrap:wrap;
  padding-top:1.6rem;border-top:1px solid rgba(244,237,222,.18)}
.hero-meta div{font-size:.92rem;color:rgba(255,255,255,.8)}
.hero-meta b{display:block;font-family:var(--display);font-size:1.5rem;color:#fff;font-weight:500}
.hero-meta .stars{color:var(--amber);letter-spacing:.1em}
/* short / landscape viewports: keep hero clear of the fixed header */
@media (max-height:780px){
  .hero h1{font-size:clamp(2.2rem,5.2vw,4rem)}
  .hero .hero-eyebrow{margin-bottom:1rem}
  .hero p{margin-top:1rem}
  .hero-actions{margin-top:1.4rem}
  .hero-meta{margin-top:1.4rem;padding-top:1.1rem}
}
@media (max-height:620px){
  .hero-meta{display:none}
  .hero p{display:none}
}

/* reveal animation (words/blocks) */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero-media img{animation:none}
}

/* ---------- Section heading block ---------- */
.sec-head{display:grid;gap:1rem;max-width:64ch;margin-bottom:clamp(2.2rem,5vw,3.5rem)}
.sec-head h2{font-size:var(--fs-h2)}
.sec-head.center{margin-inline:auto;text-align:center}

/* ---------- Intro / story (parchment) ---------- */
.panel-paper{background:var(--paper);color:var(--ink)}
.panel-paper .lead{color:var(--ink-70)}
.panel-paper .eyebrow{color:var(--amber-deep)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split.rev{direction:rtl}.split.rev>*{direction:ltr}
.split-media{position:relative}
.split-media img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.split-media .tag{position:absolute;bottom:-18px;left:-18px;background:var(--teal-deep);color:var(--paper);
  padding:1rem 1.3rem;border-radius:var(--radius);max-width:230px;box-shadow:var(--shadow)}
.split-media .tag b{font-family:var(--display);font-size:1.5rem;display:block;color:var(--teal-light)}
.split-media .tag span{font-size:.82rem;color:var(--cream-70)}
.prose p+p{margin-top:1.1rem}
.prose p{color:inherit}

/* signature: ardoise ----------------------------------------------------- */
.ardoise{background:
  radial-gradient(120% 120% at 30% 0%, #2a2c26 0%, #1c1d19 55%, #16170f 100%);
  border:1px solid #34362c;border-radius:var(--radius-lg);
  padding:clamp(1.8rem,4vw,3rem);position:relative;box-shadow:var(--shadow)}
.ardoise::before{content:"";position:absolute;inset:10px;border:1px solid rgba(140,196,206,.16);
  border-radius:6px;pointer-events:none}
.ardoise .a-eyebrow{font-family:var(--body);text-transform:uppercase;letter-spacing:.24em;
  font-size:.72rem;color:var(--teal-light);font-weight:600}
.ardoise h3{font-family:var(--chalk);font-size:clamp(2rem,5vw,3.2rem);color:#f6f1e4;
  font-weight:600;line-height:1;margin:.4rem 0 1.4rem}
.ardoise ul{display:grid;gap:.9rem}
.ardoise li{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;
  font-family:var(--chalk);font-size:1.5rem;color:#ece6d6;
  border-bottom:1px dotted rgba(236,230,214,.25);padding-bottom:.5rem}
.ardoise li .price{color:var(--amber);white-space:nowrap}
.ardoise .a-note{margin-top:1.3rem;font-size:.85rem;color:var(--cream-55);font-family:var(--body)}

/* ---------- Provenance strip ---------- */
.provenance{background:var(--teal-deep);color:var(--paper)}
.prov-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(140,196,206,.18);
  border:1px solid rgba(140,196,206,.18);border-radius:var(--radius-lg);overflow:hidden}
.prov-grid li{background:var(--teal-deep);padding:1.6rem 1.4rem}
.prov-grid b{font-family:var(--display);font-size:1.25rem;display:block;color:#fff}
.prov-grid .loc{font-size:.78rem;text-transform:uppercase;letter-spacing:.15em;color:var(--teal-light);margin-bottom:.6rem;display:block}
.prov-grid p{font-size:.9rem;color:var(--cream-70);margin-top:.3rem}

/* ---------- Menu (carte) ---------- */
.menu-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2.5rem}
.menu-tabs a{padding:.55rem 1.15rem;border:1px solid var(--paper-line);border-radius:100px;
  font-size:.9rem;font-weight:500;color:var(--ink-70);transition:all .25s var(--ease)}
.menu-tabs a:hover{border-color:var(--ink);color:var(--ink)}
.menu-group{margin-bottom:clamp(2.5rem,6vw,4.5rem)}
.menu-group>h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:.3rem;display:flex;align-items:baseline;gap:.8rem;font-weight:400}
.menu-group>h2 .n{font-family:var(--body);font-size:.8rem;font-weight:600;letter-spacing:.15em;
  color:var(--amber-deep);text-transform:uppercase}
.menu-group>.gp-note{color:var(--ink-70);font-size:.92rem;margin-bottom:1.6rem}
.dish{display:grid;grid-template-columns:1fr auto;gap:.2rem 1.5rem;align-items:baseline;
  padding:1.05rem 0;border-bottom:1px solid var(--paper-line)}
.dish:last-child{border-bottom:none}
.dish .d-name{font-family:var(--display);font-size:1.18rem;color:var(--ink);line-height:1.25}
.dish .d-price{font-family:var(--display);font-size:1.18rem;color:var(--amber-deep);white-space:nowrap;font-weight:500}
.dish .d-aller{grid-column:1/2;font-size:.78rem;color:var(--ink-70);margin-top:.3rem;
  text-transform:lowercase;letter-spacing:.02em}
.dish .d-aller span{display:inline-block;margin-right:.55rem}
.formule{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem;margin-top:1.4rem}
.formule .f-card{border:1px solid var(--paper-line);border-radius:var(--radius-lg);padding:1.6rem;background:var(--paper-2)}
.formule .f-card .price{font-family:var(--display);font-size:2.2rem;color:var(--amber-deep)}
.formule .f-card p{font-size:.95rem;color:var(--ink-70);margin-top:.3rem}

/* allergen legend */
.legend{margin-top:2rem;padding:1.2rem 1.4rem;background:var(--paper-2);border-radius:var(--radius-lg);
  font-size:.85rem;color:var(--ink-70)}

/* ---------- Cards / grids ---------- */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.4rem}
.fig-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--ink-2)}
.fig-card img{width:100%;aspect-ratio:5/3;object-fit:cover;transition:transform .7s var(--ease)}
.fig-card:hover img{transform:scale(1.06)}
.fig-card figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.2rem;
  background:linear-gradient(0deg,rgba(20,17,13,.85),transparent);
  font-family:var(--display);font-size:1.05rem;color:#fff}

/* ---------- Gallery (masonry-ish) ---------- */
.gallery{columns:3;column-gap:1rem}
.gallery button{width:100%;margin-bottom:1rem;border-radius:var(--radius-lg);overflow:hidden;
  display:block;background:var(--ink-2);break-inside:avoid;border:none;padding:0;cursor:zoom-in}
.gallery img{width:100%;transition:transform .6s var(--ease),filter .4s}
.gallery button:hover img{transform:scale(1.04);filter:brightness(1.08)}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:150;background:rgba(10,8,6,.95);display:none;
  align-items:center;justify-content:center;padding:clamp(1rem,4vw,3rem)}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:86vh;width:auto;border-radius:6px;box-shadow:var(--shadow)}
.lightbox .lb-close,.lightbox .lb-nav{position:absolute;background:rgba(244,237,222,.1);
  border:1px solid rgba(244,237,222,.25);color:#fff;width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;transition:background .25s}
.lightbox .lb-close:hover,.lightbox .lb-nav:hover{background:rgba(244,237,222,.22)}
.lightbox .lb-close{top:1.3rem;right:1.3rem}
.lightbox .lb-nav{top:50%;transform:translateY(-50%)}
.lb-prev{left:1.3rem}.lb-next{right:1.3rem}

/* ---------- Reviews ---------- */
.rating-hero{display:grid;grid-template-columns:auto 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.rating-score{text-align:center}
.rating-score .big{font-family:var(--display);font-size:clamp(4rem,12vw,7rem);line-height:.9;color:var(--paper)}
.rating-score .big span{color:var(--cream-55);font-size:.4em}
.rating-score .stars{color:var(--amber);font-size:1.5rem;letter-spacing:.15em;margin:.4rem 0}
.rating-score .count{font-size:.9rem;color:var(--cream-70)}
.rating-bars{display:grid;gap:1rem;max-width:520px}
.rbar{display:grid;grid-template-columns:120px 1fr auto;gap:1rem;align-items:center;font-size:.92rem}
.rbar .track{height:7px;background:var(--ink-3);border-radius:100px;overflow:hidden}
.rbar .fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--teal-light));border-radius:100px;
  width:var(--w,90%);transition:width 1.2s var(--ease)}
.rbar b{font-variant-numeric:tabular-nums;color:var(--teal-light)}
.verified-note{margin-top:1.6rem;font-size:.85rem;color:var(--cream-55);display:flex;align-items:center;gap:.5rem}

/* ---------- Press ---------- */
.press-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.1rem}
.press-card{border:1px solid var(--ink-3);border-radius:var(--radius-lg);padding:1.5rem;
  background:var(--ink-2);transition:border-color .3s var(--ease),transform .3s var(--ease)}
.press-card:hover{border-color:var(--teal);transform:translateY(-3px)}
.press-card .src{font-family:var(--display);font-size:1.3rem;color:var(--paper)}
.press-card .date{font-size:.8rem;color:var(--cream-55);letter-spacing:.05em;margin-top:.2rem}
.press-card p{font-size:.92rem;color:var(--cream-70);margin-top:.7rem}

/* ---------- Info / contact ---------- */
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.6rem}
.info-card h3{font-family:var(--body);font-size:.78rem;text-transform:uppercase;letter-spacing:.2em;
  color:var(--amber);font-weight:600;margin-bottom:.8rem}
.info-card p,.info-card li{color:var(--cream-70);font-size:.96rem}
.hours{display:grid;gap:.45rem}
.hours li{display:flex;justify-content:space-between;gap:1rem;padding-bottom:.45rem;
  border-bottom:1px solid var(--ink-3)}
.hours li.today{color:var(--paper)}
.hours li.today .d{color:var(--teal-light);font-weight:600}
.hours .closed{color:var(--cream-55)}
.map-wrap{border-radius:var(--radius-lg);overflow:hidden;min-height:340px;height:100%}
.map-embed{border:0;width:100%;height:100%;min-height:340px;display:block;filter:grayscale(.25) contrast(1.05)}
.map-facade{position:relative;width:100%;height:100%;min-height:340px;padding:0;cursor:pointer;display:block;background:var(--teal-deep)}
.map-facade picture{display:block;width:100%;height:100%;min-height:340px}
.map-facade img{width:100%;height:100%;min-height:340px;object-fit:cover;filter:brightness(.62) saturate(.9);transition:filter .4s var(--ease)}
.map-facade:hover img{filter:brightness(.72) saturate(1)}
.map-pin{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:inline-flex;align-items:center;gap:.55em;
  background:var(--amber);color:#231708;font-weight:600;font-size:.95rem;padding:.8em 1.3em;border-radius:100px;
  box-shadow:0 12px 30px -12px rgba(0,0,0,.6)}
.map-pin svg{width:1.1em;height:1.1em}

/* form */
.form{display:grid;gap:1.1rem}
.field{display:grid;gap:.4rem}
.field label{font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:var(--cream-70)}
.field input,.field textarea,.field select{background:var(--ink-2);border:1px solid var(--ink-3);
  color:var(--paper);padding:.85rem 1rem;border-radius:var(--radius);font:inherit;font-size:.98rem;
  transition:border-color .25s var(--ease)}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--teal);outline:none}
.field textarea{min-height:130px;resize:vertical}
.field .err{font-size:.8rem;color:#e88a6a;display:none}
.field.invalid input,.field.invalid textarea{border-color:#e88a6a}
.field.invalid .err{display:block}
.form .consent{flex-direction:row;align-items:flex-start;gap:.7rem;font-size:.85rem}
.form .consent input{width:auto;margin-top:.2rem}
.form-note{font-size:.82rem;color:var(--cream-55)}
.form-success{display:none;padding:1.2rem 1.4rem;background:rgba(78,151,166,.14);
  border:1px solid var(--teal);border-radius:var(--radius);color:var(--teal-light)}
.form-success.show{display:block}

/* ---------- CTA band ---------- */
.cta-band{position:relative;text-align:center;overflow:hidden}
.cta-band .cta-bg{position:absolute;inset:0;z-index:-2}
.cta-band .cta-bg img{width:100%;height:100%;object-fit:cover}
.cta-band::after{content:"";position:absolute;inset:0;z-index:-1;background:rgba(14,58,65,.8)}
.cta-band h2{font-size:var(--fs-h2);color:#fff;max-width:18ch;margin-inline:auto}
.cta-band p{color:rgba(255,255,255,.82);max-width:48ch;margin:1rem auto 2rem}
.cta-band .hero-actions{justify-content:center}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);border-top:1px solid var(--ink-3);padding-block:clamp(3rem,6vw,5rem) 2rem}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem}
.foot-brand .brand{font-size:1.7rem;margin-bottom:1rem}
.foot-brand p{font-size:.92rem;color:var(--cream-55);max-width:34ch}
.foot-col .foot-h{font-family:var(--body);font-size:.76rem;text-transform:uppercase;letter-spacing:.2em;
  color:var(--teal-light);margin-bottom:1rem;font-weight:600}
.foot-col li{margin-bottom:.55rem}
.foot-col a,.foot-col p{font-size:.94rem;color:var(--cream-70);transition:color .25s}
.foot-col a:hover{color:var(--paper)}
.socials{display:flex;gap:.7rem;margin-top:1.2rem}
.socials a{width:42px;height:42px;border:1px solid var(--ink-3);border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease)}
.socials a:hover{border-color:var(--teal);background:var(--teal-deep);transform:translateY(-2px)}
.socials svg{width:18px;height:18px;fill:var(--cream-70)}
.socials a:hover svg{fill:var(--teal-light)}
.foot-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  margin-top:3rem;padding-top:1.6rem;border-top:1px solid var(--ink-3);
  font-size:.82rem;color:var(--cream-55)}
.foot-bottom .legal-links{display:flex;gap:1.2rem;flex-wrap:wrap}
.foot-bottom a:hover{color:var(--paper)}

/* ---------- Breadcrumb ---------- */
.breadcrumb{font-size:.82rem;color:var(--cream-70);padding-top:6.5rem}
.breadcrumb a{color:var(--cream-70)}
.breadcrumb a:hover{color:var(--teal-light)}
.breadcrumb [aria-current]{color:var(--paper)}
.breadcrumb [aria-hidden]{margin:0 .5rem;opacity:.45}

/* page hero (interior pages) */
.page-hero{padding-top:9rem;padding-bottom:clamp(2rem,4vw,3.5rem)}
.page-hero h1{font-size:clamp(2.4rem,5.5vw,4.4rem);max-width:18ch}
.page-hero .lead{margin-top:1.2rem;max-width:54ch}

/* FAQ */
.faq{display:grid;gap:.8rem;max-width:780px}
.faq details{border:1px solid var(--ink-3);border-radius:var(--radius-lg);background:var(--ink-2);
  overflow:hidden}
.panel-paper .faq details{border-color:var(--paper-line);background:var(--paper-2)}
.faq summary{padding:1.2rem 1.4rem;font-family:var(--display);font-size:1.12rem;cursor:pointer;
  display:flex;justify-content:space-between;gap:1rem;align-items:center;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--amber);transition:transform .3s var(--ease)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .faq-body{padding:0 1.4rem 1.3rem;color:var(--cream-70);font-size:.96rem}
.panel-paper .faq .faq-body{color:var(--ink-70)}

/* 404 */
.err-page{min-height:80vh;display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;padding-top:6rem}
.err-page .code{font-family:var(--display);font-size:clamp(5rem,18vw,11rem);color:var(--teal);line-height:.9}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .foot-top{grid-template-columns:1fr 1fr}
  .prov-grid{grid-template-columns:repeat(2,1fr)}
  .gallery{columns:2}
}
/* Switch to hamburger while the full horizontal nav still fits */
@media (max-width:1180px){
  .nav-links,.nav-tel{display:none}
  .burger{display:flex}
}
@media (max-width:860px){
  .nav{padding-block:.65rem}
  .brand{font-size:1.15rem}
  .brand .brand-sm{display:none}
  .nav-cta{gap:.4rem}
  .nav-cta .btn--primary{padding:.6em 1em;font-size:.88rem}
  .split{grid-template-columns:1fr;gap:2.5rem}
  .split.rev{direction:ltr}
  .split-media .tag{left:1rem;bottom:-14px}
  .rating-hero{grid-template-columns:1fr;text-align:center}
  .rating-bars{margin-inline:auto}
}
@media (max-width:560px){
  .nav-cta .btn--primary{display:none}
  .brand{font-size:1.05rem;white-space:nowrap}
  .prov-grid{grid-template-columns:1fr}
  .gallery{columns:1}
  .foot-top{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column}
  .hero-meta{gap:1.4rem}
  .dish{grid-template-columns:1fr;gap:.1rem}
  .dish .d-price{grid-row:1;justify-self:start}
}
