/* ====== Pulcinella Mare — site styles ====== */

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  background: var(--bg-page);
  color: var(--fg-1);
  font-family: var(--font-sans);
}
a { color: inherit; text-decoration: none; }
ul { list-style: none; padding: 0; margin: 0; }
em { font-style: italic; color: var(--giallo-sole); }

/* Garantit que l'attribut HTML [hidden] masque l'élément, même s'il a un display
   explicite (grid/flex). Indispensable pour le filtrage JS des événements. */
[hidden] { display: none !important; }

/* ===== Buttons ===== */
.btn {
  font-family: var(--font-sans); font-weight: 600; font-size: 14px;
  letter-spacing: 0.04em;
  padding: 13px 24px; border-radius: var(--r-pill);
  border: none; cursor: pointer;
  transition: all var(--dur-base) var(--ease-out);
  display: inline-flex; align-items: center; gap: 6px;
}
.btn-primary { background: var(--blu-pulcinella); color: var(--crema); }
.btn-primary:hover { background: var(--blu-mare); transform: translateY(-1px); box-shadow: var(--elev-2); }
.btn-yellow { background: var(--giallo-sole); color: var(--blu-pulcinella); }
.btn-yellow:hover { transform: translateY(-1px) scale(1.02); box-shadow: var(--elev-3); }
.btn-ghost { background: transparent; color: var(--crema); border: 1.5px solid rgba(250,245,234,0.7); }
.btn-ghost:hover { background: rgba(250,245,234,0.1); }
.btn-full { width: 100%; justify-content: center; }
.btn:active { transform: scale(0.98); }

/* ===== Eyebrows ===== */
.eyebrow {
  font-family: var(--font-serif); font-size: 12px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--blu-pulcinella);
}
.eyebrow-yellow { color: var(--giallo-sole); }

/* ===== Nav ===== */
.nav {
  position: sticky; top: 16px; z-index: 50;
  padding: 0 20px; margin-top: 16px;
}
.nav-inner {
  max-width: 1200px; margin: 0 auto;
  background: rgba(250, 245, 234, 0.78);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-pill);
  padding: 10px 14px 10px 22px;
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 20px;
}
.nav-brand { display: flex; align-items: center; gap: 12px; text-decoration: none; }
.nav-brand img { height: 65px; width: auto; display: block; }
.nav-links { display: flex; gap: 28px; justify-content: center;
  font-family: var(--font-serif); font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase;
}
.nav-links a { position: relative; padding: 4px 0; transition: color var(--dur-fast); }
.nav-links a:hover { color: var(--blu-pulcinella); }
.nav-links a:hover::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 2px; background: var(--giallo-sole);
}

/* ===== Hero ===== */
.hero {
  position: relative; overflow: hidden;
  background: var(--blu-pulcinella);
  color: var(--crema);
  margin: 20px;
  border-radius: var(--r-xl);
  padding: 80px 64px 64px;
  min-height: 560px;
}
.hero-pattern {
  position: absolute; inset: 0;
  background: url('../img/ambiance-table-mer.png') center/cover;
  pointer-events: none;
}
.hero-pattern::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(95deg, rgba(11,23,64,0.78) 0%, rgba(30,63,161,0.86) 35%, rgba(30,63,161,0.72) 70%, rgba(11,23,64,0.65) 100%),
    linear-gradient(180deg, rgba(11,23,64,0.25) 0%, rgba(11,23,64,0.0) 35%, rgba(11,23,64,0.45) 100%);
}
.hero-inner { position: relative; max-width: 980px;}
.hero-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(48px, 7vw, 92px); line-height: 0.92;
  color: var(--crema); margin: 14px 0 0;
  letter-spacing: -0.02em; text-transform: uppercase;
}
.hero-title em { color: var(--giallo-sole); font-style: italic; }
.hero-sub {
  font-family: var(--font-serif); font-size: 19px; line-height: 1.55;
  color: var(--crema); opacity: 0.92; margin: 22px 0 32px;
  max-width: 520px;
}
.hero-sub em { color: var(--giallo-sole); font-style: italic; }
.hero-ctas { display: flex; gap: 18px; align-items: center; flex-wrap: wrap;}
.hero-link {
  font-family: var(--font-sans); font-size: 13px; font-weight: 600;
  color: var(--crema); letter-spacing: 0.06em;
  display: inline-flex; align-items: center; gap: 4px;
  border-bottom: 1.5px solid var(--giallo-sole); padding-bottom: 4px;
  transition: gap var(--dur-base);
}
.hero-link:hover { gap: 10px; }
.hero-link-dark { color: var(--blu-pulcinella); border-color: var(--blu-pulcinella); }
.hero-meta {
  position: relative; margin-top: 56px;
  display: flex; gap: 32px; flex-wrap: wrap;
  font-family: var(--font-sans); font-size: 13px; color: rgba(250,245,234,0.85);
}
.hero-meta span { display: inline-flex; align-items: center; gap: 8px; }
.hero-pulcinella { display: none; }

/* === Ambiance strip === */
.ambiance { max-width: 1240px; margin: 96px auto; padding: 0 20px;}
.ambiance-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 16px; height: 480px;}
.ambiance-img { border-radius: var(--r-lg); overflow: hidden; background-size: cover; background-position: center; position: relative;}
.ambiance-img.tall { grid-row: 1 / 2; }
.ambiance-col { display: grid; gap: 16px; }
.ambiance-quote {
  background: var(--giallo-sole); color: var(--blu-pulcinella);
  border-radius: var(--r-lg); padding: 28px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.ambiance-quote .q { font-family: var(--font-display); font-weight: 900; font-size: 26px; line-height: 1.05; text-transform: uppercase; letter-spacing: -0.01em;}
.ambiance-quote .src { font-family: var(--font-serif); font-style: italic; font-size: 13px; opacity: 0.85;}

/* ===== Reservation ===== */
.reserv {
  max-width: 1100px; margin: 80px auto;
  background: #fff; border: 1px solid var(--border-soft);
  border-radius: var(--r-xl); padding: 48px 56px;
  box-shadow: var(--elev-2);
}
.reserv-head { text-align: center; margin-bottom: 32px; }
.reserv-head h2 { font-family: var(--font-display); font-weight: 900; color: var(--blu-pulcinella); font-size: 40px; margin: 8px 0 6px; text-transform: uppercase; letter-spacing: -0.01em;}
.lead-mini { font-family: var(--font-serif); font-style: italic; color: var(--fg-2); font-size: 16px; margin: 0; }
.reserv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.field { display: flex; flex-direction: column; gap: 8px; }
.field-wide { grid-column: span 1; }
.lbl {
  font-family: var(--font-serif); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--blu-pulcinella);
  display: inline-flex; align-items: center; gap: 6px;
}
.field input, .field select {
  font-family: var(--font-sans); font-size: 15px; color: var(--fg-1);
  background: var(--crema); border: 1px solid transparent;
  border-radius: var(--r-md); padding: 13px 16px; outline: none;
  transition: all var(--dur-fast);
}
.field input:focus, .field select:focus {
  border-color: var(--blu-pulcinella); background: #fff;
  box-shadow: 0 0 0 3px rgba(30,63,161,0.12);
}
.reserv-submit { grid-column: 1 / -1; text-align: center; display: flex; flex-direction: column; gap: 10px; align-items: center; margin-top: 8px;}
.reserv-submit small { color: var(--fg-3); font-size: 12px; }
.reserv-submit .btn-full { max-width: 340px; }

.reserv-done {
  text-align: center; padding: 80px 48px;
  background: var(--blu-pulcinella); color: var(--crema);
  border: none;
}
.reserv-done svg { color: var(--giallo-sole); margin-bottom: 12px; }
.reserv-done h3 { font-family: var(--font-display); font-weight: 900; font-size: 38px; color: var(--crema); margin: 0 0 10px; text-transform: uppercase; letter-spacing: -0.01em;}
.reserv-done p { font-family: var(--font-serif); font-size: 17px; opacity: 0.9; max-width: 480px; margin: 0 auto;}

/* ===== Section heads (reusable) ===== */
.section-head { text-align: center; max-width: 720px; margin: 0 auto 48px; }
.section-head h2 { font-family: var(--font-display); font-weight: 900; color: var(--blu-pulcinella); font-size: 52px; line-height: 1; margin: 10px 0 12px; text-transform: uppercase; letter-spacing: -0.01em;}

/* ===== Carte ===== */
.carte { max-width: 1100px; margin: 96px auto; padding: 0 20px; text-align: center;}
.carte-grid { display: grid; grid-template-columns: 1fr; gap: 6px; text-align: left; margin-bottom: 32px;}
.dish {
  background: transparent; padding: 28px 8px 24px;
  border-bottom: 1px dashed var(--sabbia);
  position: relative;
}
.dish-sign {
  font-family: var(--font-serif); font-size: 10.5px;
  letter-spacing: 0.28em; text-transform: uppercase; color: var(--giallo-sole);
  background: var(--blu-pulcinella); color: var(--giallo-sole);
  display: inline-block; padding: 4px 10px; border-radius: var(--r-pill);
  margin-bottom: 8px;
}
.dish-row { display: flex; align-items: baseline; gap: 12px;}
.dish-row h3 { font-family: var(--font-display-alt); font-size: 30px; color: var(--blu-pulcinella); line-height: 1; flex: 0 0 auto;}
.dish-dots { flex: 1; border-bottom: 1.5px dotted var(--sabbia); position: relative; top: -8px;}
.dish-price { font-family: var(--font-display-alt); font-size: 28px; color: var(--blu-pulcinella); white-space: nowrap; flex-shrink: 0;}
.dish p { font-family: var(--font-sans); font-size: 14px; color: var(--fg-2); margin: 8px 0 10px; line-height: 1.6; max-width: 80%;}
.dish-badges { display: flex; gap: 8px; }

