/* =================================================================
   L'AMUSETTE — Restaurant · Béziers
   Direction artistique : bistro vintage-chic « comme chez Mamie ».
   Palette tirée du logo + des photos · Fraunces / Mulish / Sacramento.
   Mobile-first, desktop contenu (média-queries en fin de fichier).
   ================================================================= */

/* ---------- Tokens ---------- */
:root{
  --terracotta:#be6240;
  --terracotta-deep:#9c4a2c;
  --clay:#c97a52;
  --cream:#f7efe2;
  --cream-2:#fbf6ec;
  --sand:#efe2cf;
  --sand-deep:#e6d5bd;
  --honey:#d7a24c;
  --olive:#6e7355;
  --sage:#9aa07f;
  --ink:#2a211b;
  --espresso:#3a2b21;
  --muted:#806d5e;
  --line:rgba(42,33,27,.14);
  --line-soft:rgba(42,33,27,.08);

  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Mulish",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --script:"Sacramento",cursive;

  --wrap:1180px;
  --gutter:clamp(1.15rem,5vw,2.4rem);
  --radius:18px;
  --radius-lg:26px;
  --shadow:0 18px 48px -22px rgba(58,33,18,.45);
  --shadow-soft:0 10px 30px -18px rgba(58,33,18,.4);
  --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-size:1.02rem;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  /* subtil grain papier */
  background-image:
    radial-gradient(rgba(42,33,27,.025) 1px,transparent 1px),
    radial-gradient(rgba(42,33,27,.018) 1px,transparent 1px);
  background-size:46px 46px,46px 46px;
  background-position:0 0,23px 23px;
}
img{display:block;max-width:100%;height:auto}
svg{height:1em;flex:none}/* garde-fou : évite les SVG sans hauteur explicite */
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
:focus-visible{outline:2.5px solid var(--terracotta);outline-offset:3px;border-radius:4px}

/* ---------- Layout helpers ---------- */
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(3.4rem,9vw,6rem);scroll-margin-top:78px}
.eyebrow{
  font-family:var(--script);
  font-size:clamp(1.5rem,5vw,2rem);
  line-height:1;
  color:var(--terracotta);
  display:inline-block;
}
.title{
  font-family:var(--serif);
  font-weight:500;
  font-optical-sizing:auto;
  line-height:1.04;
  letter-spacing:-.012em;
  color:var(--espresso);
  font-size:clamp(2.1rem,6.5vw,3rem);
}
.lead{
  color:var(--muted);
  font-size:clamp(1.02rem,2.6vw,1.16rem);
  max-width:60ch;
}
.section__head{margin-bottom:clamp(1.8rem,4vw,2.8rem)}
.center{text-align:center}
.center .lead{margin-inline:auto}

/* ---------- Moustache : ornement signature ---------- */
.stache{display:inline-block;width:62px;height:auto;aspect-ratio:640/200;color:var(--terracotta);vertical-align:middle}
.divider{display:flex;align-items:center;justify-content:center;gap:1rem;margin-block:clamp(1.4rem,4vw,2.2rem);color:var(--terracotta)}
.divider::before,.divider::after{content:"";height:1px;width:min(90px,18vw);background:linear-gradient(90deg,transparent,var(--terracotta))}
.divider::after{background:linear-gradient(90deg,var(--terracotta),transparent)}
.divider .stache{width:46px}

/* ---------- Boutons ---------- */
.btn{
  --bg:var(--terracotta);--fg:#fff8f0;
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  background:var(--bg);color:var(--fg);
  font-family:var(--sans);font-weight:800;font-size:.94rem;
  letter-spacing:.01em;
  padding:.92em 1.5em;border-radius:999px;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s;
  box-shadow:0 12px 26px -14px rgba(156,74,44,.85);
  will-change:transform;
}
.btn svg{width:1.05em;height:1.05em}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 34px -14px rgba(156,74,44,.95)}
.btn:active{transform:translateY(-1px)}
.btn--ghost{--bg:transparent;--fg:var(--espresso);border:1.6px solid rgba(42,33,27,.28);box-shadow:none}
.btn--ghost:hover{--bg:rgba(42,33,27,.05);box-shadow:none}
.btn--cream{--bg:var(--cream-2);--fg:var(--terracotta-deep);box-shadow:0 12px 26px -16px rgba(58,33,18,.6)}
.btn--lg{padding:1.06em 1.9em;font-size:1rem}
.btn--block{width:100%}

