/* =====================================================================
   La Fanthaïsie — style.css
   Direction : papier de riz, bleu pétrole de l'hirondelle, kaki.
   Titres Fraunces, texte Inter. Éditorial, asymétrique, sobre.
   ===================================================================== */

:root {
  --paper:#F4EEDF;
  --paper-2:#EFE7D3;
  --ink:#241F1C;
  --ink-soft:#5B524A;
  --teal:#0E5C57;
  --teal-2:#15807A;
  --persimmon:#D9622B;
  --persimmon-2:#E89A5C;
  --olive:#6E7B3E;
  --gold:#C9A24B;

  --maxw:1120px;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 14px 40px -18px rgba(36,31,28,.28);
  --shadow-soft:0 6px 22px -14px rgba(36,31,28,.3);
  /* Typographie « esprit Hinata » : titres manuscrits + texte sans-serif doux.
     --serif est conservé comme alias de --script pour ne rien casser. */
  --script:"Caveat", "Segoe Script", cursive;
  --serif:"Caveat", "Segoe Script", cursive;
  --sans:"Work Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
}

/* --- Reset léger --------------------------------------------------- */
*,*::before,*::after { box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior:auto; }
  *,*::before,*::after { animation-duration:.001ms !important; transition-duration:.001ms !important; }
}
body {
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img { max-width:100%; display:block; }
a { color:var(--teal); text-decoration:none; }
a:hover { text-decoration:underline; }
/* Grands titres : police manuscrite (Caveat) — on agrandit car une écriture
   manuscrite « pèse » moins qu'une serif à taille égale. */
h1,h2 { font-family:var(--script); font-weight:700; line-height:1.05; color:var(--ink); margin:0 0 .3em; letter-spacing:0; }
h1 { font-size:clamp(2.6rem, 6vw, 4rem); }
h2 { font-size:clamp(2rem, 4.5vw, 3rem); }
/* Sous-titres : sans-serif, plus sobres et lisibles */
h3 { font-family:var(--sans); font-weight:600; line-height:1.2; color:var(--ink); margin:0 0 .4em; letter-spacing:-.01em; }
p { margin:0 0 1em; }

.wrap { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }

.visually-hidden {
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* --- Accessibilité : focus & skip link ----------------------------- */
:focus-visible { outline:3px solid var(--teal-2); outline-offset:2px; border-radius:3px; }
.skip-link {
  position:absolute; left:-999px; top:0; z-index:999;
  background:var(--teal); color:var(--paper); padding:.7em 1.2em; border-radius:0 0 var(--radius-sm) 0;
}
.skip-link:focus { left:0; }

/* --- Boutons ------------------------------------------------------- */
.btn {
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--sans); font-weight:600; font-size:.98rem;
  padding:.72em 1.3em; border-radius:999px; border:1.5px solid transparent;
  cursor:pointer; transition:transform .18s ease, background .2s ease, box-shadow .2s ease;
  text-decoration:none; white-space:nowrap;
}
.btn:hover { text-decoration:none; transform:translateY(-1px); }
.btn-primary { background:var(--persimmon); color:#fff; box-shadow:var(--shadow-soft); }
.btn-primary:hover { background:var(--persimmon-2); color:var(--ink); }
.btn-ghost { background:transparent; color:var(--teal); border-color:var(--teal); }
.btn-ghost:hover { background:rgba(14,92,87,.07); }
.btn-big { font-size:1.08rem; padding:.85em 1.6em; margin-top:.4em; }

/* =====================================================================
   HEADER
   ===================================================================== */
.site-header {
  position:sticky; top:0; z-index:100;
  background:var(--paper); /* repli navigateurs anciens */
  background:color-mix(in srgb, var(--paper) 85%, transparent); /* suit la palette, translucide */
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid rgba(36,31,28,.08);
}
.header-inner { display:flex; align-items:center; justify-content:space-between; gap:18px; min-height:74px; }

.brand { display:inline-flex; align-items:center; }
.brand:hover { text-decoration:none; }
/* Logo dans une pastille ronde blanche (le logo a un fond blanc : on
   l'assume joliment plutôt que de le laisser « flotter » sur le papier). */
.brand-logo {
  height:56px; width:56px; border-radius:50%; object-fit:cover; display:block;
  background:#fff; padding:5px;
  border:1.5px solid rgba(14,92,87,.25);
  box-shadow:0 4px 14px -6px rgba(36,31,28,.35);
}

.site-nav { display:flex; align-items:center; gap:26px; }
.nav-list { display:flex; align-items:center; gap:22px; list-style:none; margin:0; padding:0; }
.nav-list a { color:var(--ink-soft); font-weight:500; font-size:.97rem; padding:.3em 0; position:relative; }
.nav-list a:hover { color:var(--ink); text-decoration:none; }
.nav-list a.is-active { color:var(--teal); }
.nav-list a.is-active::after {
  content:""; position:absolute; left:0; right:0; bottom:-4px; height:2px; background:var(--persimmon); border-radius:2px;
}

.nav-actions { display:flex; align-items:center; gap:14px; }

/* --- Sélecteur de langue (menu déroulant + drapeaux) -------------- */
.lang-select { position:relative; }
.flag { border-radius:2px; box-shadow:0 0 0 1px rgba(36,31,28,.12); flex:none; display:block; }
.lang-current {
  display:inline-flex; align-items:center; gap:7px; cursor:pointer;
  font-family:var(--sans); font-weight:600; font-size:.85rem; letter-spacing:.03em; color:var(--teal);
  border:1.5px solid var(--teal); background:transparent;
  border-radius:999px; padding:.3em .6em .3em .55em;
  transition:background .15s ease, color .15s ease;
}
.lang-current:hover { background:rgba(14,92,87,.07); }
.lang-caret { transition:transform .2s ease; }
.lang-select.open .lang-caret { transform:rotate(180deg); }

.lang-menu {
  position:absolute; top:calc(100% + 8px); right:0; z-index:120;
  list-style:none; margin:0; padding:6px; min-width:168px;
  background:var(--paper); border:1px solid rgba(36,31,28,.12);
  border-radius:var(--radius-sm); box-shadow:var(--shadow);
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:opacity .16s ease, transform .16s ease, visibility .16s ease;
}
.lang-select.open .lang-menu { opacity:1; visibility:visible; transform:translateY(0); }
.lang-menu a {
  display:flex; align-items:center; gap:10px;
  padding:.55em .7em; border-radius:8px; color:var(--ink); font-weight:500; font-size:.95rem;
}
.lang-menu a:hover { background:var(--paper-2); text-decoration:none; }
.lang-menu a.is-current { color:var(--teal); font-weight:600; }
.lang-menu a.is-current::after { content:"✓"; margin-left:auto; color:var(--persimmon); }
.btn-phone { background:var(--teal); color:var(--paper); padding:.55em 1em; font-size:.92rem; }
.btn-phone:hover { background:var(--teal-2); color:#fff; }

.nav-toggle {
  display:none; flex:none; width:46px; height:46px; border:none; background:transparent;
  cursor:pointer; position:relative; border-radius:10px; -webkit-tap-highlight-color:transparent;
  transition:background .2s ease;
}
.nav-toggle:hover { background:rgba(36,31,28,.06); }
.nav-toggle-bar, .nav-toggle-bar::before, .nav-toggle-bar::after {
  content:""; position:absolute; left:11px; width:24px; height:2.5px;
  background:var(--ink); border-radius:2px;
  transition:transform .32s cubic-bezier(.6,.05,.28,1), top .28s cubic-bezier(.6,.05,.28,1), opacity .2s ease;
}
.nav-toggle-bar { top:22px; }
.nav-toggle-bar::before { top:-7px; }
.nav-toggle-bar::after  { top:7px; }
body.nav-open .nav-toggle-bar { background:transparent; transition:background 0s; }
body.nav-open .nav-toggle-bar::before { top:0; transform:rotate(45deg); }
body.nav-open .nav-toggle-bar::after  { top:0; transform:rotate(-45deg); }

/* =====================================================================
   HÉRO (asymétrique)
   ===================================================================== */
.hero { padding:64px 0 28px; overflow:hidden; }
.hero-grid {
  display:grid; grid-template-columns:1.15fr .85fr; gap:54px; align-items:center;
}
.kicker {
  font-family:var(--serif); font-style:italic; color:var(--teal);
  font-size:1.05rem; margin:0 0 .6em;
}
.hero-title { font-size:clamp(2.3rem, 5vw, 3.6rem); margin-bottom:.35em; }
.hero-title em { color:var(--persimmon); font-style:italic; }
.lede { font-size:1.16rem; color:var(--ink-soft); max-width:42ch; }
.hero-meta {
  display:flex; align-items:center; gap:.7em; flex-wrap:wrap;
  font-size:.95rem; color:var(--ink-soft); margin:1.2em 0 1.6em;
}
.meta-sep { color:var(--persimmon-2); }
.stars { color:var(--gold); letter-spacing:1px; margin-right:.3em; }
.hero-cta { display:flex; gap:14px; flex-wrap:wrap; }

/* Panneau de marque (réserve photo) */
.brand-panel {
  position:relative; border-radius:var(--radius); overflow:hidden;
  aspect-ratio:4/4.5; box-shadow:var(--shadow);
  background:var(--teal);
  transform:rotate(1.2deg);
}
.brand-panel-art { position:absolute; inset:0; width:100%; height:100%; }
.brand-panel-caption {
  position:absolute; left:14px; bottom:14px;
  background:rgba(244,238,223,.92); color:var(--ink-soft);
  font-size:.78rem; letter-spacing:.02em; padding:.4em .8em; border-radius:999px;
}
.brand-panel-tall { aspect-ratio:auto; height:100%; min-height:420px; transform:rotate(-1deg); }

/* Photo héros */
.hero-photo {
  margin:0; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow); transform:rotate(1.2deg); line-height:0;
}
.hero-photo img { width:100%; height:100%; aspect-ratio:4/4.6; object-fit:cover; }
/* Repli quand aucune photo héros n'a été ajoutée (placeholder neutre). */
.hero-photo--empty {
  aspect-ratio:4/4.6; display:flex; align-items:center; justify-content:center;
  background:var(--paper-2); color:var(--ink-soft); text-align:center; padding:24px;
}
.hero-photo-hint { font-size:.95rem; opacity:.8; }

/* =====================================================================
   CARROUSEL D'ACCUEIL (1–5 images)
   ===================================================================== */
.hero-carousel {
  position:relative; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow); transform:rotate(1.2deg); line-height:0;
  aspect-ratio:4/4.6; background:var(--teal);
}
.carousel-track { position:absolute; inset:0; }
.carousel-slide {
  position:absolute; inset:0; margin:0; opacity:0; visibility:hidden;
  transition:opacity .6s ease, visibility .6s ease;
}
.carousel-slide.is-active { opacity:1; visibility:visible; }
.carousel-slide img { width:100%; height:100%; object-fit:cover; }
.carousel-btn {
  position:absolute; top:50%; transform:translateY(-50%);
  width:42px; height:42px; border-radius:999px; border:none; cursor:pointer;
  background:rgba(244,238,223,.88); color:var(--ink); font-size:1.5rem; line-height:1;
  display:flex; align-items:center; justify-content:center; z-index:2;
  transition:background .15s ease;
}
.carousel-btn:hover { background:#fff; }
.carousel-prev { left:12px; }
.carousel-next { right:12px; }
.carousel-dots {
  position:absolute; left:0; right:0; bottom:12px; z-index:2;
  display:flex; justify-content:center; gap:8px; line-height:1;
}
.carousel-dot {
  width:9px; height:9px; border-radius:999px; border:none; cursor:pointer; padding:0;
  background:rgba(244,238,223,.55); transition:background .15s ease, transform .15s ease;
}
.carousel-dot.is-active { background:var(--persimmon); transform:scale(1.25); }

/* Bandeau actu (étape 4) */
.actu-banner {
  background:var(--persimmon); color:#fff;
}
.actu-banner-inner {
  display:flex; align-items:center; justify-content:center; gap:.6em; flex-wrap:wrap;
  padding:12px 24px; font-size:.96rem; text-align:center;
}

/* =====================================================================
   BANDEAU (accroche en grand)
   ===================================================================== */
.strip {
  background:var(--teal); color:var(--paper);
  border:0; box-shadow:none;
  /* Évite tout liseré clair au raccord avec la section papier dessous. */
  margin-bottom:-1px;
}
.strip-inner {
  display:flex; align-items:center; justify-content:center;
  padding:13px 24px; text-align:center;
}
.strip-headline {
  margin:0; font-family:var(--script); font-weight:600; line-height:1.2;
  font-size:clamp(1.3rem, 2.4vw, 1.8rem); letter-spacing:.01em;
  color:var(--paper); max-width:none;
}
/* (anciens éléments du bandeau, conservés au cas où) */
.strip-inner em { font-family:var(--serif); font-style:italic; color:var(--persimmon-2); }
.strip .dot { color:var(--teal-2); }

/* =====================================================================
   SECTIONS GÉNÉRIQUES
   ===================================================================== */
.section { padding:74px 0; }
.section-head { max-width:60ch; margin-bottom:40px; }
.eyebrow {
  text-transform:uppercase; letter-spacing:.16em; font-size:.76rem; font-weight:600;
  color:var(--persimmon); margin:0 0 .8em;
}
.eyebrow-light { color:var(--persimmon-2); }
.section h2 { font-size:clamp(1.7rem, 3.2vw, 2.4rem); }
.section-intro { font-size:1.1rem; color:var(--ink-soft); }

/* Cartes plats */
.dish-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:22px;
}
.dish-card {
  background:var(--paper-2); border:1px solid rgba(36,31,28,.07);
  border-radius:var(--radius); overflow:hidden;
  display:flex; flex-direction:column;
  transition:transform .2s ease, box-shadow .2s ease;
}
.dish-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-soft); }
.dish-photo { display:block; line-height:0; overflow:hidden; }
.dish-photo img {
  width:100%; aspect-ratio:4/3; object-fit:cover; display:block;
  transition:transform .35s ease;
}
.dish-card:hover .dish-photo img { transform:scale(1.05); }
.dish-body { padding:18px 20px 22px; }
.dish-tag {
  text-transform:uppercase; letter-spacing:.1em; font-size:.7rem; font-weight:600;
  color:var(--teal); margin:0 0 .3em;
}
.dish-card h3 { font-size:1.18rem; margin-bottom:.3em; }
.dish-card p { font-size:.95rem; color:var(--ink-soft); margin:0; }