.badge {
  font-family: var(--font-sans); font-size: 11px; font-weight: 600;
  padding: 4px 10px; border-radius: var(--r-pill); letter-spacing: 0.04em;
}
.badge-info { background: rgba(245,203,46,0.25); color: var(--blu-pulcinella); }
.badge-veg { background: rgba(92,107,58,0.14); color: var(--olive);}

/* ===== Pieds dans l'eau ===== */
.pieds {
  margin: 96px 20px;
  background: var(--blu-pulcinella); color: var(--crema);
  border-radius: var(--r-xl);
  padding: 80px 72px;
  display: grid; grid-template-columns: 1.2fr 0.9fr;
  gap: 72px; align-items: center;
  position: relative; overflow: hidden;
}
.pieds::before {
  content: ""; position: absolute; inset: 0;
  background: url('../img/pattern-dolce-vita.png') center/cover;
  opacity: 0.08; mix-blend-mode: screen; pointer-events: none;
}
.pieds-left, .pieds-right { position: relative; }
.pieds h2 { font-family: var(--font-display); font-weight: 900; font-size: 56px; line-height: 0.95; margin: 14px 0 18px; text-transform: uppercase; letter-spacing: -0.02em;}
.white { color: var(--crema); }
.white-soft { color: var(--crema); opacity: 0.86; font-family: var(--font-serif); font-size: 18px; line-height: 1.6; max-width: 92%;}
.pieds-list { margin: 28px 0; display: grid; grid-template-columns: 1fr 1fr; gap: 10px 24px; font-size: 13.5px; color: var(--crema);}
.pieds-list li { display: flex; gap: 8px; align-items: flex-start; line-height: 1.45;}
.pieds-list svg { color: var(--giallo-sole); flex: 0 0 14px; margin-top: 3px;}
.pieds-meta {
  display: grid; grid-template-columns: repeat(3, auto);
  gap: 32px; margin: 0 0 28px;
  border-top: 1px solid rgba(250,245,234,0.22);
  border-bottom: 1px solid rgba(250,245,234,0.22);
  padding: 18px 0;
}
.pieds-meta > div { display: flex; flex-direction: column; gap: 4px; }
.m-lbl { font-family: var(--font-serif); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--giallo-sole);}
.m-val { font-family: var(--font-display-alt); font-weight: 400; font-size: 22px; color: var(--crema); letter-spacing: -0.005em; line-height: 1.1;}

.pieds-right { display: grid; gap: 16px; }
.pieds-card {
  background: rgba(250,245,234,0.08); border: 1px solid rgba(250,245,234,0.18);
  border-radius: var(--r-lg); padding: 26px;
  backdrop-filter: blur(8px);
}
.pieds-photo {
  border-radius: var(--r-xl); overflow: hidden; aspect-ratio: 4/5;
  background: url('../img/ambiance-arche.jpeg') center/cover;
  box-shadow: var(--elev-3);
}
.pieds-card svg { color: var(--giallo-sole); }
.pieds-card-q { font-family: var(--font-serif); font-size: 13px; color: var(--crema); opacity: 0.8; margin-top: 8px;
  letter-spacing: 0.16em; text-transform: uppercase;
}
.pieds-card-time { font-family: var(--font-display); font-weight: 900; font-size: 52px; color: var(--giallo-sole); line-height: 1; margin: 6px 0 16px; letter-spacing: -0.02em;}
.pieds-card-foot { font-family: var(--font-sans); font-size: 12px; color: rgba(250,245,234,0.7);}
.pieds-card-foot-alt { margin-top: 12px;}
.pieds-card .script {
  font-family: var(--font-script); font-weight: 700; color: var(--giallo-sole);
  font-size: 56px; line-height: 0.85;
}

/* ===== Events ===== */
.events { max-width: 1200px; margin: 96px auto; padding: 0 20px;}
.events-row {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
}
.event {
  background: var(--crema-2);
  border-radius: var(--r-md);
  padding: 24px;
  border-top: 4px solid var(--giallo-sole);
  transition: transform var(--dur-base), box-shadow var(--dur-base);
}
.event:hover { transform: translateY(-3px); box-shadow: var(--elev-2);}
.event-day { font-family: var(--font-serif); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--blu-pulcinella);}
.event-title { font-family: var(--font-display); font-weight: 700; font-size: 19px; color: var(--fg-1); line-height: 1.2; margin: 10px 0 10px; text-transform: uppercase; letter-spacing: -0.005em;}
.event-meta { font-family: var(--font-sans); font-size: 12px; color: var(--fg-2); display: inline-flex; align-items: center; gap: 6px;}

/* ===== Footer ===== */
.footer {
  background: var(--crema-2);
  margin-top: 96px; padding: 72px 24px 28px;
}
.footer-grid {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: 48px;
}
.footer-logo { height: 60px; margin-bottom: 16px;}
.footer-tag { font-family: var(--font-serif); font-style: italic; color: var(--fg-2); margin: 0; line-height: 1.6;}
.footer h4 { font-family: var(--font-serif); font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--blu-pulcinella); margin: 0 0 16px;}
.footer p { font-family: var(--font-sans); font-size: 13.5px; color: var(--fg-2); line-height: 1.7; margin: 0 0 10px;}
.footer-social { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-sans); font-size: 14px; color: var(--blu-pulcinella); font-weight: 600;}
.footer-social:hover { color: var(--blu-mare);}
.footer-bottom {
  max-width: 1200px; margin: 56px auto 0;
  padding-top: 24px; border-top: 1px solid var(--border-soft);
  display: flex; justify-content: space-between;
  font-family: var(--font-sans); font-size: 12px; color: var(--fg-3);
}
.small { font-size: 12px; color: var(--fg-3); }

/* === Page hero (sub-pages) === */
.page-hero {
  margin: 20px;
  border-radius: var(--r-xl);
  overflow: hidden;
  display: grid; grid-template-columns: 1fr 1fr;
  min-height: 480px;
  background: var(--giallo-sole);
}
.page-hero-left {
  position: relative; padding: 64px 56px;
  display: flex; align-items: center;
  background: var(--giallo-sole);
}
.page-hero-left::before {
  content: ""; position: absolute; inset: 0;
  background: url('../img/pattern-dolce-vita.png') center/cover;
  opacity: 0.14; mix-blend-mode: multiply; pointer-events: none;
}
.page-hero-inner { position: relative; max-width: 550px; }
.page-hero-inner .eyebrow { color: var(--blu-pulcinella);}
.page-hero-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(56px, 6vw, 96px); line-height: 0.9;
  color: var(--blu-pulcinella); margin: 16px 0 22px;
  letter-spacing: -0.025em; text-transform: uppercase;
}
.page-hero-title em { font-style: italic; color: var(--blu-pulcinella); font-family: var(--font-display-alt); font-weight: 400; text-transform: none; letter-spacing: -0.01em;}
.page-hero-sub {
  font-family: var(--font-serif); font-size: 18px; line-height: 1.55;
  color: var(--blu-pulcinella); max-width: 440px; margin: 0;
  font-style: italic;
}
.page-hero-rule {
  margin-top: 32px; width: 80px; height: 4px;
  background: var(--blu-pulcinella);
  position: relative;
}
.page-hero-rule::after {
  content: "·  ·  ·"; position: absolute; left: 100px; top: -10px;
  font-size: 22px; color: var(--blu-pulcinella); letter-spacing: 8px;
}
.page-hero-right {
  position: relative;
  background-size: cover; background-position: center;
}
.page-hero-tape {
  position: absolute; top: 28px; right: 28px;
  background: var(--crema); padding: 10px;
  border-radius: 50%;
  box-shadow: var(--elev-3);
  width: 78px; height: 78px;
  display: grid; place-items: center;
  transform: rotate(-8deg);
}
.page-hero-tape img { width: 100%; }

/* === Sub-page content blocks === */
.page-section { max-width: 1200px; margin: 80px auto; padding: 0 20px; }
.page-section .lead {
  font-family: var(--font-serif); font-style: italic;
  font-size: 19px; line-height: 1.6; color: var(--fg-1);
  max-width: 680px; margin: 0 auto 56px; text-align: center;
}

/* === La carte page === */
.menu-section { margin-bottom: 56px;}
.menu-section-head {
  display: grid; grid-template-columns: auto 1fr auto; gap: 18px;
  align-items: center; margin-bottom: 22px;
}
.menu-section-head h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: 32px; color: var(--blu-pulcinella);
  text-transform: uppercase; letter-spacing: -0.01em; margin: 0;
}
.menu-section-head .it {
  font-family: var(--font-serif); font-style: italic;
  color: var(--fg-2); font-size: 15px;
}
.menu-section-head .rule { border-top: 1.5px dotted var(--sabbia); height: 1px;}
.menu-list { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 48px;}

