/*
Theme Name: POKE UP
Theme URI: https://www.poke-up.com
Author: POKE UP (design Claude Design, intégration Claude Code)
Description: Thème sur mesure POKE UP — poke bowls & bubble teas. Refonte 2026, direction visuelle « Pop Instagrammable ». Pages : accueil, concept, menu, restaurants (+7 fiches), commander, traiteur, franchise, contact, pages légales.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: Proprietary
Text Domain: pokeup
*/

/* ============================================================
   POKE UP — Refonte homepage
   Design system: brand charte + 3 switchable directions
   ============================================================ */

@font-face{
  font-family:"Cookie";
  src:url("assets/fonts/Cookie.ttf") format("truetype");
  font-weight:400;font-style:normal;font-display:swap;
}

/* Brand typography (overrides every direction, on html AND body) */
html[data-direction],body[data-direction]{
  --font-display:"Cookie","Brush Script MT",cursive;
  --font-body:"Futura","Futura PT","Jost","Century Gothic","Avenir Next",system-ui,sans-serif;
}

/* ---- Brand charte (fixed) ---- */
:root{
  --lilas:#c69dc2;
  --lilas-deep:#a87aa3;
  --lilas-soft:#e6d4e4;
  --turquoise:#50b1bd;
  --turquoise-deep:#2f8c98;
  --green:#0f2114;
  --green-soft:#1c3a26;
  --white:#ffffff;
  --cream:#f7f1ee;
  --jaune:#e7be51;
  --rose:#eb8699;
  --rouge:#d94526;

  /* type scale */
  --fs-mega:clamp(50px,7vw,96px);
  --fs-h1:clamp(40px,5.4vw,82px);
  --fs-h2:clamp(32px,3.8vw,58px);
  --fs-h3:clamp(22px,2vw,30px);
  --fs-lead:clamp(18px,1.5vw,23px);
  --fs-body:17px;
  --fs-small:14px;
  --fs-eyebrow:13px;

  /* rhythm */
  --maxw:1320px;
  --gutter:clamp(20px,5vw,64px);
  --sec-pad:clamp(60px,8vw,116px);
  --radius:26px;
  --radius-sm:16px;
  --radius-pill:999px;

  /* defaults overwritten per direction */
  --font-display:"Clash Display","General Sans",sans-serif;
  --font-body:"General Sans",system-ui,sans-serif;
  --ink:var(--green);
  --ink-soft:color-mix(in oklab,var(--green) 64%,#7d8a80);
  --accent:var(--turquoise);
  --accent-ink:var(--green);
  --cta-bg:var(--jaune);
  --cta-ink:var(--green);
  --page-bg:#f3e9ec;
  --card-bg:rgba(255,255,255,.62);
  --card-border:1px solid rgba(255,255,255,.7);
  --card-blur:saturate(140%) blur(14px);
  --card-radius:var(--radius);
  --shadow:0 24px 60px -28px rgba(15,33,20,.4);
  --shadow-soft:0 14px 40px -24px rgba(15,33,20,.35);
}

/* ============================================================
   DIRECTION 1 — Immersif Gourmand  (default, ~ ref image 1)
   warm multi-hue wash, glass cards, big photography
   ============================================================ */
[data-direction="gourmand"]{
  --font-display:"Clash Display",sans-serif;
  --font-body:"General Sans",system-ui,sans-serif;
  --ink:var(--green);
  --accent:var(--turquoise);
  --cta-bg:var(--jaune);
  --cta-ink:var(--green);
  --page-bg:
    radial-gradient(1200px 700px at 8% -5%, color-mix(in oklab,var(--lilas) 70%,#fff) 0%, transparent 55%),
    radial-gradient(1100px 800px at 100% 8%, color-mix(in oklab,var(--rose) 55%,#fff) 0%, transparent 50%),
    radial-gradient(1300px 900px at 60% 100%, color-mix(in oklab,var(--turquoise) 35%,#fff) 0%, transparent 55%),
    linear-gradient(180deg,#f6edf0,#f4efe9);
  --card-bg:rgba(255,255,255,.6);
  --card-border:1px solid rgba(255,255,255,.75);
  --card-blur:saturate(150%) blur(16px);
  --card-radius:28px;
}

/* ============================================================
   DIRECTION 2 — Frais & Éditorial
   airy white, lilas blocks, big editorial type, turquoise
   ============================================================ */
[data-direction="editorial"]{
  --font-display:"Bricolage Grotesque",sans-serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --ink:var(--green);
  --accent:var(--turquoise);
  --cta-bg:var(--green);
  --cta-ink:#fff;
  --radius:14px;
  --radius-sm:10px;
  --card-radius:16px;
  --page-bg:linear-gradient(180deg,#fbfaf8,#f6f3f7);
  --card-bg:#ffffff;
  --card-border:1px solid color-mix(in oklab,var(--lilas) 40%,#fff);
  --card-blur:none;
  --shadow:0 30px 70px -40px rgba(15,33,20,.45);
  --shadow-soft:0 18px 40px -32px rgba(15,33,20,.4);
}

/* ============================================================
   DIRECTION 3 — Pop Instagrammable
   bold colour-blocking, lilas/turquoise sections, energetic
   ============================================================ */
[data-direction="pop"]{
  --font-display:"Clash Display",sans-serif;
  --font-body:"General Sans",system-ui,sans-serif;
  --ink:var(--green);
  --accent:var(--rose);
  --cta-bg:var(--rouge);
  --cta-ink:#fff;
  --radius:30px;
  --radius-sm:18px;
  --card-radius:30px;
  --page-bg:linear-gradient(180deg,#efd9eb 0%,#f4e6ce 100%);
  --card-bg:#ffffff;
  --card-border:1.5px solid color-mix(in oklab,var(--lilas) 52%,#fff);
  --card-blur:none;
  --shadow:0 10px 22px -8px color-mix(in oklab,var(--lilas-deep) 90%,rgba(15,33,20,.7)),0 26px 48px -18px color-mix(in oklab,var(--lilas-deep) 78%,rgba(15,33,20,.5));
  --shadow-soft:0 8px 18px -6px color-mix(in oklab,var(--turquoise-deep) 82%,rgba(15,33,20,.6)),0 20px 38px -16px color-mix(in oklab,var(--turquoise-deep) 60%,rgba(15,33,20,.4));
}

/* ---- reset ---- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--page-bg);
  background-attachment:fixed;
  font-size:var(--fs-body);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
html{overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;line-height:1.1;letter-spacing:0;color:var(--ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}

/* ---- eyebrow ---- */
.eyebrow{
  font-family:var(--font-body);
  font-size:var(--fs-eyebrow);
  font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:currentColor;border-radius:2px}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 26px;border-radius:var(--radius-pill);
  font-family:var(--font-body);font-weight:600;font-size:15px;letter-spacing:.01em;
  transition:transform .25s cubic-bezier(.2,.8,.25,1),box-shadow .25s,background .2s,color .2s;
  white-space:nowrap;
}
.btn .arr{transition:transform .3s}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--cta-bg);color:var(--cta-ink);box-shadow:0 12px 26px -12px color-mix(in oklab,var(--cta-bg) 60%,transparent)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-dark{background:var(--green);color:#fff}
.btn-dark:hover{transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.7)}
.btn-ghost:hover{background:rgba(255,255,255,.16)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid color-mix(in oklab,var(--ink) 35%,transparent)}
.btn-outline:hover{background:var(--ink);color:var(--page-bg, #fff)}
[data-direction="pop"] .btn-primary{box-shadow:0 12px 24px -10px color-mix(in oklab,var(--cta-bg) 75%,transparent)}
[data-direction="pop"] .btn-primary:hover{transform:translate(-1px,-2px);box-shadow:0 16px 30px -10px color-mix(in oklab,var(--cta-bg) 85%,transparent)}

/* ============================================================
   HEADER
   ============================================================ */
.hdr{
  position:fixed;top:0;left:0;right:0;z-index:60;
  transition:background .35s,backdrop-filter .35s,box-shadow .35s,padding .35s;
  padding:22px 0;
}
.hdr.scrolled{
  background:color-mix(in oklab,var(--page-bg) 78%,#fff 22%);
  backdrop-filter:saturate(160%) blur(16px);
  box-shadow:0 1px 0 rgba(15,33,20,.08);
  padding:12px 0;
}
.hdr-in{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:11px}
.brand-logo{height:34px;width:auto;display:block}
.hdr.scrolled .brand-logo{height:29px;transition:height .35s}
.drawer .brand-logo{height:36px}
.foot-brand .brand-logo{height:40px;margin-bottom:18px}
.brand .mark{
  width:38px;height:38px;border-radius:12px;flex:none;
  background:var(--lilas);color:#fff;display:grid;place-items:center;
  box-shadow:0 8px 18px -8px var(--lilas-deep);
}
.brand .mark svg{width:21px;height:21px}
.nav{display:flex;align-items:center;gap:28px}
.nav a{font-size:15px;font-weight:500;color:var(--ink);position:relative;padding:4px 0;opacity:.82;transition:opacity .2s}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--accent);transition:right .28s cubic-bezier(.2,.8,.25,1)}
.nav a:hover{opacity:1}
.nav a:hover::after{right:0}
.hdr-actions{display:flex;align-items:center;gap:14px}
.icon-btn{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:color-mix(in oklab,var(--ink) 92%,#fff);color:#fff;position:relative;transition:transform .2s}
.icon-btn:hover{transform:translateY(-2px)}
.icon-btn svg{width:20px;height:20px}
.cart-count{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:var(--rouge);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;font-family:var(--font-body);transition:transform .3s}
.cart-count.pop{transform:scale(1.4)}
.burger{display:none;width:46px;height:46px;border-radius:14px;background:color-mix(in oklab,var(--ink) 92%,#fff);color:#fff;place-items:center}
.burger svg{width:22px;height:22px}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:80;background:var(--green);color:#fff;display:flex;flex-direction:column;padding:28px var(--gutter);transform:translateY(-100%);transition:transform .5s cubic-bezier(.5,0,.1,1);visibility:hidden}
.drawer.open{transform:translateY(0);visibility:visible}
.drawer-top{display:flex;justify-content:space-between;align-items:center}
.drawer .brand{color:#fff}
.drawer nav{display:flex;flex-direction:column;gap:6px;margin-top:auto;margin-bottom:auto}
.drawer nav a{font-family:var(--font-display);font-size:clamp(34px,9vw,58px);font-weight:600;color:#fff;opacity:.9}
.drawer-foot{display:flex;gap:14px;flex-wrap:wrap}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding-top:max(104px,12vh);padding-bottom:40px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:40px;align-items:center;width:100%}
.hero-copy{max-width:620px;position:relative;z-index:3}
.hero h1{font-size:var(--fs-mega);font-weight:400;letter-spacing:0;line-height:1.04;margin:14px 0 0}
.hero h1 em{font-style:normal;color:var(--lilas-deep)}
[data-direction="editorial"] .hero h1 em{color:var(--turquoise-deep)}
[data-direction="pop"] .hero h1 em{color:var(--rouge)}
.hero .lead{font-size:var(--fs-lead);color:var(--ink-soft);margin-top:18px;max-width:30ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.hero-cta .btn-ghost{color:var(--ink);border-color:color-mix(in oklab,var(--ink) 32%,transparent)}
.hero-cta .btn-ghost:hover{background:var(--ink);color:#fff}
.hero-tags{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px}
.tag{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:var(--radius-pill);background:var(--card-bg);border:var(--card-border);-webkit-backdrop-filter:var(--card-blur);backdrop-filter:var(--card-blur);font-size:13px;font-weight:600;color:var(--ink)}
.tag svg{width:16px;height:16px;color:var(--accent)}

/* hero visual */
.hero-visual{position:relative;z-index:2;aspect-ratio:1/1.04;max-height:min(72vh,620px);margin-inline:auto}
.hero-bowl{position:absolute;inset:0;border-radius:50%;overflow:visible}
.hero-bowl .img-slot{width:100%;height:100%;display:block}
.hero-ring{position:absolute;inset:-4% ;border-radius:50%;border:1.5px dashed color-mix(in oklab,var(--turquoise) 55%,#fff);animation:spin 60s linear infinite}
@media (prefers-reduced-motion:reduce){.hero-ring{animation:none}}
@keyframes spin{to{transform:rotate(360deg)}}
.float-badge{position:absolute;z-index:4;background:var(--card-bg);border:var(--card-border);-webkit-backdrop-filter:var(--card-blur);backdrop-filter:var(--card-blur);box-shadow:var(--shadow-soft);border-radius:18px;padding:13px 16px;display:flex;align-items:center;gap:11px}
.float-badge .ico{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex:none}
.float-badge .t1{font-family:var(--font-display);font-weight:600;font-size:18px;line-height:1}
.float-badge .t2{font-size:12px;color:var(--ink-soft);margin-top:3px}
.fb-rating{top:8%;left:-6%;animation:floaty 6s ease-in-out infinite}
.fb-price{bottom:14%;right:-4%;animation:floaty 7s ease-in-out infinite .6s}
.fb-bubble{bottom:-2%;left:6%;animation:floaty 8s ease-in-out infinite .3s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media (prefers-reduced-motion:reduce){.float-badge{animation:none!important}}

/* scroll cue */
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);z-index:3}
.scroll-cue .dot{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(10px);opacity:1}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{background:var(--green);color:#fff;padding:22px 0;overflow:hidden;position:relative}
[data-direction="pop"] .marquee{background:var(--turquoise)}
.marquee-track{display:flex;gap:0;width:max-content;animation:march 38s linear infinite}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{font-family:var(--font-display);font-size:clamp(20px,2.4vw,34px);font-weight:500;padding:0 30px;display:flex;align-items:center;gap:30px;white-space:nowrap}
.marquee span::after{content:"✺";color:var(--jaune);font-size:.7em}
@keyframes march{to{transform:translateX(-50%)}}

/* ============================================================
   SECTION GENERIC
   ============================================================ */
section{position:relative}
.sec{padding-block:var(--sec-pad)}
.sec-head{max-width:760px;margin-bottom:clamp(40px,5vw,68px)}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:var(--fs-h2);margin-top:16px}
.sec-head p{font-size:var(--fs-lead);color:var(--ink-soft);margin-top:18px}

/* reveal — visible by default; .in plays an entrance FROM hidden.
   This guarantees content can never get stuck invisible if the
   IntersectionObserver's initial callback is delayed. */
@media (prefers-reduced-motion:no-preference){
  .reveal.in{animation:revUp .7s cubic-bezier(.2,.8,.25,1) both}
  .reveal[data-d="1"].in{animation-delay:.06s}
  .reveal[data-d="2"].in{animation-delay:.14s}
  .reveal[data-d="3"].in{animation-delay:.22s}
  .reveal[data-d="4"].in{animation-delay:.30s}
}
@keyframes revUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
body.no-anim .reveal.in{animation:none}

/* ============================================================
   NOTRE DUO
   ============================================================ */
.duo-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.duo-card{position:relative;border-radius:var(--card-radius);overflow:hidden;min-height:380px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;box-shadow:var(--shadow)}
.duo-card .img-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.duo-card .scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,transparent 30%,rgba(15,33,20,.82))}
.duo-card .duo-body{position:relative;z-index:2;pointer-events:none;padding:34px}
.duo-card .chip{display:inline-block;background:var(--accent);color:#fff;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:7px 13px;border-radius:999px;margin-bottom:14px}
.duo-card.poke .chip{background:var(--turquoise)}
.duo-card.bubble .chip{background:var(--lilas-deep)}
.duo-card h3{color:#fff;font-size:clamp(28px,3vw,40px)}
.duo-card p{margin-top:10px;color:rgba(255,255,255,.86);max-width:38ch}
.duo-vs{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:5;width:74px;height:74px;border-radius:50%;background:var(--jaune);color:var(--green);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:20px;box-shadow:0 14px 30px -14px rgba(0,0,0,.5)}

/* ============================================================
   SIGNATURES
   ============================================================ */
.sig-rail{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.sig-card{position:relative;background:var(--card-bg);border:var(--card-border);-webkit-backdrop-filter:var(--card-blur);backdrop-filter:var(--card-blur);border-radius:var(--card-radius);padding:16px;box-shadow:var(--shadow-soft);transition:transform .35s cubic-bezier(.2,.8,.25,1),box-shadow .35s;overflow:hidden}
.sig-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.sig-img{position:relative;aspect-ratio:1/1;border-radius:18px;overflow:hidden;margin-bottom:14px}
.sig-img .img-slot{width:100%;height:100%}
.sig-card:hover .sig-img .img-slot{transform:scale(1.06)}
.sig-img .img-slot{transition:transform .5s}
.sig-fav{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.9);display:grid;place-items:center;color:var(--rose);z-index:3}
.sig-fav svg{width:17px;height:17px}
.sig-tier{position:absolute;top:10px;left:10px;background:var(--green);color:#fff;font-size:11px;font-weight:700;padding:5px 10px;border-radius:999px;z-index:3}
.sig-name{font-family:var(--font-display);font-weight:600;font-size:21px;line-height:1.1}
.sig-desc{font-size:13px;color:var(--ink-soft);margin-top:3px;min-height:34px}
.sig-foot{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.sig-price{font-family:var(--font-display);font-weight:600;font-size:20px}
.sig-add{width:42px;height:42px;border-radius:13px;background:var(--cta-bg);color:var(--cta-ink);display:grid;place-items:center;transition:transform .2s}
.sig-add:hover{transform:scale(1.08) rotate(90deg)}
.sig-add svg{width:20px;height:20px}

/* ============================================================
   RESTAURANTS / MAP
   ============================================================ */
.resto-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:34px;align-items:stretch}
.resto-col{position:relative}
.resto-col::after{content:"";position:absolute;left:0;right:8px;bottom:0;height:46px;pointer-events:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);background:linear-gradient(transparent,color-mix(in oklab,var(--page-bg) 80%,#fff 20%))}
.resto-col.at-end::after{opacity:0;transition:opacity .3s}
.resto-list{display:flex;flex-direction:column;gap:10px;max-height:560px;overflow-y:auto;padding:2px 10px 8px 2px;scrollbar-width:thin;scrollbar-color:color-mix(in oklab,var(--lilas) 65%,#fff) transparent}
.resto-list::-webkit-scrollbar{width:6px}
.resto-list::-webkit-scrollbar-track{background:transparent}
.resto-list::-webkit-scrollbar-thumb{background:color-mix(in oklab,var(--lilas) 65%,#fff);border-radius:6px}
.resto-item{display:flex;gap:14px;padding:15px 16px;border-radius:var(--radius-sm);background:var(--card-bg);border:var(--card-border);-webkit-backdrop-filter:var(--card-blur);backdrop-filter:var(--card-blur);cursor:pointer;transition:transform .25s,box-shadow .25s,border-color .25s}
.resto-item:hover,.resto-item.active{transform:translateX(4px);box-shadow:var(--shadow-soft);border-color:var(--accent)}
.resto-item .num{width:34px;height:34px;border-radius:11px;flex:none;background:var(--green);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:400;font-size:19px}
.resto-item.active .num{background:var(--accent)}
.resto-item h4{font-family:var(--font-display);font-size:21px;line-height:1.15}
.resto-item .addr{font-size:13.5px;color:var(--ink-soft);margin-top:2px}
.resto-item .meta{display:flex;gap:14px;margin-top:8px;font-size:12.5px;color:var(--ink-soft);flex-wrap:wrap}
.resto-item .meta span{white-space:nowrap}
.resto-item .meta b{color:var(--turquoise-deep);font-weight:600}
/* collapse detail for inactive items so 7 stay compact */
.resto-item .meta,.resto-item .resto-links{display:none}
.resto-item.active .meta{display:flex;margin-top:8px}
.resto-item.active .resto-links{display:flex;margin-top:12px}
.resto-item .quick{font-size:12.5px;color:var(--ink-soft);margin-top:4px}
.resto-item.active .quick{display:none}
.resto-links{display:flex;gap:8px;margin-top:12px}
.resto-links a{font-size:12.5px;font-weight:600;padding:7px 13px;border-radius:999px;background:color-mix(in oklab,var(--accent) 16%,#fff);color:var(--accent-ink)}
.resto-links a.go{background:var(--green);color:#fff}
.map-wrap{position:relative;border-radius:var(--card-radius);overflow:hidden;background:linear-gradient(160deg,#e8f3f1,#ede6f0);box-shadow:var(--shadow);min-height:520px}
.map-canvas{position:absolute;inset:0}
.map-canvas svg{width:100%;height:100%;opacity:.9}
.pin{position:absolute;transform:translate(-50%,-100%);z-index:4;cursor:pointer}
.pin .dot{width:30px;height:30px;border-radius:50% 50% 50% 0;background:var(--lilas-deep);transform:rotate(-45deg);border:3px solid #fff;box-shadow:0 8px 16px -6px rgba(0,0,0,.4);transition:transform .25s,background .25s}
.pin.active .dot,.pin:hover .dot{background:var(--rouge);transform:rotate(-45deg) scale(1.25)}
.pin .lbl{position:absolute;bottom:140%;left:50%;transform:translateX(-50%);background:var(--green);color:#fff;font-size:12px;font-weight:600;padding:5px 11px;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s}
.pin.active .lbl,.pin:hover .lbl{opacity:1}
.map-tag{position:absolute;top:18px;left:18px;z-index:5;background:#fff;border-radius:12px;padding:10px 15px;font-size:13px;font-weight:600;box-shadow:var(--shadow-soft);display:flex;align-items:center;gap:9px}
.map-tag b{font-family:var(--font-display)}

/* ============================================================
   AMBIANCE MOSAIC
   ============================================================ */
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.mosaic .img-slot{width:100%;height:100%;border-radius:18px;overflow:hidden}
.m-tall{grid-row:span 2}
.m-wide{grid-column:span 2}
.amb-quote{grid-column:span 2;grid-row:span 1;background:var(--lilas);color:#fff;border-radius:18px;padding:26px;display:flex;flex-direction:column;justify-content:center}
.amb-quote .q{font-family:var(--font-display);font-size:clamp(20px,1.9vw,27px);font-weight:600;line-height:1.15}
.amb-quote .who{margin-top:12px;font-size:13px;opacity:.85}

/* ============================================================
   CHIFFRES
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.stat{text-align:center}
.stat .big{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,5vw,68px);line-height:1;color:var(--ink)}
.stat .big .u{color:var(--accent)}
.stat .lbl{font-size:14px;color:var(--ink-soft);margin-top:10px}

/* ============================================================
   FRANCHISE
   ============================================================ */
.franchise{position:relative;border-radius:var(--card-radius);overflow:hidden;background:var(--green);color:#fff;padding:clamp(40px,6vw,76px)}
[data-direction="pop"] .franchise{background:var(--lilas-deep)}
.franchise::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,color-mix(in oklab,var(--turquoise) 60%,transparent),transparent 70%)}
.fr-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center}
.franchise .eyebrow{color:var(--jaune)}
.franchise h2{color:#fff;font-size:var(--fs-h2);margin-top:16px}
.franchise p{color:rgba(255,255,255,.84);font-size:var(--fs-lead);margin-top:18px;max-width:46ch}
.fr-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fr-stat{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:20px}
.fr-stat .n{font-family:var(--font-display);font-weight:700;font-size:30px;color:var(--jaune)}
.fr-stat .t{font-size:13px;color:rgba(255,255,255,.78);margin-top:5px}
.franchise .btn-primary{margin-top:30px}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--green);color:rgba(255,255,255,.78);padding-top:clamp(60px,7vw,96px);margin-top:clamp(60px,8vw,120px)}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;padding-bottom:50px}
.foot-brand .brand{color:#fff;margin-bottom:18px}
.foot-brand p{max-width:34ch;font-size:14.5px}
.foot-social{display:flex;gap:10px;margin-top:20px}
.foot-social a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.1);display:grid;place-items:center;color:#fff;transition:background .2s,transform .2s}
.foot-social a:hover{background:var(--lilas);transform:translateY(-2px)}
.foot-social svg{width:18px;height:18px}
.foot-col h5{color:#fff;font-family:var(--font-display);font-size:15px;letter-spacing:.04em;margin-bottom:16px}
.foot-col a{display:block;font-size:14px;padding:6px 0;transition:color .2s}
.foot-col a:hover{color:var(--lilas)}
.deliver{display:flex;gap:8px;flex-wrap:wrap}
.deliver a{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;background:rgba(255,255,255,.08);padding:8px 13px;border-radius:999px;color:#fff}
.deliver a:hover{background:rgba(255,255,255,.16)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:13px}
.foot-bottom .links{display:flex;gap:22px;flex-wrap:wrap}

/* ============================================================
   IMAGE-SLOT empty-state styling (on-brand placeholders)
   ============================================================ */
.img-slot{ color:var(--green)!important; }
.img-slot::part(frame){
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.6) 0 11px, rgba(255,255,255,0) 11px 22px),
    linear-gradient(135deg,color-mix(in oklab,var(--lilas) 62%,#fff),color-mix(in oklab,var(--turquoise) 52%,#fff));
}
.img-slot::part(ring){ border-color:color-mix(in oklab,var(--green) 42%,transparent)!important; border-width:1.5px; }
[data-direction="pop"] .img-slot::part(frame){
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.55) 0 14px, rgba(255,255,255,0) 14px 28px),
    linear-gradient(135deg,color-mix(in oklab,var(--lilas) 60%,#fff),color-mix(in oklab,var(--jaune) 40%,#fff));
}

/* ============================================================
   POP FLASH — extra colour & motion (tuned for the Pop direction)
   ============================================================ */

/* punchier pop entrance with overshoot */
@media (prefers-reduced-motion:no-preference){
  [data-direction="pop"] .reveal.in{animation-name:popIn}
}
@keyframes popIn{
  0%{opacity:0;transform:translateY(28px) scale(.95)}
  62%{opacity:1;transform:translateY(-5px) scale(1.012)}
  100%{opacity:1;transform:none}
}

/* floating sprinkles / confetti */
.hero-fx{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.spr{position:absolute;display:block;opacity:.92;animation:floatSpr var(--dur,9s) ease-in-out infinite;animation-delay:var(--dl,0s);will-change:transform}
.spr.dot{border-radius:50%}
.spr.sq{border-radius:5px}
.spr.ring{border-radius:50%;background:transparent!important;border:4px solid currentColor}
.spr svg{width:100%;height:100%;display:block}
@keyframes floatSpr{
  0%,100%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(-28px) rotate(var(--rot,40deg))}
}

/* drifting soft colour blobs behind the whole page (pop only) */
.pop-blobs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;display:none}
[data-direction="pop"] .pop-blobs{display:block}
.pop-blobs i{position:absolute;width:46vmax;height:46vmax;border-radius:50%;filter:blur(70px);opacity:.38;animation:drift 22s ease-in-out infinite}
@keyframes drift{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(6%,-5%) scale(1.12)}
  66%{transform:translate(-5%,6%) scale(.92)}
}

/* rising bubbles inside the bubble-tea card */
.bubbles{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.bubbles i{position:absolute;bottom:-24px;border-radius:50%;background:rgba(255,255,255,.55);box-shadow:inset 0 0 6px rgba(255,255,255,.6);animation:rise var(--rd,6.5s) linear infinite;animation-delay:var(--bd,0s)}
@keyframes rise{
  0%{transform:translateY(0) scale(.5);opacity:0}
  12%{opacity:.85}
  100%{transform:translateY(-440px) scale(1.05);opacity:0}
}

/* animated gradient text on the emphasised hero words */
[data-direction="pop"] .hero h1 em{
  background:linear-gradient(90deg,var(--rouge),var(--lilas-deep),var(--turquoise-deep),var(--jaune),var(--rouge));
  background-size:300% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:shimmer 7s linear infinite;
}
@keyframes shimmer{to{background-position:300% 0}}

/* glowing, breathing primary CTA in the hero (pop) */
[data-direction="pop"] .hero-cta .btn-primary{animation:ctaGlow 2.8s ease-in-out infinite}
@keyframes ctaGlow{
  0%,100%{box-shadow:0 12px 24px -10px color-mix(in oklab,var(--cta-bg) 75%,transparent)}
  50%{box-shadow:0 14px 28px -10px color-mix(in oklab,var(--cta-bg) 80%,transparent),0 0 0 6px color-mix(in oklab,var(--cta-bg) 18%,transparent)}
}

/* playful card tilts (pop) */
[data-direction="pop"] .sig-card{transition:transform .35s cubic-bezier(.2,1.3,.35,1),box-shadow .35s}
[data-direction="pop"] .sig-card:hover{transform:translateY(-10px) rotate(-1.4deg)}
[data-direction="pop"] .sig-card:nth-child(even):hover{transform:translateY(-10px) rotate(1.4deg)}
[data-direction="pop"] .duo-card{transition:transform .4s cubic-bezier(.2,1.2,.35,1),box-shadow .35s}
[data-direction="pop"] .duo-card:hover{transform:translateY(-7px) rotate(.6deg)}
[data-direction="pop"] .resto-item:hover{transform:translateX(5px) rotate(-.5deg)}

/* bouncing "&" badge */
.duo-vs{animation:vsBounce 2.8s ease-in-out infinite}
@keyframes vsBounce{
  0%,100%{transform:translate(-50%,-50%) scale(1) rotate(0)}
  50%{transform:translate(-50%,-50%) scale(1.13) rotate(10deg)}
}

/* tier badges get a little wiggle on hover */
[data-direction="pop"] .sig-card:hover .sig-tier{animation:wiggle .5s ease}
@keyframes wiggle{0%,100%{transform:rotate(0)}25%{transform:rotate(-6deg)}75%{transform:rotate(6deg)}}

/* spinning marquee sparkles + framed band (pop) */
[data-direction="pop"] .marquee{border-top:4px solid var(--green);border-bottom:4px solid var(--green)}
[data-direction="pop"] .marquee span::after{display:inline-block;transform-origin:center;animation:spinSep 4.5s linear infinite}
@keyframes spinSep{to{transform:rotate(360deg)}}

/* pin pop when it becomes active */
.pin.active .dot{animation:pinPop .5s cubic-bezier(.2,1.5,.4,1)}
@keyframes pinPop{
  0%{transform:rotate(-45deg) scale(.5)}
  60%{transform:rotate(-45deg) scale(1.45)}
  100%{transform:rotate(-45deg) scale(1.25)}
}

/* stat numbers spring in (pop) */
[data-direction="pop"] .stats.in .big{animation:statPop .65s cubic-bezier(.2,1.5,.4,1) both}
.stats.in .stat:nth-child(1) .big{animation-delay:.04s}
.stats.in .stat:nth-child(2) .big{animation-delay:.14s}
.stats.in .stat:nth-child(3) .big{animation-delay:.24s}
.stats.in .stat:nth-child(4) .big{animation-delay:.34s}
@keyframes statPop{0%{transform:scale(.4);opacity:0}70%{transform:scale(1.16);opacity:1}100%{transform:scale(1)}}

/* per-card "Commander" mini CTA that replaced the + button */
.sig-go{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:13px;font-weight:700;padding:9px 15px;border-radius:var(--radius-pill);background:var(--cta-bg);color:var(--cta-ink);transition:transform .22s,box-shadow .22s}
.sig-go .arr{transition:transform .25s}
.sig-card:hover .sig-go .arr{transform:translateX(3px)}
[data-direction="pop"] .sig-go{box-shadow:0 8px 18px -8px color-mix(in oklab,var(--cta-bg) 70%,transparent)}
[data-direction="pop"] .sig-go:hover{transform:translateY(-1px);box-shadow:0 12px 22px -8px color-mix(in oklab,var(--cta-bg) 80%,transparent)}

@media (prefers-reduced-motion:reduce){
  .spr,.pop-blobs i,.bubbles i,.duo-vs,
  [data-direction="pop"] .hero-cta .btn-primary,
  [data-direction="pop"] .hero h1 em,
  [data-direction="pop"] .marquee span::after,
  [data-direction="pop"] .stats.in .big{animation:none!important}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .nav{display:none}
  .burger{display:grid}
  .hero{min-height:auto;padding-top:128px;padding-bottom:54px;align-items:flex-start}
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero-visual{max-width:420px;margin:0 auto;width:100%}
  .scroll-cue{display:none}
  .resto-grid{grid-template-columns:1fr}
  .map-wrap{min-height:380px;order:-1}
  .fr-grid{grid-template-columns:1fr;gap:30px}
  .foot-top{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .sig-rail{grid-template-columns:repeat(2,1fr)}
  .duo-grid{grid-template-columns:1fr}
  .duo-vs{position:static;transform:none;margin:-12px auto;display:none}
  .mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .amb-quote{grid-column:span 2}
  .stats{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:520px){
  .sig-rail{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr}
  .hdr-actions .commander-txt{display:none}
  .float-badge{padding:10px 12px}
  .fb-rating{left:0}
  .fb-price{right:0}
}

/* ============================================================
   SUBPAGES — shared components
   ============================================================ */
.page-hero{position:relative;padding-top:clamp(148px,17vh,212px);padding-bottom:clamp(48px,7vw,92px);overflow:hidden}
.page-hero .wrap{position:relative;z-index:2}
.page-hero.center{text-align:center}
.page-hero h1{font-size:clamp(50px,7.4vw,108px);line-height:1;margin-top:14px}
.page-hero h1 em{font-style:normal;color:var(--rouge)}
[data-direction="pop"] .page-hero h1 em{
  background:linear-gradient(90deg,var(--rouge),var(--lilas-deep),var(--turquoise-deep),var(--jaune),var(--rouge));
  background-size:300% 100%;-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;animation:shimmer 7s linear infinite;
}
.page-hero .lead{font-size:var(--fs-lead);color:var(--ink-soft);margin-top:22px;max-width:56ch}
.page-hero.center .lead{margin-inline:auto}
.page-hero .hero-cta{margin-top:32px}
.page-hero.center .hero-cta{justify-content:center}
.page-hero .hero-cta .btn-ghost{color:var(--ink);border-color:color-mix(in oklab,var(--ink) 32%,transparent)}
.page-hero .hero-cta .btn-ghost:hover{background:var(--ink);color:#fff}

/* split feature rows */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.split + .split{margin-top:clamp(48px,7vw,100px)}
.split.rev .split-media{order:2}
.split-media{position:relative;border-radius:var(--card-radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3}
.split-media .img-slot{width:100%;height:100%}
.split-body .eyebrow{margin-bottom:14px}
.split-body h2{font-size:var(--fs-h2)}
.split-body p{margin-top:16px;color:var(--ink-soft);font-size:var(--fs-lead)}
.tick-list{margin-top:24px;display:flex;flex-direction:column;gap:13px}
.tick-list li{list-style:none;display:flex;gap:13px;align-items:flex-start;font-weight:500;font-size:16px}
.tick-list .tk{flex:none;width:26px;height:26px;border-radius:8px;background:var(--accent);color:#fff;display:grid;place-items:center;margin-top:1px}
.tick-list .tk svg{width:15px;height:15px}

/* numbered steps */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.steps.three{grid-template-columns:repeat(3,1fr)}
.steps.five{grid-template-columns:repeat(5,1fr)}
.step{position:relative;background:var(--card-bg);border:var(--card-border);border-radius:var(--card-radius);padding:26px;box-shadow:var(--shadow-soft)}
.step .sn{width:50px;height:50px;border-radius:15px;background:var(--green);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-size:28px;margin-bottom:15px}
.step:nth-child(5n+1) .sn{background:var(--turquoise)}
.step:nth-child(5n+2) .sn{background:var(--lilas-deep)}
.step:nth-child(5n+3) .sn{background:var(--rouge)}
.step:nth-child(5n+4) .sn{background:var(--turquoise-deep)}
.step:nth-child(5n+5) .sn{background:var(--jaune);color:var(--green)}
.step h3{font-size:21px}
.step p{margin-top:8px;font-size:14px;color:var(--ink-soft)}

/* values grid */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.value{background:var(--card-bg);border:var(--card-border);border-radius:var(--card-radius);padding:28px;box-shadow:var(--shadow-soft);transition:transform .3s}
[data-direction="pop"] .value:hover{transform:translateY(-6px) rotate(-1deg)}
.value .vico{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;color:#fff;margin-bottom:16px}
.value .vico svg{width:26px;height:26px}
.value h3{font-size:22px}
.value p{margin-top:8px;font-size:14px;color:var(--ink-soft)}

/* pricing / formules */
.formules{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.formule{position:relative;background:var(--card-bg);border:var(--card-border);border-radius:var(--card-radius);padding:32px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column}
.formule.feat{background:var(--green);color:#fff;border-color:var(--green)}
[data-direction="pop"] .formule.feat{background:var(--lilas-deep)}
.formule .ftag{position:absolute;top:-13px;left:32px;background:var(--jaune);color:var(--green);font-family:var(--font-body);font-weight:700;font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:6px 13px;border-radius:999px}
.formule .fname{font-family:var(--font-display);font-size:28px}
.formule .price{font-family:var(--font-display);font-size:44px;line-height:1;margin:12px 0 4px}
.formule .price small{font-size:16px;font-family:var(--font-body);color:var(--ink-soft);font-weight:600}
.formule.feat .price small{color:rgba(255,255,255,.7)}
.formule ul{list-style:none;margin:20px 0 24px;display:flex;flex-direction:column;gap:11px}
.formule li{display:flex;gap:11px;font-size:14.5px;align-items:flex-start}
.formule li .tk{flex:none;width:20px;height:20px;border-radius:6px;background:var(--accent);color:#fff;display:grid;place-items:center;margin-top:1px}
.formule.feat li .tk{background:var(--jaune);color:var(--green)}
.formule li .tk svg{width:12px;height:12px}
.formule .btn{margin-top:auto;justify-content:center}

/* menu page */
.menu-nav{position:sticky;top:70px;z-index:30;display:flex;gap:10px;flex-wrap:wrap;padding:14px 0;margin-bottom:10px;background:color-mix(in oklab,var(--page-bg) 82%,#fff 18%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
.menu-nav a{padding:10px 18px;border-radius:999px;background:var(--card-bg);border:var(--card-border);font-weight:600;font-size:14px;transition:background .2s,color .2s,transform .2s}
.menu-nav a:hover{transform:translateY(-2px)}
.menu-nav a.active{background:var(--green);color:#fff}
.menu-cat{padding-top:clamp(40px,5vw,64px);padding-bottom:clamp(48px,7vw,96px);scroll-margin-top:140px}
.menu-cat > .eyebrow{margin-bottom:10px}
.menu-cat h2{font-size:var(--fs-h2)}
.menu-cat .cat-intro{color:var(--ink-soft);font-size:var(--fs-lead);margin-top:12px;max-width:60ch}
.menu-list{display:grid;grid-template-columns:1fr 1fr;gap:4px 44px;margin-top:26px}
.menu-row{display:flex;gap:16px;align-items:flex-start;padding:16px 0;border-bottom:1.5px dashed color-mix(in oklab,var(--ink) 16%,transparent)}
.menu-row .mthumb{width:66px;height:66px;border-radius:15px;overflow:hidden;flex:none}
.menu-row .mthumb .img-slot{width:100%;height:100%}
.menu-row .mbody{flex:1;min-width:0}
.menu-row h4{font-family:var(--font-display);font-size:22px;line-height:1.1}
.menu-row p{font-size:13.5px;color:var(--ink-soft);margin-top:4px}
.menu-row .mprice{font-family:var(--font-display);font-size:22px;white-space:nowrap;color:var(--ink)}
.menu-row .mtag{display:inline-block;font-family:var(--font-body);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:999px;background:color-mix(in oklab,var(--turquoise) 18%,#fff);color:var(--turquoise-deep);margin-left:8px;vertical-align:middle}

/* order options (commander) */
.order-opts{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.order-opt{display:flex;gap:18px;align-items:center;background:var(--card-bg);border:var(--card-border);border-radius:var(--card-radius);padding:24px;box-shadow:var(--shadow-soft);transition:transform .25s,box-shadow .25s}
.order-opt:hover{transform:translateY(-5px)}
[data-direction="pop"] .order-opt:hover{transform:translateY(-5px) rotate(-.6deg)}
.order-opt .oico{width:60px;height:60px;border-radius:17px;display:grid;place-items:center;color:#fff;flex:none;font-family:var(--font-display);font-size:24px}
.order-opt .oico svg{width:28px;height:28px}
.order-opt .obody{flex:1}
.order-opt h3{font-size:23px}
.order-opt p{font-size:14px;color:var(--ink-soft);margin-top:4px}
.order-opt .arr{margin-left:8px;font-size:22px;color:var(--accent);transition:transform .25s}
.order-opt:hover .arr{transform:translateX(5px)}

/* forms */
.form{max-width:760px;margin:0 auto;background:var(--card-bg);border:var(--card-border);border-radius:var(--card-radius);padding:clamp(26px,4vw,46px);box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1/-1}
.field label{font-size:13px;font-weight:700;letter-spacing:.02em}
.field input,.field select,.field textarea{font-family:inherit;font-size:15px;padding:13px 15px;border-radius:14px;border:1.5px solid color-mix(in oklab,var(--ink) 18%,transparent);background:#fff;color:var(--ink);transition:border-color .2s,box-shadow .2s;width:100%}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 20%,transparent)}
.field input.invalid,.field select.invalid,.field textarea.invalid{border-color:var(--rouge);box-shadow:0 0 0 4px color-mix(in oklab,var(--rouge) 18%,transparent)}
.btn-submit{margin-top:6px;justify-content:center;width:100%}
.form-note{font-size:12.5px;color:var(--ink-soft);margin-top:14px;text-align:center}
.form-done{display:none;text-align:center;padding:18px 8px}
.form-done.show{display:block;animation:popIn .6s both}
.form-done .chk{width:66px;height:66px;border-radius:50%;background:var(--turquoise);color:#fff;display:grid;place-items:center;margin:0 auto 18px}
.form-done .chk svg{width:32px;height:32px}
.form-done h3{font-size:30px}
.form-done p{color:var(--ink-soft);margin-top:10px}

/* trust logos */
.logos{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}
.logos .lg{height:64px;min-width:160px;border-radius:15px;background:var(--card-bg);border:var(--card-border);display:grid;place-items:center;font-family:var(--font-display);font-size:21px;color:var(--ink-soft);padding:0 26px}

/* restaurant cards (nos-restaurants) — now with photo + rating + link */
.resto-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.resto-card{background:var(--card-bg);border:var(--card-border);border-radius:var(--card-radius);padding:0;overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.resto-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
[data-direction="pop"] .resto-card:hover{transform:translateY(-5px) rotate(-.6deg)}
.resto-card .rc-photo{position:relative;aspect-ratio:16/10}
.resto-card .rc-photo .img-slot{width:100%;height:100%;display:block}
.resto-card .rc-rate{position:absolute;top:12px;right:12px;background:#fff;border-radius:999px;padding:5px 12px;font-size:13px;font-weight:700;display:flex;align-items:center;gap:5px;box-shadow:var(--shadow-soft);color:var(--ink)}
.resto-card .rc-rate .st{color:var(--jaune)}
.resto-card .rc-in{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
.resto-card .rcity{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.resto-card h3{font-family:var(--font-display);font-size:25px;margin-top:6px}
.resto-card .addr{color:var(--ink-soft);font-size:14px;margin-top:8px}
.resto-card .hours{margin-top:14px;font-size:13.5px;display:flex;flex-direction:column;gap:5px}
.resto-card .hours b{color:var(--turquoise-deep)}
.resto-card .rlinks{display:flex;gap:8px;margin-top:auto;padding-top:18px;flex-wrap:wrap}
.resto-card .rlinks a,.resto-card .rlinks .go{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;padding:9px 16px;border-radius:999px;background:var(--green);color:#fff;transition:background .2s,transform .2s}
.resto-card:hover .rlinks .go{background:var(--turquoise-deep)}
.resto-card .rlinks a:hover{background:var(--turquoise-deep);transform:translateY(-1px)}
.resto-card .rlinks a .arr,.resto-card .rlinks .go .arr{transition:transform .25s}
.resto-card:hover .rlinks .go .arr{transform:translateX(3px)}
.resto-card .rlinks a:hover .arr{transform:translateX(3px)}

/* CTA band */
.cta-band{position:relative;border-radius:var(--card-radius);overflow:hidden;background:var(--green);color:#fff;padding:clamp(44px,6vw,82px);text-align:center}
[data-direction="pop"] .cta-band{background:var(--lilas-deep)}
.cta-band::after{content:"";position:absolute;right:-100px;top:-100px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,color-mix(in oklab,var(--turquoise) 55%,transparent),transparent 70%)}
.cta-band > *{position:relative;z-index:2}
.cta-band h2{color:#fff;font-size:var(--fs-h2)}
.cta-band p{color:rgba(255,255,255,.85);margin-top:14px;font-size:var(--fs-lead);max-width:52ch;margin-inline:auto}
.cta-band .hero-cta{justify-content:center;margin-top:28px}
.cta-band .btn-ghost{color:#fff;border-color:rgba(255,255,255,.6)}
.cta-band .btn-ghost:hover{background:rgba(255,255,255,.16)}

/* simple prose */
.prose{max-width:64ch}
.prose p{color:var(--ink-soft);font-size:var(--fs-lead);margin-top:18px}

/* subpage responsive */
@media (max-width:1080px){
  .steps,.steps.five{grid-template-columns:repeat(2,1fr)}
  .values{grid-template-columns:repeat(2,1fr)}
  .resto-cards{grid-template-columns:repeat(2,1fr)}
  .formules{grid-template-columns:1fr}
  .formule.feat{order:-1}
}
@media (max-width:860px){
  .split{grid-template-columns:1fr;gap:28px}
  .split.rev .split-media{order:0}
  .split-media{aspect-ratio:16/10}
  .menu-list{grid-template-columns:1fr;gap:0}
  .order-opts{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .steps,.steps.five,.steps.three,.values,.resto-cards{grid-template-columns:1fr}
}

/* ============================================================
   REFONTE v2 — section colour bands, ticker, round signatures,
   animated hero bowl, restaurant pages, interactive map
   ============================================================ */

/* ---- section colour bands: break the uniform background ---- */
.band{position:relative}
.band-cream{background:var(--cream)}
.band-lilas{background:color-mix(in oklab,var(--lilas) 22%,#fff)}
.band-turq{background:color-mix(in oklab,var(--turquoise) 15%,#fff)}
.band-rose{background:color-mix(in oklab,var(--rose) 17%,#fff)}
.band-soft{background:color-mix(in oklab,var(--lilas-soft) 60%,#fff)}
.band-green{background:var(--green);color:#fff}
.band-green .eyebrow{color:var(--jaune)}
.band-green h2,.band-green h3,.band-green h4{color:#fff}
.band-green p,.band-green .cat-intro{color:rgba(255,255,255,.84)}
/* gentle wave divider helper so bands meet softly */
.band + .band{box-shadow:0 -1px 0 rgba(15,33,20,.04)}

/* ---- reworked brand ticker (replaces the old marquee) ---- */
.ticker{position:relative;overflow:hidden;padding:16px 0;
  background:linear-gradient(90deg,var(--green),color-mix(in oklab,var(--green) 86%,var(--turquoise-deep)))}
[data-direction="pop"] .ticker{border-top:none;border-bottom:none}
.ticker::before,.ticker::after{content:"";position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(90deg,var(--green),transparent)}
.ticker::after{right:0;background:linear-gradient(270deg,color-mix(in oklab,var(--green) 86%,var(--turquoise-deep)),transparent)}
.ticker-track{display:flex;width:max-content;animation:march 46s linear infinite}
@media (prefers-reduced-motion:reduce){.ticker-track{animation:none}}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker .it{display:inline-flex;align-items:center;gap:13px;padding:0 30px;white-space:nowrap;
  font-family:var(--font-body);font-size:14px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#fff}
.ticker .it svg{width:17px;height:17px;color:var(--jaune);flex:none}
.ticker .it::after{content:"";width:5px;height:5px;border-radius:50%;background:color-mix(in oklab,var(--turquoise) 70%,#fff);margin-left:17px}

/* ---- round signature cards (home) ---- */
.sig-rail.rounds{grid-template-columns:repeat(5,1fr);gap:26px}
.sig-round{display:flex;flex-direction:column;align-items:center;text-align:center}
.sig-orb{position:relative;width:100%;margin-bottom:18px}
.sig-photo{position:relative;aspect-ratio:1;border-radius:50%;overflow:hidden;
  box-shadow:0 16px 30px -18px rgba(15,33,20,.42);
  transition:transform .5s cubic-bezier(.2,.8,.25,1),box-shadow .5s}
.sig-photo .img-slot{width:100%;height:100%;display:block}
.sig-round:hover .sig-photo{transform:scale(1.07) translateY(-6px);
  box-shadow:0 34px 56px -22px color-mix(in oklab,var(--lilas-deep) 55%,rgba(15,33,20,.55))}
.sig-round:nth-child(2):hover .sig-photo{box-shadow:0 34px 56px -22px color-mix(in oklab,var(--turquoise-deep) 60%,rgba(15,33,20,.5))}
.sig-round:nth-child(3):hover .sig-photo{box-shadow:0 34px 56px -22px color-mix(in oklab,var(--rouge) 55%,rgba(15,33,20,.5))}
.sig-round:nth-child(4):hover .sig-photo{box-shadow:0 34px 56px -22px color-mix(in oklab,var(--jaune) 65%,rgba(15,33,20,.45))}
.sig-round:nth-child(5):hover .sig-photo{box-shadow:0 34px 56px -22px color-mix(in oklab,var(--turquoise) 60%,rgba(15,33,20,.5))}
.sig-tier{position:absolute;top:4px;left:50%;transform:translateX(-50%);z-index:4;
  background:var(--green);color:#fff;font-size:11px;font-weight:700;padding:5px 12px;border-radius:999px;box-shadow:0 6px 14px -6px rgba(15,33,20,.5)}
.sig-round .sig-name{font-family:var(--font-display);font-weight:600;font-size:22px;line-height:1.1;margin-top:2px}
.sig-round .sig-desc{font-size:13.5px;color:var(--ink-soft);margin-top:6px;min-height:auto;max-width:24ch}
.s-price-note{font-family:var(--font-body);font-weight:600;font-size:15px;color:var(--ink-soft);margin-top:10px}
.s-price-note b{font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:18px}
[data-direction="pop"] .sig-round:hover{transform:none}
@media (prefers-reduced-motion:reduce){.sig-round:hover .sig-photo{transform:none}}

/* ---- immersive hero bowl + orbiting ingredients ---- */
.hero-glow{position:absolute;inset:6%;border-radius:50%;z-index:0;
  background:radial-gradient(circle at 50% 45%,color-mix(in oklab,var(--turquoise) 40%,#fff) 0%,color-mix(in oklab,var(--lilas) 28%,#fff) 45%,transparent 72%);
  filter:blur(8px);animation:glowPulse 8s ease-in-out infinite}
@keyframes glowPulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.06);opacity:1}}
.orbit-bowl{position:absolute;top:50%;left:50%;width:60%;height:60%;transform:translate(-50%,-50%);z-index:3;
  border-radius:50%;overflow:hidden;box-shadow:0 34px 66px -30px rgba(15,33,20,.55);
  animation:bowlBreath 7s ease-in-out infinite}
.orbit-bowl .img-slot{width:100%;height:100%;display:block}
@keyframes bowlBreath{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.035)}}
.orbit-ring{position:absolute;inset:7%;z-index:4;animation:spin 38s linear infinite}
.orbit-item{position:absolute;width:clamp(52px,7.4vw,86px);height:clamp(52px,7.4vw,86px);
  transform:translate(-50%,-50%);animation:counterspin 38s linear infinite}
.orbit-item .face{display:block;width:100%;height:100%;border-radius:50%;overflow:hidden;
  background:var(--card-bg);border:2px solid #fff;box-shadow:0 14px 26px -12px rgba(15,33,20,.45);
  animation:floaty 6s ease-in-out infinite}
.orbit-item:nth-child(2) .face{animation-duration:7s;animation-delay:-1s}
.orbit-item:nth-child(3) .face{animation-duration:6.6s;animation-delay:-2s}
.orbit-item:nth-child(4) .face{animation-duration:7.4s;animation-delay:-.5s}
.orbit-item:nth-child(5) .face{animation-duration:6.8s;animation-delay:-3s}
.orbit-item:nth-child(6) .face{animation-duration:7.2s;animation-delay:-1.5s}
.orbit-item .face .img-slot{width:100%;height:100%;display:block}
@keyframes counterspin{to{transform:translate(-50%,-50%) rotate(-360deg)}}
@media (prefers-reduced-motion:reduce){
  .orbit-ring,.orbit-item,.orbit-bowl,.hero-glow,.orbit-item .face{animation:none!important}
  .orbit-item{transform:translate(-50%,-50%)}
}
.fb-rating{top:4%;left:-7%;bottom:auto;right:auto;animation:floaty 6.5s ease-in-out infinite}
.fb-fresh{bottom:6%;right:-6%;top:auto;left:auto;animation:floaty 7.6s ease-in-out infinite .5s}
@media (max-width:520px){
  .fb-rating{left:-1%;top:2%} .fb-fresh{right:-1%;bottom:4%}
  .orbit-item{width:clamp(40px,12vw,60px);height:clamp(40px,12vw,60px)}
}

/* ---- lieu de vie CTA ---- */
.ambiance-cta{margin-top:clamp(28px,4vw,44px);display:flex;justify-content:center}

/* ============================================================
   INTERACTIVE MAP (restaurants) — clickable popup card
   ============================================================ */
.map-wrap.interactive{cursor:default}
.map-pop{position:absolute;z-index:8;width:min(300px,76vw);background:#fff;border-radius:18px;
  box-shadow:0 30px 60px -24px rgba(15,33,20,.5);overflow:hidden;
  opacity:0;visibility:hidden;transform-origin:50% 100%;transform:translate(-50%,-100%) translateY(0) scale(.94);
  transition:opacity .26s,transform .26s,visibility .26s;pointer-events:none}
.map-pop.show{opacity:1;visibility:visible;transform:translate(-50%,-100%) translateY(-14px) scale(1);pointer-events:auto}
.map-pop.below{transform-origin:50% 0;transform:translate(-50%,0) translateY(20px) scale(.94)}
.map-pop.below.show{transform:translate(-50%,0) translateY(16px) scale(1)}
.map-pop .mp-photo{position:relative;height:128px}
.map-pop .mp-photo .img-slot{width:100%;height:100%;display:block}
.map-pop .mp-city{position:absolute;top:10px;left:10px;background:var(--green);color:#fff;font-size:11px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:999px}
.map-pop .mp-close{position:absolute;top:9px;right:9px;width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,.92);display:grid;place-items:center;color:var(--green);z-index:3}
.map-pop .mp-close svg{width:15px;height:15px}
.map-pop .mp-body{padding:15px 17px 17px}
.map-pop .mp-body h4{font-family:var(--font-display);font-size:22px;line-height:1.1}
.map-pop .mp-addr{font-size:13px;color:var(--ink-soft);margin-top:4px}
.map-pop .mp-meta{display:flex;align-items:center;gap:8px;margin-top:9px;font-size:13px}
.map-pop .mp-stars{color:var(--jaune);letter-spacing:1px}
.map-pop .mp-meta b{font-family:var(--font-display);font-weight:600}
.map-pop .mp-meta span{color:var(--ink-soft)}
.map-pop .mp-go{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px;width:100%;
  padding:11px;border-radius:12px;background:var(--green);color:#fff;font-weight:700;font-size:14px;
  transition:background .2s}
.map-pop .mp-go:hover{background:var(--turquoise-deep)}
.map-pop .mp-go .arr{transition:transform .25s}
.map-pop .mp-go:hover .arr{transform:translateX(3px)}

/* ============================================================
   RESTAURANT DETAIL PAGE
   ============================================================ */
.rd-hero{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,52px);align-items:center}
.rd-hero .rd-photo{position:relative;border-radius:var(--card-radius);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow)}
.rd-hero .rd-photo .img-slot{width:100%;height:100%}
.rd-city{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.rd-hero h1{font-size:clamp(40px,5.6vw,78px);line-height:1;margin-top:10px}
.rd-rating{display:flex;align-items:center;gap:12px;margin-top:18px;flex-wrap:wrap}
.rd-rating .stars{color:var(--jaune);font-size:20px;letter-spacing:2px}
.rd-rating .score{font-family:var(--font-display);font-size:26px}
.rd-rating .count{color:var(--ink-soft);font-size:14px}
.rd-quick{display:flex;flex-direction:column;gap:10px;margin-top:22px}
.rd-quick .q{display:flex;gap:12px;align-items:flex-start;font-size:15.5px}
.rd-quick .q svg{width:20px;height:20px;color:var(--accent);flex:none;margin-top:2px}
.rd-quick .q b{font-weight:600}
.rd-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.rd-order-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.rd-order-row a{display:inline-flex;align-items:center;gap:8px;padding:11px 17px;border-radius:999px;
  font-size:13.5px;font-weight:700;border:1.5px solid color-mix(in oklab,var(--ink) 16%,transparent);
  background:#fff;color:var(--ink);transition:transform .2s,border-color .2s}
.rd-order-row a:hover{transform:translateY(-2px);border-color:var(--accent)}
.rd-order-row a .lg{width:18px;height:18px;border-radius:5px;flex:none}

.rd-services{display:flex;flex-wrap:wrap;gap:10px}
.rd-service{display:inline-flex;align-items:center;gap:9px;padding:11px 17px;border-radius:14px;
  background:var(--card-bg);border:var(--card-border);font-size:14.5px;font-weight:600}
.rd-service svg{width:18px;height:18px;color:var(--accent)}

.rd-map{position:relative;border-radius:var(--card-radius);overflow:hidden;aspect-ratio:16/8;box-shadow:var(--shadow-soft);
  background:linear-gradient(160deg,#e8f3f1,#ede6f0)}
.rd-map .map-canvas{position:absolute;inset:0}
.rd-map .pin{left:50%;top:54%}
.rd-itinerary{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}

.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review{background:var(--card-bg);border:var(--card-border);border-radius:var(--card-radius);padding:24px;box-shadow:var(--shadow-soft)}
.review .stars{color:var(--jaune);font-size:16px;letter-spacing:1px}
.review p{margin-top:12px;font-size:14.5px;color:var(--ink);line-height:1.55}
.review .who{margin-top:14px;font-size:13px;color:var(--ink-soft);font-weight:600}
.review .src{display:inline-flex;align-items:center;gap:6px;margin-top:4px;font-size:12px;color:var(--ink-soft)}

@media (max-width:980px){
  .sig-rail.rounds{grid-template-columns:repeat(3,1fr)}
  .rd-hero{grid-template-columns:1fr;gap:26px}
  .rd-hero .rd-photo{order:-1}
  .reviews{grid-template-columns:1fr}
}
@media (max-width:560px){
  .sig-rail.rounds{grid-template-columns:1fr 1fr;gap:18px}
  .bowl-toggle button{padding:8px 13px}
  .reviews{grid-template-columns:1fr}
}

/* ============================================================
   MENU v2 — visual bowl builder + product photos & pictos
   ============================================================ */
.bowl-builder{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:34px;counter-reset:bb}
.bb-step{position:relative;background:var(--card-bg);border:var(--card-border);border-radius:var(--card-radius);
  overflow:hidden;box-shadow:var(--shadow-soft);display:flex;flex-direction:column}
.bb-photo{position:relative;aspect-ratio:4/3}
.bb-photo .img-slot{width:100%;height:100%;display:block}
.bb-num{position:absolute;top:12px;left:12px;width:40px;height:40px;border-radius:12px;z-index:3;
  display:grid;place-items:center;font-family:var(--font-display);font-size:22px;color:#fff;
  box-shadow:0 8px 18px -8px rgba(15,33,20,.5)}
.bb-step:nth-child(1) .bb-num{background:var(--turquoise)}
.bb-step:nth-child(2) .bb-num{background:var(--lilas-deep)}
.bb-step:nth-child(3) .bb-num{background:var(--rouge)}
.bb-step:nth-child(4) .bb-num{background:var(--turquoise-deep)}
.bb-step:nth-child(5) .bb-num{background:var(--jaune);color:var(--green)}
.bb-body{padding:16px 18px 20px}
.bb-body h3{font-size:20px}
.bb-body .opts{font-size:13.5px;color:var(--ink-soft);margin-top:6px}
/* size callout (petit vs maxi) */
.size-callout{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:26px}
.size-card{position:relative;border-radius:var(--card-radius);padding:24px 26px;border:var(--card-border);
  background:var(--card-bg);box-shadow:var(--shadow-soft);display:flex;gap:18px;align-items:center}
.size-card.maxi{background:var(--green);color:#fff;border-color:var(--green)}
.size-card .sc-ico{width:54px;height:54px;border-radius:16px;flex:none;display:grid;place-items:center;
  background:var(--turquoise);color:#fff;font-family:var(--font-display);font-size:20px}
.size-card.maxi .sc-ico{background:var(--jaune);color:var(--green)}
.size-card h3{font-size:23px}
.size-card.maxi h3{color:#fff}
.size-card .sc-spec{font-size:14px;color:var(--ink-soft);margin-top:5px}
.size-card.maxi .sc-spec{color:rgba(255,255,255,.85)}
.size-card .sc-price{margin-left:auto;font-family:var(--font-display);font-size:30px;white-space:nowrap}
.size-card.maxi .sc-price{color:var(--jaune)}
/* formule pictos / photos */
.formule .f-ico{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;color:#fff;margin-bottom:8px}
.formule.feat .f-ico{background:var(--jaune);color:var(--green)}
.formule .f-ico svg{width:27px;height:27px}
.formule{padding-top:0;overflow:hidden}
.formule .f-photo{position:relative;margin:-1px -32px 20px;aspect-ratio:16/10}
.formule .f-photo .img-slot{width:100%;height:100%;display:block}
.formule .fname,.formule .price,.formule ul,.formule .btn,.formule>:not(.f-photo):not(.ftag){margin-left:0;margin-right:0}
.formule.feat{padding-top:0}
.formule.feat .ftag{z-index:3}
@media (max-width:980px){.bowl-builder{grid-template-columns:repeat(2,1fr)}.size-callout{grid-template-columns:1fr}}
@media (max-width:560px){.bowl-builder{grid-template-columns:1fr}}

/* reusable product cards (bubble teas, desserts) */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:28px}
.prod-card{background:var(--card-bg);border:var(--card-border);border-radius:var(--card-radius);overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .25s,box-shadow .25s}
.prod-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
[data-direction="pop"] .prod-card:hover{transform:translateY(-5px) rotate(-.6deg)}
.prod-photo{position:relative;aspect-ratio:1}
.prod-photo .img-slot{width:100%;height:100%;display:block}
.prod-tag{position:absolute;top:10px;left:10px;background:var(--green);color:#fff;font-size:11px;font-weight:700;padding:5px 11px;border-radius:999px;z-index:2}
.prod-tag.alt{background:var(--lilas-deep)}
.prod-tag.veg{background:var(--turquoise)}
.prod-body{padding:15px 16px 18px}
.prod-body h4{font-family:var(--font-display);font-size:20px;line-height:1.12}
.prod-body p{font-size:13px;color:var(--ink-soft);margin-top:5px;min-height:34px}
.prod-foot{display:flex;align-items:center;justify-content:space-between;margin-top:12px}
.prod-price{font-family:var(--font-display);font-size:20px}
@media(max-width:980px){.prod-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.prod-grid{grid-template-columns:1fr 1fr;gap:12px}}

/* ingredient accordion (compose your bowl) */
.accordion{display:flex;flex-direction:column;gap:14px;margin-top:32px}
.acc-item{background:var(--card-bg);border:var(--card-border);border-radius:var(--card-radius);overflow:hidden;box-shadow:var(--shadow-soft)}
.acc-head{width:100%;display:flex;align-items:center;gap:16px;padding:18px 22px;text-align:left;background:none;cursor:pointer}
.acc-num{width:46px;height:46px;border-radius:14px;flex:none;display:grid;place-items:center;font-family:var(--font-display);font-size:23px;color:#fff}
.acc-item:nth-child(1) .acc-num{background:var(--turquoise)}
.acc-item:nth-child(2) .acc-num{background:var(--lilas-deep)}
.acc-item:nth-child(3) .acc-num{background:var(--rouge)}
.acc-item:nth-child(4) .acc-num{background:var(--turquoise-deep)}
.acc-item:nth-child(5) .acc-num{background:var(--jaune);color:var(--green)}
.acc-titles{flex:1;min-width:0}
.acc-title{font-family:var(--font-display);font-size:23px;line-height:1.1}
.acc-sub{font-size:13px;color:var(--ink-soft);margin-top:2px}
.acc-count{font-size:13px;font-weight:700;color:var(--accent);white-space:nowrap}
.acc-chevron{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:color-mix(in oklab,var(--ink) 8%,#fff);transition:transform .35s,background .25s}
.acc-chevron svg{width:16px;height:16px}
.acc-item.open .acc-chevron{transform:rotate(180deg);background:var(--accent);color:#fff}
.acc-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .38s cubic-bezier(.4,0,.2,1)}
.acc-item.open .acc-panel{grid-template-rows:1fr}
.acc-panel-in{overflow:hidden;min-height:0}
.ingredients{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;padding:4px 22px 24px}
.ing{text-align:center}
.ing-img{position:relative;aspect-ratio:1;border-radius:15px;overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .3s}
.ing:hover .ing-img{transform:translateY(-4px)}
.ing-img .img-slot{width:100%;height:100%;display:block}
.ing-name{font-size:13px;font-weight:600;margin-top:9px;line-height:1.2}
.ing-name .supp{display:inline-block;font-size:11px;color:var(--turquoise-deep);font-weight:700;margin-left:3px}
@media(max-width:880px){.ingredients{grid-template-columns:repeat(4,1fr)}}
@media(max-width:560px){.ingredients{grid-template-columns:repeat(3,1fr);gap:12px;padding:4px 16px 20px}.acc-head{padding:16px}.acc-title{font-size:20px}}

/* traiteur events with imagery */
.events{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.event{position:relative;border-radius:var(--card-radius);overflow:hidden;box-shadow:var(--shadow);min-height:420px;
  display:flex;flex-direction:column;justify-content:flex-end;color:#fff}
.event .img-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.event .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 28%,rgba(15,33,20,.85))}
.event .ev-body{position:relative;z-index:2;padding:30px}
.event .chip{display:inline-block;background:var(--accent);color:#fff;font-size:12px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;padding:7px 13px;border-radius:999px;margin-bottom:14px}
.event.entreprise .chip{background:var(--turquoise)}
.event.evenement .chip{background:var(--lilas-deep)}
.event h3{color:#fff;font-size:clamp(26px,2.6vw,34px)}
.event p{color:rgba(255,255,255,.88);margin-top:10px;max-width:42ch;font-size:15px}
.event ul{list-style:none;margin-top:16px;display:flex;flex-wrap:wrap;gap:8px}
.event li{font-size:12.5px;font-weight:600;background:rgba(255,255,255,.16);padding:6px 12px;border-radius:999px;
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
@media (max-width:860px){.events{grid-template-columns:1fr}}

/* commander v2 redirect cards */
.redirect-card{display:flex;gap:20px;align-items:center;background:var(--card-bg);border:var(--card-border);
  border-radius:var(--card-radius);padding:clamp(22px,3vw,30px);box-shadow:var(--shadow-soft);
  transition:transform .25s,box-shadow .25s}
.redirect-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.redirect-card .rc-ico{width:62px;height:62px;border-radius:18px;display:grid;place-items:center;color:#fff;flex:none}
.redirect-card .rc-ico svg{width:30px;height:30px}
.redirect-card .rc-body{flex:1;min-width:0}
.redirect-card h3{font-size:24px}
.redirect-card .rc-body p{font-size:14.5px;color:var(--ink-soft);margin-top:5px}
.redirect-card .rc-note{font-size:13px;color:var(--turquoise-deep);font-weight:600;margin-top:8px;display:flex;align-items:center;gap:7px}
.redirect-card .rc-arrow{font-size:24px;color:var(--accent);transition:transform .25s}
.redirect-card:hover .rc-arrow{transform:translateX(5px)}
@media (max-width:640px){.redirect-card{flex-wrap:wrap}.redirect-card .rc-arrow{display:none}}

/* franchise CTA in the header nav */
.btn-franchise{background:transparent;color:var(--ink);border:1.5px solid color-mix(in oklab,var(--ink) 30%,transparent)}
.btn-franchise:hover{transform:translateY(-2px);background:var(--ink);color:#fff}
.hdr.scrolled .btn-franchise{border-color:color-mix(in oklab,var(--ink) 30%,transparent)}
@media (max-width:1080px){.btn-franchise{display:none}}

/* home traiteur banner (image background) */
.traiteur-banner{position:relative;border-radius:var(--card-radius);overflow:hidden;min-height:320px;display:flex;align-items:center;color:#fff;box-shadow:var(--shadow)}
.traiteur-banner .img-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.traiteur-banner .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(15,33,20,.86),rgba(15,33,20,.45) 64%,rgba(15,33,20,.12))}
.traiteur-banner .tb-body{position:relative;z-index:2;padding:clamp(28px,4.5vw,52px);max-width:580px}
.traiteur-banner .chip{display:inline-block;background:var(--lilas-deep);color:#fff;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:7px 13px;border-radius:999px;margin-bottom:14px}
.traiteur-banner h3{color:#fff;font-size:clamp(26px,3.2vw,40px)}
.traiteur-banner p{color:rgba(255,255,255,.9);margin-top:12px;max-width:46ch;font-size:var(--fs-lead)}
.traiteur-banner .btn{margin-top:24px}
@media (max-width:620px){.traiteur-banner .scrim{background:linear-gradient(180deg,rgba(15,33,20,.5),rgba(15,33,20,.86))}}

/* home traiteur split (distinct from franchise) */
.traiteur-split{display:grid;grid-template-columns:1fr 1.04fr;gap:clamp(28px,4vw,56px);align-items:center}
.ts-text .eyebrow{color:var(--turquoise-deep)}
.ts-text h2{margin-top:14px}
.ts-text p{margin-top:14px;max-width:46ch;color:var(--ink-soft)}
.ts-modes{display:flex;flex-direction:column;gap:12px;margin:24px 0 28px}
.ts-mode{display:flex;align-items:center;gap:14px;background:var(--card-bg);border:var(--card-border);border-radius:16px;padding:14px 18px;box-shadow:var(--shadow-soft)}
.ts-ico{width:44px;height:44px;border-radius:13px;flex:none;display:grid;place-items:center}
.ts-ico svg{width:22px;height:22px}
.ts-mode div{display:flex;flex-direction:column;line-height:1.25}
.ts-mode b{font-family:var(--font-display);font-weight:600;font-size:18px}
.ts-mode span{font-size:13.5px;color:var(--ink-soft)}
.ts-photo{position:relative;border-radius:var(--card-radius);overflow:hidden;aspect-ratio:4/3.4;box-shadow:var(--shadow)}
.ts-photo .img-slot{width:100%;height:100%;display:block}
@media (max-width:820px){
  .traiteur-split{grid-template-columns:1fr;gap:28px}
  .ts-photo{order:-1;aspect-ratio:16/10}
}

/* franchise photo gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gallery .img-slot{width:100%;height:100%;border-radius:18px;overflow:hidden}
.gallery .g-tall{grid-row:span 2}
.gallery .g-wide{grid-column:span 2}
@media (max-width:820px){.gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}}

/* footer logo (square stacked white lockup) + footer CTAs */
.foot-brand .brand-logo{height:86px;width:auto;margin-bottom:18px}
.btn-jaune{background:var(--jaune);color:var(--green)}
.btn-jaune:hover{transform:translateY(-2px)}
.foot-cta{display:flex;flex-direction:column;gap:12px;align-items:stretch}
.foot-cta .btn{width:100%;justify-content:center;padding:16px 24px;font-size:15.5px;gap:9px}
.foot-cta .btn span:first-child{font-weight:700}

/* ============================================================
   LEGAL PAGES (mentions légales / confidentialité)
   ============================================================ */
.legal{max-width:760px;margin:0 auto}
.legal .legal-updated{font-size:13.5px;color:var(--ink-soft);margin-bottom:8px}
.legal-block{margin-top:clamp(28px,3.5vw,44px)}
.legal-block:first-of-type{margin-top:8px}
.legal-block h2{font-size:clamp(22px,2.4vw,30px);display:flex;align-items:baseline;gap:12px}
.legal-block h2 .ln{font-family:var(--font-display);font-size:.7em;color:var(--accent);font-weight:600}
.legal-block h3{font-size:18px;margin-top:20px}
.legal-block p,.legal-block li{font-size:15.5px;line-height:1.6;color:var(--ink);margin-top:12px}
.legal-block ul{list-style:none;margin-top:12px;display:flex;flex-direction:column;gap:8px}
.legal-block ul li{margin-top:0;padding-left:22px;position:relative}
.legal-block ul li::before{content:"";position:absolute;left:2px;top:9px;width:7px;height:7px;border-radius:50%;background:var(--accent)}
.legal-block a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.legal-block .ph{background:color-mix(in oklab,var(--jaune) 30%,#fff);border-radius:4px;padding:0 5px;font-weight:600;font-style:normal}
.legal-table{margin-top:14px;border:var(--card-border);border-radius:16px;overflow:hidden;background:var(--card-bg);box-shadow:var(--shadow-soft)}
.legal-table .row{display:grid;grid-template-columns:1fr 1.4fr;gap:14px;padding:13px 18px}
.legal-table .row:nth-child(odd){background:color-mix(in oklab,var(--lilas) 10%,#fff)}
.legal-table .row b{font-weight:600}
.legal-table .row span{color:var(--ink)}
@media (max-width:560px){.legal-table .row{grid-template-columns:1fr;gap:3px}}

/* ============================================================
   IMMERSIVE EFFECTS v3 — richer hovers, lifts & accents
   ============================================================ */
/* unified card lift with colored shadow on the new component family */
.acc-item,.size-card,.formule,.rd-service,.redirect-card,.resto-card,.review,.prod-card,.bb-step,.event,.traiteur-banner{
  transition:transform .35s cubic-bezier(.2,.8,.25,1),box-shadow .35s}
.size-card:hover,.rd-service:hover,.review:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
[data-direction="pop"] .size-card:hover{transform:translateY(-5px) rotate(-.5deg)}
.acc-item:hover{box-shadow:var(--shadow)}
.acc-item.open{box-shadow:var(--shadow)}
.formule:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
[data-direction="pop"] .formule:hover{transform:translateY(-8px) rotate(-.5deg)}
[data-direction="pop"] .formule.feat:hover{transform:translateY(-8px) rotate(.5deg)}

/* image zoom inside any photo frame on card hover */
.prod-card .prod-photo .img-slot,.bb-photo .img-slot,.formule .f-photo .img-slot,
.resto-card .rc-photo .img-slot,.rd-photo .img-slot,.ing-img .img-slot,.gallery .img-slot{
  transition:transform .55s cubic-bezier(.2,.8,.25,1)}
.prod-card:hover .prod-photo .img-slot,.resto-card:hover .rc-photo .img-slot,
.formule:hover .f-photo .img-slot,.ing:hover .ing-img .img-slot,.gallery .img-slot:hover{
  transform:scale(1.07)}

/* staggered ingredient reveal when an accordion opens */
@media (prefers-reduced-motion:no-preference){
  .acc-item.open .ing{animation:ingPop .5s cubic-bezier(.2,.9,.3,1.2) both}
  .acc-item.open .ing:nth-child(n+7){animation-delay:.04s}
  .acc-item.open .ing:nth-child(n+13){animation-delay:.08s}
  .acc-item.open .ing:nth-child(n+19){animation-delay:.12s}
  .acc-item.open .ing:nth-child(n+25){animation-delay:.16s}
}
@keyframes ingPop{0%{opacity:0;transform:translateY(12px) scale(.94)}100%{opacity:1;transform:none}}

/* sheen sweep across feature photos on hover */
.f-photo,.rc-photo,.prod-photo,.rd-photo{position:relative;overflow:hidden}
.f-photo::after,.rc-photo::after,.prod-photo::after,.rd-photo::after{
  content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;z-index:4;pointer-events:none;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.42),transparent);transform:skewX(-18deg);transition:none}
.formule:hover .f-photo::after,.resto-card:hover .rc-photo::after,.prod-card:hover .prod-photo::after{
  animation:sheen .8s ease}
@keyframes sheen{from{left:-120%}to{left:160%}}

/* size-toggle pulse + price flip on the hero badges */
.float-badge{transition:transform .3s,box-shadow .3s}
.bowl-toggle button{transition:background .3s,color .3s,transform .2s}
.bowl-toggle button:active{transform:scale(.94)}
@keyframes badgePulse{0%{transform:scale(.85);opacity:.4}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}
.float-badge.flash .ico{animation:badgePulse .5s cubic-bezier(.2,1.4,.4,1)}

/* nav link underline grow */
.nav a{position:relative}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-4px;height:2px;border-radius:2px;
  background:var(--accent);transition:right .3s cubic-bezier(.2,.8,.25,1)}
.nav a:hover::after{right:0}

/* menu pill + accordion chevron micro-interactions already covered; soften scrollspy */
.menu-nav a{transition:background .25s,color .25s,transform .2s}

/* gentle scroll-parallax hook (JS adds --sy) on hero sprites */
@media (prefers-reduced-motion:no-preference){
  .page-hero .spr,.hero .spr{will-change:transform}
}

@media (prefers-reduced-motion:reduce){
  .prod-card:hover .prod-photo .img-slot,.resto-card:hover .rc-photo .img-slot,
  .formule:hover .f-photo .img-slot,.ing:hover .ing-img .img-slot,.gallery .img-slot:hover,
  .acc-item.open .ing{animation:none!important;transform:none!important}
  .f-photo::after,.rc-photo::after,.prod-photo::after,.rd-photo::after{display:none}
}

/* ============================================================
   WORDPRESS ADAPTATIONS — image slots réels + hero bigbowl
   ============================================================ */
.img-slot{display:block;position:relative;overflow:hidden}
.img-slot img{width:100%;height:100%;object-fit:cover;display:block}
.img-slot.empty{display:grid;place-items:center;min-height:100%;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.55) 0 14px, rgba(255,255,255,0) 14px 28px),
    linear-gradient(135deg,color-mix(in oklab,var(--lilas) 60%,#fff),color-mix(in oklab,var(--jaune) 40%,#fff));
  outline:1.5px dashed color-mix(in oklab,var(--green) 42%,transparent);outline-offset:-6px}
.img-slot.empty .ph-label{font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--green);
  background:rgba(255,255,255,.78);padding:6px 11px;border-radius:9px;text-align:center;max-width:82%;line-height:1.35}
.img-slot.empty .ph-slot{display:block;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10px;font-weight:700;opacity:.6;margin-top:3px;letter-spacing:.04em}

/* hero — grande image immersive (reprend l'inline style de la maquette) */
body.no-anim *{animation:none!important;transition:none!important}
.hero-copy{min-width:0}
.hero-visual{width:100%;aspect-ratio:1/1;height:auto;max-height:min(84vh,740px);max-width:740px;margin-inline:auto}
.hero-bigbowl{position:absolute;inset:0;border-radius:50%;overflow:hidden;z-index:3;
  box-shadow:0 58px 110px -40px rgba(15,33,20,.62), inset 0 0 0 8px rgba(255,255,255,.55);
  animation:heroBowlFloat 8.5s ease-in-out infinite}
.hero-bigbowl .img-slot{width:100%;height:100%;display:block;animation:heroBowlSpin 120s linear infinite}
@keyframes heroBowlFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
@keyframes heroBowlSpin{to{transform:rotate(360deg)}}
.hero-grid{grid-template-columns:minmax(0,1fr) clamp(380px,44%,560px)}
@media (prefers-reduced-motion:reduce){.hero-bigbowl,.hero-bigbowl .img-slot{animation:none!important}}
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{max-width:440px}
}

/* WordPress : neutralise les marges admin-bar sur le header fixe */
body.admin-bar .hdr{top:32px}
@media (max-width:782px){body.admin-bar .hdr{top:46px}}
