/* =====================================================
   LUTÈCE STUDIO — Feuille de style
   Palette chaude & premium : noir, crème, terracotta, or
   ===================================================== */

/* ---------- Variables ---------- */
:root {
  --noir: #14110d;
  --charbon: #1f1a14;
  --charbon-2: #2a231b;
  --creme: #f7f1e7;
  --creme-2: #efe4d3;
  --terracotta: #c2613a;
  --terracotta-fonce: #a44e2c;
  --olive: #5f6648;
  --or: #c9a35c;
  --or-clair: #e0c189;
  --texte: #2b2520;
  --texte-doux: #6f6557;
  --texte-clair: #d8cdbb;

  --serif: 'Fraunces', Georgia, 'Times New Roman', serif;
  --sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --max: 1180px;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow: 0 20px 50px -20px rgba(20, 17, 13, 0.35);
  --shadow-soft: 0 12px 30px -16px rgba(20, 17, 13, 0.25);
  --trans: 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--sans);
  color: var(--texte);
  background: var(--creme);
  line-height: 1.65;
  font-size: 17px;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

::selection { background: var(--terracotta); color: #fff; }

/* ---------- Conteneur ---------- */
.container { width: 100%; max-width: var(--max); margin: 0 auto; padding: 0 24px; }
.container--narrow { max-width: 820px; }

/* ---------- Typographie ---------- */
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 500; line-height: 1.12; letter-spacing: -0.01em; }
em { font-style: italic; }

/* ---------- Boutons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px; padding: 15px 30px; border-radius: 100px;
  font-family: var(--sans); font-weight: 600; font-size: 15px;
  letter-spacing: 0.01em; cursor: pointer; border: none;
  transition: transform var(--trans), box-shadow var(--trans), background var(--trans), color var(--trans);
  text-align: center;
}
.btn--primary {
  background: var(--terracotta); color: #fff;
  box-shadow: 0 10px 24px -10px rgba(194, 97, 58, 0.7);
}
.btn--primary:hover { background: var(--terracotta-fonce); transform: translateY(-2px); box-shadow: 0 16px 30px -12px rgba(194, 97, 58, 0.8); }
.btn--ghost {
  background: transparent; color: #fff;
  border: 1.5px solid rgba(255,255,255,0.5);
}
.btn--ghost:hover { background: rgba(255,255,255,0.12); border-color: #fff; transform: translateY(-2px); }
.btn--block { width: 100%; }

/* =====================================================
   EN-TÊTE
   ===================================================== */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 22px 0; transition: padding var(--trans), background var(--trans), box-shadow var(--trans), transform var(--trans);
}
.site-header.is-hidden { transform: translateY(-100%); }
.site-header.scrolled {
  padding: 12px 0; background: rgba(247, 241, 231, 0.92);
  backdrop-filter: blur(12px); box-shadow: 0 1px 0 rgba(0,0,0,0.06);
}
.header__inner { display: flex; align-items: center; justify-content: space-between; }

/* Logo */
.logo { display: flex; align-items: center; gap: 11px; }
.logo__mark {
  width: 38px; height: 38px; border-radius: 10px;
  background: var(--noir); color: var(--or);
  display: grid; place-items: center;
  font-family: var(--serif); font-size: 24px; font-weight: 600;
  flex-shrink: 0;
}
.logo__text {
  font-family: var(--serif); font-size: 21px; font-weight: 600;
  color: #fff; letter-spacing: 0.01em; transition: color var(--trans);
}
.logo__accent { color: var(--or); margin-left: 5px; }
.scrolled .logo__text { color: var(--noir); }

/* Navigation */
.nav { display: flex; align-items: center; gap: 30px; }
.nav__link {
  font-size: 15px; font-weight: 500; color: #fff;
  position: relative; transition: color var(--trans);
}
.nav__link::after {
  content: ''; position: absolute; left: 0; bottom: -5px;
  width: 0; height: 2px; background: var(--terracotta); transition: width var(--trans);
}
.nav__link:hover::after { width: 100%; }
.scrolled .nav__link { color: var(--texte); }
.nav__cta {
  background: var(--terracotta); color: #fff;
  padding: 11px 22px; border-radius: 100px;
  font-size: 14px; font-weight: 600;
  transition: background var(--trans), transform var(--trans);
}
.nav__cta:hover { background: var(--terracotta-fonce); transform: translateY(-2px); }

/* Case « Parrainage » : pastille dorée mise en avant */
.nav__parrain {
  display: inline-flex; align-items: center; gap: 6px;
  border: 1.5px solid var(--or); background: rgba(201,163,92,0.14);
  color: var(--or-clair); border-radius: 100px; padding: 6px 14px; font-weight: 600;
  transition: background var(--trans), color var(--trans), transform var(--trans);
}
.nav__parrain::after { display: none; }
.nav__parrain .icon { width: 15px; height: 15px; }
.nav__parrain:hover { background: var(--or); color: var(--noir); transform: translateY(-2px); }
.scrolled .nav__parrain, .site-header--solid .nav__parrain { color: var(--or); }
.scrolled .nav__parrain:hover, .site-header--solid .nav__parrain:hover { color: var(--noir); }

/* Burger mobile */
.nav-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 8px; }
.nav-toggle span { width: 26px; height: 2px; background: #fff; border-radius: 2px; transition: var(--trans); }
.scrolled .nav-toggle span { background: var(--noir); }
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* =====================================================
   1. HERO
   ===================================================== */
.hero {
  position: relative; min-height: 100vh; min-height: 100svh;
  display: flex; align-items: center;
  color: #fff; overflow: hidden;
}
.hero__bg {
  position: absolute; inset: 0;
  background-color: var(--noir);
  background-image: url('https://images.unsplash.com/photo-1517248135467-4c7edcad34c4?auto=format&fit=crop&w=1920&q=80');
  background-size: cover; background-position: center;
  transform: scale(1.05); animation: heroZoom 14s ease-out forwards;
}
@keyframes heroZoom { to { transform: scale(1.16); } }
.hero__overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(to top, rgba(20,17,13,0.92) 0%, rgba(20,17,13,0.45) 45%, rgba(20,17,13,0.65) 100%);
}
.hero__inner { position: relative; z-index: 2; padding: 120px 24px; max-width: 920px; }
.hero__eyebrow {
  text-transform: uppercase; letter-spacing: 0.22em; font-size: 13px;
  font-weight: 600; color: var(--or-clair); margin-bottom: 22px;
}
.hero__title { font-size: clamp(2.5rem, 6.5vw, 5rem); font-weight: 500; margin-bottom: 26px; }
.hero__title em { color: var(--or-clair); }
.hero__subtitle {
  font-size: clamp(1.05rem, 2vw, 1.3rem); max-width: 640px;
  color: var(--texte-clair); margin-bottom: 38px; font-weight: 400;
}
.hero__actions { display: flex; flex-wrap: wrap; gap: 16px; margin-bottom: 40px; }
.hero__contact { font-size: 15px; color: var(--texte-clair); display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.hero__contact a { transition: color var(--trans); font-weight: 500; }
.hero__contact a:hover { color: var(--or-clair); }
.hero__sep { opacity: 0.5; }
.hero__scroll {
  position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%);
  width: 26px; height: 42px; border: 2px solid rgba(255,255,255,0.5);
  border-radius: 20px; z-index: 2;
}
.hero__scroll span {
  position: absolute; top: 8px; left: 50%; transform: translateX(-50%);
  width: 4px; height: 8px; background: #fff; border-radius: 2px;
  animation: scrollDot 1.8s infinite;
}
@keyframes scrollDot { 0% { opacity: 1; top: 8px; } 70% { opacity: 0; top: 22px; } 100% { opacity: 0; } }

/* =====================================================
   SECTIONS GÉNÉRIQUES
   ===================================================== */
.section { padding: 110px 0; }
.section--cream { background: var(--creme-2); }
.section--dark { background: var(--noir); color: var(--creme); }

.section__head { max-width: 720px; margin: 0 auto 64px; text-align: center; }
.section__eyebrow {
  text-transform: uppercase; letter-spacing: 0.2em; font-size: 13px;
  font-weight: 600; color: var(--terracotta); margin-bottom: 16px;
}
.section__eyebrow--gold { color: var(--or); }
.section__title { font-size: clamp(1.9rem, 4vw, 3rem); margin-bottom: 20px; }
.section__title em { color: var(--terracotta); }
.section--dark .section__title em { color: var(--or-clair); }
.section__lead { font-size: 1.12rem; color: var(--texte-doux); }
.section--dark .section__lead { color: var(--texte-clair); }

/* ---------- 2. Statistiques ---------- */
.stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
  margin-bottom: 70px;
}
.stat {
  background: #fff; border-radius: var(--radius); padding: 34px 24px;
  text-align: center; box-shadow: var(--shadow-soft);
}
.stat__num { font-family: var(--serif); font-size: 3.2rem; font-weight: 600; color: var(--terracotta); line-height: 1; }
.stat__suffix { font-family: var(--serif); font-size: 2rem; color: var(--terracotta); }
.stat__label { font-size: 0.95rem; color: var(--texte-doux); margin-top: 12px; }

.problem-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.problem-card {
  padding: 32px; border-radius: var(--radius); background: #fff;
  border-left: 4px solid var(--terracotta); box-shadow: var(--shadow-soft);
}
.problem-card h3 { font-size: 1.3rem; margin-bottom: 12px; }
.problem-card p { color: var(--texte-doux); }