/* =================================================================
   HEADER
   ================================================================= */
.header{
  position:fixed;inset:0 0 auto 0;z-index:60;
  padding-block:.7rem;
  background:rgba(247,239,226,.9);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 1px 0 var(--line-soft);
  transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.header.scrolled{
  background:rgba(247,239,226,.95);
  box-shadow:0 1px 0 var(--line-soft),0 10px 30px -24px rgba(58,33,18,.6);
}

/* Logo wordmark + moustache */
.logo{display:flex;flex-direction:column;line-height:.9;gap:.16rem;color:var(--espresso)}
.logo__word{
  font-family:var(--serif);font-weight:600;font-size:1.62rem;letter-spacing:-.01em;
  display:inline-flex;align-items:flex-end;gap:.02em;white-space:nowrap;
}
.logo__word .logo__stache{width:1.32em;height:auto;aspect-ratio:640/200;margin:0 .04em .12em;color:currentColor;align-self:center}
.logo__sub{
  font-family:var(--sans);font-weight:800;text-transform:uppercase;
  font-size:.56rem;letter-spacing:.42em;color:var(--terracotta);padding-left:.2em;
}

.nav{display:none}
.nav__list{display:flex;align-items:center;gap:1.7rem}
.nav__list a{
  font-weight:700;font-size:.93rem;position:relative;padding-block:.3rem;color:var(--espresso);
  transition:color .25s;
}
.nav__list a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--terracotta);transition:right .35s var(--ease)}
.nav__list a:hover::after{right:0}
.header__cta{display:none}

/* Burger */
.burger{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;border-radius:50%;background:rgba(42,33,27,.06);align-items:center}
.burger span{display:block;width:21px;height:2px;background:var(--espresso);border-radius:2px;transition:transform .35s var(--ease),opacity .25s}
body.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Drawer mobile */
.drawer{
  position:fixed;inset:0;z-index:55;
  background:linear-gradient(160deg,#34271d,#251b14 70%);
  color:#f7efe2;
  display:flex;flex-direction:column;justify-content:center;
  padding:2rem var(--gutter) 3rem;
  transform:translateY(-100%);
  transition:transform .55s var(--ease);
  visibility:hidden;
}
body.menu-open .drawer{transform:translateY(0);visibility:visible}
.drawer__list{display:flex;flex-direction:column;gap:.2rem}
.drawer__list a{
  font-family:var(--serif);font-size:2rem;font-weight:500;padding-block:.45rem;
  border-bottom:1px solid rgba(247,239,226,.12);display:flex;align-items:center;justify-content:space-between;
  opacity:0;transform:translateY(16px);
}
body.menu-open .drawer__list a{animation:drawerIn .5s var(--ease) forwards}
body.menu-open .drawer__list a:nth-child(1){animation-delay:.12s}
body.menu-open .drawer__list a:nth-child(2){animation-delay:.18s}
body.menu-open .drawer__list a:nth-child(3){animation-delay:.24s}
body.menu-open .drawer__list a:nth-child(4){animation-delay:.30s}
body.menu-open .drawer__list a:nth-child(5){animation-delay:.36s}
body.menu-open .drawer__list a:nth-child(6){animation-delay:.42s}
@keyframes drawerIn{to{opacity:1;transform:none}}
.drawer__list a span{font-family:var(--sans);font-size:.85rem;color:var(--honey)}
.drawer__foot{margin-top:2.2rem;display:flex;flex-direction:column;gap:.9rem}
.drawer__meta{font-size:.92rem;color:#d9c7b2;display:flex;flex-direction:column;gap:.35rem}
.drawer__meta a{font-weight:700}

/* =================================================================
   HERO
   ================================================================= */
.hero{background:var(--cream);padding:calc(70px + clamp(1.4rem,5vw,2.2rem)) clamp(1.5rem,5vw,5rem) clamp(2.4rem,7vw,3.4rem)}
.hero__split{max-width:1120px;margin-inline:auto;display:grid;gap:clamp(1.8rem,5vw,3rem);align-items:center}
.hero__media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);background:var(--sand);order:-1}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 44%;aspect-ratio:4/5;display:block}
.hero__eyebrow{
  font-family:var(--sans);font-weight:800;text-transform:uppercase;letter-spacing:.28em;
  font-size:.72rem;color:var(--terracotta);display:flex;align-items:center;gap:.7rem;margin-bottom:1.05rem;
}
.hero__eyebrow::before{content:"";width:34px;height:1px;background:var(--terracotta);display:inline-block;flex:none}
.hero h1{
  font-family:var(--serif);font-weight:500;font-optical-sizing:auto;
  font-size:clamp(2.3rem,8vw,3.7rem);line-height:1.03;letter-spacing:-.018em;color:var(--espresso);
  text-wrap:balance;
}
.hero h1 em{font-style:italic;color:var(--terracotta)}
.hero__sub{margin-top:1rem;max-width:48ch;font-size:clamp(1.02rem,3vw,1.16rem);color:var(--muted);line-height:1.62}
.hero__actions{margin-top:1.6rem;display:flex;flex-wrap:wrap;gap:.8rem}
.hero__facts{
  margin-top:1.7rem;display:flex;flex-wrap:wrap;gap:.6rem 1.6rem;
  padding-top:1.3rem;border-top:1px solid var(--line);
  font-size:.9rem;color:var(--muted);
}
.hero__facts span{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;color:var(--espresso)}
.hero__facts svg{width:1.05em;height:1.05em;color:var(--terracotta);flex:none}

