/* =========================================================
   CROUSTY RICE — Feuille de style globale
   Charte : Magenta #DB0471 / Prune #2B0117 / Or #F2A93B
   ========================================================= */

:root{
  --magenta:#DB0471;
  --magenta-soft:#ff2a91;
  --prune:#2B0117;
  --prune-2:#3d0421;
  --or:#F2A93B;
  --blanc:#fff5fa;
  --gris:#f4eef1;
  --rayon:22px;
  --rayon-l:34px;
  --ombre:0 18px 40px -18px rgba(43,1,23,.55);
  --max:1200px;
  --font-display:"Luckiest Guy","Bungee",system-ui,sans-serif;
  --font-body:"Poppins",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--prune);
  background:var(--blanc);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}

.wrap{max-width:var(--max);margin:0 auto;padding:0 20px}
.display{font-family:var(--font-display);font-weight:400;letter-spacing:.5px;line-height:1.02;text-transform:uppercase}
.txt-mag{color:var(--magenta)}
.txt-or{color:var(--or)}
.center{text-align:center}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-display);font-size:1rem;letter-spacing:.5px;
  text-transform:uppercase;
  padding:14px 26px;border-radius:999px;border:3px solid transparent;
  cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .2s;
  line-height:1;white-space:nowrap;
}
.btn:hover{transform:translateY(-3px)}
.btn-mag{background:var(--magenta);color:#fff;box-shadow:0 10px 22px -8px var(--magenta)}
.btn-mag:hover{background:var(--magenta-soft)}
.btn-or{background:var(--or);color:var(--prune)}
.btn-ghost{background:transparent;border-color:#fff;color:#fff}
.btn-ghost:hover{background:#fff;color:var(--magenta)}
.btn-prune{background:var(--prune);color:#fff}
.btn-sm{padding:10px 18px;font-size:.85rem}
.btn-bowl{height:24px;width:auto;display:inline-block;vertical-align:-7px;margin-right:2px;
  filter:drop-shadow(0 2px 3px rgba(0,0,0,.3))}

/* ---------- Bandeau promo défilant ---------- */
.topbar{
  background:var(--or);color:var(--prune);
  font-family:var(--font-display);font-size:.82rem;letter-spacing:1px;
  text-transform:uppercase;padding:7px 0;overflow:hidden;white-space:nowrap;
}
.topbar span{display:inline-block;padding-left:100%;animation:scrollx 18s linear infinite}
@keyframes scrollx{to{transform:translateX(-100%)}}

/* ---------- Header collant ---------- */
.header{
  position:sticky;top:0;z-index:100;
  background:rgba(43,1,23,.92);backdrop-filter:blur(10px);
  border-bottom:2px solid rgba(255,255,255,.06);
}
.header .wrap{display:flex;align-items:center;justify-content:space-between;height:70px;gap:16px}
.logo{font-family:var(--font-display);font-size:1.7rem;color:#fff;display:flex;align-items:center;gap:6px;line-height:1}
.logo b{color:var(--magenta-soft)}
.logo .dot{color:var(--or)}
/* Logo image (extrait du PDF officiel) dans une pastille blanche */
.logo-img{display:inline-flex;align-items:center;background:#ff008e;border-radius:999px;
  padding:8px 16px;box-shadow:0 6px 16px -8px rgba(0,0,0,.5)}
.logo-img img{height:26px;width:auto;display:block}
.footer .logo-img{padding:9px 18px}
.footer .logo-img img{height:24px}
.nav{display:flex;align-items:center;gap:26px}
.nav a{color:#ffd9ec;font-weight:600;font-size:.95rem;position:relative;padding:4px 0}
.nav a:hover,.nav a.active{color:#fff}
.nav a.active::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:3px;background:var(--or);border-radius:3px}
.header-cta{display:flex;align-items:center;gap:12px}

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

@media(max-width:860px){
  .burger{display:flex}
  .nav{
    position:absolute;top:70px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--prune);padding:10px 0;
    transform:translateY(-150%);transition:transform .35s ease;
    box-shadow:var(--ombre);max-height:calc(100vh - 70px);overflow:auto;
  }
  .nav.open{transform:translateY(0)}
  .nav a{padding:14px 24px;width:100%;border-bottom:1px solid rgba(255,255,255,.06)}
  .header-cta .btn-text{display:none}
}

/* ---------- Sections génériques ---------- */
section{padding:72px 0}
.eyebrow{
  display:inline-block;font-family:var(--font-display);color:var(--magenta);
  letter-spacing:1.5px;font-size:.9rem;margin-bottom:10px;text-transform:uppercase;
}
h2.section-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.2rem);line-height:1.05;text-transform:uppercase}
.lead{font-size:1.08rem;color:#5a3344;max-width:62ch}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:88vh;display:flex;align-items:center;
  background:linear-gradient(120deg,var(--prune) 0%,var(--magenta) 120%);
  color:#fff;padding:40px 0;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 30%,rgba(242,169,59,.25),transparent 45%);
}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;position:relative;z-index:2}
.hero h1{font-family:var(--font-display);font-size:clamp(2.6rem,7vw,5rem);line-height:.98;text-transform:uppercase}
.hero h1 .out{ -webkit-text-stroke:2px var(--or);color:transparent}
.hero p.tagline{font-size:1.2rem;margin:18px 0 26px;max-width:46ch;color:#ffe2f1}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-photo{
  position:relative;border-radius:var(--rayon-l);overflow:hidden;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.6);transform:rotate(1.5deg);
  border:5px solid rgba(255,255,255,.12);
}
.hero-photo img{width:100%;aspect-ratio:4/3.2;object-fit:cover}
.sticker{
  position:absolute;background:var(--or);color:var(--prune);
  font-family:var(--font-display);text-transform:uppercase;
  padding:14px 18px;border-radius:50%;transform:rotate(-12deg);
  box-shadow:var(--ombre);text-align:center;line-height:1;font-size:.9rem;z-index:3;
}
.sticker.s1{top:-18px;right:14%;width:96px;height:96px;display:grid;place-items:center}
@media(max-width:860px){
  .hero{min-height:auto}
  .hero .wrap{grid-template-columns:1fr;text-align:center}
  .hero-cta{justify-content:center}
  .hero p.tagline{margin-left:auto;margin-right:auto}
  .hero-photo{order:-1;transform:none}
}
/* ============ Fumée (plat chaud) ============ */
.bowl-steam-wrap{position:relative;display:inline-block;line-height:0}
.steam{position:absolute;left:50%;top:0;transform:translateX(-50%);
  width:78%;height:60%;pointer-events:none;z-index:2;filter:blur(7px)}
.steam i{position:absolute;bottom:0;width:11%;height:80%;border-radius:60% 60% 50% 50%;
  background:linear-gradient(to top,rgba(255,255,255,0),rgba(255,255,255,.6) 45%,rgba(255,255,255,0));
  opacity:0;transform:translateY(10px);animation:steamrise 4.5s ease-in-out infinite}
.steam i:nth-child(1){left:12%;height:70%;animation-delay:0s}
.steam i:nth-child(2){left:28%;height:92%;animation-delay:1.1s}
.steam i:nth-child(3){left:43%;height:100%;animation-delay:.5s}
.steam i:nth-child(4){left:57%;height:94%;animation-delay:2s}
.steam i:nth-child(5){left:71%;height:82%;animation-delay:1.6s}
.steam i:nth-child(6){left:84%;height:68%;animation-delay:2.7s}
@keyframes steamrise{
  0%{opacity:0;transform:translateY(25px) scaleX(1)}
  25%{opacity:.7}
  55%{opacity:.5}
  100%{opacity:0;transform:translateY(-85px) scaleX(1.8)}
}
@media(prefers-reduced-motion:reduce){.steam{display:none}}

/* ============ HERO "PRODUIT DÉTOURÉ" (refonte) ============ */
.hero{padding:0}
.hero-stage{position:relative;width:100%;min-height:90vh;display:flex;align-items:center}
/* Watermark géant en fond */
.hero-watermark{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:32vw;line-height:1;color:rgba(255,255,255,.04);
  pointer-events:none;z-index:1;letter-spacing:-.04em;white-space:nowrap;text-transform:uppercase;
}
.hero-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .7s ease;z-index:1}
.hero-slide.is-active{opacity:1;visibility:visible;z-index:3;position:relative}
.hero-slide .wrap{
  width:100%;display:grid;grid-template-columns:1.05fr .95fr;gap:24px;align-items:center;
  padding:56px 20px 70px;position:relative;z-index:2;
}
/* Colonne produit */
.hero-prod{position:relative;display:flex;justify-content:center}
.hero-bowl{
  width:min(560px,92%);height:auto;
  filter:drop-shadow(0 40px 45px rgba(0,0,0,.55));
  animation:floaty 5s ease-in-out infinite;
}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
/* Bloc NOUVEAU superposé */
.hero-badge{position:absolute;left:0;bottom:6%;z-index:4;max-width:62%}
.tag-new{
  display:inline-block;background:var(--or);color:var(--prune);
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:1px;
  padding:6px 14px;border-radius:8px;font-size:.95rem;transform:rotate(-3deg);margin-bottom:8px;
}
.hero-gamme{
  display:block;font-family:var(--font-display);text-transform:uppercase;color:#fff;
  font-size:clamp(2.4rem,6vw,4.2rem);line-height:.92;
  text-shadow:0 6px 18px rgba(0,0,0,.45);
}
.hero-gamme .hl{
  display:inline-block;background:var(--magenta);color:#fff;padding:2px 14px 4px;border-radius:10px;margin-top:6px;
  box-shadow:0 10px 22px -8px var(--magenta);
}
.hero-badge .btn{margin-top:16px}
.flame{font-size:1.1em;line-height:1}
/* Colonne punchline */
.hero-q{
  font-family:var(--font-display);text-transform:uppercase;color:#fff;
  font-size:clamp(2rem,4.6vw,3.5rem);line-height:1;text-align:left;
  text-shadow:0 4px 14px rgba(0,0,0,.4);
}
.hero-q .o{color:var(--or)}
.hero-q .m{
  display:inline-block;color:#fff;background:var(--magenta);
  -webkit-text-stroke:0;padding:0 10px;border-radius:8px;transform:rotate(-1.5deg);
}
.hero-q-sub{color:#ffd9ec;font-size:1.05rem;margin:18px 0 24px;max-width:42ch}
.hero-q .hero-cta{justify-content:flex-start}
/* Puces */
.hero-dots{position:absolute;bottom:24px;left:0;right:0;z-index:6;display:flex;gap:10px;justify-content:center}
.hero-dot{width:12px;height:12px;border-radius:50%;border:2px solid #fff;background:transparent;cursor:pointer;padding:0;transition:background .25s,transform .25s}
.hero-dot.is-active{background:var(--or);border-color:var(--or);transform:scale(1.2)}
/* Flèches */
.hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:6;
  width:46px;height:46px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,255,255,.14);color:#fff;font-size:1.3rem;display:grid;place-items:center;
  backdrop-filter:blur(4px);transition:background .2s}