.prices {
  margin-top:36px; font-size:1rem; color:var(--ink-soft);
  border-top:1px dashed rgba(36,31,28,.2); padding-top:20px;
}
.prices-note { display:inline-block; margin-left:.4em; font-style:italic; opacity:.8; }

/* =====================================================================
   PRÉSENTATION (image à gauche, texte à droite)
   ===================================================================== */
.about-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center;
}
.about-photo {
  margin:0; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow); line-height:0;
}
.about-photo img { width:100%; height:100%; aspect-ratio:4/3; object-fit:cover; }
.about-text h2 { font-size:clamp(2.2rem, 4vw, 3.2rem); margin-bottom:.3em; }
.about-text p { font-size:1.08rem; color:var(--ink-soft); }

/* ---- Sections modulaires « texte + image » (constructeur) ---- */
.sec-ti-grid { display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.sec-ti-photo { margin:0; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); line-height:0; }
.sec-ti-photo img { width:100%; height:100%; aspect-ratio:4/3; object-fit:cover; }
.sec-ti-text h2 { font-size:clamp(2rem, 3.6vw, 2.9rem); margin-bottom:.3em; }
.sec-ti-text p { font-size:1.08rem; color:var(--ink-soft); }
/* Image à gauche : on inverse l'ordre (photo d'abord dans le DOM = à gauche). */
.sec-ti--left  .sec-ti-photo { order:-1; }
/* Image au centre, texte de part et d'autre */
.sec-ti--center .sec-ti-grid { display:block; }
.sec-ti--center .sec-ti-title { text-align:center; font-size:clamp(2rem,3.6vw,2.9rem); margin-bottom:.6em; }
.sec-ti-cols { display:grid; grid-template-columns:1fr auto 1fr; gap:40px; align-items:center; }
.sec-ti-cols .sec-ti-photo { width:300px; max-width:34vw; }
/* Images des deux côtés, texte au milieu */
.sec-ti--textmid .sec-ti-grid { display:block; }
.sec-ti-cols--imgsides { grid-template-columns:1fr 1.3fr 1fr; }
.sec-ti-cols--imgsides .sec-ti-photo { width:100%; max-width:none; }
.sec-ti-text--mid { text-align:center; }

