/* ============================================================
   layout.css — Sections spécifiques de la home
   Hero / Esprit / Menu teaser / Bar / Galerie / Avis /
   Localisation / Réservation / FAQ
   ============================================================ */

/* —— Hero ——————————————————————————————————— */
.hero {
  position: relative;
  min-height: 88vh;
  display: flex;
  align-items: center;
  color: white;
  overflow: hidden;
  padding: var(--sp-9) 0;
  isolation: isolate;
}
.hero__bg {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(20, 62, 77, 0.30) 0%, rgba(20, 62, 77, 0.55) 70%, rgba(20, 62, 77, 0.78) 100%),
    url("../img/terrasse.webp") center/cover no-repeat,
    linear-gradient(135deg, #E8825D 0%, #D26B47 30%, #1E5F74 100%);
  background-size: cover;
  background-position: center;
  z-index: -1;
}
.hero__inner {
  max-width: 760px;
  position: relative;
}
.hero__kicker {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.92);
  margin-bottom: var(--sp-4);
  padding: 6px 14px;
  background: rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-pill);
  backdrop-filter: blur(8px);
}
.hero h1 {
  color: white;
  font-size: clamp(3rem, 8vw + 1rem, 6.5rem);
  letter-spacing: -0.03em;
  margin-bottom: var(--sp-4);
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.25);
}
.hero__subtitle {
  font-family: var(--ff-serif);
  font-style: italic;
  font-size: clamp(1.25rem, 2vw + 0.5rem, 1.75rem);
  color: rgba(255, 255, 255, 0.95);
  margin-bottom: var(--sp-3);
  font-weight: var(--fw-regular);
  max-width: 540px;
  line-height: 1.4;
}
.hero__location {
  font-size: var(--fs-sm);
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: var(--sp-6);
}
.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-bottom: var(--sp-6);
}
.hero__badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.hero__scroll-hint {
  position: absolute;
  bottom: var(--sp-5);
  left: 50%;
  transform: translateX(-50%);
  font-size: var(--fs-xs);
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
  animation: float 2.4s ease-in-out infinite;
}
@keyframes float {
  0%, 100% { transform: translate(-50%, 0); }
  50% { transform: translate(-50%, -8px); }
}

/* —— Esprit ———————————————————————————————— */
.esprit {
  background: var(--c-sable-clair);
}
.esprit__lead {
  font-family: var(--ff-serif);
  font-size: var(--fs-xl);
  line-height: 1.45;
  color: var(--c-encre);
  max-width: 720px;
  margin: 0 auto var(--sp-5);
  text-align: center;
}
.esprit__body {
  max-width: 640px;
  margin: 0 auto var(--sp-7);
  text-align: center;
  color: var(--c-encre-doux);
  font-size: var(--fs-md);
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3);
  max-width: 800px;
  margin: 0 auto;
}
@media (max-width: 640px) { .stats-grid { grid-template-columns: 1fr; } }

/* —— Menu teaser ———————————————————————————— */
.menu-teaser {
  background: var(--c-sable);
}
.menu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--sp-5);
  margin-bottom: var(--sp-6);
}
.menu-cta { text-align: center; }

/* —— Bandes verticales auto-scroll (décoratives) ——————————— */
/* .menu-frame est l'ancrage : sa hauteur = celle de .menu-grid.
   Les bandes en `position: absolute` héritent donc de cette hauteur,
   sans déborder sur le titre ni sur le bouton. */
.menu-frame {
  position: relative;
}

.food-strip {
  position: absolute;
  top: 0;
  bottom: 0;       /* ← bornée par .menu-frame = juste les cartes */
  width: 160px;
  overflow: hidden;
  pointer-events: none; /* purement décoratif, ne capte pas le clic */
  display: none; /* affiché seulement en desktop large via media query */
  /* Fondu haut/bas pour intégrer la bande au fond sable */
  -webkit-mask-image: linear-gradient(to bottom, transparent, black 10%, black 90%, transparent);
          mask-image: linear-gradient(to bottom, transparent, black 10%, black 90%, transparent);
}
.food-strip--left  { left: 0; }
.food-strip--right { right: 0; }

.food-strip__track {
  display: flex;
  flex-direction: column;
  padding-inline: var(--sp-4);
  /* Pas de `gap` : on utilise margin-bottom sur chaque img (même la dernière)
     pour que la hauteur totale = 8 × (img + margin) → -50% tombe pile à la
     frontière img4/img5 → boucle parfaitement invisible. */
  animation: food-scroll 38s linear infinite;
  will-change: transform;
}
.food-strip--right .food-strip__track {
  animation-direction: reverse; /* descend au lieu de monter */
}

.food-strip__track img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  margin-bottom: var(--sp-4); /* gap équivalent, mais appliqué AUSSI au dernier */
}

@keyframes food-scroll {
  /* Translate de -50% car la liste est dupliquée → boucle invisible */
  from { transform: translateY(0); }
  to   { transform: translateY(-50%); }
}