.hero-arrow:hover{background:var(--magenta)}
.hero-arrow.prev{left:14px}
.hero-arrow.next{right:14px}

@media(max-width:860px){
  .hero-stage{min-height:auto}
  .hero-slide .wrap{grid-template-columns:1fr;text-align:center;gap:14px;padding:28px 18px 64px}
  .hero-prod{order:-1;flex-direction:column;align-items:center}
  .hero-bowl{width:min(360px,82%)}
  .hero-badge{position:static;max-width:100%;margin-top:10px;display:flex;flex-direction:column;align-items:center}
  .hero-gamme{font-size:clamp(2.2rem,11vw,3rem)}
  .tag-new{transform:none}
  .hero-q{text-align:center}
  .hero-q-sub{margin-left:auto;margin-right:auto}
  .hero-q .hero-cta{justify-content:center}
  .hero-arrow{display:none}
}

/* ---------- Concept ---------- */
.concept .wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.concept-img{border-radius:var(--rayon-l);overflow:hidden;box-shadow:var(--ombre)}
.concept-img img{aspect-ratio:1/1;object-fit:cover;width:100%}
/* Bol détouré qui tourne */
.concept-spin{display:flex;justify-content:center;align-items:center}
.concept-spin img{width:min(460px,90%);height:auto;filter:drop-shadow(0 30px 35px rgba(43,1,23,.35));
  animation:spin360 16s linear infinite;transform-origin:50% 50%}
