@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=DM+Sans:wght@400;500;600&display=swap');

:root{
  --green:#1D9E75;--green-d:#157A59;--green-dd:#0B5C40;
  --live:#34D399;--live-d:#0E9E6E;
  --ink:#07150E;--ink-2:#0E2318;--ink-3:#16301F;
  --paper:#fff;--paper-2:#F4F8F6;--mint:#E9F6EF;--mint-2:#D6F0E3;
  --tx:#384640;--tx-2:#5B6A62;--tx-3:#7E8C84;
  --line:rgba(11,24,18,.10);--line-2:rgba(11,24,18,.18);
  --line-dk:rgba(255,255,255,.12);
  --amber:#E0921F;--red:#E25640;
  --dist:#1D9E75;--assu:#2E7DD1;--loc:#8A63E0;--flotte:#0E9CA0;--fin:#C68A2E;
  --r:18px;--r-s:12px;--max:1180px;--ease:cubic-bezier(.22,.7,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:'Sora',sans-serif;letter-spacing:-.03em;line-height:1.05;text-wrap:balance}
h1{font-size:clamp(42px,6.3vw,78px);font-weight:700;letter-spacing:-.04em}
h2{font-size:clamp(38px,5vw,62px);font-weight:700;letter-spacing:-.035em}
h3{font-size:clamp(20px,2.3vw,26px);font-weight:600;letter-spacing:-.02em;line-height:1.18}
h4{font-size:18px;font-weight:600}
.lede{font-size:clamp(17px,1.5vw,20px);color:var(--tx-2);max-width:60ch;line-height:1.62}
section{padding:clamp(28px,3vw,44px) 0;position:relative}
.sec-head{max-width:780px}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head p{margin-top:16px;font-size:17px;color:var(--tx-2)}

/* instrumentation / mono */
.mono{font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace}
.eyebrow{font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--green-d);display:inline-flex;align-items:center;gap:10px;margin-bottom:12px}
.eyebrow::before{content:"";width:18px;height:1.5px;background:currentColor;display:inline-block}
.on-dark .eyebrow,.engine .eyebrow{color:#7FE3B6}
.live{display:inline-flex;align-items:center;gap:8px;font-family:'DM Sans',sans-serif;font-weight:600;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--live-d)}
.live .d{width:8px;height:8px;border-radius:50%;background:var(--live);animation:pulse 1.7s infinite}
.engine .live,.on-dark .live{color:var(--live)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(46,230,143,.55)}70%{box-shadow:0 0 0 8px rgba(46,230,143,0)}100%{box-shadow:0 0 0 0 rgba(46,230,143,0)}}