/* === Pieds dans l'eau page === */
.formula-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 32px;}
.formula {
  background: #fff; border-radius: var(--r-lg); padding: 32px;
  border: 1px solid var(--border-soft); position: relative;
}
.formula.featured { background: var(--blu-pulcinella); color: var(--crema); border: none; box-shadow: var(--elev-3);}
.formula.featured h3, .formula.featured .price { color: var(--giallo-sole);}
.formula.featured p, .formula.featured li { color: var(--crema);}
.formula-tag {
  position: absolute; top: -12px; right: 24px;
  background: var(--giallo-sole); color: var(--blu-pulcinella);
  font-family: var(--font-sans); font-size: 11px; font-weight: 600;
  padding: 5px 12px; border-radius: var(--r-pill); letter-spacing: 0.06em;
}
.formula h3 {
  font-family: var(--font-display); font-weight: 900; font-size: 30px;
  color: var(--blu-pulcinella); text-transform: uppercase; letter-spacing: -0.01em; margin: 0;
}
.formula .price {
  font-family: var(--font-display-alt); font-size: 38px;
  color: var(--blu-pulcinella); margin: 8px 0 16px;
}
.formula p { font-family: var(--font-sans); font-size: 14px; color: var(--fg-2); line-height: 1.6; margin: 0 0 18px;}
.formula ul { display: grid; gap: 8px; margin: 0 0 24px;}
.formula li { font-family: var(--font-sans); font-size: 13px; color: var(--fg-2); display: flex; gap: 8px; align-items: flex-start; line-height: 1.5;}
.formula li::before {content: "·"; color: var(--giallo-sole); font-weight: 900; font-size: 20px; line-height: 1;}

.process-row {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
  margin-top: 48px;
}
.step { text-align: left;}
.step .n { font-family: var(--font-display-alt); font-weight: 400; font-size: 72px; color: var(--giallo-sole); line-height: 1; letter-spacing: -0.04em;}
.step h4 { font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--blu-pulcinella); text-transform: uppercase; margin: 6px 0 10px; letter-spacing: -0.005em;}
.step p { font-family: var(--font-sans); font-size: 13px; color: var(--fg-2); line-height: 1.6; margin: 0;}

/* === Événements page === */
.evt-list { display: grid; gap: 14px;}
.evt-card {
  background: #fff; border: 1px solid var(--border-soft);
  border-radius: var(--r-lg); padding: 24px 28px;
  display: grid; grid-template-columns: 120px 1fr auto; align-items: center; gap: 28px;
  transition: all var(--dur-base) var(--ease-out);
}
.evt-card:hover { box-shadow: var(--elev-2); transform: translateY(-2px);}
.evt-date {
  background: var(--blu-pulcinella); color: var(--crema);
  border-radius: var(--r-md); padding: 12px; text-align: center;
}
.evt-date .d { font-family: var(--font-display-alt); font-weight: 400; font-size: 38px; line-height: 1; color: var(--giallo-sole);}
.evt-date .m { font-family: var(--font-serif); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; margin-top: 4px;}
.evt-body h3 { font-family: var(--font-display); font-weight: 900; font-size: 24px; color: var(--blu-pulcinella); text-transform: uppercase; letter-spacing: -0.01em; margin: 0 0 6px;}
.evt-body p { font-family: var(--font-sans); font-size: 13.5px; color: var(--fg-2); line-height: 1.55; margin: 0 0 8px;}
.evt-body .meta { font-family: var(--font-serif); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-3);}
.evt-cta { display: flex; flex-direction: column; gap: 6px; align-items: flex-end;}
.evt-price { font-family: var(--font-display-alt); font-size: 22px; color: var(--blu-pulcinella);}

.evt-categories {
  display: flex; gap: 10px; justify-content: center; margin: 0 0 48px; flex-wrap: wrap;
}
.evt-chip {
  background: #fff; border: 1px solid var(--border-soft);
  font-family: var(--font-sans); font-size: 13px; font-weight: 600;
  padding: 9px 18px; border-radius: var(--r-pill);
  color: var(--fg-2); cursor: pointer;
}
.evt-chip.on { background: var(--blu-pulcinella); color: var(--crema); border-color: var(--blu-pulcinella);}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
}


/* ============== CONTACT PAGE ============== */
.contact-grid {
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 28px;
  max-width: 1200px; margin: 80px auto; padding: 0 20px;
}
.contact-info { display: grid; gap: 20px; align-content: start;}
.chalkboard {
  background: #1c2630; color: var(--crema);
  border-radius: var(--r-lg); padding: 32px 36px;
  position: relative; border: 8px solid #8a5a2a;
  box-shadow: inset 0 0 80px rgba(0,0,0,0.55), var(--elev-3);
}
.chalkboard .ch-eyebrow {
  font-family: var(--font-serif); font-style: italic;
  color: var(--giallo-sole); letter-spacing: 0.04em; font-size: 14px;
  text-align: center; margin-bottom: 8px;
}
.chalkboard h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: 38px; color: var(--crema); text-align: center;
  text-transform: uppercase; letter-spacing: -0.01em; margin: 0 0 22px;
}
.chalk-rule { height: 1.5px; margin: 14px 0 22px;
  background: repeating-linear-gradient(90deg, rgba(255,247,229,0.45) 0 4px, transparent 4px 9px);
}
.hours-list { display: grid; gap: 10px;}
.hours-list .row {
  display: grid; grid-template-columns: 1fr auto; gap: 12px;
  font-family: var(--font-serif); font-size: 16px;
  border-bottom: 1px dashed rgba(255,247,229,0.18); padding-bottom: 8px;
}
.hours-list .row .d { letter-spacing: 0.12em; text-transform: uppercase; font-size: 12px; color: var(--giallo-sole); align-self: center;}
.hours-list .row .h { font-style: italic;}
.hours-list .row.closed .h { color: rgba(255,247,229,0.4); text-decoration: line-through;}
.chalk-foot {
  margin-top: 22px; font-family: var(--font-serif); font-style: italic;
  font-size: 14px; color: rgba(255,247,229,0.7); text-align: center;
}

.contact-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 12px;}
.ccard {
  background: #fff; border: 1px solid var(--border-soft);
  border-radius: var(--r-md); padding: 20px; text-decoration: none;
  transition: all var(--dur-base) var(--ease-out);
  display: block;
}
.ccard:hover { box-shadow: var(--elev-2); transform: translateY(-2px); border-color: var(--blu-pulcinella);}
.ccard .ic {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--giallo-sole); display: grid; place-items: center;
  color: var(--blu-pulcinella); margin-bottom: 12px;
}
.ccard h4 { font-family: var(--font-display); font-weight: 700; font-size: 15px;
  color: var(--blu-pulcinella); text-transform: uppercase; letter-spacing: -0.005em; margin: 0 0 4px;}
.ccard p { font-family: var(--font-sans); font-size: 12.5px; color: var(--fg-2); line-height: 1.5; margin: 0 0 10px;}
.ccard span { font-family: var(--font-serif); font-style: italic; font-size: 13px; color: var(--blu-pulcinella); border-bottom: 1px solid var(--blu-pulcinella);}

.find-card {
  background: var(--blu-pulcinella); color: var(--crema);
  border-radius: var(--r-lg); padding: 28px 32px;
}
.find-card .eyebrow { color: var(--giallo-sole);}
.find-card h3 { font-family: var(--font-display); font-weight: 900;
  font-size: 26px; color: var(--giallo-sole); text-transform: uppercase;
  letter-spacing: -0.01em; margin: 6px 0 16px;}
.find-card .sensory { display: grid; gap: 12px; margin: 0; padding: 0; list-style: none;}
.find-card .sensory li {
  display: grid; grid-template-columns: 30px 1fr; gap: 12px;
  font-family: var(--font-sans); font-size: 13.5px; line-height: 1.55;
  color: rgba(252,243,225,0.92); align-items: start;
}
.find-card .sensory .n {
  font-family: var(--font-display-alt); font-size: 20px;
  color: var(--giallo-sole); line-height: 1.2;
}

/* Postcard form */
.postcard {
  background: #fdfaef; border-radius: var(--r-lg);
  border: 1px solid var(--sabbia);
  padding: 38px 40px 30px; position: sticky; top: 100px;
  box-shadow: var(--elev-3);
  align-self: start;
}
.postcard::before {
  content: ""; position: absolute; inset: 12px;
  border: 1.5px dashed rgba(30,63,161,0.25);
  border-radius: calc(var(--r-lg) - 8px); pointer-events: none;
}
.postcard-head {
  display: grid; grid-template-columns: 1fr auto; gap: 20px;
  margin-bottom: 22px; position: relative; z-index: 2;
}
.postcard-head h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: 38px; color: var(--blu-pulcinella);
  text-transform: uppercase; letter-spacing: -0.015em; margin: 0;
  line-height: 0.95;
}
.postcard-head h2 em { font-family: var(--font-display-alt); font-weight: 400; font-style: italic; text-transform: none; color: var(--blu-pulcinella);}
.postcard-stamp {
  width: 72px; height: 86px;
  background: var(--giallo-sole);
  border: 3px solid var(--crema); outline: 1.5px dashed var(--blu-pulcinella);
  outline-offset: -8px;
  display: grid; place-items: center; padding: 6px;
  transform: rotate(4deg);
}
.postcard-stamp img { width: 100%; height: 100%; object-fit: contain;}
.postmark {
  position: absolute; top: 110px; right: 80px;
  width: 100px; height: 100px;
  border: 2px solid rgba(30,63,161,0.25); border-radius: 50%;
  display: grid; place-items: center; transform: rotate(-12deg);
  font-family: var(--font-display); font-weight: 700; font-size: 9px;
  color: rgba(30,63,161,0.4); text-align: center; letter-spacing: 0.16em;
  line-height: 1.3; padding: 8px; pointer-events: none;
  z-index: 0;
}