/* ---------- 3. Services ---------- */
.services { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.service {
  padding: 34px 28px; border-radius: var(--radius); background: #fff;
  border: 1px solid rgba(20,17,13,0.06); transition: transform var(--trans), box-shadow var(--trans);
}
.service:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.service__icon {
  width: 58px; height: 58px; border-radius: 14px; display: grid; place-items: center;
  background: var(--creme-2); font-size: 28px; margin-bottom: 20px;
}
.service h3 { font-size: 1.25rem; margin-bottom: 10px; }
.service p { color: var(--texte-doux); font-size: 0.97rem; }

/* ---------- 4. Réalisations ---------- */
.works { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.work {
  display: block; text-align: left; cursor: pointer;
  background: var(--charbon); border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius); overflow: hidden; padding: 0; color: var(--creme);
  font-family: inherit; transition: transform var(--trans), box-shadow var(--trans), border-color var(--trans);
}
.work:hover { transform: translateY(-8px); box-shadow: 0 30px 60px -25px rgba(0,0,0,0.6); border-color: var(--or); }
.work__img { height: 220px; background-size: cover; background-position: center; position: relative; }
.work__img::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(20,17,13,0.5), transparent 60%); }
.work__img--pizzeria { background-color: #7a3b25; background-image: url('https://images.unsplash.com/photo-1513104890138-7c749659a591?auto=format&fit=crop&w=900&q=80'); }
.work__img--gastro { background-color: #1b1b1b; background-image: url('https://images.unsplash.com/photo-1600891964599-f61ba0e24092?auto=format&fit=crop&w=900&q=80'); }
.work__img--bistrot { background-color: #5a4a32; background-image: url('https://images.unsplash.com/photo-1559339352-11d035aa65de?auto=format&fit=crop&w=900&q=80'); }
.work__body { padding: 26px; }
.work__tag {
  display: inline-block; font-size: 12px; text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--or-clair); margin-bottom: 12px; font-weight: 600;
}
.work__name { font-size: 1.6rem; margin-bottom: 8px; color: #fff; }
.work__desc { font-size: 0.95rem; color: var(--texte-clair); margin-bottom: 18px; }
.work__link { font-size: 0.92rem; font-weight: 600; color: var(--terracotta); transition: gap var(--trans); }
.work:hover .work__link { color: var(--or-clair); }
.works__note { text-align: center; margin-top: 40px; font-size: 0.9rem; color: var(--texte-clair); opacity: 0.7; }

/* ---------- 5. Fonctionnalités ---------- */
.features { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.feature {
  display: flex; align-items: center; gap: 14px;
  padding: 22px 24px; background: #fff; border-radius: var(--radius-sm);
  box-shadow: var(--shadow-soft); font-weight: 600; font-size: 1rem;
  color: var(--texte); transition: transform var(--trans);
}
.feature:hover { transform: translateY(-4px); }
.feature__ico { font-size: 24px; color: var(--terracotta); display: inline-flex; }
.feature__ico .icon { width: 24px; height: 24px; }

/* ---------- 6. Pourquoi nous ---------- */
.why { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.why__card {
  padding: 40px; border-radius: var(--radius); background: var(--creme-2);
  position: relative; overflow: hidden;
}
.why__num {
  font-family: var(--serif); font-size: 3.5rem; color: var(--terracotta);
  opacity: 0.3; line-height: 1; margin-bottom: 14px; font-weight: 600;
}
.why__card h3 { font-size: 1.45rem; margin-bottom: 12px; }
.why__card p { color: var(--texte-doux); }

/* ---------- 7. Offre ---------- */
.offer {
  display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 0;
  max-width: 920px; margin: 0 auto; border-radius: var(--radius);
  overflow: hidden; box-shadow: 0 30px 70px -30px rgba(0,0,0,0.6);
}
.offer__main {
  background: linear-gradient(160deg, var(--terracotta), var(--terracotta-fonce));
  color: #fff; padding: 50px 40px; display: flex; flex-direction: column; justify-content: center;
}
.offer__badge {
  display: inline-block; align-self: flex-start; background: rgba(255,255,255,0.18);
  padding: 7px 16px; border-radius: 100px; font-size: 13px; font-weight: 600;
  letter-spacing: 0.04em; margin-bottom: 26px;
}
.offer__price { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; margin-bottom: 8px; }
.offer__from { font-size: 0.95rem; opacity: 0.85; width: 100%; }
.offer__amount { font-family: var(--serif); font-size: 4rem; font-weight: 600; line-height: 1; }
.offer__period { font-size: 1.1rem; opacity: 0.9; }
.offer__note { font-size: 0.92rem; opacity: 0.9; margin: 14px 0 28px; }
.offer__list { background: var(--charbon); color: var(--creme); padding: 50px 44px; display: grid; gap: 16px; align-content: center; }
.offer__list li { font-size: 1.02rem; padding-left: 4px; }
.offer__compare {
  text-align: center; max-width: 640px; margin: 44px auto 0;
  font-size: 1.05rem; color: var(--texte-clair);
}
.offer__compare strong { color: var(--or-clair); }
.offer__cta { text-align: center; margin-top: 30px; display: flex; flex-direction: column; align-items: center; gap: 10px; }
.offer__cta .btn { padding: 17px 44px; font-size: 1rem; }
.offer__cta-note { font-size: 0.85rem; color: var(--texte-clair); opacity: 0.75; }

/* ---------- 8. Process ---------- */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; counter-reset: step; }
.step { text-align: center; position: relative; padding: 0 10px; }
.step__num {
  width: 64px; height: 64px; margin: 0 auto 22px; border-radius: 50%;
  background: var(--noir); color: var(--or); display: grid; place-items: center;
  font-family: var(--serif); font-size: 1.7rem; font-weight: 600;
}
.step h3 { font-size: 1.3rem; margin-bottom: 10px; }
.step p { color: var(--texte-doux); font-size: 0.97rem; }
/* trait reliant les étapes (desktop) */
.steps .step:not(:last-child)::after {
  content: ''; position: absolute; top: 32px; left: calc(50% + 42px); right: calc(-50% + 42px);
  height: 2px; background: repeating-linear-gradient(90deg, var(--terracotta) 0 6px, transparent 6px 12px);
  opacity: 0.4;
}

/* ---------- 9. FAQ ---------- */
.faq { display: grid; gap: 14px; }
.faq__item {
  background: var(--creme-2); border-radius: var(--radius-sm);
  padding: 4px 26px; transition: background var(--trans);
}
.faq__item summary {
  list-style: none; cursor: pointer; padding: 22px 0;
  font-family: var(--serif); font-size: 1.2rem; font-weight: 500;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::after {
  content: '+'; font-size: 1.6rem; color: var(--terracotta);
  transition: transform var(--trans); flex-shrink: 0; line-height: 1;
}
.faq__item[open] summary::after { transform: rotate(45deg); }
.faq__item p { padding-bottom: 24px; color: var(--texte-doux); max-width: 90%; }

/* ---------- 10. Contact ---------- */
.contact { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }
.contact__coords { margin-top: 36px; display: grid; gap: 18px; }
.contact__coords li { display: flex; align-items: center; gap: 14px; font-size: 1.1rem; }
.contact__ico {
  width: 44px; height: 44px; border-radius: 12px; background: var(--charbon);
  display: grid; place-items: center; font-size: 20px; flex-shrink: 0;
}
.contact__coords a { transition: color var(--trans); font-weight: 500; }
.contact__coords a:hover { color: var(--or-clair); }

.contact__form {
  background: var(--charbon); padding: 40px; border-radius: var(--radius);
  display: grid; gap: 18px; box-shadow: var(--shadow);
}
.field { display: grid; gap: 7px; }
.field label { font-size: 0.88rem; font-weight: 600; color: var(--texte-clair); letter-spacing: 0.02em; }
.field input, .field textarea {
  font-family: var(--sans); font-size: 1rem; padding: 14px 16px;
  border-radius: var(--radius-sm); border: 1.5px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04); color: #fff; transition: border-color var(--trans), background var(--trans);
  resize: vertical;
}
.field input::placeholder, .field textarea::placeholder { color: rgba(216,205,187,0.4); }
.field__opt { font-weight: 400; color: rgba(216,205,187,0.55); }
.field__hint { font-size: 0.8rem; color: rgba(216,205,187,0.7); margin-top: 1px; }
.field__hint a { color: var(--or-clair); text-decoration: underline; }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--or); background: rgba(255,255,255,0.08); }
.contact__formnote { font-size: 0.9rem; min-height: 1.2em; text-align: center; }
.contact__formnote.ok { color: var(--or-clair); }
.contact__formnote.err { color: #f0a98c; }

/* =====================================================
   FOOTER
   ===================================================== */
.footer { background: var(--noir); color: var(--texte-clair); padding-top: 64px; }
.footer__inner { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 40px; padding-bottom: 50px; }
.logo--footer .logo__text { color: #fff; }
.footer__brand p { margin-top: 18px; max-width: 320px; font-size: 0.95rem; }
.footer h4 { font-family: var(--sans); font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--or); margin-bottom: 18px; }
.footer__nav, .footer__contact { display: grid; gap: 11px; align-content: start; }
.footer__nav a, .footer__contact a, .footer__contact span { font-size: 0.97rem; color: var(--texte-clair); transition: color var(--trans); }
.footer__nav a:hover, .footer__contact a:hover { color: var(--or-clair); }
.footer__bottom { border-top: 1px solid rgba(255,255,255,0.1); padding: 24px 0; }
.footer__bottom .container { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.footer__bottom p { font-size: 0.85rem; opacity: 0.6; }

/* =====================================================
   MODALE D'APERÇU (réalisations)
   ===================================================== */
.modal { position: fixed; inset: 0; z-index: 300; display: none; }
.modal.open { display: block; }
.modal__backdrop { position: absolute; inset: 0; background: rgba(10,8,6,0.7); backdrop-filter: blur(4px); animation: fade 0.3s; }
.modal__dialog {
  position: relative; max-width: 720px; width: calc(100% - 32px); max-height: 90vh;
  margin: 5vh auto 0; background: #fff; border-radius: var(--radius);
  overflow: hidden auto; box-shadow: 0 40px 90px -20px rgba(0,0,0,0.7);
  animation: pop 0.4s cubic-bezier(0.22,1,0.36,1);
}
.modal__close {
  position: absolute; top: 14px; right: 14px; z-index: 5;
  width: 40px; height: 40px; border-radius: 50%; border: none; cursor: pointer;
  background: rgba(255,255,255,0.9); color: var(--noir); font-size: 26px; line-height: 1;
  display: grid; place-items: center; transition: var(--trans);
}
.modal__close:hover { background: #fff; transform: rotate(90deg); }
@keyframes fade { from { opacity: 0; } }
@keyframes pop { from { opacity: 0; transform: translateY(30px); } }

/* --- Mini-site dans la modale --- */
.demo__hero { height: 260px; background-size: cover; background-position: center; position: relative; display: flex; align-items: flex-end; padding: 30px; color: #fff; }
.demo__hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.75), rgba(0,0,0,0.15)); }
.demo__hero-content { position: relative; z-index: 2; }
.demo__cuisine { font-size: 12px; text-transform: uppercase; letter-spacing: 0.18em; opacity: 0.9; }
.demo__title { font-family: var(--serif); font-size: 2.4rem; margin: 6px 0; }
.demo__tag { font-size: 0.95rem; opacity: 0.9; }
.demo__body { padding: 32px; }
.demo__section-title { font-family: var(--serif); font-size: 1.4rem; margin-bottom: 16px; padding-bottom: 8px; border-bottom: 2px solid var(--creme-2); }
.demo__menu { display: grid; gap: 14px; margin-bottom: 28px; }
.demo__dish { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.demo__dish-name { font-weight: 600; }
.demo__dish-desc { font-size: 0.85rem; color: var(--texte-doux); display: block; font-weight: 400; }
.demo__dish-dots { flex: 1; border-bottom: 1px dotted #cbbfa9; margin: 0 4px; transform: translateY(-4px); }
.demo__dish-price { font-family: var(--serif); font-weight: 600; color: var(--terracotta); white-space: nowrap; }
.demo__info { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 26px; }
.demo__info div { background: var(--creme); padding: 16px; border-radius: 10px; font-size: 0.9rem; }
.demo__info strong { display: block; font-family: var(--serif); margin-bottom: 4px; font-size: 1rem; }
.demo__gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 26px; }
.demo__gallery div { aspect-ratio: 1; border-radius: 8px; background-size: cover; background-position: center; }
.demo__cta { text-align: center; padding: 24px; border-radius: 12px; background: var(--noir); color: #fff; }
.demo__cta h4 { font-family: var(--serif); font-size: 1.3rem; margin-bottom: 14px; color: #fff; }
.demo__cta .btn { background: var(--terracotta); color: #fff; }
.demo__disclaimer { text-align: center; font-size: 0.8rem; color: var(--texte-doux); padding: 0 32px 24px; }

/* Thème gastro (sombre/doré) */
.demo--gastro .demo__title, .demo--gastro .demo__section-title { letter-spacing: 0.02em; }
.demo--gastro .demo__dish-price { color: var(--or); }
.demo--gastro .demo__cta { background: linear-gradient(135deg, #1a1a1a, #2d2417); }
.demo--gastro .demo__cta .btn { background: var(--or); color: var(--noir); }

/* =====================================================
   ANIMATIONS AU SCROLL
   ===================================================== */
.reveal {
  opacity: 0; transform: translateY(30px); filter: blur(5px);
  transition: opacity 0.8s ease, transform 0.9s cubic-bezier(0.22,1,0.36,1), filter 0.8s ease;
}
.reveal.visible { opacity: 1; transform: none; filter: none; }

/* Transitions de page (entrée + sortie en fondu) */
main { animation: pageInUp 0.55s cubic-bezier(0.22,1,0.36,1) both; }
@keyframes pageInUp { from { opacity: 0; transform: translateY(14px); } }
body.is-leaving { opacity: 0; transition: opacity 0.28s ease; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; filter: none; transition: none; }
  .hero__bg { animation: none; }
  main { animation: none; }
  body.is-leaving { transition: none; }
  html { scroll-behavior: auto; }
}

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media (max-width: 1024px) {
  .stats, .services, .features { grid-template-columns: repeat(2, 1fr); }
  .works { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }
  .steps { grid-template-columns: repeat(2, 1fr); gap: 40px 26px; }
  .steps .step::after { display: none; }
}

@media (max-width: 760px) {
  body { font-size: 16px; }
  .section { padding: 76px 0; }
  .section__head { margin-bottom: 44px; }

  /* Nav mobile */
  .nav {
    position: fixed; inset: 0 0 0 auto; width: min(80vw, 320px);
    flex-direction: column; justify-content: center; gap: 28px;
    background: var(--noir); padding: 40px;
    transform: translateX(100%); transition: transform var(--trans);
    box-shadow: -20px 0 60px rgba(0,0,0,0.4);
  }
  .nav.open { transform: translateX(0); }
  .nav__link, .scrolled .nav__link { color: #fff; font-size: 1.2rem; }
  .nav-toggle { display: flex; z-index: 110; }

  .stats, .problem-grid, .services, .why, .features, .steps { grid-template-columns: 1fr; }
  .stat__num { font-size: 2.8rem; }

  .offer { grid-template-columns: 1fr; }
  .offer__main, .offer__list { padding: 36px 28px; }

  .contact { grid-template-columns: 1fr; gap: 36px; }
  .contact__form { padding: 28px; }

  .footer__inner { grid-template-columns: 1fr; gap: 32px; }
  .footer__bottom .container { flex-direction: column; text-align: center; }

  .hero__inner { padding: 110px 24px 90px; }
  .hero__actions .btn { flex: 1; }
  .modal__dialog { margin-top: 0; max-height: 100vh; border-radius: 0; min-height: 100vh; }
}

@media (max-width: 420px) {
  .features { grid-template-columns: 1fr; }
  .demo__info, .demo__gallery { grid-template-columns: 1fr 1fr; }
}

/* =====================================================
   ICÔNES SVG (style ligne, cohérentes)
   ===================================================== */
.svg-sprite { position: absolute; width: 0; height: 0; overflow: hidden; }
.icon {
  display: inline-block; width: 24px; height: 24px;
  fill: none; stroke: currentColor; stroke-width: 1.6;
  stroke-linecap: round; stroke-linejoin: round;
  vertical-align: middle; flex-shrink: 0;
}
/* Services : icône terracotta dans une pastille crème */
.service__icon { color: var(--terracotta); }
.service__icon .icon { width: 30px; height: 30px; }
/* Fonctionnalités */
.feature__ico { color: var(--terracotta); display: inline-flex; }
.feature__ico .icon { width: 26px; height: 26px; }
/* Contact (fond sombre) : icône dorée */
.contact__ico { color: var(--or-clair); }
.contact__ico .icon { width: 22px; height: 22px; }
/* Hero : petit mail doré */
.hero__contact a { display: inline-flex; align-items: center; gap: 8px; }
.hero__contact .icon { width: 18px; height: 18px; color: var(--or-clair); }
/* Footer */
.footer__mail, .footer__loc { display: inline-flex; align-items: center; gap: 9px; }
.footer__contact .icon { width: 18px; height: 18px; color: var(--or); }

/* =====================================================
   SIMULATEUR ROI (#probleme)
   ===================================================== */
.roi {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border-radius: var(--radius); overflow: hidden; margin-bottom: 64px;
  box-shadow: var(--shadow); background: #fff;
}
.roi__form { padding: 40px; display: grid; gap: 26px; align-content: center; }
.roi__field { display: grid; gap: 9px; }
.roi__field label { font-size: 0.9rem; font-weight: 600; color: var(--texte); letter-spacing: 0.01em; }
.roi__field label strong { color: var(--terracotta); font-family: var(--serif); font-size: 1.05rem; }
.roi__field input[type="number"] {
  font-family: var(--sans); font-size: 1.1rem; font-weight: 600; padding: 13px 16px;
  border: 1.5px solid var(--creme-2); border-radius: var(--radius-sm);
  background: var(--creme); color: var(--texte); transition: border-color var(--trans);
}
.roi__field input[type="number"]:focus { outline: none; border-color: var(--terracotta); }
.roi__field--range input[type="range"] {
  -webkit-appearance: none; appearance: none; width: 100%; height: 6px; border-radius: 6px;
  background: var(--creme-2); cursor: pointer; margin-top: 4px;
}
.roi__field--range input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none; width: 24px; height: 24px; border-radius: 50%;
  background: var(--terracotta); border: 3px solid #fff; box-shadow: 0 2px 8px rgba(194,97,58,0.5); cursor: pointer;
}
.roi__field--range input[type="range"]::-moz-range-thumb {
  width: 22px; height: 22px; border-radius: 50%; background: var(--terracotta);
  border: 3px solid #fff; box-shadow: 0 2px 8px rgba(194,97,58,0.5); cursor: pointer;
}
.roi__range-scale { display: flex; justify-content: space-between; font-size: 0.8rem; color: var(--texte-doux); margin-top: 4px; }

.roi__result {
  background: var(--noir); color: var(--creme); padding: 44px 40px;
  display: flex; flex-direction: column; justify-content: center; text-align: center;
}
.roi__result-label { font-size: 0.95rem; color: var(--texte-clair); letter-spacing: 0.04em; }
.roi__amount { display: flex; align-items: baseline; justify-content: center; gap: 10px; flex-wrap: wrap; margin: 10px 0 4px; }
.roi__amount span:first-child { font-family: var(--serif); font-size: clamp(2.8rem, 6vw, 4rem); font-weight: 600; color: var(--or-clair); line-height: 1; }
.roi__per { font-size: 1.1rem; color: var(--texte-clair); }
.roi__year { font-size: 1rem; color: var(--texte-clair); }
.roi__year span { color: var(--or-clair); font-weight: 600; }
.roi__note { margin-top: 18px; font-size: 0.85rem; font-style: italic; color: var(--texte-clair); opacity: 0.7; }

/* =====================================================
   QUEL EST VOTRE ÉTABLISSEMENT ? (#etablissement)
   ===================================================== */
.etab__cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.etab-card {
  cursor: pointer; text-align: left; font-family: inherit;
  background: #fff; border: 2px solid transparent; border-radius: var(--radius);
  padding: 30px 28px 24px; display: grid; gap: 10px; box-shadow: var(--shadow-soft);
  position: relative; overflow: hidden;
  transition: transform var(--trans), border-color var(--trans), box-shadow var(--trans);
}
.etab-card::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(160deg, transparent 55%, rgba(194, 97, 58, 0.06));
  opacity: 0; transition: opacity var(--trans);
}
.etab-card:hover, .etab-card:focus-visible {
  transform: translateY(-6px); box-shadow: var(--shadow); border-color: var(--terracotta); outline: none;
}
.etab-card:hover::after { opacity: 1; }
.etab-card__icon {
  width: 58px; height: 58px; border-radius: 15px; display: grid; place-items: center;
  background: var(--creme); color: var(--terracotta); margin-bottom: 4px;
  transition: background var(--trans), color var(--trans), transform var(--trans);
}
.etab-card__icon .icon { width: 30px; height: 30px; }
.etab-card:hover .etab-card__icon { background: var(--terracotta); color: #fff; transform: rotate(-6deg) scale(1.05); }
.etab-card__title { font-family: var(--serif); font-size: 1.45rem; font-weight: 600; color: var(--texte); }
.etab-card__sub { font-size: 0.9rem; color: var(--texte-doux); }
.etab-card__chips { display: flex; flex-wrap: wrap; gap: 6px; margin: 6px 0 4px; }
.etab-card__chips span {
  font-size: 0.74rem; font-weight: 600; letter-spacing: 0.02em; color: var(--terracotta-fonce);
  background: var(--creme); border-radius: 100px; padding: 4px 11px;
}
.etab-card__cta {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 8px;
  font-weight: 700; font-size: 0.92rem; color: var(--terracotta-fonce);
}
.etab-card__cta .icon { width: 18px; height: 18px; transition: transform var(--trans); }
.etab-card:hover .etab-card__cta .icon { transform: translateX(5px); }
.etab__hint { text-align: center; margin-top: 26px; color: var(--texte-doux); font-size: 0.95rem; }

@keyframes fadeUp { from { opacity: 0; transform: translateY(16px); } }

/* =====================================================
   PAGE PLEIN ÉCRAN PAR ÉTABLISSEMENT (#etabPage)
   ===================================================== */
.etabpage {
  position: fixed; inset: 0; z-index: 200; background: var(--creme);
  display: flex; flex-direction: column;
  opacity: 0; visibility: hidden; transform: translateY(14px);
  transition: opacity 0.45s ease, transform 0.45s ease, visibility 0.45s;
}
.etabpage.open { opacity: 1; visibility: visible; transform: none; }
.etabpage__topbar {
  flex-shrink: 0; background: rgba(247, 241, 231, 0.92); backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(20, 17, 13, 0.08); z-index: 2;
}
.etabpage__topbar-inner { display: flex; align-items: center; justify-content: space-between; height: 70px; }
.etabpage__close {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  font-family: inherit; font-weight: 600; font-size: 0.95rem; color: var(--texte);
  background: #fff; border: 1px solid rgba(20, 17, 13, 0.12); border-radius: 100px; padding: 9px 18px;
  transition: background var(--trans), color var(--trans);
}
.etabpage__close span { font-size: 1.3rem; line-height: 1; }
.etabpage__close:hover { background: var(--terracotta); color: #fff; border-color: var(--terracotta); }
.etabpage__scroll { flex: 1; overflow-y: auto; overflow-x: hidden; -webkit-overflow-scrolling: touch; }

/* Héros de la page */
.etabpage__hero { position: relative; color: #fff; padding: 92px 0 84px; overflow: hidden; }
.etabpage__hero-bg {
  position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center;
  transform: scale(1.05); filter: saturate(1.05) brightness(0.62);
}
.etabpage__hero::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(110deg, rgba(20,17,13,0.9) 38%, rgba(20,17,13,0.55) 88%),
              linear-gradient(0deg, var(--accent, #c0552e) 0%, transparent 42%);
}
.etabpage__hero-inner { position: relative; z-index: 2; max-width: 760px; }
.etabpage__hero-icon {
  display: grid; place-items: center; width: 64px; height: 64px; border-radius: 17px;
  background: var(--accent, #c0552e); color: #fff; margin-bottom: 22px;
  box-shadow: 0 12px 30px -10px rgba(0,0,0,0.5);
}
.etabpage__hero-icon .icon { width: 34px; height: 34px; }
.etabpage__kicker { text-transform: uppercase; letter-spacing: 0.14em; font-size: 0.8rem; font-weight: 600; color: var(--or-clair); margin-bottom: 14px; }
.etabpage__title { font-size: clamp(2rem, 4.5vw, 3.4rem); line-height: 1.05; margin-bottom: 20px; }
.etabpage__intro { font-size: 1.15rem; color: var(--texte-clair); line-height: 1.6; }
.etabpage__hint { display: inline-block; margin-top: 30px; font-size: 0.9rem; color: var(--or-clair); font-weight: 600; }

/* Corps : services en alternance */
.etabpage__body { padding: 70px 24px 90px; }
.etabsvc {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center;
  padding: 46px 0; border-bottom: 1px solid rgba(20, 17, 13, 0.08);
}
.etabsvc--rev .etabsvc__text { order: 2; }
.etabsvc__num {
  display: inline-block; font-family: var(--serif); font-size: 1rem; font-weight: 600;
  color: #fff; background: var(--terracotta); width: 40px; height: 40px; border-radius: 50%;
  text-align: center; line-height: 40px; margin-bottom: 16px;
}
.etabsvc__text h3 { font-size: clamp(1.5rem, 2.6vw, 2rem); margin-bottom: 12px; }
.etabsvc__text p { color: var(--texte-doux); font-size: 1.05rem; max-width: 460px; }
.etabsvc__demo-label {
  display: inline-block; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--terracotta-fonce); margin-bottom: 12px;
}
.etabsvc__demo {
  background: #fff; border-radius: var(--radius); padding: 24px;
  box-shadow: var(--shadow); border: 1px solid rgba(20,17,13,0.05);
}

/* Bloc réalisations (maquettes concrètes) en bas de page */
.etabpage__works { margin-top: 64px; background: var(--noir); border-radius: 24px; padding: 52px clamp(22px, 5vw, 56px); }
.etabpage__works-head { text-align: center; margin-bottom: 40px; }
.etabpage__works-head h3 { color: #fff; font-size: clamp(1.55rem, 3vw, 2.2rem); margin: 6px 0 10px; }
.etabpage__works-head p { color: var(--texte-clair); max-width: 560px; margin: 0 auto; }
.etabpage__works .works { margin: 0; }
.etabpage__works .works__note { margin-top: 30px; color: var(--texte-clair); opacity: 0.65; }

/* Bloc offre/prix en bas de page */
.etabpage__offer {
  margin-top: 60px; background: var(--noir); color: #fff; border-radius: 24px;
  padding: 50px clamp(24px, 5vw, 60px); text-align: center;
}
.etabpage__offer-head h3 { font-size: clamp(1.6rem, 3vw, 2.3rem); margin: 8px 0 10px; }
.etabpage__offer-head p { color: var(--texte-clair); max-width: 560px; margin: 0 auto; }
.etabpage__plans { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; max-width: 720px; margin: 34px auto 30px; }
.etabpage__plans--three { grid-template-columns: repeat(3, 1fr); max-width: 860px; gap: 16px; }
.etabpage__plan {
  background: var(--charbon); border: 1px solid rgba(255,255,255,0.1); border-radius: 16px; padding: 26px 24px;
}
.etabpage__plan--featured { border-color: var(--or); box-shadow: 0 0 0 1px var(--or); }
.etabpage__plan-badge { font-size: 0.78rem; font-weight: 600; letter-spacing: 0.04em; color: var(--or-clair); }
.etabpage__plan-price { font-family: var(--serif); font-size: 2.4rem; font-weight: 600; margin: 8px 0 4px; }
.etabpage__plan-price span { font-size: 1.1rem; color: var(--or-clair); font-family: var(--sans); font-weight: 600; }
.etabpage__plan-sub { font-size: 0.9rem; color: var(--texte-clair); }
.etabpage__offer-actions { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }

/* =====================================================
   WIDGETS DE DÉMONSTRATION INTERACTIFS
   ===================================================== */
.w { font-size: 0.95rem; }
.w-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: inherit; font-weight: 600; font-size: 0.92rem; cursor: pointer;
  background: var(--terracotta); color: #fff; border: none; border-radius: 100px;
  padding: 12px 22px; transition: background var(--trans), transform 0.15s;
}
.w-btn:hover:not(:disabled) { background: var(--terracotta-fonce); }
.w-btn:active:not(:disabled) { transform: scale(0.97); }
.w-btn:disabled { opacity: 0.45; cursor: not-allowed; }
.w-msg { margin-top: 12px; font-size: 0.9rem; color: var(--terracotta-fonce); min-height: 1.2em; font-weight: 500; }
.w-done {
  margin-top: 14px; background: #eef6ec; border: 1px solid #cfe6c9; color: #2f6d3a;
  border-radius: 12px; padding: 12px 14px; font-size: 0.9rem; font-weight: 500;
}
.w-done em { color: var(--terracotta-fonce); font-style: normal; font-weight: 600; }

/* Stepper / commande */
.w-stepper { display: inline-flex; align-items: center; gap: 4px; }
.w-stepper button {
  width: 30px; height: 30px; border-radius: 8px; border: 1px solid rgba(20,17,13,0.15);
  background: #fff; cursor: pointer; font-size: 1.1rem; line-height: 1; color: var(--texte);
  transition: background 0.15s, border-color 0.15s;
}
.w-stepper button:hover { background: var(--creme); border-color: var(--terracotta); }
.w-stepper span { min-width: 22px; text-align: center; font-weight: 600; }
.w-order__row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 11px 0; border-bottom: 1px dashed rgba(20,17,13,0.1); }
.w-order__info strong { display: block; font-weight: 600; }
.w-order__info span { font-size: 0.85rem; color: var(--texte-doux); }
.w-order__foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 16px; flex-wrap: wrap; }
.w-order__total { font-size: 0.95rem; color: var(--texte-doux); }
.w-order__total strong { font-family: var(--serif); font-size: 1.4rem; color: var(--texte); margin-left: 6px; }

/* Fidélité */
.w-loyalty { background: linear-gradient(135deg, var(--charbon), var(--charbon-2)); color: #fff; border-radius: 14px; padding: 20px; margin-bottom: 16px; }
.w-loyalty__head { display: flex; flex-direction: column; margin-bottom: 16px; }
.w-loyalty__head strong { font-family: var(--serif); font-size: 1.2rem; }
.w-loyalty__head span { font-size: 0.85rem; color: var(--or-clair); }
.w-loyalty__slots { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; }
.w-slot {
  aspect-ratio: 1; border-radius: 50%; border: 2px dashed rgba(255,255,255,0.3);
  display: grid; place-items: center; color: rgba(255,255,255,0.4);
  transition: all 0.3s cubic-bezier(0.22,1,0.36,1);
}
.w-slot .icon { width: 20px; height: 20px; }
.w-slot.is-on { background: var(--terracotta); border-color: var(--terracotta); border-style: solid; color: #fff; transform: scale(1.08); }
.w-slot--reward { border-color: var(--or); color: var(--or); }
.w-slot.is-reward { background: var(--or); border-color: var(--or); border-style: solid; color: var(--noir); transform: scale(1.12); box-shadow: 0 0 18px rgba(201,163,92,0.6); }

/* Fidélité : 2 colonnes (commerçant + téléphone client) */
.w-fid { display: flex; flex-wrap: wrap; gap: 24px; align-items: flex-start; }
.w-fid__col { flex: 1 1 230px; min-width: 0; }
.w-fid__col--phone { display: flex; flex-direction: column; }
.w-fid__label { display: block; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--texte-doux); margin-bottom: 12px; }
.w-fid__label strong { color: var(--terracotta-fonce); }

/* Téléphone Wallet */
.w-phone--wallet .w-phone__screen { position: relative; min-height: 380px; background: #0b0b0d; padding: 0; }
.w-wallet__lock, .w-wallet__view { position: absolute; inset: 0; display: flex; flex-direction: column; }
.w-wallet__lock {
  padding: 16px 16px 18px; color: #fff;
  background: linear-gradient(165deg, #3a3128 0%, #14110d 70%);
}
.w-wallet__status { display: flex; justify-content: space-between; font-size: 0.72rem; opacity: 0.85; font-weight: 600; }
.w-wallet__clock { text-align: center; margin-top: 22px; }
.w-wallet__clock strong { display: block; font-size: 2.6rem; font-weight: 300; letter-spacing: 0.01em; line-height: 1; }
.w-wallet__clock small { font-size: 0.8rem; opacity: 0.8; }
.w-wallet__notif {
  margin-top: auto; display: flex; gap: 11px; align-items: center;
  background: rgba(255,255,255,0.14); backdrop-filter: blur(8px);
  border-radius: 15px; padding: 12px 13px;
}
.w-wallet__notif-ic { width: 34px; height: 34px; border-radius: 9px; flex-shrink: 0; display: grid; place-items: center; background: var(--terracotta); color: #fff; }
.w-wallet__notif-ic .icon { width: 19px; height: 19px; }
.w-wallet__notif strong { display: block; font-size: 0.84rem; }
.w-wallet__notif span { font-size: 0.74rem; opacity: 0.85; }
.w-wallet__tap { display: flex; align-items: center; justify-content: center; gap: 9px; margin-top: 14px; font-size: 0.8rem; font-weight: 600; }
.w-wallet__ring { width: 14px; height: 14px; border-radius: 50%; border: 2px solid #fff; position: relative; }
.w-wallet__ring::after { content: ""; position: absolute; inset: -5px; border-radius: 50%; border: 2px solid rgba(255,255,255,0.6); animation: walletPulse 1.6s ease-out infinite; }
@keyframes walletPulse { 0% { transform: scale(0.6); opacity: 1; } 100% { transform: scale(1.5); opacity: 0; } }

/* Wallet ouvert : la carte dématérialisée */
.w-wallet__view { background: #0b0b0d; padding: 14px; animation: walletIn 0.32s cubic-bezier(0.22,1,0.36,1); }
@keyframes walletIn { from { opacity: 0; transform: translateY(12px); } }
.w-wallet__back { align-self: flex-start; background: none; border: none; cursor: pointer; font-family: inherit; font-size: 0.85rem; font-weight: 600; color: var(--or-clair); padding: 2px 0 10px; }
.w-wallet__pass {
  background: linear-gradient(160deg, var(--terracotta), var(--terracotta-fonce));
  border-radius: 16px; padding: 16px; color: #fff; box-shadow: 0 14px 30px -12px rgba(0,0,0,0.6);
}
.w-wallet__pass-head { display: flex; align-items: center; gap: 9px; font-family: var(--serif); font-weight: 600; font-size: 1.05rem; }
.w-wallet__logo { width: 26px; height: 26px; border-radius: 7px; background: var(--noir); color: var(--or); display: grid; place-items: center; font-family: var(--serif); font-weight: 600; font-size: 1rem; }
.w-wallet__pass-type { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.12em; opacity: 0.85; margin-top: 4px; }
.w-wallet__qrwrap { background: #fff; border-radius: 12px; padding: 9px; width: 132px; margin: 14px auto 12px; box-shadow: 0 6px 16px -8px rgba(0,0,0,0.5); }
.w-wallet__qrwrap .qr { width: 100%; height: auto; display: block; }
.w-wallet__pass-foot { text-align: center; }
.w-wallet__pass-foot strong { display: block; font-size: 0.95rem; }
.w-wallet__pass-foot span { font-size: 0.74rem; opacity: 0.85; }

/* Réservation */
.w-resa__group { margin-bottom: 16px; }
.w-resa__group > label { display: block; font-weight: 600; font-size: 0.85rem; margin-bottom: 8px; color: var(--texte-doux); }
.w-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.w-chips button {
  font-family: inherit; font-size: 0.88rem; font-weight: 600; cursor: pointer;
  background: #fff; border: 1.5px solid rgba(20,17,13,0.14); border-radius: 10px;
  padding: 9px 14px; color: var(--texte); transition: all 0.15s;
  display: inline-flex; flex-direction: column; align-items: center; line-height: 1.2;
}
.w-chips button small { font-size: 0.68rem; color: var(--texte-doux); font-weight: 500; text-transform: capitalize; }
.w-chips button:hover { border-color: var(--terracotta); }
.w-chips button.is-on { background: var(--terracotta); border-color: var(--terracotta); color: #fff; }
.w-chips button.is-on small { color: rgba(255,255,255,0.85); }

/* Téléphone (menu + chat) */
.w-phone { display: flex; justify-content: center; }
.w-phone__screen {
  width: 100%; max-width: min(290px, 100%); background: var(--creme); border-radius: 22px;
  border: 7px solid #1a1712; box-shadow: var(--shadow); overflow: hidden;
}
.w, .w-phone { min-width: 0; max-width: 100%; }
.w-phone__bar { background: #1a1712; color: #fff; font-size: 0.8rem; font-weight: 600; padding: 8px 14px 12px; display: flex; align-items: center; gap: 8px; }
.w-phone__dot { width: 8px; height: 8px; border-radius: 50%; background: #4ade80; box-shadow: 0 0 0 3px rgba(74,222,128,0.25); }
.w-menu__tabs { display: flex; gap: 4px; padding: 12px 12px 8px; background: #fff; overflow-x: auto; }
.w-menu__tabs button {
  font-family: inherit; font-size: 0.78rem; font-weight: 600; white-space: nowrap; cursor: pointer;
  background: var(--creme); border: none; border-radius: 100px; padding: 6px 13px; color: var(--texte-doux); transition: all 0.15s;
}
.w-menu__tabs button.is-on { background: var(--terracotta); color: #fff; }
.w-menu__items { padding: 6px 14px 16px; background: #fff; min-height: 150px; }
.w-menu__item { display: flex; justify-content: space-between; gap: 12px; padding: 10px 0; border-bottom: 1px solid rgba(20,17,13,0.07); }
.w-menu__item strong { display: block; font-size: 0.9rem; }
.w-menu__item span { font-size: 0.76rem; color: var(--texte-doux); }
.w-menu__item em { font-style: normal; font-weight: 600; color: var(--terracotta-fonce); white-space: nowrap; }

/* Chat / SMS */
.w-phone--chat .w-phone__screen { background: #e9e3d8; }
.w-chat { padding: 14px; min-height: 200px; max-height: 240px; overflow-y: auto; display: flex; flex-direction: column; gap: 8px; }
.w-bubble { max-width: 80%; padding: 9px 13px; border-radius: 15px; font-size: 0.84rem; line-height: 1.4; animation: bubbleIn 0.3s ease; }
.w-bubble--in { background: #fff; align-self: flex-start; border-bottom-left-radius: 5px; }
.w-bubble--out { background: var(--terracotta); color: #fff; align-self: flex-end; border-bottom-right-radius: 5px; }
.w-typing { display: inline-flex; gap: 4px; align-items: center; }
.w-typing span { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,0.7); animation: typing 1s infinite; }
.w-typing span:nth-child(2) { animation-delay: 0.15s; }
.w-typing span:nth-child(3) { animation-delay: 0.3s; }
@keyframes bubbleIn { from { opacity: 0; transform: translateY(6px); } }
@keyframes typing { 0%, 60%, 100% { opacity: 0.3; } 30% { opacity: 1; } }

/* Avis Google */
.w-rev__head { display: flex; align-items: center; gap: 14px; padding-bottom: 16px; border-bottom: 1px solid rgba(20,17,13,0.08); }
.w-rev__google { width: 42px; height: 42px; border-radius: 50%; background: #fff; border: 1px solid rgba(20,17,13,0.12); display: grid; place-items: center; font-family: var(--serif); font-weight: 700; font-size: 1.4rem; color: #4285f4; }
.w-rev__score { font-family: var(--serif); font-size: 1.6rem; margin-right: 8px; }
.w-rev__stars { color: #f5b301; letter-spacing: 1px; }
.w-rev__count { display: block; font-size: 0.82rem; color: var(--texte-doux); margin-top: 2px; }
.w-rev__rate { padding: 14px 0; border-bottom: 1px solid rgba(20,17,13,0.08); margin-bottom: 14px; }
.w-rev__rate > span { font-size: 0.85rem; color: var(--texte-doux); margin-right: 8px; }
.w-rate { display: inline-flex; gap: 2px; }
.w-rate button { background: none; border: none; cursor: pointer; font-size: 1.6rem; line-height: 1; color: #d8cdbb; padding: 0 1px; transition: color 0.12s, transform 0.12s; }
.w-rate button:hover { transform: scale(1.15); }
.w-rate button.is-on { color: #f5b301; }
.w-rev__card { padding: 10px 0; }
.w-rev__who { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.w-rev__ava { width: 26px; height: 26px; border-radius: 50%; background: var(--olive); color: #fff; display: grid; place-items: center; font-size: 0.78rem; font-weight: 600; }
.w-rev__who strong { font-size: 0.88rem; }
.w-rev__mini { color: #f5b301; font-size: 0.8rem; letter-spacing: 0.5px; }
.w-rev__card p { font-size: 0.86rem; color: var(--texte-doux); }

/* Événement */
.w-event { background: var(--creme); border-radius: 12px; padding: 18px; margin: 14px 0; border-left: 3px solid var(--terracotta); }
.w-event__tag { display: inline-block; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: #fff; background: var(--terracotta); border-radius: 100px; padding: 3px 11px; margin-bottom: 8px; }
.w-event strong { display: block; font-family: var(--serif); font-size: 1.15rem; margin-bottom: 4px; }
.w-event p { font-size: 0.88rem; color: var(--texte-doux); margin-bottom: 8px; }
.w-event__date { display: inline-flex; align-items: center; gap: 6px; font-size: 0.82rem; font-weight: 600; color: var(--terracotta-fonce); }
.w-event__date .icon { width: 16px; height: 16px; }

/* =====================================================
   ONGLETS RÉALISATIONS (#realisations)
   ===================================================== */
.tabs { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; margin-bottom: 44px; }
.tab {
  cursor: pointer; font-family: var(--sans); font-size: 0.95rem; font-weight: 600;
  color: var(--texte-clair); background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(255,255,255,0.14); border-radius: 100px; padding: 11px 26px;
  transition: var(--trans);
}
.tab:hover { border-color: var(--or); color: #fff; }
.tab.is-active { background: var(--or); color: var(--noir); border-color: var(--or); }
/* chaque carte apparaît en fondu (régénérée à chaque onglet) */
.works .work { animation: fadeUp 0.5s cubic-bezier(0.22,1,0.36,1) backwards; }
.works .work:nth-child(2) { animation-delay: 0.07s; }
.works .work:nth-child(3) { animation-delay: 0.14s; }

/* =====================================================
   OFFRE : DEUX FORMULES + OPTIONS (#offre)
   ===================================================== */
.plans { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; max-width: 920px; margin: 0 auto; }
.plans--three { grid-template-columns: repeat(3, 1fr); max-width: 1140px; gap: 22px; align-items: stretch; }
.plans--three .plan { padding: 34px 28px; }
.plan {
  position: relative; background: var(--charbon); border: 1.5px solid rgba(255,255,255,0.1);
  border-radius: var(--radius); padding: 40px 34px; display: flex; flex-direction: column;
  box-shadow: var(--shadow-soft);
}
.plans--three .plan--featured { transform: scale(1.03); z-index: 1; }
.plan__permo { font-family: var(--sans); font-size: 1rem; font-weight: 600; color: var(--texte-clair); margin-left: 6px; }
.plan__tagline { color: var(--or-clair); font-size: 0.98rem; font-style: italic; margin: 4px 0 2px; }
.plan__more { color: #fff; font-weight: 600; opacity: 0.9; }
.plan__more span { font-size: 0.92rem; }
.plan--featured { border-color: var(--or); background: linear-gradient(170deg, #2a2218, var(--charbon)); }
.plan__badge {
  display: inline-block; align-self: flex-start; background: rgba(255,255,255,0.12);
  color: var(--creme); padding: 7px 16px; border-radius: 100px; font-size: 12px; font-weight: 600;
  letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: 24px;
}
.plan__badge--gold { background: var(--or); color: var(--noir); }
.plan__price { display: flex; flex-direction: column; gap: 4px; margin-bottom: 6px; }
.plan__amount { font-family: var(--serif); font-size: 3rem; font-weight: 600; color: #fff; line-height: 1; }
.plan__period { font-size: 0.98rem; color: var(--texte-clair); }
.plan__highlight { color: var(--or-clair); font-weight: 600; font-size: 0.95rem; margin-bottom: 6px; }
.plan__list { display: grid; gap: 14px; margin: 22px 0 30px; flex: 1; }
.plan__list li { display: flex; gap: 12px; align-items: flex-start; font-size: 0.98rem; color: var(--creme); }
.plan__list .icon { width: 20px; height: 20px; color: var(--or); margin-top: 2px; stroke-width: 2.2; }
.plan__list strong { color: var(--or-clair); font-weight: 600; }

.options { max-width: 920px; margin: 48px auto 0; }
.options__title { text-align: center; font-size: 1.5rem; margin-bottom: 24px; color: var(--creme); }
.options__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.option {
  display: flex; align-items: center; gap: 18px;
  background: var(--charbon); border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius); padding: 24px 26px;
}
.option__icon {
  width: 48px; height: 48px; border-radius: 12px; flex-shrink: 0;
  display: grid; place-items: center; background: rgba(201,163,92,0.14); color: var(--or-clair);
}
.option__icon .icon { width: 24px; height: 24px; }
.option h4 { font-size: 1.12rem; margin-bottom: 4px; color: #fff; }
.option p { font-size: 0.9rem; color: var(--texte-clair); }
.option__price {
  margin-left: auto; font-family: var(--serif); font-weight: 600; font-size: 1.25rem;
  color: var(--or-clair); white-space: nowrap; align-self: flex-start;
}

/* =====================================================
   RESPONSIVE — nouveaux composants
   ===================================================== */
@media (max-width: 1040px) {
  .plans--three { grid-template-columns: 1fr; max-width: 460px; }
  .plans--three .plan--featured { transform: none; }
}
@media (max-width: 900px) {
  .roi, .plans, .options__grid { grid-template-columns: 1fr; }
  .etab__cards { grid-template-columns: 1fr; }
  .etabsvc, .etabsvc--rev { grid-template-columns: 1fr; gap: 26px; }
  .etabsvc--rev .etabsvc__text { order: 0; }
  .etabsvc__text, .etabsvc__demo { min-width: 0; }
  .etabpage__plans, .etabpage__plans--three { grid-template-columns: 1fr; }
  .works { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .roi__form, .roi__result { padding: 30px 24px; }
  .option { flex-wrap: wrap; }
  .option__price { margin-left: 0; }
  .tab { padding: 9px 18px; font-size: 0.88rem; }
  .etabpage__hero { padding: 64px 0 56px; }
  .etabpage__body { padding: 44px 18px 64px; }
  .etabpage__offer { padding: 36px 22px; }
  .etabsvc__text p { max-width: none; }
  /* Barre du haut : compacter logo + bouton pour les petits écrans */
  .etabpage__topbar-inner { padding-left: 16px; padding-right: 16px; }
  .etabpage__topbar-inner .logo__mark { width: 34px; height: 34px; font-size: 21px; }
  .etabpage__topbar-inner .logo__text { font-size: 17px; }
  .etabpage__close { padding: 8px 14px; font-size: 0.85rem; gap: 6px; }
  .etabpage__close span { font-size: 1.1rem; }
}

/* =====================================================
   FOOTER — liens légaux
   ===================================================== */
.footer__legal { display: flex; flex-wrap: wrap; gap: 18px; justify-content: center; }
.footer__legal a { font-size: 0.85rem; color: var(--texte-clair); opacity: 0.75; transition: color var(--trans), opacity var(--trans); }
.footer__legal a:hover { color: var(--or-clair); opacity: 1; }

/* =====================================================
   PAGES LÉGALES (mentions, CGV, confidentialité)
   ===================================================== */
.legal-page { padding: 120px 0 90px; background: var(--creme); min-height: 70vh; }
.legal { max-width: 820px; margin: 0 auto; }
.legal__back { display: inline-flex; align-items: center; gap: 7px; font-weight: 600; font-size: 0.92rem; color: var(--terracotta); margin-bottom: 26px; }
.legal__back:hover { color: var(--terracotta-fonce); }
.legal__eyebrow { text-transform: uppercase; letter-spacing: 0.2em; font-size: 13px; font-weight: 600; color: var(--terracotta); margin-bottom: 14px; }
.legal__title { font-size: clamp(2rem, 4.5vw, 3rem); margin-bottom: 12px; }
.legal__updated { font-size: 0.9rem; color: var(--texte-doux); margin-bottom: 44px; }
.legal h2 {
  font-size: 1.5rem; margin: 40px 0 14px; padding-top: 24px;
  border-top: 1px solid rgba(20,17,13,0.1);
}
.legal h2:first-of-type { border-top: none; padding-top: 0; }
.legal h3 { font-size: 1.15rem; margin: 22px 0 8px; }
.legal p, .legal li { color: var(--texte); line-height: 1.7; margin-bottom: 12px; }
.legal ul { padding-left: 22px; margin-bottom: 16px; list-style: disc; }
.legal li { margin-bottom: 6px; }
.legal a { color: var(--terracotta); text-decoration: underline; text-underline-offset: 2px; }
.legal strong { color: var(--texte); }
.legal__fill {
  background: rgba(194,97,58,0.12); color: var(--terracotta-fonce);
  font-weight: 600; padding: 1px 7px; border-radius: 5px; white-space: nowrap;
}
.legal__note {
  background: var(--creme-2); border-left: 4px solid var(--or);
  padding: 16px 20px; border-radius: 8px; font-size: 0.95rem; margin: 18px 0;
}
.legal__note strong { color: var(--terracotta-fonce); }

/* En-tête plein (pages légales : pas de hero sombre derrière) */
.site-header--solid {
  position: sticky; background: rgba(247, 241, 231, 0.96);
  backdrop-filter: blur(12px); box-shadow: 0 1px 0 rgba(0,0,0,0.06); padding: 14px 0;
}
.site-header--solid .logo__text { color: var(--noir); }
.site-header--solid .nav__link { color: var(--texte); }
.site-header--solid .nav__link[aria-current="page"] { color: var(--terracotta); }
.site-header--solid .nav-toggle span { background: var(--noir); }

/* =====================================================
   PAGE TARIFS (tarifs.html)
   ===================================================== */
.tarifs-page { padding: 110px 0 90px; background: var(--creme); }
.tarifs__head { text-align: center; max-width: 720px; margin: 18px auto 44px; }
.tarifs__title { font-size: clamp(2rem, 4.5vw, 3rem); margin: 8px 0 16px; }
.tarifs__lead { color: var(--texte-doux); font-size: 1.1rem; }
.tarifs__lead strong { color: var(--texte); }

/* Bandeau de cartes prix */
.tarifs__cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 46px; }
.tarifs__card {
  position: relative; background: #fff; border: 1.5px solid rgba(20,17,13,0.1); border-radius: var(--radius);
  padding: 28px 26px; display: flex; flex-direction: column; align-items: flex-start; box-shadow: var(--shadow-soft);
}
.tarifs__card--feat { border-color: var(--terracotta); box-shadow: var(--shadow); }
.tarifs__card-badge { position: absolute; top: -12px; left: 26px; background: var(--terracotta); color: #fff; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; padding: 5px 12px; border-radius: 100px; }
.tarifs__card-name { font-family: var(--serif); font-size: 1.3rem; font-weight: 600; }
.tarifs__card-price { font-family: var(--serif); font-size: 2.6rem; font-weight: 600; line-height: 1; margin: 6px 0 2px; }
.tarifs__card-price small { font-family: var(--sans); font-size: 1rem; font-weight: 600; color: var(--texte-doux); margin-left: 4px; }
.tarifs__card-sub { font-size: 0.84rem; color: var(--texte-doux); }
.tarifs__card-desc { font-style: italic; color: var(--terracotta-fonce); margin: 12px 0 18px; }
.tarifs__card .btn { margin-top: auto; }

.tarifs__scroll-hint { display: none; text-align: center; color: var(--texte-doux); font-size: 0.85rem; margin-bottom: 12px; }

/* Tableau comparatif */
.cmp { overflow-x: auto; border-radius: var(--radius); border: 1px solid rgba(20,17,13,0.08); background: #fff; box-shadow: var(--shadow-soft); -webkit-overflow-scrolling: touch; }
.cmp__table { width: 100%; min-width: 720px; border-collapse: collapse; }
.cmp__table th, .cmp__table td { padding: 13px 18px; text-align: center; border-bottom: 1px solid rgba(20,17,13,0.07); vertical-align: middle; }
.cmp__table thead th { font-family: var(--serif); font-size: 1.2rem; font-weight: 600; color: var(--texte); padding: 22px 18px; background: var(--creme); position: sticky; top: 0; z-index: 3; }
.cmp__table thead th small { display: block; font-family: var(--sans); font-size: 0.8rem; font-weight: 600; color: var(--texte-doux); margin-top: 3px; }
.cmp__table th[scope="row"] { text-align: left; font-weight: 500; font-size: 0.95rem; color: var(--texte); position: sticky; left: 0; background: #fff; z-index: 1; }
.cmp__table th[scope="row"] em { font-style: italic; color: var(--terracotta-fonce); }
.cmp__feat-h { text-align: left; position: sticky; left: 0; background: var(--creme); z-index: 4; }

/* Colonne Pro mise en avant */
.cmp__table td:nth-child(3) { background: rgba(194,97,58,0.05); }
.cmp__table thead .cmp__col-feat { background: linear-gradient(var(--creme), var(--creme)) padding-box, rgba(194,97,58,0.12); box-shadow: inset 0 0 0 99px rgba(194,97,58,0.08); }

/* Lignes de catégorie */
.cmp__group td { text-align: left; background: var(--noir); color: var(--or-clair); font-family: var(--serif); font-size: 1.04rem; font-weight: 600; padding: 11px 18px; position: sticky; left: 0; }

/* Cellules oui / non / option / texte */
.cmp__table td.yes::before {
  content: "✓"; display: inline-grid; place-items: center; width: 26px; height: 26px;
  border-radius: 50%; background: var(--terracotta); color: #fff; font-size: 0.88rem; font-weight: 700;
}
.cmp__table td:nth-child(3).yes::before { background: var(--terracotta-fonce); }
.cmp__table td.no::before { content: "—"; color: rgba(20,17,13,0.3); font-weight: 600; font-size: 1.1rem; }
.cmp__table td.opt { color: var(--texte-doux); font-size: 0.85rem; font-style: italic; }
.cmp__table td.txt { font-weight: 600; font-size: 0.9rem; color: var(--texte); }
.cmp__table tfoot td { padding: 18px; background: #fff; }
.cmp__table tfoot td:nth-child(3) { background: rgba(194,97,58,0.05); }

/* Clé en main + note */
.tarifs__keymain { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin: 42px 0 18px; background: var(--noir); color: #fff; border-radius: var(--radius); padding: 30px 34px; }
.tarifs__keymain h3 { color: #fff; font-size: 1.4rem; margin-bottom: 6px; }
.tarifs__keymain p { color: var(--texte-clair); max-width: 560px; }
.tarifs__keymain strong { color: var(--or-clair); }
.tarifs__note { text-align: center; font-size: 0.82rem; color: var(--texte-doux); margin-top: 22px; }
.tarifs__note a { color: var(--terracotta-fonce); text-decoration: underline; }

@media (max-width: 860px) {
  .tarifs__cards { grid-template-columns: 1fr; max-width: 420px; margin-inline: auto; }
  .tarifs__scroll-hint { display: block; }
  .tarifs__keymain { flex-direction: column; align-items: flex-start; }
}

/* =====================================================
   PAGE PARRAINAGE (parrainage.html)
   ===================================================== */
.parr-page { padding: 110px 0 90px; background: var(--creme); }
.parr__head { text-align: center; max-width: 760px; margin: 18px auto 44px; }
.parr__title { font-size: clamp(2rem, 5vw, 3.2rem); margin: 10px 0 18px; }
.parr__title em { color: var(--terracotta); font-style: italic; }
.parr__lead { color: var(--texte-doux); font-size: 1.12rem; }
.parr__lead strong { color: var(--texte); }

/* Le deal gagnant-gagnant */
.parr-deal { display: flex; align-items: stretch; justify-content: center; flex-wrap: wrap; margin-bottom: 64px; }
.parr-deal__side {
  flex: 1 1 280px; max-width: 360px; background: #fff; border: 1.5px solid rgba(20,17,13,0.1);
  border-radius: var(--radius); padding: 32px 28px; text-align: center;
  display: flex; flex-direction: column; align-items: center; box-shadow: var(--shadow-soft);
}
.parr-deal__side--you { background: linear-gradient(165deg, #2a2218, var(--noir)); border-color: var(--or); color: #fff; box-shadow: var(--shadow); }
.parr-deal__role { font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--texte-doux); margin-bottom: 16px; }
.parr-deal__side--you .parr-deal__role { color: var(--or-clair); }
.parr-deal__icon { width: 62px; height: 62px; border-radius: 16px; display: grid; place-items: center; background: var(--creme); color: var(--terracotta); margin-bottom: 16px; }
.parr-deal__side--you .parr-deal__icon { background: var(--or); color: var(--noir); }
.parr-deal__icon .icon { width: 30px; height: 30px; }
.parr-deal__reward { font-family: var(--serif); font-size: 1.7rem; font-weight: 600; line-height: 1.12; color: var(--texte); }
.parr-deal__side--you .parr-deal__reward { color: #fff; }
.parr-deal__sub { font-size: 0.86rem; color: var(--texte-doux); margin-top: 8px; }
.parr-deal__side--you .parr-deal__sub { color: var(--texte-clair); }
.parr-deal__plus { display: grid; place-items: center; font-family: var(--serif); font-size: 2rem; color: var(--terracotta); padding: 0 20px; }

/* Comment ça marche */
.parr-steps-wrap { margin-bottom: 66px; }
.parr-section-title { text-align: center; font-size: clamp(1.6rem, 3vw, 2.2rem); margin-bottom: 38px; }
.parr-steps { grid-template-columns: repeat(3, 1fr); max-width: 880px; margin: 0 auto; }
.parr-steps .step::after { display: none; }

/* Récompense Premium (panneau sombre) */
.parr-premium {
  background: var(--noir); border-radius: 24px; padding: clamp(30px, 5vw, 54px);
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 42px; align-items: center; color: #fff;
}
.parr-premium h2 { color: #fff; font-size: clamp(1.6rem, 3vw, 2.3rem); margin: 8px 0 14px; }
.parr-premium__text > p { color: var(--texte-clair); margin-bottom: 24px; }
.parr-premium__text strong { color: var(--or-clair); }
.parr-premium__cta { display: flex; flex-wrap: wrap; gap: 14px; }
.parr-premium__list { display: grid; gap: 14px; }
.parr-premium__list li { display: flex; align-items: flex-start; gap: 12px; font-weight: 500; color: var(--creme); }
.parr-premium__list .icon { width: 20px; height: 20px; color: var(--or); flex-shrink: 0; margin-top: 2px; stroke-width: 2.2; }
.parr-premium__list strong { color: var(--or-clair); }

.parr__note { text-align: center; font-size: 0.84rem; color: var(--texte-doux); margin-top: 30px; }
.parr__note a { color: var(--terracotta-fonce); text-decoration: underline; }

@media (max-width: 760px) {
  .parr-deal__plus { padding: 14px 0; }
  .parr-steps { grid-template-columns: 1fr; gap: 30px; }
  .parr-premium { grid-template-columns: 1fr; gap: 26px; }
}

/* =====================================================
   FINITION HAUT DE GAMME (Phase E)
   ===================================================== */
/* Barre de progression de lecture */
.scroll-progress {
  position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 150;
  background: linear-gradient(90deg, var(--terracotta), var(--or));
  transition: width 0.12s linear; pointer-events: none;
}

/* Bouton « retour en haut » */
.to-top {
  position: fixed; right: 22px; bottom: 22px; z-index: 150;
  width: 46px; height: 46px; border-radius: 50%; border: none; cursor: pointer;
  background: var(--terracotta); color: #fff; display: grid; place-items: center;
  box-shadow: 0 12px 26px -10px rgba(194,97,58,0.85);
  opacity: 0; visibility: hidden; transform: translateY(12px) scale(0.9);
  transition: opacity var(--trans), transform var(--trans), visibility var(--trans), background var(--trans);
}
.to-top.show { opacity: 1; visibility: visible; transform: none; }
.to-top:hover { background: var(--terracotta-fonce); transform: translateY(-3px); }
.to-top svg { width: 20px; height: 20px; }

/* Focus clavier soigné (accessibilité) */
:focus-visible { outline: 2px solid var(--or); outline-offset: 3px; border-radius: 5px; }
.btn:focus-visible, .nav__cta:focus-visible, .to-top:focus-visible { outline-offset: 4px; }

/* Barre de défilement personnalisée */
* { scrollbar-color: var(--terracotta) transparent; scrollbar-width: thin; }
::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--terracotta); border-radius: 10px; border: 3px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: var(--terracotta-fonce); background-clip: padding-box; }

/* Micro-interaction : retour tactile sur les boutons */
.btn:active { transform: translateY(0) scale(0.98); }

@media (prefers-reduced-motion: reduce) {
  .scroll-progress { transition: none; }
  .to-top { transition: opacity 0.01ms; }
}

/* =====================================================
   DÉMOS AVANCÉES — boutons utilitaires partagés
   ===================================================== */
.w-btn--sm { padding: 9px 16px; font-size: 0.85rem; }
.w-btn--block { width: 100%; }
.w-chips--sm button { padding: 7px 12px; font-size: 0.82rem; }
.w-phone__dot--live { background: #e24b4a; animation: wPulse 1.4s ease-in-out infinite; }
@keyframes wPulse { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }

/* ---- Plan de salle ---- */
.w-tables__top { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.w-tables__free { font-size: 0.92rem; color: var(--texte-doux); }
.w-tables__free strong { color: var(--terracotta-fonce); }
.w-tables { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.w-table {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: 14px 6px; border-radius: var(--radius-sm); cursor: pointer;
  border: 1.5px solid transparent; font-family: inherit; background: var(--creme-2);
  transition: transform var(--trans), box-shadow var(--trans);
}
.w-table:hover { transform: translateY(-2px); box-shadow: var(--shadow-soft); }
.w-table__n { font-family: var(--serif); font-weight: 600; font-size: 1.05rem; color: var(--texte); }
.w-table__seats { font-size: 0.75rem; color: var(--texte-doux); }
.w-table__st { font-size: 0.72rem; font-weight: 600; letter-spacing: 0.01em; }
.w-table.is-libre { background: #e9f0e1; border-color: #7d9152; }
.w-table.is-libre .w-table__st { color: #4f6021; }
.w-table.is-reservee { background: #f8edd5; border-color: var(--or); }
.w-table.is-reservee .w-table__st { color: #8a6a1f; }
.w-table.is-occupee { background: #f4ddd1; border-color: var(--terracotta); }
.w-table.is-occupee .w-table__st { color: var(--terracotta-fonce); }
.w-table.is-debarrasser { background: #ece6dc; border-color: #b3a78f; }
.w-table.is-debarrasser .w-table__st { color: #7a6f59; }
.w-tables__legend { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 14px; font-size: 0.8rem; color: var(--texte-doux); }
.w-tables__legend span { display: inline-flex; align-items: center; gap: 6px; }
.w-dot { width: 11px; height: 11px; border-radius: 3px; display: inline-block; }
.w-dot--libre { background: #7d9152; }
.w-dot--reservee { background: var(--or); }
.w-dot--occupee { background: var(--terracotta); }
.w-dot--debarrasser { background: #b3a78f; }

/* ---- Paiement à table ---- */
.w-pay { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 12px; }
.w-pay__lines { display: grid; gap: 8px; }
.w-pay__line { display: flex; justify-content: space-between; font-size: 0.92rem; color: var(--texte); }
.w-pay__line em { font-style: normal; font-weight: 600; }
.w-pay__tip { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding-top: 10px; border-top: 1px solid rgba(20,17,13,0.1); }
.w-pay__tip > span { font-size: 0.88rem; color: var(--texte-doux); }
.w-pay__total { display: flex; justify-content: space-between; align-items: baseline; font-size: 0.95rem; color: var(--texte-doux); padding-top: 8px; border-top: 1px solid rgba(20,17,13,0.1); }
.w-pay__total strong { font-family: var(--serif); font-size: 1.6rem; color: var(--terracotta-fonce); }

@media (max-width: 520px) {
  .w-tables { grid-template-columns: repeat(3, 1fr); }
}

/* =====================================================
   VITRINE FONCTIONNALITÉS (#fonctionnalites-demo)
   ===================================================== */
.vitrine { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; margin-top: 12px; }
.vitrine__card {
  background: #fff; border: 1px solid rgba(20,17,13,0.08); border-radius: var(--radius);
  padding: 26px 24px; box-shadow: var(--shadow-soft);
}
.vitrine__head { display: flex; gap: 14px; align-items: flex-start; margin-bottom: 18px; }
.vitrine__ico {
  flex-shrink: 0; width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center;
  background: var(--creme-2); color: var(--terracotta);
}
.vitrine__ico .icon { width: 24px; height: 24px; }
.vitrine__head h3 { font-size: 1.25rem; font-weight: 600; color: var(--texte); margin-bottom: 4px; }
.vitrine__head p { font-size: 0.92rem; color: var(--texte-doux); line-height: 1.5; }
@media (max-width: 820px) { .vitrine { grid-template-columns: 1fr; } }

/* ---- Anti no-show / liste d'attente ---- */
.w-ns__opts { display: grid; gap: 12px; margin-bottom: 14px; }
.w-toggle { display: flex; align-items: center; gap: 10px; cursor: pointer; font-size: 0.95rem; color: var(--texte); }
.w-toggle input { width: 18px; height: 18px; accent-color: var(--terracotta); cursor: pointer; flex-shrink: 0; }
.w-toggle small { color: var(--texte-doux); }
.w-ns__row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-size: 0.88rem; color: var(--texte-doux); padding-left: 28px; }
.w-ns__wait { margin-top: 16px; padding-top: 16px; border-top: 1px solid rgba(20,17,13,0.1); }
.w-ns__waitlbl { font-size: 0.9rem; color: var(--texte-doux); margin-bottom: 8px; }

/* ---- Tableau de bord ---- */
.w-dash__top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 14px; }
.w-dash__lbl { font-size: 0.9rem; font-weight: 600; color: var(--texte); }
.w-dash__kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 18px; }
.w-kpi { background: var(--creme-2); border-radius: var(--radius-sm); padding: 14px 8px; text-align: center; }
.w-kpi__v { display: block; font-family: var(--serif); font-size: 1.5rem; font-weight: 600; color: var(--terracotta-fonce); line-height: 1.1; }
.w-kpi__l { display: block; font-size: 0.74rem; color: var(--texte-doux); margin-top: 4px; }
.w-dash__chart { display: flex; align-items: flex-end; gap: 8px; height: 130px; padding: 8px 4px 0; }
.w-bar { flex: 1; background: var(--terracotta); border-radius: 5px 5px 0 0; position: relative; min-height: 8px; transition: height var(--trans); display: flex; align-items: flex-end; justify-content: center; }
.w-bar i { position: absolute; bottom: -20px; font-style: normal; font-size: 0.72rem; color: var(--texte-doux); }
.w-bar--low { background: #c9b89a; }
.w-dash__insight { margin-top: 28px; font-size: 0.9rem; color: var(--texte); background: var(--creme-2); border-radius: var(--radius-sm); padding: 12px 14px; }

/* ---- CRM / e-mail ---- */
.w-mail { background: var(--creme-2); border: 1px solid rgba(20,17,13,0.08); border-radius: var(--radius-sm); padding: 16px; margin: 14px 0; }
.w-mail__head { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.w-mail__head .icon { width: 18px; height: 18px; color: var(--terracotta); flex-shrink: 0; }
.w-mail__head strong { font-size: 1rem; color: var(--texte); }
.w-mail p { font-size: 0.9rem; color: var(--texte-doux); line-height: 1.5; }

@media (max-width: 520px) { .w-dash__kpis { grid-template-columns: repeat(2, 1fr); } }

/* ---- Diffusion automatique ---- */
.w-diff__msg { background: var(--creme-2); border-radius: var(--radius-sm); padding: 12px 14px; font-size: 0.92rem; color: var(--texte); margin: 14px 0; }
.w-diff__msg strong { color: var(--terracotta-fonce); }

/* ---- Livraison / suivi ---- */
.w-track { padding: 14px 16px; display: grid; gap: 0; }
.w-track__step { display: flex; gap: 14px; align-items: flex-start; position: relative; padding-bottom: 20px; }
.w-track__step:not(:last-child)::before { content: ""; position: absolute; left: 7px; top: 18px; bottom: 0; width: 2px; background: rgba(20,17,13,0.12); }
.w-track__step.is-done:not(:last-child)::before { background: var(--terracotta); }
.w-track__dot { width: 16px; height: 16px; border-radius: 50%; border: 2px solid rgba(20,17,13,0.2); background: #fff; flex-shrink: 0; margin-top: 1px; z-index: 1; transition: var(--trans); }
.w-track__step.is-done .w-track__dot { background: var(--terracotta); border-color: var(--terracotta); }
.w-track__step.is-active .w-track__dot { border-color: var(--terracotta); box-shadow: 0 0 0 4px rgba(194,97,58,0.2); }
.w-track__txt strong { display: block; font-size: 0.95rem; color: var(--texte-doux); transition: color var(--trans); }
.w-track__txt small { font-size: 0.8rem; color: var(--texte-doux); opacity: 0.7; }
.w-track__step.is-done .w-track__txt strong,
.w-track__step.is-active .w-track__txt strong { color: var(--texte); font-weight: 600; }

/* ---- Accessibilité / infos ---- */
.w-acc__lbl { font-size: 0.9rem; color: var(--texte-doux); margin-bottom: 10px; }
.w-acc__fiche { display: flex; flex-wrap: wrap; gap: 8px; margin: 14px 0; min-height: 36px; }
.w-acc__badge { font-size: 0.82rem; font-weight: 600; color: var(--terracotta-fonce); background: var(--creme-2); border: 1px solid rgba(194,97,58,0.25); border-radius: 100px; padding: 6px 13px; }
.w-acc__empty { font-size: 0.85rem; color: var(--texte-doux); font-style: italic; }
