
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#faf8f3;--bg2:#f2efe8;--bg3:#e8e3d8;
  --ink:#0c0c0e;--ink2:#1a1a1e;--ink3:#2d2d32;
  --mid:#5a5a62;--faint:#9a9aa4;--bdr:#d6d0c4;--bdr2:#bfb8a8;
  --g:#00c47a;--gd:#007a4d;--gl:#d0f5e5;--gm:rgba(0,196,122,.1);
  --navy:#0d1526;--navy2:#131f33;--navy3:#1a2840;
  --charcoal:#18181c;--charcoal2:#222228;
  --accent:#00c47a;
  --f:'DM Sans',system-ui,sans-serif;--fm:'DM Mono',monospace;
  --ease:cubic-bezier(.16,1,.3,1);
}
html{font-size:16px;scroll-behavior:smooth;cursor:none}
body{font-family:var(--f);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;cursor:none}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:var(--f)}
.page{display:none}.page.active{display:block}
.W{max-width:1200px;margin:0 auto;padding:0 52px}
.Wsm{max-width:740px;margin:0 auto;padding:0 52px}

/* ── CURSOR ── */
#cur{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;will-change:transform}
#cd{width:7px;height:7px;background:var(--g);border-radius:50%;position:absolute;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s}
#cr{width:32px;height:32px;border:1.5px solid var(--ink3);border-radius:50%;position:absolute;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),border-color .3s,background .3s,opacity .3s}
body.ch #cr{width:50px;height:50px;border-color:var(--g);background:rgba(0,196,122,.08)}
body.cl #cd{width:44px;height:44px;background:var(--g);opacity:.9}
body.cl #cr{opacity:0}
body.ct #cr{width:3px;height:44px;border-radius:2px;border-color:var(--ink2)}