.postcard-form { display: grid; gap: 16px; position: relative; z-index: 1;}
.pc-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px;}
.pc-field { display: grid; gap: 6px;}
.pc-field label {
  font-family: var(--font-serif); font-style: italic;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--blu-pulcinella);
}
.pc-field input, .pc-field textarea, .pc-field select {
  background: transparent; border: none;
  border-bottom: 1.5px dotted var(--blu-pulcinella);
  font-family: var(--font-serif); font-size: 15px;
  color: var(--blu-pulcinella); padding: 8px 0;
  outline: none; transition: border-color var(--dur-base) var(--ease-out);
}
.pc-field input:focus, .pc-field textarea:focus, .pc-field select:focus { border-bottom-color: var(--giallo-sole); border-bottom-style: solid;}
.pc-field textarea { min-height: 96px; resize: vertical; line-height: 1.55;}
.pc-field input::placeholder, .pc-field textarea::placeholder { color: rgba(30,63,161,0.4); font-style: italic;}
.pc-field select { appearance: none; -webkit-appearance: none; cursor: pointer;}

.pc-submit {
  margin-top: 8px; align-self: start;
  background: var(--blu-pulcinella); color: var(--giallo-sole);
  border: 2.5px dashed var(--giallo-sole); outline: 2px solid var(--blu-pulcinella); outline-offset: -7px;
  font-family: var(--font-display); font-weight: 900; font-size: 16px;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 14px 28px; border-radius: 4px; cursor: pointer;
  transform: rotate(-2deg);
}

.postcard.sent .postcard-form { opacity: 0.4; pointer-events: none;}
.postcard-sent {
  position: absolute; inset: 0; display: grid; place-items: center;
  background: rgba(253,250,239,0.92); border-radius: var(--r-lg);
  text-align: center; padding: 40px; z-index: 5;
}
.postcard-sent .sent-stamp {
  font-family: var(--font-display); font-weight: 900;
  font-size: 56px; color: var(--rosso-tomate);
  border: 4px solid var(--rosso-tomate); padding: 16px 32px;
  transform: rotate(-8deg); letter-spacing: 0.06em;
  text-transform: uppercase;
}
.postcard-sent p { font-family: var(--font-serif); font-style: italic; font-size: 16px; color: var(--blu-pulcinella); margin: 22px 0 0; max-width: 360px;}

/* ============== RESERVATION PAGE ============== */
.reserv-event-banner {
  max-width: 1180px;
  margin: 36px auto 0;
  padding: 0 20px;
}
.reserv-event-banner-inner {
  background: var(--blu-pulcinella);
  color: var(--crema);
  border-radius: var(--r-lg);
  padding: 22px 28px;
  box-shadow: var(--elev-2);
  position: relative;
}
.reserv-event-banner .eyebrow {
  color: var(--giallo-sole);
  font-family: var(--font-serif);
  font-size: 12px;
  letter-spacing: var(--tracking-xwide);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.reserv-event-banner h2 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 28px;
  margin: 4px 0 6px;
  color: var(--crema);
  text-transform: uppercase;
  letter-spacing: var(--tracking-tight);
}
.reserv-event-banner p {
  font-family: var(--font-serif);
  font-size: 15px;
  color: var(--giallo-limone);
  margin: 0;
  letter-spacing: 0.04em;
}
.reserv-event-banner-change {
  position: absolute;
  top: 16px;
  right: 22px;
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 600;
  color: var(--giallo-sole);
  text-decoration: none;
  letter-spacing: 0.02em;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(245, 203, 46, 0.4);
  transition: background var(--dur-fast) var(--ease-out);
}
.reserv-event-banner-change:hover {
  background: rgba(245, 203, 46, 0.18);
}
@media (max-width: 700px) {
  .reserv-event-banner h2 { font-size: 22px; }
  .reserv-event-banner-change {
    position: static;
    display: inline-block;
    margin-top: 12px;
  }
}

.reserv-shell {
  display: grid; grid-template-columns: 1fr 340px; gap: 28px;
  max-width: 1180px; margin: 60px auto 80px; padding: 0 20px; align-items: start;
}
.reserv-main {
  background: #fff; border: 1px solid var(--border-soft);
  border-radius: var(--r-xl); padding: 36px 40px;
  box-shadow: var(--elev-2);
}
.steps-rail {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px;
  margin-bottom: 32px;
}
.steps-rail .st {
  display: grid; grid-template-columns: auto 1fr; gap: 10px; align-items: center;
  padding: 12px 4px; border-top: 3px solid var(--border-soft);
}
.steps-rail .st.active { border-top-color: var(--blu-pulcinella);}
.steps-rail .st.done { border-top-color: var(--giallo-sole);}
.steps-rail .st .n {
  font-family: var(--font-display-alt); font-size: 22px; color: var(--fg-3);
  line-height: 1;
}
.steps-rail .st.active .n, .steps-rail .st.done .n { color: var(--blu-pulcinella);}
.steps-rail .st .lbl {
  font-family: var(--font-serif); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fg-3); line-height: 1.2;
}
.steps-rail .st.active .lbl, .steps-rail .st.done .lbl { color: var(--blu-pulcinella);}

.step-head { display: grid; gap: 6px; margin-bottom: 20px;}
.step-head h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: 34px; color: var(--blu-pulcinella);
  text-transform: uppercase; letter-spacing: -0.015em; margin: 0;
  line-height: 0.95;
}
.step-head h2 em { font-family: var(--font-display-alt); font-weight: 400; font-style: italic; text-transform: none; color: var(--blu-pulcinella);}
.step-head p { font-family: var(--font-serif); font-style: italic; font-size: 15px; color: var(--fg-2); margin: 0;}