@keyframes spin360{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){.concept-spin img{animation:none}}
@media(max-width:760px){.concept .wrap{grid-template-columns:1fr}}

/* ---------- Produit signature ---------- */
.signature{background:var(--prune);color:#fff;position:relative;overflow:hidden}
.signature::after{content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(219,4,113,.55),transparent 70%);top:-160px;left:-120px}
.signature .wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:48px;align-items:center;position:relative;z-index:2}
.signature h2{color:#fff}
.signature .lead{color:#ffd2e6}
.sauces{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0}
.sauce-chip{background:rgba(255,255,255,.08);border:2px solid rgba(242,169,59,.5);
  border-radius:999px;padding:8px 16px;font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:6px}
.ico-bbq{vertical-align:middle;color:var(--or)}
.sizes{display:flex;gap:14px;margin:14px 0 26px}
.size-pill{background:var(--or);color:var(--prune);font-family:var(--font-display);
  width:54px;height:54px;border-radius:50%;display:grid;place-items:center;font-size:1.2rem}
.signature-img{border-radius:var(--rayon-l);overflow:hidden;border:5px solid rgba(242,169,59,.4);box-shadow:var(--ombre)}
.signature-img img{aspect-ratio:1/1;object-fit:cover;width:100%}
.signature-cut{display:flex;justify-content:center;align-items:center}
.signature-cut img{width:min(520px,92%);height:auto;
  filter:drop-shadow(0 30px 40px rgba(0,0,0,.5));animation:floaty 5s ease-in-out infinite}
@media(max-width:760px){.signature .wrap{grid-template-columns:1fr}}

/* ---------- Grille nouveautés / cartes produits ---------- */
.grid-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:24px}
.card{
  background:#fff;border-radius:var(--rayon-l);overflow:hidden;
  box-shadow:var(--ombre);transition:transform .2s;display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-6px)}