/* ---- Sections galerie / carrousel / vidéo / coordonnées ---- */
.sec-block-title { font-size:clamp(1.8rem,3.2vw,2.6rem); text-align:center; margin:0 0 .8em; }
.sec-gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.sec-gallery-grid figure { margin:0; border-radius:var(--radius-sm); overflow:hidden; line-height:0; aspect-ratio:4/3; }
.sec-gallery-grid img { width:100%; height:100%; object-fit:cover; transition:transform .3s ease; }
.sec-gallery-grid figure:hover img { transform:scale(1.05); }
/* Carrousel en section : plus compact que le hero (largeur réduite, ratio
   paysage, pas de rotation ni de hauteur quasi-carrée). */
.sec-carousel-box {
  max-width:680px; margin:0 auto;
  aspect-ratio:16/9; transform:none; box-shadow:var(--shadow-soft);
}
.sec-carousel-box .carousel-slide img { width:100%; height:100%; aspect-ratio:auto; object-fit:cover; border-radius:0; }
.sec-video-frame { max-width:920px; margin:0 auto; aspect-ratio:16/9; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-soft); }
.sec-video-frame iframe { width:100%; height:100%; border:0; display:block; }
/* Bloc Coordonnées & horaires : une carte en deux colonnes, avec icônes. */
.sec-ci-card {
  display:grid; grid-template-columns:1fr 1fr; gap:0;
  background:var(--paper-2); border:1px solid rgba(36,31,28,.08);
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-soft);
}
.sec-ci-col { padding:34px 38px; }
.sec-ci-col + .sec-ci-col { border-left:1px solid rgba(36,31,28,.10); }
.sec-ci-head { display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.sec-ci-head svg { color:var(--teal); flex:none; }
.sec-ci-head h2 { margin:0; font-size:clamp(1.4rem,2.4vw,1.9rem); }
.sec-ci-addr { font-style:normal; font-size:1.08rem; line-height:1.75; }
.sec-ci-tel { display:flex; align-items:center; gap:9px; margin:12px 0 20px; }
.sec-ci-tel svg { color:var(--persimmon); flex:none; }
.sec-ci-tel a { font-family:var(--serif); font-size:1.5rem; color:var(--persimmon); }
.sec-ci-days { font-size:1.1rem; margin-bottom:.3em; }
.sec-ci-dl { display:grid; grid-template-columns:auto 1fr; gap:.5em 1.4em; margin:.7em 0; max-width:300px; }
.sec-ci-dl dt { font-weight:600; } .sec-ci-dl dd { margin:0; color:var(--ink-soft); }
.sec-ci-closed { color:var(--ink-soft); margin-top:16px; font-style:italic; }
@media (max-width:760px) {
  .sec-gallery-grid { grid-template-columns:1fr 1fr; }
  .sec-ci-card { grid-template-columns:1fr; }
  .sec-ci-col { padding:26px 24px; }
  .sec-ci-col + .sec-ci-col { border-left:0; border-top:1px solid rgba(36,31,28,.10); }
}
.sec-ti-cols .sec-ti-text p { font-size:1rem; }
@media (max-width: 760px) {
  .sec-ti-grid { grid-template-columns:1fr; gap:28px; }
  .sec-ti--left .sec-ti-photo { order:0; }
  .sec-ti-photo img { aspect-ratio:16/10; }
  .sec-ti-cols { grid-template-columns:1fr; gap:22px; }
  .sec-ti-cols .sec-ti-photo { width:100%; max-width:none; order:-1; }
}
.about-quote {
  margin:1.4em 0; padding:1.1em 1.3em; border-left:4px solid var(--persimmon);
  background:var(--paper-2); border-radius:0 var(--radius-sm) var(--radius-sm) 0;
}
.about-quote .quote-swallow { margin-bottom:.3em; }
.about-quote blockquote {
  margin:0; font-family:var(--script); font-size:1.6rem;
  color:var(--teal); line-height:1.3;
}
.about-sign {
  font-family:var(--script); font-size:1.7rem;
  color:var(--ink); margin-top:.6em;
}

@media (max-width: 880px) {
  .about-grid { grid-template-columns:1fr; gap:30px; }
  .about-photo img { aspect-ratio:16/10; }
}

/* =====================================================================
   FORMULE (carte pétrole)
   ===================================================================== */
.lunch-card {
  position:relative; overflow:hidden;
  background:linear-gradient(135deg, var(--teal), var(--teal-2));
  color:var(--paper); border-radius:var(--radius);
  display:grid; grid-template-columns:1.5fr .9fr; gap:30px;
  padding:46px 44px; box-shadow:var(--shadow);
}
.lunch-watermark { position:absolute; right:-20px; top:10px; width:340px; opacity:.9; pointer-events:none; }
.lunch-body { position:relative; z-index:1; }
.lunch-card h2 { color:#fff; }
.lunch-text { color:rgba(244,238,223,.9); }
.lunch-items {
  list-style:none; margin:1.2em 0 0; padding:0;
  display:flex; flex-wrap:wrap; gap:.5em .8em;
}
.lunch-items li {
  background:rgba(244,238,223,.14); border:1px solid rgba(244,238,223,.25);
  padding:.35em .9em; border-radius:999px; font-size:.92rem;
}
.lunch-price-box {
  position:relative; z-index:1;
  display:flex; flex-direction:column; align-items:flex-start; justify-content:center; gap:.2em;
  background:rgba(244,238,223,.1); border-radius:var(--radius-sm); padding:26px;
  border:1px solid rgba(244,238,223,.2);
}
.lunch-price { font-family:var(--serif); font-size:2.6rem; color:#fff; line-height:1; }
.lunch-price-note { color:rgba(244,238,223,.85); font-size:.95rem; }
.lunch-renew {
  margin:.6em 0 1em; font-style:italic; font-family:var(--serif);
  color:var(--persimmon-2); font-size:1rem;
}

/* =====================================================================
   PAGE-HEAD (carte/histoire/contact/legal)
   ===================================================================== */
.page-head { padding:60px 0 10px; }
.page-head h1 { font-size:clamp(2rem, 4vw, 3rem); }
.page-head--centered { text-align:center; padding:60px 0 20px; }
.page-head--centered h1 { font-size:clamp(2.6rem, 6vw, 4rem); margin:0; }
.page-intro { font-size:1.12rem; color:var(--ink-soft); max-width:54ch; }

/* =====================================================================
   CARTE (menu)
   ===================================================================== */
/* Une seule colonne, façon menu imprimé, centrée et de largeur lisible. */
.menu-wrap { max-width:680px; margin-inline:auto; }
.menu-block { margin-bottom:30px; }
/* En-tête de catégorie = <summary> (repliable sur mobile). */
.menu-block-head {
  display:flex; align-items:center; justify-content:space-between; gap:.6em;
  margin-bottom:.7em; list-style:none; cursor:default;
}
.menu-block-head::-webkit-details-marker { display:none; }
.menu-block-title {
  margin:0; font-size:1.4rem; color:var(--teal);
  border-bottom:2px solid var(--persimmon); padding-bottom:.15em;
}
.menu-block-chevron { display:none; flex:none; color:var(--teal); transition:transform .2s ease; }
.menu-block-note { margin:-.2em 0 .9em; font-style:italic; color:var(--ink-soft); font-size:.92rem; }
/* Séparations optionnelles avant une catégorie (réglées en admin). */
.menu-gap { height:34px; }
.menu-sep {
  border:0; height:0; border-top:1px solid rgba(36,31,28,.15);
  width:120px; margin:34px auto;
}
/* Séparateur coloré : ressort nettement (couleur de marque). */
.menu-band {
  height:4px; border-radius:999px; margin:38px auto 34px; width:90px;
  background:var(--persimmon);
}
/* Séparateur en SECTION (accueil / contact) : un peu d'air vertical, centré. */
.sec-separator { padding:8px 0; }
.sec-separator .wrap { display:flex; justify-content:center; }
.sec-separator--space { padding:0; }
.sec-separator--space .menu-gap { height:48px; }
/* Desktop : tout déplié, non repliable. */
@media (min-width:561px) { .menu-block-head { pointer-events:none; } }
.menu-list { list-style:none; margin:0; padding:0; }
.menu-item { padding:.7em 0; border-bottom:1px solid rgba(36,31,28,.08); }
.menu-item-main { display:flex; align-items:baseline; gap:.5em; }
.menu-item-name { font-weight:600; font-family:var(--serif); font-size:1.08rem; }
.menu-item-leader { flex:1; border-bottom:1px dotted rgba(36,31,28,.3); transform:translateY(-3px); }
.menu-item-price { font-weight:600; color:var(--persimmon); white-space:nowrap; }
.menu-item-desc { display:block; color:var(--ink-soft); font-size:.94rem; margin-top:.15em; }

/* Plat avec photo : miniature à gauche */
.menu-item { display:flex; gap:14px; align-items:flex-start; }
.menu-item-body { flex:1; min-width:0; }
.menu-item-photo { flex:none; line-height:0; }
.menu-item-photo img {
  width:64px; height:64px; object-fit:cover; border-radius:var(--radius-sm);
}
.menu-item-price2 { color:var(--ink-soft); font-weight:500; font-size:.92em; }
/* Vins : prix par volume (verre / 25cl / 75cl…) alignés à droite */
.menu-item-price:has(.menu-vol) { white-space:normal; text-align:right; }
.menu-vol { white-space:nowrap; }
.menu-vol + .menu-vol::before { content:"·"; margin:0 .45em; color:var(--ink-soft); font-weight:400; }
.menu-vol-l { color:var(--ink-soft); font-weight:600; font-size:.82em; margin-right:.25em; }

/* Suggestion / plat du jour */
.menu-special-tag {
  display:inline-block; vertical-align:middle; margin-right:.4em;
  background:var(--persimmon); color:#fff; font-family:var(--sans);
  font-size:.66rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  padding:.18em .55em; border-radius:999px;
}
.menu-item.is-special .menu-item-name { color:var(--persimmon); }

/* Labels diététiques + allergènes */
.menu-item-meta { display:flex; flex-wrap:wrap; align-items:center; gap:.4em .6em; margin-top:.35em; }
.menu-label {
  background:rgba(110,123,62,.14); color:var(--olive);
  font-size:.74rem; font-weight:600; padding:.15em .6em; border-radius:999px;
}
.menu-allergens { font-size:.82rem; color:var(--ink-soft); font-style:italic; }

.menu-example-note {
  grid-column:1 / -1; margin-top:14px; font-style:italic; color:var(--ink-soft); font-size:.92rem;
}

/* Formule PDF */
.formula { background:transparent; border-radius:var(--radius); padding-top:0; }
.formula-updated { color:var(--ink-soft); }
/* Affichage PDF : la page A4 entière, sans scroll interne (ratio A4 = 1/√2).
   Le cadre prend la hauteur correspondant à sa largeur → tout est visible. */
.formula-preview {
  border-radius:var(--radius-sm); overflow:hidden;
  box-shadow:var(--shadow); background:#fff;
  max-width:820px; margin:0 auto;   /* une page A4 bien lisible, centrée */
}
.formula-preview object,
.formula-pdf {
  display:block; width:100%; aspect-ratio:1 / 1.414; height:auto; border:0;
}
/* Carte affichée comme IMAGE (fond blanc parfait, aucun cadre de viewer). */
.formula-preview.is-image { background:#fff; max-width:880px; }
.formula-img { display:block; width:100%; height:auto; }
.formula-fallback { padding:30px; text-align:center; }
.formula-soon {
  background:#fff; border:1px dashed var(--teal); border-radius:var(--radius);
  padding:34px; max-width:60ch;
}
.formula-soon h3 { color:var(--teal); }

/* =====================================================================
   HISTOIRE
   ===================================================================== */
.story-grid { display:grid; grid-template-columns:1.3fr .7fr; gap:54px; align-items:start; }
.story-text p { font-size:1.1rem; }
.story-quote {
  margin:1.6em 0; padding:1.2em 1.4em; border-left:4px solid var(--persimmon);
  background:var(--paper-2); border-radius:0 var(--radius-sm) var(--radius-sm) 0;
}
.quote-swallow { margin-bottom:.3em; }
.story-quote blockquote {
  margin:0; font-family:var(--serif); font-style:italic; font-size:1.32rem; color:var(--teal); line-height:1.35;
}
.story-sign {
  font-family:var(--serif); font-style:italic; font-size:1.25rem; color:var(--ink); margin-top:1.2em;
}
.story-aside { position:sticky; top:100px; }
.story-photo {
  margin:0; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow); transform:rotate(-1deg); line-height:0;
}
.story-photo img { width:100%; aspect-ratio:276/400; object-fit:cover; }

/* =====================================================================
   CONTACT
   ===================================================================== */
.contact-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-bottom:38px; }
.contact-card {
  background:var(--paper-2); border:1px solid rgba(36,31,28,.10);
  border-radius:var(--radius); padding:26px 24px;
  box-shadow:0 12px 30px -22px rgba(36,31,28,.55);
  transition:transform .2s ease, box-shadow .2s ease;
}
.contact-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-soft); }
.contact-card-head { display:flex; align-items:center; gap:9px; margin-bottom:12px; }
.contact-card-head svg { color:var(--teal); flex:none; }
.contact-card-head h2 { margin:0; }
.contact-card h2 { font-size:1.25rem; color:var(--teal); }
.contact-card address { font-style:normal; font-size:1.05rem; }
.contact-note { color:var(--ink-soft); font-size:.92rem; margin-top:.6em; }
.contact-link { font-weight:600; }
.contact-tel { font-family:var(--serif); font-size:1.5rem; color:var(--persimmon); }
.contact-insta {
  display:inline-flex; align-items:center; gap:.55em;
  margin-top:1em; padding:.5em .9em;
  border:1px solid rgba(36,31,28,.12); border-radius:999px;
  font-weight:600; color:var(--teal); background:var(--paper);
  transition:color .2s ease, border-color .2s ease, transform .2s ease;
}
.contact-insta:hover { color:var(--persimmon); border-color:var(--persimmon); transform:translateY(-2px); }
.contact-insta-icon { flex:none; }
.contact-insta-handle { font-size:1rem; }
.hours-dl { display:grid; grid-template-columns:auto 1fr; gap:.3em 1em; margin:.6em 0; }
.hours-dl dt { font-weight:600; }
.hours-dl dd { margin:0; color:var(--ink-soft); }
.contact-closed, .contact-hours { color:var(--ink-soft); }
.map-embed { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-soft); line-height:0; }
/* Section « Carte Google Maps » (page Contact composée en sections). */
.sec-map { padding:24px 0; }
.sec-map-title { margin:0 0 14px; }