/* Pause au survol pour permettre de regarder une photo */
.food-strip:hover .food-strip__track,
.food-strip:focus-within .food-strip__track {
  animation-play-state: paused;
}

/* Affichage : à partir de 1360px, on a la place pour 2 bandes 160px + container 1080px sans chevauchement */
@media (min-width: 1360px) {
  .food-strip { display: block; }
}

/* Accessibilité : pas d'animation si l'utilisateur le demande */
@media (prefers-reduced-motion: reduce) {
  .food-strip__track { animation: none; }
}

/* —— Bar ————————————————————————————————— */
.bar-section {
  /* Photo de fond + overlay sombre ocean pour garder le texte blanc lisible.
     2 options en lice — décommente celle que tu préfères, commente l'autre. */

  /* OPTION A — Plateau de shots Damoiseau (ambiance vacances/piscine)
     Overlay très léger pour garder la photo lumineuse et ensoleillée. */
  background:
    linear-gradient(180deg, rgba(20, 62, 77, 0.18) 0%, rgba(20, 62, 77, 0.38) 100%),
    url("../img/shots-bar.webp") center/cover no-repeat;

  /* OPTION B — Rhums arrangés (intérieur du bar, identité du lieu)
  background:
    linear-gradient(180deg, rgba(20, 62, 77, 0.70) 0%, rgba(20, 62, 77, 0.82) 100%),
    url("../img/rhums-arranges.webp") center/cover no-repeat;
  */

  background-color: var(--c-ocean); /* fallback si image pas chargée */
  color: white;
  position: relative;
  overflow: hidden;
}
.bar-section h2 {
  color: white;
  /* Double ombre (proche + diffuse) car overlay très léger → titre passe sur la zone ciel/palmiers très claire */
  text-shadow:
    0 2px 4px rgba(0, 0, 0, 0.55),
    0 4px 16px rgba(0, 0, 0, 0.45);
}
.bar-section .kicker {
  color: var(--c-coucher);
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.65);
}
.bar-section p {
  color: rgba(255, 255, 255, 0.97);
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.6);
}
.bar-section .section-header p {
  color: rgba(255, 255, 255, 0.92);
}
.bar-section__lead {
  max-width: 640px;
  margin: 0 auto var(--sp-6);
  text-align: center;
  font-size: var(--fs-md);
}
.bar-section__cta { text-align: center; }

/* Mini-grille "Notre sélection" : 3 cards (bières / vins / shot signature) */
.bar-selection {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-7);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}
.bar-selection__card {
  /* Card translucide claire qui laisse la photo de fond du bar légèrement transparaître */
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-lg);
  overflow: hidden;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: transform var(--t-base), background var(--t-base);
}
.bar-selection__card:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.14);
}
.bar-selection__card figure { margin: 0; }
.bar-selection__card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}
.bar-selection__card figcaption {
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
}
.bar-selection__card h3 {
  margin: 0 0 var(--sp-2);
  color: white;
  font-size: var(--fs-md);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
}
.bar-selection__card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.88);
  font-size: var(--fs-sm);
  line-height: 1.5;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

/* Mobile : empile les cards en colonne */
@media (max-width: 760px) {
  .bar-selection { grid-template-columns: 1fr; gap: var(--sp-4); }
}

/* —— Galerie : carrousel ——————————————————— */
.gallery { background: var(--c-sable-clair); }

.carousel {
  position: relative;
  margin: 0 calc(var(--container-pad) * -1);
  padding: var(--sp-2) 0;
}

.carousel__track {
  display: flex;
  gap: var(--sp-3);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  padding: var(--sp-3) var(--container-pad);
  -webkit-overflow-scrolling: touch;
}
.carousel__track::-webkit-scrollbar { display: none; }

.carousel__slide {
  flex: 0 0 auto;
  width: clamp(280px, 80vw, 560px);
  scroll-snap-align: center;
  scroll-snap-stop: always;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--c-sable);
  box-shadow: var(--shadow-md);
  position: relative;
  aspect-ratio: 4 / 3;
  transition: transform var(--t-base);
}
.carousel__slide:hover { transform: translateY(-4px); }

.carousel__slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.carousel__caption {
  position: absolute;
  inset: auto 0 0 0;
  padding: var(--sp-5) var(--sp-4) var(--sp-3);
  background: linear-gradient(180deg, transparent 0%, rgba(20, 62, 77, 0.85) 100%);
  color: white;
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  letter-spacing: 0.01em;
}

/* Boutons prev/next */
.carousel__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--c-coquillage);
  color: var(--c-ocean);
  display: grid;
  place-items: center;
  box-shadow: var(--shadow-md);
  z-index: 2;
  font-size: 1.4rem;
  transition: background var(--t-fast), transform var(--t-fast), opacity var(--t-fast);
}
.carousel__btn:hover { background: var(--c-coucher); color: white; transform: translateY(-50%) scale(1.05); }
.carousel__btn--prev { left: var(--sp-3); }
.carousel__btn--next { right: var(--sp-3); }
.carousel__btn[disabled] { opacity: 0.3; cursor: not-allowed; }