.card-img{position:relative;overflow:hidden}
.card-img img{aspect-ratio:1/1;object-fit:cover;width:100%;transition:transform .4s}
.card:hover .card-img img{transform:scale(1.06)}
.card-tag{position:absolute;top:12px;left:12px;background:var(--magenta);color:#fff;
  font-family:var(--font-display);font-size:.72rem;padding:6px 12px;border-radius:999px;letter-spacing:.5px}
.card-body{padding:18px 20px 22px;flex:1;display:flex;flex-direction:column;gap:6px}
.card-body h3{font-family:var(--font-display);font-size:1.25rem;text-transform:uppercase;line-height:1.05}
.card-body p{font-size:.92rem;color:#6b4356}
.price{margin-top:auto;font-family:var(--font-display);color:var(--magenta);font-size:1.15rem;padding-top:8px}

/* ---------- Punchline (mur néon) ---------- */
.punch{
  background:var(--prune);color:#fff;text-align:center;position:relative;overflow:hidden;
  padding:88px 0;
}
.punch::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 15% 25%,rgba(219,4,113,.45),transparent 40%),
    radial-gradient(circle at 85% 75%,rgba(242,169,59,.30),transparent 45%);
}
.punch .wrap{position:relative;z-index:2}
.punch .eyebrow{color:var(--or)}
.punch-lines{display:flex;flex-direction:column;gap:6px;align-items:center;margin:6px 0 26px}
.punch-line{
  font-family:var(--font-display);text-transform:uppercase;line-height:1.04;
  font-size:clamp(2.2rem,8vw,4.6rem);letter-spacing:1px;
  color:var(--magenta-soft);
  -webkit-text-stroke:2px var(--or);
  text-shadow:0 0 18px rgba(219,4,113,.6),0 0 38px rgba(219,4,113,.35);
}
.punch-line .star{color:var(--or);-webkit-text-stroke:0}
.punch-eat{color:#fff;-webkit-text-stroke:2px var(--magenta);
  text-shadow:0 0 18px rgba(242,169,59,.7),0 0 38px rgba(242,169,59,.4);margin-top:8px}