/* =================================================================
   MARQUEE valeurs
   ================================================================= */
.marquee{background:var(--espresso);color:var(--cream);overflow:hidden;padding-block:.95rem;border-block:1px solid rgba(247,239,226,.08)}
.marquee__track{display:flex;width:max-content;gap:0;animation:scrollx 34s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__item{display:inline-flex;align-items:center;gap:1.3rem;padding-inline:1.3rem;font-family:var(--serif);font-style:italic;font-size:1.18rem;color:#f4e7d4;white-space:nowrap}
.marquee__item svg{width:30px;height:auto;aspect-ratio:640/200;color:var(--honey)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* =================================================================
   À PROPOS
   ================================================================= */
.about{position:relative}
.about__grid{display:grid;gap:clamp(1.8rem,5vw,3.4rem);align-items:center}
.about__media{position:relative}
.about__media .ph{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.about__media .ph img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform 1.1s var(--ease)}
.about__media .ph:hover img{transform:scale(1.05)}
.about__media .ph--sm{position:absolute;width:46%;bottom:-7%;right:-5%;border:6px solid var(--cream);border-radius:var(--radius);box-shadow:var(--shadow)}
.about__media .ph--sm img{aspect-ratio:1/1}
.about__badge{
  position:absolute;top:-4%;left:-4%;width:108px;height:108px;border-radius:50%;
  background:var(--honey);color:var(--espresso);display:grid;place-items:center;text-align:center;
  font-family:var(--serif);font-weight:600;font-size:.82rem;line-height:1.1;rotate:-8deg;
  box-shadow:var(--shadow-soft);padding:.6rem;
}
.about__badge b{display:block;font-size:1.5rem}
.about p+p{margin-top:1rem}
.about__sign{font-family:var(--script);font-size:2.2rem;color:var(--terracotta);margin-top:1.2rem;line-height:1}
.about__vals{margin-top:1.6rem;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.val{display:flex;gap:.75rem;align-items:flex-start}
.val svg{width:1.5rem;height:1.5rem;color:var(--terracotta);flex:none;margin-top:.1rem}
.val b{display:block;font-weight:800;color:var(--espresso)}
.val span{font-size:.9rem;color:var(--muted);line-height:1.4}

/* =================================================================
   LA CARTE
   ================================================================= */
.carte{background:linear-gradient(180deg,var(--cream),var(--sand) 120%)}
.formules{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;max-width:720px;margin:0 auto clamp(2rem,5vw,3rem)}
.formule{
  background:var(--cream-2);border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:1.15rem .8rem;text-align:center;box-shadow:var(--shadow-soft);
}
.formule b{display:block;font-family:var(--serif);font-size:2rem;color:var(--terracotta);font-weight:600}
.formule span{font-size:.82rem;color:var(--muted);font-weight:600;line-height:1.3;display:block;margin-top:.2rem}
.formule small{display:block;font-size:.66rem;text-transform:uppercase;letter-spacing:.18em;color:var(--sage);margin-bottom:.45rem;font-weight:800}

.menucard{
  background:linear-gradient(165deg,var(--clay),var(--terracotta) 58%,var(--terracotta-deep));
  color:#fbeede;border-radius:var(--radius-lg);
  padding:clamp(1.8rem,6vw,3.4rem) clamp(1.5rem,5vw,3rem);
  box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.menucard::after{content:"";position:absolute;inset:14px;border:1px solid rgba(251,238,222,.28);border-radius:calc(var(--radius-lg) - 8px);pointer-events:none}
.menucard__top{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.4rem;margin-bottom:1.8rem;position:relative}
.menucard__top .stache{color:#fbeede;width:54px}
.menucard h3{font-family:var(--serif);font-weight:400;font-size:clamp(2.2rem,8vw,3.4rem);letter-spacing:.04em;line-height:1}
.menucard__week{font-family:var(--script);font-size:1.7rem;color:#ffe6c9;line-height:.9}
.menu-cols{display:grid;gap:1.7rem;position:relative}
.menu-block h4{font-family:var(--script);font-size:2rem;color:#ffe7cb;font-weight:400;line-height:.9;margin-bottom:.7rem}
.menu-block ul{display:flex;flex-direction:column;gap:.7rem}
.menu-block li{font-size:1.02rem;line-height:1.45;padding-left:1.1rem;position:relative;color:#fbf0e2}
.menu-block li::before{content:"";position:absolute;left:0;top:.62em;width:6px;height:6px;border-radius:50%;background:var(--honey)}
.menu-block li b{font-weight:800;color:#fff}
.menucard__foot{margin-top:1.9rem;padding-top:1.3rem;border-top:1px solid rgba(251,238,222,.25);display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;position:relative}
.menucard__foot p{font-size:.92rem;color:#fbe7d3;max-width:42ch}
.menu-tabs{display:flex;gap:.5rem;justify-content:center;margin-bottom:1.4rem;flex-wrap:wrap}
.menu-tab{
  border:1.5px solid var(--line);border-radius:999px;padding:.5em 1.15em;font-weight:800;font-size:.86rem;color:var(--espresso);
  background:var(--cream-2);transition:all .3s var(--ease);
}
.menu-tab[aria-selected="true"]{background:var(--espresso);color:var(--cream);border-color:var(--espresso)}
.menu-pane{display:none}
.menu-pane.active{display:block;animation:fadeUp .5s var(--ease)}
.carte__note{text-align:center;margin-top:1.6rem;color:var(--muted);font-size:.95rem}
.carte__note b{color:var(--terracotta-deep)}

/* =================================================================
   GALERIE
   ================================================================= */
.gallery__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem}
.gitem{position:relative;overflow:hidden;border-radius:14px;cursor:pointer;background:var(--sand)}
.gitem img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease);aspect-ratio:1/1}
.gitem--tall{grid-row:span 2}
.gitem--tall img{aspect-ratio:auto;height:100%}
.gitem::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(28,18,12,.55));opacity:0;transition:opacity .4s}
.gitem figcaption{position:absolute;left:0;right:0;bottom:0;padding:.9rem 1rem;color:#fff;font-weight:700;font-size:.9rem;transform:translateY(8px);opacity:0;transition:all .4s var(--ease);z-index:1;display:flex;align-items:center;gap:.4rem}
.gitem:hover img{transform:scale(1.08)}
.gitem:hover::after{opacity:1}
.gitem:hover figcaption{transform:none;opacity:1}
.gallery__cta{text-align:center;margin-top:1.8rem}
.ig-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:800;color:var(--terracotta-deep)}
.ig-link svg{width:1.2em;height:1.2em}

/* =================================================================
   AVIS / PRESSE
   ================================================================= */
.avis{background:linear-gradient(180deg,var(--espresso),#2c2017);color:var(--cream);position:relative;overflow:hidden}
.avis::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(215,162,76,.16),transparent 70%);top:-15%;right:-12%}
.avis .title{color:var(--cream)}
.avis .eyebrow{color:var(--honey)}
.press{
  background:rgba(247,239,226,.05);border:1px solid rgba(247,239,226,.14);border-radius:var(--radius-lg);
  padding:clamp(1.7rem,5vw,3rem);position:relative;backdrop-filter:blur(3px);max-width:880px;margin-inline:auto;
}
.press__badge{display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.2em;color:var(--honey);margin-bottom:1.1rem}
.press__badge::before{content:"★"}
.press blockquote{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.25rem,3.6vw,1.7rem);line-height:1.4;color:#fdf3e6}
.press blockquote .stache{width:40px;color:var(--honey);margin-bottom:.6rem}
.press cite{display:block;margin-top:1.3rem;font-style:normal;font-weight:800;font-size:.95rem;color:var(--honey)}
.press cite span{display:block;font-weight:500;color:#cdb89f;font-size:.85rem;margin-top:.15rem}
.avis__small{display:grid;grid-template-columns:repeat(2,1fr);gap:.9rem;max-width:880px;margin:1.3rem auto 0}
.mini{background:rgba(247,239,226,.05);border:1px solid rgba(247,239,226,.12);border-radius:14px;padding:1.1rem 1.2rem}
.mini__stars{color:var(--honey);font-size:.9rem;letter-spacing:.12em}
.mini p{font-size:.95rem;color:#eaddcb;margin-top:.4rem}
.mini b{display:block;margin-top:.6rem;font-size:.82rem;color:#bba287}

/* =================================================================
   INFOS PRATIQUES
   ================================================================= */
.infos__grid{display:grid;gap:1.4rem}
.hours{background:var(--cream-2);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:clamp(1.5rem,5vw,2.3rem);box-shadow:var(--shadow-soft)}
.hours h3,.coords h3{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--espresso);margin-bottom:1.1rem;display:flex;align-items:center;gap:.6rem}
.hours h3 svg,.coords h3 svg{width:1.3rem;height:1.3rem;color:var(--terracotta)}
.hours ul{display:flex;flex-direction:column}
.hours li{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:.62rem 0;border-bottom:1px dashed var(--line);font-size:.97rem}
.hours li:last-child{border-bottom:none}
.hours li span:first-child{font-weight:700;color:var(--espresso)}
.hours li .h{color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}
.hours li.is-closed .h{color:var(--clay)}
.hours li .tag{display:inline-block;font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;background:var(--olive);color:#fff;padding:.15em .5em;border-radius:6px;margin-left:.4rem;vertical-align:middle}
.hours__note{margin-top:1rem;font-size:.86rem;color:var(--muted);line-height:1.5;background:var(--sand);border-radius:12px;padding:.8rem 1rem}
.hours__note b{color:var(--terracotta-deep)}
.coords{display:flex;flex-direction:column;gap:1.1rem}
.coord-card{background:var(--cream-2);border:1px solid var(--line-soft);border-radius:var(--radius);padding:1.2rem 1.3rem;display:flex;gap:.9rem;align-items:flex-start;box-shadow:var(--shadow-soft);transition:transform .3s var(--ease)}
.coord-card:hover{transform:translateY(-3px)}
.coord-card svg{width:1.5rem;height:1.5rem;color:var(--terracotta);flex:none;margin-top:.15rem}
.coord-card b{display:block;font-weight:800;color:var(--espresso);font-size:1.02rem}
.coord-card span,.coord-card a{font-size:.94rem;color:var(--muted);line-height:1.5}
.coord-card a{font-weight:700;color:var(--terracotta-deep)}
.map{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-soft);border:1px solid var(--line-soft);min-height:280px;background:var(--sand)}
.map iframe{width:100%;height:100%;min-height:280px;border:0;display:block;filter:saturate(.9) sepia(.12)}

/* =================================================================
   RÉSERVATION / CONTACT
   ================================================================= */
.reserve{background:linear-gradient(165deg,var(--terracotta),var(--terracotta-deep));color:#fdf3e8;position:relative;overflow:hidden}
.reserve .stache{color:rgba(253,243,232,.9)}
.reserve__grid{display:grid;gap:clamp(1.8rem,5vw,3rem)}
.reserve .title{color:#fff8ef}
.reserve__intro p{color:#fbe7d6;margin-top:.8rem;max-width:46ch}
.reserve__quick{margin-top:1.6rem;display:flex;flex-direction:column;gap:.7rem}
.qcta{display:flex;align-items:center;gap:.9rem;background:rgba(255,247,238,.1);border:1px solid rgba(255,247,238,.22);border-radius:14px;padding:.85rem 1.1rem;transition:background .3s,transform .3s var(--ease)}
.qcta:hover{background:rgba(255,247,238,.18);transform:translateX(4px)}
.qcta svg{width:1.4rem;height:1.4rem;flex:none;color:#ffe6cd}
.qcta b{display:block;font-weight:800;font-size:1.05rem;color:#fff}
.qcta span{font-size:.84rem;color:#fbddc6}
.form{background:var(--cream-2);border-radius:var(--radius-lg);padding:clamp(1.5rem,5vw,2.2rem);box-shadow:var(--shadow);color:var(--ink)}
.form h3{font-family:var(--serif);font-size:1.4rem;color:var(--espresso);font-weight:600;margin-bottom:.3rem}
.form>p{font-size:.88rem;color:var(--muted);margin-bottom:1.2rem}
.field{margin-bottom:.95rem}
.field label{display:block;font-weight:700;font-size:.82rem;color:var(--espresso);margin-bottom:.35rem}
.field input,.field textarea,.field select{
  width:100%;font:inherit;font-size:.96rem;color:var(--ink);
  background:var(--cream);border:1.5px solid var(--line);border-radius:12px;padding:.75rem .9rem;
  transition:border-color .25s,box-shadow .25s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--terracotta);box-shadow:0 0 0 3px rgba(190,98,64,.15)}
.field textarea{resize:vertical;min-height:84px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.form__note{font-size:.78rem;color:var(--muted);margin-top:.4rem;text-align:center}
.form__ok{display:none;text-align:center;padding:1.4rem 0}
.form__ok.show{display:block;animation:fadeUp .5s var(--ease)}
.form__ok .stache{color:var(--olive);width:60px;margin-bottom:.5rem}
.form__ok b{font-family:var(--serif);font-size:1.4rem;color:var(--espresso);display:block}
.form__ok p{color:var(--muted);font-size:.92rem;margin-top:.3rem}
.form__ok a{font-weight:800;color:var(--terracotta-deep)}

/* =================================================================
   FOOTER
   ================================================================= */
.footer{background:#211912;color:#d9c8b5;padding-block:clamp(2.6rem,6vw,3.6rem) 1.6rem}
.footer__grid{display:grid;gap:2rem;margin-bottom:2rem}
.footer .logo__word{color:#f7efe2}.footer .logo__sub{color:var(--honey)}
.footer p{font-size:.92rem;line-height:1.6;margin-top:1rem;color:#bda88f;max-width:34ch}
.footer h4{font-family:var(--serif);font-size:1.15rem;color:#f3e7d6;margin-bottom:.9rem;font-weight:500}
.footer a:hover{color:var(--honey)}
.footer__col ul{display:flex;flex-direction:column;gap:.55rem;font-size:.93rem}
.footer__col li{display:flex;gap:.55rem;align-items:flex-start}
.footer__col svg{width:1.05rem;height:1.05rem;color:var(--terracotta);flex:none;margin-top:.18rem}
.footer__social{display:flex;gap:.6rem;margin-top:1rem}
.footer__social a{width:42px;height:42px;border-radius:50%;background:rgba(247,239,226,.08);display:grid;place-items:center;transition:background .3s,transform .3s var(--ease)}
.footer__social a:hover{background:var(--terracotta);transform:translateY(-3px)}
.footer__social svg{width:1.2rem;height:1.2rem;color:#f7efe2}
.footer__bar{border-top:1px solid rgba(247,239,226,.1);padding-top:1.4rem;display:flex;flex-wrap:wrap;gap:.6rem 1.2rem;justify-content:space-between;font-size:.8rem;color:#9c8a74}
.footer__bar a{color:#bda88f;font-weight:700}
.footer__credit{display:inline-flex;align-items:center;gap:.4rem}

/* =================================================================
   CTA flottant mobile
   ================================================================= */
.dock{
  position:fixed;left:0;right:0;bottom:0;z-index:50;
  display:flex;gap:.55rem;padding:.6rem .7rem calc(.6rem + env(safe-area-inset-bottom));
  background:rgba(247,239,226,.94);backdrop-filter:blur(12px);
  border-top:1px solid var(--line-soft);box-shadow:0 -8px 24px -18px rgba(58,33,18,.6);
  transform:translateY(120%);transition:transform .45s var(--ease);
}
.dock.show{transform:none}
.dock .btn{flex:1;padding:.85em 1em;font-size:.9rem}

/* =================================================================
   Lightbox
   ================================================================= */
.lightbox{position:fixed;inset:0;z-index:90;background:rgba(20,13,8,.94);display:none;align-items:center;justify-content:center;padding:1.2rem;cursor:zoom-out}
.lightbox.show{display:flex;animation:fade .3s}
.lightbox img{max-width:100%;max-height:88vh;border-radius:10px;box-shadow:0 30px 80px -20px #000;cursor:default}
.lightbox__close{position:absolute;top:1rem;right:1.1rem;width:48px;height:48px;border-radius:50%;background:rgba(247,239,226,.12);color:#fff;font-size:1.5rem;display:grid;place-items:center}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;background:rgba(247,239,226,.12);color:#fff;font-size:1.6rem;display:grid;place-items:center;transition:background .25s}
.lightbox__nav:hover{background:rgba(247,239,226,.25)}
.lightbox__nav.prev{left:1rem}.lightbox__nav.next{right:1rem}

/* =================================================================
   Reveal animations
   ================================================================= */
.reveal{transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js .reveal{opacity:0;transform:translateY(26px)}
.js .reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.1s}.reveal[data-d="2"]{transition-delay:.2s}.reveal[data-d="3"]{transition-delay:.3s}.reveal[data-d="4"]{transition-delay:.4s}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.marquee__track,.scroll-cue i{animation:none}}

/* =================================================================
   DESKTOP — contenu, épuré (mobile-first préservé)
   ================================================================= */
@media (min-width:760px){
  .about__grid{grid-template-columns:1.05fr .95fr}
  .about__grid.rev{direction:rtl}.about__grid.rev>*{direction:ltr}
  .infos__grid{grid-template-columns:1fr 1fr}
  .reserve__grid{grid-template-columns:.9fr 1.1fr;align-items:center}
  .gallery__grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr}
  .menu-cols{grid-template-columns:repeat(3,1fr);gap:2rem}
  .avis__small{grid-template-columns:repeat(3,1fr)}
  .footer__grid{grid-template-columns:1.4fr 1fr 1fr;gap:2.4rem}
}
@media (min-width:900px){
  .nav{display:block}
  .header__cta{display:inline-flex}
  .burger{display:none}
  .dock{display:none}
  /* Hero scindé en 2 colonnes : texte | photo, marges crème généreuses */
  .hero{padding-top:calc(72px + clamp(2rem,4vw,3.4rem));padding-bottom:clamp(2rem,4vw,3.4rem)}
  .hero__split{grid-template-columns:1.02fr .98fr;gap:clamp(2.6rem,5vw,4.6rem)}
  .hero__media{order:0;height:min(76vh,660px)}
  .hero__media img{aspect-ratio:auto;height:100%}
  .infos__grid{grid-template-columns:1.05fr 1.25fr}
  .reserve__grid{grid-template-columns:.85fr 1.15fr}
}
@media (min-width:1100px){
  :root{--gutter:2.4rem}
  .hero h1{font-size:clamp(3rem,4vw,3.9rem)}
  .menu-cols{gap:2.6rem}
}
@media (min-width:1500px){.hero__media{height:660px}}