@media (max-width: 640px) {
  .carousel__btn { display: none; }
}

/* Dots */
.carousel__dots {
  display: flex;
  justify-content: center;
  gap: var(--sp-2);
  margin-top: var(--sp-4);
  padding: 0 var(--container-pad);
  flex-wrap: wrap;
}
.carousel__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(42, 37, 34, 0.2);
  transition: all var(--t-fast);
  padding: 0;
}
.carousel__dot:hover { background: var(--c-mer-claire); }
.carousel__dot[aria-current="true"] {
  background: var(--c-coucher);
  width: 28px;
  border-radius: var(--radius-pill);
}

/* —— Avis ————————————————————————————————— */
.reviews {
  background: var(--c-sable);
}
.reviews-grid {
  margin-bottom: var(--sp-6);
}
.reviews-grid > .menu-empty { text-align: center; padding: var(--sp-6) 0; }
.reviews-cta { text-align: center; }

/* Carrousel d'avis : reste dans le container (pas de breakout) +
   padding horizontal à 0 sur le track → la boucle infinie se fait sans
   décalage visuel (scrollLeft=0 et scrollLeft=N×step doivent rendre
   exactement le même pixel pour que le wrap soit invisible). */
.reviews-carousel {
  margin: 0;
  padding: 0;
}
.reviews-carousel .carousel__track {
  padding: var(--sp-3) 0;
  /* Fade aux bords pour signaler le défilement infini (purement esthétique) */
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 32px, #000 calc(100% - 32px), transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 32px, #000 calc(100% - 32px), transparent 100%);
}
.reviews-carousel .carousel__slide--review {
  width: clamp(280px, 85vw, 400px);
  aspect-ratio: auto;
  background: transparent;
  box-shadow: none;
  display: flex;
  align-items: stretch;
  overflow: visible;
  /* Snap au bord gauche : cohérent avec currentIndex() en mode boucle.
     Évite que le navigateur ré-aligne sur "center" et désynchronise les dots. */
  scroll-snap-align: start;
}
.reviews-carousel .carousel__slide--review:hover { transform: none; }
.reviews-carousel .carousel__slide--review > .review {
  width: 100%;
  margin: 0;
}
/* Boutons prev/next : repositionnés sur le bord du carrousel (sans le
   décalage du breakout) pour rester visibles et cliquables. */
.reviews-carousel .carousel__btn--prev { left: calc(var(--sp-3) * -1); }
.reviews-carousel .carousel__btn--next { right: calc(var(--sp-3) * -1); }

/* —— Localisation ———————————————————————— */
.location {
  background: var(--c-coquillage);
}
.location-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-7);
  align-items: start;
}
@media (max-width: 880px) {
  .location-grid { grid-template-columns: 1fr; }
}
.location-info dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-3) var(--sp-5);
  margin-bottom: var(--sp-5);
}
.location-info dt {
  font-weight: var(--fw-semibold);
  color: var(--c-mute);
  font-size: var(--fs-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding-top: 4px;
}
.location-info dd { margin: 0; color: var(--c-encre); }
.location-info dd a { color: var(--c-ocean); font-weight: var(--fw-medium); }

#map {
  width: 100%;
  height: 420px;
  border-radius: var(--radius-lg);
  background: var(--c-sable);
  box-shadow: var(--shadow-md);
  overflow: hidden;
}

.howto-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
  margin-top: var(--sp-7);
}
@media (max-width: 720px) { .howto-grid { grid-template-columns: 1fr; } }
.howto-card {
  background: var(--c-sable);
  border-radius: var(--radius-md);
  padding: var(--sp-5);
}
.howto-card h4 {
  font-family: var(--ff-sans);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-base);
  margin-bottom: var(--sp-2);
  color: var(--c-ocean);
}
.howto-card p {
  font-size: var(--fs-sm);
  color: var(--c-encre-doux);
  margin: 0;
}

/* —— Réservation / contact ——————————————— */
.reservation {
  background: var(--c-sable-clair);
}
.contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
  max-width: 720px;
  margin: 0 auto;
}
@media (max-width: 640px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-card {
  background: var(--c-coquillage);
  border-radius: var(--radius-lg);
  padding: var(--sp-6) var(--sp-4);
  text-align: center;
  text-decoration: none;
  color: var(--c-encre);
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-base), box-shadow var(--t-base);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
}
.contact-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  color: var(--c-ocean);
}
.contact-card__icon {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--c-coucher);
  color: white;
  display: grid; place-items: center;
  margin-bottom: var(--sp-2);
  font-size: 1.4rem;
}
.contact-card__label {
  font-size: var(--fs-xs);
  color: var(--c-mute);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.contact-card__value {
  font-weight: var(--fw-semibold);
  font-size: var(--fs-md);
}

/* —— FAQ ————————————————————————————————— */
.faq {
  background: var(--c-sable);
}
.faq-list {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.faq-item {
  background: var(--c-coquillage);
  border-radius: var(--radius-md);
  border: var(--border);
  overflow: hidden;
}
.faq-item summary {
  cursor: pointer;
  padding: var(--sp-4) var(--sp-5);
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  font-weight: var(--fw-semibold);
  color: var(--c-ocean);
  transition: background var(--t-fast);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+";
  flex-shrink: 0;
  width: 28px; height: 28px;
  display: grid; place-items: center;
  background: var(--c-sable);
  border-radius: 50%;
  font-size: 1.2rem;
  color: var(--c-coucher);
  transition: transform var(--t-base);
}
.faq-item[open] summary::after {
  content: "−";
  transform: rotate(180deg);
  background: var(--c-coucher);
  color: white;
}
.faq-item summary:hover { background: var(--c-sable-clair); }
.faq-item__answer {
  padding: 0 var(--sp-5) var(--sp-4);
  color: var(--c-encre-doux);
  font-size: var(--fs-sm);
  line-height: 1.6;
}

/* —— Animations d'apparition ——————————————— */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 600ms ease-out, transform 600ms ease-out;
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; }
}