.month-head { display: flex; justify-content: space-between; align-items: center; margin: 16px 0 14px;}
.month-head .m { font-family: var(--font-display-alt); font-weight: 400; font-size: 26px; color: var(--blu-pulcinella); letter-spacing: -0.005em;}
.month-head button { background: transparent; border: 1px solid var(--border-soft); width: 32px; height: 32px; border-radius: 50%; cursor: pointer; color: var(--blu-pulcinella);}
.month-head .nav-arr { display: flex; gap: 6px;}
.weekdays { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; margin-bottom: 6px;}
.weekdays div { font-family: var(--font-serif); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-3); text-align: center;}
.date-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px;}
.dcell {
  aspect-ratio: 1 / 1; background: #fff; border: 1.5px solid var(--border-soft);
  border-radius: var(--r-md); display: grid; place-items: center;
  cursor: pointer; padding: 6px;
}
.dcell.empty { background: transparent; border: none; cursor: default;}
.dcell.past { opacity: 0.3; cursor: not-allowed; background: var(--bg-soft);}
.dcell .num { font-family: var(--font-display-alt); font-size: 20px; color: var(--blu-pulcinella); line-height: 1;}
.dcell .dot { width: 5px; height: 5px; border-radius: 50%; margin-top: 4px;}
.dcell .dot.free { background: #1f8a5b;}
.dcell .dot.few { background: var(--giallo-sole);}
.dcell .dot.full { background: rgba(218,28,32,0.7);}
.dcell.full { cursor: not-allowed;}
.dcell.full .num { color: var(--fg-3); text-decoration: line-through;}
.dcell:not(.past):not(.full):not(.empty):hover { border-color: var(--blu-pulcinella);}
.dcell.sel { background: var(--blu-pulcinella); border-color: var(--blu-pulcinella);}
.dcell.sel .num { color: var(--giallo-sole);}
.dcell.sel .dot { background: var(--giallo-sole);}

.legend { display: flex; gap: 16px; margin-top: 16px; font-family: var(--font-serif); font-size: 11px; color: var(--fg-2); flex-wrap: wrap;}
.legend span { display: flex; align-items: center; gap: 6px;}
.legend .d { width: 8px; height: 8px; border-radius: 50%;}

/* ---- Calendrier de réservation : extensions ---- */
.pulc-calendar-wrap { margin: 16px 0 8px; }
.dcell { position: relative; }
.dcell.closed { opacity: 0.55; cursor: not-allowed; background: var(--bg-soft); }
.dcell.closed .num { color: var(--fg-3); text-decoration: line-through; }
.dcell-flag {
  font-family: var(--font-serif);
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-top: 4px;
}
.dcell.has-event {
  background: linear-gradient(180deg, #fff 0%, var(--giallo-limone) 100%);
  border-color: var(--giallo-sole);
}
.dcell.has-event:hover {
  border-color: var(--giallo-sole);
  box-shadow: 0 4px 16px rgba(245, 203, 46, 0.35);
}
.dcell .dot.event { background: var(--giallo-sole); width: 7px; height: 7px; }
.dcell.sel.has-event { background: var(--blu-pulcinella); }
.dcell.sel.has-event .num { color: var(--giallo-sole); }
.dcell.sel.has-event .dot { background: var(--giallo-sole); }

.dcell-tooltip {
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  background: var(--blu-notte);
  color: var(--crema);
  padding: 10px 14px;
  border-radius: var(--r-sm);
  font-family: var(--font-sans);
  font-size: 12px;
  line-height: 1.4;
  min-width: 180px;
  max-width: 240px;
  text-align: left;
  box-shadow: var(--elev-2);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out);
  z-index: 5;
}
.dcell-tooltip::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: var(--blu-notte);
}
.dcell-tooltip-event { padding: 4px 0; }
.dcell-tooltip-event + .dcell-tooltip-event {
  border-top: 1px solid rgba(250, 245, 234, 0.18);
  margin-top: 4px;
  padding-top: 6px;
}
.dcell-tooltip-event strong {
  display: block;
  color: var(--giallo-sole);
  font-weight: 700;
  letter-spacing: 0.01em;
}
.dcell-tooltip-event span {
  font-family: var(--font-serif);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--crema);
  opacity: 0.85;
}
.dcell.has-event:hover .dcell-tooltip,
.dcell.has-event:focus .dcell-tooltip,
.dcell.has-event.show-tooltip .dcell-tooltip {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
@media (max-width: 700px) {
  .dcell-tooltip { display: none; }
  .dcell.has-event.show-tooltip .dcell-tooltip { display: block; }
}

/* Disabled month-head buttons */
.month-head button:disabled { opacity: 0.3; cursor: not-allowed; }

/* Flash erreur si on tente d'avancer sans avoir choisi de date */
.pulc-calendar-error { animation: pulc-shake 0.45s ease-out; }
.pulc-calendar-error .date-grid { box-shadow: 0 0 0 2px var(--tomate); border-radius: var(--r-md); }
@keyframes pulc-shake {
  0%, 100% { transform: translateX(0); }
  20%, 60% { transform: translateX(-8px); }
  40%, 80% { transform: translateX(8px); }
}

.hours-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px; margin-top: 20px;}
.hslot {
  border: 1.5px solid var(--border-soft); background: #fff;
  font-family: var(--font-display-alt); font-size: 17px; color: var(--blu-pulcinella);
  padding: 12px 8px; border-radius: var(--r-md); cursor: pointer;
  text-align: center;
}
.hslot:hover { border-color: var(--blu-pulcinella);}
.hslot.sel { background: var(--blu-pulcinella); color: var(--giallo-sole); border-color: var(--blu-pulcinella);}
.hslot.x { opacity: 0.35; text-decoration: line-through; cursor: not-allowed;}

.convives-row {
  display: grid; grid-template-columns: 56px 1fr 56px; gap: 0;
  align-items: center; max-width: 420px; margin: 20px auto 0;
  border: 2px solid var(--blu-pulcinella); border-radius: var(--r-pill);
  padding: 6px 8px; background: #fff;
}
.convives-row button {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--blu-pulcinella); color: var(--giallo-sole);
  border: none; font-size: 24px; cursor: pointer; line-height: 1; font-weight: 700;
}
.convives-row button:disabled { opacity: 0.3; cursor: not-allowed;}
.convives-row .display { text-align: center;}
.convives-row .display .n { font-family: var(--font-display-alt); font-size: 48px; color: var(--blu-pulcinella); line-height: 1;}
.convives-row .display .lbl { font-family: var(--font-serif); font-style: italic; font-size: 12px; color: var(--fg-2); letter-spacing: 0.08em;}

.plates-row { display: flex; justify-content: center; gap: 8px; margin: 16px 0 4px; flex-wrap: wrap;}
.plate {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--crema); border: 2px solid var(--sabbia);
  display: grid; place-items: center;
}
.plate.on { background: var(--giallo-sole); border-color: var(--blu-pulcinella);}

.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 20px;}
.form-grid .full { grid-column: span 2;}
.fld { display: grid; gap: 6px;}
.fld label { font-family: var(--font-serif); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--blu-pulcinella);}
.fld input, .fld textarea {
  border: 1.5px solid var(--border-soft); background: #fff;
  border-radius: var(--r-md); padding: 11px 14px;
  font-family: var(--font-serif); font-size: 15px; color: var(--fg-1);
  outline: none;
}
.fld input:focus, .fld textarea:focus { border-color: var(--blu-pulcinella);}
.fld textarea { min-height: 86px; resize: vertical;}

.wizard-foot {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 32px; padding-top: 22px; border-top: 1px dashed var(--sabbia);
}
.btn-ghost {
  background: transparent; border: none; cursor: pointer;
  font-family: var(--font-serif); font-style: italic; font-size: 14px;
  color: var(--fg-2);
}
.btn-ghost:hover { color: var(--blu-pulcinella);}

/* ---- Carte : filtre sticky par section ---- */
.menu-section-nav {
  position: sticky;
  top: 78px;
  z-index: 5;
  background: var(--crema);
  margin: 24px -20px 32px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--sabbia);
  box-shadow: 0 4px 12px rgba(11, 23, 64, 0.04);
}
.menu-section-nav-inner {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  flex-wrap: nowrap;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}
.menu-section-nav-inner::-webkit-scrollbar { height: 4px; }
.menu-section-nav-inner::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 2px; }
.menu-section-chip {
  flex: 0 0 auto;
  padding: 8px 16px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 600;
  color: var(--fg-2);
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.menu-section-chip:hover {
  border-color: var(--blu-pulcinella);
  color: var(--blu-pulcinella);
}
.menu-section-chip.on {
  background: var(--blu-pulcinella);
  color: var(--crema);
  border-color: var(--blu-pulcinella);
}
@media (max-width: 700px) {
  .menu-section-nav { top: 64px; padding: 10px 16px; }
  .menu-section-chip { font-size: 12px; padding: 6px 12px; }
}

/* ============================================================
 * PAGE PRIVATISER
 * ============================================================ */

.priv-pdj { max-width: 1200px; margin: 56px auto 80px; padding: 0 20px; }
.priv-pdj-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 28px;
}
.priv-pdj-card {
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: var(--r-lg);
  padding: 28px;
  position: relative;
  transition: transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.priv-pdj-card:hover { transform: translateY(-2px); box-shadow: var(--elev-2); }
.priv-pdj-card.featured {
  background: linear-gradient(180deg, #fff 0%, var(--giallo-limone) 100%);
  border-color: var(--giallo-sole);
}
.priv-pdj-card h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 30px;
  color: var(--blu-pulcinella);
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0 0 4px;
}
.priv-pdj-price {
  font-family: var(--font-display-alt);
  font-size: 28px;
  color: var(--blu-pulcinella);
  margin: 0 0 10px;
}
.priv-pdj-hours {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
  color: var(--fg-2);
  padding-bottom: 14px;
  margin-bottom: 14px;
  border-bottom: 1px dashed var(--sabbia);
}
.priv-pdj-card ul { list-style: none; padding: 0; margin: 0; }
.priv-pdj-card li {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--fg-1);
  padding: 5px 0;
  line-height: 1.5;
}
.priv-pdj-card li::before { content: ". "; color: var(--giallo-sole); font-weight: 700; }

.priv-quote {
  background: var(--blu-pulcinella);
  color: var(--crema);
  padding: 80px 20px;
  position: relative;
}
.priv-quote::before {
  content: ""; position: absolute; inset: 0;
  background: url('../img/pattern-dolce-vita.png') center/cover;
  opacity: 0.06; pointer-events: none;
}
.priv-quote-grid {
  position: relative;
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 48px;
  align-items: start;
}
.priv-quote-text .eyebrow { color: var(--giallo-sole); }
.priv-quote-text h2 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 48px;
  line-height: 0.95;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  color: var(--crema);
  margin: 10px 0 18px;
}
.priv-quote-lead {
  font-family: var(--font-serif);
  font-size: 17px;
  line-height: 1.6;
  color: var(--crema);
  opacity: 0.9;
  margin-bottom: 20px;
}
.priv-quote-groups {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
  color: var(--giallo-limone);
  padding: 14px 18px;
  background: rgba(245, 203, 46, 0.1);
  border-left: 3px solid var(--giallo-sole);
  border-radius: var(--r-sm);
  line-height: 1.5;
}

.priv-quote-form-wrap {
  background: #fff;
  color: var(--fg-1);
  border-radius: var(--r-xl);
  padding: 36px;
  box-shadow: var(--elev-3);
}
.priv-quote-form { display: grid; gap: 14px; }
.priv-quote-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.priv-quote-field { display: flex; flex-direction: column; gap: 4px; }
.priv-quote-field-wide { grid-column: 1 / -1; }
.priv-quote-field span {
  font-family: var(--font-serif);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.priv-quote-field input,
.priv-quote-field select,
.priv-quote-field textarea {
  background: var(--bg-page);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-sm);
  padding: 11px 14px;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--fg-1);
}
.priv-quote-field input:focus,
.priv-quote-field select:focus,
.priv-quote-field textarea:focus {
  outline: none;
  border-color: var(--blu-pulcinella);
  box-shadow: 0 0 0 2px rgba(30,63,161,0.15);
}
.priv-quote-success {
  text-align: center;
  padding: 32px 16px;
}
.priv-quote-success svg { color: var(--olive); margin-bottom: 12px; }
.priv-quote-success h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 26px;
  color: var(--blu-pulcinella);
  text-transform: uppercase;
  margin: 6px 0 12px;
}