/* animated underline on key words */
.u{position:relative;white-space:nowrap;color:var(--green-d)}
.engine .u,.on-dark .u{color:var(--live)}
.u::after{content:"";position:absolute;left:0;bottom:.14em;width:100%;height:4px;background:currentColor;border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .7s var(--ease) .2s}
.show .u::after,.u.go::after{transform:scaleX(1)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15.5px;padding:15px 26px;border-radius:100px;border:1.5px solid transparent;cursor:pointer;transition:.22s var(--ease)}
.btn svg{width:18px;height:18px;transition:transform .22s}
.btn:hover svg{transform:translateX(4px)}
.btn-p{background:var(--green-d);color:#fff}
.btn-p:hover{background:var(--green-dd);transform:translateY(-2px);box-shadow:0 14px 32px rgba(11,92,64,.28)}
.btn-live{background:var(--live);color:var(--ink)}
.btn-w{background:#fff;color:var(--green-dd)}
.btn-w:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(0,0,0,.2)}
.btn-live:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(46,230,143,.4)}
.btn-o{background:transparent;border-color:var(--line-2);color:var(--ink)}
.btn-o:hover{border-color:var(--green);color:var(--green-d)}
.engine .btn-o{border-color:var(--line-dk);color:#fff}
.engine .btn-o:hover{border-color:var(--live);color:var(--live)}

/* engine (dark) sections */
.engine{background:radial-gradient(130% 110% at 50% -10%,#0E6149,#06301F);color:#fff;overflow:hidden}
.engine h1,.engine h2,.engine h3,.engine h4{color:#fff}
.engine .lede{color:rgba(255,255,255,.74)}
.in{position:relative;z-index:2}
.cursor{display:inline-block;width:9px;height:1em;background:var(--green);margin-left:3px;vertical-align:-2px;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* header */
header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.logo{font-family:'Sora';font-weight:800;font-size:23px;letter-spacing:-.04em;color:var(--green-d);display:flex;align-items:center;gap:9px}
.logo .lt{font-family:'DM Sans',sans-serif;font-weight:600;font-size:10px;font-weight:500;letter-spacing:.16em;color:var(--tx-3);text-transform:uppercase;border-left:1px solid var(--line);padding-left:9px}
.nav-links{display:flex;align-items:center;gap:26px;font-size:15px;font-weight:500}
.nav-links a{color:var(--tx);transition:.15s}
.nav-links a:hover{color:var(--green-d)}.nav-links a.active{color:var(--green-d);font-weight:700}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px}

/* hero */
.hero{background:linear-gradient(180deg,var(--mint),#fff);padding:clamp(50px,6vw,86px) 0 clamp(78px,9vw,116px);position:relative}
.hero::before{content:"";pointer-events:none;position:absolute;inset:0;background-image:radial-gradient(rgba(21,122,89,.06) 1px,transparent 1px);background-size:30px 30px;mask-image:radial-gradient(80% 70% at 70% 30%,#000,transparent 75%);-webkit-mask-image:radial-gradient(80% 70% at 70% 30%,#000,transparent 75%)}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:54px;align-items:center;position:relative;z-index:2}
.htag{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--mint-2);color:var(--green-dd);padding:7px 15px;border-radius:100px;font-family:'DM Sans',sans-serif;font-weight:600;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:24px;box-shadow:0 4px 16px rgba(29,158,117,.08)}
.htag .d{width:8px;height:8px;border-radius:50%;background:var(--live);animation:pulse 1.7s infinite}
.hero h1{margin-bottom:22px}
.hero .lede{margin-bottom:32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.hstats{display:flex;gap:32px;flex-wrap:wrap}
.hstat .n{font-family:'Sora';font-weight:700;font-size:30px;letter-spacing:-.03em;color:var(--green-d)}
.hstat .l{font-size:13.5px;color:var(--tx-2)}

/* phone mockup */
.stage{position:relative;display:flex;justify-content:center}
.phone{position:relative;z-index:2;width:292px;max-width:84vw;background:#0B1812;border-radius:44px;padding:7px;box-shadow:0 40px 90px rgba(11,40,28,.28);cursor:pointer}
.screen{background:#fff;border-radius:32px;overflow:hidden}
.island{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:52px;height:15px;background:#0B1812;border-radius:10px;z-index:4}
.statusbar{display:flex;align-items:center;justify-content:space-between;padding:13px 22px 4px;font-size:12px;font-weight:600;color:var(--ink)}
.statusbar .b{width:19px;height:10px;border:1.5px solid var(--ink);border-radius:2.5px;position:relative;opacity:.85}
.statusbar .b::after{content:"";position:absolute;top:1.5px;bottom:1.5px;left:1.5px;right:5px;background:var(--ink);border-radius:1px}
.scr-body{padding:6px 20px 0}
.scr-img{height:172px;border-radius:16px;overflow:hidden;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;padding:6px}
.scr-img img{width:100%;height:100%;object-fit:contain;display:block}
.scr-img .dev{width:60px;height:108px;border-radius:14px;background:linear-gradient(160deg,#20201f,#000);box-shadow:0 12px 26px rgba(0,0,0,.32),inset 0 0 0 2px rgba(255,255,255,.07);position:relative}
.scr-img .dev::after{content:"";position:absolute;inset:5px;border-radius:10px;background:linear-gradient(155deg,#1c3a31,#0a201a)}
.scr-img .dev::before{content:"";position:absolute;top:9px;left:50%;transform:translateX(-50%);width:20px;height:5px;border-radius:3px;background:rgba(0,0,0,.55);z-index:2}
.scr-cat{font-size:11px;color:var(--tx-3);margin-top:15px;text-transform:uppercase;letter-spacing:.08em}
.scr-name{font-family:'Sora';font-weight:600;font-size:20px;margin-top:3px}
.scr-stars{color:#E8A91E;font-size:13px;margin-top:5px}
.scr-price{display:flex;align-items:baseline;gap:10px;margin-top:12px}
.scr-price .net{font-family:'Sora';font-weight:800;font-size:32px;letter-spacing:-.03em;color:var(--green-d)}
.scr-price .old{font-size:15px;color:var(--tx-3);text-decoration:line-through;text-decoration-color:var(--red)}
.scr-trade{margin-top:14px;background:var(--mint);border:1px solid var(--mint-2);border-radius:14px;padding:11px 12px;display:flex;align-items:center;gap:8px}
.scr-trade .ti{width:28px;height:28px;border-radius:9px;background:var(--green);display:flex;align-items:center;justify-content:center;flex:none}
.scr-trade .ti svg{width:17px;height:17px;color:#fff}
.scr-trade .tt{font-weight:600;font-size:11px;color:var(--green-dd);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.scr-trade .ts{font-size:11px;color:var(--tx-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.scr-trade .tp{font-family:'Sora';font-weight:700;font-size:16px;color:var(--green-d);flex:none;white-space:nowrap;font-variant-numeric:tabular-nums}
.scr-cta{margin:12px 20px 20px;background:var(--green-d);color:#fff;text-align:center;padding:13px;border-radius:13px;font-weight:600;font-size:14px}
.scr-live{position:absolute;top:18px;right:14px;z-index:3;background:#fff;border-radius:100px;padding:5px 12px;box-shadow:0 8px 22px rgba(11,40,28,.16);font-size:11px;font-weight:600;display:flex;align-items:center;gap:6px}
.scr-live .d{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 1.7s infinite}

/* logos */
.logos{padding:38px 0;border-bottom:1px solid var(--line)}
.logos .lbl{text-align:center;font-family:'DM Sans',sans-serif;font-weight:600;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--tx-3);margin-bottom:20px}
.logos .row{display:flex;justify-content:center;align-items:center;gap:clamp(24px,5vw,60px);flex-wrap:wrap}
.logos .row span{font-family:'Sora';font-weight:700;font-size:20px;color:#9AA8A0;letter-spacing:-.02em}

/* stat cards */
.statcards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.statcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;position:relative;overflow:hidden}
.statcard::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:var(--ac,var(--green))}
.statcard .ic{width:44px;height:44px;border-radius:12px;background:var(--acl);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.statcard .ic svg{width:21px;height:21px;color:var(--ac,var(--green-d))}
.statcard .big{font-family:'Sora';font-weight:700;font-size:44px;letter-spacing:-.04em}
.statcard p{font-size:14.5px;color:var(--tx-2);margin-top:5px}
.statcard .src{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--tx-3);margin-top:13px}
.punch{text-align:center;max-width:780px;margin:52px auto 0;font-family:'Sora';font-weight:600;font-size:clamp(20px,2.4vw,28px);letter-spacing:-.025em;line-height:1.3}.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}.quote{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 28px 130px;display:flex;flex-direction:column;position:relative}.quote .qm{font-family:'Sora';font-weight:800;font-size:52px;line-height:.5;color:var(--mint-2);height:26px}.quote blockquote{font-size:15px;color:var(--tx);line-height:1.62;margin:4px 0 22px}.quote figcaption{position:absolute;bottom:24px;left:28px;right:28px;display:flex;flex-direction:column;border-top:1px solid var(--line);padding-top:15px;min-height:110px}.quote figcaption .qbadge{align-self:flex-start;margin-bottom:6px}.quote .qa{font-family:'Sora';font-weight:600;font-size:14px;color:var(--ink)}.quote .qr{font-size:12.5px;color:var(--tx-2);margin-top:2px}.qbadge{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border-radius:20px;margin-bottom:8px;font-family:'DM Sans',sans-serif}.qbadge--dist{background:#E3F5EC;color:#157A59}.qbadge--fin{background:#FDF0DC;color:#A06B1A}.qbadge--loc{background:#EDE8FC;color:#6540C0}.qbadge--ass{background:#DCE9F8;color:#1F5FA5}.qbadge--flo{background:#D9F2F3;color:#0A7A80}

/* big price (engine) */
.bigprice{text-align:center}
.bigprice .pre,.bigprice .post{font-size:clamp(16px,1.8vw,21px);color:var(--tx-2);max-width:36ch;margin:0 auto}
.bigprice .post b{color:var(--green-d);font-weight:700}
.bp-num{font-family:'Sora';font-weight:800;font-size:clamp(96px,19vw,230px);line-height:.92;letter-spacing:-.05em;margin:6px 0;color:var(--green-d)}
.bp-num .cur{color:inherit}
.bp-meta{display:inline-flex;gap:26px;margin-top:30px;font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;font-size:13px;color:rgba(255,255,255,.6);flex-wrap:wrap;justify-content:center}
.bp-meta b{color:var(--live)}

/* results */
.results{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.resc{text-align:center;padding:40px 24px;border-radius:var(--r);background:var(--paper-2);border:1px solid var(--line)}
.resc .n{font-family:'Sora';font-weight:800;font-size:clamp(54px,7vw,80px);letter-spacing:-.05em;color:var(--green-d);line-height:1}
.resc .l{font-size:14.5px;color:var(--tx-2);margin-top:8px}
.resc .bar{height:6px;border-radius:6px;background:var(--mint);margin-top:18px;overflow:hidden}
.resc .bar i{display:block;height:100%;width:0;background:var(--green);border-radius:6px;transition:width 1.2s var(--ease)}
.show .resc .bar i{width:var(--w,70%)}

/* flow */
.flow{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:22px;margin-top:58px;position:relative}
.flow-track{position:absolute;top:29px;left:10%;right:10%;height:2px;background:var(--mint-2);border-radius:2px;z-index:0}
.flow-dot{position:absolute;top:-6px;left:0;width:14px;height:14px;border-radius:50%;background:var(--green);box-shadow:0 0 0 5px rgba(29,158,117,.20);opacity:0;transform:translateX(-50%)}
.fstep{position:relative;z-index:1;text-align:center}
.fstep .ring{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;background:#fff;border:2px solid var(--mint-2);color:var(--green-d);transition:.35s var(--ease)}
.fstep .ring svg{width:25px;height:25px}
.fstep.lit .ring{border-color:var(--green);background:var(--mint);box-shadow:0 0 0 5px rgba(29,158,117,.14)}
.fstep h4{font-size:17px}
.fstep p{font-size:14px;color:var(--tx-2);margin-top:6px}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.split.rev .col-txt{order:2}
.duo{display:flex;flex-direction:column;gap:18px}
.duocard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 26px;position:relative;overflow:hidden}
.duocard::before{content:"";position:absolute;top:0;left:0;width:5px;height:100%;background:var(--ac,var(--green))}
.duocard .tag{display:inline-block;font-family:'DM Sans',sans-serif;font-weight:700;font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;color:#fff;background:var(--ac,var(--green-d));padding:5px 12px;border-radius:100px}
.duocard h3{margin:14px 0 0;font-size:22px}
.duocard ul{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:9px}
.duocard li{font-size:14.5px;color:var(--tx);display:flex;gap:10px;align-items:flex-start}
.duocard li svg{width:17px;height:17px;color:var(--ac,var(--green));flex:none;margin-top:3px}

/* code */
.codecard{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:0 24px 54px rgba(11,40,28,.10)}
.codecard .bar{display:flex;align-items:center;gap:7px;padding:13px 17px;border-bottom:1px solid var(--line)}
.codecard .bar i{width:11px;height:11px;border-radius:50%}
.codecard .bar .t{font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;font-size:12px;color:var(--tx-3);margin-left:8px}
.codecard pre{font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;font-size:13px;line-height:1.75;padding:20px;color:#3A4640;overflow-x:auto}
.codecard .k{color:var(--green-d)}.codecard .s{color:#2E7DD1}.codecard .n{color:#B5710F}.codecard .c{color:#9AA8A0}
.techlist{display:flex;flex-direction:column;gap:16px;margin-top:6px}
.techrow{display:flex;gap:15px;align-items:flex-start}
.techrow .ic{width:42px;height:42px;border-radius:12px;background:var(--mint);display:flex;align-items:center;justify-content:center;flex:none}
.techrow .ic svg{width:20px;height:20px;color:var(--green-d)}
.techrow b{font-size:15.5px;font-family:'Sora';font-weight:600}
.techrow p{font-size:13.5px;color:var(--tx-2);margin-top:1px}

/* live bid panel (engine) */
.bidpanel{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:0 24px 54px rgba(11,40,28,.10)}
.bidpanel .ph{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line);font-size:13px;color:var(--tx-2);font-weight:500}
.bidrow{display:flex;align-items:center;gap:14px;padding:15px 20px;border-bottom:1px solid var(--line)}
.bidrow .av{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:'Sora';font-weight:700;font-size:13px;color:#fff;flex:none}
.bidrow .nm{font-size:14px;color:var(--ink);font-weight:500}
.bidrow .lc{font-size:12px;color:var(--tx-3)}
.bidrow .amt{margin-left:auto;font-family:'Sora';font-weight:700;font-size:19px;color:var(--tx-2)}
.bidrow.win{background:rgba(29,158,117,.07)}
.bidrow.win .amt{color:var(--green-d)}
.bidrow .tag{font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:600;color:var(--green-d);border:1px solid var(--green);border-radius:100px;padding:3px 9px;margin-left:10px}
.bidrow.win .tag{opacity:1}
.bidpanel .pf{padding:14px 20px;font-size:12.5px;color:var(--tx-2);display:flex;justify-content:space-between}
.bidpanel .pf b{color:var(--green-d)}

/* offers */
.offers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.entry{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;position:relative;overflow:hidden;transition:.25s var(--ease)}
.entry::before{content:"";position:absolute;top:0;left:0;width:100%;height:5px;background:var(--ac,var(--green))}
.entry:hover{transform:translateY(-6px);box-shadow:0 28px 56px rgba(11,40,28,.13);border-color:var(--line-2)}
.entry .pill{align-self:flex-start;display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:100px;font-size:12.5px;font-weight:600;background:var(--acl);color:var(--acd)}
.entry .pill .dot{width:8px;height:8px;border-radius:50%;background:var(--ac)}
.entry h3{margin:16px 0 9px}
.entry p{font-size:14px;color:var(--tx-2);flex:1;margin-bottom:18px}
.entry .go{display:inline-flex;align-items:center;gap:8px;font-size:14.5px;font-weight:600;color:var(--acd)}
.entry .go svg{width:17px;height:17px;transition:transform .2s}
.entry:hover .go svg{transform:translateX(5px)}

/* big stats */
.bigstats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px}
.bigstat{text-align:center}
.bigstat .n{font-family:'Sora';font-weight:800;font-size:clamp(38px,5vw,58px);letter-spacing:-.04em;color:var(--green-d)}
.bigstat .l{font-size:13.5px;color:var(--tx-2);margin-top:4px}

/* timeline */
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:54px;position:relative}
.tl-track{position:absolute;top:21px;left:12.5%;right:12.5%;height:2px;background:var(--mint-2);border-radius:2px;z-index:0}
.tl-fill{position:absolute;top:21px;left:12.5%;width:0;height:2px;background:var(--green);border-radius:2px;z-index:1}
.tl-dot{position:absolute;top:15px;left:12.5%;width:14px;height:14px;border-radius:50%;background:var(--green);box-shadow:0 0 0 5px rgba(29,158,117,.18);z-index:2;opacity:0;transform:translateX(-50%)}
.tlstep{position:relative;z-index:3;text-align:center}
.tlstep .dot{width:42px;height:42px;border-radius:50%;background:#fff;border:2px solid var(--mint-2);color:var(--tx-3);font-family:'DM Sans',sans-serif;font-weight:600;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;transition:.35s var(--ease)}
.tlstep.lit .dot{border-color:var(--green);color:var(--green-d);background:var(--mint);box-shadow:0 0 0 5px rgba(29,158,117,.12)}
.tlstep h4{font-size:17px}
.tlstep p{font-size:13.5px;color:var(--tx-2);margin-top:6px}

/* faq */
.faq{max-width:820px;margin:48px auto 0}
.faqitem{border-bottom:1px solid var(--line)}
.faqq{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:23px 4px;cursor:pointer;font-family:'Sora';font-weight:600;font-size:18px}
.faqq .pm{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--line-2);display:flex;align-items:center;justify-content:center;flex:none;transition:.2s;font-size:18px;color:var(--green-d)}
.faqitem.open .pm{background:var(--green-d);color:#fff;border-color:var(--green-d);transform:rotate(45deg)}
.faqa{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faqa p{padding:0 4px 23px;font-size:15.5px;color:var(--tx-2)}

/* cta */
.cta-card{display:grid;grid-template-columns:1.1fr .9fr;gap:42px;align-items:center}
.cta-mini{background:#fff;color:var(--ink);border-radius:var(--r);padding:22px;box-shadow:0 24px 54px rgba(11,40,28,.14);max-width:330px;margin-left:auto;border:1px solid var(--line)}
.cta-mini .h{font-family:'DM Sans';font-weight:600;font-size:13px;color:var(--tx-2);margin-bottom:14px}
.cta-mini .li{display:flex;align-items:center;gap:13px;padding:9px 0}
.cta-mini .av{width:44px;height:44px;border-radius:11px;background:linear-gradient(145deg,#EEF2F0,#D7E2DC);flex:none}
.cta-mini .pr{margin-left:auto;font-family:'Sora';font-weight:700;color:var(--green-d);font-size:18px}
.cta-mini .ck{width:22px;height:22px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center}
.cta-mini .ck svg{width:13px;height:13px;color:#fff}

/* footer */
footer{background:var(--ink);color:rgba(255,255,255,.6);padding:62px 0 34px}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-bottom:38px}
footer .logo{color:#fff}
footer .fcol h5{color:#fff;font-family:'Sora';font-size:14px;margin-bottom:13px;font-weight:600}
footer .fcol a{display:block;font-size:14px;padding:5px 0;color:rgba(255,255,255,.6)}
footer .fcol a:hover{color:var(--live)}
.foot-support{border-top:1px solid var(--line-dk);padding-top:26px;margin-bottom:30px;display:flex;align-items:center;gap:22px;flex-wrap:wrap}.foot-support .fs-label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.5);font-weight:600}.foot-support .fs-logos{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.foot-support .fs-badge{display:inline-flex;align-items:center;justify-content:center;background:#fff;color:var(--ink);border-radius:10px;padding:10px 18px;font-family:'Sora',sans-serif;font-weight:700;font-size:14px;line-height:1;box-shadow:0 4px 14px rgba(0,0,0,.18)}@media(max-width:560px){.foot-support{gap:14px}.foot-support .fs-badge{font-size:13px;padding:9px 14px}}.foot-bottom{border-top:1px solid var(--line-dk);padding-top:22px;font-size:13px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

/* reveal */
.rv{opacity:0;transform:translateY(26px);transition:.7s var(--ease)}
.rv.show{opacity:1;transform:none}

@media(max-width:900px){
  .hero-grid,.split,.cta-card{grid-template-columns:1fr;gap:46px}
  .split.rev .col-txt{order:0}
  .statcards,.offers,.quotes{grid-template-columns:1fr}
  .results,.flow,.bigstats,.timeline{grid-template-columns:1fr 1fr}
  .flow-track,.flow-dot,.tl-track,.tl-fill,.tl-dot{display:none}
  .nav-links{position:absolute;top:70px;left:0;right:0;display:none;flex-direction:column;align-items:stretch;gap:0;background:#fff;padding:6px 28px 16px;border-bottom:1px solid var(--line);box-shadow:0 16px 30px rgba(11,40,28,.10)}.nav-links a{padding:14px 2px;border-bottom:1px solid var(--line)}.nav-links a:last-child{border-bottom:none}.burger{display:flex}
  .cta-mini{margin:0 auto}
}
@media(max-width:560px){.results,.flow,.bigstats,.timeline{grid-template-columns:1fr}}
.catrow{display:grid;grid-template-columns:repeat(7,1fr);gap:14px;margin-top:50px}
.catcard{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:3/4;box-shadow:0 14px 30px rgba(11,40,28,.10)}
.catcard img{width:100%;height:100%;object-fit:cover;display:block}
.catcard .ck{position:absolute;top:10px;right:10px;width:26px;height:26px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center}
.catcard .ck svg{width:14px;height:14px;color:#fff}
.catcard .lbl{position:absolute;left:10px;bottom:10px;background:rgba(255,255,255,.92);padding:5px 11px;border-radius:8px;font-size:12.5px;font-weight:600;color:var(--ink)}
@media(max-width:900px){.catrow{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.catrow{grid-template-columns:repeat(2,1fr)}}
.scr-price .net,#est-net,#bp-num,.hstat .n,.resc .n,.bigstat .n,.statcard .big,.bidrow .amt{font-variant-numeric:tabular-nums}
.scr-price{min-height:42px}
.logos .row img{max-height:46px;max-width:170px;width:auto;object-fit:contain;opacity:.9;transition:.25s ease}.logos .row img:hover{opacity:1;transform:translateY(-2px)}

/* ===== FIX : chips flottants hero distribution ===== */
.stage{width:fit-content;max-width:100%;margin-inline:auto}
.floaty{position:absolute;z-index:6;display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:15px;padding:11px 15px;box-shadow:0 18px 42px rgba(11,40,28,.16);animation:floaty 5s var(--ease) infinite}
.floaty .fic{width:38px;height:38px;border-radius:11px;background:var(--mint);display:flex;align-items:center;justify-content:center;flex:none}
.floaty .fic svg{width:20px;height:20px;color:var(--green-d)}
.floaty .flab{display:block;font-size:11.5px;color:var(--tx-2);line-height:1.25}
.floaty .fval{display:block;font-family:'Sora',sans-serif;font-weight:700;font-size:19px;color:var(--green-d);line-height:1.15;letter-spacing:-.02em}
.floaty.f-top{top:8%;left:-92px}
.floaty.f-bot{bottom:5%;right:-96px;animation-delay:1.8s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media(max-width:560px){.floaty{padding:8px 11px;gap:8px}.floaty .fic{width:32px;height:32px}.floaty .fval{font-size:16px}.floaty.f-top{left:-8px;top:8%}.floaty.f-bot{right:-8px;bottom:10%}}
@media(prefers-reduced-motion:reduce){.floaty{animation:none}}

/* ===== FIX : tableau comparaison des leviers (distribution) ===== */
.cmp-wrap{margin-top:42px;overflow-x:auto;border:1px solid var(--line);border-radius:var(--r);background:#fff;box-shadow:0 18px 44px rgba(11,40,28,.07);-webkit-overflow-scrolling:touch}
.cmp{width:100%;border-collapse:collapse;min-width:680px}
.cmp th,.cmp td{text-align:left;padding:16px 22px;font-size:14.5px;border-bottom:1px solid var(--line);white-space:nowrap}
.cmp thead th{font-family:'Sora',sans-serif;font-weight:600;font-size:12.5px;color:var(--tx-2);text-transform:uppercase;letter-spacing:.05em;background:var(--paper-2)}
.cmp tbody td:first-child,.cmp thead th:first-child{font-family:'Sora',sans-serif;font-weight:600;color:var(--ink);white-space:normal}
.cmp tbody tr:last-child td{border-bottom:none}
.cmp td.yes{color:var(--green-d);font-weight:600}
.cmp td.no{color:var(--tx-3)}
.cmp td.mid{color:var(--amber);font-weight:600}
.cmp td.bad{color:var(--red);font-weight:600}
.cmp tr.win{background:rgba(29,158,117,.06)}
.cmp tr.win td{color:var(--ink);font-weight:600}
.cmp tr.win td:first-child{color:var(--green-dd)}
.cmp .gain{display:inline-flex;align-items:center;gap:6px;background:var(--mint);color:var(--green-dd);font-weight:700;padding:6px 13px;border-radius:100px;font-size:13.5px}
.cmp-note{text-align:center;font-size:12.5px;color:var(--tx-3);margin-top:16px}

/* ===== carte "Estimation de parc" dans les hero (flotte + verticales) : taille mesurée ===== */
.hero .mockcard{max-width:440px;width:100%;margin-left:auto;border-radius:20px;box-shadow:0 34px 74px rgba(11,40,28,.14)}
.hero .mockcard .mh{padding:17px 22px;font-size:16px}
.hero .mockcard .mh .tag{font-size:11px;padding:5px 11px;background:var(--mint);color:var(--green-d)}
.hero .mockcard .mb{padding:6px 22px 20px}
.hero .mockcard .mrow{padding:13px 0;font-size:14px}
.hero .mockcard .mbig{padding-top:16px;align-items:center}
.hero .mockcard .mbig .k{font-size:13px}
.hero .mockcard .mbig .v{font-size:clamp(28px,3vw,34px)}
@media(max-width:900px){.hero .mockcard{max-width:430px;margin-inline:auto}}

/* ===== FIX : éviter que les titres hero non-sécables fassent déborder la grille ===== */
.hero-grid>*{min-width:0}
.hero h1 .u{white-space:normal}

/* ===== FIX : badge reprise (−471 €) qui ne déborde plus du téléphone ===== */
.scr-trade>div{min-width:0}
.scr-trade .tp{font-size:15px}

/* ===== punch distribution : 2e phrase en vert ===== */
.punch-hi{color:var(--green-d);font-weight:700}

/* ===== references : mur de logos par secteur (tuiles) ===== */
.logowall{margin-top:48px;display:flex;flex-direction:column;gap:34px}
.lw-h{font-family:'Sora',sans-serif;font-weight:700;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ac,var(--green-d));margin-bottom:16px;display:flex;align-items:center;gap:14px;white-space:nowrap}
.lw-h::after{content:"";flex:1;height:1px;background:var(--line)}
.lw-grid{display:flex;flex-wrap:wrap;gap:14px}
.lw-grid img{height:66px;width:auto;max-width:170px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:14px;padding:15px 24px;transition:.2s ease}
.lw-grid img:hover{border-color:var(--ac,var(--green));box-shadow:0 10px 24px rgba(11,40,28,.09);transform:translateY(-2px)}
@media(max-width:560px){.lw-grid img{height:56px;padding:12px 16px;max-width:130px}}

/* ===== témoignage vedette (pages verticales) ===== */
.testimonial{max-width:900px;margin:0 auto;text-align:center}
.testimonial .tq{font-family:'Sora',sans-serif;font-weight:800;font-size:72px;line-height:.4;height:34px;color:var(--green-d);opacity:.22}
.testimonial blockquote{font-family:'DM Sans',sans-serif;font-weight:400;font-size:clamp(17px,1.8vw,21px);line-height:1.7;color:var(--tx);margin:14px 0 30px;max-width:700px;margin-left:auto;margin-right:auto}
.testimonial figcaption{display:inline-flex;flex-direction:column;gap:3px}
.testimonial .ta{font-family:'Sora',sans-serif;font-weight:600;font-size:15.5px;color:var(--green-d)}
.testimonial .tr{font-size:13.5px;color:var(--tx-2)}


/* ===== RESPONSIVE FIXES ===== */

/* Header mobile : bouton démo réduit + burger toujours visible */
@media(max-width:900px){
  .nav .btn{font-size:13px;padding:10px 16px}
  .nav .btn svg{width:14px;height:14px}
  .burger{display:flex !important}
}

@media(max-width:560px){
  .nav .btn{font-size:12px;padding:9px 14px;gap:6px}
  .nav .btn svg{display:none}
  
  /* Hero : réduire padding */
  .hero{padding:clamp(32px,5vw,60px) 0 clamp(50px,7vw,80px)}
  .hero h1{font-size:clamp(32px,8vw,42px)}
  .hero .lede{font-size:15px}
  .hero-cta{flex-direction:column;gap:10px}
  .hero-cta .btn{width:100%;justify-content:center;font-size:14px;padding:14px 20px}
  
  /* Stats hero */
  .hstats{gap:18px}
  .hstat .n{font-size:22px}
  .hstat .l{font-size:12px}
  
  /* Section padding mobile */
  section{padding:clamp(20px,3vw,36px) 0}
  h2{font-size:clamp(28px,6vw,42px)}
  
  /* Offers cards stack */
  .offers{grid-template-columns:1fr;gap:16px}
  
  /* Quotes stack */
  .quotes{grid-template-columns:1fr;gap:16px}
  
  /* Split sections */
  .split{gap:28px}
  
  /* FAQ */
  .faqq{font-size:15px;padding:18px 4px}
  
  /* Flow steps */
  .flow{gap:16px}
  .fstep .ring{width:46px;height:46px;margin-bottom:12px}
  .fstep .ring svg{width:20px;height:20px}
  .fstep h4{font-size:14px}
  .fstep p{font-size:12.5px}
  
  /* Timeline steps */
  .timeline{gap:14px}
  .tlstep .dot{width:34px;height:34px;font-size:13px}
  .tlstep h4{font-size:14px}
  .tlstep p{font-size:12.5px}
  
  /* Footer */
  .foot-top{flex-direction:column;gap:28px}
  footer .fcol{width:100%}
  .foot-bottom{flex-direction:column;text-align:center;gap:8px}
  
  /* Testimonial */
  .testimonial blockquote{font-size:15px}
  
  /* Big stats */
  .bigstats{grid-template-columns:repeat(2,1fr);gap:16px}
  .bigstat .n{font-size:clamp(30px,6vw,44px)}
  
  /* Stat cards */
  .statcards{gap:14px}
  .statcard{padding:24px 20px}
  .statcard .big{font-size:34px}
  
  /* CTA card */
  .cta-card{gap:28px}
  
  /* Phone mockup */
  .phone{width:240px;border-radius:36px;padding:5px}
  .screen{border-radius:28px}
  
  /* Legal pages */
  .legal{font-size:14.5px}
  .legal h3{font-size:18px;margin-top:28px;margin-bottom:10px}
}

/* Extra small - 380px and below */
@media(max-width:380px){
  .wrap{padding:0 16px}
  .nav{height:58px}
  .logo{font-size:20px}
  .logo .lt{display:none}
  .nav .btn{font-size:11px;padding:8px 12px}
  .hero h1{font-size:28px}
  h2{font-size:26px}
}