/* ============================================================
   Menu cards (highlights home + cartes complètes)
   ============================================================ */

.menu-card {
  background: var(--c-coquillage);
  border: var(--border);
  border-radius: var(--radius-lg);
  padding: var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-base), box-shadow var(--t-base);
}
.menu-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}
.menu-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
}
.menu-card__cat {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--c-mute);
}
.menu-card__name {
  margin: 0;
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  color: var(--c-ocean);
  line-height: var(--lh-snug);
}
.menu-card__desc {
  margin: 0;
  color: var(--c-encre-doux);
  font-size: var(--fs-sm);
  line-height: 1.55;
  flex: 1;
}
.menu-card__foot {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--sp-2);
}
.menu-card__price {
  font-family: var(--ff-serif);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-md);
  color: var(--c-coucher);
  background: rgba(232, 130, 93, 0.12);
  padding: 0.2em 0.7em;
  border-radius: var(--radius-pill);
}

/* —— Badges sur les items —— */
.menu-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25em;
  font-size: 0.95em;
  line-height: 1;
  padding: 0.25em 0.55em;
  border-radius: var(--radius-pill);
  background: rgba(20, 62, 77, 0.06);
  color: var(--c-ocean);
  font-weight: var(--fw-semibold);
  white-space: nowrap;
}
.menu-badge.badge--signature   { background: rgba(232, 130, 93, 0.15); color: var(--c-coucher-fonce); }
.menu-badge.badge--local       { background: rgba(74, 158, 183, 0.15); color: var(--c-ocean); }
.menu-badge.badge--maison      { background: rgba(139, 115, 85, 0.18); color: var(--c-bois); }
.menu-badge.badge--best        { background: rgba(194, 86, 62, 0.15); color: #8E2E18; }   /* WCAG AA sur fond clair */
.menu-badge.badge--veg         { background: rgba(92, 158, 110, 0.18); color: #2F6A40; }   /* WCAG AA sur fond clair */

/* ============================================================
   Section "Spécialités d'Oléron" — home
   ============================================================ */

.specialites {
  background: linear-gradient(180deg, var(--c-sable-clair) 0%, var(--c-sable) 100%);
}
.specialites-grid {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-6);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--sp-5);
}
.specialite-card {
  position: relative;
  background: var(--c-coquillage);
  border-radius: var(--radius-lg);
  padding: var(--sp-6) var(--sp-5) var(--sp-5);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  transition: transform var(--t-base), box-shadow var(--t-base);
  border-top: 4px solid var(--c-ocean);
}
.specialite-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}
.specialite-card--ice      { border-top-color: #D88BBA; }
.specialite-card--moules   { border-top-color: var(--c-mer-claire); }
.specialite-card--allan    { border-top-color: var(--c-coucher); }

.specialite-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.specialite-card__icon {
  font-size: 2rem;
  line-height: 1;
}
.specialite-card h3 {
  margin: 0;
  font-family: var(--ff-serif);
  font-size: var(--fs-xl);
  font-weight: var(--fw-semibold);
  color: var(--c-ocean);
  line-height: var(--lh-snug);
}
.specialite-card p {
  margin: 0;
  color: var(--c-encre-doux);
  font-size: var(--fs-sm);
  line-height: 1.6;
  flex: 1;
}
.specialite-card__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--sp-3);
  padding-top: var(--sp-3);
  border-top: var(--border);
}
.specialite-card__price {
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--c-coucher);
}
.specialite-card__cat {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--c-mute);
  font-weight: var(--fw-semibold);
}

.specialites-note {
  text-align: center;
  margin: 0;
  color: var(--c-encre-doux);
  font-size: var(--fs-sm);
}
.specialites-note a {
  display: inline-block;
  margin-left: var(--sp-3);
  color: var(--c-coucher);
  font-weight: var(--fw-semibold);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
}
.specialites-note a:hover { color: var(--c-coucher-fonce); }

@media (max-width: 640px) {
  .specialites-grid { grid-template-columns: 1fr; }
  .specialites-note a { display: block; margin: var(--sp-2) 0 0; }
}