@media (max-width: 900px) {
  .priv-pdj-grid { grid-template-columns: 1fr; }
  .priv-quote-grid { grid-template-columns: 1fr; gap: 32px; }
  .priv-quote-text h2 { font-size: 36px; }
  .priv-quote-row { grid-template-columns: 1fr; }
  .priv-quote-form-wrap { padding: 24px; }
}

/* ============================================================
 * HOME TEASERS (PDJ + Privatiser) - 2 cards cote-a-cote
 * ============================================================ */

.home-teasers {
  max-width: 1200px;
  margin: 60px auto;
  padding: 0 20px;
}
.home-teasers-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.home-card {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  min-height: 320px;
  transition: transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.home-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--elev-3);
}
.home-card-inner {
  position: relative;
  z-index: 1;
  padding: 36px 32px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
}
.home-card .eyebrow {
  font-family: var(--font-serif);
  font-size: 11px;
  letter-spacing: var(--tracking-xwide);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.home-card h2 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 34px;
  line-height: 0.98;
  text-transform: uppercase;
  letter-spacing: var(--tracking-tight);
  margin: 0 0 14px;
}
.home-card p {
  font-family: var(--font-serif);
  font-size: 16px;
  line-height: 1.55;
  margin: 0 0 22px;
  flex-grow: 1;
}
.home-card .btn { margin-top: auto; }

/* PDJ card : fond crema chaleureux, contenu bleu Pulcinella */
.home-card-pdj {
  background: linear-gradient(160deg, var(--crema) 0%, var(--giallo-limone) 100%);
  border: 1px solid var(--sabbia);
}
.home-card-pdj .eyebrow { color: var(--blu-pulcinella); }
.home-card-pdj h2 { color: var(--blu-pulcinella); }
.home-card-pdj p { color: var(--fg-2); }

/* Privatiser card : fond bleu profond avec pattern Dolce Vita */
.home-card-priv {
  background: var(--blu-pulcinella);
  color: var(--crema);
}
.home-card-priv::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('../img/pattern-dolce-vita.png') center/cover;
  opacity: 0.08;
  pointer-events: none;
  z-index: 0;
}
.home-card-priv .eyebrow { color: var(--giallo-sole); }
.home-card-priv h2.white { color: var(--crema); }
.home-card-priv p.white-soft { color: var(--crema); opacity: 0.88; }

@media (max-width: 800px) {
  .home-teasers-grid { grid-template-columns: 1fr; gap: 16px; }
  .home-card { min-height: 260px; }
  .home-card-inner { padding: 28px 24px; }
  .home-card h2 { font-size: 28px; }
  .home-card p { font-size: 15px; }
}

/* ============================================================
 * PAGE D'ATTENTE : 2 cards autonomes (PDJ + Privatiser+form)
 * ============================================================ */

.waiting-cards {
  max-width: 1280px;
  margin: 60px auto;
  padding: 0 20px;
}
.waiting-cards-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: start;
}

.waiting-card {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.waiting-card-head {
  padding: 34px 32px 24px;
  position: relative;
  z-index: 1;
}
.waiting-card-head .eyebrow {
  font-family: var(--font-serif);
  font-size: 11px;
  letter-spacing: var(--tracking-xwide);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.waiting-card-head h2 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 32px;
  line-height: 0.98;
  text-transform: uppercase;
  letter-spacing: var(--tracking-tight);
  margin: 0 0 12px;
}
.waiting-card-head p {
  font-family: var(--font-serif);
  font-size: 15px;
  line-height: 1.55;
  margin: 0;
}

.waiting-card-body {
  padding: 0 32px 32px;
  position: relative;
  z-index: 1;
}

/* ---- Card PDJ : fond cream + giallo ---- */
.waiting-card-pdj {
  background: linear-gradient(160deg, var(--crema) 0%, var(--giallo-limone) 100%);
  border: 1px solid var(--sabbia);
}
.waiting-card-pdj .eyebrow { color: var(--blu-pulcinella); }
.waiting-card-pdj h2 { color: var(--blu-pulcinella); }
.waiting-card-pdj p { color: var(--fg-2); }

/* Sous-cartes formules a l'interieur de la card PDJ */
.waiting-formula {
  background: #fff;
  border: 1px solid var(--sabbia);
  border-radius: var(--r-md);
  padding: 18px 20px;
  margin-bottom: 14px;
}
.waiting-formula:last-child { margin-bottom: 0; }
.waiting-formula.featured {
  background: linear-gradient(180deg, #fff 0%, var(--giallo-limone) 100%);
  border-color: var(--giallo-sole);
  box-shadow: var(--elev-1);
}
.waiting-formula-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 4px;
}
.waiting-formula-head h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 22px;
  color: var(--blu-pulcinella);
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0;
}
.waiting-formula-head .price {
  font-family: var(--font-display-alt);
  font-size: 22px;
  color: var(--blu-pulcinella);
  white-space: nowrap;
}
.waiting-formula-hours {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 13px;
  color: var(--fg-3);
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 1px dashed var(--sabbia);
}
.waiting-formula ul { list-style: none; padding: 0; margin: 0; }
.waiting-formula li {
  font-family: var(--font-sans);
  font-size: 13.5px;
  color: var(--fg-1);
  padding: 3px 0;
  line-height: 1.45;
}
.waiting-formula li::before { content: ". "; color: var(--giallo-sole); font-weight: 700; }

/* ---- Card Privatiser : fond bleu + pattern + formulaire ---- */
.waiting-card-priv {
  background: var(--blu-pulcinella);
  color: var(--crema);
}
.waiting-card-priv::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('../img/pattern-dolce-vita.png') center/cover;
  opacity: 0.08;
  pointer-events: none;
  z-index: 0;
}
.waiting-card-priv .eyebrow { color: var(--giallo-sole); }
.waiting-card-priv .white { color: var(--crema); }
.waiting-card-priv .white-soft { color: var(--crema); opacity: 0.88; }

/* Formulaire dans la card Privatiser */
.waiting-form { display: grid; gap: 12px; }
.waiting-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.waiting-form-field { display: flex; flex-direction: column; gap: 4px; }
.waiting-form-field-wide { grid-column: 1 / -1; }
.waiting-form-field span {
  font-family: var(--font-serif);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(250, 245, 234, 0.78);
}
.waiting-form-field input,
.waiting-form-field select,
.waiting-form-field textarea {
  background: rgba(250, 245, 234, 0.96);
  border: 1px solid transparent;
  border-radius: var(--r-sm);
  padding: 10px 12px;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--fg-1);
}
.waiting-form-field input:focus,
.waiting-form-field select:focus,
.waiting-form-field textarea:focus {
  outline: none;
  border-color: var(--giallo-sole);
  box-shadow: 0 0 0 2px rgba(245, 203, 46, 0.35);
}
.waiting-form .btn-full { margin-top: 6px; }
.waiting-form-groups {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 12.5px;
  color: var(--giallo-limone);
  text-align: center;
  margin: 12px 0 0;
  padding: 10px 12px;
  background: rgba(245, 203, 46, 0.12);
  border-radius: var(--r-sm);
  line-height: 1.45;
}

.waiting-form-success {
  text-align: center;
  padding: 28px 16px;
  color: var(--crema);
}
.waiting-form-success svg { color: var(--giallo-sole); margin-bottom: 10px; }
.waiting-form-success h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 22px;
  color: var(--giallo-sole);
  text-transform: uppercase;
  margin: 6px 0 10px;
}
.waiting-form-success p { color: var(--crema); opacity: 0.9; font-family: var(--font-serif); font-size: 15px; }

@media (max-width: 900px) {
  .waiting-cards-grid { grid-template-columns: 1fr; gap: 18px; }
  .waiting-card-head { padding: 26px 22px 18px; }
  .waiting-card-head h2 { font-size: 26px; }
  .waiting-card-body { padding: 0 22px 24px; }
  .waiting-form-row { grid-template-columns: 1fr; }
}

/* ---- Carte : bouton de téléchargement du PDF ---- */
.carte-pdf-dl {
  display: flex;
  justify-content: center;
  margin: 24px auto 48px;
}
.carte-pdf-dl .btn {
  display: inline-flex;
  align-items: center;
}

/* ---- Wizard 5 étapes (Composer mon panier / Pieds dans l'eau) ---- */
.steps-rail-5 { grid-template-columns: repeat(5, 1fr); }
.pulcinella-wizard-5 .steps-rail-5 .st .lbl { font-size: 10px; letter-spacing: 0.13em; }