/* ── HEADER ── */
#hdr{position:fixed;top:0;left:0;right:0;z-index:400;transition:border-color .3s}
#hdr-bg{position:absolute;inset:0;background:var(--bg);opacity:0;transition:opacity .35s}
#hdr.stuck #hdr-bg{opacity:.94;backdrop-filter:blur(16px)}
#hdr.stuck{border-bottom:1px solid var(--bdr)}
.hdr-in{display:flex;align-items:center;height:64px;padding:0 52px;max-width:1400px;margin:0 auto;position:relative;z-index:1}
.logo{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#fff;cursor:none;flex:1;user-select:none;transition:color .25s}
#hdr.stuck .logo{color:var(--ink)}
.ld{width:6px;height:6px;border-radius:50%;background:var(--g);animation:ldot 2.6s ease-in-out infinite}
@keyframes ldot{0%,100%{transform:scale(1)}50%{transform:scale(.45)}}
.hdr-nav{display:flex;gap:0}
.hn{padding:7px 13px;font-size:13px;font-weight:400;color:rgba(255,255,255,.55);cursor:none;transition:color .25s,background .25s}
#hdr.stuck .hn{color:var(--mid)}
.hn:hover,#hdr:not(.stuck) .hn:hover{color:#fff !important}
#hdr.stuck .hn:hover,#hdr.stuck .hn.on{color:var(--ink)}
.hn:hover,.hn.on{color:var(--ink)}
.hdr-sep{width:1px;height:14px;background:rgba(255,255,255,.2);align-self:center;margin:0 6px;transition:background .25s}
#hdr.stuck .hdr-sep{background:var(--bdr)}
.hdr-cta{margin-left:14px;padding:9px 22px;background:var(--g);color:#000;border-radius:999px;font-size:13px;font-weight:600;cursor:none;transition:background .25s,color .25s;white-space:nowrap}
#hdr.stuck .hdr-cta{background:var(--ink);color:var(--bg)}
.hdr-cta:hover{background:#00da88}
#hdr.stuck .hdr-cta:hover{background:var(--navy);color:var(--bg)}
.burger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:none}
.bl{width:20px;height:1.5px;background:#fff;transition:background .25s}
#hdr.stuck .bl{background:var(--ink)}
.mnav{position:fixed;inset:0;background:var(--bg);z-index:900;display:none;flex-direction:column;padding:92px 52px 44px}
.mnav.open{display:flex}
.mnav-x{position:absolute;top:22px;right:44px;background:none;border:none;font-size:22px;color:var(--mid);cursor:none}
.mnl{padding:15px 0;font-size:26px;font-weight:300;color:var(--ink);border-bottom:1px solid var(--bdr);cursor:none;transition:color .18s,padding-left .22s var(--ease)}
.mnl:hover{color:var(--gd);padding-left:10px}
.mnav-cta{margin-top:28px;padding:14px;background:var(--ink);color:var(--bg);font-size:14px;font-weight:500;border-radius:999px;text-align:center;cursor:none;border:none;width:100%}

/* ── BUTTONS ── */
.btn-dk{display:inline-flex;align-items:center;gap:9px;padding:12px 26px;background:var(--ink);color:var(--bg);border-radius:999px;font-size:14px;font-weight:500;cursor:none;border:none;transition:background .18s,gap .22s}
.btn-dk:hover{background:var(--navy);gap:13px}
.btn-bd{display:inline-flex;align-items:center;gap:8px;padding:11px 24px;border:1.5px solid var(--bdr2);color:var(--ink);border-radius:999px;font-size:14px;font-weight:400;cursor:none;transition:.18s,gap .22s}
.btn-bd:hover{border-color:var(--ink);gap:12px}
.btn-g{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;background:var(--g);color:#000;border-radius:999px;font-size:14px;font-weight:600;cursor:none;border:none;transition:.18s,gap .22s}
.btn-g:hover{background:#00da88;gap:12px}
.btn-inv{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;background:var(--bg);color:var(--ink);border-radius:999px;font-size:14px;font-weight:500;cursor:none;border:none;transition:.18s,gap .22s}
.btn-inv:hover{background:var(--gl);gap:12px}
.btn-inv-bd{display:inline-flex;align-items:center;gap:8px;padding:11px 24px;border:1.5px solid rgba(255,255,255,.2);color:rgba(255,255,255,.65);border-radius:999px;font-size:14px;font-weight:400;cursor:none;transition:.18s,gap .22s}
.btn-inv-bd:hover{border-color:rgba(255,255,255,.5);color:#fff;gap:12px}

/* ── SECTION SYSTEM ── */
.sec{padding:112px 0}
.sec-sm{padding:72px 0}
.bg-cream{background:var(--bg)}
.bg-off{background:var(--bg2)}
.bg-stone{background:var(--bg3)}
.bg-navy{background:var(--navy)}
.bg-charcoal{background:var(--charcoal)}
.bg-green{background:#003d28}
.lbl{font-family:var(--fm);font-size:10.5px;letter-spacing:.17em;text-transform:uppercase;color:var(--mid);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.lbl::before{content:'';width:16px;height:1px;background:var(--bdr2)}
.lbl-inv{font-family:var(--fm);font-size:10.5px;letter-spacing:.17em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.lbl-inv::before{content:'';width:16px;height:1px;background:rgba(255,255,255,.2)}
.lbl-g{font-family:var(--fm);font-size:10.5px;letter-spacing:.17em;text-transform:uppercase;color:var(--g);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.lbl-g::before{content:'';width:16px;height:1px;background:rgba(0,196,122,.4)}
.h2{font-size:clamp(28px,3.8vw,48px);font-weight:300;line-height:1.1;letter-spacing:-.022em;color:var(--ink);margin-bottom:20px}
.h2 strong{font-weight:700}
.h2 em{font-style:italic;color:var(--mid);font-weight:300}
.h2-inv{font-size:clamp(28px,3.8vw,48px);font-weight:300;line-height:1.1;letter-spacing:-.022em;color:#fff;margin-bottom:20px}
.h2-inv strong{font-weight:700}
.h2-inv em{color:rgba(255,255,255,.45);font-style:italic}
.h2-g{font-size:clamp(28px,3.8vw,48px);font-weight:300;line-height:1.1;letter-spacing:-.022em;color:#fff;margin-bottom:20px}
.h2-g strong{font-weight:700;color:var(--g)}
.bod{font-size:16px;color:var(--mid);line-height:1.75;max-width:500px}
.bod-inv{font-size:16px;color:rgba(255,255,255,.5);line-height:1.75;max-width:500px}
hr.dv{border:none;border-top:1px solid var(--bdr)}
hr.dv-inv{border:none;border-top:1px solid rgba(255,255,255,.08)}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(22px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.rv.in{opacity:1;transform:none}
.rvx{opacity:0;transform:translateX(-18px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rvx.in{opacity:1;transform:none}
.stg>*{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.stg.in>*{opacity:1;transform:none}
.stg.in>*:nth-child(1){transition-delay:.04s}.stg.in>*:nth-child(2){transition-delay:.09s}
.stg.in>*:nth-child(3){transition-delay:.14s}.stg.in>*:nth-child(4){transition-delay:.19s}
.stg.in>*:nth-child(5){transition-delay:.24s}.stg.in>*:nth-child(6){transition-delay:.29s}

/* ══════════════ HERO ══════════════ */
.hero{min-height:100vh;display:flex;flex-direction:column;background:var(--navy);position:relative;overflow:hidden}
.hero-grain{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 300 300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.78' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");background-size:220px;pointer-events:none}
.hero-glow{position:absolute;top:-40%;right:-10%;width:700px;height:700px;background:radial-gradient(ellipse,rgba(0,100,60,.35) 0%,transparent 65%);pointer-events:none}
.hero-body{flex:1;display:flex;flex-direction:column;justify-content:flex-end;padding:120px 52px 0;max-width:1200px;margin:0 auto;width:100%;position:relative;z-index:1}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--fm);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--g);margin-bottom:40px}
.he-dot{width:5px;height:5px;border-radius:50%;background:var(--g);animation:ldot 2s ease-in-out infinite}
.hero-h1{font-size:clamp(44px,6.5vw,84px);font-weight:700;line-height:.96;letter-spacing:-.04em;color:#fff;margin-bottom:0;max-width:900px}
.hero-h1 em{display:block;font-weight:300;font-style:italic;color:var(--g);margin-top:4px}
/* split bar */
.hero-bar{display:grid;grid-template-columns:1fr 1px 1fr;border-top:1px solid rgba(255,255,255,.1);margin-top:60px;position:relative;z-index:1}
.hero-sep{background:rgba(255,255,255,.1)}
.hcol{padding:36px 52px 52px}
.hcol:first-child{padding-left:0}
.hcol:last-child{padding-right:0}
.hcol-lbl{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:14px}
.hcol-text{font-size:16px;color:rgba(255,255,255,.58);line-height:1.72;margin-bottom:26px;max-width:440px}
.hbtns{display:flex;gap:10px;flex-wrap:wrap}
.hero-badges{display:flex;flex-direction:column;gap:10px}
.hbadge{display:flex;align-items:center;gap:9px;font-family:var(--fm);font-size:11px;color:rgba(255,255,255,.38);letter-spacing:.02em}
.hbadge-ok{width:16px;height:16px;border-radius:4px;background:rgba(0,196,122,.15);border:1px solid rgba(0,196,122,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
/* ticker */
.ticker{background:rgba(255,255,255,.04);border-top:1px solid rgba(255,255,255,.07);overflow:hidden;position:relative;z-index:1}
.ticker-inner{display:flex;animation:tick 28s linear infinite;width:max-content}
.ticker-inner { /* hover handled by JS */ }
.ti{display:flex;align-items:center;gap:10px;padding:12px 36px;white-space:nowrap;font-family:var(--fm);font-size:10px;color:rgba(255,255,255,.28);letter-spacing:.1em;text-transform:uppercase}
.ti strong{color:var(--g);font-weight:400}
.tdiv{width:1px;height:12px;background:rgba(255,255,255,.08)}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══════════════ STATEMENT (big editorial) ══════════════ */
.statement{background:var(--charcoal);padding:80px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.statement-inner{display:grid;grid-template-columns:1fr 2fr;gap:64px;align-items:center}
.st-label{font-family:var(--fm);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.3)}
.st-quote{font-size:clamp(20px,2.8vw,32px);font-weight:300;color:rgba(255,255,255,.75);line-height:1.45;letter-spacing:-.015em}
.st-quote strong{color:#fff;font-weight:600}
.st-quote .g{color:var(--g)}

/* ══════════════ POSITION (problema central) ══════════════ */
.pos-2col{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr);border-radius:20px;overflow:hidden;margin-top:52px}
.pos-half{background:var(--bg);padding:48px 44px}
.pos-half.dark{background:var(--charcoal);padding:48px 44px}
.pos-half.navy{background:var(--navy);padding:48px 44px}
.problem-label{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:#e55;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.problem-label::before{content:'';width:14px;height:1px;background:#e55}
.solution-label{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--g);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.solution-label::before{content:'';width:14px;height:1px;background:var(--g)}
.result-label{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:#6ab0ff;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.result-label::before{content:'';width:14px;height:1px;background:#6ab0ff}
.pos-h{font-size:clamp(20px,2.4vw,28px);font-weight:400;line-height:1.25;letter-spacing:-.015em;color:var(--ink);margin-bottom:16px}
.pos-h.inv{color:#fff}
.pos-body{font-size:14px;color:var(--mid);line-height:1.72}
.pos-body.inv{color:rgba(255,255,255,.45)}
.result-stat{margin-top:18px;padding:16px 18px;background:rgba(0,196,122,.08);border:1px solid rgba(0,196,122,.2);border-radius:10px}
.rs-num{font-size:32px;font-weight:700;color:var(--g);letter-spacing:-.03em;line-height:1}
.rs-txt{font-size:12px;color:rgba(255,255,255,.4);margin-top:4px;font-family:var(--fm);letter-spacing:.04em}
.rs-txt.dark-v{color:var(--mid)}

/* ══════════════ SERVICES GRID ══════════════ */
.svc-grid-4{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr);border-radius:20px;overflow:hidden;margin-top:52px}
.sc{background:var(--bg);padding:42px 38px;transition:background .22s;cursor:none;position:relative;animation:none}
.sc:hover{background:var(--bg2)}
.sc-letter{font-family:var(--fm);font-size:10px;letter-spacing:.12em;color:var(--g);text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:6px}
.sc-title{font-size:19px;font-weight:600;color:var(--ink);margin-bottom:12px;letter-spacing:-.016em}
.sc-problem{font-size:13px;color:#c45050;line-height:1.65;margin-bottom:12px;padding-left:12px;border-left:2px solid #e55}
.sc-body{font-size:14px;color:var(--mid);line-height:1.7}
.sc-result{display:inline-flex;align-items:center;gap:6px;margin-top:14px;padding:6px 12px;background:var(--gl);border-radius:6px;font-family:var(--fm);font-size:11px;color:var(--gd);border:1px solid rgba(0,196,122,.2)}

/* ══════════════ DARK SERVICE ROWS (B, C) ══════════════ */
.svc-dark-row{background:var(--charcoal);padding:80px 0}
.svc-dark-2col{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.svc-dark-lbl{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.svc-dark-lbl::before{content:'';width:14px;height:1px;background:rgba(255,255,255,.2)}
.svc-dark-h{font-size:clamp(24px,3vw,36px);font-weight:300;color:#fff;line-height:1.15;letter-spacing:-.022em;margin-bottom:14px}
.svc-dark-h strong{font-weight:700}
.svc-dark-problem{font-size:14px;color:rgba(255,100,100,.7);line-height:1.7;padding:14px 18px;border-left:2px solid rgba(255,100,100,.5);background:rgba(255,60,60,.05);border-radius:0 8px 8px 0;margin-bottom:20px}
.svc-dark-body{font-size:15px;color:rgba(255,255,255,.5);line-height:1.75}
.svc-dark-result{padding:18px 20px;background:rgba(0,196,122,.08);border:1px solid rgba(0,196,122,.18);border-radius:12px;margin-top:20px}
.sdr-num{font-size:28px;font-weight:700;color:var(--g);letter-spacing:-.03em;line-height:1;margin-bottom:4px}
.sdr-txt{font-size:12px;color:rgba(255,255,255,.38);font-family:var(--fm);letter-spacing:.05em}
.module-list{display:flex;flex-direction:column;gap:0}
.mod{padding:16px 0;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:flex-start;gap:14px}
.mod:last-child{border-bottom:none}
.mod-dot{width:6px;height:6px;border-radius:50%;background:var(--g);flex-shrink:0;margin-top:7px}
.mod-text{font-size:14px;color:rgba(255,255,255,.55);line-height:1.6}
.mod-text strong{color:rgba(255,255,255,.85);font-weight:500}

/* ══════════════ COMPLIANCE ══════════════ */
.comp-navy{background:var(--navy);padding:112px 0}
.comp-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.07);border-radius:20px;overflow:hidden;margin-top:56px}
.cg-half{background:rgba(255,255,255,.02);padding:48px 44px}
.cg-half.solid{background:rgba(0,196,122,.05);padding:48px 44px;border-left:1px solid rgba(0,196,122,.15)}
.cg-problem-box{background:rgba(255,60,60,.06);border:1px solid rgba(255,60,60,.15);border-radius:12px;padding:18px 20px;margin-bottom:28px}
.cpb-lbl{font-family:var(--fm);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,100,100,.7);margin-bottom:8px}
.cpb-text{font-size:14px;color:rgba(255,255,255,.5);line-height:1.65}
.guarantee-list{display:flex;flex-direction:column;gap:0}
.guar{display:flex;align-items:flex-start;gap:14px;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.guar:last-child{border-bottom:none}
.guar-ico{width:36px;height:36px;border-radius:10px;background:rgba(0,196,122,.1);border:1px solid rgba(0,196,122,.22);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.guar-num{font-family:var(--fm);font-size:11px;color:var(--g);letter-spacing:.07em;margin-bottom:4px}
.guar-title{font-size:15px;font-weight:500;color:#fff;margin-bottom:5px;letter-spacing:-.012em}
.guar-body{font-size:13px;color:rgba(255,255,255,.42);line-height:1.6}
.guar-tag{font-family:var(--fm);font-size:10px;color:var(--g);background:rgba(0,196,122,.1);padding:2px 8px;border-radius:4px;display:inline-block;margin-top:7px;letter-spacing:.04em}

/* ══════════════ SECTORS ══════════════ */
.sector-tabs{display:grid;grid-template-columns:280px 1fr;gap:0;border:1px solid var(--bdr);border-radius:20px;overflow:hidden;margin-top:56px}
.sector-nav{background:var(--bg2);border-right:1px solid var(--bdr)}
.sector-tab{padding:18px 24px;cursor:none;border-bottom:1px solid var(--bdr);transition:background .18s;display:flex;align-items:center;justify-content:space-between}
.sector-tab:last-child{border-bottom:none}
.sector-tab:hover{background:var(--bg3)}
.sector-tab.active-tab{background:var(--ink);color:#fff}
.sector-tab.active-tab .st-badge{background:var(--g);color:#000;border-color:var(--g)}
.st-name{font-size:15px;font-weight:500;letter-spacing:-.012em}
.st-badge{font-family:var(--fm);font-size:9px;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border-radius:999px;border:1px solid var(--bdr2);color:var(--mid);transition:.18s}
.sector-content{background:var(--bg);padding:48px 44px;position:relative}
.sc-panel{display:none}
.sc-panel.active{display:block}
.sc-problem-block{padding:18px 20px;background:#fff5f5;border:1px solid rgba(220,50,50,.15);border-radius:10px;margin-bottom:22px}
.scpb-lbl{font-family:var(--fm);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#c45050;margin-bottom:6px}
.scpb-text{font-size:14px;color:#6a3030;line-height:1.65}
.sc-solution-block{margin-bottom:20px}
.sc-sol-title{font-size:18px;font-weight:600;color:var(--ink);margin-bottom:8px;letter-spacing:-.015em}
.sc-sol-body{font-size:14px;color:var(--mid);line-height:1.7}
.sc-result-block{padding:16px 18px;background:var(--gl);border:1px solid rgba(0,196,122,.2);border-radius:10px}
.scrb-lbl{font-family:var(--fm);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gd);margin-bottom:8px}
.scrb-text{font-size:14px;color:var(--gd);font-weight:500;line-height:1.6}

/* ══════════════ METHODOLOGY ══════════════ */
.mlist{border-top:1px solid var(--bdr);margin-top:52px}
.mi{display:grid;grid-template-columns:68px 1fr auto;gap:32px;padding:34px 0;border-bottom:1px solid var(--bdr);cursor:none;align-items:start;transition:padding-left .2s var(--ease)}
.mi:hover{padding-left:8px}
.mi:hover .minum{color:var(--gd)}
.minum{font-family:var(--fm);font-size:38px;font-weight:400;color:var(--bdr2);line-height:1;letter-spacing:-.03em;transition:color .22s}
.mit{font-size:17px;font-weight:600;color:var(--ink);margin-bottom:6px;letter-spacing:-.014em}
.mid_{font-size:14px;color:var(--mid);line-height:1.65}
.mitag{padding:5px 14px;border:1.5px solid var(--bdr2);border-radius:999px;font-family:var(--fm);font-size:10px;color:var(--faint);white-space:nowrap;align-self:flex-start;margin-top:4px;letter-spacing:.06em}
.not-doing{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr);border-radius:16px;overflow:hidden;margin-top:32px}
.nd-item{background:var(--bg2);padding:24px 28px}
.nd-cross{font-size:11px;font-weight:600;color:#c45050;font-family:var(--fm);letter-spacing:.08em;margin-bottom:8px}
.nd-title{font-size:15px;font-weight:500;color:var(--ink);margin-bottom:5px;letter-spacing:-.012em}
.nd-body{font-size:13px;color:var(--mid);line-height:1.6}

/* ══════════════ CTA SECTIONS ══════════════ */
.cta-green{background:var(--gd);padding:88px 0;position:relative;overflow:hidden}
.cta-green-noise{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 300 300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");background-size:200px;pointer-events:none}
.cta-navy{background:var(--navy);padding:88px 0;position:relative;overflow:hidden}
.cta-navy-noise{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 300 300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");background-size:200px;pointer-events:none}
.cta-in{position:relative;z-index:1;display:flex;align-items:flex-end;justify-content:space-between;gap:56px;flex-wrap:wrap}
.cta-h-grn{font-size:clamp(26px,4vw,48px);font-weight:700;color:#000;letter-spacing:-.03em;line-height:1.08;max-width:600px}
.cta-h-inv{font-size:clamp(26px,4vw,48px);font-weight:300;color:#fff;letter-spacing:-.025em;line-height:1.1;max-width:600px}
.cta-h-inv strong{font-weight:700}
.cta-r{display:flex;flex-direction:column;align-items:flex-end;gap:12px;flex-shrink:0}
.cta-note-grn{font-size:14px;color:rgba(0,0,0,.5);max-width:250px;text-align:right;line-height:1.6}
.cta-note-inv{font-size:14px;color:rgba(255,255,255,.38);max-width:250px;text-align:right;line-height:1.6}

/* ══════════════ INNER HERO ══════════════ */
.ih{padding:136px 0 76px;background:var(--navy);border-bottom:1px solid rgba(255,255,255,.08);position:relative;overflow:hidden}
.ih-grain{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 300 300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.78' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");background-size:180px;pointer-events:none}
.ih-glow{position:absolute;top:-40%;right:-8%;width:600px;height:600px;background:radial-gradient(ellipse,rgba(0,100,60,.3) 0%,transparent 65%);pointer-events:none}
.ih-lbl{font-family:var(--fm);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:22px;position:relative;z-index:1;display:flex;align-items:center;gap:8px}
.ih-slash{color:rgba(255,255,255,.15)}
.ih-h1{font-size:clamp(34px,5.5vw,64px);font-weight:700;color:#fff;letter-spacing:-.038em;line-height:.97;margin-bottom:22px;position:relative;z-index:1}
.ih-h1 em{font-weight:300;font-style:italic;color:rgba(255,255,255,.55)}
.ih-sub{font-size:16px;color:rgba(255,255,255,.48);max-width:540px;line-height:1.72;position:relative;z-index:1}

/* ══════════════ PRODUCT DETAIL ══════════════ */
.pd-2col{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.pd-h{font-size:clamp(28px,4vw,44px);font-weight:300;color:var(--ink);letter-spacing:-.028em;line-height:1.06;margin-bottom:16px}
.pd-h strong{font-weight:700}
.pd-problem{font-size:14px;color:#c45050;line-height:1.65;padding:14px 18px;border-left:2px solid #e55;background:#fff5f5;border-radius:0 8px 8px 0;margin-bottom:20px}
.pd-desc{font-size:15px;color:var(--mid);line-height:1.75;margin-bottom:24px}
.pd-feats{display:flex;flex-direction:column;border-top:1px solid var(--bdr);margin-bottom:24px}
.pd-feat{display:flex;align-items:flex-start;gap:12px;padding:11px 0;border-bottom:1px solid var(--bdr)}
.pd-fdot{width:4px;height:4px;border-radius:50%;background:var(--g);flex-shrink:0;margin-top:7px}
.pd-ft{font-size:13px;color:var(--mid);line-height:1.6}
.pd-ft strong{color:var(--ink)}
.pd-result{padding:16px 20px;background:var(--gl);border:1px solid rgba(0,196,122,.25);border-radius:12px;margin-bottom:24px}
.pdr-lbl{font-family:var(--fm);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gd);margin-bottom:10px}
.pdr-stats{display:flex;gap:24px;flex-wrap:wrap}
.pdr-stat{display:flex;flex-direction:column}
.pdr-num{font-size:28px;font-weight:700;color:var(--gd);letter-spacing:-.03em;line-height:1}
.pdr-note{font-size:12px;color:var(--gd);font-family:var(--fm);margin-top:2px;letter-spacing:.04em;opacity:.7}
.price-table{border:1px solid var(--bdr);border-radius:14px;overflow:hidden;margin-bottom:10px}
.ptr{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--bdr)}
.ptr:last-child{border-bottom:none}
.ptr.h{background:var(--bg2)}
.ptr-n{font-size:13px;font-weight:500;color:var(--ink)}
.ptr-p{font-size:19px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.ptr-note{font-family:var(--fm);font-size:10px;color:var(--faint);letter-spacing:.04em}
/* mock terminal */
.mw{background:#0a0a12;border:1px solid rgba(255,255,255,.07);border-radius:10px;overflow:hidden;margin-bottom:24px}
.mwb{display:flex;align-items:center;gap:7px;padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.05)}
.mwc{display:flex;gap:4px}
.mc{width:8px;height:8px;border-radius:50%}
.mc-r{background:rgba(255,88,80,.4)}.mc-y{background:rgba(255,190,40,.4)}.mc-g{background:rgba(40,196,60,.4)}
.mwtitle{font-family:var(--fm);font-size:10px;color:rgba(255,255,255,.18);margin-left:7px}
.mwbody{padding:12px}
.mwr{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:rgba(255,255,255,.03);border-radius:7px;margin-bottom:5px;font-size:11px}
.mwr:last-child{margin-bottom:0}
.mwn{color:rgba(255,255,255,.6)}
.mwa{color:#fff;font-weight:600;font-family:var(--fm)}
.tok{display:inline-flex;padding:2px 7px;border-radius:999px;font-size:9px;font-family:var(--fm);background:rgba(0,196,122,.12);color:var(--g)}
.tpend{display:inline-flex;padding:2px 7px;border-radius:999px;font-size:9px;font-family:var(--fm);background:rgba(251,191,36,.1);color:#fbbf24}
.mcal{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;margin-bottom:9px}
.mcd{text-align:center;padding:9px 3px;background:rgba(255,255,255,.03);border-radius:5px}
.mcd.act{background:var(--gd)}
.mcd-d{font-size:8px;color:rgba(255,255,255,.25);font-family:var(--fm);letter-spacing:.06em;margin-bottom:2px}
.mcd.act .mcd-d{color:rgba(255,255,255,.6)}
.mcd-n{font-size:13px;font-weight:700;color:#fff;line-height:1}
.mcd-c{font-size:9px;color:var(--g);margin-top:2px;font-family:var(--fm)}
.mcd.act .mcd-c{color:rgba(255,255,255,.8)}

/* ══════════════ ABOUT ══════════════ */
.about-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:80px;align-items:start;margin-top:56px}
.about-prose{display:flex;flex-direction:column;gap:20px}
.about-highlight{font-size:19px;color:var(--ink);font-weight:400;line-height:1.55;letter-spacing:-.012em;border-left:3px solid var(--g);padding-left:20px;margin-bottom:4px}
.about-p{font-size:15px;color:var(--mid);line-height:1.82}
.tcard{border:1px solid var(--bdr);border-radius:18px;padding:34px;position:sticky;top:88px;background:var(--bg)}
.tav{width:58px;height:58px;border-radius:50%;background:var(--ink);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--bg);margin-bottom:18px;letter-spacing:.07em}
.tnm{font-size:19px;font-weight:500;color:var(--ink);margin-bottom:3px;letter-spacing:-.018em}
.trl{font-family:var(--fm);font-size:11px;color:var(--faint);margin-bottom:16px;letter-spacing:.04em}
.tbio{font-size:13px;color:var(--mid);line-height:1.7;margin-bottom:20px}
.tlinks{display:flex;flex-direction:column;gap:9px}
.tl{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--gd);cursor:none;transition:gap .18s}
.tl:hover{gap:11px}

/* ══════════════ CONTACT ══════════════ */
.ct-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:start}
.form-h{font-size:20px;font-weight:600;color:var(--ink);margin-bottom:24px;letter-spacing:-.018em}
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.fl{font-family:var(--fm);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.fi,.fsl,.fta{background:var(--bg);border:1.5px solid var(--bdr2);border-radius:9px;padding:11px 15px;font-size:14px;color:var(--ink);transition:border-color .18s;outline:none;width:100%;appearance:none;font-family:var(--f)}
.fi:focus,.fsl:focus,.fta:focus{border-color:var(--ink);box-shadow:0 0 0 3px rgba(0,0,0,.05)}
.fta{resize:vertical;min-height:100px;line-height:1.6}
.fsl{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4' fill='none' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:14px;cursor:none}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fchk{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--mid)}
.fchk input{accent-color:var(--gd);margin-top:2px;flex-shrink:0;cursor:none}
.fsub{width:100%;padding:13px;background:var(--ink);color:var(--bg);border:none;border-radius:999px;font-size:14px;font-weight:500;cursor:none;transition:background .18s;margin-top:16px;font-family:var(--f)}
.fsub:hover{background:var(--navy)}
.fsub:disabled{opacity:.5}
.asi-list{display:flex;flex-direction:column}
.asi{display:flex;gap:12px;padding:16px 0;border-bottom:1px solid var(--bdr);align-items:flex-start}
.asi:first-child{padding-top:0}.asi:last-child{border-bottom:none}
.asi-ico{width:36px;height:36px;border-radius:9px;border:1.5px solid var(--bdr2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.asi-l{font-family:var(--fm);font-size:10px;color:var(--faint);letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px}
.asi-v{font-size:13px;color:var(--mid)}
.asi-v a{color:var(--gd)}
.demobox{background:var(--navy);border-radius:14px;padding:24px;margin-bottom:18px}
.demobox h3{font-size:16px;font-weight:600;color:#fff;margin-bottom:7px;letter-spacing:-.015em}
.demobox p{font-size:13px;color:rgba(255,255,255,.4);line-height:1.6;margin-bottom:16px}
.fs-box{display:none;text-align:center;padding:48px 20px}
.fs-box.show{display:block}
.fs-ico{width:52px;height:52px;border-radius:50%;background:var(--gl);border:1px solid rgba(0,196,122,.22);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.fs-t{font-size:22px;font-weight:600;color:var(--ink);margin-bottom:8px;letter-spacing:-.02em}
.fs-b{font-size:14px;color:var(--mid);line-height:1.65}

/* ══════════════ LEGAL ══════════════ */
.legal-page{padding:136px 0 80px;background:var(--bg)}
.legal-h1{font-size:clamp(28px,4vw,44px);font-weight:300;color:var(--ink);letter-spacing:-.025em;margin-bottom:6px}
.legal-h1 strong{font-weight:700}
.legal-date{font-family:var(--fm);font-size:11px;color:var(--faint);margin-bottom:44px;letter-spacing:.05em}
.lsec{margin-bottom:36px}
.lsec h2{font-size:20px;font-weight:500;color:var(--ink);margin-bottom:12px;letter-spacing:-.016em}
.lsec p,.lsec li{font-size:14px;color:var(--mid);line-height:1.8}
.lsec ul{padding-left:16px;display:flex;flex-direction:column;gap:7px}
.lsec a{color:var(--gd)}

/* ══════════════ FOOTER ══════════════ */
footer{background:var(--charcoal);padding:68px 0 32px;border-top:1px solid rgba(255,255,255,.06)}
.fg-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:52px;margin-bottom:48px}
.f-brand{font-size:13px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#fff;margin-bottom:8px}
.f-sub{font-size:13px;color:rgba(255,255,255,.25);line-height:1.65;max-width:210px;margin-bottom:18px}
.f-soc{width:32px;height:32px;border:1px solid rgba(255,255,255,.1);border-radius:7px;display:flex;align-items:center;justify-content:center;cursor:none;transition:border-color .18s}
.f-soc:hover{border-color:rgba(255,255,255,.35)}
.f-col-h{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.2);margin-bottom:14px}
.flnks{display:flex;flex-direction:column;gap:8px}
.flnk{font-size:13px;color:rgba(255,255,255,.3);cursor:none;transition:color .15s}
.flnk:hover{color:#fff}
.flnk.ext{color:var(--g)}.flnk.ext:hover{color:rgba(0,255,140,.8)}
.fbot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;padding-top:24px;border-top:1px solid rgba(255,255,255,.06)}
.fcp{font-family:var(--fm);font-size:10px;color:rgba(255,255,255,.18);letter-spacing:.05em}
.fleg{display:flex;gap:16px}
.fll{font-family:var(--fm);font-size:10px;color:rgba(255,255,255,.18);cursor:none;transition:color .15s;letter-spacing:.04em}
.fll:hover{color:rgba(255,255,255,.5)}

/* ── COOKIE ── */
#ck{position:fixed;bottom:0;left:0;right:0;background:var(--charcoal);padding:12px 40px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;z-index:700;font-size:12px;color:rgba(255,255,255,.35);border-top:1px solid rgba(255,255,255,.07)}
.ckg{color:var(--g);cursor:none}
.cka{padding:7px 16px;background:var(--g);color:#000;border:none;border-radius:999px;font-size:12px;font-weight:600;cursor:none;font-family:var(--f)}
.ckd{padding:6px 14px;border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.35);background:transparent;border-radius:999px;font-size:12px;cursor:none;font-family:var(--f)}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .pos-2col,.pd-2col,.about-grid,.ct-grid,.svc-dark-2col,.comp-grid-2{grid-template-columns:1fr}
  .sector-tabs{grid-template-columns:1fr}
  .sector-nav{display:none}
  .sc-panel{display:block!important}
  .fg-grid{grid-template-columns:1fr 1fr;gap:36px}
  .svc-grid-4,.not-doing{grid-template-columns:1fr}
}
@media(max-width:768px){
  .hdr-nav,.hdr-cta{display:none}
  .burger{display:flex}
  .hdr-in,.hero-body,.W,.Wsm{padding-left:24px;padding-right:24px}
  .hcol{padding:24px 0 32px}
  .hero-bar{grid-template-columns:1fr}
  .hero-sep{display:none}
  .sec{padding:72px 0}
  .fg-grid{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .mi{grid-template-columns:52px 1fr;gap:18px}
  .mi>:last-child{display:none}
  html{cursor:auto}body{cursor:auto}#cur{display:none}
}
@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ══════════════ SCROLL + MOUSE ANIMATIONS ══════════════ */

/* Parallax hero */
.hero-parallax{will-change:transform;transition:transform .05s linear}

/* Magnetic buttons */
.mag{display:inline-flex;position:relative;transform:translate(0,0);transition:transform .4s var(--ease)}

/* Floating compliance nodes (interactive section) */
.compliance-viz{position:relative;height:480px;overflow:hidden;background:var(--navy);border-radius:20px;margin-top:52px;cursor:none}
.compliance-viz-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at 50% 50%,rgba(0,196,122,.06) 0%,transparent 70%)}
.cvnode{position:absolute;cursor:none;transition:transform .3s var(--ease),opacity .3s}
.cvnode-circle{width:72px;height:72px;border-radius:50%;border:1px solid rgba(0,196,122,.25);display:flex;align-items:center;justify-content:center;background:rgba(0,196,122,.06);transition:border-color .3s,background .3s,transform .3s var(--ease)}
.cvnode:hover .cvnode-circle{border-color:var(--g);background:rgba(0,196,122,.14);transform:scale(1.08)}
.cvnode-label{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);white-space:nowrap;font-family:var(--fm);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);text-align:center}
.cvnode:hover .cvnode-label{color:var(--g)}
.cv-line{position:absolute;pointer-events:none;transform-origin:left center}
.cv-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
.cv-center-circle{width:100px;height:100px;border-radius:50%;background:rgba(0,196,122,.1);border:1.5px solid var(--g);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:4px}
.cvc-label{font-family:var(--fm);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--g)}
.cvc-name{font-size:13px;font-weight:700;color:#fff;letter-spacing:-.01em}
.cv-pulse{position:absolute;inset:-10px;border-radius:50%;border:1px solid rgba(0,196,122,.3);animation:cv-pulse 3s ease-in-out infinite}
.cv-pulse2{position:absolute;inset:-22px;border-radius:50%;border:1px solid rgba(0,196,122,.15);animation:cv-pulse 3s 1s ease-in-out infinite}
@keyframes cv-pulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.06);opacity:.2}}

/* Scroll counter animation */
.stat-num{display:inline-block;will-change:transform}

/* Section slide-in variants */
.rv-left{opacity:0;transform:translateX(-40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv-left.in{opacity:1;transform:none}
.rv-right{opacity:0;transform:translateX(40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv-right.in{opacity:1;transform:none}
.rv-scale{opacity:0;transform:scale(.94);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv-scale.in{opacity:1;transform:none}

/* Stagger with more gap */
.stg2>*{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.stg2.in>*{opacity:1;transform:none}
.stg2.in>*:nth-child(1){transition-delay:.06s}.stg2.in>*:nth-child(2){transition-delay:.14s}
.stg2.in>*:nth-child(3){transition-delay:.22s}.stg2.in>*:nth-child(4){transition-delay:.30s}
.stg2.in>*:nth-child(5){transition-delay:.38s}.stg2.in>*:nth-child(6){transition-delay:.46s}

/* Horizontal scroll section */
.hscroll-section{background:var(--charcoal);padding:80px 0;overflow:hidden;position:relative}
.hscroll-track{display:flex;gap:24px;width:max-content;padding:0 52px;animation:hscroll 30s linear infinite}
.hscroll-track:hover{animation-play-state:paused}
.hscroll-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:28px 32px;width:280px;flex-shrink:0;cursor:none;transition:background .22s,border-color .22s}
.hscroll-card:hover{background:rgba(0,196,122,.06);border-color:rgba(0,196,122,.2)}
.hscroll-icon{width:40px;height:40px;border-radius:10px;background:rgba(0,196,122,.1);border:1px solid rgba(0,196,122,.2);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.hsc-label{font-family:var(--fm);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:8px}
.hsc-title{font-size:15px;font-weight:600;color:#fff;margin-bottom:6px;letter-spacing:-.013em}
.hsc-body{font-size:12px;color:rgba(255,255,255,.4);line-height:1.6}
@keyframes hscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Hero floating elements */
.hero-float{position:absolute;pointer-events:none;z-index:2}
.hf1{top:18%;right:8%;width:220px;opacity:.55;animation:float1 8s ease-in-out infinite}
.hf2{top:55%;right:14%;width:160px;opacity:.35;animation:float2 11s ease-in-out infinite}
.hf3{top:30%;right:22%;width:120px;opacity:.25;animation:float3 9s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-16px) rotate(1deg)}}
@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(12px)}}
@keyframes float3{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-10px) rotate(-1deg)}}

/* Stats counter section */
.stats-bar{background:var(--gd);padding:52px 0;position:relative;overflow:hidden}
.stats-bar-noise{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 300 300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");background-size:180px;pointer-events:none}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;z-index:1}
.stat-item{text-align:center;padding:0 20px;border-right:1px solid rgba(0,0,0,.15)}
.stat-item:last-child{border-right:none}
.stat-big{font-size:48px;font-weight:800;color:#000;letter-spacing:-.04em;line-height:1}
.stat-big span{color:rgba(0,0,0,.5);font-size:32px}
.stat-label{font-family:var(--fm);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(0,0,0,.55);margin-top:6px}

/* Typewriter on hero */
.typewriter-wrap{min-height:1.2em;display:inline-block}
.typewriter{border-right:2px solid var(--g);padding-right:2px;animation:blink .75s step-end infinite}
@keyframes blink{0%,100%{border-color:var(--g)}50%{border-color:transparent}}

/* Mouse parallax layers */
.parallax-layer{transition:transform .1s linear;will-change:transform}


/* Service cards direct animation */
.svc-grid-4 .sc{
  opacity:0;
  transform:translateY(20px);
  animation:sc-enter .6s var(--ease) forwards;
}
.svc-grid-4.visible .sc{
  opacity:1 !important;
  transform:none !important;
  animation:none !important;
}
.svc-grid-4 .sc:nth-child(1){animation-delay:.1s}
.svc-grid-4 .sc:nth-child(2){animation-delay:.18s}
.svc-grid-4 .sc:nth-child(3){animation-delay:.26s}
.svc-grid-4 .sc:nth-child(4){animation-delay:.34s}
@keyframes sc-enter{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}


/* ═══════════════════════════════════════
   CONTINUOUS SCROLL & MICRO-INTERACTIONS
═══════════════════════════════════════ */

/* Section titles — subtle parallax handled by JS */
.h2, .h2-inv, .h2-g { will-change: transform; }

/* Cards: hover state with 3D lift */
.sc {
  transform-style: preserve-3d;
  perspective: 1000px;
}
.sc:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 20px 40px rgba(0,0,0,.08);
}

/* Methodology items — slide in from left on scroll */
.mi {
  border-left: 2px solid transparent;
  transition: border-color .3s, padding-left .22s var(--ease), background .2s;
}
.mi.in-view { border-left-color: var(--g); }
.mi:hover { border-left-color: var(--gd) !important; }

/* Statement block — text grows slightly on scroll */
.st-quote {
  transition: opacity .8s var(--ease), transform .8s var(--ease), font-size .3s;
}

/* Service cards individual entrance */
.svc-grid-4 .sc { animation-play-state: running; }

/* Section dividers with animated line */
.sec-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--bdr), transparent);
  margin: 0;
  transform-origin: left;
  animation: expand-line 1s var(--ease) forwards;
  opacity: 0;
}
.sec-divider.in { opacity: 1; }
@keyframes expand-line { from { transform: scaleX(0); opacity: 0; } to { transform: scaleX(1); opacity: 1; } }

/* Compliance nodes animation */
.cvnode {
  animation: node-float 4s ease-in-out infinite;
}
.cvnode:nth-child(2) { animation-delay: .5s; }
.cvnode:nth-child(3) { animation-delay: 1s; }
.cvnode:nth-child(4) { animation-delay: 1.5s; }
.cvnode:nth-child(5) { animation-delay: 2s; }
@keyframes node-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

/* Stats bar numbers — clip reveal */
.stat-big { overflow: hidden; }
.stat-num { display: inline-block; }

/* Horizontal scroll cards interactive */
.hscroll-card {
  transform: translateY(0) scale(1);
  transition: transform .3s var(--ease), background .22s, border-color .22s, box-shadow .3s;
}
.hscroll-card:hover {
  transform: translateY(-6px) scale(1.02) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,.3);
}

/* Guarantee items pop on hover */
.guar {
  transition: background .2s, padding-left .2s var(--ease), transform .3s var(--ease);
  border-radius: 8px;
  padding-left: 0;
}
.guar:hover {
  background: rgba(0,196,122,.04);
  padding-left: 8px;
}

/* Methodology items pop */
.mi {
  transition: background .2s, padding-left .22s var(--ease);
  border-radius: 0 12px 12px 0;
}

/* Price table rows highlight */
.ptr {
  transition: background .18s, transform .18s var(--ease);
}
.ptr:hover {
  background: var(--gl) !important;
  transform: translateX(4px);
}

/* Section labels bounce in */
.lbl, .lbl-inv, .lbl-g {
  will-change: opacity, letter-spacing;
}

/* About highlight pulses border */
.about-highlight {
  border-left-width: 3px;
  transition: border-color .4s, padding-left .3s var(--ease);
}
.about-highlight:hover {
  border-left-color: var(--gd);
  padding-left: 24px;
}

/* Hero h1 lines — stagger already in CSS, add glow on focus words */
.hero-h1 strong { color: #fff; }
.hero-h1 em { 
  background: linear-gradient(135deg, var(--g) 0%, rgba(0,196,122,.6) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* CTA sections — subtle breathe */
.cta-green .cta-h-grn {
  animation: text-breathe 6s ease-in-out infinite;
}
@keyframes text-breathe {
  0%, 100% { opacity: 1; }
  50% { opacity: .88; }
}

/* Scroll-driven color transitions on section bg */
.sec-bg-shift {
  transition: background-color .6s ease;
}

/* Floating badge chips in hero — orbit effect */
.hero-float svg { filter: drop-shadow(0 4px 12px rgba(0,196,122,.15)); }

/* Inner hero pages — subtle grain animation */
.ih { 
  background-attachment: fixed;
}

/* Progress bar pulse */
#scroll-progress::after {
  content: '';
  position: absolute;
  right: 0;
  top: -1px;
  width: 40px;
  height: 4px;
  background: rgba(255,255,255,.6);
  border-radius: 2px;
  filter: blur(4px);
}

/* Mobile — disable heavy effects */
@media (max-width: 768px) {
  .h2, .h2-inv, .hero-h1, .st-quote { will-change: auto; transform: none !important; }
  .hero-float { display: none; }
  .cvnode { animation: none; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
    transform: none !important;
  }
}


@keyframes grid-drift{from{background-position:0 0}to{background-position:60px 60px}}
@keyframes bg-pan{from{background-position:0% 50%}to{background-position:100% 50%}}
/* Hero gradient animation */
.hero{background:linear-gradient(135deg,#0d1526 0%,#0d1a2e 40%,#081520 100%);background-size:200% 200%;animation:bg-pan 12s ease-in-out infinite alternate}