/* ============================================================
   Pages "carte complète" (carte-restaurant.html / carte-glaces.html)
   ============================================================ */

.menu-page {
  background: var(--c-sable);
}

/* Hero compact en tête des pages cartes */
.menu-page__hero {
  background: linear-gradient(180deg, var(--c-sable-clair) 0%, var(--c-sable) 100%);
  padding: clamp(var(--sp-7), 12vw, var(--sp-9)) 0 var(--sp-7);
  text-align: center;
  border-bottom: 1px dashed rgba(194, 86, 62, 0.25);
}
.menu-page__hero .kicker {
  color: var(--c-rouge-carte);
}
.menu-page__hero h1 {
  font-family: var(--ff-handwritten);
  font-size: clamp(3rem, 8vw, 5rem);
  font-weight: 700;
  color: var(--c-rouge-carte);
  margin: var(--sp-2) 0 var(--sp-3);
  line-height: 1;
}
.menu-page__hero p {
  max-width: 640px;
  margin: 0 auto;
  color: var(--c-encre-doux);
  font-size: var(--fs-md);
}

/* Variante "glaces" : dégradé pastel rose/violet */
.menu-page--glaces .menu-page__hero {
  background: linear-gradient(180deg, #FCEEF3 0%, #F5EDE0 100%);
  border-bottom-color: rgba(216, 139, 186, 0.4);
}
.menu-page--glaces .menu-page__hero .kicker,
.menu-page--glaces .menu-page__hero h1 {
  color: #B85287;
}

/* ============================================================
   Sections de catégorie — mode ACCORDÉON
   <details>/<summary> natifs : accessibilité + SEO préservés.
   Animation moderne via ::details-content (Chrome 131+, Safari 18+).
   Dégrade en open/close instantané sur les navigateurs plus anciens.
   ============================================================ */
.menu-section {
  position: relative;
  border-bottom: 1px solid rgba(42, 37, 34, 0.08);
  transition: border-left-color 200ms ease;
  border-left: 4px solid transparent;
}
.menu-section[open] {
  border-left-color: var(--c-rouge-carte);
}

/* Bandeau cliquable (toujours visible) */
.menu-section__summary {
  cursor: pointer;
  list-style: none;       /* Firefox : retire la flèche par défaut */
  padding: var(--sp-4) 0;
  min-height: 56px;       /* tap-target Google guidelines */
  transition: background 180ms ease;
  user-select: none;
}
.menu-section__summary::-webkit-details-marker { display: none; }
.menu-section__summary::marker { content: ""; }
.menu-section__summary:hover { background: rgba(255, 255, 255, 0.45); }
.menu-section__summary:focus-visible {
  outline: 3px solid var(--c-coucher);
  outline-offset: -3px;
}

.menu-section__summary-inner {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.menu-section__count {
  font-family: var(--ff-sans);
  font-size: var(--fs-sm);
  color: var(--c-encre-doux);
  opacity: 0.7;
  white-space: nowrap;
}
.menu-section__chevron {
  width: 1.25em;
  height: 1.25em;
  flex-shrink: 0;
  color: var(--c-rouge-carte);
  transition: transform 250ms ease;
}
.menu-section[open] .menu-section__chevron { transform: rotate(180deg); }

/* Corps déplié */
.menu-section__body {
  padding: var(--sp-3) 0 var(--sp-7);
}

/* Animation moderne de l'ouverture (CSS pur, opt-in via @supports).
   Scope local : on n'autorise interpolate-size que sur les <details>
   pour éviter d'affecter d'autres transitions de la page. */
@supports (interpolate-size: allow-keywords) {
  .menu-section { interpolate-size: allow-keywords; }
  .menu-section::details-content {
    block-size: 0;
    overflow: clip;
    transition: block-size 280ms ease, content-visibility 280ms allow-discrete;
  }
  .menu-section[open]::details-content { block-size: auto; }
}

/* Bandeau de couleur par catégorie : fond doux + accent du titre.
   Chaque catégorie a sa propre teinte pour que l'œil distingue d'un
   coup d'œil où on est dans la carte. */
#cat-aperos        { background: linear-gradient(180deg, #FFF6D9 0%, #F8E9B4 100%); }
#cat-aperos        .menu-section__title { color: #7A5C0E; }   /* jaune doré apéro — assombri pour WCAG AA */

#cat-burgers       { background: linear-gradient(180deg, #F2DCC9 0%, #E8C4A8 100%); }
#cat-burgers       .menu-section__title { color: #6E2A14; }   /* brun viande grillée — assombri pour WCAG AA */

#cat-moules-frites { background: linear-gradient(180deg, #E8F1F5 0%, #DCE9F0 100%); }
#cat-moules-frites .menu-section__title { color: #1E5F74; }   /* bleu océan */

#cat-snack         { background: linear-gradient(180deg, #F5EDE0 0%, #FBF6EE 100%); }
#cat-snack         .menu-section__title { color: var(--c-rouge-carte); }

#cat-pizzas        { background: linear-gradient(180deg, #FBE8DE 0%, #F7DACA 100%); }
#cat-pizzas        .menu-section__title { color: #C2563E; }   /* tomate */

#cat-incontournables { background: linear-gradient(180deg, #EDE3D2 0%, #D9C7A8 100%); }
#cat-incontournables .menu-section__title { color: #5C3A1E; }  /* parchemin / brun marché */

#cat-desserts      { background: linear-gradient(180deg, #F2E5D2 0%, #E8D2B5 100%); }
#cat-desserts      .menu-section__title { color: #6B4423; }   /* chocolat / cacao */

#cat-menu-enfant   { background: linear-gradient(180deg, #FFF4D6 0%, #FFEAB3 100%); }
#cat-menu-enfant   .menu-section__title { color: #D88A1A; }   /* miel/joueur */

#cat-coupes-glacees      { background: linear-gradient(180deg, #FCEEF3 0%, #F8DCE8 100%); }
#cat-coupes-glacees      .menu-section__title { color: #943867; }   /* assombri pour WCAG AA */

#cat-coupes-alcoolisees  { background: linear-gradient(180deg, #EFE5F5 0%, #E2D2EE 100%); }
#cat-coupes-alcoolisees  .menu-section__title { color: #6B3E8A; }

/* Les lignes de plats restent lisibles sur ces fonds : pointillés un peu plus
   foncés et nom de plat passe de "ocean" à "encre" pour ne pas jurer. */
.menu-section .menu-line { border-bottom-color: rgba(42, 37, 34, 0.22); }
.menu-section .menu-line__name { color: var(--c-encre); }

/* Le titre vit désormais dans le <summary> — pas centré, flex avec count + chevron */
.menu-section__title {
  flex: 1;
  font-family: var(--ff-handwritten);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  color: var(--c-rouge-carte);
  margin: 0;
  font-weight: 700;
  line-height: 1;
}
.menu-page--glaces .menu-section__title { color: #943867; }

.menu-section__desc {
  max-width: 560px;
  margin: 0 auto var(--sp-5);
  color: var(--c-encre-doux);
  font-size: var(--fs-sm);
  font-style: italic;
  text-align: center;
}

.menu-section__items {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--sp-4);
}

/* Variante "ligne carte papier" : prix aligné à droite avec pointillés */
.menu-line {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  border-bottom: 1px dotted rgba(42, 37, 34, 0.18);
}
.menu-line:last-child { border-bottom: 0; }
.menu-line__name {
  font-family: var(--ff-serif);
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  color: var(--c-ocean);
}
.menu-line__desc {
  grid-column: 1 / -1;
  margin: var(--sp-1) 0 0;
  color: var(--c-encre-doux);
  font-size: var(--fs-sm);
  line-height: 1.5;
}
.menu-line__price {
  font-family: var(--ff-serif);
  font-weight: var(--fw-semibold);
  color: var(--c-rouge-carte);
}
.menu-line__badges {
  grid-column: 1 / -1;
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-top: var(--sp-2);
}

/* Item à variantes (crêpes, gaufres…) — un titre puis liste sucre/chocolat/caramel */
.menu-line--variants .menu-line__name { grid-column: 1 / -1; }
.menu-variants {
  grid-column: 1 / -1;
  list-style: none;
  margin: var(--sp-2) 0 0;
  padding: 0;
  display: grid;
  gap: var(--sp-1);
}
.menu-variant {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  gap: var(--sp-2);
  padding-left: var(--sp-3);
  font-size: var(--fs-sm);
}
.menu-variant__name {
  color: var(--c-encre-doux);
  font-family: var(--ff-serif);
}
.menu-variant__name::before {
  content: "·";
  display: inline-block;
  width: 1em;
  margin-left: -1em;
  color: var(--c-rouge-carte);
  opacity: 0.7;
}
.menu-variant__price {
  font-family: var(--ff-serif);
  font-weight: var(--fw-semibold);
  color: var(--c-rouge-carte);
}
.menu-variant__desc {
  grid-column: 1 / -1;
  font-size: var(--fs-xs);
  color: var(--c-encre-doux);
  opacity: 0.85;
  line-height: 1.4;
  padding-left: 1em;
}

/* Pastille de prix rouge (cartes papier) */
.price-pill {
  display: inline-block;
  font-family: var(--ff-serif);
  font-weight: var(--fw-semibold);
  color: white;
  background: var(--c-rouge-carte);
  padding: 0.25em 0.75em;
  border-radius: var(--radius-pill);
  font-size: var(--fs-sm);
}

/* Grille des 14 parfums de glace */
.ice-flavors {
  background: linear-gradient(180deg, #FCEEF3 0%, var(--c-sable-clair) 100%);
  padding: var(--sp-7) 0;
}
.ice-flavors__intro {
  text-align: center;
  max-width: 560px;
  margin: 0 auto var(--sp-5);
  color: var(--c-encre-doux);
  font-size: var(--fs-sm);
}
.ice-flavors-grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: var(--sp-3);
}
.ice-flavors-grid li {
  background: var(--c-coquillage);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius-md);
  font-family: var(--ff-handwritten);
  font-size: 1.4rem;
  text-align: center;
  color: #B85287;
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-base);
}
.ice-flavors-grid li:hover { transform: translateY(-2px) rotate(-1deg); }