.punch p.sub{color:#ffd2e6;max-width:46ch;margin:0 auto 26px;font-size:1.05rem}

/* ---------- Avantages ---------- */
.avantages{background:var(--gris)}
.av-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:22px;margin-top:36px}
.av{background:#fff;border-radius:var(--rayon);padding:28px 22px;text-align:center;box-shadow:var(--ombre)}
.av .ico{width:64px;height:64px;border-radius:50%;background:var(--magenta);color:#fff;
  display:grid;place-items:center;margin:0 auto 14px;font-size:1.7rem}
.av h3{font-family:var(--font-display);font-size:1.1rem;text-transform:uppercase;margin-bottom:6px}
.av p{font-size:.9rem;color:#6b4356}

/* ---------- Franchise (bloc accueil) ---------- */
.franchise-band{
  background:linear-gradient(120deg,var(--magenta),var(--prune));color:#fff;
  border-radius:var(--rayon-l);padding:54px 40px;position:relative;overflow:hidden;
}
.franchise-band::before{content:"";position:absolute;right:-80px;top:-80px;width:280px;height:280px;
  border-radius:50%;background:rgba(242,169,59,.25)}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px;margin:30px 0;position:relative;z-index:2}
.stat{text-align:center}
.stat b{font-family:var(--font-display);font-size:2.6rem;color:var(--or);display:block;line-height:1}
.stat span{font-size:.9rem;color:#ffdcec}

/* ---------- FAQ ---------- */
.faq-list{max-width:760px;margin:36px auto 0}
.faq-item{background:#fff;border-radius:var(--rayon);margin-bottom:14px;box-shadow:var(--ombre);overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;
  padding:20px 24px;font-family:var(--font-display);font-size:1.05rem;text-transform:uppercase;
  display:flex;justify-content:space-between;align-items:center;gap:14px;color:var(--prune)}
.faq-q .plus{color:var(--magenta);font-size:1.6rem;transition:transform .3s;line-height:1}
.faq-item.open .plus{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;padding:0 24px}
.faq-a p{padding-bottom:20px;color:#5a3344}
.faq-item.open .faq-a{max-height:320px}
.editable{background:rgba(242,169,59,.18);border-left:3px solid var(--or);padding:8px 12px;border-radius:6px;font-style:italic;font-size:.92rem}

/* ---------- Footer ---------- */
.footer{background:var(--prune);color:#ffd9ec;padding:56px 0 26px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:32px}
.footer h4{font-family:var(--font-display);color:#fff;text-transform:uppercase;margin-bottom:14px;font-size:1rem;letter-spacing:.5px}
.footer a{display:block;padding:5px 0;color:#ffc8e2;font-size:.92rem}
.footer a:hover{color:#fff}
.footer .logo{font-size:1.5rem;margin-bottom:12px}
.socials{display:flex;gap:12px;margin-top:10px}
.socials a{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;padding:0;color:#fff}
.socials a:hover{background:var(--magenta)}
.socials svg{display:block}
.foot-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:36px;padding-top:20px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem;color:#c89bb1}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Page header (sous-pages) ---------- */
.page-hero{
  background:linear-gradient(120deg,var(--prune),var(--magenta));color:#fff;
  padding:64px 0 56px;text-align:center;position:relative;overflow:hidden;
}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(242,169,59,.22),transparent 50%)}
.page-hero h1{font-family:var(--font-display);font-size:clamp(2.4rem,6vw,4rem);text-transform:uppercase;position:relative}
.page-hero p{position:relative;max-width:60ch;margin:14px auto 0;color:#ffdcec}

/* ---------- Carte (menu) ---------- */
.menu-cat{margin-bottom:56px}
.menu-cat-head{display:flex;align-items:baseline;gap:14px;margin-bottom:8px;flex-wrap:wrap}
.menu-cat-head h2{font-family:var(--font-display);font-size:2rem;text-transform:uppercase}
.menu-cat-head .from{color:var(--magenta);font-weight:700}
.dessert-banner{margin-top:22px;border-radius:var(--rayon-l);overflow:hidden;box-shadow:var(--ombre)}
.dessert-banner img{width:100%;height:auto;display:block;aspect-ratio:16/10;object-fit:cover}

/* ---------- Restaurants ---------- */
.resto-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px}
.resto{background:#fff;border-radius:var(--rayon-l);overflow:hidden;box-shadow:var(--ombre);display:flex;flex-direction:column}
.resto-img{position:relative}
.resto-img img{aspect-ratio:16/10;object-fit:cover;width:100%}
.status{position:absolute;top:14px;left:14px;font-family:var(--font-display);font-size:.78rem;
  padding:6px 14px;border-radius:999px;color:#fff;letter-spacing:.5px;display:flex;align-items:center;gap:6px}
.status.open{background:#1e9e54}
.status.closed{background:#9e1e2f}
.status.soon{background:var(--or);color:var(--prune)}
.status .dotled{width:8px;height:8px;border-radius:50%;background:currentColor}
.resto-body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.resto-body h3{font-family:var(--font-display);font-size:1.5rem;text-transform:uppercase}
.resto-body .addr{color:#6b4356;font-size:.95rem}
.resto-hours{font-size:.88rem;color:#6b4356}
.resto-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:auto;padding-top:8px}
.resto.soon{opacity:.96}
.resto.soon .resto-img img{filter:grayscale(.3)}

/* ---------- Franchise page ---------- */
.fr-args{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:24px;margin-top:36px}
.fr-arg{background:#fff;border-radius:var(--rayon);padding:28px 24px;box-shadow:var(--ombre)}
.fr-arg .ico{width:56px;height:56px;border-radius:16px;background:var(--or);color:var(--prune);
  display:grid;place-items:center;font-size:1.5rem;margin-bottom:14px}
.fr-arg h3{font-family:var(--font-display);text-transform:uppercase;font-size:1.15rem;margin-bottom:6px}
.fr-arg p{font-size:.92rem;color:#6b4356}

/* ---------- Formulaires ---------- */
.form-card{background:#fff;border-radius:var(--rayon-l);box-shadow:var(--ombre);padding:36px;max-width:680px;margin:0 auto;color:var(--prune)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;margin-bottom:6px;font-size:.92rem}
.field input,.field textarea,.field select{
  width:100%;padding:13px 16px;border:2px solid #ecd9e3;border-radius:14px;
  font-family:inherit;font-size:1rem;background:#fff;transition:border .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--magenta)}
.field textarea{min-height:120px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}
.form-success{
  background:#1e9e54;color:#fff;border-radius:var(--rayon);padding:18px 22px;
  font-weight:600;margin-bottom:20px;display:none;align-items:center;gap:10px;
}
.form-success.show{display:flex;animation:pop .3s ease}
@keyframes pop{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-info .info-block{display:flex;gap:14px;margin-bottom:22px}
.contact-info .ico{width:48px;height:48px;border-radius:14px;background:var(--magenta);color:#fff;
  display:grid;place-items:center;font-size:1.2rem;flex-shrink:0}
.contact-info h3{font-family:var(--font-display);text-transform:uppercase;font-size:1.05rem}
.contact-info p{color:#6b4356;font-size:.95rem}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}

/* ---------- Animations apparition au scroll ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ============ Assistant IA (chatbot) ============ */
.chat-fab{position:fixed;right:20px;bottom:20px;z-index:200;width:62px;height:62px;border-radius:50%;
  border:0;cursor:pointer;background:var(--magenta);color:#fff;font-size:1.6rem;
  box-shadow:0 14px 30px -8px rgba(219,4,113,.7);display:grid;place-items:center;
  transition:transform .2s,background .2s}
.chat-fab:hover{transform:scale(1.07);background:var(--magenta-soft)}
.chat-fab .ic-close{display:none}
.chat-fab.open .ic-open{display:none}
.chat-fab.open .ic-close{display:block}
.chat-pop{position:fixed;right:20px;bottom:94px;z-index:200;width:min(380px,calc(100vw - 32px));
  height:min(560px,calc(100vh - 130px));background:#fff;border-radius:22px;overflow:hidden;
  box-shadow:0 26px 60px -16px rgba(43,1,23,.55);display:flex;flex-direction:column;
  opacity:0;visibility:hidden;transform:translateY(16px) scale(.98);
  transition:opacity .25s,transform .25s,visibility .25s}
.chat-pop.open{opacity:1;visibility:visible;transform:none}
.chat-head{background:linear-gradient(120deg,var(--prune),var(--magenta));color:#fff;padding:16px 18px;
  display:flex;align-items:center;gap:12px}
.chat-head .ava{width:42px;height:42px;border-radius:50%;background:var(--or);display:grid;place-items:center;font-size:1.4rem;flex-shrink:0}
.chat-head b{font-family:var(--font-display);font-size:1.05rem;letter-spacing:.3px;display:block;line-height:1.1}
.chat-head span{font-size:.78rem;color:#ffd9ec}
.chat-head .x{margin-left:auto;background:none;border:0;color:#fff;font-size:1.4rem;cursor:pointer;opacity:.85}
.chat-head .x:hover{opacity:1}
.chat-body{flex:1;overflow-y:auto;padding:16px;background:var(--gris);display:flex;flex-direction:column;gap:10px}
.msg{max-width:84%;padding:11px 14px;border-radius:16px;font-size:.92rem;line-height:1.45;animation:pop .25s ease}
.msg.bot{background:#fff;color:var(--prune);align-self:flex-start;border-bottom-left-radius:5px;box-shadow:0 4px 12px -6px rgba(43,1,23,.25)}
.msg.user{background:var(--magenta);color:#fff;align-self:flex-end;border-bottom-right-radius:5px}
.msg a{color:var(--magenta);font-weight:700;text-decoration:underline}
.msg.user a{color:#fff}
.chat-chips{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 12px;background:var(--gris)}
.chip{background:#fff;border:2px solid var(--magenta);color:var(--magenta);border-radius:999px;
  padding:7px 13px;font-size:.82rem;font-weight:600;cursor:pointer;transition:.15s;font-family:inherit}
.chip:hover{background:var(--magenta);color:#fff}
.chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid #eee;background:#fff}
.chat-input input{flex:1;border:2px solid #ecd9e3;border-radius:999px;padding:11px 16px;font-family:inherit;font-size:.92rem}
.chat-input input:focus{outline:none;border-color:var(--magenta)}
.chat-input button{width:44px;height:44px;border-radius:50%;border:0;background:var(--magenta);color:#fff;font-size:1.1rem;cursor:pointer;flex-shrink:0}
.chat-input button:hover{background:var(--magenta-soft)}
@media(max-width:480px){.chat-pop{right:10px;left:10px;width:auto;bottom:88px}}

/* ---------- Pages légales ---------- */
.legal{max-width:820px;margin:0 auto}
.legal h2{font-family:var(--font-display);text-transform:uppercase;font-size:1.5rem;margin:34px 0 10px;color:var(--magenta)}
.legal h2:first-child{margin-top:0}
.legal p,.legal li{color:#4a2a39;font-size:1rem;line-height:1.65}
.legal p{margin-bottom:12px}
.legal ul{margin:0 0 14px 1.2em}
.legal li{margin-bottom:6px;list-style:disc}
.legal a{color:var(--magenta);font-weight:600;text-decoration:underline;display:inline}
.legal .todo{background:rgba(242,169,59,.18);border-left:3px solid var(--or);padding:2px 8px;border-radius:5px;font-style:italic}
.legal .maj{color:#6b4356;font-size:.9rem;margin-bottom:26px}

/* ---------- Divers ---------- */
.bg-prune{background:var(--prune);color:#fff}
.mt-0{margin-top:0}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
}
