/* ===========================================================
   ARIIWA — Présentation (landing)
   Premium · lumineuse · caramel & crème — « Par nous, pour nous »
   =========================================================== */
:root{
  --night:   #1B110B;
  --night-2: #2A1A10;
  --night-3: #3A2718;

  --cream:   #F7EFE0;   /* page base */
  --cream-2: #FBF6EC;   /* lighter band */
  --cream-3: #F1E6D2;   /* darker band */
  --card:    #FFFDF8;   /* card surface */
  --paper:   #FFFFFF;

  --gold:    #E3A943;
  --gold-2:  #F2CC83;
  --gold-deep:#B9842C;
  --caramel: #B5694A;
  --caramel-2:#C97E5C;
  --caramel-soft:#E9C6AE;
  --green:   #2E9F69;
  --green-deep:#1F7B4F;
  --red:     #C9463A;

  --ink:   #2A1A12;
  --ink-2: #6E5849;
  --ink-3: #9C8B7C;

  --line:  rgba(42,26,18,.10);
  --line-2:rgba(42,26,18,.055);

  --cream-on-dark: #F4EBDB;
  --muted-on-dark: rgba(244,235,219,.64);
  --faint-on-dark: rgba(244,235,219,.36);
  --line-on-dark:  rgba(244,235,219,.14);

  --r-sm: 12px; --r: 18px; --r-lg: 24px; --r-xl: 30px; --r-2xl: 42px;
  --shadow-sm: 0 1px 2px rgba(42,26,18,.05), 0 3px 10px rgba(42,26,18,.05);
  --shadow:    0 6px 18px rgba(42,26,18,.07), 0 18px 44px rgba(42,26,18,.07);
  --shadow-lg: 0 30px 70px -22px rgba(80,46,20,.30);
  --shadow-phone: 0 40px 90px -28px rgba(40,22,8,.45), 0 16px 36px rgba(40,22,8,.20);

  --font-display: "Bricolage Grotesque", system-ui, sans-serif;
  --font-body: "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --font-mono: ui-monospace, "SFMono-Regular", "Menlo", monospace;
  --maxw: 1180px;

  /* warm dark used for the app phone + accent panels */
  --deep-bg:
    radial-gradient(1100px 720px at 78% -8%, #3a260f 0%, rgba(52,35,15,0) 60%),
    radial-gradient(900px 600px at 6% 110%, #2a1a10 0%, rgba(42,26,16,0) 55%),
    #1B110B;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: hidden; }
body{
  margin: 0; font-family: var(--font-body);
  background: var(--cream); color: var(--ink);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; overflow-x: hidden;
}
h1,h2,h3,h4{ font-family: var(--font-display); margin: 0; letter-spacing: -.025em; line-height: 1.04; font-weight: 700; }
p{ margin: 0; }
a{ color: inherit; text-decoration: none; }
img{ max-width: 100%; display: block; }
button{ font-family: var(--font-body); cursor: pointer; border: none; background: none; color: inherit; }
input{ font-family: var(--font-body); }
::selection{ background: var(--gold); color: var(--night); }
.wrap{ width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }
.mono{ font-family: var(--font-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; }

/* ============ LOGO ============ */
.logo-link{ display: inline-flex; align-items: center; }
.logo-img{ height: 34px; width: auto; display: block; }
.foot-logo{ height: 36px; margin-bottom: 18px; }
/* Repli texte (si aucune image) */
.logo-word{ font-family: var(--font-display); font-weight: 800; font-size: 23px; letter-spacing: .14em; color: var(--gold-deep); display: inline-flex; align-items: center; line-height: 1; }
.logo-word::after{ content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--green); margin-left: 4px; align-self: flex-end; margin-bottom: 4px; }
.foot-brand .logo-word{ color: var(--gold-2); margin-bottom: 18px; }

/* ============ NAV ============ */
.nav{ position: sticky; top: 0; z-index: 60; background: color-mix(in srgb, var(--cream-2) 82%, transparent);
  backdrop-filter: blur(18px) saturate(1.3); -webkit-backdrop-filter: blur(18px) saturate(1.3); border-bottom: 1px solid var(--line); }
.nav-in{ display: flex; align-items: center; gap: 26px; height: 72px; }
.nav .logo{ height: 34px; width: auto; }
.nav-links{ display: flex; align-items: center; gap: 26px; margin-left: 14px; }
.nav-links a{ font-size: 14.5px; font-weight: 550; color: var(--ink-2); transition: color .15s; white-space: nowrap; }
.nav-links a:hover{ color: var(--ink); }
.nav-cta{ margin-left: auto; display: flex; align-items: center; gap: 12px; }

/* -- hamburger + tiroir mobile -- */
.nav-burger{ display: none; flex-direction: column; justify-content: center; gap: 5px; width: 44px; height: 44px; padding: 0 11px; border: 1px solid var(--line); border-radius: 12px; background: var(--card); cursor: pointer; }
.nav-burger span{ display: block; height: 2px; border-radius: 2px; background: var(--ink); transition: transform .25s ease, opacity .2s ease; }
.nav.open .nav-burger{ background: var(--night); border-color: var(--night); }
.nav.open .nav-burger span{ background: var(--cream-on-dark); }
.nav.open .nav-burger span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav.open .nav-burger span:nth-child(2){ opacity: 0; }
.nav.open .nav-burger span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }
.nav-drawer{ display: none; flex-direction: column; padding: 8px 20px 22px; border-top: 1px solid var(--line); }
.nav-drawer a{ padding: 14px 4px; font-size: 16px; font-weight: 600; color: var(--ink); border-bottom: 1px solid var(--line-2); }
.nav-drawer a:hover{ color: var(--caramel); }
.nav-drawer .btn{ margin-top: 16px; border-bottom: none; width: 100%; }
.nav.open .nav-drawer{ display: flex; }
/* CTA dans le tiroir : affichés seulement quand retirés du topbar (cf. responsive) */
.nav-drawer .drawer-secondary, .nav-drawer .drawer-primary{ display: none; }

.btn{ display: inline-flex; align-items: center; justify-content: center; gap: 9px; height: 46px; padding: 0 22px;
  border-radius: 999px; font-size: 15px; font-weight: 650; white-space: nowrap;
  transition: transform .14s ease, box-shadow .2s, background .2s, color .2s, border-color .2s; }
.btn:active{ transform: scale(.97); }
.btn-gold{ background: var(--gold); color: var(--night); box-shadow: 0 6px 18px -4px rgba(227,169,67,.5); }
.btn-gold:hover{ background: var(--gold-2); box-shadow: 0 10px 26px -6px rgba(227,169,67,.6); }
.btn-dark{ background: var(--night); color: var(--gold-2); }
.btn-dark:hover{ background: var(--night-2); }
.btn-ghost{ background: transparent; color: var(--ink); border: 1px solid var(--line); }
.btn-ghost:hover{ background: var(--card); border-color: rgba(42,26,18,.22); box-shadow: var(--shadow-sm); }
.btn-caramel{ background: var(--caramel); color: #fff; box-shadow: 0 6px 18px -4px rgba(181,105,74,.5); }
.btn-caramel:hover{ background: var(--caramel-2); }
.btn-sm{ height: 40px; padding: 0 18px; font-size: 14px; }
.btn-lg{ height: 54px; padding: 0 28px; font-size: 16.5px; }

/* store badge button */
.store-btn{ display: inline-flex; align-items: center; gap: 12px; height: 56px; padding: 0 22px; border-radius: 15px;
  background: var(--night); color: var(--cream-on-dark); border: 1px solid var(--night-3); transition: transform .14s, background .2s; }
.store-btn:active{ transform: scale(.97); }
.store-btn:hover{ background: var(--night-2); }
.store-btn .si{ font-size: 23px; line-height: 1; }
.store-btn .st{ text-align: left; line-height: 1.12; }
.store-btn .st small{ display: block; font-size: 10.5px; color: var(--faint-on-dark); letter-spacing: .04em; }
.store-btn .st b{ font-size: 16px; font-weight: 700; }

/* ============ HERO ============ */
.hero{ position: relative; overflow: hidden;
  background:
    radial-gradient(900px 520px at 82% -6%, rgba(242,204,131,.45) 0%, rgba(242,204,131,0) 60%),
    radial-gradient(760px 520px at -4% 8%, rgba(233,198,174,.5) 0%, rgba(233,198,174,0) 58%),
    var(--cream-2); }
.hero::after{ content:""; position: absolute; inset: 0; pointer-events: none;
  background-image: radial-gradient(rgba(42,26,18,.05) 1px, transparent 1px);
  background-size: 26px 26px; opacity: .5; mask-image: linear-gradient(180deg,#000,transparent 78%); }
.hero-in{ position: relative; z-index: 2; display: grid; grid-template-columns: 1.05fr .95fr; gap: 44px; align-items: center; padding-top: 70px; padding-bottom: 88px; }
.eyebrow{ display: inline-flex; align-items: center; gap: 10px; padding: 7px 16px 7px 10px; border-radius: 999px;
  background: var(--card); border: 1px solid var(--line); color: var(--caramel); font-size: 13px; font-weight: 600; margin-bottom: 26px; white-space: nowrap; box-shadow: var(--shadow-sm); }
.eyebrow .dot{ width: 7px; height: 7px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 4px rgba(46,159,105,.2); }
.eyebrow b{ color: var(--ink); font-weight: 700; }
.hero h1{ font-size: clamp(44px, 6vw, 82px); line-height: .96; letter-spacing: -.038em; color: var(--ink); }
.hero h1 .accent{ color: var(--caramel); }
.hero h1 .gold{ color: var(--gold-deep); }
.hero-sub{ margin-top: 24px; font-size: clamp(17px,1.5vw,20px); line-height: 1.55; color: var(--ink-2); max-width: 540px; }
.hero-sub b{ color: var(--ink); font-weight: 600; }
.hero-cta{ display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; align-items: center; }
.avail{ margin-top: 30px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.avail .lbl{ color: var(--ink-3); }
.avail-row{ display: flex; flex-wrap: wrap; gap: 9px; }
.avail-chip{ display: inline-flex; align-items: center; gap: 8px; height: 36px; padding: 0 15px; border-radius: 999px;
  background: var(--card); border: 1px solid var(--line); font-size: 13.5px; font-weight: 600; color: var(--ink-2); }
.avail-chip .gi{ color: var(--green); font-size: 13px; }

.hero-phones{ position: relative; display: flex; justify-content: center; align-items: center; min-height: 600px; }
.glow{ position: absolute; width: 420px; height: 420px; border-radius: 50%; background: radial-gradient(circle, rgba(227,169,67,.45), transparent 70%); filter: blur(50px); z-index: 0; }

/* ============ PHONE MOCKUP (dark app) ============ */
.phone{ position: relative; width: 300px; flex: 0 0 300px; border-radius: 46px; padding: 11px;
  background: linear-gradient(160deg, #2c1c12, #140c07); box-shadow: var(--shadow-phone); border: 1px solid rgba(244,235,219,.10); }
.phone-screen{ position: relative; border-radius: 36px; overflow: hidden; background: #1B110B; height: 600px; }
.phone-notch{ position: absolute; top: 10px; left: 50%; transform: translateX(-50%); width: 96px; height: 26px; background: #0c0705; border-radius: 999px; z-index: 5; }
.statusbar{ display: flex; justify-content: space-between; align-items: center; padding: 14px 24px 4px; color: #F4EBDB; font-size: 13px; font-weight: 600; }
.statusbar .dots{ display: flex; gap: 5px; align-items: center; }
.statusbar .dots span{ width: 4px; height: 4px; border-radius: 50%; background: #F4EBDB; }
.app-top{ display: flex; align-items: center; gap: 10px; padding: 6px 18px 12px; }
.city-pill{ display: inline-flex; align-items: center; gap: 6px; height: 32px; padding: 0 12px; border-radius: 999px; background: rgba(244,235,219,.08); border: 1px solid rgba(244,235,219,.13); color: #F4EBDB; font-size: 12.5px; font-weight: 600; }
.app-word{ font-family: var(--font-display); font-weight: 800; letter-spacing: .14em; font-size: 15px; color: #F4EBDB; margin: 0 auto; }
.app-ic{ width: 30px; height: 30px; border-radius: 50%; background: rgba(244,235,219,.08); border: 1px solid rgba(244,235,219,.13); display: grid; place-items: center; color: var(--gold-2); font-size: 13px; }
.app-ic.av{ background: var(--caramel); color: #1B110B; font-weight: 800; }
.app-greet{ padding: 4px 18px 0; }
.app-greet h4{ font-size: 21px; color: #F4EBDB; }
.app-greet p{ font-size: 12.5px; color: rgba(244,235,219,.62); margin-top: 4px; }
.app-search{ margin: 12px 18px; height: 42px; border-radius: 14px; background: rgba(244,235,219,.07); border: 1px solid rgba(244,235,219,.13); display: flex; align-items: center; gap: 9px; padding: 0 14px; color: rgba(244,235,219,.34); font-size: 12.5px; }
.app-cats{ display: flex; gap: 8px; padding: 0 18px 12px; overflow: hidden; }
.app-cat{ flex: 0 0 auto; height: 34px; padding: 0 13px; border-radius: 999px; background: #FFFDF8; color: #2A1A12; display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 600; }
.app-cat.on{ background: var(--gold); }
.feat-card{ margin: 0 18px 14px; border-radius: 20px; overflow: hidden; position: relative; padding: 16px; color: #F4EBDB; background: linear-gradient(150deg,#5a3a22,#3a2415); border: 1px solid rgba(244,235,219,.08); }
.badge{ position: relative; display: inline-flex; align-items: center; gap: 5px; height: 26px; padding: 0 11px; border-radius: 999px; font-size: 11px; font-weight: 700; }
.badge-gold{ background: var(--gold); color: #1B110B; }
.badge-green{ background: var(--green); color: #fff; }
.badge-caramel{ background: var(--caramel); color: #fff; }
.feat-card .meta{ position: relative; margin-top: 58px; font-size: 10.5px; font-weight: 700; letter-spacing: .08em; color: var(--gold-2); text-transform: uppercase; }
.feat-card h5{ position: relative; font-family: var(--font-display); font-size: 19px; font-weight: 700; margin-top: 5px; line-height: 1.1; }
.feat-card .crow{ position: relative; display: flex; align-items: center; justify-content: space-between; margin-top: 14px; }
.feat-card .price{ font-size: 13px; font-weight: 700; }
.mini-btn{ height: 34px; padding: 0 16px; border-radius: 999px; background: var(--gold); color: #1B110B; font-size: 12.5px; font-weight: 700; display: inline-flex; align-items: center; }
.app-section-h{ display: flex; align-items: center; justify-content: space-between; padding: 4px 18px 10px; }
.app-section-h .t{ font-family: var(--font-display); font-size: 16px; font-weight: 700; color: #F4EBDB; }
.app-section-h .more{ font-size: 12px; color: var(--gold-2); font-weight: 600; }
.mini-cards{ display: flex; gap: 12px; padding: 0 18px; }
.mini-card{ flex: 1; border-radius: 16px; overflow: hidden; position: relative; height: 120px; }
.mini-card .body{ position: absolute; inset: 0; padding: 10px; display: flex; flex-direction: column; justify-content: flex-start; }
.mini-card .lbl{ font-size: 10.5px; font-weight: 700; color: #fff; margin-top: auto; }
.app-nav{ position: absolute; bottom: 0; left: 0; right: 0; height: 64px; background: linear-gradient(180deg, rgba(20,12,7,0), #140c07 45%); display: flex; align-items: center; justify-content: space-around; padding: 0 16px 10px; }
.app-nav .item{ display: flex; align-items: center; gap: 7px; color: rgba(244,235,219,.4); font-size: 12px; font-weight: 600; }
.app-nav .item.on{ background: var(--gold); color: #1B110B; height: 40px; padding: 0 16px; border-radius: 999px; }
.ph-stripe{ background-image: repeating-linear-gradient(135deg, rgba(255,255,255,.07) 0 2px, transparent 2px 9px); }
.phone.p-back{ position: absolute; transform: rotate(6deg) translate(74px, 14px) scale(.86); opacity: .94; z-index: 1; filter: brightness(.86); }
.phone.p-front{ position: relative; z-index: 2; transform: rotate(-3deg); }

/* ============ STRIP (carrousel) ============ */
.strip{ background: var(--night); padding: 22px 0; color: var(--muted-on-dark); }
.strip-marquee{ overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.strip-track{ display: inline-flex; align-items: center; gap: 16px; white-space: nowrap; will-change: transform;
  animation: marquee 36s linear infinite; }
.strip-marquee:hover .strip-track{ animation-play-state: paused; }
.strip .lbl{ color: var(--faint-on-dark); font-size: 12px; }
.strip .stat{ font-size: 15px; flex: 0 0 auto; }
.strip .stat b{ color: var(--gold-2); font-family: var(--font-display); font-size: 17px; }
.strip .sep{ width: 5px; height: 5px; border-radius: 50%; background: var(--faint-on-dark); flex: 0 0 auto; }
@keyframes marquee{ from{ transform: translateX(0); } to{ transform: translateX(-50%); } }

/* ============ SECTION SHELL ============ */
section{ position: relative; }
.sec{ padding: 104px 0; }
.s-cream{ background: var(--cream); }
.s-cream-2{ background: var(--cream-2); }
.s-cream-3{ background: var(--cream-3); }
.s-deep{ background: var(--deep-bg); color: var(--cream-on-dark); }
.sec-head{ max-width: 740px; margin: 0 auto 60px; text-align: center; }
.sec-head.left{ text-align: left; margin: 0 0 52px; }
.kicker{ display: inline-flex; align-items: center; gap: 8px; color: var(--caramel); font-weight: 700; font-size: 13px; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 16px; }
.s-deep .kicker{ color: var(--gold-2); }
.kicker .bar{ width: 22px; height: 2px; background: currentColor; border-radius: 2px; }
.sec-head h2{ font-size: clamp(32px, 4vw, 56px); letter-spacing: -.032em; }
.sec-head .lede{ margin-top: 18px; font-size: clamp(16px,1.4vw,19px); line-height: 1.55; color: var(--ink-2); }
.s-deep .sec-head .lede{ color: var(--muted-on-dark); }

/* ============ COMMENT ÇA MARCHE ============ */
.hiw-seg{ display: flex; justify-content: center; margin-bottom: 46px; }
.fseg{ display: inline-flex; padding: 5px; gap: 5px; border-radius: 999px; background: var(--card); border: 1px solid var(--line); box-shadow: var(--shadow-sm); }
.fseg button{ height: 48px; padding: 0 28px; border-radius: 999px; font-size: 15px; font-weight: 650; color: var(--ink-2); transition: color .2s, background .2s; display: inline-flex; align-items: center; gap: 9px; }
.fseg button.on{ background: var(--night); color: var(--gold-2); }
.fseg button[data-flow="part"].on{ background: var(--caramel); color: #fff; }

.steps{ display: none; }
.steps.on{ display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; animation: fadein .4s ease both; }
@keyframes fadein{ from{ opacity: 0; transform: translateY(10px);} to{ opacity:1; transform:none; } }
.step{ background: var(--card); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px; position: relative; box-shadow: var(--shadow-sm); display: flex; flex-direction: column; }
.step .sn{ font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; color: var(--ink-3); }
.step .si{ width: 52px; height: 52px; border-radius: 15px; display: grid; place-items: center; font-size: 23px; margin: 16px 0 18px;
  background: linear-gradient(160deg,var(--gold-2),var(--gold)); color: var(--night); }
.steps.flow-part .step .si{ background: linear-gradient(160deg,var(--caramel-soft),var(--caramel)); color: #fff; }
.step h4{ font-size: 18.5px; }
.step p{ margin-top: 9px; font-size: 14.5px; line-height: 1.5; color: var(--ink-2); }
.step .conn{ position: absolute; top: 52px; right: -22px; width: 24px; height: 2px; background: var(--line); z-index: 2; }
.step:last-child .conn{ display: none; }

/* ============ POURQUOI (benefit grid) ============ */
.why-grid{ display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.why-card{ background: var(--card); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 32px; box-shadow: var(--shadow-sm); transition: transform .2s, box-shadow .2s, border-color .2s; }
.why-card:hover{ transform: translateY(-3px); box-shadow: var(--shadow); border-color: rgba(42,26,18,.16); }
.why-card .wi{ width: 54px; height: 54px; border-radius: 16px; display: grid; place-items: center; font-size: 24px; margin-bottom: 20px;
  background: rgba(227,169,67,.14); color: var(--gold-deep); }
.why-card.cm .wi{ background: rgba(181,105,74,.14); color: var(--caramel); }
.why-card.gr .wi{ background: rgba(46,159,105,.14); color: var(--green-deep); }
.why-card h4{ font-size: 20px; }
.why-card p{ margin-top: 10px; font-size: 15px; line-height: 1.55; color: var(--ink-2); }
.why-card .wtag{ display: inline-block; margin-top: 16px; font-size: 11.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--green-deep); background: rgba(46,159,105,.1); padding: 6px 11px; border-radius: 999px; }
.why-card.cm .wtag{ color: var(--caramel); background: rgba(181,105,74,.1); }

/* ============ POURQUOI — preuve (maquettes + cartes + socle) ============ */
#pourquoi{ overflow: hidden; }
.proof-grid{ display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr); gap: 44px; align-items: center; }

/* -- maquettes téléphone -- */
.proof-phones{ position: relative; display: flex; justify-content: center; align-items: center; gap: 0; padding: 8px 0 30px; overflow: visible; max-width: 100%; min-height: 560px; }
.pp-fig{ display: flex; flex-direction: column; align-items: center; gap: 24px; margin: 0; }
.pp-fig .phone{ width: 280px; flex: 0 0 280px; }
.pp-fig .phone-screen{ height: 572px; }
/* maquettes en "V" : les deux bases se rejoignent au centre-bas (l'apex) et les
   têtes s'écartent. La rotation est portée par chaque .phone (coin bas intérieur). */
.pp-left{ position: relative; z-index: 2; }
.pp-right{ position: relative; z-index: 1; }
.pp-cap{ font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-3); font-weight: 700; }

/* -- contenu écran (thème clair, en-tête sombre) -- */
.pv-screen{ background: var(--cream-2); }
.av{ width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; font-size: 12px; font-weight: 800; color: #fff; flex: 0 0 auto; }

.pv-head{ display: flex; align-items: center; gap: 10px; padding: 22px 13px 14px; background: linear-gradient(160deg, #241710, #140d07); color: var(--cream-on-dark); }
.pv-back{ width: 30px; height: 30px; border-radius: 50%; background: rgba(244,235,219,.1); display: grid; place-items: center; font-size: 16px; flex: 0 0 auto; }
.pv-ht{ flex: 1; min-width: 0; }
.pv-t{ font-family: var(--font-display); font-size: 14.5px; font-weight: 700; }
.pv-s{ font-size: 9.5px; color: rgba(244,235,219,.55); margin-top: 2px; }
.pv-ic{ width: 30px; height: 30px; border-radius: 50%; background: rgba(244,235,219,.1); display: grid; place-items: center; color: rgba(244,235,219,.7); font-size: 13px; flex: 0 0 auto; }
.pv-body{ padding: 12px 14px; }

.pv-evt{ display: flex; align-items: center; gap: 8px; padding: 10px 12px; border-radius: 14px; background: #fff; border: 1px solid var(--line); }
.pv-evt > div{ flex: 1; }
.pv-evt-n{ font-family: var(--font-display); font-weight: 700; font-size: 13px; color: var(--ink); }
.pv-evt-m{ font-size: 10px; color: var(--ink-3); margin-top: 3px; }
.pv-done{ font-size: 8.5px; font-weight: 800; letter-spacing: .04em; color: var(--ink-2); background: var(--cream-3); padding: 4px 8px; border-radius: 999px; }

.pv-rate{ display: flex; gap: 14px; align-items: center; margin-top: 10px; padding: 13px; border-radius: 16px; background: #fff; border: 1px solid var(--line); }
.pv-rate-l{ text-align: center; flex: 0 0 auto; }
.pv-big{ font-family: var(--font-display); font-size: 36px; font-weight: 800; color: var(--ink); line-height: 1; }
.pv-stars{ color: var(--gold); font-size: 11px; letter-spacing: 1px; margin-top: 3px; }
.pv-stars span{ color: rgba(42,26,18,.18); }
.pv-sub{ font-size: 9.5px; color: var(--ink-3); margin-top: 3px; }
.pv-rate-r{ flex: 1; display: flex; flex-direction: column; gap: 7px; }
.pv-bar{ display: flex; align-items: center; gap: 8px; font-size: 10px; color: var(--ink-2); }
.pv-bar > span:first-child{ width: 70px; }
.pv-bar .trk{ flex: 1; height: 5px; border-radius: 3px; background: var(--cream-3); overflow: hidden; }
.pv-bar .trk span{ display: block; height: 100%; background: var(--gold); border-radius: 3px; }
.pv-bar b{ width: 20px; text-align: right; color: var(--caramel); font-weight: 800; }

.pv-note{ display: block; text-align: center; margin-top: 10px; font-size: 9.5px; font-weight: 700; color: var(--green-deep); background: rgba(46,159,105,.12); padding: 8px 11px; border-radius: 10px; }
.pv-h{ font-size: 12px; font-weight: 700; color: var(--ink); margin: 14px 0 2px; }

.pv-rev{ margin-top: 11px; padding: 12px; border-radius: 14px; background: #fff; border: 1px solid var(--line); }
.pv-rev-h{ display: flex; align-items: center; gap: 9px; }
.pv-rid{ flex: 1; min-width: 0; }
.pv-rid b{ font-size: 12.5px; font-weight: 700; color: var(--ink); display: block; }
.pv-ok{ font-size: 9px; color: var(--green-deep); font-weight: 600; }
.pv-ago{ font-size: 9.5px; color: var(--ink-3); flex: 0 0 auto; }
.pv-score{ font-size: 11px; font-weight: 800; color: var(--caramel); margin-top: 9px; }
.pv-score .pv-st{ color: var(--gold); font-weight: 700; }
.pv-txt{ font-size: 11px; line-height: 1.5; color: var(--ink-2); margin-top: 7px; }
.pv-tags{ display: flex; gap: 6px; flex-wrap: wrap; margin-top: 9px; }
.pv-tags span{ font-size: 9px; font-weight: 700; color: var(--green-deep); background: rgba(46,159,105,.12); padding: 3px 8px; border-radius: 999px; }

/* communauté / discussion */
.pc-prog{ height: 6px; margin: 10px 14px 2px; border-radius: 999px; background: var(--cream-3); overflow: hidden; }
.pc-prog span{ display: block; width: 42%; height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--caramel), var(--gold)); }
.pc-compose{ padding: 10px 12px; border-radius: 14px; background: #fff; border: 1px solid var(--line); }
.pc-c-t{ font-size: 12px; font-weight: 700; color: var(--ink); }
.pc-c-s{ font-size: 9.5px; color: var(--ink-3); margin-top: 2px; }
.pc-post{ margin-top: 9px; padding: 11px; border-radius: 14px; background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-sm); }
.pc-ph{ display: flex; align-items: center; gap: 9px; }
.pc-ph .av{ width: 32px; height: 32px; font-size: 12px; }
.pc-ph .pv-rid b{ font-size: 12px; }
.pv-ago2{ font-size: 9px; color: var(--ink-3); }
.pc-badge{ font-size: 9px; font-weight: 800; color: #fff; background: var(--caramel); padding: 3px 9px; border-radius: 999px; flex: 0 0 auto; }
.pc-badge.org{ background: var(--green); }
.pc-title{ font-family: var(--font-display); font-size: 12.5px; font-weight: 700; color: var(--ink); margin-top: 8px; }
.pc-txt{ font-size: 9.5px; line-height: 1.45; color: var(--ink-2); margin-top: 4px; }
.pc-hash{ font-size: 9px; font-weight: 700; color: var(--caramel); margin-top: 6px; }
.pc-react{ display: flex; align-items: center; gap: 7px; margin-top: 8px; }
.pc-up{ font-size: 9px; font-weight: 800; color: var(--caramel); background: rgba(181,105,74,.12); padding: 4px 9px; border-radius: 999px; }
.pc-disc{ font-size: 9px; font-weight: 600; color: var(--ink-3); background: var(--cream-3); padding: 4px 9px; border-radius: 999px; }
.pc-ext{ margin-left: auto; color: var(--ink-3); font-size: 12px; }
.pp-right .pv-body{ padding-bottom: 52px; }
.pc-input{ position: absolute; left: 0; right: 0; bottom: 0; display: flex; align-items: center; gap: 9px; padding: 11px 13px 14px; background: var(--cream-2); border-top: 1px solid var(--line); }
.pc-field{ flex: 1; height: 36px; border-radius: 999px; background: #fff; border: 1px solid var(--line); display: flex; align-items: center; padding: 0 14px; font-size: 11px; color: var(--ink-3); }
.pc-send{ width: 40px; height: 38px; border-radius: 12px; background: var(--gold); color: var(--night); display: grid; place-items: center; font-size: 14px; flex: 0 0 auto; }

/* -- cartes preuve -- */
.proof-cards{ display: flex; flex-direction: column; gap: 14px; }
.pcard{ position: relative; display: flex; gap: 18px; align-items: flex-start; border-radius: 20px; padding: 22px 24px; overflow: hidden; transition: transform .2s; }
.pcard:hover{ transform: translateY(-2px); }
.pcard .pc-n{ position: absolute; top: 18px; right: 20px; font-family: var(--font-display); font-weight: 700; font-size: 14px; letter-spacing: .05em; opacity: .5; }
.pcard .pc-ic{ flex: 0 0 auto; width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; font-size: 20px; }
.pcard .pc-body{ min-width: 0; }
.pcard .pc-top{ display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.pcard h4{ font-family: var(--font-display); font-size: 18px; }
.pcard p{ margin-top: 6px; font-size: 14px; line-height: 1.5; }
.pcard .pc-tag{ font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; padding: 4px 9px; border-radius: 999px; }
.pc-dark{ background: linear-gradient(135deg,#241610,#1b110b); color: var(--cream-on-dark); }
.pc-caramel{ background: linear-gradient(135deg,var(--caramel-2),#9a5238); color: #fff; }
.pc-gold{ background: linear-gradient(135deg,var(--gold-2),var(--gold)); color: var(--night); }
.pc-dark .pc-ic{ background: rgba(244,235,219,.1); color: var(--gold-2); }
.pc-caramel .pc-ic{ background: rgba(255,255,255,.16); color: #fff; }
.pc-gold .pc-ic{ background: rgba(27,17,11,.12); color: var(--night); }
.pc-dark p{ color: var(--muted-on-dark); }
.pc-caramel p{ color: rgba(255,255,255,.82); }
.pc-gold p{ color: rgba(27,17,11,.72); }
.pc-dark .pc-tag, .pc-caramel .pc-tag{ background: rgba(244,235,219,.14); color: var(--cream-on-dark); }
.pc-gold .pc-tag{ background: rgba(27,17,11,.14); color: var(--night); }

/* -- socle -- */
.proof-socle{ display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 10px; margin-top: 46px; }
.proof-socle .ps-lbl{ font-size: 13px; font-weight: 600; color: var(--ink-3); margin-right: 4px; }
.ps-chip{ display: inline-flex; align-items: center; gap: 8px; height: 34px; padding: 0 14px; border-radius: 999px; background: var(--card); border: 1px solid var(--line); font-size: 13px; font-weight: 600; color: var(--ink-2); }
.ps-chip::before{ content: ""; width: 5px; height: 5px; border-radius: 50%; background: var(--caramel); }

/* ============ VALEURS ============ */
.val-grid{ display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.val-card{ border-radius: var(--r-lg); padding: 30px; border: 1px solid var(--line-on-dark); background: rgba(244,235,219,.05); }
.val-card .vn{ font-family: var(--font-mono); font-size: 12px; color: var(--gold-2); letter-spacing: .1em; }
.val-card .vi{ font-size: 30px; margin: 14px 0 16px; }
.val-card h4{ font-size: 21px; color: var(--cream-on-dark); }
.val-card p{ margin-top: 11px; font-size: 14.5px; line-height: 1.55; color: var(--muted-on-dark); }

/* ============ BANNER CTA ============ */
.banner{ position: relative; overflow: hidden; }
.banner-in{ position: relative; z-index: 2; display: grid; grid-template-columns: 1.1fr .9fr; gap: 40px; align-items: center;
  border-radius: var(--r-2xl); padding: 56px; }
.banner.part .banner-in{ background: linear-gradient(150deg, #C97E5C, #8a4a30); color: #fff; box-shadow: var(--shadow-lg); }
.banner.org .banner-in{ background: linear-gradient(150deg, #2A1A10, #140c07); color: var(--cream-on-dark); box-shadow: var(--shadow-lg); border: 1px solid var(--night-3); }
.banner-in::after{ content:""; position: absolute; inset: 0; pointer-events: none; border-radius: inherit;
  background-image: radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px); background-size: 24px 24px; opacity: .6;
  mask-image: linear-gradient(110deg,#000,transparent 70%); }
.banner-copy{ position: relative; z-index: 2; }
.banner .bk{ font-family: var(--font-mono); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; opacity: .85; }
.banner h3{ font-size: clamp(28px,3.4vw,42px); letter-spacing: -.03em; margin-top: 12px; line-height: 1.02; }
.banner p{ margin-top: 14px; font-size: 16.5px; line-height: 1.5; max-width: 460px; opacity: .9; }
.banner .banner-cta{ position: relative; z-index: 2; display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
.banner.part .store-btn{ background: var(--night); }
.banner-cta .qr{ display: flex; align-items: center; gap: 14px; margin-top: 6px; }
.banner-cta .qr .qbox{ width: 76px; height: 76px; border-radius: 14px; background: #FFFDF8; padding: 9px; }
.banner-cta .qr .qbox div{ width: 100%; height: 100%; border-radius: 5px; background-image: repeating-conic-gradient(#1B110B 0% 25%, #fff 0% 50%); background-size: 12px 12px; }
.banner-cta .qr .qt{ font-size: 13.5px; line-height: 1.4; opacity: .9; max-width: 150px; }

/* ============ POSITION AUJOURD'HUI ============ */
.pos-grid{ display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.pos-stats{ display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.pos-stat{ background: var(--card); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 26px; box-shadow: var(--shadow-sm); }
.pos-stat .num{ font-family: var(--font-display); font-size: clamp(34px,4vw,46px); font-weight: 800; letter-spacing: -.03em; color: var(--ink); }
.pos-stat .num .u{ font-size: 20px; color: var(--gold-deep); }
.pos-stat .lab{ margin-top: 6px; font-size: 14px; color: var(--ink-2); line-height: 1.4; }
.pos-now{ display: inline-flex; align-items: center; gap: 10px; padding: 9px 16px; border-radius: 999px; background: var(--night); color: var(--gold-2); font-size: 13.5px; font-weight: 600; margin-bottom: 22px; }
.pos-now .ld{ width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 4px rgba(46,159,105,.28); }
.pos-copy h2{ font-size: clamp(30px,3.6vw,46px); }
.pos-copy p{ margin-top: 18px; font-size: 16.5px; line-height: 1.6; color: var(--ink-2); }
.city-grid{ display: flex; flex-wrap: wrap; gap: 11px; margin-top: 26px; }
.city-chip{ display: inline-flex; align-items: center; gap: 9px; height: 44px; padding: 0 18px; border-radius: 999px; border: 1px solid var(--line); background: var(--card); font-size: 14px; font-weight: 600; color: var(--ink-2); }
.city-chip.live{ background: var(--caramel); color: #fff; border-color: var(--caramel); }
.city-chip .ld{ width: 8px; height: 8px; border-radius: 50%; background: #fff; box-shadow: 0 0 0 4px rgba(255,255,255,.3); }
.city-chip.soon{ border-style: dashed; color: var(--ink-3); background: transparent; }

/* ============ TARIFS ============ */
.price-grid{ display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; align-items: stretch; }
.price-card{ background: var(--card); border: 1px solid var(--line); border-radius: var(--r-xl); padding: 34px; display: flex; flex-direction: column; box-shadow: var(--shadow-sm); }
.price-card.feat{ background: linear-gradient(170deg,#2a1a10,#1b110b); color: var(--cream-on-dark); border-color: var(--night-3); box-shadow: var(--shadow-lg); transform: scale(1.03); }
.price-card .pl-name{ font-family: var(--font-display); font-size: 21px; font-weight: 700; }
.price-card .pl-tag{ font-size: 13.5px; color: var(--ink-2); margin-top: 6px; min-height: 38px; }
.price-card.feat .pl-tag{ color: var(--muted-on-dark); }
.price-card .pl-price{ margin: 18px 0 4px; font-family: var(--font-display); font-size: 42px; font-weight: 800; letter-spacing: -.02em; }
.price-card .pl-price small{ font-size: 15px; font-weight: 600; color: var(--ink-3); letter-spacing: 0; }
.price-card.feat .pl-price small{ color: var(--muted-on-dark); }
.price-card .pl-badge{ align-self: flex-start; font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 6px 11px; border-radius: 999px; background: var(--gold); color: var(--night); margin-bottom: 16px; }
.pl-list{ list-style: none; padding: 0; margin: 22px 0 28px; display: flex; flex-direction: column; gap: 13px; flex: 1; }
.pl-list li{ display: flex; gap: 11px; font-size: 14.5px; line-height: 1.4; color: var(--ink-2); }
.price-card.feat .pl-list li{ color: var(--muted-on-dark); }
.pl-list li .ck{ flex: 0 0 20px; width: 20px; height: 20px; border-radius: 50%; background: rgba(46,159,105,.14); color: var(--green-deep); display: grid; place-items: center; font-size: 11px; margin-top: 1px; }
.price-card.feat .pl-list li .ck{ background: rgba(227,169,67,.18); color: var(--gold-2); }

/* ============ CALCULATEUR ============ */
.calc{ margin-top: 30px; border-radius: var(--r-2xl); overflow: hidden; border: 1px solid var(--line); background: var(--card); box-shadow: var(--shadow); }
.calc-head{ display: flex; align-items: center; gap: 16px; flex-wrap: wrap; padding: 26px 34px; border-bottom: 1px solid var(--line); background: var(--cream-2); }
.calc-head .ct{ font-family: var(--font-display); font-size: 20px; font-weight: 700; }
.calc-head .cd{ font-size: 14px; color: var(--ink-2); }
.calc-seg{ margin-left: auto; display: inline-flex; padding: 4px; gap: 4px; border-radius: 999px; background: var(--cream-3); border: 1px solid var(--line); }
.calc-seg button{ height: 40px; padding: 0 20px; border-radius: 999px; font-size: 14px; font-weight: 650; color: var(--ink-2); display: inline-flex; align-items: center; gap: 8px; transition: background .2s, color .2s; }
.calc-seg button.on{ background: var(--night); color: var(--gold-2); }
.calc-seg button[data-calc="part"].on{ background: var(--caramel); color: #fff; }
.cin-cur{ display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.cin-cur .k{ font-weight: 650; color: var(--ink-2); }
.cur-seg{ display: inline-flex; padding: 4px; gap: 4px; border-radius: 999px; background: var(--cream-3); border: 1px solid var(--line); }
.cur-seg button{ height: 34px; padding: 0 16px; border-radius: 999px; font-size: 13px; font-weight: 650; color: var(--ink-2); display: inline-flex; align-items: center; transition: background .2s, color .2s; }
.cur-seg button.on{ background: var(--night); color: var(--gold-2); }
.calc-body{ display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.calc-inputs{ padding: 34px; display: flex; flex-direction: column; gap: 28px; border-right: 1px solid var(--line); }
.cin .clab{ display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 12px; }
.cin .clab .k{ font-size: 14.5px; font-weight: 600; color: var(--ink); }
.cin .clab .v{ font-family: var(--font-display); font-size: 20px; font-weight: 800; color: var(--caramel); }
.cin .clab .v small{ font-size: 13px; font-weight: 600; color: var(--ink-3); }
input[type=range]{ -webkit-appearance: none; appearance: none; width: 100%; height: 6px; border-radius: 999px; background: var(--cream-3); outline: none; }
input[type=range]::-webkit-slider-thumb{ -webkit-appearance: none; appearance: none; width: 24px; height: 24px; border-radius: 50%; background: var(--gold); border: 3px solid #fff; box-shadow: 0 2px 8px rgba(42,26,18,.25); cursor: pointer; }
input[type=range]::-moz-range-thumb{ width: 24px; height: 24px; border-radius: 50%; background: var(--gold); border: 3px solid #fff; box-shadow: 0 2px 8px rgba(42,26,18,.25); cursor: pointer; }
.calc-part input[type=range]::-webkit-slider-thumb{ background: var(--caramel); }
.calc-part input[type=range]::-moz-range-thumb{ background: var(--caramel); }
.cin .crange-tags{ display: flex; justify-content: space-between; margin-top: 9px; font-size: 11.5px; color: var(--ink-3); }
.cin .cnumber{ display: flex; align-items: center; gap: 10px; }
.cin .cnumber button{ width: 44px; height: 44px; border-radius: 12px; border: 1px solid var(--line); background: var(--cream-2); font-size: 22px; font-weight: 600; color: var(--ink); display: grid; place-items: center; transition: background .15s; }
.cin .cnumber button:hover{ background: var(--cream-3); }
.cin .cnumber input{ flex: 1; height: 48px; border-radius: 12px; border: 1px solid var(--line); background: var(--cream-2); text-align: center; font-family: var(--font-display); font-size: 19px; font-weight: 700; color: var(--ink); }
.cin .cnumber input:focus{ outline: 2px solid var(--gold); }

.calc-out{ padding: 34px; display: flex; flex-direction: column; }
.calc-out .res-main{ background: linear-gradient(165deg,#2a1a10,#1b110b); color: var(--cream-on-dark); border-radius: var(--r-lg); padding: 26px; }
.calc-part .calc-out .res-main{ background: linear-gradient(165deg, #C97E5C, #8a4a30); }
.calc-out .res-main .rk{ font-size: 13px; color: var(--muted-on-dark); font-weight: 600; }
.calc-part .calc-out .res-main .rk{ color: rgba(255,255,255,.8); }
.calc-out .res-main .rv{ font-family: var(--font-display); font-size: clamp(36px,4.2vw,52px); font-weight: 800; letter-spacing: -.03em; margin-top: 6px; color: var(--gold-2); }
.calc-part .calc-out .res-main .rv{ color: #fff; }
.calc-out .res-main .rv small{ font-size: 18px; font-weight: 700; }
.calc-out .res-main .rsub{ font-size: 13px; color: var(--muted-on-dark); margin-top: 8px; }
.calc-part .calc-out .res-main .rsub{ color: rgba(255,255,255,.85); }
.res-rows{ margin-top: 18px; display: flex; flex-direction: column; }
.res-row{ display: flex; align-items: center; justify-content: space-between; padding: 13px 0; border-bottom: 1px solid var(--line); font-size: 14.5px; }
.res-row:last-child{ border-bottom: none; }
.res-row .rl{ color: var(--ink-2); display: inline-flex; align-items: center; gap: 9px; }
.res-row .rl .dot{ width: 9px; height: 9px; border-radius: 3px; }
.res-row .rr{ font-family: var(--font-display); font-weight: 700; color: var(--ink); font-size: 16px; }
.res-row .rr.gold{ color: var(--gold-deep); }
.res-row .rr.green{ color: var(--green-deep); }
.res-row .rr.caramel{ color: var(--caramel); }
.calc-note{ margin-top: 18px; font-size: 12.5px; line-height: 1.5; color: var(--ink-3); }
.calc-kolo{ margin-top: 16px; display: flex; align-items: center; gap: 12px; background: rgba(227,169,67,.1); border: 1px solid rgba(227,169,67,.28); border-radius: var(--r); padding: 14px 16px; }
.calc-kolo .cc-ic{ width: 50px; height: 50px; background: transparent; display: grid; place-items: center; }
/* Icône KOLO (cauri SVG) — carte preuve « 04 » + encarts cashback du simulateur.
   Pas d'enveloppe : le cauri s'affiche seul, sans fond/cadre. */
.pc-ic:has(.kolo-svg){ background: transparent; }
.pc-ic .kolo-svg{ width: 34px; height: 34px; display: block; }
.cc-ic .kolo-svg{ width: 34px; height: 34px; display: block; }
.calc-kolo .cc-t{ font-size: 13.5px; line-height: 1.4; color: var(--ink-2); }
.calc-kolo .cc-t b{ color: var(--ink); }
.calc-kolo .cc-eq{ color: var(--green-deep); font-weight: 600; white-space: nowrap; }
.calc-kolo .cc-eq b{ color: var(--green-deep); }
.res-row .rr small{ display: block; font-family: var(--font-body); font-weight: 600; font-size: 11.5px; color: var(--ink-3); margin-top: 1px; }

/* ============ FAQ ============ */
.faq-wrap{ max-width: 820px; margin: 0 auto; }
.faq{ border-bottom: 1px solid var(--line); }
.faq summary{ list-style: none; cursor: pointer; padding: 24px 0; display: flex; align-items: center; justify-content: space-between; gap: 20px; font-family: var(--font-display); font-size: 19px; font-weight: 600; color: var(--ink); }
.faq summary::-webkit-details-marker{ display: none; }
.faq .q-ic{ flex: 0 0 30px; width: 30px; height: 30px; border-radius: 50%; border: 1px solid var(--line); display: grid; place-items: center; transition: transform .25s, background .2s, color .2s; font-size: 16px; color: var(--caramel); }
.faq[open] .q-ic{ transform: rotate(45deg); background: var(--night); color: var(--gold-2); border-color: var(--night); }
.faq .a{ padding: 0 0 26px; font-size: 15.5px; line-height: 1.62; color: var(--ink-2); max-width: 700px; }

/* ============ FOOTER ============ */
.footer{ background: #140c07; color: rgba(244,235,219,.62); padding: 70px 0 36px; }
.foot-top{ display: grid; grid-template-columns: 1.7fr 1fr 1fr 1fr; gap: 36px; }
.foot-brand .logo{ height: 34px; margin-bottom: 18px; }
.foot-brand p{ font-size: 14px; line-height: 1.55; max-width: 300px; }
.foot-col h5{ font-family: var(--font-display); color: #F4EBDB; font-size: 14px; margin-bottom: 16px; letter-spacing: .02em; }
.foot-col a{ display: block; font-size: 14px; padding: 6px 0; color: rgba(244,235,219,.62); transition: color .15s; }
.foot-col a:hover{ color: var(--gold-2); }
.foot-legal{ margin-top: 44px; padding-top: 22px; border-top: 1px solid rgba(244,235,219,.13); display: flex; flex-wrap: wrap; gap: 10px 22px; }
.foot-legal a{ font-size: 13px; color: rgba(244,235,219,.62); transition: color .15s; }
.foot-legal a:hover{ color: var(--gold-2); }
.foot-bottom{ margin-top: 18px; display: flex; justify-content: space-between; align-items: center; gap: 16px; font-size: 13px; color: rgba(244,235,219,.34); flex-wrap: wrap; }
.foot-fon{ color: var(--gold-2); font-style: italic; }

/* ============ REVEAL ============ */
.rev{ opacity: 0; transform: translateY(22px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.rev.in{ opacity: 1; transform: none; }
.rev.d1{ transition-delay: .07s; } .rev.d2{ transition-delay: .14s; } .rev.d3{ transition-delay: .21s; } .rev.d4{ transition-delay: .28s; }
@media (prefers-reduced-motion: reduce){ .rev{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* ============ RESPONSIVE ============ */
@media (max-width: 1027px){
  .nav-links{ display: none; }
  .nav-burger{ display: flex; }
}
@media (max-width: 1000px){
  .hero-in{ grid-template-columns: 1fr; gap: 14px; padding-top: 52px; padding-bottom: 56px; }
  .hero-phones{ min-height: 0; margin-top: 26px; transform: scale(.92); }
  .steps.on{ grid-template-columns: 1fr 1fr; }
  .step .conn{ display: none; }
  .why-grid{ grid-template-columns: 1fr; }
  .proof-grid{ grid-template-columns: 1fr; gap: 40px; }
  .proof-phones{ order: 2; }
  .proof-cards{ order: 1; }
  .val-grid{ grid-template-columns: 1fr 1fr; }
  .pos-grid{ grid-template-columns: 1fr; gap: 40px; }
  .price-grid{ grid-template-columns: 1fr; }
  .price-card.feat{ transform: none; }
  .calc-body{ grid-template-columns: 1fr; }
  .calc-inputs{ border-right: none; border-bottom: 1px solid var(--line); }
  .banner-in{ grid-template-columns: 1fr; gap: 28px; padding: 40px; }
  .foot-top{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px){
  .wrap{ padding: 20px; }
  .nav-links{ display: none; }
  .sec{ padding: 70px 0; }
  .steps.on{ grid-template-columns: 1fr; }
  .val-grid{ grid-template-columns: 1fr; }
  .pos-stats{ grid-template-columns: 1fr 1fr; }
  .foot-top{ grid-template-columns: 1fr; gap: 28px; }
  .hero h1{ font-size: clamp(38px,11vw,58px); }
  .calc-seg{ margin-left: 0; width: 100%; }
  .calc-seg button{ flex: 1; justify-content: center; padding: 0 10px; }
  .nav .nav-cta .hide-sm{ display: none; }
  .nav-drawer .drawer-secondary{ display: flex; }
}
@media (max-width: 560px){
  .proof-socle{ justify-content: flex-start; }
  /* Plus de place pour le bouton gold → on le déplace dans le hamburger */
  .nav-cta-primary{ display: none; }
  .nav-drawer .drawer-primary{ display: flex; }
}
/* Le "V" reste côte à côte sur mobile : on réduit sa taille (cadre + contenu)
   via `zoom` par paliers pour qu'il tienne toujours dans la largeur, sans rogner
   le téléphone de droite. Valeurs calées sur la largeur réelle du V. */
@media (max-width: 680px){ .proof-phones{ zoom: .80; } }
@media (max-width: 520px){ .proof-phones{ zoom: .60; } }
@media (max-width: 420px){ .proof-phones{ zoom: .48; } }
@media (max-width: 360px){ .proof-phones{ zoom: .42; } }
@media (max-width: 480px){
  .phone.p-back{ display: none; }
  .phone.p-front{ transform: none; }
}

/* ============ TARIFS — PALIERS + CARTE « ENTRE NOUS » (redesign) ============ */
/* eyebrow centré avec une barre de chaque côté */
.kicker-c{ justify-content: center; }

/* --- 3 paliers en cercles --- */
.tiers{ display: flex; justify-content: center; align-items: flex-start; gap: clamp(20px,5vw,72px); flex-wrap: wrap; margin: 4px 0 64px; }
.tier{ position: relative; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.tier-circle{ width: 168px; height: 168px; border-radius: 50%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px;
  background: var(--card); border: 1px solid var(--caramel-soft); box-shadow: var(--shadow-sm); }
.tier-val{ font-family: var(--font-display); font-weight: 800; font-size: 40px; line-height: 1; letter-spacing: -.03em; color: var(--caramel); display: flex; flex-direction: column; align-items: center; gap: 2px; }
.tier-val small{ font-size: 12px; font-weight: 600; letter-spacing: .04em; color: var(--ink-3); }
.tier-unit{ font-size: 12.5px; color: var(--ink-3); }
.tier-cap{ font-size: 13.5px; font-weight: 650; color: var(--ink); text-align: center; max-width: 170px; line-height: 1.35; }
.tier-cap em{ font-style: normal; color: var(--ink-3); font-weight: 500; }
/* palier vedette : plus grand + dégradé doré */
.tier-feat{ margin-top: -14px; }
.tier-feat .tier-circle{ width: 196px; height: 196px; border: 1px solid var(--gold); background: linear-gradient(165deg,#FCEFD3,#F7E0B0);
  box-shadow: 0 22px 48px -18px rgba(185,132,44,.55); }
.tier-feat .tier-val{ font-size: 48px; color: var(--gold-deep); }
.tier-feat .tier-unit{ color: var(--gold-deep); opacity: .8; }
.tier-badge{ position: absolute; top: -12px; left: 50%; transform: translateX(-50%); white-space: nowrap; z-index: 2;
  font-size: 11px; font-weight: 700; letter-spacing: .04em; padding: 6px 14px; border-radius: 999px;
  background: var(--night); color: var(--gold-2); box-shadow: var(--shadow-sm); }

/* bandeau gratuit / 0 % sous les paliers */
.tier-free{ display: flex; align-items: center; gap: 16px; max-width: 720px; margin: 0 auto 30px; padding: 16px 22px;
  background: rgba(46,159,105,.08); border: 1px solid rgba(46,159,105,.22); border-radius: 999px; }
.tier-free .tf-pill{ flex: 0 0 auto; font-family: var(--font-display); font-weight: 800; font-size: 20px; letter-spacing: -.02em;
  color: #fff; background: var(--green); padding: 8px 16px; border-radius: 999px; }
.tier-free p{ margin: 0; font-size: 14px; line-height: 1.45; color: var(--ink-2); }
.tier-free p b{ color: var(--ink); font-weight: 650; }

/* --- carte « entre nous » : J'organise | Je participe --- */
.duo{ position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  background: linear-gradient(165deg,#FBF6EC,#F4EAD6); border: 1px solid var(--line); border-radius: var(--r-2xl);
  box-shadow: var(--shadow-lg); padding: 48px clamp(36px,5vw,64px); overflow: hidden; }
.duo-col{ display: flex; flex-direction: column; }
.duo-org{ padding-right: clamp(28px,4vw,56px); border-right: 1px solid var(--line); }
.duo-part{ padding-left: clamp(28px,4vw,56px); }
.duo-head{ display: flex; align-items: center; gap: 14px; margin-bottom: 26px; }
.duo-part .duo-head{ justify-content: flex-end; text-align: right; }
.duo-ic{ flex: 0 0 46px; width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; font-size: 22px; background: rgba(181,105,74,.14); }
.duo-ic.part{ background: rgba(46,159,105,.16); }
.duo-ht h3{ font-size: 22px; letter-spacing: -.02em; }
.duo-ht p{ margin: 4px 0 0; font-size: 13.5px; color: var(--ink-2); }
.duo-list{ list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0; }
.duo-list li{ display: flex; align-items: flex-start; gap: 13px; padding: 14px 0; border-bottom: 1px solid var(--line-2); }
.duo-list li:last-child{ border-bottom: none; }
.duo-list.right li{ justify-content: flex-end; }
.duo-tx{ display: flex; flex-direction: column; gap: 3px; }
.duo-tx b{ font-size: 14.5px; font-weight: 650; color: var(--ink); line-height: 1.3; }
.duo-tx span{ font-size: 12.5px; line-height: 1.45; color: var(--ink-2); }
.duo-list.right .duo-tx{ align-items: flex-end; text-align: right; }
.duo-ck{ flex: 0 0 22px; width: 22px; height: 22px; margin-top: 1px; border-radius: 50%; display: grid; place-items: center; font-size: 12px; font-weight: 800; color: #fff; }
.duo-ck.org{ background: var(--caramel); }
.duo-ck.part{ background: var(--green); }
/* médaillon central */
.duo-seal{ position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 3;
  width: 66px; height: 66px; border-radius: 50%; display: grid; place-items: center; text-align: center;
  font-family: var(--font-display); font-weight: 700; font-size: 12px; line-height: 1.05; letter-spacing: .02em;
  color: var(--gold-2); background: var(--night); box-shadow: 0 0 0 8px var(--cream-2), var(--shadow); }

@media (max-width: 1000px){
  .tier-feat{ margin-top: 0; }
  .tier-free{ flex-direction: column; text-align: center; border-radius: var(--r-lg); gap: 12px; }
  .duo{ grid-template-columns: 1fr; padding: 36px; gap: 36px; }
  .duo-org{ padding-right: 0; border-right: none; border-bottom: 1px solid var(--line); padding-bottom: 36px; }
  .duo-part{ padding-left: 0; }
  /* On conserve l'alignement à droite du bloc participant (check sur le bord
     droit, texte aligné à droite) — pas de bascule en row-reverse qui décalait. */
  .duo-seal{ display: none; }
}

/* ============ CONTACT — WhatsApp d'abord ============ */
.sec-head h2 .wa{ color: var(--green); }
.contact-grid{ display: grid; grid-template-columns: 1fr 1fr; gap: 36px; align-items: start; }

/* maquette de conversation (colonne gauche) */
.contact-chat{ background: var(--night); border: 1px solid var(--night-3); border-radius: var(--r-xl); padding: 14px; box-shadow: var(--shadow-phone); display: flex; flex-direction: column; }
.cc-head{ display: flex; align-items: center; gap: 12px; padding: 8px 8px 14px; border-bottom: 1px solid var(--line-on-dark); }
.cc-av{ flex: 0 0 40px; width: 40px; height: 40px; border-radius: 50%; background: var(--gold); color: var(--night); display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; font-size: 17px; }
.cc-who{ display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.cc-who b{ color: var(--cream-on-dark); font-size: 15px; font-weight: 700; }
.cc-on{ display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--green); }
.cc-dot{ width: 7px; height: 7px; border-radius: 50%; background: var(--green); }
.cc-call{ color: var(--muted-on-dark); font-size: 16px; }
.cc-thread{ display: flex; flex-direction: column; gap: 10px; padding: 16px 6px; }
.cc-day{ align-self: center; font-size: 11px; color: var(--muted-on-dark); background: rgba(244,235,219,.07); padding: 3px 12px; border-radius: 999px; }
.cc-msg{ position: relative; max-width: 86%; font-size: 13.5px; line-height: 1.42; padding: 9px 13px 19px; border-radius: 13px; }
.cc-msg b{ font-weight: 700; }
.cc-msg.out{ align-self: flex-end; background: #1F4D38; color: #EAFBF1; border-bottom-right-radius: 4px; }
.cc-msg.in{ align-self: flex-start; background: #FBF6EC; color: var(--ink); border-bottom-left-radius: 4px; }
.cc-msg .cc-t{ position: absolute; right: 11px; bottom: 5px; font-size: 9.5px; opacity: .55; }
.cc-input{ display: flex; align-items: center; gap: 10px; margin-top: 6px; padding: 6px 6px 6px 18px; background: rgba(244,235,219,.06); border: 1px solid var(--line-on-dark); border-radius: 999px; }
.cc-input span:first-child{ flex: 1; color: var(--muted-on-dark); font-size: 13px; }
.cc-send{ flex: 0 0 38px; width: 38px; height: 38px; border-radius: 50%; background: var(--green); color: #fff; display: grid; place-items: center; font-size: 14px; }

/* canaux (colonne droite) */
.contact-side{ display: flex; flex-direction: column; gap: 22px; }
.contact-primary{ background: var(--card); border: 1px solid rgba(46,159,105,.32); border-radius: var(--r-lg); padding: 24px; box-shadow: var(--shadow-sm); }
.cp-top{ display: flex; align-items: center; gap: 14px; }
.cp-ic{ flex: 0 0 50px; width: 50px; height: 50px; border-radius: 15px; background: var(--green); display: grid; place-items: center; box-shadow: 0 6px 16px -5px rgba(46,159,105,.55); }
.cp-ic svg{ width: 27px; height: 27px; fill: #fff; }
.cp-ht{ display: flex; flex-direction: column; gap: 3px; }
.cp-ht b{ font-family: var(--font-display); font-size: 19px; font-weight: 700; color: var(--ink); }
.cp-ht span{ font-size: 13px; color: var(--ink-2); }
.cp-act{ display: flex; align-items: center; gap: 16px; margin: 20px 0 18px; flex-wrap: wrap; }
.btn-wa{ display: inline-flex; align-items: center; gap: 9px; background: var(--green); color: #fff; font-weight: 650; font-size: 15px; padding: 13px 22px; border-radius: 999px; box-shadow: 0 6px 18px -4px rgba(46,159,105,.5); transition: background .2s, box-shadow .2s; }
.btn-wa:hover{ background: var(--green-deep); box-shadow: 0 10px 26px -6px rgba(46,159,105,.6); }
.btn-wa svg{ width: 18px; height: 18px; fill: #fff; }
.cp-num{ font-family: var(--font-display); font-weight: 700; color: var(--ink); font-size: 16px; }
.cp-chips{ display: flex; flex-wrap: wrap; gap: 8px; }
.cp-chip{ font-size: 12px; color: var(--ink-2); background: var(--cream-2); border: 1px solid var(--line); padding: 7px 12px; border-radius: 999px; white-space: nowrap; }

.contact-alt-label{ font-family: var(--font-mono); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-3); }
.contact-alt{ display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.alt-card{ display: flex; align-items: flex-start; gap: 12px; background: var(--card); border: 1px solid var(--line); border-radius: var(--r); padding: 16px; box-shadow: var(--shadow-sm); transition: transform .15s, border-color .2s; }
.alt-card:hover{ transform: translateY(-2px); border-color: var(--caramel-soft); }
.alt-ic{ flex: 0 0 38px; width: 38px; height: 38px; border-radius: 11px; background: rgba(181,105,74,.12); display: grid; place-items: center; font-size: 17px; }
.alt-tx{ display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.alt-tx b{ font-size: 14.5px; font-weight: 650; color: var(--ink); }
.alt-hi{ font-size: 13px; color: var(--caramel); font-weight: 600; }
.alt-tx small{ font-size: 11.5px; color: var(--ink-3); }

@media (max-width: 1000px){
  .contact-grid{ grid-template-columns: 1fr; gap: 28px; }
}
@media (max-width: 480px){
  .contact-alt{ grid-template-columns: 1fr; }
  .cp-act{ gap: 12px; }
}

/* ===========================================================
   ANIMATIONS — futuriste à l'africaine
   Couche additive : motifs géométriques, lueurs, flottements,
   shimmer or. Tout est neutralisé en prefers-reduced-motion.
   =========================================================== */

/* -- Barre de progression du défilement -- */
.scroll-progress{ position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 100; pointer-events: none;
  background: linear-gradient(90deg, var(--caramel), var(--gold), var(--gold-2));
  box-shadow: 0 0 14px rgba(227,169,67,.6); transition: width .12s linear; }

/* -- Nav : élévation au défilement -- */
.nav{ transition: box-shadow .3s ease, background .3s ease; }
.nav.scrolled{ box-shadow: 0 12px 32px -14px rgba(40,22,8,.28); background: color-mix(in srgb, var(--cream-2) 93%, transparent); }

/* -- Hero : aurora chaude animée -- */
.hero::before{ content:""; position: absolute; inset: -12% -12% 0 -12%; z-index: 1; pointer-events: none;
  background:
    radial-gradient(420px 320px at 22% 28%, rgba(227,169,67,.30), transparent 60%),
    radial-gradient(360px 300px at 80% 18%, rgba(181,105,74,.26), transparent 62%),
    radial-gradient(400px 340px at 62% 82%, rgba(242,204,131,.24), transparent 60%);
  filter: blur(22px); animation: aurora 18s ease-in-out infinite alternate; }
@keyframes aurora{
  0%  { transform: translate3d(0,0,0) scale(1); }
  50% { transform: translate3d(-3%, 2%, 0) scale(1.08); }
  100%{ transform: translate3d(3%, -2%, 0) scale(1.04); }
}
/* dérive douce des points du hero */
.hero::after{ animation: dot-drift 30s linear infinite; }
@keyframes dot-drift{ to{ background-position: 26px 52px; } }

/* -- Bande "kente" animée en haut du bandeau sombre -- */
.strip{ position: relative; overflow: hidden; }
.strip::before{ content:""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: repeating-linear-gradient(90deg,
    var(--gold) 0 22px, var(--caramel) 22px 44px, var(--green) 44px 60px, var(--red) 60px 76px, var(--gold-deep) 76px 96px);
  background-size: 96px 100%; animation: kente 7s linear infinite; }
@keyframes kente{ to{ background-position: 96px 0; } }

/* -- Motif géométrique africain dérivant (sections sombres) -- */
.afro-band{ position: relative; overflow: hidden; }
.afro-band > .wrap{ position: relative; z-index: 1; }
.afro-band::before{ content:""; position: absolute; inset: 0; pointer-events: none; opacity: .08; color: var(--gold-2);
  background-image:
    repeating-linear-gradient(45deg, currentColor 0 2px, transparent 2px 16px),
    repeating-linear-gradient(-45deg, currentColor 0 2px, transparent 2px 16px),
    radial-gradient(currentColor 1.4px, transparent 1.6px);
  background-size: 32px 32px, 32px 32px, 22px 22px;
  animation: afro-drift 26s linear infinite; }
@keyframes afro-drift{ to{ background-position: 64px 0, -64px 0, 44px 44px; } }
/* losanges "mudcloth" en surcouche, dérive inverse pour un fond plus riche */
.afro-band::after{ content:""; position: absolute; inset: 0; pointer-events: none; z-index: 0; opacity: .06; color: var(--caramel-soft);
  background-image:
    repeating-linear-gradient(0deg, currentColor 0 1.5px, transparent 1.5px 40px),
    repeating-linear-gradient(90deg, currentColor 0 1.5px, transparent 1.5px 40px);
  background-size: 40px 40px; animation: afro-drift-2 34s linear infinite; }
@keyframes afro-drift-2{ to{ background-position: -40px 40px, 40px -40px; } }

/* -- Motif africain doux (sections claires) -- */
.afro-soft{ position: relative; }
.afro-soft > .wrap{ position: relative; z-index: 1; }
.afro-soft::before{ content:""; position: absolute; inset: 0; pointer-events: none; z-index: 0; opacity: .045; color: var(--caramel);
  background-image:
    repeating-linear-gradient(60deg, currentColor 0 1.5px, transparent 1.5px 20px),
    repeating-linear-gradient(-60deg, currentColor 0 1.5px, transparent 1.5px 20px),
    radial-gradient(currentColor 1.3px, transparent 1.5px);
  background-size: 34px 58px, 34px 58px, 26px 26px;
  animation: afro-drift 32s linear infinite;
  -webkit-mask-image: linear-gradient(180deg, transparent, #000 18%, #000 82%, transparent);
  mask-image: linear-gradient(180deg, transparent, #000 18%, #000 82%, transparent); }

/* -- Titre : mot accent en dégradé chatoyant -- */
.hero h1 .accent{
  background: linear-gradient(100deg, var(--caramel) 0%, var(--gold) 34%, var(--gold-2) 50%, var(--gold) 66%, var(--caramel) 100%);
  background-size: 220% auto; -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  animation: shimmer-text 7s linear infinite; }
@keyframes shimmer-text{ to{ background-position: 220% center; } }

/* -- Maquettes téléphone : flottement (transforms de base préservés) -- */
.hero-phones{ transition: transform .25s ease; }
.hero-phones .p-front{ animation: float-front 7s ease-in-out infinite; }
.hero-phones .p-back{ animation: float-back 9s ease-in-out infinite; }
@keyframes float-front{ 0%,100%{ transform: rotate(-3deg) translateY(0); } 50%{ transform: rotate(-3deg) translateY(-16px); } }
@keyframes float-back{ 0%,100%{ transform: rotate(6deg) translate(74px,14px) scale(.86); } 50%{ transform: rotate(6deg) translate(74px,3px) scale(.86); } }
/* "V" : chaque .phone pivote sur son coin bas INTÉRIEUR → les deux apex
   coïncident au centre-bas (gap 0). Rotation intégrée aux keyframes pour ne pas
   être écrasée par le flottement, et reprise en statique pour le reduced-motion. */
.pp-left .phone{ transform-origin: bottom right; transform: translateX(20px) rotate(-4deg); animation: float-front2 8s ease-in-out infinite; }
.pp-right .phone{ transform-origin: bottom left; transform: translateX(-20px) rotate(4deg); animation: float-back2 10s ease-in-out infinite; }
@keyframes float-front2{ 0%,100%{ transform: translateX(20px) rotate(-4deg) translateY(0); } 50%{ transform: translateX(20px) rotate(-4deg) translateY(-8px); } }
@keyframes float-back2{ 0%,100%{ transform: translateX(-20px) rotate(4deg) translateY(0); } 50%{ transform: translateX(-20px) rotate(4deg) translateY(7px); } }

/* -- Lueur du hero qui respire -- */
.glow{ animation: glow-pulse 6s ease-in-out infinite; }
@keyframes glow-pulse{ 0%,100%{ opacity: .8; transform: scale(1); } 50%{ opacity: 1; transform: scale(1.14); } }

/* -- Points "live" qui pulsent -- */
.eyebrow .dot, .pos-now .ld{ animation: pulse-green 2.2s ease-out infinite; }
@keyframes pulse-green{ 0%{ box-shadow: 0 0 0 0 rgba(46,159,105,.5); } 70%,100%{ box-shadow: 0 0 0 11px rgba(46,159,105,0); } }
.city-chip.live .ld{ animation: pulse-white 2.2s ease-out infinite; }
@keyframes pulse-white{ 0%{ box-shadow: 0 0 0 0 rgba(255,255,255,.55); } 70%,100%{ box-shadow: 0 0 0 11px rgba(255,255,255,0); } }

/* -- Reflet or qui balaie les boutons gold (sous le texte) -- */
.btn-gold{ position: relative; overflow: hidden; isolation: isolate; }
.btn-gold::after{ content:""; position: absolute; top: 0; left: -60%; width: 45%; height: 100%; z-index: -1; pointer-events: none;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.55), transparent); transform: skewX(-20deg);
  animation: sheen 5s ease-in-out infinite; }
@keyframes sheen{ 0%, 18%{ left: -60%; } 48%, 100%{ left: 135%; } }

/* -- Survol : élévation + lueur caramel -- */
.val-card, .pos-stat, .tier, .price-card{ transition: transform .25s ease, box-shadow .25s ease; }
.val-card:hover, .pos-stat:hover{ transform: translateY(-4px); box-shadow: 0 20px 44px -18px rgba(181,105,74,.42); }
.pcard{ transition: transform .25s ease, box-shadow .25s ease; }
.pcard:hover{ transform: translateY(-3px); box-shadow: 0 22px 48px -18px rgba(40,22,8,.5); }
.store-btn{ transition: transform .2s ease, box-shadow .2s ease; }
.store-btn:hover{ transform: translateY(-2px); }

/* -- Reveal : ajout d'un léger flou + zoom pour un rendu plus "premium" -- */
.rev{ will-change: transform, opacity; }

/* ===========================================================
   MAQUETTE ANIMÉE DU HERO — thème fidèle aux captures (50s)
   Accueil SOMBRE (feed) affiché avant CHAQUE scénario ; écrans
   avis / publication CLAIRS ; forum = en-tête sombre + corps clair.
   États de base = accueil (prefers-reduced-motion).
   =========================================================== */
.demo-phone{ --loop: 50s; }
.demo-phone .phone-screen{ height: 620px; background: var(--cream-2); }
.demo-phone .statusbar{ position: relative; z-index: 4; color: var(--ink); }
.demo-phone .statusbar .dots span{ background: var(--ink); }
.sc-home .statusbar, .sc-forum .statusbar{ color: var(--cream-on-dark); }
.sc-home .statusbar .dots span, .sc-forum .statusbar .dots span{ background: var(--cream-on-dark); }
.demo-stage{ position: relative; height: 620px; }
.dsc{ position: absolute; inset: 0; overflow: hidden; opacity: 0; background: var(--cream-2); }
.sc-home{ opacity: 1; animation: dm-home var(--loop) ease infinite;
  background:
    radial-gradient(130% 55% at 85% -5%, rgba(135,86,40,.55), rgba(135,86,40,0) 60%),
    linear-gradient(180deg, #34230f 0px, #3c2814 130px, #5f4129 240px, #a98253 290px, var(--cream-3) 325px, var(--cream-2) 380px); }
.sc-actions{ opacity: 0; background: transparent; animation: dm-sc1 var(--loop) ease infinite; }
.sc-note{ animation: dm-sc2 var(--loop) ease infinite; }
.sc-content{ animation: dm-sc3 var(--loop) ease infinite; }
.sc-forum{ animation: dm-sc4 var(--loop) ease infinite; }
.sc-create{ animation: dm-sc5 var(--loop) ease infinite; }
@keyframes dm-home{ 0%{ opacity:1;} 11%{ opacity:1;} 13%{ opacity:0;} 36%{ opacity:0;} 37.5%{ opacity:1;} 43%{ opacity:1;} 45%{ opacity:0;} 94%{ opacity:0;} 98%{ opacity:1;} 100%{ opacity:1;} }
@keyframes dm-sc1{ 0%,8%{ opacity:0;} 9.5%,13%{ opacity:1;} 14%,100%{ opacity:0;} }
@keyframes dm-sc2{ 0%,12%{ opacity:0; transform: translateX(8px);} 14%,23%{ opacity:1; transform:none;} 24.5%,100%{ opacity:0; transform: translateX(-8px);} }
@keyframes dm-sc3{ 0%,23.5%{ opacity:0; transform: translateX(8px);} 25%,36%{ opacity:1; transform:none;} 37.5%,100%{ opacity:0; transform: translateX(-8px);} }
@keyframes dm-sc4{ 0%,43.5%{ opacity:0; transform: translateX(8px);} 45%,65%{ opacity:1; transform:none;} 66.5%,100%{ opacity:0; transform: translateX(-8px);} }
@keyframes dm-sc5{ 0%,64%{ opacity:0; transform: translateX(8px);} 66%,94%{ opacity:1; transform:none;} 96%,100%{ opacity:0; transform: translateX(-8px);} }

/* curseur "tap" générique */
.d-tap{ position: absolute; width: 40px; height: 40px; border-radius: 50%; border: 2px solid var(--caramel); opacity: 0; transform: translate(-50%,-50%) scale(.4); pointer-events: none; z-index: 6; }
.tap1{ left: 50%; top: 66%; animation: dm-rip1 var(--loop) ease infinite; }
.tap2{ left: 84%; top: 90%; animation: dm-rip2 var(--loop) ease infinite; }
.tap3{ left: 86%; top: 8%; animation: dm-rip3 var(--loop) ease infinite; }
@keyframes dm-rip1{ 0%,11%{ opacity:0; transform: translate(-50%,-50%) scale(.4);} 12%{ opacity:.85;} 13.2%{ opacity:0; transform: translate(-50%,-50%) scale(1.3);} 100%{opacity:0;} }
@keyframes dm-rip2{ 0%,63%{ opacity:0; transform: translate(-50%,-50%) scale(.4);} 64.5%{ opacity:.85;} 66%{ opacity:0; transform: translate(-50%,-50%) scale(1.3);} 100%{opacity:0;} }
@keyframes dm-rip3{ 0%,89%{ opacity:0; transform: translate(-50%,-50%) scale(.4);} 90.5%{ opacity:.85;} 92%{ opacity:0; transform: translate(-50%,-50%) scale(1.3);} 100%{opacity:0;} }

/* SCÈNE 0 — page d'accueil (SOMBRE, fidèle à l'app) */
.ho-scroll{ padding-bottom: 64px; will-change: transform; animation: ho-scroll var(--loop) ease infinite; }
@keyframes ho-scroll{ 0%,2%{ transform: translateY(0); } 7%,11%{ transform: translateY(-200px); } 13%,38%{ transform: translateY(0); } 41%,43%{ transform: translateY(-200px); } 45%,100%{ transform: translateY(0); } }
.ho-top{ display: flex; align-items: center; justify-content: space-between; padding: 4px 16px 8px; }
.ho-city{ font-size: 13.5px; font-weight: 700; color: var(--cream-on-dark); }
.ho-bell{ position: relative; font-size: 16px; }
.ho-bell em{ position: absolute; top: -4px; right: -9px; font-style: normal; font-size: 8px; font-weight: 800; color: #fff; background: var(--red); padding: 1px 4px; border-radius: 999px; }
.ho-search{ margin: 0 16px 10px; padding: 10px 13px; border-radius: 12px; background: rgba(244,235,219,.07); border: 1px solid rgba(244,235,219,.13); font-size: 12px; color: rgba(244,235,219,.45); }
.ho-chips{ display: flex; gap: 7px; padding: 0 16px; overflow: hidden; }
.ho-chips span{ flex: 0 0 auto; padding: 6px 13px; border-radius: 999px; font-size: 11.5px; font-weight: 600; color: rgba(244,235,219,.75); background: rgba(244,235,219,.08); border: 1px solid rgba(244,235,219,.13); }
.ho-chips .on{ background: var(--gold); color: var(--night); border-color: var(--gold); }
.ho-greet{ font-family: var(--font-display); font-size: 20px; font-weight: 700; color: var(--cream-on-dark); margin: 11px 16px 0; }
.ho-subt{ font-size: 12px; color: rgba(244,235,219,.6); margin: 4px 16px 0; }
.ho-banner{ display: flex; align-items: center; gap: 10px; margin: 10px 16px 0; padding: 9px 12px; border-radius: 14px; background: rgba(244,235,219,.06); border: 1px solid rgba(244,235,219,.1); }
.ho-bav{ width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; font-size: 15px; background: rgba(227,169,67,.18); flex: 0 0 auto; }
.ho-btx{ flex: 1; font-size: 12px; font-weight: 600; color: var(--cream-on-dark); }
.ho-bcta{ font-size: 12px; font-weight: 700; color: var(--gold-2); }
.ho-tabs2{ display: flex; gap: 4px; margin: 11px 16px 0; padding: 4px; border-radius: 14px; background: #3a2718; box-shadow: var(--shadow); }
.ho-tabs2 span{ flex: 1; display: flex; align-items: center; justify-content: center; gap: 5px; padding: 9px 0; border-radius: 10px; font-size: 12px; font-weight: 700; color: rgba(244,235,219,.6); }
.ho-tabs2 .on{ color: var(--gold-2); box-shadow: inset 0 -2px var(--gold); }
.ho-tabs2 em{ font-style: normal; font-size: 9px; font-weight: 800; background: var(--gold); color: var(--night); padding: 1px 6px; border-radius: 999px; }
.ho-hh{ display: flex; align-items: center; justify-content: space-between; margin: 11px 16px 6px; }
.ho-h{ font-family: var(--font-display); font-size: 16px; font-weight: 700; color: var(--ink); }
.ho-view{ display: inline-flex; gap: 2px; padding: 3px; border-radius: 999px; background: #fff; border: 1px solid var(--line); }
.ho-view i{ width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; font-style: normal; font-size: 12px; color: var(--ink-3); }
.ho-view i.on{ background: var(--gold); color: var(--night); }
.ho-card{ position: relative; margin: 0 16px 11px; padding: 16px; border-radius: 18px; min-height: 138px; background: linear-gradient(150deg,#5a3a22,#2e2545); color: #fff; overflow: hidden; box-shadow: var(--shadow-lg); }
.ho-card::after{ content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,12,7,.05), rgba(20,12,7,.55)); }
.ho-card > *{ position: relative; z-index: 1; }
.ho-fav{ position: absolute; top: 12px; right: 12px; width: 30px; height: 30px; border-radius: 50%; background: rgba(20,12,7,.4); display: grid; place-items: center; font-size: 14px; }
.ho-date{ position: absolute; top: 12px; left: 12px; text-align: center; font-family: var(--font-display); font-weight: 800; font-size: 12px; line-height: 1.05; background: rgba(20,12,7,.5); padding: 6px 9px; border-radius: 10px; }
.ho-badge{ display: inline-block; margin-top: 38px; font-size: 9px; font-weight: 800; letter-spacing: .05em; background: var(--caramel); padding: 4px 9px; border-radius: 999px; }
.ho-badge.green{ background: var(--green); }
.ho-tt{ font-family: var(--font-display); font-size: 18px; font-weight: 700; margin-top: 12px; }
.ho-meta{ font-size: 11.5px; opacity: .85; margin-top: 8px; }
.ho-att{ font-size: 11px; opacity: .72; margin-top: 7px; }
.ho-price{ font-size: 13.5px; font-weight: 800; color: var(--gold-2); margin-top: 12px; }
.ho-card.sm{ min-height: 104px; }
.ho-card.sm .ho-badge{ margin-top: 26px; }
.ho-card.sm .ho-tt{ margin-top: 11px; }
.ho-card.sm .ho-meta{ margin-top: 8px; }
.ho-card.sm .ho-tt{ font-size: 16px; }
.ho-card.g{ background: linear-gradient(150deg,#2f6b4a,#1f4a33); }
.ho-nav{ position: absolute; left: 0; right: 0; bottom: 0; z-index: 5; display: flex; align-items: flex-end; justify-content: space-around; padding: 8px 10px 11px; background: linear-gradient(180deg, #6a4a2c 0%, #4a3120 45%, #2c1c0f 100%); border-top: 1px solid rgba(244,235,219,.12); }
.ho-nav span{ display: flex; flex-direction: column; align-items: center; gap: 3px; font-size: 9.5px; font-weight: 600; color: rgba(244,235,219,.6); }
.ho-nav span i{ font-style: normal; font-size: 17px; line-height: 1; }
.ho-nav .on{ color: var(--gold); }
.ho-nav .nav-tools{ color: var(--gold); font-weight: 700; margin-top: -14px; }
.ho-nav .navfab{ width: 40px; height: 40px; border-radius: 50%; background: var(--gold); color: var(--night); display: grid; place-items: center; font-size: 18px; box-shadow: 0 6px 16px -4px rgba(227,169,67,.6); }

/* SCÈNE 1 — action-sheet « Mes actions » (par-dessus l'accueil) */
.as-dim{ position: absolute; inset: 0; background: rgba(20,12,7,.42); opacity: 0; animation: dm-dim var(--loop) ease infinite; }
@keyframes dm-dim{ 0%,8%{ opacity:0;} 9.5%,13%{ opacity:1;} 14%,100%{ opacity:0;} }
.as-sheet{ position: absolute; left: 0; right: 0; bottom: 0; padding: 16px 16px 20px; border-radius: 22px 22px 0 0; background: var(--card); box-shadow: 0 -16px 40px rgba(40,22,8,.3); animation: dm-sheetup var(--loop) ease infinite; }
@keyframes dm-sheetup{ 0%,8%{ transform: translateY(100%);} 9.5%,13%{ transform: translateY(0);} 14%,100%{ transform: translateY(100%);} }
.as-h{ font-size: 12px; font-weight: 700; color: var(--ink-3); margin-bottom: 8px; }
.as-item{ padding: 13px 12px; border-radius: 12px; font-size: 14px; font-weight: 650; color: var(--ink); }
.as-item.hot{ animation: dm-hot var(--loop) ease infinite; }
@keyframes dm-hot{ 0%,11%{ background: transparent; } 11.5%,12.8%{ background: rgba(227,169,67,.2); } 13.2%,100%{ background: transparent; } }
.as-cancel{ margin-top: 8px; padding: 13px; text-align: center; border-radius: 12px; background: #fff; border: 1px solid var(--line); font-size: 13px; font-weight: 700; color: var(--ink); }

/* en-têtes / progression (scènes avis — clair) */
.demo-top{ display: flex; align-items: center; gap: 10px; padding: 4px 16px 4px; color: var(--ink); }
.demo-top .ic{ color: var(--ink-3); font-size: 17px; }
.demo-tt{ display: flex; flex-direction: column; line-height: 1.18; }
.demo-tt .t{ font-size: 14px; font-weight: 700; }
.demo-tt .se{ font-size: 9.5px; color: var(--caramel); }
.demo-prog{ height: 4px; margin: 6px 16px 8px; border-radius: 2px; background: rgba(42,26,18,.1); overflow: hidden; }
.demo-prog-fill{ display: block; height: 100%; border-radius: 2px; background: var(--gold); }
.f-step1{ width: 38%; } .f-step2{ width: 72%; }

/* SCÈNE 2 — note globale + sous-notes */
.dn-card{ margin: 4px 14px; padding: 15px; border-radius: 18px; text-align: center; background: rgba(99,153,34,.12); border: 1px solid rgba(99,153,34,.24); }
.dn-emoji{ font-size: 36px; line-height: 1; }
.dn-score{ font-family: var(--font-display); font-size: 33px; font-weight: 800; color: var(--green-deep); margin-top: 3px; }
.dn-score span{ font-size: 15px; color: var(--green); }
.dn-stars{ color: var(--green); font-size: 15px; letter-spacing: 2px; margin-top: 2px; }
.dn-stars .off{ color: rgba(99,153,34,.32); }
.dn-badge{ display: inline-block; margin-top: 8px; padding: 4px 13px; border-radius: 999px; background: var(--green); color: #fff; font-size: 11px; font-weight: 700; }
.dn-hint{ font-size: 10px; color: var(--ink-3); margin-top: 9px; }
.dn-detail{ margin: 10px 14px; padding: 13px; border-radius: 16px; background: #fff; border: 1px solid var(--line); }
.dn-dh{ font-size: 12px; font-weight: 700; color: var(--ink); margin-bottom: 11px; }
.dn-dh span{ color: var(--ink-3); font-weight: 600; }
.dsub{ margin-bottom: 11px; }
.dsub:last-child{ margin-bottom: 0; }
.dsub-h{ display: flex; justify-content: space-between; font-size: 11px; color: var(--ink-2); margin-bottom: 6px; }
.dsub-h b{ color: var(--caramel); font-weight: 800; }
.dn-track{ position: relative; height: 6px; border-radius: 3px; }
.dn-card .dn-track{ margin: 14px 4px 0; background: rgba(181,105,74,.22); }
.dn-track.sm{ height: 5px; background: rgba(181,105,74,.18); }
.dn-fill{ position: absolute; left: 0; top: 0; bottom: 0; border-radius: 3px; background: var(--caramel); width: var(--p, 70%); animation: dm-fill var(--loop) ease infinite; }
.dn-thumb{ position: absolute; top: 50%; width: 15px; height: 15px; border-radius: 50%; background: var(--caramel); border: 2px solid #fff; box-shadow: 0 1px 4px rgba(0,0,0,.25); transform: translate(-50%,-50%); left: var(--p, 70%); animation: dm-thumb var(--loop) ease infinite; }
.dn-track.sm .dn-thumb{ width: 13px; height: 13px; }
.dn-fill.main, .dn-thumb.main{ --p: 72%; }
.s-org, .t-org{ --p: 76%; } .s-cont, .t-cont{ --p: 66%; } .s-amb, .t-amb{ --p: 82%; }
@keyframes dm-fill{ 0%,13%{ width: 0; } 18%,100%{ width: var(--p); } }
@keyframes dm-thumb{ 0%,13%{ left: 0; } 18%,100%{ left: var(--p); } }
.b-continue{ animation: dm-tapc var(--loop) ease infinite; }
@keyframes dm-tapc{ 0%,21%{ transform: none; filter: none; } 22.5%{ transform: scale(.95); filter: brightness(1.06); } 24%,100%{ transform: none; filter: none; } }

/* SCÈNE 3 — contenu (clair) */
.dseg{ display: flex; gap: 6px; margin: 2px 14px 10px; padding: 4px; border-radius: 12px; background: rgba(42,26,18,.06); }
.dseg-b{ flex: 1; text-align: center; padding: 8px; border-radius: 9px; font-size: 12px; font-weight: 600; color: var(--ink-2); }
.dseg-b.on{ background: var(--caramel); color: #fff; }
.dtext{ position: relative; margin: 0 14px; padding: 11px; border-radius: 12px; background: #fff; border: 1px solid var(--line); min-height: 62px; }
.t-review{ width: auto; font-size: 12.5px; line-height: 1.5; color: var(--ink); animation: dm-rfade var(--loop) ease infinite; }
@keyframes dm-rfade{ 0%,26%{ opacity: 0; } 30%,100%{ opacity: 1; } }
.dtext-count{ display: block; text-align: right; font-size: 9.5px; color: var(--ink-3); margin-top: 7px; }
.d-caret{ display: inline-block; width: 2px; height: 13px; background: var(--caramel); margin-left: 1px; vertical-align: middle; visibility: hidden; }
.c-review{ animation: dm-caret3 var(--loop) steps(1) infinite, dm-blink .9s ease infinite; }
@keyframes dm-caret3{ 0%,26%{ visibility: hidden; } 27%,31%{ visibility: visible; } 32%,100%{ visibility: hidden; } }
@keyframes dm-blink{ 0%,100%{ opacity: 1; } 50%{ opacity: 0; } }
.dtags-h, .dident-h{ font-size: 11px; font-weight: 700; color: var(--ink); margin: 12px 14px 6px; }
.dtags-h span{ color: var(--ink-3); font-weight: 600; }
.dtags{ display: flex; flex-wrap: wrap; gap: 7px; margin: 0 14px; }
.dtag{ padding: 6px 11px; border-radius: 999px; font-size: 11px; font-weight: 600; background: #fff; border: 1px solid var(--line); color: var(--ink); }
.dtag.on{ background: var(--caramel); color: #fff; border-color: var(--caramel); }
.dtag.anim1{ animation: dm-tag1 var(--loop) ease infinite; }
.dtag.anim2{ animation: dm-tag2 var(--loop) ease infinite; }
@keyframes dm-tag1{ 0%,30%{ background: #fff; color: var(--ink); border-color: var(--line); } 31%,100%{ background: var(--caramel); color: #fff; border-color: var(--caramel); } }
@keyframes dm-tag2{ 0%,31%{ background: #fff; color: var(--ink); border-color: var(--line); } 32%,100%{ background: var(--caramel); color: #fff; border-color: var(--caramel); } }
.dident{ display: flex; gap: 8px; margin: 0 14px; }
.did{ flex: 1; display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 9px 4px; border-radius: 12px; background: #fff; border: 1.5px solid var(--line); font-size: 16px; }
.did b{ font-weight: 700; font-size: 10.5px; color: var(--ink); }
.id-anon{ animation: dm-idanon var(--loop) ease infinite; }
.id-name{ animation: dm-idname var(--loop) ease infinite; }
@keyframes dm-idanon{ 0%,30%{ background: rgba(181,105,74,.12); border-color: var(--caramel); } 31.5%,100%{ background: #fff; border-color: var(--line); } }
@keyframes dm-idname{ 0%,31%{ background: #fff; border-color: var(--line); } 32%,100%{ background: rgba(181,105,74,.12); border-color: var(--caramel); } }
.b-publish{ animation: dm-tapp var(--loop) ease infinite; }
@keyframes dm-tapp{ 0%,33%{ transform: none; filter: none; } 34.5%{ transform: scale(.95); filter: brightness(1.06); } 36%,100%{ transform: none; filter: none; } }
.d-btn{ margin: 12px 14px 0; height: 40px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; background: var(--gold); color: var(--night); }

/* SCÈNE 4 — forum (en-tête sombre, corps clair) */
.fo-sb{ background: #1b110b; }
.fo-head{ padding: 4px 16px 12px; background: linear-gradient(150deg, #3a2718, #1b110b); color: var(--cream-on-dark); position: relative; }
.fo-badge{ position: absolute; top: 6px; right: 16px; font-size: 10.5px; font-weight: 700; color: #6fdaa3; background: rgba(46,159,105,.18); padding: 4px 10px; border-radius: 999px; }
.fo-title{ font-family: var(--font-display); font-weight: 700; font-size: 16px; line-height: 1.15; max-width: 80%; }
.fo-by{ font-size: 11px; color: rgba(244,235,219,.55); margin-top: 5px; }
.fo-stats{ display: flex; gap: 10px; margin-top: 12px; }
.fo-stats span{ flex: 1; display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 9px 0; border-radius: 12px; background: rgba(244,235,219,.06); font-size: 8.5px; letter-spacing: .04em; color: rgba(244,235,219,.5); }
.fo-stats b{ font-family: var(--font-display); font-size: 17px; color: var(--cream-on-dark); }
.fo-tabs{ position: relative; display: flex; padding: 0 8px; background: var(--cream-2); border-bottom: 1px solid var(--line); }
.fo-tab{ flex: 1; text-align: center; padding: 11px 0; font-size: 12.5px; font-weight: 700; color: var(--ink-3); }
.tabd{ animation: dm-tabd var(--loop) step-end infinite; }
.taba{ animation: dm-taba var(--loop) step-end infinite; }
.tabe{ animation: dm-tabe var(--loop) step-end infinite; }
@keyframes dm-tabd{ 0%,52%{ color: var(--caramel);} 53%,100%{ color: var(--ink-3);} }
@keyframes dm-taba{ 0%,52%{ color: var(--ink-3);} 53%,59%{ color: var(--caramel);} 60%,100%{ color: var(--ink-3);} }
@keyframes dm-tabe{ 0%,59%{ color: var(--ink-3);} 60%,65%{ color: var(--caramel);} 66%,100%{ color: var(--ink-3);} }
.fo-ind{ position: absolute; bottom: -1px; left: 8px; width: calc((100% - 16px) / 3); height: 2px; border-radius: 2px; background: var(--caramel); animation: dm-ind var(--loop) ease infinite; }
@keyframes dm-ind{ 0%,52%{ transform: translateX(0);} 53%,59%{ transform: translateX(100%);} 60%,65%{ transform: translateX(200%);} 66%,100%{ transform: translateX(0);} }
.fo-body{ position: absolute; left: 0; right: 0; top: 218px; bottom: 0; padding: 12px 14px; overflow: hidden; }
.fb-disc{ animation: dm-fbd var(--loop) ease infinite; }
.fb-avis{ opacity: 0; animation: dm-fba var(--loop) ease infinite; }
.fb-evt{ opacity: 0; animation: dm-fbe var(--loop) ease infinite; }
@keyframes dm-fbd{ 0%,44%{ opacity:0;} 46%,52%{ opacity:1;} 53%,100%{ opacity:0;} }
@keyframes dm-fba{ 0%,52%{ opacity:0;} 54%,59%{ opacity:1;} 60%,100%{ opacity:0;} }
@keyframes dm-fbe{ 0%,59%{ opacity:0;} 61%,65%{ opacity:1;} 66%,100%{ opacity:0;} }
.fo-post{ padding: 11px; border-radius: 14px; background: #fff; border: 1px solid var(--line); margin-bottom: 10px; }
.fo-post-h{ display: flex; align-items: center; gap: 8px; }
.d-av{ width: 28px; height: 28px; border-radius: 50%; display: grid; place-items: center; font-size: 11px; font-weight: 800; color: #fff; background: var(--caramel); flex: 0 0 auto; }
.d-av.q{ background: #4a3d6b; }
.fo-pid b{ font-size: 12px; color: var(--ink); display: block; }
.fo-pid span{ font-size: 9.5px; color: var(--ink-3); }
.fo-tag-type{ margin-left: auto; font-size: 9.5px; font-weight: 800; padding: 3px 8px; border-radius: 999px; }
.fo-tag-type.ann{ background: rgba(181,105,74,.16); color: var(--caramel); }
.fo-tag-type.qst{ background: rgba(227,169,67,.2); color: var(--gold-deep); }
.fo-tag-type.prt{ background: rgba(46,159,105,.16); color: var(--green-deep); }
.fo-post-tx{ font-size: 11.5px; color: var(--ink-2); margin-top: 8px; }
.fo-hash{ font-size: 10.5px; color: var(--caramel); margin-top: 7px; }
.fo-react{ display: flex; gap: 13px; margin-top: 9px; font-size: 11px; color: var(--ink-3); font-weight: 600; }
.fo-audio{ display: flex; align-items: center; gap: 7px; margin-top: 9px; padding: 8px 10px; border-radius: 10px; background: var(--cream-3); font-size: 11px; color: var(--caramel); }
.fa-avg{ display: flex; align-items: center; gap: 12px; padding: 12px; border-radius: 14px; background: #fff; border: 1px solid var(--line); margin-bottom: 11px; }
.fa-n{ font-family: var(--font-display); font-size: 26px; font-weight: 800; color: var(--gold-deep); }
.fa-avg b{ font-size: 12.5px; color: var(--ink); display: block; }
.fa-avg span{ font-size: 10px; color: var(--ink-3); }
.fa-rev{ padding: 11px; border-radius: 14px; background: #fff; border: 1px solid var(--line); margin-bottom: 9px; }
.fa-rh{ display: flex; align-items: center; gap: 8px; }
.fa-rh b{ font-size: 12px; color: var(--ink); }
.fa-v{ font-size: 9px; font-weight: 800; color: var(--green-deep); background: rgba(46,159,105,.15); padding: 2px 7px; border-radius: 999px; }
.fa-s{ margin-left: auto; font-size: 12.5px; font-weight: 800; }
.fa-s.good{ color: var(--green-deep); }
.fa-tx{ font-size: 11px; color: var(--ink-2); margin-top: 7px; }
.fe-seg{ display: flex; gap: 7px; margin-bottom: 11px; }
.fe-seg span{ padding: 6px 13px; border-radius: 999px; font-size: 11px; font-weight: 700; color: var(--ink-2); background: #fff; border: 1px solid var(--line); }
.fe-seg span.on{ background: var(--caramel); color: #fff; border-color: var(--caramel); }
.fe-card{ display: flex; align-items: center; gap: 11px; padding: 10px; border-radius: 14px; background: #fff; border: 1px solid var(--line); margin-bottom: 10px; }
.fe-img{ flex: 0 0 auto; width: 46px; height: 46px; border-radius: 10px; background: linear-gradient(150deg,#5a3a22,#2e2545); }
.fe-img.b{ background: linear-gradient(150deg,#2f6b4a,#1f4a33); }
.fe-tt{ font-size: 12.5px; font-weight: 700; color: var(--ink); }
.fe-tt em{ font-style: normal; font-size: 9px; font-weight: 800; padding: 2px 7px; border-radius: 999px; margin-left: 4px; }
.fe-tt .past{ background: rgba(42,26,18,.1); color: var(--ink-3); }
.fe-tt .soon{ background: rgba(46,159,105,.16); color: var(--green-deep); }
.fe-meta{ font-size: 10.5px; color: var(--ink-3); margin-top: 4px; }
.fo-fab{ position: absolute; right: 16px; bottom: 16px; width: 46px; height: 46px; border-radius: 50%; background: var(--caramel); color: #fff; display: grid; place-items: center; font-size: 24px; box-shadow: 0 8px 20px rgba(40,22,8,.3); }

/* SCÈNE 5 — nouvelle publication (claire) */
.sc-create{ background: var(--cream-2); }
.cr-top{ display: flex; align-items: center; justify-content: space-between; padding: 4px 16px 12px; border-bottom: 1px solid var(--line); }
.cr-cancel{ font-size: 12.5px; color: var(--ink-3); }
.cr-t{ font-weight: 700; font-size: 14px; color: var(--ink); }
.cr-pub{ font-size: 12.5px; font-weight: 700; color: var(--night); background: var(--gold); padding: 6px 13px; border-radius: 999px; animation: dm-tappub var(--loop) ease infinite; }
@keyframes dm-tappub{ 0%,89%{ transform: none; } 90.5%{ transform: scale(.92); } 92%,100%{ transform: none; } }
.cr-lbl{ font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-3); margin: 9px 16px 5px; }
.cr-lbl em{ font-style: normal; color: var(--red); }
.cr-lbl small{ font-size: 9px; font-weight: 600; letter-spacing: 0; text-transform: none; color: var(--ink-3); }
.cr-note{ display: flex; gap: 5px; margin: 6px 16px 0; font-size: 9.5px; color: var(--ink-3); }
.cr-select{ position: relative; display: flex; align-items: center; margin: 0 16px; padding: 11px; border-radius: 11px; background: #fff; border: 1px solid var(--line); font-size: 12.5px; }
.cr-select .evt-ph{ color: var(--ink-3); animation: dm-evtph var(--loop) ease infinite; }
.cr-select .evt-val{ position: absolute; left: 11px; font-weight: 600; color: var(--ink); opacity: 0; animation: dm-evtval var(--loop) ease infinite; }
.cr-select .cr-dd{ position: relative; z-index: 1; margin-left: auto; color: var(--ink-3); }
@keyframes dm-evtph{ 0%,70%{ opacity: 1; } 72%,100%{ opacity: 0; } }
@keyframes dm-evtval{ 0%,70%{ opacity: 0; } 72%,100%{ opacity: 1; } }
.cr-taginput{ display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin: 0 16px; padding: 9px 10px; border-radius: 11px; background: #fff; border: 1px solid var(--line); }
.cr-taginput .dtag{ font-size: 10.5px; padding: 4px 9px; }
.cr-tagph{ font-size: 11.5px; color: var(--ink-3); }
.tg1{ animation: dm-tag-a var(--loop) ease infinite; }
.tg2{ animation: dm-tag-b var(--loop) ease infinite; }
.tg3{ animation: dm-tag-c var(--loop) ease infinite; }
@keyframes dm-tag-a{ 0%,83%{ opacity: 0; transform: scale(.7); } 85%,100%{ opacity: 1; transform: scale(1); } }
@keyframes dm-tag-b{ 0%,85%{ opacity: 0; transform: scale(.7); } 87%,100%{ opacity: 1; transform: scale(1); } }
@keyframes dm-tag-c{ 0%,87%{ opacity: 0; transform: scale(.7); } 89%,100%{ opacity: 1; transform: scale(1); } }
.cr-photos{ margin: 0 16px; padding: 12px; border-radius: 11px; border: 1px dashed var(--line); text-align: center; font-size: 12px; font-weight: 600; color: var(--ink-2); }
.cr-lbl.row{ display: flex; align-items: center; justify-content: space-between; }
.cr-lbl span{ color: var(--ink-3); }
.cr-types{ display: flex; gap: 7px; margin: 0 16px; }
.crty{ flex: 1; text-align: center; padding: 9px 4px; border-radius: 11px; font-size: 11px; font-weight: 700; color: var(--ink); background: #fff; border: 1px solid var(--line); }
.crty.on{ background: var(--caramel); color: #fff; border-color: var(--caramel); }
.crty.lock{ opacity: .5; }
.cr-field{ margin: 0 16px; padding: 11px; border-radius: 11px; background: #fff; border: 1px solid var(--line); min-height: 38px; }
.cr-field .d-type{ display: inline-block; overflow: hidden; white-space: nowrap; vertical-align: bottom; color: var(--ink); font-size: 12.5px; }
.t-title{ width: 30ch; animation: dm-type5 var(--loop) steps(30,end) infinite; }
@keyframes dm-type5{ 0%,68%{ width: 0; } 76%,100%{ width: 30ch; } }
.c-title{ background: var(--caramel); animation: dm-caret5 var(--loop) steps(1) infinite, dm-blink .9s ease infinite; }
@keyframes dm-caret5{ 0%,68%{ visibility: hidden; } 69%,76%{ visibility: visible; } 77%,100%{ visibility: hidden; } }
.cr-seg{ display: inline-flex; gap: 4px; padding: 3px; border-radius: 999px; background: var(--cream-3); }
.cr-seg span{ padding: 4px 12px; border-radius: 999px; font-size: 10.5px; font-weight: 700; color: var(--ink-2); }
.cr-seg .on{ background: var(--caramel); color: #fff; }
.cr-content{ position: relative; margin: 0 16px; padding: 11px; border-radius: 11px; background: #fff; border: 1px solid var(--line); min-height: 56px; }
.cc-txt{ font-size: 12px; line-height: 1.5; color: var(--ink); animation: dm-cfade var(--loop) ease infinite; }
@keyframes dm-cfade{ 0%,77%{ opacity: 0; } 83%,100%{ opacity: 1; } }
.c-content{ animation: dm-ccaret var(--loop) steps(1) infinite, dm-blink .9s ease infinite; }
@keyframes dm-ccaret{ 0%,77%{ visibility: hidden; } 78%,83%{ visibility: visible; } 84%,100%{ visibility: hidden; } }
.cr-tags{ display: flex; gap: 7px; margin: 0 16px; }

/* toasts de confirmation */
.d-toast{ position: absolute; left: 50%; bottom: 18px; transform: translate(-50%, 10px); padding: 9px 16px; border-radius: 999px; font-size: 12px; font-weight: 700; color: #fff; background: var(--green); box-shadow: 0 10px 26px rgba(31,123,79,.4); opacity: 0; white-space: nowrap; }
.tt-review{ animation: dm-toastr var(--loop) ease infinite; }
.tt-post{ animation: dm-toastp var(--loop) ease infinite; }
@keyframes dm-toastr{ 0%,34%{ opacity: 0; transform: translate(-50%,10px); } 35%,36.5%{ opacity: 1; transform: translate(-50%,0); } 37.5%,100%{ opacity: 0; transform: translate(-50%,10px); } }
@keyframes dm-toastp{ 0%,89%{ opacity: 0; transform: translate(-50%,10px); } 90.5%,92.5%{ opacity: 1; transform: translate(-50%,0); } 94%,100%{ opacity: 0; transform: translate(-50%,10px); } }

/* ===== Neutralisation mouvement (accessibilité) ===== */
@media (prefers-reduced-motion: reduce){
  .scroll-progress, .nav.scrolled{ transition: none; }
  .hero::before, .hero::after, .strip::before,
  .afro-band::before, .afro-band::after, .afro-soft::before,
  .hero h1 .accent, .hero-phones .p-front, .hero-phones .p-back,
  .pp-left .phone, .pp-right .phone, .glow,
  .eyebrow .dot, .pos-now .ld, .city-chip.live .ld, .btn-gold::after,
  .strip-track, .demo-phone *{
    animation: none !important;
  }
  .hero h1 .accent{ -webkit-text-fill-color: var(--caramel); color: var(--caramel); }
  /* Carrousel figé → rangée statique centrée, sans doublon */
  .strip-track{ flex-wrap: wrap; justify-content: center; }
  .strip-track .stat[aria-hidden="true"], .strip-track .sep[aria-hidden="true"]{ display: none; }
}

/* ===========================================================
   RESPONSIVE ≤425px — overrides ajoutés tout à la fin pour
   l'emporter par l'ordre source. NE modifie aucune règle existante.
   PARTIE A : texte de contenu lisible réduit de 3px (plancher 9px ;
              clamp → min & max −3px). Maquettes téléphone EXCLUES.
   PARTIE B : cartes de contenu → padding réduit de 10px/côté
              (plancher 6px). Maquettes téléphone EXCLUES.
   =========================================================== */
@media (max-width: 425px){

  /* ----------------- PARTIE A — texte −3px ----------------- */

  /* base / utilitaires */
  .mono{ font-size: 9px; }              /* 11 → 8 → plancher 9 */

  /* nav */
  .nav-links a{ font-size: 11.5px; }    /* 14.5 → 11.5 */
  .nav-drawer a{ font-size: 13px; }     /* 16 → 13 */

  /* boutons */
  .btn{ font-size: 12px; }              /* 15 → 12 */
  .btn-sm{ font-size: 11px; }           /* 14 → 11 */
  .btn-lg{ font-size: 13.5px; }         /* 16.5 → 13.5 */

  /* store badge (contenu lisible) */
  .store-btn .st small{ font-size: 9px; } /* 10.5 → 7.5 → plancher 9 */
  .store-btn .st b{ font-size: 13px; }    /* 16 → 13 */

  /* hero */
  .eyebrow{ font-size: 10px; }                       /* 13 → 10 */
  .hero h1{ font-size: clamp(23px, 7.2vw, 44px); }   /* mobile : tient sans déborder « monde » */
  .hero-sub{ font-size: clamp(14px,1.5vw,17px); }    /* clamp(17,..,20) −3 */
  .avail-chip{ font-size: 10.5px; }                  /* 13.5 → 10.5 */
  .avail-chip .gi{ font-size: 10px; }                /* 13 → 10 */
  /* Hero : la grille 1 colonne `1fr` grandissait au min-content du téléphone
     (300px) → plus large que l'écran → le téléphone centré tombait à droite.
     `minmax(0,1fr)` borne la piste à la largeur réelle → vrai centrage. */
  .hero-in{ grid-template-columns: minmax(0, 1fr); }
  .hero-phones{ transform: none; min-height: 0; margin-top: 12px; }
  /* On réduit le TÉLÉPHONE lui-même (depuis le haut-centre) pour qu'il tienne
     entièrement. (Pas sur .hero-phones : landing.js y pose un transform de
     parallaxe souris qui écraserait le nôtre.) */
  .demo-phone{ transform: scale(.85); transform-origin: top center; }

  /* strip / carrousel */
  .strip .lbl{ font-size: 9px; }        /* 12 → 9 */
  .strip .stat{ font-size: 12px; }      /* 15 → 12 */
  .strip .stat b{ font-size: 14px; }    /* 17 → 14 */

  /* sec-head */
  .kicker{ font-size: 10px; }                          /* 13 → 10 */
  .sec-head h2{ font-size: clamp(29px, 4vw, 53px); }   /* clamp(32,..,56) −3 */
  .sec-head .lede{ font-size: clamp(13px,1.4vw,16px); }/* clamp(16,..,19) −3 */

  /* comment ça marche / steps */
  .fseg button{ font-size: 12px; }   /* 15 → 12 */
  .step .sn{ font-size: 9px; }       /* 12 → 9 */
  .step h4{ font-size: 15.5px; }     /* 18.5 → 15.5 */
  .step p{ font-size: 11.5px; }      /* 14.5 → 11.5 */

  /* pourquoi (why) */
  .why-card h4{ font-size: 17px; }      /* 20 → 17 */
  .why-card p{ font-size: 12px; }       /* 15 → 12 */
  .why-card .wtag{ font-size: 9px; }    /* 11.5 → 8.5 → plancher 9 */

  /* cartes preuve (CONTENU — à inclure) */
  .pcard .pc-n{ font-size: 11px; }      /* 14 → 11 */
  .pcard h4{ font-size: 15px; }         /* 18 → 15 */
  .pcard p{ font-size: 11px; }          /* 14 → 11 */
  .pcard .pc-tag{ font-size: 9px; }     /* 10 → 7 → plancher 9 */

  /* socle preuve */
  .proof-socle .ps-lbl{ font-size: 10px; } /* 13 → 10 */
  .ps-chip{ font-size: 10px; }             /* 13 → 10 */

  /* valeurs */
  .val-card .vn{ font-size: 9px; }      /* 12 → 9 */
  .val-card h4{ font-size: 18px; }      /* 21 → 18 */
  .val-card p{ font-size: 11.5px; }     /* 14.5 → 11.5 */

  /* banner CTA */
  .banner .bk{ font-size: 9px; }                       /* 12 → 9 */
  .banner h3{ font-size: clamp(25px,3.4vw,39px); }     /* clamp(28,..,42) −3 */
  .banner p{ font-size: 13.5px; }                      /* 16.5 → 13.5 */
  .banner-cta .qr .qt{ font-size: 10.5px; }            /* 13.5 → 10.5 */

  /* position aujourd'hui */
  .pos-stats{ grid-template-columns: 1fr; }            /* #4 : stats empilées (1 colonne) */
  .pos-stat .num{ font-size: clamp(31px,4vw,43px); }   /* clamp(34,..,46) −3 */
  .pos-stat .num .u{ font-size: 17px; }                /* 20 → 17 */
  .pos-stat .lab{ font-size: 11px; }                   /* 14 → 11 */
  .pos-now{ font-size: 10.5px; }                       /* 13.5 → 10.5 */
  .pos-copy h2{ font-size: clamp(27px,3.6vw,43px); }   /* clamp(30,..,46) −3 */
  .pos-copy p{ font-size: 13.5px; }                    /* 16.5 → 13.5 */
  .city-chip{ font-size: 11px; }                       /* 14 → 11 */

  /* tarifs — price cards */
  .price-card .pl-name{ font-size: 18px; }             /* 21 → 18 */
  .price-card .pl-tag{ font-size: 10.5px; }            /* 13.5 → 10.5 */
  .price-card .pl-price{ font-size: 39px; }            /* 42 → 39 */
  .price-card .pl-price small{ font-size: 12px; }      /* 15 → 12 */
  .price-card .pl-badge{ font-size: 9px; }             /* 11 → 8 → plancher 9 */
  .pl-list li{ font-size: 11.5px; }                    /* 14.5 → 11.5 */
  .pl-list li .ck{ font-size: 9px; }                   /* 11 → 8 → plancher 9 */

  /* tarifs — paliers (tiers) */
  .tier-val{ font-size: 37px; }                        /* 40 → 37 */
  .tier-val small{ font-size: 9px; }                   /* 12 → 9 */
  .tier-unit{ font-size: 9.5px; }                      /* 12.5 → 9.5 */
  .tier-cap{ font-size: 10.5px; }                      /* 13.5 → 10.5 */
  .tier-feat .tier-val{ font-size: 45px; }             /* 48 → 45 */
  .tier-badge{ font-size: 9px; }                       /* 11 → 8 → plancher 9 */
  .tier-free .tf-pill{ font-size: 17px; }              /* 20 → 17 */
  .tier-free p{ font-size: 11px; }                     /* 14 → 11 */

  /* tarifs — carte « entre nous » (duo) */
  .duo-ht h3{ font-size: 19px; }        /* 22 → 19 */
  .duo-ht p{ font-size: 10.5px; }       /* 13.5 → 10.5 */
  .duo-tx b{ font-size: 11.5px; }       /* 14.5 → 11.5 */
  .duo-tx span{ font-size: 9.5px; }     /* 12.5 → 9.5 */
  .duo-seal{ font-size: 9px; }          /* 12 → 9 */

  /* calculateur (hors maquette) */
  .calc-head .ct{ font-size: 17px; }                   /* 20 → 17 */
  .calc-head .cd{ font-size: 11px; }                   /* 14 → 11 */
  .calc-seg button{ font-size: 11px; }                 /* 14 → 11 */
  .cin .clab .k{ font-size: 11.5px; }                  /* 14.5 → 11.5 */
  .cin .clab .v{ font-size: 17px; }                    /* 20 → 17 */
  .cin .clab .v small{ font-size: 10px; }              /* 13 → 10 */
  .cin .crange-tags{ font-size: 9px; }                 /* 11.5 → 8.5 → plancher 9 */
  .cin .cnumber button{ font-size: 19px; }             /* 22 → 19 */
  .cin .cnumber input{ font-size: 16px; }              /* 19 → 16 */
  .calc-out .res-main .rk{ font-size: 10px; }          /* 13 → 10 */
  .calc-out .res-main .rv{ font-size: clamp(33px,4.2vw,49px); } /* clamp(36,..,52) −3 */
  .calc-out .res-main .rv small{ font-size: 15px; }    /* 18 → 15 */
  .calc-out .res-main .rsub{ font-size: 10px; }        /* 13 → 10 */
  .res-row{ font-size: 11.5px; }                       /* 14.5 → 11.5 */
  .res-row .rr{ font-size: 13px; }                     /* 16 → 13 */
  .res-row .rr small{ font-size: 9px; }                /* 11.5 → 8.5 → plancher 9 */
  .calc-note{ font-size: 9.5px; }                      /* 12.5 → 9.5 */
  .calc-kolo .cc-t{ font-size: 10.5px; }             /* 13.5 → 10.5 */

  /* FAQ */
  .faq summary{ font-size: 16px; }      /* 19 → 16 */
  .faq .a{ font-size: 12.5px; }         /* 15.5 → 12.5 */

  /* contact — cartes lisibles (la maquette .cc-* de chat reste figée) */
  .cp-ht b{ font-size: 16px; }                /* 19 → 16 */
  .cp-ht span{ font-size: 10px; }             /* 13 → 10 */
  .btn-wa{ font-size: 12px; }                 /* 15 → 12 */
  .cp-num{ font-size: 13px; }                 /* 16 → 13 */
  .cp-chip{ font-size: 9px; }                 /* 12 → 9 */
  .contact-alt-label{ font-size: 9px; }       /* 12 → 9 */
  .alt-tx b{ font-size: 11.5px; }             /* 14.5 → 11.5 */
  .alt-hi{ font-size: 10px; }                 /* 13 → 10 */
  .alt-tx small{ font-size: 9px; }            /* 11.5 → 8.5 → plancher 9 */

  /* footer */
  .foot-brand p{ font-size: 11px; }     /* 14 → 11 */
  .foot-col h5{ font-size: 11px; }      /* 14 → 11 */
  .foot-col a{ font-size: 11px; }       /* 14 → 11 */
  .foot-legal a{ font-size: 10px; }     /* 13 → 10 */
  .foot-bottom{ font-size: 10px; }      /* 13 → 10 */

  /* ----------------- PARTIE B — padding cartes −10px ----------------- */

  .pcard{ padding: 12px 14px; }                 /* 22 24 → 12 14 */
  .why-card{ padding: 22px; }                   /* 32 → 22 */
  .step{ padding: 18px; }                       /* 28 → 18 */
  .val-card{ padding: 20px; }                   /* 30 → 20 */
  .pos-stat{ padding: 16px; }                   /* 26 → 16 */
  .price-card{ padding: 24px; }                 /* 34 → 24 */
  .calc-head{ padding: 16px 24px; }             /* 26 34 → 16 24 */
  .calc-inputs{ padding: 24px; }                /* 34 → 24 */
  .calc-out{ padding: 24px; }                   /* 34 → 24 */
  .calc-out .res-main{ padding: 16px; }         /* 26 → 16 */
  .calc-kolo{ padding: 6px 6px; }             /* 14 16 → 4 6 → plancher 6 */
  .banner-in{ padding: 46px; }                  /* 56 → 46 */
  .tier-free{ padding: 6px 12px; }              /* 16 22 → 6 12 */
  .duo{ padding: 38px clamp(26px,5vw,54px); }   /* 48 clamp(36,..,64) → 38 clamp(26,..,54) */
  .contact-primary{ padding: 14px; }            /* 24 → 14 */
  .alt-card{ padding: 6px; }                    /* 16 → 6 */
}