.ice-pricing {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--sp-4);
  margin-top: var(--sp-5);
  padding: var(--sp-5);
  background: var(--c-coquillage);
  border-radius: var(--radius-lg);
  text-align: center;
}
.ice-pricing div strong {
  display: block;
  font-family: var(--ff-serif);
  font-size: var(--fs-xl);
  color: var(--c-rouge-carte);
}
.ice-pricing div span {
  font-size: var(--fs-xs);
  color: var(--c-mute);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* —— Bouton "outline carte papier" : pour les liens croisés
   entre les pages cartes (carte restaurant ↔ carte glaces).
   Bord et texte rouge carte, hover rempli — secondaire face au CTA orange
   primaire mais bien visible sur fond crème. */
.btn--outline-carte {
  background: transparent;
  color: var(--c-rouge-carte);
  border: 2px solid var(--c-rouge-carte);
  font-weight: var(--fw-semibold);
}
.btn--outline-carte:hover {
  background: var(--c-rouge-carte);
  color: white;
}

/* Variante glaces : on bascule sur le rose framboise pour rester cohérent
   avec le titre de la page carte-glaces. */
.menu-page--glaces .btn--outline-carte {
  color: #B85287;
  border-color: #B85287;
}
.menu-page--glaces .btn--outline-carte:hover {
  background: #B85287;
  color: white;
}

/* CTA retour à l'accueil en bas de page carte (lien, pas bouton) */
.menu-page__back {
  text-align: center;
  padding: var(--sp-6) 0 var(--sp-8);
}
.menu-page__back-link {
  display: inline-block;
  color: var(--c-rouge-carte);
  font-weight: var(--fw-semibold);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  transition: color var(--t-fast), transform var(--t-fast);
}
.menu-page__back-link:hover {
  color: var(--c-rouge-carte-fonce);
  transform: translateX(-3px);
}
.menu-page--glaces .menu-page__back-link { color: #B85287; }
.menu-page--glaces .menu-page__back-link:hover { color: #8B3D6A; }

.menu-page--bar .menu-page__back-link { color: #6B3E8A; }
.menu-page--bar .menu-page__back-link:hover { color: #4D2A66; }

/* ============================================================
   PAGE BAR — "Carte à venir"
   ============================================================ */

/* Bandeau accroche "saison 2026" */
.bar-coming {
  padding: var(--sp-7) 0 var(--sp-6);
  background: linear-gradient(180deg, #FBF6EE 0%, #F5EDE0 100%);
}
.bar-coming__card {
  position: relative;
  background: #fff;
  border-radius: var(--radius-lg);
  padding: clamp(var(--sp-6), 5vw, var(--sp-8));
  text-align: center;
  box-shadow: 0 8px 30px rgba(42, 37, 34, 0.08);
  border: 1px solid rgba(232, 130, 93, 0.18);
}
.bar-coming__chip {
  display: inline-block;
  background: var(--c-rouge-carte);
  color: #fff;
  font-family: var(--ff-sans);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: 999px;
  margin-bottom: var(--sp-4);
}
.bar-coming__title {
  font-family: var(--ff-handwritten);
  font-size: clamp(2rem, 5vw, 3.25rem);
  color: var(--c-encre);
  line-height: 1.05;
  margin: 0 0 var(--sp-4);
}
.bar-coming__lead {
  max-width: 560px;
  margin: 0 auto var(--sp-5);
  font-size: var(--fs-md);
  color: var(--c-encre-doux);
  line-height: 1.6;
}
.bar-coming__cta {
  margin: var(--sp-5) 0 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
}
.bar-coming__cta-hint {
  font-size: var(--fs-sm);
  color: var(--c-mute);
  font-style: italic;
}

/* Grille des catégories */
.bar-categories {
  padding: var(--sp-7) 0;
}
.bar-categories__grid {
  list-style: none;
  padding: 0;
  margin: var(--sp-6) 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--sp-4);
}
.bar-cat-card {
  position: relative;
  background: #fff;
  border: 1px solid rgba(42, 37, 34, 0.10);
  border-radius: var(--radius-lg);
  padding: var(--sp-5);
  transition: transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast);
}
.bar-cat-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(42, 37, 34, 0.10);
  border-color: rgba(232, 130, 93, 0.35);
}
.bar-cat-card__icon {
  font-size: 2.25rem;
  line-height: 1;
  margin-bottom: var(--sp-3);
}
.bar-cat-card h3 {
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  color: var(--c-encre);
  margin: 0 0 var(--sp-2);
}
.bar-cat-card p {
  margin: 0;
  font-size: var(--fs-sm);
  color: var(--c-encre-doux);
  line-height: 1.55;
}
.bar-cat-card--featured {
  background: linear-gradient(180deg, #FFFBF2 0%, #FBF1DA 100%);
  border-color: rgba(184, 146, 58, 0.35);
}
.bar-cat-card__badge {
  position: absolute;
  top: var(--sp-3);
  right: var(--sp-3);
  background: #B8923A;
  color: #fff;
  font-size: 0.7rem;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 999px;
}

/* Bloc "Boire local, boire bien" */
.bar-promise {
  padding: var(--sp-7) 0 var(--sp-8);
  background: linear-gradient(180deg, #F5EDE0 0%, #FBF6EE 100%);
}
.bar-promise__inner {
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
}
.bar-promise__title {
  font-family: var(--ff-handwritten);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  color: var(--c-rouge-carte);
  margin: 0 0 var(--sp-4);
}
.bar-promise p {
  color: var(--c-encre-doux);
  line-height: 1.65;
  font-size: var(--fs-md);
}
.bar-promise__signature {
  margin-top: var(--sp-4);
  font-family: var(--ff-handwritten);
  font-size: var(--fs-lg);
  color: var(--c-encre);
}

/* Barre de contrôles "Tout déplier / Tout replier" */
.menu-controls {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-5) var(--sp-4) var(--sp-4);
  border-bottom: 1px dotted rgba(42, 37, 34, 0.18);
}
.menu-controls__btn {
  background: transparent;
  border: 1px solid var(--c-rouge-carte);
  color: var(--c-rouge-carte);
  font-family: var(--ff-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  padding: 8px 16px;
  border-radius: 999px;
  cursor: pointer;
  transition: background 180ms ease, color 180ms ease;
  letter-spacing: 0.02em;
}
.menu-controls__btn:hover {
  background: var(--c-rouge-carte);
  color: #fff;
}
.menu-controls__btn:focus-visible {
  outline: 3px solid var(--c-coucher);
  outline-offset: 2px;
}
.menu-page--glaces .menu-controls__btn {
  border-color: #B85287;
  color: #B85287;
}
.menu-page--glaces .menu-controls__btn:hover {
  background: #B85287;
  color: #fff;
}

/* Note enfant / supplément ingrédient */
.menu-note {
  background: rgba(232, 130, 93, 0.08);
  border-left: 3px solid var(--c-coucher);
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  color: var(--c-encre-doux);
  margin: var(--sp-4) 0;
}
.menu-note--bottom { margin-top: var(--sp-5); }

/* Note "carte tournante" — placée en haut, ton plus chaleureux/feuillage */
.menu-note--rotation {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  background: linear-gradient(180deg, #FFF8E8 0%, #FCEEC8 100%);
  border-left: 4px solid #B8923A;
  border-radius: var(--radius-md);
  padding: var(--sp-4) var(--sp-5);
  margin: 0 0 var(--sp-5);
  font-style: italic;
  font-size: var(--fs-sm);
  line-height: 1.55;
  color: #5C3A1E;
  box-shadow: 0 1px 2px rgba(92, 58, 30, 0.06);
}
.menu-note__icon {
  font-size: 1.4em;
  flex-shrink: 0;
  line-height: 1;
}
.menu-note__text { flex: 1; }

/* Page bar/cocktails placeholder */
.bar-placeholder {
  text-align: center;
  padding: var(--sp-9) var(--container-pad);
  max-width: 640px;
  margin: 0 auto;
}
.bar-placeholder__icon {
  font-size: 4rem;
  margin-bottom: var(--sp-4);
}
.bar-placeholder h2 {
  font-family: var(--ff-handwritten);
  font-size: clamp(2.5rem, 6vw, 3.5rem);
  color: var(--c-rouge-carte);
  margin: 0 0 var(--sp-3);
  line-height: 1;
}
.bar-placeholder p {
  color: var(--c-encre-doux);
  font-size: var(--fs-md);
  margin: 0 0 var(--sp-5);
}

/* ============================================================
   CLS guards — réservation de hauteur pour les zones hydratées
   en JS, afin d'éviter les sauts de mise en page.
   `:empty` se désactive dès que le JS injecte des enfants.
   ============================================================ */

/* Highlights de la carte (data/menu.json) */
.menu-grid:empty {
  min-height: 1180px;
  contain: layout;
}
@media (min-width: 768px) {
  .menu-grid:empty { min-height: 740px; }
}
@media (min-width: 1100px) {
  .menu-grid:empty { min-height: 380px; }
}

/* Avis Google (data-reviews) */
.reviews-grid:empty {
  min-height: 820px;
  contain: layout;
}
@media (min-width: 768px) {
  .reviews-grid:empty { min-height: 320px; }
}

/* Bandeau d'agrégat (note moyenne) */
.reviews-aggregate { min-height: 44px; }

/* Tableau d'horaires (data-hours-table) */
[data-hours-table]:empty {
  display: inline-block;
  min-height: 168px;
  min-width: 220px;
}

/* Sticky-CTA fixe en bas : isole son layout pour éviter les
   recalculs qui se propagent à la page. */
.sticky-cta { contain: layout style; }

/* Hero h1 : line-height fixe pour bloquer la hauteur quand la
   police Caveat/Fraunces termine de charger (FOUT swap). */
.hero h1 { line-height: 1.05; }