/* =====================================================================
   LEGAL
   ===================================================================== */
.legal-wrap { max-width:70ch; }
.legal-wrap h2 { font-size:1.3rem; color:var(--teal); margin-top:1.4em; }

/* =====================================================================
   BANDEAU COOKIES
   ===================================================================== */
.cookie-banner {
  position:fixed; left:0; right:0; bottom:0; z-index:200;
  background:var(--ink); color:var(--paper-2);
  box-shadow:0 -8px 30px -16px rgba(36,31,28,.6);
}
.cookie-inner {
  display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding:14px 24px; flex-wrap:wrap;
}
.cookie-text { margin:0; font-size:.92rem; max-width:70ch; }
.cookie-text a { color:var(--persimmon-2); }
.cookie-actions { display:flex; gap:10px; flex:none; }
.cookie-btn { padding:.5em 1.1em; font-size:.9rem; }
.cookie-banner .btn-ghost { color:var(--paper-2); border-color:rgba(244,238,223,.5); }
.cookie-banner .btn-ghost:hover { background:rgba(244,238,223,.12); }

/* Carte : message de remplacement avant consentement */
.map-embed { position:relative; }
.map-consent {
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px;
  text-align:center; padding:48px 24px; background:var(--paper-2);
  border-radius:var(--radius); color:var(--ink-soft);
}
.map-consent-icon { color:var(--teal); opacity:.85; }
.map-consent-text { margin:0; max-width:42ch; font-size:1.02rem; line-height:1.5; }
.map-noscript { padding:20px; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer { background:var(--ink); color:var(--paper-2); margin-top:40px; }
.footer-grid {
  display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding:56px 24px 30px;
}
.footer-brand {
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--serif); font-size:1.4rem; color:var(--paper); margin-bottom:.5em;
}
.footer-brand-logo {
  width:40px; height:40px; border-radius:50%; object-fit:contain;
  background:#fff; padding:3px; flex:none;
}
.footer-pitch p { color:rgba(244,238,223,.72); max-width:38ch; }
.footer-h { font-size:1.05rem; color:var(--persimmon-2); margin-bottom:.6em; }
.site-footer address { font-style:normal; line-height:1.9; }
.site-footer a { color:var(--paper-2); }
.site-footer a:hover { color:#fff; }
.footer-hours strong { color:var(--paper); }
.footer-closed { color:var(--persimmon-2); font-style:italic; margin-top:.6em; }
.footer-bottom {
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  border-top:1px solid rgba(244,238,223,.15); padding:18px 24px;
  font-size:.88rem; color:rgba(244,238,223,.6);
}
.footer-bottom p { margin:0; }

/* =====================================================================
   ADMIN
   ===================================================================== */
.page-admin { background:var(--paper-2); }
.admin-main { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:40px 20px; }
.admin-card {
  width:100%; max-width:460px; background:var(--paper);
  border-radius:var(--radius); box-shadow:var(--shadow); padding:38px 34px;
  border:1px solid rgba(36,31,28,.08);
}
.admin-head { display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.admin-head h1 { font-size:1.5rem; margin:0; }
.admin-intro { color:var(--ink-soft); }
.admin-alert { padding:.8em 1em; border-radius:var(--radius-sm); font-size:.95rem; margin-bottom:16px; }
.admin-alert-error { background:#fbe6dd; color:#9a3b14; border:1px solid var(--persimmon); }
.admin-alert-ok { background:#e0efe7; color:#0e5c57; border:1px solid var(--teal); }
.admin-form { display:flex; flex-direction:column; gap:14px; margin-bottom:8px; }
.admin-label { font-weight:600; font-size:.95rem; }
.admin-input {
  font:inherit; padding:.72em .9em; border:1.5px solid rgba(36,31,28,.25);
  border-radius:var(--radius-sm); background:#fff;
}
.admin-input:focus { border-color:var(--teal); outline:none; }
.admin-btn { justify-content:center; }
.admin-status, .admin-upload { margin-top:24px; padding-top:20px; border-top:1px solid rgba(36,31,28,.1); }

/* PDF par langue */
.admin-pdf-lang {
  border:1px solid rgba(36,31,28,.14); border-radius:var(--radius-sm);
  padding:16px 18px; margin-bottom:16px; background:var(--paper);
}
.admin-pdf-lang h3 { margin:0 0 .5em; font-size:1.1rem; }
.admin-pdf-actions { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.admin-pdf-actions form { display:inline; }
.admin-status h2, .admin-upload h2 { font-size:1.15rem; color:var(--teal); }
.admin-status-yes { color:var(--teal); }
.admin-status-no { color:var(--ink-soft); font-style:italic; }

.admin-file-input { position:absolute; width:1px; height:1px; opacity:0; }
.admin-file-label {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap; cursor:pointer;
  border:1.5px dashed var(--teal); border-radius:var(--radius-sm); padding:.9em 1em; background:#fff;
}
.admin-file-label:hover { background:rgba(14,92,87,.05); }
.admin-file-input:focus + .admin-file-label,
.admin-file-label:focus-within { outline:3px solid var(--teal-2); outline-offset:2px; }
.admin-file-cta { font-weight:600; color:var(--teal); }
.admin-file-name { color:var(--ink-soft); font-size:.92rem; }
.admin-file-hint { font-size:.85rem; color:var(--ink-soft); margin:0; }
.admin-footer { display:flex; justify-content:space-between; gap:14px; margin-top:24px; flex-wrap:wrap; }

/* --- Admin : éditeur de carte ------------------------------------- */
.admin-card-wide { max-width:940px; }

/* Layout éditeur : menu latéral + contenu */
.admin-menu-layout { display:grid; grid-template-columns:220px 1fr; gap:24px; align-items:start; }
.admin-menu-main { min-width:0; }

.admin-side {
  position:sticky; top:20px;
  background:var(--paper-2); border:1px solid rgba(36,31,28,.12);
  border-radius:var(--radius-sm); padding:14px;
}
.admin-side-h {
  text-transform:uppercase; letter-spacing:.1em; font-size:.7rem; font-weight:600;
  color:var(--ink-soft); margin:0 0 .6em;
}
.admin-side-list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:2px; }
.admin-side-item { display:flex; align-items:center; gap:6px; }
.admin-side-link {
  flex:1; display:flex; align-items:center; justify-content:space-between; gap:8px;
  padding:.5em .6em; border-radius:8px; color:var(--ink); font-weight:500; font-size:.92rem;
  min-width:0;
}
.admin-side-link:hover { background:var(--paper); text-decoration:none; }
.admin-side-name { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.admin-side-count {
  flex:none; background:var(--teal); color:#fff; border-radius:999px;
  font-size:.72rem; font-weight:600; min-width:20px; height:20px;
  display:inline-flex; align-items:center; justify-content:center; padding:0 5px;
}
.admin-side-arrows { flex:none; }
.admin-move-sm { width:24px; height:24px; font-size:.8rem; }

/* Décalage d'ancre pour ne pas masquer le titre sous le bord */
.admin-cat { scroll-margin-top:16px; }

.admin-block { margin-top:26px; padding-top:22px; border-top:1px solid rgba(36,31,28,.12); }
.admin-block:first-of-type { border-top:none; padding-top:0; }
.admin-block > h2 { font-size:1.2rem; color:var(--teal); }

/* Choix du mode */
.admin-mode-form { display:flex; flex-direction:column; gap:12px; }
.admin-radio {
  display:flex; gap:12px; align-items:flex-start; cursor:pointer;
  border:1.5px solid rgba(36,31,28,.2); border-radius:var(--radius-sm);
  padding:.85em 1em; background:#fff; transition:border-color .15s ease, background .15s ease;
}
.admin-radio.is-selected { border-color:var(--teal); background:rgba(14,92,87,.05); }
.admin-radio input { margin-top:.25em; }
.admin-radio small { color:var(--ink-soft); }
.admin-mode-form .admin-btn { align-self:flex-start; }

/* Catégorie */
.admin-cat {
  border:1px solid rgba(36,31,28,.14); border-radius:var(--radius-sm);
  padding:16px 18px; margin-bottom:16px; background:var(--paper);
}
.admin-cat-head { display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap; }
.admin-cat-head h3 { margin:0; font-size:1.15rem; }
.admin-cat-tools, .admin-dish-tools { display:flex; align-items:center; gap:8px; flex:none; }
.admin-move-form { display:inline-flex; gap:4px; }
.admin-move-btn {
  width:28px; height:28px; border-radius:8px; cursor:pointer;
  border:1px solid rgba(36,31,28,.25); background:#fff; color:var(--ink);
  font-size:1rem; line-height:1; display:inline-flex; align-items:center; justify-content:center;
  transition:.15s ease;
}
.admin-move-btn:hover:not(:disabled) { background:var(--teal); color:#fff; border-color:var(--teal); }
.admin-move-btn:disabled { opacity:.3; cursor:not-allowed; }

.admin-dish-row { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; }

/* Boutons d'action empilés (Supprimer + Modifier, même style) */
.admin-btn-stack { display:flex; flex-direction:column; gap:6px; align-items:stretch; }
.admin-btn-stack form { display:block; }
.admin-action-btn {
  display:block; width:100%; text-align:center; box-sizing:border-box;
  border-radius:999px; padding:.25em .8em; font-size:.82rem; font-weight:600;
  cursor:pointer; transition:.15s ease; background:transparent; list-style:none;
  white-space:nowrap;
}
.admin-action-btn::-webkit-details-marker { display:none; }
.admin-action-del { border:1px solid var(--persimmon); color:var(--persimmon); }
.admin-action-del:hover { background:var(--persimmon); color:#fff; }
.admin-action-edit { border:1px solid var(--teal); color:var(--teal); }
.admin-action-edit:hover { background:var(--teal); color:#fff; }

/* Le <details> de modification : le panneau s'ouvre pleine largeur sous la ligne */
.admin-edit[open] > summary { background:var(--teal); color:#fff; }
.admin-edit { position:static; }
.admin-edit-form {
  margin-top:12px;
  background:var(--paper-2); border:1px solid rgba(36,31,28,.18);
  border-radius:var(--radius-sm); padding:14px; box-shadow:var(--shadow-soft);
}
/* Le formulaire d'édition occupe toute la largeur de la catégorie/du plat */
.admin-cat-head { position:relative; }
.admin-cat-head .admin-edit-form { position:absolute; left:0; right:0; top:100%; z-index:5; }
.admin-dish { position:relative; }
.admin-dish .admin-edit-form { position:absolute; left:0; right:0; top:100%; z-index:5; }
.admin-cat-en { font-style:italic; font-weight:400; color:var(--ink-soft); font-size:.85em; }
.admin-no-dish { color:var(--ink-soft); font-style:italic; font-size:.9rem; margin:.6em 0; }

.admin-dish-list { list-style:none; margin:.6em 0; padding:0; }
.admin-dish {
  padding:.6em 0; border-bottom:1px solid rgba(36,31,28,.08);
}
.admin-dish-info small { color:var(--ink-soft); }
.admin-dish-price { color:var(--persimmon); font-weight:600; margin-left:.5em; }

.admin-del-btn {
  flex:none; background:transparent; border:1px solid var(--persimmon);
  color:var(--persimmon); border-radius:999px; padding:.25em .8em;
  font-size:.82rem; font-weight:600; cursor:pointer; transition:.15s ease;
}
.admin-del-btn:hover { background:var(--persimmon); color:#fff; }

.admin-grid-form { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:10px; }
.admin-grid-form label { display:flex; flex-direction:column; gap:.3em; font-size:.88rem; font-weight:500; }
.admin-grid-form .admin-input { font-weight:400; }
.admin-grid-form .admin-price-field { grid-column:1 / 2; }
.admin-grid-form .admin-btn { grid-column:1 / -1; justify-content:center; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */

/* --- Tablette : grilles intermédiaires (1024px) ------------------- */
@media (max-width: 1024px) and (min-width: 881px) {
  .dish-grid { grid-template-columns:repeat(2, 1fr); }
  .contact-grid { grid-template-columns:1fr; }
  .hero-grid { gap:40px; }
}

/* --- Tablette / mobile : nav burger (≤ 880px) --------------------- */
@media (max-width: 880px) {
  .nav-toggle { display:block; order:3; }
  .header-inner { min-height:64px; }
  .brand-logo { height:48px; width:48px; }

  /* Overlay sombre derrière le menu */
  .site-nav::before {
    content:""; position:fixed; inset:0; z-index:-1;
    background:rgba(36,31,28,.5); opacity:0; transition:opacity .3s ease;
  }
  .site-nav {
    position:fixed; left:0; right:0; top:0; bottom:0; z-index:90;
    flex-direction:column; align-items:stretch; justify-content:flex-start; gap:0;
    background:transparent; padding:0;
    visibility:hidden; pointer-events:none;
  }
  /* Le panneau blanc glissant */
  .nav-list, .nav-actions {
    background:var(--paper);
    transform:translateY(-12px); opacity:0;
    transition:transform .34s cubic-bezier(.22,.61,.36,1), opacity .26s ease;
  }
  .nav-list {
    margin-top:64px; padding:8px 24px 4px;
    flex-direction:column; align-items:stretch; gap:0;
    box-shadow:0 18px 30px -24px rgba(36,31,28,.5);
    max-height:calc(100vh - 64px); overflow-y:auto;
  }
  .nav-list li { border-bottom:1px solid rgba(36,31,28,.08); }
  .nav-list a { display:block; padding:1em 0; font-size:1.1rem; }
  .nav-list a.is-active::after { display:none; }
  .nav-actions {
    margin:0; padding:18px 24px 24px; justify-content:flex-start; gap:18px;
    border-bottom:1px solid rgba(36,31,28,.12);
  }

  body.nav-open { overflow:hidden; }   /* empêche le scroll de fond */
  body.nav-open .site-nav { visibility:visible; pointer-events:auto; }
  body.nav-open .site-nav::before { opacity:1; }
  body.nav-open .nav-list,
  body.nav-open .nav-actions {
    transform:translateY(0); opacity:1;
    visibility:visible; position:relative; z-index:2;
  }
  /* Garantit l'affichage des liens de pages dans le menu ouvert. */
  body.nav-open .nav-list { display:flex; }
  body.nav-open .nav-list li, body.nav-open .nav-list a { display:block; }

  /* Layout des pages */
  .hero { padding:44px 0 24px; }
  .hero-grid { grid-template-columns:1fr; gap:34px; }
  .hero-photo, .story-photo { transform:none; }
  .brand-panel { transform:none; aspect-ratio:4/3; }
  .brand-panel-tall { min-height:320px; }

  .dish-grid { grid-template-columns:1fr 1fr; }
  .lunch-card { grid-template-columns:1fr; padding:34px 26px; }
  .story-grid { grid-template-columns:1fr; gap:32px; }
  .story-aside { position:static; max-width:420px; }
  .contact-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:28px; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }

  /* Admin : menu latéral repassé au-dessus, en pleine largeur */
  .admin-menu-layout { grid-template-columns:1fr; }
  .admin-side { position:static; }
}

/* --- Mobile (≤ 560px) -------------------------------------------- */
@media (max-width: 560px) {
  body { font-size:16px; }
  .wrap { padding:0 18px; }
  .dish-grid { grid-template-columns:1fr; }
  /* Carte : catégories repliables (accordéon tactile). */
  .menu-block-head { cursor:pointer; }
  .menu-block-chevron { display:block; }
  .menu-block[open] .menu-block-chevron { transform:rotate(180deg); }
  .brand-logo { height:44px; width:44px; }
  .section { padding:50px 0; }
  .hero-cta { flex-direction:column; align-items:stretch; }
  .hero-cta .btn { justify-content:center; }
  .lunch-card { padding:28px 20px; }
  .lunch-price { font-size:2.2rem; }
  .admin-card { padding:26px 18px; }
  .admin-grid-form { grid-template-columns:1fr; }
  .admin-grid-form .admin-price-field { grid-column:auto; }
  .admin-cat-head { gap:8px; }
  .map-embed iframe { height:320px; }
}

/* --- Très petit (≤ 380px) : éviter le débordement du tél ---------- */
@media (max-width: 380px) {
  .btn-phone span { display:none; }   /* garde l'icône, masque le numéro */
}