.pulc-formula-picker {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin: 8px 0 4px;
}
.pulc-formula-card {
  position: relative;
  display: block;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: var(--r-lg);
  padding: 22px 22px 16px;
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out);
}
.pulc-formula-card input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.pulc-formula-card:hover {
  border-color: var(--blu-pulcinella);
  box-shadow: var(--elev-2);
  transform: translateY(-2px);
}
.pulc-formula-card.featured {
  background: linear-gradient(180deg, #fff 0%, var(--giallo-limone) 100%);
  border-color: var(--giallo-sole);
}
.pulc-formula-card.selected {
  border-color: var(--blu-pulcinella);
  box-shadow: 0 0 0 3px rgba(30, 63, 161, 0.18), var(--elev-2);
}
.pulc-formula-card .formula-tag {
  position: absolute;
  top: -10px; left: 50%;
  transform: translateX(-50%);
  background: var(--giallo-sole);
  color: var(--blu-pulcinella);
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: var(--r-pill);
  white-space: nowrap;
  box-shadow: var(--elev-1);
}
.pulc-formula-card h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 22px;
  color: var(--blu-pulcinella);
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 6px 0 4px;
}
.pulc-formula-card .price {
  font-family: var(--font-display-alt);
  font-size: 26px;
  color: var(--blu-pulcinella);
  margin-bottom: 10px;
}
.pulc-formula-card p {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--fg-2);
  line-height: 1.5;
  margin: 0 0 10px;
}
.pulc-formula-card ul {
  list-style: none; padding: 0; margin: 0;
  border-top: 1px dashed var(--sabbia);
  padding-top: 10px;
}
.pulc-formula-card li {
  font-family: var(--font-serif);
  font-size: 13px;
  color: var(--fg-2);
  padding: 4px 0;
  line-height: 1.4;
}
.pulc-formula-card li::before {
  content: "·"; color: var(--giallo-sole); font-weight: 700; margin-right: 6px;
}
@media (max-width: 900px) {
  .pulc-formula-picker { grid-template-columns: 1fr; }
  .steps-rail-5 { grid-template-columns: repeat(3, 1fr); }
}

/* Type de panier + Options à la carte (étape 1 du wizard pieds) */
.pulc-options-group {
  margin: 28px 0 0;
  padding-top: 24px;
  border-top: 1px dashed var(--sabbia);
}
.pulc-options-label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--blu-pulcinella);
  margin-bottom: 12px;
}
.pulc-options-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.pulc-option-chip {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 10px 18px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: var(--r-pill);
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 600;
  color: var(--fg-2);
  transition: all var(--dur-fast) var(--ease-out);
}
.pulc-option-chip input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.pulc-option-chip:hover {
  border-color: var(--blu-pulcinella);
  color: var(--blu-pulcinella);
}
.pulc-option-chip:has(input:checked) {
  background: var(--blu-pulcinella);
  border-color: var(--blu-pulcinella);
  color: var(--crema);
}

.pulc-extras-list {
  display: grid;
  gap: 10px;
}
.pulc-extra {
  display: grid;
  grid-template-columns: 22px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 12px 16px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.pulc-extra:hover { border-color: var(--blu-pulcinella); }
.pulc-extra input[type="checkbox"] {
  margin: 0;
  width: 18px;
  height: 18px;
  accent-color: var(--blu-pulcinella);
}
.pulc-extra:has(input:checked) {
  background: var(--giallo-limone);
  border-color: var(--giallo-sole);
}
.pulc-extra-label {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  color: var(--fg-1);
}
.pulc-extra-price {
  font-family: var(--font-display-alt);
  font-size: 15px;
  color: var(--blu-pulcinella);
  white-space: nowrap;
}

.carnet {
  position: sticky; top: 100px;
  background: var(--crema); border: 1px solid var(--sabbia);
  border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--elev-2);
}
.carnet-head {
  background: var(--blu-pulcinella); color: var(--crema);
  padding: 18px 22px; text-align: center;
}
.carnet-head .eyebrow { color: var(--giallo-sole); font-size: 11px;}
.carnet-head h3 { font-family: var(--font-display); font-weight: 900; font-size: 20px; text-transform: uppercase; letter-spacing: -0.005em; margin: 4px 0 0; color: var(--giallo-sole);}
.carnet-body { padding: 22px;}
.carnet-row {
  display: grid; gap: 4px; padding: 12px 0;
  border-bottom: 1.5px dotted rgba(30,63,161,0.18);
}
.carnet-row:last-of-type { border-bottom: none;}
.carnet-row .lbl { font-family: var(--font-serif); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-3);}
.carnet-row .val { font-family: var(--font-display-alt); font-size: 20px; color: var(--blu-pulcinella); line-height: 1.2;}
.carnet-row .val.muted { color: var(--fg-3); font-style: italic; font-size: 15px;}
.carnet-note { font-family: var(--font-serif); font-style: italic; font-size: 12.5px; color: var(--fg-2); line-height: 1.5; margin-top: 14px; padding-top: 14px; border-top: 1px dashed var(--sabbia);}

.ticket {
  background: var(--crema); border-radius: var(--r-lg);
  position: relative; padding: 40px; text-align: center;
  border: 1px solid var(--sabbia);
}
.ticket .pic-wrap { width: 70px; height: 70px; border-radius: 50%; background: var(--giallo-sole); display: grid; place-items: center; margin: 0 auto 16px;}
.ticket .pic-wrap img { width: 56px;}
.ticket .eyebrow { color: var(--blu-pulcinella);}
.ticket h2 { font-family: var(--font-display); font-weight: 900; font-size: 40px; color: var(--blu-pulcinella); text-transform: uppercase; letter-spacing: -0.01em; margin: 8px 0 6px; line-height: 0.95;}
.ticket h2 em { font-family: var(--font-display-alt); font-weight: 400; font-style: italic; text-transform: none;}
.ticket p { font-family: var(--font-serif); font-style: italic; font-size: 15px; color: var(--fg-2); max-width: 480px; margin: 0 auto;}
.ticket-meta {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  margin: 26px auto 22px; max-width: 560px;
  border-top: 1.5px dashed var(--sabbia); border-bottom: 1.5px dashed var(--sabbia);
  padding: 16px 0;
}
.ticket-meta > div { display: grid; gap: 4px; border-right: 1.5px dashed var(--sabbia); padding: 0 12px;}
.ticket-meta > div:last-child { border-right: none;}
.ticket-meta .lbl { font-family: var(--font-serif); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-3);}
.ticket-meta .val { font-family: var(--font-display-alt); font-size: 22px; color: var(--blu-pulcinella);}
.ticket-num { font-family: var(--font-serif); font-style: italic; font-size: 12px; color: var(--fg-3); letter-spacing: 0.16em; margin-top: 18px;}

/* ====================================================================
   RESPONSIVE — tablet (≤1024) and mobile (≤640)
   ==================================================================== */

/* --- Burger button (hidden on desktop) --- */
.nav-burger {
  display: none;
  background: transparent; border: none; cursor: pointer;
  width: 40px; height: 40px; padding: 8px;
  flex-direction: column; justify-content: center; gap: 5px;
}
.nav-burger span {
  display: block; width: 22px; height: 2px;
  background: var(--blu-pulcinella); border-radius: 2px;
  transition: transform var(--dur-base) var(--ease-out), opacity var(--dur-base);
}
.nav-open .nav-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg);}
.nav-open .nav-burger span:nth-child(2) { opacity: 0;}
.nav-open .nav-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg);}

/* ============== TABLET — ≤ 1024px ============== */
@media (max-width: 1024px) {
  /* Hero */
  .hero { padding: 64px 40px 48px; min-height: 480px; margin: 16px;}
  .hero-meta { gap: 20px; margin-top: 40px;}

  /* Page hero */
  .page-hero { min-height: 420px;}
  .page-hero-left { padding: 48px 36px;}

  /* Ambiance */
  .ambiance { margin: 72px auto;}
  .ambiance-grid { height: auto; grid-template-columns: 1.2fr 1fr;}
  .ambiance-img.tall { min-height: 360px;}
  .ambiance-quote { padding: 22px;}
  .ambiance-quote .q { font-size: 22px;}

  /* Pieds */
  .pieds { padding: 56px 40px; gap: 40px; grid-template-columns: 1.1fr 0.9fr;}
  .pieds h2 { font-size: 44px;}
  .pieds-meta { gap: 22px;}

  /* Events */
  .events-row { grid-template-columns: repeat(2, 1fr);}

  /* Footer */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px;}

  /* Reservation home form */
  .reserv { padding: 36px 32px;}
  .reserv-grid { grid-template-columns: repeat(2, 1fr);}

  /* Carte page */
  .menu-list { grid-template-columns: 1fr; gap: 0;}

  /* Pieds page formulas + process */
  .formula-grid { grid-template-columns: 1fr;}
  .process-row { grid-template-columns: repeat(2, 1fr); gap: 32px;}

  /* Reservation page */
  .reserv-shell { grid-template-columns: 1fr; gap: 24px;}
  .carnet { position: static;}
  .reserv-main { padding: 28px 28px;}
  .hours-grid { grid-template-columns: repeat(4, 1fr);}

  /* Contact page */
  .contact-grid { grid-template-columns: 1fr; gap: 24px;}
  .postcard { position: static;}
  .postmark { right: 40px; top: 130px;}

  /* Events page */
  .evt-card { grid-template-columns: 100px 1fr auto; gap: 20px; padding: 20px 22px;}
}

