/* Certicar - Certificat d'entretien · V2 (baselayer-inspired, light Certicar DA)
   Extends page.css. Self-contained for certificat-entretien-v2.html */

:root {
  --cream: #FAF8F4;
  --ink-70: rgba(26,26,46,0.7);
  --ink-55: rgba(26,26,46,0.55);
  --glass: rgba(255,255,255,0.92);
  --glass-border: rgba(255,255,255,0.7);
  --sh-soft: 0 12px 32px -18px rgba(89,85,239,0.12);
  --sh-float: 0 22px 50px -26px rgba(40,32,110,0.28);
  --sh-card: 0 1px 0 rgba(20,16,80,0.03), 0 18px 40px -28px rgba(89,85,239,0.30);
}
body.v2b { background: #fff; }

/* ---------- motion primitives ---------- */
.rv { opacity: 0; transform: translateY(34px); transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); }
.rv.in { opacity: 1; transform: none; }
.rv.s1 { transition-delay: .08s; } .rv.s2 { transition-delay: .16s; } .rv.s3 { transition-delay: .24s; }
.rv.s4 { transition-delay: .32s; } .rv.s5 { transition-delay: .40s; }
[data-parallax] { will-change: transform; }

/* ---------- section scaffold ---------- */
.s { padding: clamp(72px, 9vw, 134px) clamp(22px, 4vw, 88px); position: relative; }
.wrap { max-width: 76rem; margin: 0 auto; position: relative; }
.shead { max-width: 720px; margin: 0 auto clamp(44px, 6vw, 68px); text-align: center; display: flex; flex-direction: column; align-items: center; gap: 14px; }
.eyebrow { display: inline-flex; align-items: center; gap: 8px; font-family: 'Onest', sans-serif; font-size: 0.78rem; font-weight: 800; color: var(--purple); text-transform: uppercase; letter-spacing: 0.13em; background: rgba(89,85,239,0.07); border: 1px solid rgba(89,85,239,0.16); padding: 7px 14px; border-radius: 999px; }
.eyebrow .d { width: 7px; height: 7px; border-radius: 50%; background: var(--purple); }
.s-title { font-family: 'Onest', sans-serif; font-size: clamp(2rem, 4vw, 3.05rem); font-weight: 600; line-height: 1.04; letter-spacing: -0.035em; color: var(--text); }
.s-sub { font-size: clamp(1rem, 1.4vw, 1.16rem); line-height: 1.6; color: var(--ink-70); max-width: 600px; }
.tint { background: #f5f6f8; }

/* ---------- floating CTA bar (base styles, shared from V1) ---------- */
.floating-bar { position: fixed; z-index: 100; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(120px); display: flex; align-items: center; gap: 8px; padding: 6px; border-radius: 18px; background: rgba(255,255,255,0.85); backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px); border: 1px solid var(--grey-border); box-shadow: 0 10px 44px rgba(13,9,60,0.16), 0 2px 8px rgba(0,0,0,0.05); opacity: 0; transition: transform .55s cubic-bezier(.16,1,.3,1), opacity .55s cubic-bezier(.16,1,.3,1); }
.floating-bar.visible { transform: translateX(-50%) translateY(0); opacity: 1; }
.floating-bar a.fb-whatsapp { display: flex; align-items: center; gap: 10px; padding: 14px 26px; border-radius: 12px; font-family: 'Onest', sans-serif; font-size: 14px; font-weight: 600; text-decoration: none; white-space: nowrap; background: rgba(0,0,0,0.04); color: var(--text); border: 1px solid var(--grey-border); transition: all .3s cubic-bezier(.16,1,.3,1); }
.floating-bar a.fb-whatsapp svg { width: 18px; height: 18px; flex-shrink: 0; color: #25D366; transition: color .3s; }
.floating-bar a.fb-whatsapp:hover { background: #25D366; color: #fff; border-color: #25D366; transform: translateY(-1px); box-shadow: 0 4px 20px rgba(37,211,102,0.3); }
.floating-bar a.fb-whatsapp:hover svg { color: #fff; }

/* ============================================================ HERO */
.hero { position: relative; overflow: hidden; padding: clamp(48px, 6vw, 96px) clamp(22px, 4vw, 88px) clamp(40px, 5vw, 70px); text-align: center; background: #fff; }
.hero-aura { position: absolute; inset: -10% -10% auto -10%; height: 760px; background:
    radial-gradient(46% 38% at 50% 8%, rgba(89,85,239,0.18), transparent 70%),
    radial-gradient(30% 30% at 78% 18%, rgba(150,120,255,0.16), transparent 70%),
    radial-gradient(28% 28% at 20% 22%, rgba(120,150,255,0.14), transparent 70%);
  pointer-events: none; z-index: 0; }
.hero-dots { position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: radial-gradient(rgba(89,85,239,0.10) 1.1px, transparent 1.1px);
  background-size: 26px 26px;
  mask-image: radial-gradient(ellipse 70% 55% at 50% 28%, #000 0%, transparent 72%);
  -webkit-mask-image: radial-gradient(ellipse 70% 55% at 50% 28%, #000 0%, transparent 72%); }
.hero-inner { position: relative; z-index: 2; max-width: 60rem; margin: 0 auto; }
.hero h1 { font-family: 'Onest', sans-serif; font-weight: 600; font-size: clamp(2.6rem, 6vw, 4.6rem); line-height: 1.0; letter-spacing: -0.045em; color: var(--text); margin: 22px 0 0; }
.hero h1 .hl { position: relative; color: var(--purple); white-space: nowrap; }
.hero h1 .hl::after { content: ''; position: absolute; left: -1%; right: -1%; bottom: 0.06em; height: 0.30em; background: rgba(89,85,239,0.18); border-radius: 99px; z-index: -1; }
.s-title .hl { position: relative; color: var(--purple); white-space: nowrap; }
.s-title .hl::after { content: ''; position: absolute; left: -1%; right: -1%; bottom: 0.04em; height: 0.26em; background: rgba(89,85,239,0.18); border-radius: 99px; z-index: -1; }
.hero-sub { font-size: clamp(1.05rem, 1.6vw, 1.3rem); line-height: 1.55; color: var(--ink-70); max-width: 600px; margin: clamp(18px, 2.4vh, 28px) auto clamp(26px, 3vh, 36px); }
.hero-cta { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.hero-cta .cta-ghost { background: #fff; border: 1px solid var(--grey-border); color: var(--text); box-shadow: var(--sh-soft); }
.hero-cta .cta-ghost:hover { background: #fff; border-color: rgba(89,85,239,0.4); transform: translateY(-2px); }
.hero-cta .cta-ghost svg { color: var(--purple); }
/* primary CTA: clean solid purple pill on the light hero */
.hero-cta .cta-hero { background: linear-gradient(160deg, var(--purple), var(--purple-dark)); padding: 0; box-shadow: 0 14px 28px -12px rgba(89,85,239,0.5); }
.hero-cta .cta-hero:hover { transform: translateY(-2px); box-shadow: 0 18px 34px -12px rgba(89,85,239,0.58); }
.hero-cta .cta-hero-inner { background: transparent; border: 0; box-shadow: none; }
.hero-cta .cta-hero-text { color: #fff; padding: 14px 8px 14px 24px; }
.hero-cta .cta-hero:hover .cta-hero-text { color: #fff; }
.hero-cta .cta-hero-icon { background: rgba(255,255,255,0.2); box-shadow: none; }
.hero-cta .cta-hero:hover .cta-hero-icon { background: rgba(255,255,255,0.32); }
.hero-cta .cta-hero-icon svg { color: #fff; }
.hero-trust { display: inline-flex; align-items: center; gap: 10px; margin-top: 22px; color: var(--ink-70); font-size: 13.5px; font-family: 'Onest', sans-serif; font-weight: 500; }
.hero-trust .stars { color: #ffb800; letter-spacing: 1px; }

/* hero product showcase */
.hero-show { position: relative; z-index: 2; max-width: 60rem; margin: clamp(34px, 5vw, 64px) auto 0; display: flex; justify-content: center; }
/* soft stage the device rests on (replaces the floating drop-shadow) */
.hero-show::before { content: ''; position: absolute; left: 50%; bottom: 4px; transform: translateX(-50%); width: min(78%, 520px); height: clamp(150px, 22vw, 230px); z-index: 0; background: radial-gradient(58% 62% at 50% 64%, rgba(89,85,239,0.14), rgba(89,85,239,0.05) 46%, transparent 72%); }
.hero-show::after { content: ''; position: absolute; left: 50%; bottom: 6px; transform: translateX(-50%); width: 58%; max-width: 250px; height: 26px; z-index: 1; border-radius: 50%; background: radial-gradient(ellipse at center, rgba(40,32,110,0.30), rgba(40,32,110,0.12) 45%, transparent 72%); filter: blur(7px); animation: heroGround 7s ease-in-out infinite; }
.hero-device { position: relative; z-index: 2; width: clamp(230px, 30vw, 320px); filter: drop-shadow(0 10px 18px rgba(40,32,110,0.14)); animation: floaty 7s ease-in-out infinite; }
.hero-device img { width: 100%; height: auto; display: block; border-radius: 26px; }
@keyframes heroGround { 0%,100% { transform: translateX(-50%) scaleX(1); opacity: .9; } 50% { transform: translateX(-50%) scaleX(.82); opacity: .6; } }
.hero-fx { position: absolute; z-index: 3; display: inline-flex; align-items: center; gap: 10px; background: #fff; border: 1px solid var(--grey-border); border-radius: 14px; padding: 11px 15px; box-shadow: 0 8px 22px -12px rgba(40,32,110,0.20), 0 1px 3px rgba(20,16,80,0.05); font-family: 'Onest', sans-serif; white-space: nowrap; }
.hero-fx .fx-ic { width: 32px; height: 32px; border-radius: 9px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.hero-fx .fx-ic.g { background: rgba(22,163,74,0.12); color: #16a34a; } .hero-fx .fx-ic.p { background: var(--purple-light); color: var(--purple); }
.hero-fx .fx-ic svg { width: 17px; height: 17px; }
.hero-fx .fx-t { display: flex; flex-direction: column; gap: 1px; line-height: 1.2; }
.hero-fx .fx-k { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-50); }
.hero-fx .fx-v { font-size: 13px; font-weight: 600; color: var(--text); }
.hero-fx.f1 { top: 16%; left: -2%; animation: floaty 6s ease-in-out infinite; }
.hero-fx.f2 { bottom: 18%; right: -3%; animation: floaty 7.5s ease-in-out infinite 1s; }
.hero-fx.f3 { bottom: -4%; left: 8%; animation: floaty 6.6s ease-in-out infinite .5s; }
.hero-sticker { position: absolute; z-index: 4; right: 2%; top: -3%; width: clamp(58px, 7vw, 82px); height: auto; filter: drop-shadow(0 14px 22px rgba(89,85,239,0.3)); animation: floaty 5.6s ease-in-out infinite .3s; }
@keyframes floaty { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }

/* ============================================================ MARQUEE */
.marq { background: #fff; border-top: 1px solid var(--grey-border); border-bottom: 1px solid var(--grey-border); padding: clamp(26px,4vw,40px) 0; overflow: hidden; }
.marq-h { text-align: center; font-family: 'Onest', sans-serif; font-size: clamp(.86rem,1.3vw,1rem); color: var(--text-50); margin-bottom: 20px; padding: 0 24px; }
.marq-h b { color: var(--purple); font-weight: 800; }
.marquee { position: relative; width: 100%; 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); }
.marquee-track { display: flex; align-items: center; width: max-content; animation: marquee 32s linear infinite; }
.marquee-track img { height: clamp(20px,2.4vw,27px); width: auto; opacity: .9; padding: 0 26px; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ============================================================ FEATURE GRID */
.feat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(14px, 1.8vw, 22px); }
.feat { position: relative; background: #fff; border: 1px solid var(--grey-border); border-radius: var(--radius-lg); padding: clamp(24px,2.4vw,32px); overflow: hidden; transition: transform .4s cubic-bezier(.16,1,.3,1), box-shadow .4s, border-color .3s; }
.feat::before { content: ''; position: absolute; inset: 0; background: radial-gradient(120% 80% at 100% 0%, rgba(89,85,239,0.07), transparent 60%); opacity: 0; transition: opacity .4s; pointer-events: none; }
.feat:hover { transform: translateY(-6px); border-color: rgba(89,85,239,0.3); box-shadow: var(--sh-card); }
.feat:hover::before { opacity: 1; }
.feat-ic { width: 54px; height: 54px; border-radius: 15px; margin-bottom: 18px; background: var(--purple-light); color: var(--purple); display: flex; align-items: center; justify-content: center; transition: transform .4s cubic-bezier(.16,1,.3,1), background .4s, color .4s; }
.feat-ic svg { width: 26px; height: 26px; }
.feat:hover .feat-ic { transform: translateY(-3px); background: var(--purple); color: #fff; }
.feat h3 { font-family: 'Onest', sans-serif; font-size: 1.12rem; font-weight: 600; letter-spacing: -0.01em; margin-bottom: 8px; }
.feat p { font-size: 0.92rem; line-height: 1.55; color: var(--ink-70); }

/* ============================================================ HOW IT WORKS (sticky scroll) */
.hiw-inner { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(30px, 5vw, 80px); align-items: start; }
.hiw-inner { align-items: start; }
.hiw-visual { position: sticky; top: 120px; justify-self: center; width: 100%; max-width: 410px; }
.hiw-stage { position: relative; aspect-ratio: 4/5; border-radius: 26px; overflow: hidden; background: linear-gradient(165deg, #ffffff 0%, #f4f2ff 100%); border: 1px solid var(--grey-border); box-shadow: var(--sh-float); }
.hiw-stage::before { content: ''; position: absolute; width: 70%; aspect-ratio: 1; top: -10%; right: -12%; border-radius: 50%; background: radial-gradient(circle, rgba(89,85,239,0.16), transparent 66%); filter: blur(8px); pointer-events: none; }
.hiw-panel { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; padding: 26px; opacity: 0; transform: scale(.96) translateY(10px); transition: opacity .55s cubic-bezier(.16,1,.3,1), transform .55s cubic-bezier(.16,1,.3,1); }
.hiw-panel.on { opacity: 1; transform: none; }
.hiw-prog { position: absolute; left: 16px; right: 16px; bottom: 14px; z-index: 5; display: flex; gap: 6px; }
.hiw-prog i { flex: 1; height: 4px; border-radius: 99px; background: rgba(89,85,239,0.18); overflow: hidden; }
.hiw-prog i.on { background: var(--purple); }
.hiw-steps { display: flex; flex-direction: column; gap: clamp(110px, 26vh, 280px); padding: 20vh 0; }
.hiw-step { transition: opacity .45s; opacity: .3; }
.hiw-step.act { opacity: 1; }
.hiw-step .num { display: inline-flex; align-items: center; justify-content: center; width: 50px; height: 50px; border-radius: 15px; background: var(--purple-light); color: var(--purple); font-family: 'Onest', sans-serif; font-weight: 800; font-size: 1.2rem; margin-bottom: 22px; transition: background .4s, color .4s, transform .4s; }
.hiw-step.act .num { background: var(--purple); color: #fff; transform: scale(1.06); box-shadow: 0 14px 28px -12px rgba(89,85,239,0.6); }
.hiw-step h3 { font-family: 'Onest', sans-serif; font-size: clamp(1.85rem, 3.3vw, 2.8rem); font-weight: 600; letter-spacing: -0.025em; line-height: 1.05; margin-bottom: 16px; }
.hiw-step p { font-size: clamp(1.05rem, 1.45vw, 1.24rem); line-height: 1.62; color: var(--ink-70); max-width: 480px; }

/* fake-UI primitives (panels) */
.ui { width: 100%; max-width: 250px; background: #fff; border-radius: 18px; border: 1px solid rgba(20,16,80,0.06); box-shadow: 0 20px 44px -24px rgba(40,32,110,0.4); padding: 16px; }
.ui-row { display: flex; align-items: center; gap: 10px; padding: 9px; border-radius: 10px; }
.ui-row.sel { background: rgba(89,85,239,0.09); box-shadow: inset 0 0 0 1px rgba(89,85,239,0.25); }
.ui-dot { width: 26px; height: 26px; border-radius: 8px; background: var(--purple-light); flex-shrink: 0; display:flex;align-items:center;justify-content:center; color: var(--purple); }
.ui-dot svg { width: 14px; height: 14px; }
.ui-bar { height: 8px; border-radius: 99px; background: #ebebf3; } .ui-bar.s { background: #f1f1f7; } .ui-bar.p { background: var(--purple); }
.ui-col { display: flex; flex-direction: column; gap: 6px; flex: 1; min-width: 0; }
.ui-big { font-family: 'Onest', sans-serif; font-weight: 700; font-size: 1.5rem; letter-spacing: -0.02em; color: var(--text); }
.ui-badge { display: inline-flex; align-items: center; gap: 5px; background: rgba(22,163,74,0.12); color: #16a34a; border-radius: 8px; padding: 5px 9px; font-family: 'Onest', sans-serif; font-size: 11px; font-weight: 700; }
.ui-badge svg { width: 12px; height: 12px; }
.ui-cta { margin-top: 4px; height: 36px; border-radius: 10px; background: linear-gradient(160deg, var(--purple), var(--purple-dark)); color: #fff; display: flex; align-items: center; justify-content: center; font-family: 'Onest', sans-serif; font-weight: 700; font-size: 12.5px; gap: 6px; }
.ui-cta svg { width: 14px; height: 14px; }
.ui-up { display:inline-flex; align-items:center; gap:4px; color:#16a34a; font-family:'Onest',sans-serif; font-weight:700; font-size:12px; }
/* clear, legible fake-UI panels */
.ui2 { width:100%; max-width:272px; background:#fff; border-radius:18px; border:1px solid rgba(20,16,80,0.07); box-shadow:0 22px 48px -26px rgba(40,32,110,0.45); padding:16px; }
.ui-eye { font-family:'Onest',sans-serif; font-size:10px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--purple); }
.ui-list { display:flex; flex-direction:column; gap:8px; margin-top:12px; }
.ui-item { display:flex; align-items:center; gap:10px; padding:10px; border-radius:11px; border:1px solid var(--grey-border); background:#fff; }
.ui-item.sel { border-color:rgba(89,85,239,.4); background:rgba(89,85,239,.06); box-shadow:0 6px 18px -10px rgba(89,85,239,.4); }
.ui-pin { width:30px;height:30px;border-radius:9px;background:var(--purple-light);color:var(--purple);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.ui-pin svg{width:15px;height:15px;}
.ui-it { flex:1; min-width:0; display:flex; flex-direction:column; gap:2px; }
.ui-it b { font-family:'Onest',sans-serif; font-size:12.5px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ui-it span { font-size:10.5px; color:var(--text-50); }
.ui-chk { width:20px;height:20px;border-radius:50%;background:var(--purple);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.ui-chk svg{width:11px;height:11px;}
.ui-cert-head { display:flex; align-items:center; gap:9px; padding-bottom:12px; border-bottom:1px solid var(--grey-border); }
.ui-logo { width:30px;height:30px;border-radius:8px;background:linear-gradient(160deg,var(--purple),var(--purple-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Onest',sans-serif;font-weight:800;font-size:14px;flex-shrink:0; }
.ui-verif { display:inline-flex; align-items:center; gap:4px; background:rgba(22,163,74,.12); color:#16a34a; border-radius:7px; padding:4px 7px; font-family:'Onest',sans-serif; font-size:9.5px; font-weight:700; flex-shrink:0; }
.ui-verif svg{width:10px;height:10px;}
.ui-km { display:flex; align-items:baseline; justify-content:space-between; margin:12px 0; }
.ui-km span { font-size:10.5px; color:var(--text-50); font-family:'Onest',sans-serif; font-weight:600; }
.ui-km b { font-family:'Onest',sans-serif; font-size:1.35rem; font-weight:700; letter-spacing:-0.02em; color:var(--text); }
.ui-lines { display:flex; flex-direction:column; gap:9px; }
.ui-line { display:flex; align-items:center; gap:8px; font-family:'Onest',sans-serif; font-size:11.5px; font-weight:500; color:var(--text); }
.ui-line svg { width:14px;height:14px; color:#16a34a; flex-shrink:0; }
.ui-foot { display:flex; align-items:center; justify-content:space-between; margin-top:14px; padding-top:12px; border-top:1px solid var(--grey-border); }
.ui-foot .dt { font-size:10.5px; color:var(--text-50); font-family:'Onest',sans-serif; }
.ui-qr { width:34px;height:34px;border-radius:7px;background:#1a1a2e; display:grid; grid-template-columns:repeat(3,1fr); grid-template-rows:repeat(3,1fr); gap:2px; padding:5px; }
.ui-qr i { background:#fff; border-radius:1px; } .ui-qr i:nth-child(2),.ui-qr i:nth-child(4),.ui-qr i:nth-child(9){ background:transparent; }
.ui-app-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.ui-app-head b { font-family:'Onest',sans-serif; font-size:13px; font-weight:700; }
.ui-val { display:inline-flex; align-items:center; gap:4px; background:rgba(22,163,74,.12); color:#16a34a; border-radius:7px; padding:4px 8px; font-family:'Onest',sans-serif; font-size:10.5px; font-weight:700; }
.ui-val svg{width:11px;height:11px;}
.ui-doc { display:flex; align-items:center; gap:10px; padding:10px; border-radius:11px; border:1px solid var(--grey-border); margin-bottom:8px; }
.ui-doc-ic { width:30px;height:30px;border-radius:8px;background:var(--purple-light);color:var(--purple);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.ui-doc-ic svg{width:15px;height:15px;}
.ui-share { margin-top:6px; height:40px; border-radius:11px; background:linear-gradient(160deg,var(--purple),var(--purple-dark)); color:#fff; display:flex; align-items:center; justify-content:center; gap:7px; font-family:'Onest',sans-serif; font-weight:700; font-size:12px; box-shadow:0 12px 24px -12px rgba(89,85,239,.7); }
.ui-share svg{width:14px;height:14px;}

/* ============================================================ APP (alternating) */
.app2-inner { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.app2-copy { order: 1; }
.app2-visual { position: relative; order: 2; }
.app2-visual > img { width: 100%; height: auto; display: block; filter: drop-shadow(0 40px 70px -34px rgba(40,32,110,0.45)); }
.app2-glow { position: absolute; inset: 6% 4% 10%; z-index: -1; background: radial-gradient(circle, rgba(89,85,239,0.22), transparent 64%); filter: blur(20px); }
.app2-fx { position: absolute; z-index: 3; display: inline-flex; align-items: center; gap: 9px; background: #fff; border: 1px solid var(--grey-border); border-radius: 13px; padding: 9px 13px; box-shadow: 0 8px 22px -12px rgba(40,32,110,0.20), 0 1px 3px rgba(20,16,80,0.05); font-family: 'Onest', sans-serif; white-space: nowrap; }
.app2-fx .fx-ic { width: 28px; height: 28px; border-radius: 8px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.app2-fx .fx-ic.g { background: rgba(22,163,74,0.12); color: #16a34a; } .app2-fx .fx-ic.p { background: var(--purple-light); color: var(--purple); }
.app2-fx .fx-ic svg { width: 15px; height: 15px; }
.app2-fx .fx-t { display: flex; flex-direction: column; gap: 1px; line-height: 1.2; }
.app2-fx .fx-k { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--text-50); }
.app2-fx .fx-v { font-size: 12.5px; font-weight: 600; color: var(--text); }
.app2-fx.a1 { top: 10%; left: -4%; animation: floaty 5.6s ease-in-out infinite; }
.app2-fx.a2 { bottom: 14%; right: -3%; animation: floaty 6.6s ease-in-out infinite 1s; }
.app2-feats { list-style: none; display: flex; flex-direction: column; gap: 18px; margin: clamp(18px,2.5vh,26px) 0; }
.app2-feat { display: flex; gap: 13px; align-items: flex-start; }
.app2-feat .k { width: 38px; height: 38px; border-radius: 11px; background: var(--purple-light); color: var(--purple); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.app2-feat .k svg { width: 19px; height: 19px; }
.app2-feat h3 { font-family: 'Onest', sans-serif; font-size: 1rem; font-weight: 600; margin-bottom: 3px; letter-spacing: -0.01em; }
.app2-feat p { font-size: 0.9rem; line-height: 1.5; color: var(--ink-70); }
.store-badges { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }
.store-badges img { height: 50px; width: auto; display: block; }

/* ============================================================ RESEAU band */
.res-inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px,5vw,72px); align-items: center; }
.res-copy { order: 1; }
.res-media { position: relative; max-width: 460px; justify-self: center; width: 100%; order: 2; }
.res-photo { border-radius: 22px; overflow: hidden; background: #fff; }
.res-photo.main { aspect-ratio: 4/5; box-shadow: var(--sh-soft); border: 1px solid var(--grey-border); transform: rotate(1.5deg); }
.res-photo.main img { width: 100%; height: 100%; object-fit: cover; display: block; }
.res-photo.proof { position: absolute; left: -28px; bottom: -26px; width: 46%; aspect-ratio: 1/1; border: 5px solid #fff; box-shadow: var(--sh-float); transform: rotate(-4deg); animation: floaty 6.5s ease-in-out infinite .4s; }
.res-photo.proof img { width: 100%; height: 100%; object-fit: cover; display: block; }
.res-chip { position: absolute; right: -20px; top: 24px; z-index: 5; display:inline-flex; align-items:center; gap:9px; background:#fff; border:1px solid var(--grey-border); border-radius:13px; padding:9px 14px; box-shadow: var(--sh-float); font-family:'Onest',sans-serif; white-space:nowrap; animation: floaty 5.5s ease-in-out infinite; }
.res-chip .nc-ic { width:28px;height:28px;border-radius:8px;background:rgba(22,163,74,0.12);color:#16a34a;display:flex;align-items:center;justify-content:center; }
.res-chip .nc-ic svg { width:15px;height:15px; }
.res-chip .nc-t { font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-50);display:block; }
.res-chip .nc-v { font-size:12.5px;font-weight:600;color:var(--text);display:block; }
.res-copy .eyebrow { margin-bottom: 4px; }
.res-copy h2 { font-family:'Onest',sans-serif; font-size: clamp(1.9rem,3.6vw,2.8rem); font-weight:600; letter-spacing:-0.03em; line-height:1.05; margin:14px 0 14px; }
.res-copy > p { font-size: 1.02rem; line-height: 1.6; color: var(--ink-70); max-width: 480px; }
.res-stats { display: flex; gap: 12px; margin-top: 30px; flex-wrap: wrap; }
.res-stat { flex: 1 1 0; min-width: 120px; background: #fff; border: 1px solid var(--grey-border); border-radius: var(--radius-md); padding: 18px 16px; text-align: center; }
.res-stat b { display:block; font-family:'Onest',sans-serif; font-size: clamp(1.4rem,2.2vw,1.9rem); font-weight:700; color: var(--purple); letter-spacing:-0.02em; line-height:1; }
.res-stat span { display:block; font-size: 11.5px; color: var(--text-50); margin-top:7px; font-family:'Onest',sans-serif; line-height:1.35; }

/* ============================================================ REVENTE */
.rev-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(28px,4vw,60px); align-items: center; }
.rev-big { font-family:'Onest',sans-serif; font-size: clamp(3.4rem, 8vw, 6rem); font-weight: 700; letter-spacing:-0.04em; line-height:0.9; color: var(--purple); }
.rev-big small { display:block; font-size: 1rem; font-weight: 600; color: var(--ink-70); letter-spacing: 0; margin-top: 12px; }
.rev-cards { display: flex; flex-direction: column; gap: 14px; }
.rev-card { display:flex; gap:15px; align-items:center; background:#fff; border:1px solid var(--grey-border); border-radius: var(--radius-lg); padding: clamp(18px,2vw,24px); box-shadow: var(--sh-soft); }
.rev-card .av { width: 56px; height: 56px; border-radius: 15px; overflow:hidden; flex-shrink:0; border: 2px solid var(--purple-light); }
.rev-card .av img { width:100%; height:100%; object-fit:cover; display:block; }
.rev-card .tag { font-family:'Onest',sans-serif; font-size: 11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--purple); margin-bottom:5px; }
.rev-card p { font-size: clamp(.95rem,1.2vw,1.05rem); line-height:1.5; color:var(--text); font-weight:500; }
.rev-card .stars { color:#ffb800; font-size:12.5px; letter-spacing:1px; margin-top:7px; }
.platforms { margin-top: clamp(36px,5vw,56px); text-align: center; }
.platforms-label { font-family:'Onest',sans-serif; font-size:13px; font-weight:600; color:var(--text-50); margin-bottom:16px; }
.platforms-row { display:flex; flex-wrap:wrap; justify-content:center; gap:12px; }
.platform-chip { display:inline-flex; align-items:center; gap:10px; background:#fff; border:1px solid var(--grey-border); border-radius:999px; padding:8px 18px 8px 10px; box-shadow:0 4px 14px rgba(40,30,15,0.05); transition:transform .3s, box-shadow .3s; }
.platform-chip:hover { transform: translateY(-2px); box-shadow: 0 10px 26px -14px rgba(89,85,239,0.16); }
.platform-chip img { border-radius:6px; }
.platform-chip span { font-family:'Onest',sans-serif; font-size:13.5px; font-weight:600; color:var(--text); }

/* revente: persona cards + signature car-on-road animation */
#revente { overflow: hidden; }
.rev-personas { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(16px,3vw,40px); align-items: start; margin-bottom: clamp(8px,2vw,18px); }
.rev-personas .rev-card.seller { margin-right: auto; max-width: 420px; }
.rev-personas .rev-card.buyer { margin-left: auto; max-width: 420px; }
.road { position: relative; left: 50%; right: 50%; width: 100vw; margin-left: -50vw; margin-right: -50vw; height: clamp(180px, 23vw, 250px); margin-top: 6px; }
.car { position: absolute; left: 50%; bottom: 6px; z-index: 2; width: clamp(190px, 25vw, 296px); transform: translateX(-50%); animation: carBob 0.9s ease-in-out infinite; }
.car img { width: 100%; height: auto; display: block; }
@keyframes carBob { 0%,100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(-2.5px); } }
.road-cert { position: absolute; left: 50%; bottom: 118px; z-index: 4; transform: translateX(58px); display: inline-flex; align-items: center; gap: 9px; padding: 9px 14px; border-radius: 13px; background: #fff; border: 1px solid var(--grey-border); box-shadow: var(--sh-float); font-family: 'Onest', sans-serif; font-size: 12.5px; font-weight: 600; animation: floaty 3.4s ease-in-out infinite; }
.road-cert .rc-ic { width: 26px; height: 26px; border-radius: 8px; background: var(--purple-light); color: var(--purple); display: flex; align-items: center; justify-content: center; }
.road-cert .rc-ic svg { width: 15px; height: 15px; }
.car-shadow { position: absolute; left: 50%; bottom: 30px; z-index: 1; width: clamp(150px, 20vw, 234px); height: 14px; transform: translateX(-50%); background: radial-gradient(ellipse, rgba(20,16,80,0.3) 0%, transparent 70%); filter: blur(4px); animation: shadowPulse 0.9s ease-in-out infinite; }
@keyframes shadowPulse { 0%,100% { transform: translateX(-50%) scaleX(1); opacity: .85; } 50% { transform: translateX(-50%) scaleX(0.94); opacity: .7; } }
.road-base { position: absolute; left: 0; right: 0; bottom: 0; height: 76px; background: linear-gradient(180deg, #e7e4fb 0%, #dcd8f7 100%); border-top: 2px solid rgba(89,85,239,0.2); }
.road-line { position: absolute; left: 0; right: 0; bottom: 34px; height: 6px; background-image: repeating-linear-gradient(90deg, var(--purple) 0 42px, transparent 42px 84px); background-size: 84px 100%; opacity: 0.5; animation: roadDash 0.55s linear infinite; }
@keyframes roadDash { to { background-position-x: -84px; } }
.speedlines { position: absolute; left: 50%; bottom: 92px; z-index: 1; transform: translateX(-182px); pointer-events: none; }
.speedlines span { position: absolute; right: 0; height: 3px; border-radius: 99px; background: linear-gradient(90deg, transparent, rgba(89,85,239,0.55)); animation: speed 0.5s linear infinite; }
.speedlines span:nth-child(1) { width: 40px; top: 0; }
.speedlines span:nth-child(2) { width: 26px; top: 15px; right: 8px; animation-delay: .12s; }
.speedlines span:nth-child(3) { width: 46px; top: 30px; right: -4px; animation-delay: .26s; }
@keyframes speed { from { transform: translateX(24px); opacity: 0; } 40% { opacity: 1; } to { transform: translateX(-30px); opacity: 0; } }

/* ============================================================ FAQ */
.faq-inner { max-width: 56rem; margin: 0 auto; }
.faq-list { display: flex; flex-direction: column; gap: 12px; }
.faq-item { border: 1px solid var(--grey-border); border-radius: var(--radius-md); background: #fff; overflow: hidden; transition: border-color .3s, box-shadow .3s; }
.faq-item.open { border-color: rgba(89,85,239,0.35); box-shadow: 0 12px 32px -16px rgba(89,85,239,0.12); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: clamp(18px,2.4vw,24px) clamp(20px,2.6vw,28px); background: none; border: 0; cursor: pointer; text-align: left; font-family: 'Onest', sans-serif; font-size: clamp(.98rem,1.5vw,1.12rem); font-weight: 600; color: var(--text); }
.faq-icon { width: 30px; height: 30px; border-radius: 50%; background: var(--purple-light); color: var(--purple); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: transform .35s cubic-bezier(.16,1,.3,1), background .3s, color .3s; }
.faq-icon svg { width: 15px; height: 15px; }
.faq-item.open .faq-icon { background: var(--purple); color: #fff; transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .4s cubic-bezier(.16,1,.3,1); }
.faq-item.open .faq-a { max-height: 320px; }
.faq-a-inner { padding: 0 clamp(20px,2.6vw,28px) clamp(20px,2.4vw,24px); font-size: .96rem; line-height: 1.62; color: var(--ink-70); }
.faq-a-inner a { color: var(--purple); font-weight: 600; }

a:focus-visible, button:focus-visible { outline: 3px solid rgba(89,85,239,0.5); outline-offset: 3px; border-radius: 8px; }

/* ============================================================ FACTURE VS CERTIFICAT */
.fc-duo { display: flex; align-items: stretch; justify-content: center; gap: clamp(12px, 3vw, 50px); margin-top: 10px; }
.fc-doc { display: flex; flex-direction: column; align-items: center; gap: 16px; flex: 0 1 auto; }
.fc-cap { display: inline-flex; align-items: center; gap: 8px; font-family: 'Onest', sans-serif; font-size: 12.5px; font-weight: 700; letter-spacing: .01em; padding: 7px 15px; border-radius: 999px; }
.fc-cap.muted { background: #eceef2; color: var(--text-50); }
.fc-cap.live { background: var(--purple-light); color: var(--purple-dark); }
.fc-cap.live .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--purple); }
.fc-frame { position: relative; flex: 1; display: flex; align-items: center; justify-content: center; border-radius: 28px; padding: clamp(30px, 3.4vw, 50px) clamp(24px, 3vw, 42px); }
.fc-doc.old { width: clamp(280px, 30vw, 340px); }
.fc-doc.new { width: clamp(290px, 31vw, 360px); }
.frame-old { background: linear-gradient(165deg, #f4f5f9 0%, #e7e9f1 100%); border: 1px solid #e1e3ec; }
.frame-new { background: linear-gradient(165deg, #eef0ff 0%, #e2e4ff 100%); border: 1px solid #dad8fb; }
.frame-new::before { content: ""; position: absolute; inset: 0; border-radius: inherit; background: radial-gradient(62% 48% at 50% 36%, rgba(89,85,239,0.20), transparent 70%); }
.fc-paper { position: relative; z-index: 1; width: clamp(190px, 19vw, 236px); height: auto; display: block; filter: drop-shadow(0 20px 34px rgba(40,32,110,0.18)); transform: rotate(-1deg); }
.cert-real { width: clamp(230px, 25vw, 300px); transform: rotate(1.2deg); animation: floaty 6.5s ease-in-out infinite; filter: drop-shadow(0 26px 46px rgba(40,32,110,0.28)); }
.cert-card { position: relative; z-index: 1; width: 100%; max-width: 312px; background: #fff; border-radius: 20px; border: 1px solid rgba(20,16,80,0.05); box-shadow: 0 34px 64px -34px rgba(40,32,110,0.55); overflow: hidden; animation: floaty 6.5s ease-in-out infinite; }
.cc-head { display: flex; align-items: center; gap: 11px; padding: 16px; background: linear-gradient(150deg, var(--purple), var(--purple-dark)); }
.cc-logo { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.18); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cc-logo svg { width: 20px; height: 20px; color: #fff; }
.cc-title { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.cc-title b { font-family: 'Onest', sans-serif; font-size: 14px; font-weight: 700; color: #fff; }
.cc-title span { font-size: 11px; color: rgba(255,255,255,0.78); }
.cc-verif { width: 27px; height: 27px; border-radius: 50%; background: #16a34a; color: #fff; display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 0 0 3px rgba(255,255,255,0.22); }
.cc-verif svg { width: 14px; height: 14px; }
.cc-km { display: flex; flex-direction: column; gap: 2px; align-items: center; text-align: center; padding: 18px 16px 12px; }
.cc-km span { font-size: 10px; color: var(--text-50); font-family: 'Onest', sans-serif; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.cc-km b { font-family: 'Onest', sans-serif; font-size: 1.95rem; font-weight: 800; letter-spacing: -0.02em; color: var(--text); }
.cc-lines { display: flex; flex-direction: column; gap: 8px; padding: 4px 16px 16px; }
.cc-line { display: flex; align-items: center; gap: 10px; font-family: 'Onest', sans-serif; font-size: 12.5px; font-weight: 600; color: var(--text); background: #f6f6fa; border-radius: 10px; padding: 9px 12px; }
.cc-line .ck { width: 19px; height: 19px; border-radius: 50%; background: #16a34a; color: #fff; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cc-line .ck svg { width: 11px; height: 11px; }
.cc-foot { display: flex; align-items: center; justify-content: space-between; padding: 13px 16px; border-top: 1px solid var(--grey-border); }
.cc-dt { font-size: 11px; color: var(--text-50); font-family: 'Onest', sans-serif; font-weight: 600; }
.cc-qr { width: 42px; height: 42px; border-radius: 8px; background: #1a1a2e; display: grid; grid-template-columns: repeat(4,1fr); grid-template-rows: repeat(4,1fr); gap: 2px; padding: 5px; }
.cc-qr i { background: #fff; border-radius: 1px; }
.cc-qr i:nth-child(2), .cc-qr i:nth-child(7), .cc-qr i:nth-child(9), .cc-qr i:nth-child(12), .cc-qr i:nth-child(14) { background: transparent; }
.fc-flag { position: absolute; z-index: 4; left: 50%; bottom: -17px; transform: translateX(-50%); display: inline-flex; align-items: center; gap: 7px; font-family: 'Onest', sans-serif; font-size: 12.5px; font-weight: 700; padding: 9px 15px; border-radius: 12px; background: #fff; box-shadow: 0 14px 32px -14px rgba(40,32,110,0.32), 0 1px 3px rgba(20,16,80,0.06); white-space: nowrap; }
.fc-flag svg { width: 17px; height: 17px; }
.fc-flag.warn { color: #c2410c; }
.fc-flag.warn svg { color: #ea580c; }
.fc-flag.ok { color: var(--purple-dark); }
.fc-flag.ok svg { color: #16a34a; }
.fc-arrow { display: flex; flex-direction: column; align-items: center; gap: 9px; flex: 0 0 auto; align-self: center; }
.fc-arrow svg { width: 40px; height: 40px; color: var(--purple); }
.fc-arrow span { font-family: 'Onest', sans-serif; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .09em; color: var(--text-50); }
.fc-args { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(16px, 1.8vw, 24px); max-width: 1000px; margin: clamp(44px, 5.5vw, 70px) auto 0; }
.fc-arg { background: #fff; border: 1px solid var(--grey-border); border-radius: var(--radius-lg); padding: clamp(22px, 2.2vw, 30px); transition: transform .4s cubic-bezier(.16,1,.3,1), box-shadow .4s, border-color .3s; }
.fc-arg:hover { transform: translateY(-5px); border-color: rgba(89,85,239,0.3); box-shadow: var(--sh-card); }
.fc-arg-ic { width: 50px; height: 50px; border-radius: 14px; margin-bottom: 16px; background: var(--purple-light); color: var(--purple); display: flex; align-items: center; justify-content: center; }
.fc-arg-ic svg { width: 25px; height: 25px; }
.fc-arg h3 { font-family: 'Onest', sans-serif; font-size: 1.18rem; font-weight: 600; letter-spacing: -0.01em; color: var(--text); margin-bottom: 8px; }
.fc-arg p { font-family: 'HafferSQ', sans-serif; font-size: 14.5px; line-height: 1.55; color: var(--text-50); }

/* ============================================================ RESPONSIVE */
@media (max-width: 980px) {
  .feat-grid { grid-template-columns: repeat(2, 1fr); }
  .fc-args { grid-template-columns: 1fr; max-width: 480px; }
  .hiw-inner { grid-template-columns: 1fr; }
  .hiw-visual { display: none; }
  .hiw-steps { padding: 0; gap: 52px; }
  .hiw-step { opacity: 1; }
  .hiw-inline-panel { position: static; inset: auto; opacity: 1; transform: none; display: flex; align-items: center; justify-content: center; padding: 28px 24px; margin: 0 0 22px; border-radius: 22px; background: linear-gradient(165deg, #ffffff 0%, #f3f1ff 100%); border: 1px solid var(--grey-border); box-shadow: var(--sh-float); transition: none; }
  .hiw-inline-panel .ui2 { max-width: 300px; }
  .app2-inner { grid-template-columns: 1fr; }
  .app2-visual { order: -1; max-width: 460px; margin: 0 auto; }
  .res-inner { grid-template-columns: 1fr; }
  .res-media { order: -1; }
  .rev-grid { grid-template-columns: 1fr; gap: 26px; }
  .rev-personas { grid-template-columns: 1fr; gap: 14px; }
  .rev-personas .rev-card.seller, .rev-personas .rev-card.buyer { max-width: 100%; margin: 0; }
}
@media (max-width: 620px) {
  .feat-grid { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
  .fc-duo { flex-direction: column; gap: 14px; }
  .fc-doc.old, .fc-doc.new { width: 100%; max-width: 360px; }
  .fc-doc.new { margin-top: 10px; }
  .fc-arrow svg { transform: rotate(90deg); }
  .fc-args { max-width: 400px; }
  .hero-fx { display: none; }
  .road-cert { display: none; }
  .floating-bar { width: calc(100% - 28px); left: 14px; transform: translateX(0) translateY(120px); bottom: 12px; }
  .floating-bar.visible { transform: translateX(0) translateY(0); }
  .floating-bar > .cta-3d { flex: 1 1 50%; min-width: 0; }
  .floating-bar > .cta-3d .cta-3d-inner { width: 100%; }
  .floating-bar > .cta-3d .cta-3d-text { flex: 1; text-align: center; padding: 9px 8px; }
  .floating-bar a.fb-whatsapp { flex: 1 1 50%; min-width: 0; justify-content: center; padding: 12px; box-sizing: border-box; }
}

@media (prefers-reduced-motion: reduce) {
  .rv { opacity: 1; transform: none; transition: none; }
  .hero-device, .hero-fx, .hero-sticker, .app2-fx, .res-photo.proof, .res-chip, .marquee-track,
  .car, .car-shadow, .road-line, .road-cert, .speedlines span { animation: none !important; }
  [data-parallax] { transform: none !important; }
  .floating-bar { transition: opacity .3s ease; }
}

/* ===================== GARAGE FINDER MODAL ===================== */
.gf-modal { position: fixed; inset: 0; z-index: 200; display: flex; align-items: center; justify-content: center; padding: 22px; opacity: 0; visibility: hidden; transition: opacity .28s ease, visibility .28s ease; }
.gf-modal.open { opacity: 1; visibility: visible; }
.gf-backdrop { position: absolute; inset: 0; background: rgba(24,20,60,0.42); backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px); }
.gf-card { position: relative; z-index: 1; width: 100%; max-width: 440px; background: #fff; border-radius: 24px; padding: clamp(28px, 4vw, 40px) clamp(24px, 3.4vw, 38px) clamp(24px, 3vw, 32px); text-align: center; box-shadow: 0 40px 90px -30px rgba(40,32,110,0.5); transform: translateY(14px) scale(.97); transition: transform .32s cubic-bezier(.16,1,.3,1); }
.gf-modal.open .gf-card { transform: none; }
.gf-close { position: absolute; top: 14px; right: 14px; width: 34px; height: 34px; border: 0; border-radius: 10px; background: var(--grey-bg); color: var(--text); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background .2s; }
.gf-close:hover { background: #e9e9ef; }
.gf-close svg { width: 17px; height: 17px; }
.gf-badge { display: inline-flex; align-items: center; gap: 7px; font-family: 'Onest', sans-serif; font-size: 11.5px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--purple); background: var(--purple-light); padding: 6px 12px; border-radius: 999px; }
.gf-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--purple); box-shadow: 0 0 0 0 rgba(89,85,239,0.5); animation: gfPulse 1.8s ease-out infinite; }
@keyframes gfPulse { 0% { box-shadow: 0 0 0 0 rgba(89,85,239,0.45); } 70% { box-shadow: 0 0 0 8px rgba(89,85,239,0); } 100% { box-shadow: 0 0 0 0 rgba(89,85,239,0); } }
.gf-ic { width: 64px; height: 64px; margin: 20px auto 4px; border-radius: 20px; background: linear-gradient(160deg, var(--purple), var(--purple-dark)); display: flex; align-items: center; justify-content: center; box-shadow: 0 18px 32px -14px rgba(89,85,239,0.6); }
.gf-ic svg { width: 30px; height: 30px; color: #fff; }
.gf-card h3 { font-family: 'Onest', sans-serif; font-size: clamp(1.4rem, 3vw, 1.7rem); font-weight: 600; letter-spacing: -0.02em; color: var(--text); margin: 14px 0 10px; line-height: 1.15; }
.gf-card p { font-size: 15px; line-height: 1.6; color: var(--ink-70); margin: 0 auto; max-width: 360px; }
.gf-card .gf-sub { margin-top: 12px; font-weight: 500; color: var(--text); }
.gf-actions { display: flex; flex-direction: column; gap: 10px; margin-top: 24px; }
.gf-wa { display: inline-flex; align-items: center; justify-content: center; gap: 9px; padding: 14px 20px; border-radius: 14px; background: #25D366; color: #fff; font-family: 'Onest', sans-serif; font-weight: 700; font-size: 15px; text-decoration: none; transition: transform .2s, filter .2s; }
.gf-wa:hover { transform: translateY(-2px); filter: brightness(1.04); }
.gf-wa svg { width: 18px; height: 18px; }
.gf-ghost { border: 0; background: transparent; color: var(--text-50); font-family: 'Onest', sans-serif; font-weight: 600; font-size: 14px; padding: 8px; cursor: pointer; transition: color .2s; }
.gf-ghost:hover { color: var(--text); }
@media (prefers-reduced-motion: reduce) { .gf-card { transition: none; } .gf-dot { animation: none; } }

/* ===================== JOURNEY (continuité hiw -> app -> network + connecteur) ===================== */
.journey { position: relative; }
.journey > .s { padding-top: clamp(50px, 6.5vw, 84px); padding-bottom: clamp(50px, 6.5vw, 84px); position: relative; z-index: 1; }
.journey-rail { position: absolute; left: 50%; transform: translateX(-50%); width: 2px; border-radius: 3px; background: rgba(89,85,239,0.13); z-index: 0; pointer-events: none; }
.journey-fill { position: absolute; left: 0; top: 0; width: 100%; height: 0; border-radius: 3px; background: linear-gradient(180deg, var(--purple), var(--purple-dark)); box-shadow: 0 0 10px rgba(89,85,239,0.35); }
.journey-fill::after { content: ''; position: absolute; left: 50%; bottom: -5px; transform: translateX(-50%); width: 12px; height: 12px; border-radius: 50%; background: var(--purple); box-shadow: 0 0 0 5px rgba(89,85,239,0.16), 0 0 16px rgba(89,85,239,0.65); }
.journey-node { position: absolute; left: 50%; transform: translate(-50%,-50%); width: 11px; height: 11px; border-radius: 50%; background: #fff; border: 2px solid rgba(89,85,239,0.32); z-index: 0; }
.journey-node.passed { border-color: var(--purple); background: var(--purple); box-shadow: 0 0 0 4px rgba(89,85,239,0.14); }
@media (max-width: 980px) { .journey-rail, .journey-node { display: none; } }
@media (prefers-reduced-motion: reduce) { .journey-fill { transition: none; } }

/* ===================== JOURNEY COHESION (typo + nodes unifiés) ===================== */
/* titres de section homogènes sur les 3 */
.journey .s-title { font-size: clamp(1.9rem, 3.2vw, 2.55rem); letter-spacing: -0.03em; line-height: 1.06; }
.journey .res-copy h2 { font-size: clamp(1.9rem, 3.2vw, 2.55rem); letter-spacing: -0.03em; line-height: 1.06; }
/* sous-titres d'étape (niveau inférieur, cohérents) */
.journey .hiw-step h3 { font-size: clamp(1.35rem, 2vw, 1.7rem); line-height: 1.14; margin-bottom: 12px; }
/* corps de texte homogène */
.journey .hiw-step p { font-size: clamp(1.02rem, 1.25vw, 1.14rem); line-height: 1.6; max-width: 440px; }
.journey .res-copy > p { font-size: clamp(1.02rem, 1.25vw, 1.14rem); line-height: 1.6; }
/* rythme des étapes resserré (sticky-scroll conservé, moins gigantesque) */
.journey .hiw-steps { padding: 9vh 0; gap: clamp(86px, 18vh, 200px); }
/* le badge inline d'étape laisse place au nœud numéroté sur la ligne (desktop) */
@media (min-width: 981px){ .journey .hiw-step .num { display: none; } }

/* nœuds de la ligne : au-dessus du contenu de section */
.journey-node { z-index: 2; }
/* nœud numéroté = l'étape, posé sur la ligne */
.journey-node.step { width: 46px; height: 46px; border-radius: 14px; border: 0; background: var(--purple-light); color: var(--purple); display: flex; align-items: center; justify-content: center; font-family: 'Onest', sans-serif; font-weight: 800; font-size: 1.12rem; box-shadow: 0 1px 0 rgba(20,16,80,0.04); transition: background .4s, color .4s, transform .4s, box-shadow .4s; }
.journey-node.step.active { background: var(--purple); color: #fff; transform: translate(-50%,-50%) scale(1.06); box-shadow: 0 16px 30px -12px rgba(89,85,239,0.6); }
/* nœud simple = séparateur app / réseau */
.journey-node.plain { width: 14px; height: 14px; border-radius: 50%; background: #fff; border: 2px solid rgba(89,85,239,0.30); transition: background .35s, border-color .35s, box-shadow .35s; }
.journey-node.plain.passed { background: var(--purple); border-color: var(--purple); box-shadow: 0 0 0 5px rgba(89,85,239,0.14); }

/* grilles symétriques -> la ligne centrale tombe pile dans la gouttière, nœuds sans collision */
.journey .hiw-inner { grid-template-columns: 1fr 1fr; gap: clamp(56px, 6vw, 96px); }
.journey .app2-inner { grid-template-columns: 1fr 1fr; gap: clamp(56px, 6vw, 96px); }
.journey .res-inner { grid-template-columns: 1fr 1fr; gap: clamp(56px, 6vw, 96px); }
.journey-node.step { width: 42px; height: 42px; font-size: 1.05rem; }

/* mobile : pas de connecteur ni de nœuds (les badges .num inline reprennent le rôle) */
@media (max-width: 980px){ .journey-rail, .journey-node, .journey-node.step, .journey-node.plain { display: none !important; } }

/* ===================== APP en bloc plein largeur (visuel au-dessus, coupe la ligne) ===================== */
.app2-inner.app2-stack { display: block; max-width: 900px; margin: 0 auto; text-align: center; }
.app2-stack .app2-head { margin-bottom: clamp(28px, 3.6vw, 44px); }
.app2-stack .app2-head .s-title { text-align: center; margin: 14px auto 0; max-width: 680px; }
.app2-stack .app2-visual { max-width: 760px; margin: 0 auto; }
.app2-stack .app2-copy { margin-top: clamp(30px, 3.8vw, 48px); }
.app2-stack .app2-feats { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 2.6vw, 34px); text-align: left; margin: 0 auto clamp(24px, 3vw, 34px); max-width: 860px; }
.app2-stack .app2-feat { gap: 12px; }
.app2-stack .store-badges { justify-content: center; }
@media (max-width: 760px){
  .app2-stack .app2-feats { grid-template-columns: 1fr; max-width: 420px; }
}