/* ============== MOBILE — ≤ 640px ============== */
@media (max-width: 640px) {
  body { font-size: 15px;}

  /* --- Nav becomes hamburger --- */
  .nav { padding: 0 12px; margin-top: 10px;}
  .nav-inner {
    grid-template-columns: 1fr auto;
    padding: 8px 10px 8px 14px; gap: 8px;
    position: relative;
  }
  .nav-brand img { height: 32px;}
  .nav-burger { display: flex;}
  /* hide the "Réserver" pill button on mobile — it lives in the drawer */
  .nav-inner > .btn { display: none;}

  .nav-links {
    position: absolute; top: calc(100% + 10px); left: 0; right: 0;
    flex-direction: column; gap: 0;
    background: rgba(250, 245, 234, 0.96);
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    border: 1px solid var(--border-soft);
    border-radius: 18px;
    padding: 12px 4px;
    font-size: 14px; letter-spacing: 0.14em;
    box-shadow: var(--elev-3);
    /* hidden by default */
    opacity: 0; visibility: hidden; transform: translateY(-8px);
    transition: opacity var(--dur-base), transform var(--dur-base), visibility 0s linear var(--dur-base);
  }
  .nav-open .nav-links {
    opacity: 1; visibility: visible; transform: translateY(0);
    transition: opacity var(--dur-base), transform var(--dur-base), visibility 0s;
  }
  .nav-links li { width: 100%; text-align: center;}
  .nav-links a { display: block; padding: 12px 16px;}
  .nav-links a:hover::after { display: none;}

  /* --- Hero --- */
  .hero {
    margin: 12px; padding: 56px 22px 40px;
    min-height: auto; border-radius: 20px;
  }
  .hero-title { font-size: clamp(36px, 11vw, 60px); line-height: 0.95;}
  .hero-sub { font-size: 16px; margin: 18px 0 26px; max-width: 100%;}
  .hero-ctas { flex-direction: column; align-items: stretch; gap: 14px;}
  .hero-ctas .btn { width: 100%; justify-content: center;}
  .hero-link { justify-content: center;}
  .hero-meta { flex-direction: column; gap: 10px; margin-top: 32px; font-size: 12px;}

  /* --- Page hero --- */
  .page-hero {
    grid-template-columns: 1fr; min-height: auto;
    margin: 12px; border-radius: 20px;
  }
  .page-hero-left { padding: 40px 24px 36px;}
  .page-hero-title { font-size: clamp(40px, 11vw, 68px);}
  .page-hero-sub { font-size: 16px;}
  .page-hero-right { min-height: 240px;}
  .page-hero-tape { width: 64px; height: 64px; top: 16px; right: 16px;}

  /* --- Section heads --- */
  .section-head { margin: 0 16px 36px;}
  .section-head h2 { font-size: 38px;}

  /* --- Ambiance --- */
  .ambiance { margin: 56px auto; padding: 0 12px;}
  .ambiance-grid { grid-template-columns: 1fr; gap: 12px;}
  .ambiance-img { min-height: 220px;}
  .ambiance-quote { padding: 20px;}
  .ambiance-quote .q { font-size: 20px;}

  /* --- Reservation home block --- */
  .reserv {
    margin: 56px 12px; padding: 28px 20px;
    border-radius: 20px;
  }
  .reserv-head h2 { font-size: 30px;}
  .reserv-grid { grid-template-columns: 1fr; gap: 14px;}
  .reserv-done { padding: 56px 24px;}
  .reserv-done h3 { font-size: 28px;}

  /* --- Carte (home preview) --- */
  .carte { margin: 64px auto; padding: 0 16px;}
  .dish { padding: 20px 4px;}
  .dish-row { flex-wrap: wrap; gap: 6px;}
  .dish-row h3 { font-size: 24px;}
  .dish-price { font-size: 22px;}
  .dish-dots { display: none;}
  .dish p { max-width: 100%; font-size: 13.5px;}

  /* --- Pieds dans l'eau home --- */
  .pieds {
    margin: 56px 12px; padding: 48px 24px;
    grid-template-columns: 1fr; gap: 32px;
    border-radius: 20px;
  }
  .pieds h2 { font-size: 34px;}
  .white-soft { font-size: 16px; max-width: 100%;}
  .pieds-list { grid-template-columns: 1fr; gap: 8px;}
  .pieds-meta {
    grid-template-columns: 1fr 1fr; gap: 16px;
    padding: 14px 0;
  }
  .pieds-meta > div:nth-child(3) { grid-column: span 2;}
  .pieds-card-time { font-size: 40px;}
  .formula-grid{display: flex;flex-direction: column;}

  /* --- Events row --- */
  .events { margin: 64px auto; padding: 0 16px;}
  .events-row { grid-template-columns: 1fr; gap: 12px;}

  /* --- Footer --- */
  .footer { padding: 56px 20px 24px; margin-top: 64px;}
  .footer-grid { grid-template-columns: 1fr; gap: 32px;}
  .footer-bottom {
    flex-direction: column; gap: 10px; align-items: flex-start;
    margin-top: 36px;
  }
  .footer-logo { height: 48px;}

  /* --- Page section padding --- */
  .page-section { margin: 56px auto; padding: 0 16px;}
  .page-section .lead { font-size: 16px; margin-bottom: 36px;}

  /* --- Carte page (menu sections) --- */
  .menu-section-head { grid-template-columns: 1fr; gap: 4px;}
  .menu-section-head .rule { display: none;}
  .menu-section-head h2 { font-size: 26px;}

  /* --- Pieds page --- */
  .formula { padding: 24px;}
  .formula h3 { font-size: 24px;}
  .formula .price { font-size: 30px;}
  .process-row { grid-template-columns: 1fr; gap: 24px;}
  .step .n { font-size: 56px;}

  /* --- Events page --- */
  .evt-card {
    grid-template-columns: 1fr; gap: 16px;
    padding: 20px;
  }
  .evt-date { justify-self: start; width: 84px; padding: 10px;}
  .evt-date .d { font-size: 30px;}
  .evt-body h3 { font-size: 20px;}
  .evt-cta { flex-direction: row; align-items: center; justify-content: space-between; width: 100%;}
  .evt-categories { gap: 6px; margin-bottom: 32px;}
  .evt-chip { padding: 7px 14px; font-size: 12px;}

  /* --- Contact page --- */
  .contact-grid { margin: 56px auto; padding: 0 12px;}
  .chalkboard { padding: 22px; border-width: 6px;}
  .chalkboard h2 { font-size: 28px;}
  .contact-cards { grid-template-columns: 1fr;}
  .find-card { padding: 22px;}
  .postcard { padding: 28px 22px 24px;}
  .postcard::before { inset: 8px;}
  .postcard-head h2 { font-size: 28px;}
  .postcard-stamp { width: 58px; height: 70px;}
  .postmark { width: 78px; height: 78px; top: 88px; right: 24px; font-size: 8px;}
  .pc-row { grid-template-columns: 1fr; gap: 12px;}
  .pc-submit { width: 100%; text-align: center;}

  /* --- Reservation page wizard --- */
  .reserv-shell { margin: 40px auto 56px; padding: 0 12px;}
  .reserv-main { padding: 22px 18px; border-radius: 18px;}
  .step-head h2 { font-size: 26px;}
  .steps-rail { grid-template-columns: repeat(2, 1fr); gap: 4px;}
  .steps-rail .st { padding: 10px 4px;}
  .steps-rail .st .lbl { font-size: 10px; letter-spacing: 0.12em;}
  .month-head .m { font-size: 22px;}
  .weekdays div { font-size: 9px;}
  .dcell { padding: 4px;}
  .dcell .num { font-size: 16px;}
  .dcell .dot { width: 4px; height: 4px;}
  .legend { font-size: 10px; gap: 10px;}
  .hours-grid { grid-template-columns: repeat(3, 1fr); gap: 6px;}
  .hslot { font-size: 15px; padding: 10px 4px;}
  .convives-row { max-width: 100%;}
  .convives-row .display .n { font-size: 38px;}
  .form-grid { grid-template-columns: 1fr; gap: 14px;}
  .form-grid .full { grid-column: span 1;}
  .wizard-foot { flex-direction: column-reverse; gap: 14px; align-items: stretch;}
  .wizard-foot .btn { width: 100%; justify-content: center;}

  /* Ticket confirmation */
  .ticket { padding: 32px 22px;}
  .ticket h2 { font-size: 30px;}
  .ticket-meta {
    grid-template-columns: 1fr; gap: 12px;
    border-top: none; border-bottom: none;
    padding: 0;
  }
  .ticket-meta > div {
    border-right: none;
    border-bottom: 1.5px dashed var(--sabbia);
    padding: 8px 0;
  }
  .ticket-meta > div:last-child { border-bottom: none;}
}

/* ============== EXTRA-NARROW — ≤ 380px ============== */
@media (max-width: 380px) {
  .hero { padding: 48px 18px 32px;}
  .hero-title { font-size: 34px;}
  .nav-brand img { height: 28px;}
  .page-hero-title { font-size: 38px;}
  .hours-grid { grid-template-columns: repeat(2, 1fr);}
  .dcell .num { font-size: 14px;}
}
