/* Ruphus ERP — Shared Styles */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --cream:#FAF7F2;--white:#FFF;--sand:#F0EBE3;--stone:#E5DFD5;
  --ink:#1A1A1A;--ink2:#3D3D3D;--ink3:#6B6B6B;--ink4:#9B9B9B;
  --teal:#f97c2b;--tl:#FEF0E5;--td:#D46620;
  --coral:#E8634A;--cl:#FDF0ED;
  --amber:#D4A017;--al:#FFF8E7;
  --violet:#6C5CE7;--vl:#F0EEFB;
  --serif:'Fraunces',Georgia,serif;--sans:'Outfit',system-ui,sans-serif;--mono:'JetBrains Mono',monospace;
  --max:1180px;--gap:14px;--r:12px;--rl:20px;
  --bg:var(--cream);--bg2:var(--white);--tx:var(--ink);--tx2:var(--ink3);--tx3:var(--ink4);--brd:var(--stone);--fg:var(--ink);--card:var(--white);--muted:var(--ink3);
}
html.dark{
  --bg:#0D0F14;--bg2:#161820;--tx:#E4E4EE;--tx2:#9494AB;--tx3:#5A5A72;--brd:#252536;
  --sand:#1A1B26;--stone:#252536;--cream:#0D0F14;--white:#161820;
  --card:#1A1C24;--muted:#8888A0;--fg:#F0F0F8;
  --tl:rgba(249,124,43,.1);--cl:rgba(232,99,74,.08);--al:rgba(212,160,23,.08);--vl:rgba(108,92,231,.08);
}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--sans);background:var(--bg);color:var(--tx);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden;transition:background .3s,color .3s}
h1,h2,h3,h4,h5,h6{font-family:var(--serif);line-height:1.15;color:var(--fg);text-wrap:balance}
h1{font-weight:900;letter-spacing:-.04em}
h2{font-weight:800;letter-spacing:-.03em}
h3{font-weight:700;letter-spacing:-.02em}
h4{font-weight:700;letter-spacing:-.01em}
p{text-wrap:pretty}
a{color:inherit;text-decoration:none}button{font-family:var(--sans);cursor:pointer}
.w{max-width:var(--max);margin:0 auto;padding:0 24px}

/* REVEAL */
[data-r]{opacity:0;transform:translateY(24px);transition:opacity .65s cubic-bezier(.16,1,.3,1),transform .65s cubic-bezier(.16,1,.3,1)}
[data-r].v{opacity:1;transform:none}
[data-r="1"]{transition-delay:.07s}[data-r="2"]{transition-delay:.14s}[data-r="3"]{transition-delay:.21s}[data-r="4"]{transition-delay:.28s}[data-r="5"]{transition-delay:.35s}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;width:100%;z-index:100;padding:12px 0;transition:all .3s;background:rgba(250,247,242,.85);backdrop-filter:blur(12px)}
.nav.scrolled{background:rgba(250,247,242,.95);backdrop-filter:blur(16px);box-shadow:0 1px 0 var(--brd);padding:8px 0}
html.dark .nav{background:rgba(15,17,23,.85)}
html.dark .nav.scrolled{background:rgba(15,17,23,.95)}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:12px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:700;font-size:1.25rem;letter-spacing:-.02em}
.logo svg{width:30px;height:30px}
.nlinks{display:flex;gap:22px}
.nlinks a{font-size:.84rem;font-weight:500;color:var(--tx2);transition:color .2s}
.nlinks a:hover{color:var(--tx)}
.ncta{display:flex;gap:8px;align-items:center}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 22px;border-radius:99px;font-size:.84rem;font-weight:600;border:none;transition:all .25s;white-space:nowrap}
.btn-g{background:transparent;color:var(--tx2)}.btn-g:hover{background:var(--sand)}
.btn-t{background:var(--teal);color:#fff;position:relative;overflow:hidden}
.btn-t:hover{background:var(--td);transform:translateY(-1px);box-shadow:0 4px 16px rgba(249,124,43,.25)}
.btn-t::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);transform:translateX(-100%)}
.btn-t:hover::after{transform:translateX(100%);transition:transform .5s}
.btn-lg{padding:14px 32px;font-size:.95rem}
.btn-ol{background:transparent;border:1.5px solid var(--brd);color:var(--tx2)}.btn-ol:hover{border-color:var(--tx3);background:var(--bg2)}
.theme-btn{background:none;border:1px solid var(--brd);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--tx2);transition:all .2s;font-size:1rem}
.theme-btn:hover{border-color:var(--tx3);color:var(--tx)}
.hambg{display:none;background:none;border:none;color:var(--tx);padding:4px}
.mob{position:fixed;inset:0;z-index:99;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;opacity:0;pointer-events:none;transition:opacity .3s}
.mob.open{opacity:1;pointer-events:auto}
.mob a{font-family:var(--serif);font-size:1.4rem;font-weight:700;padding:8px 0}
.mob-x{position:absolute;top:18px;right:24px;background:none;border:none;color:var(--tx);font-size:1.4rem}

/* ── HERO ── */
.hero{padding:130px 0 56px;position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;top:-200px;right:-150px;width:600px;height:600px;background:radial-gradient(circle,rgba(249,124,43,.06),transparent 70%);pointer-events:none;animation:orbFloat 8s ease-in-out infinite}
.hero::before{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(59,130,246,.04),transparent 70%);pointer-events:none;animation:orbFloat 10s ease-in-out infinite reverse}
@keyframes orbFloat{0%,100%{transform:translate(0,0)}50%{transform:translate(20px,-20px)}}
.hero-ey{display:inline-flex;align-items:center;gap:8px;font-size:.74rem;font-weight:600;letter-spacing:.04em;color:var(--teal);background:var(--tl);padding:6px 16px;border-radius:99px;margin-bottom:20px}
.hero-ey .p{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.7)}}
.hero h1{font-family:var(--serif);font-size:clamp(2.5rem,6vw,4.8rem);font-weight:900;line-height:1.04;letter-spacing:-.04em;max-width:820px}
.hero h1 em{font-style:italic;font-weight:500;color:var(--teal)}
.typed-wrap{position:relative;display:inline}
.cursor{display:inline-block;width:3px;height:.82em;background:var(--teal);margin-left:3px;vertical-align:baseline;animation:blink .8s step-end infinite}
@keyframes blink{50%{opacity:0}}
.hero-sub{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:40px;align-items:start}
.hero-desc{font-size:1.05rem;color:var(--tx2);line-height:1.7;max-width:400px}
.hero-right{display:flex;flex-direction:column;gap:16px;align-items:flex-start}
.hero-right .btn-lg{padding:16px 36px;font-size:1rem}
.sp{display:flex;align-items:center;gap:12px}
.avatars{display:flex}
.av{width:28px;height:28px;border-radius:50%;border:2.5px solid var(--bg);margin-left:-9px;font-size:.52rem;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff}.av:first-child{margin-left:0}
.sp-t{font-size:.78rem;color:var(--tx3);line-height:1.35}.sp-t strong{color:var(--tx2);font-weight:600}

/* ── TRUST BADGES ── */
.trust{padding:28px 0;border-top:1px solid var(--brd);border-bottom:1px solid var(--brd)}
.trust-inner{display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap}
.trust-badge{display:flex;align-items:center;gap:6px;font-size:.74rem;font-weight:500;color:var(--tx3)}
.trust-badge .ico{width:20px;height:20px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:.6rem;flex-shrink:0}

/* ── MARQUEE ── */
.marquee{padding:24px 0;overflow:hidden;border-bottom:1px solid var(--brd)}
.marquee-label{text-align:center;font-size:.65rem;color:var(--tx3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.marquee-track{display:flex;animation:mq 28s linear infinite;width:max-content}
.marquee-item{padding:0 32px;font-size:.9rem;font-weight:600;color:var(--tx3);white-space:nowrap;display:flex;align-items:center;gap:8px}
.marquee-item .dot{width:5px;height:5px;border-radius:50%;background:var(--teal);opacity:.4}
@keyframes mq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── BENTO ── */
.bento-s{padding:20px 0 72px}
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--gap)}
.bc{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--rl);overflow:hidden;transition:transform .3s,box-shadow .3s}
.bc:hover{transform:translateY(-3px);box-shadow:0 10px 32px rgba(0,0,0,.06)}
html.dark .bc:hover{box-shadow:0 10px 32px rgba(0,0,0,.3)}
.c-h{grid-column:span 8;grid-row:span 2;padding:0;position:relative;min-height:360px}
.c-s{grid-column:span 4;padding:24px;display:flex;flex-direction:column;justify-content:space-between}
.c-w{grid-column:span 6;padding:22px 26px}
.c-lbl{font-size:.64rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--tx3);margin-bottom:4px}
.c-num{font-family:var(--mono);font-size:2.4rem;font-weight:600;line-height:1}
.c-det{font-size:.8rem;color:var(--tx2);margin-top:3px}
.c-ttl{font-family:var(--serif);font-size:1.1rem;font-weight:700;margin-bottom:4px}
.c-txt{font-size:.84rem;color:var(--tx2);line-height:1.6}
.spark{display:flex;align-items:flex-end;gap:3px;height:40px;margin-top:auto}
.spark i{flex:1;border-radius:3px;display:block}

/* UI mock */
.ui{position:absolute;inset:0;display:flex;flex-direction:column}
.ui-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--brd);background:var(--bg);font-size:.72rem;color:var(--tx2);overflow-x:auto;flex-shrink:0}
.ui-bar .nm{font-weight:600;color:var(--tx);margin-right:4px}
.tb{padding:5px 11px;border-radius:6px;font-size:.7rem;font-weight:500;border:none;background:transparent;color:var(--tx2);transition:all .2s;white-space:nowrap}
.tb.on{background:var(--tl);color:var(--teal);font-weight:600}.tb:hover:not(.on){background:var(--sand)}
.ui-bd{flex:1;display:grid;grid-template-columns:170px 1fr;overflow:hidden}
.ui-sb{padding:10px;border-right:1px solid var(--brd);font-size:.7rem;display:flex;flex-direction:column;gap:1px;overflow-y:auto}
.si{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:6px;color:var(--tx2);cursor:pointer;transition:all .15s;white-space:nowrap}
.si:hover,.si.on{background:var(--tl);color:var(--teal)}
.si-ic{width:14px;height:14px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:.5rem;flex-shrink:0}
.ui-c{padding:14px;overflow:auto}
.ui-c h4{font-family:var(--serif);font-size:.9rem;font-weight:700;margin-bottom:10px}
.pn{display:none}.pn.show{display:block}
.tbl{width:100%;border-collapse:collapse;font-size:.67rem}
.tbl th{text-align:left;padding:5px 7px;font-weight:600;color:var(--tx3);text-transform:uppercase;letter-spacing:.04em;font-size:.56rem;border-bottom:1px solid var(--brd)}
.tbl td{padding:6px 7px;border-bottom:1px solid rgba(0,0,0,.03);color:var(--tx2)}
html.dark .tbl td{border-bottom-color:rgba(255,255,255,.04)}
.bg{display:inline-block;padding:2px 7px;border-radius:99px;font-size:.55rem;font-weight:600}
.bg-g{background:#DCFCE7;color:#8B3E22}.bg-a{background:#FEF3C7;color:#92400E}.bg-r{background:#FEE2E2;color:#991B1B}.bg-v{background:var(--vl);color:var(--violet)}
html.dark .bg-g{background:rgba(22,101,52,.2);color:#4ade80}html.dark .bg-a{background:rgba(146,64,14,.2);color:#fbbf24}html.dark .bg-r{background:rgba(153,27,27,.2);color:#f87171}

/* ── TRANSFORMATION — rich ── */
.ba{padding:80px 0;background:var(--bg2);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd)}
.ba-toggle{display:flex;justify-content:center;margin:28px 0 32px;position:relative}
.ba-pill{display:flex;border-radius:99px;border:2px solid var(--brd);overflow:hidden;background:var(--bg);position:relative}
.ba-pill::before{content:'';position:absolute;top:2px;left:2px;width:calc(50% - 4px);height:calc(100% - 4px);border-radius:99px;transition:transform .35s cubic-bezier(.4,0,.2,1);z-index:0}
.ba-pill.state-before::before{background:var(--coral);transform:translateX(0)}
.ba-pill.state-after::before{background:var(--teal);transform:translateX(100%)}
.ba-pb{padding:12px 32px;font-size:.85rem;font-weight:600;border:none;background:transparent;color:var(--tx2);position:relative;z-index:1;cursor:pointer;transition:color .3s}
.ba-pill.state-before .ba-pb:first-child,.ba-pill.state-after .ba-pb:last-child{color:#fff}
.ba-content{position:relative;min-height:420px}
.ba-panel{display:none;animation:fadeUp .45s ease}.ba-panel.show{display:block}
/* metrics row */
.ba-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
.ba-metric{padding:20px;border-radius:var(--rl);text-align:center;border:1px solid var(--brd);background:var(--bg);position:relative;overflow:hidden}
.ba-metric .bm-icon{font-size:1.6rem;margin-bottom:6px;display:block}
.ba-metric .bm-val{font-family:var(--mono);font-size:1.6rem;font-weight:700;line-height:1.1}
.ba-metric .bm-label{font-size:.7rem;color:var(--tx2);margin-top:2px}
.ba-metric .bm-bar{position:absolute;bottom:0;left:0;right:0;height:4px;border-radius:0 0 var(--rl) var(--rl)}
/* pain/gain cards */
.ba-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap)}
.ba-item{display:flex;gap:14px;padding:20px;border-radius:var(--rl);border:1px solid var(--brd);background:var(--bg);transition:transform .3s,border-color .3s}
.ba-item:hover{transform:translateY(-2px)}
.ba-item .ba-num{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;flex-shrink:0;font-family:var(--mono)}
.ba-item h4{font-size:.92rem;font-weight:700;margin-bottom:3px;line-height:1.25}
.ba-item p{font-size:.78rem;color:var(--tx2);line-height:1.5}
/* before state */
.ba-panel.before .ba-metric{border-color:rgba(232,99,74,.15)}
.ba-panel.before .ba-metric .bm-val{color:var(--coral)}
.ba-panel.before .ba-metric .bm-bar{background:var(--coral)}
.ba-panel.before .ba-item:hover{border-color:var(--coral)}
.ba-panel.before .ba-num{background:var(--cl);color:var(--coral)}
/* after state */
.ba-panel.after .ba-metric{border-color:rgba(249,124,43,.15)}
.ba-panel.after .ba-metric .bm-val{color:var(--teal)}
.ba-panel.after .ba-metric .bm-bar{background:var(--teal)}
.ba-panel.after .ba-item:hover{border-color:var(--teal)}
.ba-panel.after .ba-num{background:var(--tl);color:var(--teal)}
/* impact bar */
.ba-impact{margin-top:28px;padding:24px 32px;border-radius:var(--rl);border:2px solid var(--teal);background:var(--tl);display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
html.dark .ba-impact{background:rgba(249,124,43,.08)}
.ba-impact-text{font-family:var(--serif);font-size:1.05rem;font-weight:700;color:var(--tx)}
.ba-impact-text em{color:var(--teal);font-style:italic}
@media(max-width:768px){.ba-metrics{grid-template-columns:1fr 1fr}.ba-grid{grid-template-columns:1fr}.ba-pb{padding:10px 20px;font-size:.78rem}}

/* ── MODULES + ROADMAP ── */
.mods{padding:80px 0}
.s-ey{font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--teal)}
.s-hd{font-family:var(--serif);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-.03em;margin:8px 0 6px;max-width:620px;line-height:1.12}
.s-desc{font-size:.95rem;color:var(--tx2);max-width:440px;line-height:1.65}
.mod-tabs{display:flex;gap:8px;margin:32px 0 0;flex-wrap:wrap}
.mt{padding:8px 18px;border-radius:99px;font-size:.8rem;font-weight:500;border:1.5px solid var(--brd);background:transparent;color:var(--tx2);transition:all .25s}
.mt.on{background:var(--ink);color:var(--cream);border-color:var(--ink)}
html.dark .mt.on{background:var(--teal);color:#fff;border-color:var(--teal)}
.mt:hover:not(.on){border-color:var(--tx3)}
.mod-c{margin-top:28px}
.mc{display:none;animation:fadeUp .4s ease}.mc.show{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.mc-info h3{font-family:var(--serif);font-size:1.35rem;font-weight:700;margin-bottom:8px}
.mc-info p{font-size:.92rem;color:var(--tx2);line-height:1.65;margin-bottom:16px;max-width:420px}
.mc-feats{display:flex;flex-direction:column;gap:8px}
.mc-f{display:flex;gap:9px;font-size:.86rem;color:var(--tx2);align-items:flex-start}
.mc-f .ck{width:18px;height:18px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700;flex-shrink:0;margin-top:3px}
.mc-vis{border:1px solid var(--brd);border-radius:var(--rl);background:var(--bg2);overflow:hidden;min-height:280px;display:flex;align-items:center;justify-content:center}
/* mini visuals */
.mv-pipe{width:100%;padding:18px}
.mv-row{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:7px;margin-bottom:4px;font-size:.76rem;font-weight:500;color:var(--tx2);transition:background .15s;cursor:default}
.mv-row:hover{background:rgba(0,0,0,.02)}html.dark .mv-row:hover{background:rgba(255,255,255,.03)}
.mv-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.mv-name{flex:1}.mv-bar{height:5px;flex:2;background:var(--sand);border-radius:3px;overflow:hidden}
.mv-bf{height:100%;border-radius:3px;transition:width 1s ease}
.mv-val{font-family:var(--mono);font-size:.7rem;color:var(--tx3);min-width:40px;text-align:right}
.mv-kpis{display:grid;grid-template-columns:1fr 1fr;gap:9px;padding:18px;width:100%}
.mv-kpi{padding:14px;border-radius:var(--r);border:1px solid var(--brd);text-align:center;background:var(--bg)}
.mv-kpi-l{font-size:.58rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--tx3);margin-bottom:4px}
.mv-kpi-v{font-family:var(--mono);font-size:1.2rem;font-weight:600}
.mv-flow{display:flex;align-items:center;gap:7px;padding:20px;flex-wrap:wrap;justify-content:center}
.mv-nd{padding:11px 14px;border-radius:9px;border:1.5px solid var(--brd);background:var(--bg);font-size:.76rem;font-weight:500;text-align:center;white-space:nowrap;transition:all .3s;cursor:default}
.mv-nd:hover{border-color:var(--teal);transform:translateY(-2px)}
.mv-nd.done{background:var(--tl);border-color:var(--teal);color:var(--teal);font-weight:600}
.mv-arr{color:var(--tx3);font-size:1rem}
.mv-bars{display:flex;align-items:flex-end;gap:7px;height:130px;padding:20px;width:100%}
.mv-bv{flex:1;border-radius:4px 4px 0 0;position:relative;cursor:default;transition:opacity .2s}
.mv-bv:hover{opacity:.8}
.mv-bv .tip{position:absolute;top:-22px;left:50%;transform:translateX(-50%);font-size:.58rem;font-family:var(--mono);color:var(--tx3);opacity:0;transition:opacity .2s;white-space:nowrap}
.mv-bv:hover .tip{opacity:1}

/* ── ROADMAP ── */
.roadmap{padding:80px 0;background:var(--bg2);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd)}
.roadmap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:36px}
.rm-card{padding:20px;border-radius:var(--rl);border:1px solid var(--brd);background:var(--bg);transition:transform .3s}
.rm-card:hover{transform:translateY(-2px)}
.rm-card .rm-icon{font-size:1.4rem;margin-bottom:10px}
.rm-card h4{font-size:.92rem;font-weight:700;margin-bottom:4px}
.rm-card p{font-size:.76rem;color:var(--tx2);line-height:1.5}
.rm-status{display:inline-flex;align-items:center;gap:4px;font-size:.6rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 10px;border-radius:99px;margin-top:10px}
.rm-live{background:#DCFCE7;color:#8B3E22}
.rm-dev{background:var(--al);color:#92400E}
.rm-plan{background:var(--vl);color:var(--violet)}
html.dark .rm-live{background:rgba(22,101,52,.2);color:#4ade80}
html.dark .rm-dev{background:rgba(146,64,14,.2);color:#fbbf24}
html.dark .rm-plan{background:rgba(108,92,231,.15);color:#a78bfa}

/* ── ROI CALCULATOR ── */
.calc{padding:80px 0}
.calc-box{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--rl);overflow:hidden}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;min-height:380px}
.calc-left{padding:36px;display:flex;flex-direction:column;gap:18px;border-right:1px solid var(--brd)}
.calc-left label{font-size:.78rem;font-weight:600;color:var(--tx2);margin-bottom:4px;display:block}
.calc-left input[type=number],.calc-left input[type=text],.calc-left select{width:100%;padding:11px 14px;border:1.5px solid var(--brd);border-radius:var(--r);font-family:var(--sans);font-size:.88rem;color:var(--tx);background:var(--bg);outline:none;transition:border-color .2s}
.calc-left input:focus,.calc-left select:focus{border-color:var(--teal)}
.range-wrap input[type=range]{width:100%;height:6px;border-radius:3px;appearance:none;background:var(--sand);outline:none;cursor:pointer}
.range-wrap input[type=range]::-webkit-slider-thumb{appearance:none;width:20px;height:20px;border-radius:50%;background:var(--teal);cursor:pointer;box-shadow:0 2px 8px rgba(249,124,43,.3)}
.range-info{display:flex;justify-content:space-between;font-size:.7rem;color:var(--tx3);margin-top:4px}
.range-info .val{color:var(--teal);font-weight:700}
.calc-right{padding:36px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:18px}
.calc-big{font-family:var(--mono);font-size:2.2rem;font-weight:600}
.calc-label{font-size:.82rem;color:var(--tx2)}
.calc-row{display:flex;justify-content:space-between;width:100%;padding:10px 0;border-bottom:1px solid var(--brd);font-size:.85rem}
.calc-row span:last-child{font-weight:600}
.calc-roi{background:var(--tl);border:1px solid rgba(249,124,43,.2);border-radius:var(--r);padding:16px 24px;width:100%;text-align:center}
.calc-roi .big{font-family:var(--mono);font-size:1.6rem;font-weight:600;color:var(--teal)}
.calc-roi .lab{font-size:.75rem;color:var(--teal);margin-top:2px}

/* ── EDU — magazine layout ── */
.edu{padding:80px 0;background:var(--bg2);border-top:1px solid var(--brd)}
.edu-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;flex-wrap:wrap;gap:16px}
.edu-cats{display:flex;gap:6px}
.ecat{padding:7px 14px;border-radius:99px;font-size:.78rem;font-weight:500;border:1px solid var(--brd);color:var(--tx2);background:transparent;transition:all .2s}
.ecat.on,.ecat:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
html.dark .ecat.on{background:var(--teal);border-color:var(--teal);color:#fff}
.edu-featured{display:grid;grid-template-columns:1.1fr 1fr;gap:var(--gap);margin-bottom:var(--gap)}
.ef-card{border-radius:var(--rl);overflow:hidden;border:1px solid var(--brd);background:var(--bg);transition:transform .35s,box-shadow .35s;position:relative;display:flex;flex-direction:column}
.ef-card:hover{transform:translateY(-3px);box-shadow:0 10px 36px rgba(0,0,0,.06)}
html.dark .ef-card:hover{box-shadow:0 10px 36px rgba(0,0,0,.3)}
.ef-visual{aspect-ratio:16/9;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.ef-visual .ef-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.1) 60%,transparent 100%);z-index:1}
.ef-visual .ef-badge{position:absolute;top:16px;left:16px;z-index:2;padding:5px 12px;border-radius:6px;font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;backdrop-filter:blur(8px)}
.ef-visual .ef-title{position:absolute;bottom:16px;left:16px;right:16px;z-index:2}
.ef-visual .ef-title h3{font-family:var(--serif);font-size:1.25rem;font-weight:700;color:#fff;line-height:1.25;margin-bottom:4px}
.ef-visual .ef-title p{font-size:.76rem;color:rgba(255,255,255,.7);line-height:1.45}
/* pattern backgrounds */
.ev-pattern{position:absolute;inset:0;overflow:hidden}
.ev-pattern .grid-lines{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:32px 32px}
.ev-pattern .circle{position:absolute;border-radius:50%;border:1.5px solid rgba(255,255,255,.1)}
.ev-pattern .glow{position:absolute;border-radius:50%;filter:blur(40px)}
.ev-icon-center{position:relative;z-index:1;font-size:3.5rem;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2))}
/* text-only featured card */
.ef-body{padding:24px;display:flex;flex-direction:column;flex:1}
.ef-meta{display:flex;align-items:center;gap:12px;font-size:.7rem;color:var(--tx3);margin-bottom:10px}
.ef-meta .tag-dot{width:6px;height:6px;border-radius:50%}
.ef-body h4{font-family:var(--serif);font-size:1.1rem;font-weight:700;line-height:1.3;margin-bottom:8px}
.ef-body p{font-size:.82rem;color:var(--tx2);line-height:1.6;flex:1}
.ef-foot{display:flex;justify-content:space-between;align-items:center;padding:14px 24px;border-top:1px solid rgba(0,0,0,.04);font-size:.72rem;color:var(--tx3);margin-top:auto}
html.dark .ef-foot{border-color:rgba(255,255,255,.04)}
.ef-arrow{font-weight:600;color:var(--teal);display:flex;align-items:center;gap:3px;transition:gap .2s}
.ef-card:hover .ef-arrow{gap:6px}
/* small cards grid */
.edu-g{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.ec{border-radius:var(--rl);overflow:hidden;border:1px solid var(--brd);background:var(--bg);display:flex;flex-direction:column;transition:transform .35s,box-shadow .35s}
.ec:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.05)}
html.dark .ec:hover{box-shadow:0 8px 28px rgba(0,0,0,.25)}
.ec-visual{aspect-ratio:16/9;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.ec-visual .ev-icon{position:relative;z-index:1;font-size:2.5rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.15))}
.ec-body{padding:16px;flex:1;display:flex;flex-direction:column}
.ec-tag{font-size:.6rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:4px}
.ec h4{font-family:var(--serif);font-size:.95rem;font-weight:700;line-height:1.3;margin-bottom:4px}
.ec p{font-size:.76rem;color:var(--tx2);line-height:1.5;flex:1}
.ec-ft{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-top:1px solid rgba(0,0,0,.04);font-size:.68rem;color:var(--tx3)}
html.dark .ec-ft{border-color:rgba(255,255,255,.04)}
.ec-arr{font-weight:600;color:var(--teal);display:flex;align-items:center;gap:3px;transition:gap .2s}
.ec:hover .ec-arr{gap:6px}
/* newsletter */
.edu-nl{margin-top:40px;padding:36px;border-radius:var(--rl);border:1px solid var(--brd);background:var(--bg);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.edu-nl-text h4{font-family:var(--serif);font-size:1.1rem;font-weight:700;margin-bottom:4px}
.edu-nl-text p{font-size:.85rem;color:var(--tx2)}
.edu-nl-form{display:flex;gap:8px}
.edu-nl-form input{padding:11px 16px;border:1.5px solid var(--brd);border-radius:99px;font-family:var(--sans);font-size:.85rem;color:var(--tx);background:var(--bg2);outline:none;min-width:220px;transition:border-color .2s}
.edu-nl-form input:focus{border-color:var(--teal)}

/* ── BLOG — Insights & Mercado ── */
.blog{padding:80px 0;border-top:1px solid var(--brd)}
.blog-dash{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:32px 0 40px;padding:20px;border-radius:var(--rl);border:1px solid var(--brd);background:var(--bg2);position:relative;overflow:hidden}
.blog-dash::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(249,124,43,.03),transparent 60%);pointer-events:none}
.bd-card{padding:14px;border-radius:var(--r);border:1px solid var(--brd);background:var(--bg);text-align:center;transition:border-color .3s}
.bd-card:hover{border-color:var(--teal)}
.bd-label{font-size:.58rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--tx3);margin-bottom:2px}
.bd-val{font-family:var(--mono);font-size:1.35rem;font-weight:600;line-height:1.2}
.bd-change{font-size:.65rem;font-weight:600;margin-top:2px;display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:99px}
.bd-up{color:#8B3E22;background:#DCFCE7}
.bd-down{color:#991B1B;background:#FEE2E2}
.bd-neutral{color:var(--tx3);background:var(--sand)}
html.dark .bd-up{color:#4ade80;background:rgba(22,101,52,.2)}
html.dark .bd-down{color:#f87171;background:rgba(153,27,27,.2)}
.bd-src{font-size:.56rem;color:var(--tx3);text-align:center;margin-top:8px}
.blog-cats{display:flex;gap:6px;margin-bottom:24px;flex-wrap:wrap}
.bc-cat{padding:7px 14px;border-radius:99px;font-size:.78rem;font-weight:500;border:1px solid var(--brd);color:var(--tx2);background:transparent;transition:all .2s;cursor:pointer}
.bc-cat.on,.bc-cat:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
html.dark .bc-cat.on{background:var(--teal);border-color:var(--teal);color:#fff}
.blog-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}
.blog-feat{grid-column:span 2;display:grid;grid-template-columns:1.2fr 1fr;border-radius:var(--rl);overflow:hidden;border:1px solid var(--brd);background:var(--bg2);transition:transform .3s,box-shadow .3s}
.blog-feat:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.05)}
html.dark .blog-feat:hover{box-shadow:0 8px 28px rgba(0,0,0,.25)}
.bf-visual{position:relative;overflow:hidden;min-height:280px}
.bf-visual img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.bf-body{padding:28px;display:flex;flex-direction:column;justify-content:center}
.bf-badge{display:inline-flex;align-items:center;gap:5px;font-size:.62rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:4px 10px;border-radius:6px;margin-bottom:10px;width:fit-content}
.bf-body h3{font-family:var(--serif);font-size:1.2rem;font-weight:700;line-height:1.25;margin-bottom:8px}
.bf-body p{font-size:.84rem;color:var(--tx2);line-height:1.6;margin-bottom:12px}
.bf-meta{font-size:.7rem;color:var(--tx3);display:flex;gap:12px;align-items:center;margin-top:auto}
.ba-card2{border-radius:var(--rl);overflow:hidden;border:1px solid var(--brd);background:var(--bg2);display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.ba-card2:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.05)}
html.dark .ba-card2:hover{box-shadow:0 8px 28px rgba(0,0,0,.25)}
.ba-card2 .bc-visual{position:relative;overflow:hidden;height:180px;flex-shrink:0}
.ba-card2 .bc-visual img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .4s}
.ba-card2:hover .bc-visual img{transform:scale(1.03)}
.ba-card2 .bc-body{padding:16px 18px;flex:1;display:flex;flex-direction:column;gap:4px}
.ba-card2 .bc-tag{font-size:.6rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.ba-card2 h4{font-family:var(--serif);font-size:.88rem;font-weight:700;line-height:1.3;color:var(--fg)}
.ba-card2 p{font-size:.78rem;color:var(--tx2);line-height:1.5;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.ba-card2 .bc-foot{display:flex;justify-content:space-between;align-items:center;padding:10px 18px;border-top:1px solid var(--brd);font-size:.68rem;color:var(--tx3);margin-top:auto}
html.dark .ba-card2 .bc-foot{border-color:rgba(255,255,255,.06)}
.bc-arrow{font-weight:600;color:var(--teal);transition:gap .2s;display:flex;align-items:center;gap:3px}
.ba-card2:hover .bc-arrow{gap:6px}
@media(max-width:1024px){.blog-dash{grid-template-columns:repeat(3,1fr)}.blog-feat{grid-template-columns:1fr}.bf-visual{min-height:220px}}
@media(max-width:768px){.blog-dash{grid-template-columns:1fr 1fr}.blog-grid{grid-template-columns:1fr}.blog-feat{grid-column:span 1}.ba-card2 .bc-visual{height:200px}}

/* ── SEGMENTS — carousel + tabs ── */
.seg{padding:80px 0;background:var(--bg2);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd)}
.seg-tabs{display:flex;gap:6px;margin:28px 0 24px;flex-wrap:wrap;justify-content:center}
.sg-tab{padding:8px 16px;border-radius:99px;font-size:.78rem;font-weight:500;border:1.5px solid var(--brd);color:var(--tx2);background:transparent;transition:all .25s;cursor:pointer;white-space:nowrap}
.sg-tab.on{background:var(--ink);color:var(--cream);border-color:var(--ink)}
html.dark .sg-tab.on{background:var(--teal);color:#fff;border-color:var(--teal)}
.sg-tab:hover:not(.on){border-color:var(--tx3)}
.seg-scroll{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--gap);padding:4px 0 16px}
.sc{border-radius:var(--rl);border:1px solid var(--brd);background:var(--card);overflow:hidden;transition:transform .35s,border-color .35s,box-shadow .35s;display:flex;flex-direction:column}
.sc.hidden{display:none}
.sc:hover{transform:translateY(-3px);border-color:rgba(249,124,43,.3);box-shadow:0 8px 24px rgba(0,0,0,.06)}
html.dark .sc:hover{box-shadow:0 8px 24px rgba(0,0,0,.2)}
.sc:hover{transform:translateY(-3px);border-color:var(--teal);box-shadow:0 10px 32px rgba(249,124,43,.08)}
html.dark .sc:hover{box-shadow:0 10px 32px rgba(249,124,43,.12)}
.sc-header{padding:18px 22px 14px;position:relative;overflow:hidden;display:flex;flex-direction:column;gap:8px;border-bottom:1px solid var(--brd)}
.sc-header .sc-bg{display:none}
.sc-header .sc-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;position:relative;z-index:1;border:1px solid var(--brd);background:var(--bg)}
.sc-header h3{font-family:var(--serif);font-size:1.05rem;font-weight:700;position:relative;z-index:1;line-height:1.25;color:var(--fg) !important}
.sc-header .sc-porte{font-size:.58rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:3px 10px;border-radius:99px;position:absolute;top:14px;right:14px;z-index:1;border:1px solid var(--brd);background:var(--bg);color:var(--muted)}
.sc-body{padding:16px 22px 20px;flex:1;display:flex;flex-direction:column}
.sc-body>p{font-size:.8rem;color:var(--tx2);line-height:1.55;margin-bottom:12px;flex:1}
.sc-mods{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:14px}
.sc-mod{font-size:.6rem;font-weight:600;padding:3px 8px;border-radius:99px;border:1px solid var(--brd);color:var(--tx2);background:var(--bg2);transition:background .2s}
.sc:hover .sc-mod{background:var(--tl);border-color:rgba(249,124,43,.15);color:var(--teal)}
.sc-use{font-size:.7rem;color:var(--tx3);margin-bottom:10px;display:flex;align-items:center;gap:5px}
.sc-use strong{color:var(--tx2)}
.sc-cta{font-size:.78rem;font-weight:600;color:var(--teal);display:flex;align-items:center;gap:4px;transition:gap .2s;cursor:pointer;margin-top:auto}
.sc:hover .sc-cta{gap:8px}
.sc-ai{font-size:.68rem;color:var(--teal);background:rgba(249,124,43,.06);border:1px solid rgba(249,124,43,.1);padding:6px 10px;border-radius:8px;margin-bottom:10px;line-height:1.45;display:flex;align-items:flex-start;gap:6px}
.sc-ai::before{content:'✦';font-size:.7rem;flex-shrink:0;margin-top:1px}
.seg-hint{text-align:center;margin-top:8px;font-size:.7rem;color:var(--tx3);display:flex;align-items:center;justify-content:center;gap:6px}
@media(max-width:768px){.seg-scroll{grid-template-columns:1fr}}

/* ── COMPARE ── */
.cmp{padding:80px 0}
.cmp-wrap{margin-top:36px;border-radius:var(--rl);border:1px solid var(--brd);overflow:hidden;background:var(--bg2)}
.cmp-table{width:100%;border-collapse:collapse;font-size:.82rem}
.cmp-table thead th{padding:14px 16px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--tx3);text-align:center;border-bottom:2px solid var(--brd);background:var(--bg)}
.cmp-table thead th:first-child{text-align:left;width:180px}
.cmp-table thead th.hl{background:var(--tl);color:var(--teal);border-bottom-color:var(--teal);position:relative}
.cmp-table thead th.hl::before{content:'RECOMENDADO';position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--teal);color:#fff;font-size:.5rem;font-weight:700;letter-spacing:.06em;padding:2px 10px;border-radius:0 0 6px 6px}
.cmp-table tbody td{padding:12px 16px;text-align:center;border-bottom:1px solid var(--brd);color:var(--tx2);vertical-align:middle}
.cmp-table tbody td:first-child{text-align:left;font-weight:600;color:var(--tx);font-size:.84rem}
.cmp-table tbody td.hl{background:rgba(249,124,43,.03)}
html.dark .cmp-table tbody td.hl{background:rgba(249,124,43,.06)}
.cmp-table tbody tr:last-child td{border-bottom:none}
.cmp-table tbody tr:hover td{background:rgba(0,0,0,.01)}html.dark .cmp-table tbody tr:hover td{background:rgba(255,255,255,.02)}
.cmp-table tbody tr:hover td.hl{background:rgba(249,124,43,.06)}
.cmp-yes{color:var(--teal);font-weight:700;font-size:.95rem}.cmp-no{color:var(--tx3);font-size:.85rem}.cmp-partial{color:var(--amber);font-weight:600;font-size:.85rem}
.cmp-rank{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;font-size:.72rem;font-weight:800;font-family:var(--mono)}
.cmp-rank.r1{background:linear-gradient(135deg,#f97c2b,#14b89c);color:#fff;box-shadow:0 2px 8px rgba(249,124,43,.3)}
.cmp-rank.r2{background:var(--sand);color:var(--ink2)}
.cmp-rank.r3{background:var(--sand);color:var(--tx3)}
.cmp-rank.r4{background:var(--sand);color:var(--tx3)}
.cmp-rank.r5{background:var(--sand);color:var(--tx3);opacity:.6}
html.dark .cmp-rank.r2,html.dark .cmp-rank.r3,html.dark .cmp-rank.r4{background:var(--stone);color:var(--tx2)}
html.dark .cmp-rank.r5{background:var(--stone);color:var(--tx3)}
.cmp-header-sub{display:block;font-size:.52rem;font-weight:500;letter-spacing:.02em;color:var(--tx3);margin-top:2px;text-transform:none}
.cmp-table thead th.hl .cmp-header-sub{color:rgba(249,124,43,.7)}
.cmp-score{margin-top:16px;display:grid;grid-template-columns:repeat(5,1fr);gap:10px;max-width:800px;margin-left:auto;margin-right:auto}
.cmp-sc{text-align:center;padding:16px 10px;border-radius:var(--r);border:1px solid var(--brd);background:var(--bg);transition:border-color .3s}
.cmp-sc:first-child{border-color:var(--teal);background:var(--tl)}
html.dark .cmp-sc:first-child{background:rgba(249,124,43,.08)}
.cmp-sc-pos{font-family:var(--mono);font-size:1.6rem;font-weight:700;line-height:1}
.cmp-sc-label{font-size:.65rem;font-weight:600;color:var(--tx3);margin-top:4px;text-transform:uppercase;letter-spacing:.03em}
.cmp-sc-score{font-family:var(--mono);font-size:.78rem;color:var(--tx2);margin-top:2px}
@media(max-width:768px){.cmp-score{grid-template-columns:repeat(3,1fr)}}
.cmp-note{text-align:center;margin-top:16px;font-size:.72rem;color:var(--tx3);font-style:italic}
@media(max-width:768px){.cmp-wrap{overflow-x:auto}.cmp-table{min-width:640px}}

/* ── CHANGELOG ── */
.clog{padding:80px 0;background:var(--bg2);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd)}
.clog-line{position:relative;max-width:700px;margin:36px auto 0;padding-left:32px}
.clog-line::before{content:'';position:absolute;left:11px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--teal),var(--brd));border-radius:2px}
.clog-item{position:relative;padding:0 0 32px;animation:fadeUp .5s ease}
.clog-item:last-child{padding-bottom:0}
.clog-dot{position:absolute;left:-28px;top:4px;width:14px;height:14px;border-radius:50%;border:3px solid var(--bg2);z-index:1}
.clog-dot.live{background:var(--teal)}
.clog-dot.dev{background:var(--amber)}
.clog-dot.plan{background:var(--violet)}
.clog-date{font-size:.65rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--tx3);margin-bottom:3px}
.clog-item h4{font-family:var(--serif);font-size:1rem;font-weight:700;margin-bottom:4px;display:flex;align-items:center;gap:8px}
.clog-item h4 .clog-badge{font-size:.55rem;font-weight:700;padding:2px 8px;border-radius:99px;letter-spacing:.03em}
.clog-item p{font-size:.82rem;color:var(--tx2);line-height:1.55}
.clog-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.clog-tag{font-size:.6rem;font-weight:500;padding:2px 8px;border-radius:99px;border:1px solid var(--brd);color:var(--tx3)}

/* ── SOCIAL PROOF / DEPOIMENTOS ── */
.proof{padding:80px 0}
.proof-feat{display:grid;grid-template-columns:1.2fr 1fr;gap:0;margin:36px 0 28px;border-radius:18px;border:1px solid var(--brd);background:var(--card);position:relative;overflow:hidden}
.pf-accent{position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--teal),#3B82F6,#8B5CF6,#EC4899);border-radius:18px 18px 0 0}
.pf-left{padding:36px 32px}
.pf-badge{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--teal);background:rgba(249,124,43,.06);padding:4px 10px;border-radius:6px;display:inline-block;margin-bottom:14px}
.pf-left .proof-quote{font-size:1.05rem;line-height:1.6;font-style:italic;margin-bottom:20px}
.pf-right{padding:36px 32px;background:linear-gradient(135deg,rgba(249,124,43,.03),rgba(59,130,246,.02));border-left:1px solid var(--brd);display:flex;flex-direction:column;justify-content:center;gap:20px}
.pf-metrics{display:flex;gap:16px}
.pf-metric{flex:1;text-align:center;padding:14px 8px;border-radius:12px;background:var(--card);border:1px solid var(--brd)}
.pf-val{font-family:var(--mono);font-size:1.3rem;font-weight:800;color:var(--teal)}
.pf-lab{font-size:.65rem;color:var(--muted);margin-top:3px;line-height:1.3}
.pf-company{font-size:.68rem;color:var(--muted);margin-top:1px}
.pf-modules{display:flex;flex-wrap:wrap;gap:5px}
.pf-modules span{padding:4px 10px;border-radius:6px;font-size:.62rem;font-weight:600;background:var(--bg);border:1px solid var(--brd);color:var(--muted)}
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.proof-card{padding:24px;border-radius:16px;border:1px solid var(--brd);background:var(--card);position:relative;display:flex;flex-direction:column;transition:transform .3s,border-color .3s,box-shadow .3s}
.proof-card:hover{transform:translateY(-3px);border-color:rgba(249,124,43,.25);box-shadow:0 8px 24px rgba(0,0,0,.05)}
html.dark .proof-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.3)}
.proof-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px;gap:8px}
.proof-stars{display:flex;gap:2px;flex-shrink:0}
.proof-quote{font-size:.86rem;font-style:italic;line-height:1.6;color:var(--fg);flex:1;margin-bottom:16px;position:relative;padding-left:16px;border-left:2px solid rgba(249,124,43,.2)}
.proof-result{padding:6px 10px;border-radius:8px;background:var(--tl);display:inline-flex;align-items:center;gap:6px;flex-shrink:0}
html.dark .proof-result{background:rgba(249,124,43,.08)}
.proof-result .pr-val{font-family:var(--mono);font-size:.82rem;font-weight:700;color:var(--teal)}
.proof-result .pr-label{font-size:.62rem;color:var(--muted);max-width:100px;line-height:1.2}
.proof-author{display:flex;align-items:center;gap:10px;margin-top:auto}
.proof-av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#fff;flex-shrink:0}
.proof-info .pf-name{font-size:.82rem;font-weight:600}
.proof-info .pf-role{font-size:.68rem;color:var(--muted)}
.proof-summary{display:flex;align-items:center;justify-content:center;gap:28px;margin-top:32px;padding:22px 32px;border-radius:16px;border:1px solid var(--brd);background:var(--card)}
.ps-item{text-align:center}
.ps-val{font-family:var(--mono);font-size:1.15rem;font-weight:800;color:var(--teal)}
.ps-lab{font-size:.65rem;color:var(--muted);margin-top:2px}
.ps-divider{width:1px;height:32px;background:var(--brd)}
@media(max-width:1024px){.proof-grid{grid-template-columns:1fr 1fr}.proof-feat{grid-template-columns:1fr}.pf-right{border-left:none;border-top:1px solid var(--brd)}}
@media(max-width:768px){.proof-grid{grid-template-columns:1fr}.proof-summary{flex-wrap:wrap;gap:16px}.ps-divider{display:none}.pf-metrics{flex-wrap:wrap}.proof-card-top{flex-direction:column}}

/* ── STATS COUNTER ── */
.stats{padding:48px 0;border-bottom:1px solid var(--brd)}
.stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
.stat-card{text-align:center;padding:20px 10px;border-radius:var(--rl);border:1px solid var(--brd);background:var(--bg2);transition:border-color .3s,transform .3s}
.stat-card:hover{border-color:var(--teal);transform:translateY(-2px)}
.stat-val{font-family:var(--mono);font-size:clamp(1.4rem,3vw,2rem);font-weight:700;color:var(--teal);line-height:1}
.stat-label{font-size:.68rem;color:var(--tx2);margin-top:4px;line-height:1.3}
.stat-icon{font-size:1.3rem;margin-bottom:6px;display:block}
@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.stats-grid{grid-template-columns:repeat(2,1fr)}}

/* ── ARCHITECTURE / SECURITY ── */
.arq{padding:80px 0;background:var(--bg2);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd)}
.arq-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:36px;align-items:start}
.arq-diagram{border-radius:var(--rl);border:1px solid var(--brd);background:var(--bg);padding:28px;position:relative;overflow:hidden}
.arq-diagram::before{content:'';position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 width=%2232%22 height=%2232%22><rect width=%2232%22 height=%2232%22 fill=%22none%22 stroke=%22%23E5DFD5%22 stroke-width=%220.3%22/></svg>') repeat;opacity:.3}
html.dark .arq-diagram::before{opacity:.08}
.arq-layers{position:relative;z-index:1;display:flex;flex-direction:column;gap:8px}
.arq-layer{padding:14px 18px;border-radius:var(--r);border:1.5px solid var(--brd);background:var(--bg2);display:flex;align-items:center;gap:12px;transition:border-color .3s,transform .2s}
.arq-layer:hover{border-color:var(--teal);transform:translateX(4px)}
.arq-layer .al-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.arq-layer .al-name{font-size:.82rem;font-weight:600}
.arq-layer .al-desc{font-size:.7rem;color:var(--tx2)}
.arq-conn{text-align:center;font-size:.6rem;color:var(--tx3);padding:2px 0;letter-spacing:.1em}
.arq-features{display:flex;flex-direction:column;gap:12px}
.arq-feat{display:flex;gap:14px;padding:20px;border-radius:var(--rl);border:1px solid var(--brd);background:var(--bg);transition:border-color .3s}
.arq-feat:hover{border-color:var(--teal)}
.arq-feat .af-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.arq-feat h4{font-size:.9rem;font-weight:700;margin-bottom:3px}
.arq-feat p{font-size:.78rem;color:var(--tx2);line-height:1.5}
@media(max-width:768px){.arq-layout{grid-template-columns:1fr}}

/* ── GUARANTEES / SLA ── */
.sla{padding:80px 0}
.sla-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap);margin-top:36px}
.sla-card{padding:28px 22px;border-radius:var(--rl);border:2px solid var(--brd);background:var(--bg2);text-align:center;position:relative;transition:transform .3s,border-color .3s}
.sla-card:hover{transform:translateY(-3px);border-color:var(--teal)}
.sla-icon{font-size:2rem;margin-bottom:10px;display:block}
.sla-card h4{font-family:var(--serif);font-size:.95rem;font-weight:700;margin-bottom:6px}
.sla-card p{font-size:.78rem;color:var(--tx2);line-height:1.5}
.sla-badge{display:inline-block;margin-top:12px;font-size:.65rem;font-weight:700;padding:4px 12px;border-radius:99px;letter-spacing:.03em}
.sla-promise{margin-top:32px;padding:24px 32px;border-radius:var(--rl);border:2px solid var(--teal);background:var(--tl);display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
html.dark .sla-promise{background:rgba(249,124,43,.08)}
.sla-promise-text{font-family:var(--serif);font-size:1rem;font-weight:700}
.sla-promise-text em{color:var(--teal);font-style:italic}
@media(max-width:1024px){.sla-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.sla-grid{grid-template-columns:1fr}}

/* ── FAQ — rich ── */
.faq{padding:80px 0}
.faq-head{text-align:center;margin-bottom:12px}
.faq-cats{display:flex;justify-content:center;gap:6px;margin-bottom:32px;flex-wrap:wrap}
.fq-cat{padding:7px 16px;border-radius:99px;font-size:.78rem;font-weight:500;border:1px solid var(--brd);color:var(--tx2);background:transparent;transition:all .2s;cursor:pointer}
.fq-cat.on,.fq-cat:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
html.dark .fq-cat.on{background:var(--teal);border-color:var(--teal);color:#fff}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);max-width:900px;margin:0 auto}
.faq-it{border:1px solid var(--brd);border-radius:var(--rl);overflow:hidden;background:var(--bg2);transition:border-color .3s}
.faq-it:hover{border-color:var(--teal)}
.faq-it.open-card{border-color:var(--teal)}
.faq-q{width:100%;padding:18px 20px;text-align:left;display:flex;justify-content:space-between;align-items:center;background:none;border:none;font-size:.88rem;font-weight:600;color:var(--tx);gap:12px;line-height:1.35;cursor:pointer}
.faq-q .q-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0;transition:background .3s}
.faq-q .arr{transition:transform .3s;color:var(--tx3);font-size:.8rem;flex-shrink:0;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg);border:1px solid var(--brd)}
.faq-q.open .arr{transform:rotate(180deg);background:var(--tl);border-color:var(--teal);color:var(--teal)}
.faq-a{display:none;padding:0 20px 18px;font-size:.84rem;color:var(--tx2);line-height:1.7}
.faq-a.show{display:block;animation:fadeUp .3s ease}
.faq-a strong{color:var(--tx);font-weight:600}
.faq-a ul{margin:8px 0 0 16px;display:flex;flex-direction:column;gap:4px;list-style:none}
.faq-a ul li{position:relative;padding-left:16px;font-size:.82rem}
.faq-a ul li::before{content:'→';position:absolute;left:0;color:var(--teal);font-size:.7rem;top:2px}
.faq-cta{text-align:center;margin-top:36px;padding:28px;border-radius:var(--rl);border:1px solid var(--brd);background:var(--bg2)}
.faq-cta p{font-size:.9rem;color:var(--tx2);margin-bottom:12px}
.faq-cta p strong{color:var(--tx)}
@media(max-width:768px){.faq-grid{grid-template-columns:1fr}}

/* ── DEMO CTA (replaces pricing) ── */
.demo-cta{padding:80px 0;background:var(--bg2);border-top:1px solid var(--brd)}
.demo-box{display:grid;grid-template-columns:1.15fr 1fr;border-radius:var(--rl);overflow:hidden;border:1px solid var(--brd)}
.demo-left{padding:52px 48px;background:var(--bg)}
.demo-left-ey{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;color:var(--teal);margin-bottom:16px;padding:5px 12px;background:var(--tl);border-radius:99px}
.demo-left-ey svg{color:var(--teal)}
.demo-left h2{font-family:var(--serif);font-size:clamp(1.4rem,2.8vw,2.2rem);font-weight:700;line-height:1.15;margin-bottom:12px}
.demo-left>p{font-size:.92rem;color:var(--tx2);line-height:1.65;margin-bottom:24px;max-width:420px}
.demo-form{display:flex;flex-direction:column;gap:10px}
.demo-form label{font-size:.75rem;font-weight:600;color:var(--tx2);margin-bottom:2px}
.demo-form input,.demo-form select,.demo-form textarea{padding:11px 14px;border:1.5px solid var(--brd);border-radius:var(--r);font-family:var(--sans);font-size:.86rem;color:var(--tx);background:var(--bg2);outline:none;transition:border-color .25s,box-shadow .25s;width:100%}
.demo-form input:focus,.demo-form select:focus,.demo-form textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(249,124,43,.08)}
.demo-form .btn{margin-top:6px;display:inline-flex;align-items:center;justify-content:center}
.demo-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.demo-trust-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:8px}
.demo-trust-row span{font-size:.68rem;color:var(--tx3);display:flex;align-items:center;gap:4px}
.demo-right{background:linear-gradient(135deg,var(--teal) 0%,#D46620 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;min-height:300px;padding:44px 36px}
.demo-right::before{content:'';position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.04);top:-80px;right:-80px}
.demo-right::after{content:'';position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.03);bottom:-40px;left:-40px}
.demo-right h3{font-family:var(--serif);font-size:1.4rem;font-weight:700;color:#fff;margin-bottom:28px;text-align:center;position:relative;z-index:1;line-height:1.2}
.demo-timeline{display:flex;flex-direction:column;gap:0;position:relative;z-index:1;width:100%;max-width:280px;margin-bottom:28px}
.demo-tl-item{display:flex;gap:14px;align-items:flex-start;padding-bottom:18px;position:relative}
.demo-tl-item:last-child{padding-bottom:0}
.demo-tl-item:not(:last-child)::after{content:'';position:absolute;left:6px;top:16px;width:1.5px;height:calc(100% - 8px);background:rgba(255,255,255,.2)}
.demo-tl-dot{width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.25);border:2px solid #fff;flex-shrink:0;margin-top:2px}
.demo-tl-content{display:flex;flex-direction:column;gap:1px}
.demo-tl-content strong{font-size:.78rem;color:#fff;font-weight:600}
.demo-tl-content span{font-size:.7rem;color:rgba(255,255,255,.6);line-height:1.35}
.demo-sts{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;position:relative;z-index:1;width:100%;max-width:280px}
.demo-st{text-align:center;padding:10px 6px;border-radius:10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1)}
.demo-st-v{font-family:var(--mono);font-size:1.2rem;font-weight:600;color:#fff}
.demo-st-l{font-size:.62rem;color:rgba(255,255,255,.55);margin-top:1px}
/* Contact channels */
.contact-channels{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px}
.cc-item{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:var(--r);border:1px solid var(--brd);background:var(--bg2);text-decoration:none;color:var(--tx);transition:all .25s}
.cc-item:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.06)}
.cc-ico{font-size:1.3rem}
.cc-item strong{display:block;font-size:.82rem;font-weight:600}
.cc-item span{font-size:.7rem;color:var(--tx3)}

/* ── FOOTER ── */
footer{padding:48px 0 22px;border-top:1px solid var(--brd)}
.ft-top{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
.ft-brand p{font-size:.8rem;color:var(--tx2);margin-top:8px;line-height:1.6;max-width:280px}
.ft-col h5{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--tx3);margin-bottom:10px}
.ft-col a{display:block;font-size:.8rem;color:var(--tx2);padding:2px 0;transition:color .2s}.ft-col a:hover{color:var(--tx)}
.ft-bot{display:flex;justify-content:space-between;padding-top:14px;border-top:1px solid var(--brd);font-size:.72rem;color:var(--tx3);flex-wrap:wrap;gap:8px}

/* ── MODAL ── */
.modal-bg{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.5);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;padding:20px}
.modal-bg.open{opacity:1;pointer-events:auto}
.modal{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--rl);padding:36px;max-width:420px;width:100%;position:relative;max-height:90vh;overflow-y:auto}
.modal h3{font-family:var(--serif);font-size:1.3rem;font-weight:700;margin-bottom:4px}
.modal .sub{font-size:.82rem;color:var(--tx2);margin-bottom:20px}
.modal label{font-size:.76rem;font-weight:600;color:var(--tx2);display:block;margin-bottom:4px}
.modal input,.modal select{width:100%;padding:10px 14px;border:1.5px solid var(--brd);border-radius:var(--r);font-family:var(--sans);font-size:.85rem;color:var(--tx);background:var(--bg);outline:none;margin-bottom:4px;transition:border-color .25s,box-shadow .25s}
.modal input:focus,.modal select:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(249,124,43,.08)}
.modal-x{position:absolute;top:14px;right:14px;background:none;border:none;font-size:1.2rem;color:var(--tx2)}
.modal .err{font-size:.72rem;color:var(--coral);margin-top:0;margin-bottom:8px;display:none}
/* validation states */
.fg{position:relative;margin-bottom:0}
.fg .vicon{position:absolute;right:12px;top:34px;font-size:.85rem;opacity:0;transition:opacity .25s;pointer-events:none}
.fg.valid input{border-color:var(--teal)}
.fg.valid .vicon{opacity:1;color:var(--teal)}
.fg.invalid input{border-color:var(--coral)}
.fg.invalid .vicon{opacity:1;color:var(--coral)}
.fg .hint{font-size:.68rem;color:var(--tx3);margin:0 0 8px;min-height:16px;transition:color .2s}
.fg.invalid .hint{color:var(--coral)}
.fg.valid .hint{color:var(--teal)}
/* demo inline form validation */
.demo-form .fg{margin-bottom:0}
.demo-form .fg .vicon{top:30px}
.demo-form input,.demo-form select{transition:border-color .25s,box-shadow .25s}
.demo-form input:focus,.demo-form select:focus{box-shadow:0 0 0 3px rgba(249,124,43,.08)}
.demo-form .fg.valid input{border-color:var(--teal)}
.demo-form .fg.invalid input{border-color:var(--coral)}
/* disabled submit */
.btn-submit[disabled]{opacity:.5;cursor:not-allowed;pointer-events:none}

/* TOAST */
.toast{position:fixed;bottom:24px;right:24px;background:var(--teal);color:#fff;padding:14px 24px;border-radius:var(--r);font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:8px;transform:translateY(80px);opacity:0;transition:all .35s;z-index:300;box-shadow:0 8px 24px rgba(249,124,43,.3)}
.toast.show{transform:translateY(0);opacity:1}

/* WHATSAPP FAB */
.wa-fab{position:fixed;bottom:24px;left:24px;z-index:80;width:52px;height:52px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.35);transition:transform .3s;border:none;text-decoration:none}
.wa-fab:hover{transform:scale(1.1)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .hero-sub{grid-template-columns:1fr;gap:24px}
  .c-h{grid-column:span 12}.c-s{grid-column:span 6}.c-w{grid-column:span 6}
  .ba-grid{grid-template-columns:1fr}
  .mc.show{grid-template-columns:1fr}
  .calc-grid{grid-template-columns:1fr}.calc-left{border-right:none;border-bottom:1px solid var(--brd)}
  .edu-g{grid-template-columns:1fr 1fr}.edu-featured{grid-template-columns:1fr}
  .demo-box{grid-template-columns:1fr}
  .ft-top{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nlinks,.ncta{display:none}.hambg{display:block}
  .c-h,.c-s,.c-w{grid-column:span 12}
  .ui-bd{grid-template-columns:1fr}.ui-sb{display:none}
  .edu-g{grid-template-columns:1fr}
  .edu-nl{flex-direction:column;text-align:center}
  .edu-nl-form{flex-direction:column;width:100%}
  .edu-nl-form input{min-width:0;width:100%}
  .edu-nl-form .btn{width:100%}
  .ft-top{grid-template-columns:1fr}.ft-bot{flex-direction:column}
  .trust-inner{gap:16px}
  .demo-box{grid-template-columns:1fr}
  .demo-right{min-height:auto;padding:32px 28px}
  .demo-form-row{grid-template-columns:1fr}
  .contact-channels{grid-template-columns:1fr}
}
@media(max-width:480px){
  .hero h1{font-size:2rem}
  .demo-left{padding:32px 20px}
  .demo-right{padding:32px 20px}
  .calc-left,.calc-right{padding:24px}
  .roadmap-grid{grid-template-columns:1fr 1fr}
}

/* ═══════════════════════════════════════════════════════════════
   FEATURE 1: CONTADOR DE DESPERDÍCIO (waste ticker)
   ═══════════════════════════════════════════════════════════════ */
.waste-bar{background:linear-gradient(135deg,rgba(249,124,43,.06),rgba(59,130,246,.04));border-bottom:1px solid rgba(249,124,43,.12);padding:10px 0;position:relative;overflow:hidden;z-index:99}
html.dark .waste-bar{background:linear-gradient(135deg,#1a1a2e,#16213e);border-bottom-color:rgba(232,99,74,.15)}
.waste-bar::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(249,124,43,.03),transparent);animation:wastePulse 3s ease infinite}
@keyframes wastePulse{0%,100%{opacity:.3}50%{opacity:1}}
.waste-inner{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;font-size:.82rem;color:var(--tx2)}
html.dark .waste-inner{color:rgba(255,255,255,.7)}
.waste-icon{font-size:1.1rem;animation:wasteBurn 1.5s ease infinite}
@keyframes wasteBurn{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.waste-amount{font-family:var(--mono);font-size:1.15rem;font-weight:700;color:#E8634A;min-width:140px;text-align:center;letter-spacing:-.5px}
.waste-cta{color:#f97c2b;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s}
.waste-cta:hover{color:#3B82F6;text-decoration:underline}
.waste-close{background:none;border:none;color:var(--tx2);cursor:pointer;font-size:1rem;padding:4px 8px;transition:color .2s}
.waste-close:hover{color:var(--tx)}
html.dark .waste-close{color:rgba(255,255,255,.3)}
html.dark .waste-close:hover{color:#fff}

/* ═══════════════════════════════════════════════════════════════
   FEATURE 2: MAPA DE CALOR DO ECOSSISTEMA
   ═══════════════════════════════════════════════════════════════ */
.eco-map{padding:80px 0;background:var(--bg)}
.eco-map h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.eco-map .eco-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.eco-svg-wrap{position:relative;max-width:900px;margin:0 auto;aspect-ratio:16/10}
.eco-svg-wrap svg{width:100%;height:100%}
.eco-node{cursor:pointer;transition:all .3s ease}
.eco-node:hover .eco-node-bg{filter:brightness(1.3);transform:scale(1.08)}
.eco-node-bg{transition:all .3s;rx:12}
.eco-node text{font-family:var(--sans);font-size:11px;fill:#fff;pointer-events:none;font-weight:500}
.eco-node .eco-count{font-family:var(--mono);font-size:9px;fill:rgba(255,255,255,.6)}
.eco-link{stroke-width:1.5;fill:none;opacity:.08;transition:opacity .4s}
.eco-link.active{opacity:.6;stroke-width:2.5}
.eco-tooltip{position:absolute;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px 20px;box-shadow:0 20px 40px rgba(0,0,0,.15);pointer-events:none;opacity:0;transition:all .25s;z-index:10;min-width:220px;font-size:.85rem}
.eco-tooltip.show{opacity:1;transform:translateY(-5px)}
.eco-tooltip h4{font-family:var(--serif);margin:0 0 6px;font-size:1rem}
.eco-tooltip .eco-perms{color:var(--teal);font-family:var(--mono);font-size:.8rem;margin-bottom:8px}
.eco-tooltip .eco-conns{color:var(--muted);font-size:.8rem;line-height:1.6}
.eco-legend{display:flex;gap:20px;justify-content:center;margin-top:24px;flex-wrap:wrap}
.eco-legend span{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--muted)}
.eco-legend i{width:12px;height:12px;border-radius:3px;display:inline-block}

/* ═══════════════════════════════════════════════════════════════
   FEATURE 3: SIMULADOR DE OPERAÇÃO AO VIVO (sandbox)
   ═══════════════════════════════════════════════════════════════ */
.sandbox{padding:80px 0;background:var(--bg)}
.sandbox h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.sandbox .sand-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.sand-picker{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:32px}
.sand-picker button{padding:8px 18px;border-radius:100px;border:1px solid var(--border);background:var(--card);color:var(--fg);font-size:.82rem;cursor:pointer;transition:all .25s;font-family:var(--sans)}
.sand-picker button.active{background:var(--teal);color:#fff;border-color:var(--teal);box-shadow:0 4px 15px rgba(249,124,43,.3)}
.sand-screen{max-width:860px;margin:0 auto;background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.08)}
.sand-titlebar{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:10px 16px;display:flex;align-items:center;gap:8px}
.sand-dots{display:flex;gap:6px}
.sand-dots span{width:10px;height:10px;border-radius:50%}
.sand-dots span:nth-child(1){background:#E8634A}
.sand-dots span:nth-child(2){background:#f5a623}
.sand-dots span:nth-child(3){background:#f97c2b}
.sand-titlebar .sand-url{flex:1;text-align:center;font-family:var(--mono);font-size:.72rem;color:rgba(255,255,255,.5)}
.sand-body{display:flex;min-height:400px}
.sand-sidebar{width:200px;border-right:1px solid var(--border);padding:16px 0;background:rgba(0,0,0,.02);flex-shrink:0}
.sand-sidebar a{display:flex;align-items:center;gap:8px;padding:8px 16px;font-size:.8rem;color:var(--muted);cursor:pointer;transition:all .2s;text-decoration:none;border-left:3px solid transparent}
.sand-sidebar a.active{color:var(--teal);background:rgba(249,124,43,.06);border-left-color:var(--teal);font-weight:600}
.sand-sidebar a:hover{color:var(--fg);background:rgba(0,0,0,.03)}
.sand-content{flex:1;padding:24px;position:relative;overflow:hidden}
.sand-step{display:none;animation:sandFadeIn .4s ease}
.sand-step.active{display:block}
@keyframes sandFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.sand-content h3{font-family:var(--serif);font-size:1.1rem;margin:0 0 16px}
.sand-table{width:100%;border-collapse:collapse;font-size:.78rem}
.sand-table th{background:rgba(249,124,43,.08);padding:8px 12px;text-align:left;font-weight:600;border-bottom:2px solid var(--border)}
.sand-table td{padding:8px 12px;border-bottom:1px solid var(--border)}
.sand-badge{display:inline-block;padding:2px 8px;border-radius:100px;font-size:.7rem;font-weight:600}
.sand-badge.green{background:rgba(249,124,43,.1);color:#f97c2b}
.sand-badge.red{background:rgba(232,99,74,.1);color:#E8634A}
.sand-badge.blue{background:rgba(59,130,246,.1);color:#3B82F6}
.sand-mini-chart{height:40px;display:flex;align-items:end;gap:2px}
.sand-mini-chart span{background:var(--teal);border-radius:2px 2px 0 0;flex:1;transition:height .4s ease}
.sand-kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px}
.sand-kpi{background:rgba(249,124,43,.04);border:1px solid var(--border);border-radius:10px;padding:14px;text-align:center}
.sand-kpi .val{font-family:var(--mono);font-size:1.3rem;font-weight:700;color:var(--teal)}
.sand-kpi .lbl{font-size:.7rem;color:var(--muted);margin-top:2px}
.sand-progress{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin:8px 0}
.sand-progress span{display:block;height:100%;border-radius:3px;transition:width 1s ease}
.sand-nav-row{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}
.sand-nav-row button{padding:8px 20px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--fg);cursor:pointer;font-size:.82rem;transition:all .2s}
.sand-nav-row button.primary{background:var(--teal);color:#fff;border-color:var(--teal)}
.sand-nav-row button:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.1)}
.sand-nav-row .step-dots{display:flex;gap:6px}
.sand-nav-row .step-dots span{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .3s}
.sand-nav-row .step-dots span.active{background:var(--teal);width:20px;border-radius:4px}
@media(max-width:768px){.sand-sidebar{display:none}.sand-body{flex-direction:column}}

/* ═══════════════════════════════════════════════════════════════
   FEATURE 4: DIAGNÓSTICO COM IA
   ═══════════════════════════════════════════════════════════════ */
.diag{padding:80px 0;background:linear-gradient(180deg,var(--bg),rgba(249,124,43,.03))}
.diag h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.diag .diag-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.diag-container{max-width:560px;margin:0 auto;background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.06)}
.diag-chat{padding:20px;min-height:220px;max-height:400px;overflow-y:auto;scroll-behavior:smooth}
.diag-msg{margin-bottom:16px;display:flex;gap:10px;animation:diagFade .4s ease}
@keyframes diagFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.diag-msg.bot .diag-avatar{width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,#f97c2b,#3B82F6);display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0;color:#fff}
.diag-msg.user{flex-direction:row-reverse}
.diag-msg .diag-bubble{max-width:80%;padding:12px 16px;border-radius:12px;font-size:.85rem;line-height:1.5}
.diag-msg.bot .diag-bubble{background:rgba(249,124,43,.06);border:1px solid rgba(249,124,43,.12);color:var(--fg)}
.diag-msg.user .diag-bubble{background:var(--teal);color:#fff;border-radius:12px 12px 4px 12px}
.diag-options{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.diag-options button{padding:8px 16px;border-radius:100px;border:1px solid var(--border);background:var(--card);color:var(--fg);font-size:.8rem;cursor:pointer;transition:all .25s}
.diag-options button:hover{border-color:var(--teal);color:var(--teal);background:rgba(249,124,43,.05)}
.diag-typing{display:flex;gap:4px;padding:8px 0}
.diag-typing span{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:diagDot 1.4s infinite}
.diag-typing span:nth-child(2){animation-delay:.2s}
.diag-typing span:nth-child(3){animation-delay:.4s}
@keyframes diagDot{0%,80%,100%{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}
.diag-result{padding:24px;border-top:1px solid var(--border);background:rgba(249,124,43,.02)}
.diag-result h3{font-family:var(--serif);margin:0 0 16px;font-size:1.1rem}
.diag-score-ring{width:100px;height:100px;margin:0 auto 16px}
.diag-modules-rec{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0}
.diag-modules-rec span{padding:4px 10px;border-radius:6px;font-size:.75rem;background:rgba(249,124,43,.08);color:var(--teal);font-weight:500}
.diag-report-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;border-radius:10px;border:none;background:var(--teal);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;margin-top:16px;transition:all .2s}
.diag-report-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(249,124,43,.3)}

/* ═══════════════════════════════════════════════════════════════
   FEATURE 5: RADAR DE MATURIDADE DIGITAL
   ═══════════════════════════════════════════════════════════════ */
.radar{padding:80px 0;background:var(--bg)}
.radar h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.radar .radar-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.radar-container{max-width:800px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.radar-questions{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px}
.radar-q{margin-bottom:20px}
.radar-q label{font-size:.85rem;font-weight:600;display:block;margin-bottom:8px}
.radar-q .radar-slider-wrap{display:flex;align-items:center;gap:12px}
.radar-q input[type="range"]{flex:1;accent-color:var(--teal);height:6px}
.radar-q .radar-val{font-family:var(--mono);font-size:.85rem;font-weight:700;color:var(--teal);min-width:24px;text-align:center}
.radar-chart-wrap{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;text-align:center;position:sticky;top:100px}
.radar-chart-wrap canvas{max-width:100%}
.radar-score-big{font-family:var(--serif);font-size:2.5rem;font-weight:900;background:linear-gradient(135deg,var(--teal),#3B82F6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:8px 0 4px}
.radar-score-label{font-size:.82rem;color:var(--muted)}
.radar-gaps{margin-top:16px;text-align:left}
.radar-gaps h4{font-size:.9rem;margin-bottom:8px}
.radar-gap-item{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:.8rem}
.radar-gap-item .gap-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.radar-share-btn{margin-top:16px;padding:10px 20px;border-radius:8px;border:1px solid var(--teal);background:transparent;color:var(--teal);cursor:pointer;font-size:.82rem;font-weight:600;transition:all .2s;width:100%}
.radar-share-btn:hover{background:var(--teal);color:#fff}
@media(max-width:768px){.radar-container{grid-template-columns:1fr}.radar-chart-wrap{position:static}}

/* ═══════════════════════════════════════════════════════════════
   FEATURE 6: CALCULADORA TCO (3 anos)
   ═══════════════════════════════════════════════════════════════ */
.tco{padding:80px 0;background:linear-gradient(180deg,rgba(249,124,43,.02),var(--bg))}
.tco h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.tco .tco-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.tco-grid{max-width:900px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:32px}
.tco-inputs{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px}
.tco-field{margin-bottom:18px}
.tco-field label{font-size:.82rem;font-weight:600;display:block;margin-bottom:6px}
.tco-field input,.tco-field select{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--fg);font-size:.88rem;font-family:var(--sans)}
.tco-field input:focus,.tco-field select:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 3px rgba(249,124,43,.1)}
.tco-results{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px}
.tco-bar-group{margin-bottom:20px}
.tco-bar-label{display:flex;justify-content:space-between;font-size:.8rem;margin-bottom:6px}
.tco-bar-label .name{font-weight:600}
.tco-bar-label .amount{font-family:var(--mono);color:var(--teal)}
.tco-bar{height:28px;background:var(--border);border-radius:6px;overflow:hidden;position:relative}
.tco-bar span{display:block;height:100%;border-radius:6px;transition:width 1s ease}
.tco-savings{background:linear-gradient(135deg,rgba(249,124,43,.1),rgba(59,130,246,.1));border:1px solid rgba(249,124,43,.2);border-radius:12px;padding:20px;text-align:center;margin-top:20px}
.tco-savings .big{font-family:var(--serif);font-size:2rem;font-weight:900;color:var(--teal)}
.tco-savings .desc{font-size:.82rem;color:var(--muted);margin-top:4px}
.tco-year-tabs{display:flex;gap:4px;margin-bottom:16px}
.tco-year-tabs button{flex:1;padding:8px;border:1px solid var(--border);background:var(--bg);color:var(--fg);border-radius:8px;cursor:pointer;font-size:.8rem;transition:all .2s}
.tco-year-tabs button.active{background:var(--teal);color:#fff;border-color:var(--teal)}
@media(max-width:768px){.tco-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   FEATURE 7: SIMULADOR SEMANA COM vs SEM ERP
   ═══════════════════════════════════════════════════════════════ */
.week-sim{padding:80px 0;background:var(--bg)}
.week-sim h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.week-sim .week-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.week-toggle{display:flex;justify-content:center;margin-bottom:32px}
.week-toggle-pill{display:flex;background:var(--card);border:1px solid var(--border);border-radius:100px;padding:4px;gap:4px}
.week-toggle-pill button{padding:10px 24px;border-radius:100px;border:none;background:transparent;color:var(--muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s}
.week-toggle-pill button.active{background:var(--teal);color:#fff;box-shadow:0 4px 15px rgba(249,124,43,.25)}
.week-timeline{max-width:900px;margin:0 auto;position:relative}
.week-day{display:grid;grid-template-columns:80px 1fr;gap:16px;margin-bottom:24px;align-items:start}
.week-day-label{font-family:var(--serif);font-weight:700;font-size:1rem;padding-top:12px;text-align:right;color:var(--fg)}
.week-day-label small{display:block;font-family:var(--sans);font-size:.7rem;font-weight:400;color:var(--muted)}
.week-tasks{display:flex;flex-direction:column;gap:6px}
.week-task{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:var(--card);font-size:.8rem;transition:all .4s;animation:weekTaskIn .5s ease backwards}
@keyframes weekTaskIn{from{opacity:0;transform:translateX(-15px)}to{opacity:1;transform:translateX(0)}}
.week-task .task-time{font-family:var(--mono);font-size:.72rem;color:var(--muted);min-width:50px}
.week-task .task-icon{font-size:1rem}
.week-task .task-name{flex:1;font-weight:500}
.week-task .task-dur{font-family:var(--mono);font-size:.72rem;padding:3px 8px;border-radius:100px;font-weight:600}
.week-task.pain .task-dur{background:rgba(232,99,74,.1);color:#E8634A}
.week-task.gain .task-dur{background:rgba(249,124,43,.1);color:#f97c2b}
.week-task.saved{border-style:dashed;opacity:.5;text-decoration:line-through}
.week-summary{max-width:900px;margin:20px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.week-summary-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center}
.week-summary-card .val{font-family:var(--mono);font-size:1.5rem;font-weight:700}
.week-summary-card .lbl{font-size:.75rem;color:var(--muted);margin-top:4px}
@media(max-width:768px){.week-day{grid-template-columns:60px 1fr}.week-summary{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   FEATURE 8: STATUS DA PLATAFORMA (uptime)
   ═══════════════════════════════════════════════════════════════ */
.status{padding:80px 0;background:var(--bg)}
.status h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.status .status-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.status-container{max-width:700px;margin:0 auto}
.status-hero-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px;text-align:center;margin-bottom:24px}
.status-indicator{display:inline-flex;align-items:center;gap:10px;padding:10px 24px;border-radius:100px;background:rgba(249,124,43,.08);border:1px solid rgba(249,124,43,.2);margin-bottom:16px}
.status-dot{width:10px;height:10px;border-radius:50%;background:#f97c2b;animation:statusPulse 2s ease infinite}
@keyframes statusPulse{0%,100%{box-shadow:0 0 0 0 rgba(249,124,43,.4)}50%{box-shadow:0 0 0 8px rgba(249,124,43,0)}}
.status-indicator span{font-weight:700;color:#f97c2b;font-size:.95rem}
.status-uptime-big{font-family:var(--serif);font-size:3rem;font-weight:900;background:linear-gradient(135deg,#f97c2b,#3B82F6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.status-uptime-label{font-size:.85rem;color:var(--muted)}
.status-bars{display:flex;gap:2px;height:32px;align-items:end;margin:24px 0 8px}
.status-bars .day-bar{flex:1;border-radius:3px 3px 0 0;transition:all .3s;cursor:pointer;position:relative;min-height:4px}
.status-bars .day-bar.up{background:#f97c2b}
.status-bars .day-bar.partial{background:#f5a623}
.status-bars .day-bar.down{background:#E8634A}
.status-bars .day-bar:hover{filter:brightness(1.2);transform:scaleY(1.1)}
.status-bar-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--muted);margin-bottom:24px}
.status-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.status-metric{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center}
.status-metric .val{font-family:var(--mono);font-size:1.2rem;font-weight:700;color:var(--fg)}
.status-metric .lbl{font-size:.72rem;color:var(--muted);margin-top:4px}
.status-incidents{margin-top:24px}
.status-incidents h3{font-family:var(--serif);font-size:1rem;margin-bottom:12px}
.status-incident{padding:12px 16px;border-left:3px solid #f97c2b;background:var(--card);border-radius:0 10px 10px 0;margin-bottom:8px;font-size:.82rem}
.status-incident.resolved{border-left-color:#f97c2b}
.status-incident .inc-date{font-family:var(--mono);font-size:.72rem;color:var(--muted)}

/* ═══════════════════════════════════════════════════════════════
   DIAGRAMA 1: JORNADA DO USUÁRIO (user journey)
   ═══════════════════════════════════════════════════════════════ */
.journey{padding:80px 0;background:linear-gradient(180deg,var(--bg),rgba(249,124,43,.02))}
.journey h2{text-align:center;font-size:clamp(1.7rem,3vw,2.4rem);font-weight:800;letter-spacing:-.03em;margin-bottom:8px}
.journey .j-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.j-timeline{position:relative;max-width:680px;margin:0 auto;padding:0 0 0 44px}
.j-timeline::before{content:'';position:absolute;left:19px;top:10px;bottom:10px;width:2px;background:linear-gradient(180deg,var(--teal),#3B82F6,#8B5CF6,#EC4899,var(--teal));border-radius:2px}
.j-step{display:flex;align-items:flex-start;gap:20px;margin-bottom:24px;position:relative}
.j-step:last-child{margin-bottom:0}
.j-num{width:38px;height:38px;border-radius:50%;background:var(--bg);border:2.5px solid var(--jc,var(--teal));color:var(--jc,var(--teal));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;flex-shrink:0;position:relative;left:-44px;margin-right:-44px;z-index:2;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.j-final{background:var(--teal) !important;color:#fff !important;border-color:var(--teal) !important;font-size:.9rem}
.j-card{flex:1;background:var(--card);border:1px solid var(--brd);border-radius:12px;padding:18px 20px;transition:border-color .2s,box-shadow .2s}
.j-card:hover{border-color:rgba(249,124,43,.25);box-shadow:0 4px 16px rgba(0,0,0,.04)}
.j-card-final{border-color:var(--teal);background:rgba(249,124,43,.02)}
.j-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:12px}
.j-head h4{font-size:.95rem;font-weight:700;margin:0}
.j-time{font-family:var(--mono);font-size:.68rem;color:var(--teal);white-space:nowrap;padding:2px 8px;border-radius:4px;background:rgba(249,124,43,.06)}
.j-card p{font-size:.82rem;color:var(--muted);line-height:1.5;margin:0 0 8px}
.j-tags{display:flex;flex-wrap:wrap;gap:4px}
.j-tag{padding:2px 8px;border-radius:6px;font-size:.68rem;font-weight:600;background:color-mix(in srgb,var(--jtc,var(--teal)) 8%,transparent);color:var(--jtc,var(--teal))}
@media(max-width:600px){
  .j-timeline{padding-left:36px}
  .j-timeline::before{left:15px}
  .j-num{width:32px;height:32px;font-size:.75rem;left:-36px;margin-right:-36px}
  .j-card{padding:14px 16px}
  .j-head{flex-direction:column;align-items:flex-start;gap:4px}
}

/* ═══════════════════════════════════════════════════════════════
   DIAGRAMA 2: FLUXO FINANCEIRO COMPLETO
   ═══════════════════════════════════════════════════════════════ */
.finflow{padding:80px 0;background:var(--bg)}
.finflow h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.finflow .ff-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.ff-diagram{max-width:900px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:12px;align-items:start}
.ff-col{display:flex;flex-direction:column;align-items:center;gap:12px}
.ff-node{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px;text-align:center;width:100%;cursor:pointer;transition:all .3s;position:relative}
.ff-node:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.ff-node.active{border-color:var(--teal);box-shadow:0 0 0 3px rgba(249,124,43,.15)}
.ff-node .ff-icon{font-size:1.5rem;margin-bottom:6px}
.ff-node h5{font-size:.82rem;font-weight:700;margin:0 0 4px}
.ff-node p{font-size:.7rem;color:var(--muted);margin:0;line-height:1.4}
.ff-node .ff-badge{position:absolute;top:-8px;right:-8px;padding:2px 8px;border-radius:100px;font-size:.6rem;font-weight:700;color:#fff}
.ff-arrow{display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--teal);height:24px;opacity:.5}
.ff-detail{max-width:900px;margin:24px auto 0;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:24px;display:none;animation:sandFadeIn .3s ease}
.ff-detail.show{display:block}
.ff-detail h4{font-family:var(--serif);font-size:1rem;margin:0 0 8px}
.ff-detail .ff-steps{display:flex;gap:8px;flex-wrap:wrap}
.ff-detail .ff-st{padding:8px 14px;border-radius:8px;font-size:.78rem;background:rgba(249,124,43,.05);border:1px solid rgba(249,124,43,.1);display:flex;align-items:center;gap:6px}
@media(max-width:768px){.ff-diagram{grid-template-columns:repeat(2,1fr)}.ff-arrow{display:none}}

/* ═══════════════════════════════════════════════════════════════
   DIAGRAMA 3: ORGANOGRAMA POR CARGO
   ═══════════════════════════════════════════════════════════════ */
.orgchart{padding:80px 0;background:linear-gradient(180deg,rgba(249,124,43,.02),var(--bg))}
.orgchart h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.orgchart .org-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.org-tree{max-width:900px;margin:0 auto}
.org-level{margin-bottom:32px}
.org-level-label{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:12px;padding-left:4px}
.org-roles{display:flex;gap:12px;flex-wrap:wrap}
.org-role{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px 20px;flex:1;min-width:200px;cursor:pointer;transition:all .3s;position:relative;overflow:hidden}
.org-role::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0}
.org-role:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.06)}
.org-role.active{border-color:var(--teal)}
.org-role h5{font-size:.9rem;font-weight:700;margin:0 0 4px;display:flex;align-items:center;gap:6px}
.org-role .org-desc{font-size:.78rem;color:var(--muted);margin:0 0 10px}
.org-modules{display:flex;flex-wrap:wrap;gap:4px}
.org-modules span{padding:2px 8px;border-radius:6px;font-size:.68rem;font-weight:600;background:rgba(249,124,43,.06);color:var(--teal)}
.org-perm-count{font-family:var(--mono);font-size:.7rem;color:var(--muted);margin-top:8px}

/* ═══════════════════════════════════════════════════════════════
   DIAGRAMA 4: FLUXO DE IMPLANTAÇÃO
   ═══════════════════════════════════════════════════════════════ */
.implflow{padding:80px 0;background:var(--bg)}
.implflow h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.implflow .impl-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.impl-steps{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:0}
.impl-step{display:flex;gap:20px;align-items:stretch}
.impl-marker{display:flex;flex-direction:column;align-items:center;width:60px;flex-shrink:0}
.impl-num{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:900;font-size:1.1rem;color:#fff;z-index:1}
.impl-line{flex:1;width:3px;border-radius:2px;min-height:20px}
.impl-card{flex:1;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:16px;transition:all .3s}
.impl-card:hover{transform:translateX(4px);box-shadow:0 6px 20px rgba(0,0,0,.06)}
.impl-card h4{font-family:var(--serif);font-size:1rem;margin:0 0 4px;display:flex;align-items:center;gap:8px}
.impl-card h4 .impl-dur{font-family:var(--mono);font-size:.7rem;padding:2px 8px;border-radius:100px;background:rgba(249,124,43,.08);color:var(--teal);font-weight:600}
.impl-card p{font-size:.82rem;color:var(--muted);margin:0 0 8px;line-height:1.5}
.impl-card .impl-delivs{display:flex;flex-wrap:wrap;gap:4px}
.impl-card .impl-deliv{padding:3px 10px;border-radius:6px;font-size:.7rem;font-weight:500;background:var(--bg);border:1px solid var(--border)}

/* ═══════════════════════════════════════════════════════════════
   DIAGRAMA 5: MAPA DE INTEGRAÇÕES
   ═══════════════════════════════════════════════════════════════ */
.intmap{padding:80px 0;background:linear-gradient(180deg,var(--bg),rgba(59,130,246,.02))}
.intmap h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.intmap .int-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.int-hub{max-width:700px;margin:0 auto;position:relative}
.int-center{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--teal),#3B82F6);display:flex;align-items:center;justify-content:center;flex-direction:column;margin:0 auto;position:relative;z-index:2;box-shadow:0 8px 32px rgba(249,124,43,.3)}
.int-center span{color:#fff;font-weight:700;font-size:.9rem}
.int-center small{color:rgba(255,255,255,.7);font-size:.7rem}
.int-ring{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;margin-top:-20px;padding-top:40px}
.int-node{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 18px;min-width:140px;text-align:center;transition:all .3s;cursor:pointer}
.int-node:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.08);border-color:var(--teal)}
.int-node .int-ico{font-size:1.4rem;margin-bottom:4px}
.int-node h5{font-size:.82rem;font-weight:700;margin:0 0 2px}
.int-node p{font-size:.68rem;color:var(--muted);margin:0}
.int-node .int-status{display:inline-block;padding:2px 8px;border-radius:100px;font-size:.6rem;font-weight:700;margin-top:6px}
.int-node .int-status.live{background:rgba(249,124,43,.1);color:#f97c2b}
.int-node .int-status.soon{background:rgba(245,166,35,.1);color:#f5a623}
.int-cats{display:flex;gap:20px;justify-content:center;margin-top:32px;flex-wrap:wrap}
.int-cat{font-size:.78rem;display:flex;align-items:center;gap:6px;color:var(--muted)}
.int-cat i{width:10px;height:10px;border-radius:3px;display:inline-block}

/* ═══════════════════════════════════════════════════════════════
   DIAGRAMA 6: CICLO OPERACIONAL
   ═══════════════════════════════════════════════════════════════ */
.cycle{padding:80px 0;background:var(--bg)}
.cycle h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.cycle .cy-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 40px;font-size:.95rem}
.cy-wheel{max-width:700px;margin:0 auto;position:relative}
.cy-phases{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cy-phase{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center;transition:all .3s;cursor:pointer;position:relative;overflow:hidden}
.cy-phase::after{content:'→';position:absolute;right:-14px;top:50%;transform:translateY(-50%);font-size:1.2rem;color:var(--teal);z-index:2}
.cy-phase:nth-child(3)::after,.cy-phase:nth-child(6)::after{content:'↓';right:50%;transform:translateX(50%);top:auto;bottom:-18px}
.cy-phase:nth-child(4)::after,.cy-phase:nth-child(5)::after{content:'←'}
.cy-phase:last-child::after{content:'↗';right:auto;left:-14px}
.cy-phase:hover{transform:scale(1.03);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.cy-phase .cy-num{font-family:var(--mono);font-size:.7rem;color:var(--muted);margin-bottom:4px}
.cy-phase .cy-ico{font-size:1.5rem;margin-bottom:6px}
.cy-phase h5{font-size:.85rem;font-weight:700;margin:0 0 4px}
.cy-phase p{font-size:.72rem;color:var(--muted);margin:0;line-height:1.4}
.cy-phase .cy-mods{display:flex;flex-wrap:wrap;gap:3px;justify-content:center;margin-top:8px}
.cy-phase .cy-mod{padding:2px 6px;border-radius:4px;font-size:.62rem;font-weight:600;background:rgba(249,124,43,.06);color:var(--teal)}
@media(max-width:768px){.cy-phases{grid-template-columns:1fr}.cy-phase::after{display:none}}

/* ═══════════════════════════════════════════════════════════════
   SEÇÃO: MERCADO EM NÚMEROS (dados reais)
   ═══════════════════════════════════════════════════════════════ */
.mkt{padding:80px 0;background:linear-gradient(180deg,#0d1117,#161b22);color:#fff}
.mkt h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:6px;color:#fff}
.mkt .mkt-sub{text-align:center;color:rgba(255,255,255,.55);max-width:640px;margin:0 auto 48px;font-size:.92rem}
.mkt-grid{max-width:960px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.mkt-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:24px;position:relative;overflow:hidden;transition:all .3s}
.mkt-card:hover{background:rgba(255,255,255,.07);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.mkt-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.mkt-card .mkt-val{font-family:var(--serif);font-size:2.2rem;font-weight:900;margin-bottom:4px;line-height:1.1}
.mkt-card .mkt-lbl{font-size:.82rem;color:rgba(255,255,255,.7);margin-bottom:10px;line-height:1.4}
.mkt-card .mkt-src{font-size:.65rem;color:rgba(255,255,255,.3);font-family:var(--mono);display:flex;align-items:center;gap:4px}
.mkt-card .mkt-trend{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:100px;font-size:.7rem;font-weight:700;margin-left:8px}
.mkt-card .mkt-trend.up{background:rgba(249,124,43,.2);color:#34d399}
.mkt-card .mkt-trend.down{background:rgba(232,99,74,.2);color:#fca5a5}
.mkt-card .mkt-trend.neutral{background:rgba(245,166,35,.15);color:#fbbf24}
.mkt-featured{grid-column:span 3;background:linear-gradient(135deg,rgba(249,124,43,.12),rgba(59,130,246,.08));border-color:rgba(249,124,43,.2);padding:32px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;align-items:center}
.mkt-featured .mkt-feat-text{grid-column:span 2}
.mkt-featured .mkt-feat-text h3{font-family:var(--serif);font-size:1.3rem;color:#fff;margin:0 0 8px}
.mkt-featured .mkt-feat-text p{font-size:.85rem;color:rgba(255,255,255,.6);line-height:1.6;margin:0}
.mkt-featured .mkt-feat-cta{text-align:center}
@media(max-width:768px){.mkt-grid{grid-template-columns:1fr}.mkt-featured{grid-column:span 1;grid-template-columns:1fr}.mkt-featured .mkt-feat-text{grid-column:span 1}}

/* ═══════════════════════════════════════════════════════════════
   SEÇÃO: CENÁRIOS REAIS POR SEGMENTO
   ═══════════════════════════════════════════════════════════════ */
.cases{padding:80px 0;background:var(--bg)}
.cases h2{text-align:center;font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px}
.cases .cases-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 48px;font-size:.92rem}
.case-tabs{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin-bottom:32px}
.case-tabs button{padding:8px 18px;border-radius:100px;border:1px solid var(--border);background:var(--card);color:var(--muted);font-size:.8rem;cursor:pointer;transition:all .25s;font-family:var(--sans)}
.case-tabs button.active{background:var(--teal);color:#fff;border-color:var(--teal)}
.case-panels{max-width:900px;margin:0 auto}
.case-panel{display:none;animation:sandFadeIn .4s ease}
.case-panel.show{display:block}
.case-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.case-header .case-ico{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.6rem}
.case-header h3{font-family:var(--serif);font-size:1.3rem;margin:0 0 4px}
.case-header p{font-size:.82rem;color:var(--muted);margin:0}
.case-split{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.case-before,.case-after{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px}
.case-before{border-top:3px solid #E8634A}
.case-after{border-top:3px solid var(--teal)}
.case-before h4,.case-after h4{font-size:.85rem;margin:0 0 12px;display:flex;align-items:center;gap:6px}
.case-metric{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.82rem}
.case-metric:last-child{border-bottom:none}
.case-metric .cm-val{font-family:var(--mono);font-weight:700;min-width:80px}
.case-metric .cm-val.bad{color:#E8634A}
.case-metric .cm-val.good{color:#f97c2b}
.case-impact{background:linear-gradient(135deg,rgba(249,124,43,.05),rgba(59,130,246,.05));border:1px solid rgba(249,124,43,.15);border-radius:14px;padding:20px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;text-align:center}
.case-impact-item .ci-val{font-family:var(--serif);font-size:1.5rem;font-weight:900;color:var(--teal)}
.case-impact-item .ci-lbl{font-size:.72rem;color:var(--muted);margin-top:2px}
.case-source{font-size:.7rem;color:var(--muted);margin-top:16px;font-style:italic;text-align:right}
@media(max-width:768px){.case-split{grid-template-columns:1fr}.case-impact{grid-template-columns:repeat(2,1fr)}}

/* ═══════════════════════════════════════════════════
   PREMIUM FLOW DIAGRAMS
   ═══════════════════════════════════════════════════ */
.flow-diagram{padding:60px 0}
.flow-diagram h2{text-align:center;font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.2rem);margin-bottom:6px}
.flow-diagram .flow-sub{text-align:center;color:var(--muted);max-width:560px;margin:0 auto 36px;font-size:.92rem}
.flow-phase{display:flex;align-items:stretch;gap:8px;margin-bottom:8px;position:relative}
.flow-phase::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:2px}
.flow-phase[data-c="coral"]::before{background:#F0997B}
.flow-phase[data-c="purple"]::before{background:#AFA9EC}
.flow-phase[data-c="teal"]::before{background:#5DCAA5}
.flow-phase[data-c="pink"]::before{background:#ED93B1}
.flow-phase[data-c="blue"]::before{background:#85B7EB}
.flow-phase[data-c="amber"]::before{background:#FAC775}
.flow-phase-label{writing-mode:vertical-rl;text-orientation:mixed;font-size:.72rem;font-weight:600;letter-spacing:.05em;padding:8px 6px 8px 10px;color:var(--muted);min-width:32px;display:flex;align-items:center;justify-content:center;text-transform:uppercase}
.flow-cards{display:flex;gap:8px;flex:1;flex-wrap:wrap}
.flow-card{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;border:1px solid var(--brd);background:var(--card);cursor:pointer;transition:all .25s;flex:1;min-width:140px}
.flow-card:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.06)}
.flow-card .fc-ico{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.flow-card .fc-ico svg{width:18px;height:18px}
.flow-card .fc-tx h5{font-size:.85rem;font-weight:600;color:var(--fg);margin:0;line-height:1.3}
.flow-card .fc-tx p{font-size:.73rem;color:var(--muted);margin:2px 0 0;line-height:1.3}
.flow-conn{display:flex;align-items:center;justify-content:center;padding:4px 0;color:var(--muted)}
.flow-conn svg{width:18px;height:18px}
.flow-loop{display:flex;align-items:center;gap:8px;justify-content:center;padding:8px 18px;border-radius:99px;border:1px dashed var(--brd);font-size:.75rem;color:var(--muted);margin-top:8px}
.flow-loop svg{width:13px;height:13px}
/* Security tower */
.sec-layer{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:14px;border:1px solid var(--brd);background:var(--card);margin-bottom:8px;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}
.sec-layer:hover{border-color:var(--teal);transform:translateX(4px)}
.sec-layer::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px}
.sec-layer[data-c="blue"]::before{background:#85B7EB}
.sec-layer[data-c="purple"]::before{background:#AFA9EC}
.sec-layer[data-c="coral"]::before{background:#F0997B}
.sec-layer[data-c="teal"]::before{background:#5DCAA5}
.sec-layer[data-c="pink"]::before{background:#ED93B1}
.sec-num{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:600;flex-shrink:0}
.sec-ico{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sec-ico svg{width:20px;height:20px}
.sec-info h5{font-size:.92rem;font-weight:600;color:var(--fg);margin:0;line-height:1.3}
.sec-info p{font-size:.78rem;color:var(--muted);margin:2px 0 0;line-height:1.4}
.sec-between{display:flex;align-items:center;justify-content:center;gap:8px;padding:3px 0;font-size:.72rem;color:var(--muted)}
.sec-between svg{width:14px;height:14px}
.sec-foot{text-align:center;font-size:.8rem;color:var(--muted);padding:10px 18px;border-radius:12px;background:rgba(0,0,0,.02);margin-top:10px;line-height:1.5}
html.dark .sec-foot{background:rgba(255,255,255,.03)}
@media(max-width:768px){.flow-cards{flex-direction:column}.flow-card{min-width:100%}.sec-layer{flex-wrap:wrap}}

/* ═══════════════════════════════════════════════════
   ECO HUB — Clean module ecosystem
   ═══════════════════════════════════════════════════ */
.eco-hub{display:flex;flex-direction:column;align-items:center;gap:32px;margin-top:12px}
.eco-center{display:flex;flex-direction:column;align-items:center;gap:6px;padding:24px 32px;border-radius:20px;background:var(--card);border:1px solid var(--brd);position:relative}
.eco-c-label{font-family:var(--serif);font-weight:700;font-size:1.1rem;color:var(--fg)}
.eco-c-sub{font-size:.75rem;color:var(--muted)}
.eco-ring{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:100%}
.eco-card{border-radius:14px;border:1px solid var(--brd);background:var(--card);overflow:hidden;transition:all .25s}
.eco-card:hover{border-color:var(--ec);box-shadow:0 6px 20px rgba(0,0,0,.06);transform:translateY(-3px)}
.eco-card-hdr{display:flex;align-items:center;gap:12px;padding:16px 16px 12px;background:var(--ecl);border-bottom:1px solid var(--brd)}
.eco-card-ico{width:40px;height:40px;border-radius:10px;background:var(--card);border:1px solid var(--brd);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.eco-card-ico svg{width:20px;height:20px}
.eco-card-title{font-size:.88rem;font-weight:700;color:var(--ecd)}
.eco-card-count{font-size:.7rem;color:var(--ec);font-weight:500;margin-top:1px}
.eco-card-bar{padding:0 16px;margin-top:10px}
.eco-card-bar div{height:3px;border-radius:3px;background:var(--ec);opacity:.4;transition:width .6s ease}
.eco-card:hover .eco-card-bar div{opacity:.7}
.eco-card-chips{padding:10px 16px 16px;display:flex;flex-wrap:wrap;gap:6px}
.eco-card-chips span{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:8px;font-size:.74rem;font-weight:500;color:var(--fg);background:var(--bg);border:1px solid var(--brd);transition:all .2s}
.eco-card-chips span:hover{border-color:var(--ec);background:var(--ecl)}
.eco-card-chips b{font-size:.62rem;font-weight:600;color:var(--ec);font-family:var(--mono);background:var(--ecl);padding:1px 5px;border-radius:4px;margin-left:2px}
@media(max-width:768px){.eco-ring{grid-template-columns:1fr}}
@media(min-width:769px) and (max-width:1024px){.eco-ring{grid-template-columns:repeat(2,1fr)}}
.eco-ring .eco-card:nth-child(4),.eco-ring .eco-card:nth-child(5){grid-column:span 1}
@media(min-width:769px){.eco-ring{grid-template-columns:repeat(3,1fr)}.eco-ring .eco-card:nth-child(4){grid-column:span 2}.eco-ring .eco-card:nth-child(5){grid-column:span 1}}

/* ═══════════════════════════════════════════════════
   DIAGNOSTIC — redesigned layout
   ═══════════════════════════════════════════════════ */
.diag-layout{display:grid;grid-template-columns:260px 1fr;gap:24px;max-width:860px;margin:0 auto;align-items:start}
.diag-benefits{display:flex;flex-direction:column;gap:16px;padding-top:8px}
.diag-ben{display:flex;gap:12px;align-items:flex-start}
.diag-ben-ico{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.diag-ben h5{font-size:.85rem;font-weight:600;color:var(--fg);margin:0;line-height:1.3}
.diag-ben p{font-size:.75rem;color:var(--muted);margin:2px 0 0;line-height:1.3}
.diag-header{display:flex;align-items:center;gap:8px;padding:12px 20px;border-bottom:1px solid var(--brd);font-size:.8rem;font-weight:600;color:var(--fg)}
.diag-hdr-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;flex-shrink:0}
.diag-hdr-steps{margin-left:auto;font-size:.72rem;font-weight:500;color:var(--muted);font-family:var(--mono)}
@media(max-width:768px){.diag-layout{grid-template-columns:1fr}.diag-benefits{flex-direction:row;flex-wrap:wrap;gap:12px}.diag-ben{flex:1;min-width:140px}}

/* ECO HUB — additions */
.eco-g-total{font-size:.68rem;font-weight:500;color:var(--muted);text-align:right;margin-top:8px;font-family:var(--mono);padding-top:4px;border-top:1px solid var(--brd)}
.eco-techs-divider{width:100%;height:1px;background:var(--brd);margin:20px 0 12px}
.eco-techs-label{font-size:.78rem;color:var(--muted);text-align:center;margin-bottom:10px;font-weight:600}
.eco-techs{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.eco-tech{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:99px;border:1px solid var(--brd);background:var(--card);font-size:.72rem;font-weight:500;color:var(--muted);transition:all .15s}
.eco-tech:hover{border-color:var(--teal);color:var(--fg)}
.eco-tech svg{opacity:.5;flex-shrink:0}

/* ═══════════════════════════════════════════════════
   PRICING TRANSPARENCY
   ═══════════════════════════════════════════════════ */
.pricing{padding:80px 0}
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:900px;margin:0 auto;align-items:start}
.price-card{border-radius:16px;border:2px solid var(--teal);background:var(--card);padding:32px;position:relative}
.price-badge{position:absolute;top:-12px;left:24px;background:var(--teal);color:#fff;font-size:.68rem;font-weight:600;padding:4px 14px;border-radius:99px;text-transform:uppercase;letter-spacing:.04em}
.price-card h3{font-family:var(--serif);font-size:1.4rem;font-weight:700;margin:8px 0 12px;color:var(--fg)}
.price-val{font-size:.95rem;color:var(--muted);margin-bottom:16px}
.price-val strong{font-size:1.6rem;font-weight:800;color:var(--teal);font-family:var(--serif)}
.price-val span{font-size:.8rem;color:var(--muted)}
.price-card>p{font-size:.82rem;color:var(--muted);line-height:1.5;margin-bottom:20px}
.price-list{list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:10px}
.price-list li{display:flex;align-items:center;gap:10px;font-size:.84rem;color:var(--fg)}
.price-list li svg{flex-shrink:0}
.price-faq{display:flex;flex-direction:column;gap:14px}
.price-q{padding:18px 20px;border-radius:12px;border:1px solid var(--brd);background:var(--card)}
.price-q h4{font-size:.88rem;font-weight:600;color:var(--fg);margin-bottom:6px}
.price-q p{font-size:.8rem;color:var(--muted);line-height:1.5}
@media(max-width:768px){.price-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════
   NEWSLETTER
   ═══════════════════════════════════════════════════ */
.news{padding:40px 0 60px}
.news-box{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:32px 36px;border-radius:16px;background:var(--tl);border:1px solid rgba(249,124,43,.12)}
.news-left h3{font-family:var(--serif);font-size:1.2rem;font-weight:700;color:var(--fg);margin-bottom:4px}
.news-left p{font-size:.82rem;color:var(--muted)}
.news-form{display:flex;gap:8px;flex-shrink:0}
.news-form input{padding:10px 16px;border-radius:10px;border:1px solid var(--brd);background:var(--card);font-size:.85rem;width:240px;color:var(--fg);font-family:var(--sans)}
.news-form input:focus{outline:none;border-color:var(--teal)}
@media(max-width:768px){.news-box{flex-direction:column;text-align:center;padding:24px}.news-form{width:100%;flex-direction:column}.news-form input{width:100%}}

/* ═══════════════════════════════════════════════════
   RESPONSIVE FIXES — GLOBAL
   ═══════════════════════════════════════════════════ */
@media(max-width:768px){
  .hero h1{font-size:clamp(1.8rem,8vw,2.8rem)}
  .hero-sub{flex-direction:column;gap:16px}
  .hero-right{width:100%}
  .hero-right .btn{width:100%;text-align:center;justify-content:center}
  .sp{justify-content:center}
  .s-hd{font-size:clamp(1.4rem,5vw,2rem)}
  .calc-grid{grid-template-columns:1fr}
  .calc-right{margin-top:16px}
  .demo-box{flex-direction:column;gap:24px}
  .demo-right{padding:0}
  .impl-steps{grid-template-columns:1fr}
  .int-grid{grid-template-columns:1fr}
  .org-tree{overflow-x:auto}
}
@media(max-width:480px){
  .w{padding:0 16px}
  .hero{padding:100px 0 40px}
  .hero h1{font-size:1.6rem}
  body{font-size:15px}
}

/* ═══════════════════════════════════════════════════
   EXIT-INTENT POPUP
   ═══════════════════════════════════════════════════ */
.exit-overlay{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;padding:24px}
.exit-overlay.show{opacity:1;pointer-events:auto}
.exit-popup{max-width:480px;width:100%;background:var(--card);border-radius:20px;padding:40px 36px;position:relative;box-shadow:0 24px 64px rgba(0,0,0,.15);transform:translateY(20px);transition:transform .3s}
.exit-overlay.show .exit-popup{transform:translateY(0)}
.exit-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:1.2rem;color:var(--muted);cursor:pointer;padding:4px}
.exit-popup h3{font-family:var(--serif);font-size:1.5rem;font-weight:800;color:var(--fg);line-height:1.2;margin-bottom:8px}
.exit-popup p{font-size:.88rem;color:var(--muted);line-height:1.5;margin-bottom:20px}
.exit-benefits{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.exit-ben{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--fg)}
.exit-ben svg{flex-shrink:0;color:var(--teal)}
@media(max-width:480px){.exit-popup{padding:28px 24px}.exit-popup h3{font-size:1.2rem}}

/* ═══════════════════════════════════════════════════
   DIAGNOSTIC RESULTS — AI-powered
   ═══════════════════════════════════════════════════ */
.diag-r-header{text-align:center;padding:20px 0 16px}
.diag-r-score{display:flex;align-items:baseline;justify-content:center;gap:2px}
.diag-r-num{font-family:var(--serif);font-size:3.5rem;font-weight:900;color:var(--teal);line-height:1}
.diag-r-of{font-size:1.2rem;color:var(--muted);font-weight:500}
.diag-r-label{font-size:.78rem;color:var(--muted);margin-top:4px}
.diag-r-analise{font-size:.88rem;color:var(--fg);line-height:1.6;padding:16px 20px;background:rgba(249,124,43,.04);border-radius:12px;border-left:3px solid var(--teal);margin:0 0 16px}
.diag-r-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.diag-r-m{text-align:center;padding:14px 8px;border-radius:12px;background:var(--bg);border:1px solid var(--brd)}
.diag-r-mv{font-family:var(--serif);font-size:1.3rem;font-weight:800;color:var(--teal)}
.diag-r-ml{font-size:.68rem;color:var(--muted);margin-top:2px}
.diag-r-section{margin-bottom:14px}
.diag-r-section strong{font-size:.82rem;color:var(--fg);display:block;margin-bottom:8px}
.diag-r-mods{display:flex;flex-wrap:wrap;gap:6px}
.diag-r-mods span{padding:5px 12px;border-radius:8px;font-size:.75rem;font-weight:500;background:var(--tl);color:var(--teal);border:1px solid rgba(249,124,43,.15)}
.diag-r-wins{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.diag-r-wins li{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--fg)}
.diag-r-wins li svg{flex-shrink:0}
.diag-r-risk{font-size:.8rem;color:var(--coral);padding:10px 14px;border-radius:10px;background:rgba(249,124,43,.04);border:1px solid rgba(249,124,43,.1);margin-bottom:16px}
.diag-r-actions{display:flex;gap:8px;flex-wrap:wrap}
.diag-r-actions .btn{flex:1;min-width:180px;text-align:center;justify-content:center}
@media(max-width:480px){.diag-r-metrics{grid-template-columns:1fr}.diag-r-actions{flex-direction:column}}

/* ═══════════════════════════════════════════════════
   NEW PAGES — responsive
   ═══════════════════════════════════════════════════ */
@media(max-width:768px){.about-grid{grid-template-columns:1fr !important}}

/* Simulador Monte seu ERP */
/* Simulator — Modern grouped layout */
.sim-layout{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start}
.sim-groups{display:flex;flex-direction:column;gap:12px}
.sim-group{border:1px solid var(--brd);border-radius:14px;background:var(--card);overflow:hidden}
.sim-group-head{display:flex;align-items:center;gap:8px;padding:12px 16px;font-size:.82rem;font-weight:700;border-bottom:1px solid var(--brd);background:var(--bg)}
.sim-group-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.sim-group-toggle{margin-left:auto;font-size:.65rem;font-weight:600;color:var(--teal);background:none;border:1px solid var(--brd);padding:3px 10px;border-radius:6px;cursor:pointer;transition:all .15s}
.sim-group-toggle:hover{border-color:var(--teal);background:var(--tl)}
.sim-group-mods{display:flex;flex-direction:column}
.sim-mod{padding:10px 16px;border-bottom:1px solid rgba(0,0,0,.03);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:10px;user-select:none}
html.dark .sim-mod{border-bottom-color:rgba(255,255,255,.03)}
.sim-mod:last-child{border-bottom:none}
.sim-mod:hover{background:rgba(249,124,43,.02)}
.sim-mod.active{background:var(--tl)}
.sim-mod .sim-check{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--brd);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.sim-mod.active .sim-check{background:var(--teal);border-color:var(--teal)}
.sim-mod.active .sim-check::after{content:'✓';color:#fff;font-size:.6rem;font-weight:700}
.sim-name{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0;font-size:.82rem;font-weight:500}
.sim-name small{font-size:.65rem;font-weight:400;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sim-mod.active .sim-name{font-weight:600;color:var(--td)}
.sim-perms{font-size:.6rem;color:var(--muted);font-family:var(--mono);background:var(--bg);padding:2px 6px;border-radius:4px;flex-shrink:0}
.sim-mod.active .sim-perms{color:var(--teal);background:rgba(249,124,43,.08)}

/* Simulator — sticky result panel */
.sim-panel{position:sticky;top:90px;border:1px solid var(--brd);border-radius:14px;background:var(--card);padding:20px;min-height:200px}
.sim-panel-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px 16px;text-align:center}
.sim-panel-empty p{font-size:.82rem;color:var(--muted);line-height:1.5}
.sim-bar-wrap{position:relative;height:6px;background:var(--bg);border-radius:3px;margin:12px 0;overflow:hidden}
.sim-bar{height:100%;background:linear-gradient(90deg,var(--teal),#3B82F6);border-radius:3px;transition:width .3s}
.sim-bar-label{position:absolute;right:0;top:-16px;font-size:.6rem;color:var(--muted);font-family:var(--mono)}
.sim-mods-list{display:flex;flex-wrap:wrap;gap:4px;margin-top:12px}
.sim-mods-list span{padding:2px 8px;border-radius:5px;font-size:.62rem;font-weight:500;background:var(--tl);color:var(--teal)}
.sim-metrics{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
.sim-metric{text-align:center;padding:12px 6px;border-radius:10px;background:var(--bg);border:1px solid var(--brd)}
.sim-metric .v{font-size:1.2rem;font-weight:800;color:var(--teal)}
.sim-metric .l{font-size:.6rem;color:var(--muted);margin-top:1px}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:768px){.sim-layout{grid-template-columns:1fr}.sim-panel{position:static}}

/* Roadmap voting cards */
.rm-vote-card{padding:18px;border-radius:12px;border:1px solid var(--brd);background:var(--card);transition:border-color .2s,opacity .3s}
.rm-vote-card:hover{border-color:rgba(249,124,43,.3)}
.rm-vote-card[data-status="done"]{border-left:3px solid #0F6E56}
.rm-vote-card[data-status="progress"]{border-left:3px solid #3B82F6}
.rm-vote-card[data-status="planned"]{border-left:3px solid #8B5CF6}
.rm-vote-card.hidden{display:none}
.rm-vote-btn:hover{border-color:var(--teal) !important;color:var(--teal) !important}
.rm-vote-btn.voted{background:var(--tl) !important;border-color:var(--teal) !important;color:var(--teal) !important}

/* ═══════════════════════════════════════════════════
   BLOG ARTICLE READER
   ═══════════════════════════════════════════════════ */
.article-reader{position:fixed;inset:0;z-index:100;background:var(--bg);overflow-y:auto;opacity:0;pointer-events:none;transition:opacity .3s}
.article-reader.open{opacity:1;pointer-events:auto}
.ar-close{position:fixed;top:20px;right:24px;z-index:101;width:40px;height:40px;border-radius:50%;border:1px solid var(--brd);background:var(--card);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;color:var(--fg);box-shadow:0 2px 8px rgba(0,0,0,.1);transition:transform .2s}
.ar-close:hover{transform:scale(1.1)}
.ar-hero{width:100%;max-height:360px;object-fit:cover;border-radius:0 0 20px 20px}
.ar-body{max-width:720px;margin:0 auto;padding:40px 24px 80px}
.ar-tag{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--teal);margin-bottom:8px;display:block}
.ar-body h1{font-size:clamp(1.6rem,4vw,2.2rem);font-weight:800;letter-spacing:-.03em;line-height:1.12;margin-bottom:12px}
.ar-meta{font-size:.78rem;color:var(--muted);margin-bottom:28px;display:flex;gap:12px;align-items:center}
.ar-body p{font-size:1rem;color:var(--fg);line-height:1.75;margin-bottom:16px}
.ar-body h2{font-size:1.2rem;font-weight:700;margin:32px 0 12px;color:var(--fg)}
.ar-body blockquote{border-left:3px solid var(--teal);padding:12px 20px;margin:20px 0;background:rgba(249,124,43,.03);border-radius:0 10px 10px 0;font-size:.92rem;color:var(--muted);font-style:italic}
.ar-cta{text-align:center;padding:32px;margin-top:32px;border-radius:16px;background:rgba(249,124,43,.04);border:1px solid rgba(249,124,43,.1)}
.ar-cta p{font-size:.88rem;color:var(--muted);margin-bottom:12px}
@media(max-width:600px){.ar-body{padding:24px 16px 60px}.ar-hero{max-height:220px}}

/* ═══════════════════════════════════════════════════
   UX IMPROVEMENTS — Micro-animations, Progress, Dark
   ═══════════════════════════════════════════════════ */

/* Reading progress bar */
.progress-bar{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--teal),#3B82F6,#8B5CF6);z-index:101;width:0%;transition:width .1s linear;pointer-events:none;opacity:0;transition:width .1s,opacity .3s}
.progress-bar.visible{opacity:1}

/* CTA button pulse glow */
.btn-t{animation:ctaGlow 3s ease-in-out infinite}
@keyframes ctaGlow{0%,100%{box-shadow:0 0 0 0 rgba(249,124,43,0)}50%{box-shadow:0 0 0 6px rgba(249,124,43,.12)}}
.btn-t:hover{animation:none}

/* Animated counter */
.count-up{transition:all .3s}

/* Card hover lift — universal */
.proof-card,.sc,.rm-card,.clog-item,.tco-grid,.calc-box{transition:transform .25s,border-color .25s,box-shadow .25s}

/* Smooth image zoom on hover */
.bf-visual img,.bc-visual img{transition:transform .6s cubic-bezier(.16,1,.3,1)}
.blog-feat:hover .bf-visual img,.ba-card2:hover .bc-visual img{transform:scale(1.04)}

/* Link underline animation */
.nlinks a{position:relative}
.nlinks a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--teal);border-radius:1px;transition:width .25s cubic-bezier(.16,1,.3,1)}
.nlinks a:hover::after{width:100%}

/* Focus visible for accessibility */
:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:4px}
button:focus-visible,.btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px}

/* Scroll-triggered scale for stats */
.stat-pop{opacity:0;transform:scale(.85);transition:opacity .5s,transform .5s cubic-bezier(.16,1,.3,1)}
.stat-pop.v{opacity:1;transform:scale(1)}

/* Dark mode polish */
html.dark .btn-t{box-shadow:0 0 20px rgba(249,124,43,.15)}
html.dark .btn-t:hover{box-shadow:0 4px 24px rgba(249,124,43,.3)}
html.dark .btn-ol{border-color:var(--brd);color:var(--tx2)}
html.dark .btn-ol:hover{border-color:var(--teal);color:var(--teal);background:rgba(249,124,43,.05)}
html.dark .hero::after{background:radial-gradient(circle,rgba(249,124,43,.08),transparent 70%)}
html.dark .proof-card:hover{border-color:rgba(249,124,43,.25);box-shadow:0 8px 28px rgba(0,0,0,.3)}
html.dark .s-ey{color:var(--teal)}
html.dark img{opacity:.92}
html.dark .bf-visual img,html.dark .bc-visual img{opacity:.85}
html.dark input,html.dark select,html.dark textarea{background:var(--bg2);border-color:var(--brd);color:var(--tx)}
html.dark input:focus,html.dark select:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(249,124,43,.1)}
html.dark .modal{background:var(--bg2);border:1px solid var(--brd)}
html.dark .modal-bg{background:rgba(0,0,0,.7)}
html.dark .wa-fab{background:var(--bg2);border:1px solid var(--brd)}
html.dark .sc-ai{background:rgba(249,124,43,.08);border-color:rgba(249,124,43,.15)}
html.dark .sim-group{border-color:var(--brd);background:var(--bg2)}
html.dark .sim-group-head{background:var(--bg);border-color:var(--brd)}
html.dark .sim-panel{background:var(--bg2);border-color:var(--brd)}
html.dark .article-reader{background:var(--bg)}

/* Tooltip for interactive elements */
[data-tip]{position:relative}
[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);padding:4px 10px;border-radius:6px;font-size:.68rem;font-weight:500;background:var(--ink);color:var(--cream);white-space:nowrap;z-index:10;pointer-events:none;animation:tipIn .15s ease}
html.dark [data-tip]:hover::after{background:var(--cream);color:var(--ink)}
@keyframes tipIn{from{opacity:0;transform:translateX(-50%) translateY(4px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* Smooth section transitions */
section{position:relative}
section + section{border-top:1px solid transparent}

/* Footer hover effects */
.ft-col a{transition:color .2s,padding-left .2s}
.ft-col a:hover{color:var(--teal);padding-left:4px}

/* Toast improvement */
.toast{backdrop-filter:blur(12px)}
html.dark .toast{background:var(--bg2);border:1px solid var(--brd);color:var(--tx)}

/* Card stagger entrance */
.seg-scroll .sc{opacity:0;transform:translateY(16px);transition:opacity .4s,transform .4s}
.seg-scroll .sc.v{opacity:1;transform:none}
.seg-scroll .sc:nth-child(2){transition-delay:.05s}
.seg-scroll .sc:nth-child(3){transition-delay:.1s}
.seg-scroll .sc:nth-child(4){transition-delay:.15s}
.seg-scroll .sc:nth-child(5){transition-delay:.2s}
.seg-scroll .sc:nth-child(6){transition-delay:.25s}
.seg-scroll .sc:nth-child(7){transition-delay:.3s}

/* Smooth page transitions */
main{animation:pageIn .4s ease}
@keyframes pageIn{from{opacity:0}to{opacity:1}}

/* Improved scrollbar */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--brd);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--tx3)}
html.dark ::-webkit-scrollbar-thumb{background:var(--brd)}
html{scrollbar-width:thin;scrollbar-color:var(--brd) transparent}

/* Selection color */
::selection{background:rgba(249,124,43,.15);color:var(--fg)}
html.dark ::selection{background:rgba(249,124,43,.25)}

/* ═══════════════════════════════════════════════════
   ABOUT PAGE — /sobre
   ═══════════════════════════════════════════════════ */

/* Metrics bar */
.ab-metrics-section{padding:0 0 48px}
.ab-metrics-bar{display:flex;justify-content:center;align-items:center;gap:0;padding:24px 32px;border-radius:var(--rl);border:1px solid var(--brd);background:var(--card);flex-wrap:wrap}
.ab-m{text-align:center;padding:8px 24px;flex:1;min-width:100px}
.ab-mv{font-family:var(--mono);font-size:1.5rem;font-weight:700;color:var(--teal);display:block}
.ab-ml{font-size:.68rem;color:var(--muted);display:block;margin-top:2px}
.ab-m-div{width:1px;height:36px;background:var(--brd);flex-shrink:0}

/* Story section */
.ab-story{padding:64px 0}
.ab-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.ab-story-text h2{font-size:clamp(1.4rem,2.8vw,2rem);font-weight:800;margin-bottom:16px}
.ab-story-text p{font-size:.9rem;color:var(--muted);line-height:1.7;margin-bottom:14px}
.ab-story-text p:last-child{margin-bottom:0}

/* Before/After visual */
.ab-before-after{display:flex;align-items:center;gap:16px}
.ab-ba-card{flex:1;padding:20px;border-radius:14px;border:1px solid var(--brd);background:var(--card)}
.ab-ba-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}
.ab-before .ab-ba-label{color:var(--coral)}
.ab-after .ab-ba-label{color:var(--teal)}
.ab-ba-items{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.ab-ba-items span{font-size:.78rem;color:var(--fg);padding:4px 0}
.ab-ba-result{font-size:.68rem;color:var(--muted);padding-top:10px;border-top:1px solid var(--brd);line-height:1.4}
.ab-after{border-color:var(--teal);background:linear-gradient(135deg,rgba(249,124,43,.04),rgba(249,124,43,.01))}
.ab-ba-arrow{font-size:1.4rem;color:var(--teal);font-weight:700;flex-shrink:0}

/* Values */
.ab-values{padding:64px 0;background:linear-gradient(180deg,var(--bg),rgba(249,124,43,.02))}
.ab-values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:32px}
.ab-val-card{padding:28px 24px;border-radius:16px;border:1px solid var(--brd);background:var(--card);transition:border-color .25s,transform .25s}
.ab-val-card:hover{border-color:var(--teal);transform:translateY(-3px)}
.ab-val-ico{font-size:1.6rem;margin-bottom:12px}
.ab-val-card h4{font-family:var(--serif);font-weight:700;font-size:.95rem;margin-bottom:8px}
.ab-val-card p{font-size:.8rem;color:var(--muted);line-height:1.55}

/* Stack */
.ab-stack{padding:64px 0}
.ab-stack-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;max-width:920px;margin:0 auto}
.ab-stack-card{padding:20px;border-radius:12px;border:1px solid var(--brd);background:var(--card);transition:border-color .25s,transform .25s}
.ab-stack-card:hover{border-color:var(--teal);transform:translateY(-2px)}
.ab-stack-name{font-size:.85rem;font-weight:700;margin-bottom:4px}
.ab-stack-desc{font-size:.72rem;color:var(--muted);line-height:1.4}

/* CTA */
.ab-cta{padding:64px 0 80px;background:linear-gradient(180deg,rgba(249,124,43,.02),var(--bg))}

/* Responsive */
@media(max-width:768px){
  .ab-metrics-bar{flex-direction:column;gap:0;padding:20px}
  .ab-m-div{width:80%;height:1px;margin:6px 0}
  .ab-story-grid{grid-template-columns:1fr}
  .ab-before-after{flex-direction:column}
  .ab-ba-arrow{transform:rotate(90deg)}
  .ab-values-grid{grid-template-columns:1fr 1fr}
  .ab-stack-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .ab-values-grid{grid-template-columns:1fr}
  .ab-stack-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════
   INTEGRAÇÕES PAGE — /integracoes
   ═══════════════════════════════════════════════════ */
.ig-section{padding:48px 0}
.ig-section + .ig-section{padding-top:0}
.ig-cat-title{font-family:var(--serif);font-size:1.3rem;font-weight:800;display:flex;align-items:center;gap:10px;margin-bottom:6px}
.ig-cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.ig-cat-desc{font-size:.85rem;color:var(--muted);margin-bottom:20px;max-width:500px}
.ig-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.ig-card{padding:24px;border-radius:14px;border:1px solid var(--brd);background:var(--card);transition:border-color .25s,transform .25s,box-shadow .25s}
.ig-card:hover{border-color:var(--teal);transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.06)}
html.dark .ig-card:hover{box-shadow:0 6px 20px rgba(0,0,0,.2)}
.ig-card-featured{border-color:rgba(139,92,246,.2);background:linear-gradient(135deg,rgba(139,92,246,.03),transparent)}
.ig-card-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.ig-ico{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.65rem;flex-shrink:0}
.ig-card h4{font-family:var(--sans);font-weight:700;font-size:.92rem}
.ig-tag{font-size:.68rem;padding:2px 8px;border-radius:99px;font-weight:600;display:inline-block;margin-top:2px}
.ig-active{background:rgba(15,110,86,.1);color:#0F6E56}
.ig-soon{background:rgba(0,0,0,.06);color:var(--muted)}
html.dark .ig-active{background:rgba(15,110,86,.15);color:#34D399}
html.dark .ig-soon{background:rgba(255,255,255,.06)}
.ig-card p{font-size:.82rem;color:var(--muted);line-height:1.55;margin-bottom:12px}
.ig-techs{display:flex;gap:6px;flex-wrap:wrap}
.ig-techs span{font-size:.65rem;padding:3px 8px;border-radius:6px;background:var(--sand);color:var(--muted);font-weight:500}
html.dark .ig-techs span{background:rgba(255,255,255,.06)}
/* CTA box */
.ig-cta{padding:48px 0 72px}
.ig-cta-box{display:flex;align-items:center;justify-content:space-between;gap:32px;padding:36px 40px;border-radius:var(--rl);border:1px solid var(--brd);background:linear-gradient(135deg,rgba(249,124,43,.03),rgba(59,130,246,.02))}
.ig-cta-box h2{font-family:var(--serif);font-size:1.3rem;font-weight:800;margin-bottom:6px}
.ig-cta-box p{font-size:.85rem;color:var(--muted)}
.ig-cta-btns{display:flex;gap:10px;flex-shrink:0}
@media(max-width:768px){
  .ig-grid{grid-template-columns:1fr}
  .ig-cta-box{flex-direction:column;text-align:center;padding:28px 24px}
  .ig-cta-btns{flex-direction:column;width:100%}
  .ig-cta-btns .btn{width:100%}
}

   ═══════════════════════════════════════════════════ */

/* Hero standardized padding */
.hero{padding:130px 0 48px}

/* Section spacing consistency */
.s-hd{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2.2rem);font-weight:800;letter-spacing:-.03em;line-height:1.15;margin-bottom:8px}
.s-desc{font-size:.88rem;color:var(--muted);line-height:1.6}
.s-ey{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--teal);background:var(--tl);padding:6px 14px;border-radius:99px;margin-bottom:14px}

/* Card base — reusable */
.card-base{padding:24px;border-radius:14px;border:1px solid var(--brd);background:var(--card);transition:border-color .25s,transform .25s,box-shadow .25s}
.card-base:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.05)}
html.dark .card-base:hover{box-shadow:0 4px 16px rgba(0,0,0,.2)}

/* Improve textarea dark mode */
html.dark textarea{background:var(--card);border-color:var(--brd);color:var(--fg)}
html.dark textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(249,124,43,.1)}

/* Link visited state */
.ft-col a:visited{color:var(--muted)}

/* Smooth page load */
html{scroll-behavior:smooth}

/* Better mobile nav spacing */
@media(max-width:768px){
  .mob a{font-size:1.2rem;padding:6px 0}
  .mob .btn{margin-top:8px;width:80%;text-align:center}
}

/* Fix for long content overflow */
.w{overflow-wrap:break-word;word-wrap:break-word}

/* Improve select styling */
select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239B9B9B' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}

/* Consistent section backgrounds */
section:nth-of-type(even){background:linear-gradient(180deg,var(--bg),rgba(249,124,43,.015),var(--bg))}

/* Skip link improvement */
.skip-link{position:absolute;top:-60px;left:0;background:var(--teal);color:#fff;padding:10px 20px;z-index:9999;font-size:.85rem;transition:top .2s;border-radius:0 0 8px 0;font-weight:600}
.skip-link:focus{top:0}

/* Proof bottom — CTA + segment tags */
.proof-bottom{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:28px}
.proof-segs{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}
.proof-segs span{font-size:.72rem;font-weight:500;color:var(--muted);padding:5px 14px;border-radius:99px;border:1px solid var(--brd);background:var(--card);transition:all .2s}
.proof-segs span:hover{border-color:var(--teal);color:var(--teal);background:var(--tl)}

/* ═══════════════════════════════════════════════════
   TEMPLATES PAGE — /templates
   ═══════════════════════════════════════════════════ */
.tpl-card{padding:22px;border-radius:14px;border:1px solid var(--brd);background:var(--card);display:flex;flex-direction:column;transition:border-color .25s,transform .25s,box-shadow .25s}
.tpl-card:hover{border-color:var(--teal);transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.05)}
html.dark .tpl-card:hover{box-shadow:0 6px 20px rgba(0,0,0,.2)}
.tpl-head{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}
.tpl-ico{font-size:1.3rem;margin-top:2px}
.tpl-cat{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--teal);display:block;margin-bottom:2px}
.tpl-card h4{font-family:var(--sans);font-weight:700;font-size:.88rem;line-height:1.25}
.tpl-card p{font-size:.78rem;color:var(--muted);line-height:1.55;flex:1;margin-bottom:12px}
.tpl-foot{display:flex;justify-content:space-between;align-items:center;padding-top:10px;border-top:1px solid var(--brd);gap:6px}
.tpl-fmt{font-size:.6rem;font-weight:700;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.03em}
.tpl-xlsx{background:rgba(15,110,86,.1);color:#0F6E56}
.tpl-pdf{background:rgba(232,99,74,.1);color:#E8634A}
html.dark .tpl-xlsx{background:rgba(15,110,86,.15)}
html.dark .tpl-pdf{background:rgba(232,99,74,.15)}
.tpl-size{font-size:.6rem;color:var(--muted);flex:1;text-align:center}
.tpl-btn{padding:5px 14px!important;font-size:.72rem!important;text-decoration:none}

/* ═══════════════════════════════════════════════════
   LEGAL PAGES — /privacidade, /termos
   ═══════════════════════════════════════════════════ */
.legal-content{padding:32px 0 72px}
.legal-body{max-width:780px;margin:0 auto}
.legal-toc{padding:20px 24px;border-radius:14px;border:1px solid var(--brd);background:var(--card);margin-bottom:36px}
.legal-toc h4{font-family:var(--serif);font-size:.88rem;font-weight:700;margin-bottom:10px}
.legal-toc a{display:block;font-size:.78rem;color:var(--muted);padding:3px 0;text-decoration:none;transition:color .2s}
.legal-toc a:hover{color:var(--teal)}
.legal-body article h2{font-family:var(--serif);font-size:1.2rem;font-weight:800;margin:36px 0 12px;padding-top:20px;border-top:1px solid var(--brd);letter-spacing:-.02em}
.legal-body article h2:first-child{border-top:none;margin-top:0;padding-top:0}
.legal-body article h3{font-family:var(--sans);font-size:.92rem;font-weight:700;margin:16px 0 8px;color:var(--fg)}
.legal-body article p{font-size:.86rem;color:var(--muted);line-height:1.7;margin-bottom:12px}
.legal-body article ul{margin:8px 0 16px 20px;list-style:disc}
.legal-body article ul li{font-size:.84rem;color:var(--muted);line-height:1.6;margin-bottom:6px}
.legal-body article ul li strong{color:var(--fg);font-weight:600}
.legal-body article a{color:var(--teal);font-weight:500}
.legal-ref{margin-top:40px;padding:16px 20px;border-radius:12px;background:rgba(249,124,43,.03);border:1px solid rgba(249,124,43,.08)}
.legal-ref h4{font-size:.75rem;font-weight:700;color:var(--teal);margin-bottom:6px}
.legal-ref p{font-size:.72rem;color:var(--muted);line-height:1.6;margin:0}
@media(max-width:768px){.legal-body{padding:0 4px}}

/* ═══════════════════════════════════════════════════
   MOBILE RESPONSIVENESS FIXES
   ═══════════════════════════════════════════════════ */

/* Table overflow wrapper */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r);border:1px solid var(--brd)}
.tbl-wrap table{min-width:500px}
.tbl-wrap::-webkit-scrollbar{height:4px}
.tbl-wrap::-webkit-scrollbar-thumb{background:var(--brd);border-radius:4px}

/* Missing mobile breakpoints */
@media(max-width:768px){
  .demo-sts{grid-template-columns:1fr!important}
  .status-metrics{grid-template-columns:1fr 1fr}
  .contact-channels{grid-template-columns:1fr}
  .cmp-score{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .cmp-score{grid-template-columns:1fr}
  .status-metrics{grid-template-columns:1fr}
  .demo-sts{max-width:100%}
}

/* Improve touch targets */
.ft-col a{min-height:44px;display:flex;align-items:center}
.legal-toc a{min-height:40px;display:flex;align-items:center}
.mob a{min-height:48px;display:flex;align-items:center;justify-content:center}
.btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center}

/* Prevent horizontal overflow on all pages */
html,body{overflow-x:hidden;max-width:100vw}
img,video,svg,canvas{max-width:100%}

/* Mobile hero improvements */
@media(max-width:768px){
  .hero{padding:100px 0 32px!important}
  .hero h1{font-size:clamp(1.8rem,7vw,2.8rem)}
  .hero-desc{font-size:.92rem}
  .s-hd{font-size:clamp(1.3rem,5vw,2rem)}
  .s-desc{font-size:.85rem}
  .s-ey{font-size:.62rem;padding:5px 12px}
}

/* Mobile modal improvements */
@media(max-width:768px){
  .modal{width:95%;max-height:90vh;overflow-y:auto;padding:20px;margin:auto}
  .modal h3{font-size:1.1rem}
  .modal input,.modal select{font-size:16px!important}
}

/* Mobile footer improvements */
@media(max-width:768px){
  .ft-top{grid-template-columns:1fr;gap:24px}
  .ft-col{display:flex;flex-direction:column;gap:2px}
  .ft-col a{min-height:38px}
  .ft-bot{flex-direction:column;gap:8px;text-align:center}
}

/* Prevent text from being too wide on mobile */
@media(max-width:768px){
  .w{padding:0 16px}
  p,li{word-break:break-word}
}

/* Mobile-specific utility */
@media(max-width:768px){
  .ab-metrics-bar{flex-direction:column;gap:12px}
  .ab-m-div{width:40px;height:1px;background:var(--brd)}
  .ig-cta-box{padding:24px 20px}
  .proof-bottom{gap:12px}
  .proof-segs{gap:6px}
  .proof-segs span{font-size:.65rem;padding:4px 10px}
}

/* Fix input zoom on iOS (font-size < 16px triggers zoom) */
@media(max-width:768px){
  input[type="text"],input[type="email"],input[type="tel"],
  input[type="password"],select,textarea{
    font-size:16px!important
  }
}

/* Safe area for notch devices */
@supports(padding:env(safe-area-inset-bottom)){
  .nav{padding-top:env(safe-area-inset-top)}
  .wa-fab{bottom:calc(20px + env(safe-area-inset-bottom))}
  footer{padding-bottom:env(safe-area-inset-bottom)}
}

/* Fix inline flex containers on mobile */
@media(max-width:768px){
  [style*="display:flex"]{flex-wrap:wrap}
  [style*="display: flex"]{flex-wrap:wrap}
  
  /* Roadmap cards specific */
  .rm-card{flex-direction:column}
  
  /* Fix padding for para/ pages */
  .para-features{gap:12px}
  .para-features>div{padding:16px}
  
  /* Case impact grid */
  .case-impact{grid-template-columns:1fr 1fr}
  
  /* Glossary grid */
  [style*="grid-template-columns:repeat(auto-fill,minmax(270px"]{
    grid-template-columns:1fr!important
  }
  
  /* FAQ accordion touch target */
  .faq-q{min-height:48px;padding:14px 16px}
  
  /* Webinar cards */
  .webinar-card{flex-direction:column}
}
@media(max-width:480px){
  .case-impact{grid-template-columns:1fr}
}

/* Screen-reader only (SEO heading hierarchy) */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ═══════════════════════════════════════════════════
   RUPHUS PRELOADER — Branded loading screen
   ═══════════════════════════════════════════════════ */
.preloader{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);transition:opacity .5s,visibility .5s}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}

/* Logo hexagon container */
.pl-logo{position:relative;width:80px;height:80px;margin-bottom:28px}

/* Rotating hexagon ring */
.pl-hex{position:absolute;inset:0;animation:plSpin 2.5s cubic-bezier(.4,0,.2,1) infinite}
.pl-hex svg{width:80px;height:80px}

/* Pulsing R letter */
.pl-r{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;animation:plPulse 2.5s ease-in-out infinite}
.pl-r svg{width:32px;height:32px}

/* Orbiting dots */
.pl-dots{position:absolute;inset:-12px;animation:plSpin 3s linear infinite reverse}
.pl-dot{position:absolute;width:5px;height:5px;border-radius:50%;background:var(--teal)}
.pl-dot:nth-child(1){top:0;left:50%;transform:translateX(-50%)}
.pl-dot:nth-child(2){bottom:0;left:50%;transform:translateX(-50%);opacity:.5}
.pl-dot:nth-child(3){top:50%;left:0;transform:translateY(-50%);opacity:.3}

/* Brand name */
.pl-name{font-family:var(--serif);font-size:1.1rem;font-weight:700;letter-spacing:-.02em;color:var(--fg);margin-bottom:6px;animation:plFadeUp .6s ease .2s both}

/* Tagline */
.pl-tag{font-size:.68rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-weight:500;animation:plFadeUp .6s ease .4s both}

/* Progress bar */
.pl-bar{width:120px;height:2px;border-radius:2px;background:var(--brd);margin-top:20px;overflow:hidden;animation:plFadeUp .6s ease .5s both}
.pl-bar-fill{height:100%;width:0;border-radius:2px;background:linear-gradient(90deg,var(--teal),#3B82F6,#8B5CF6,#EC4899);animation:plProgress 1.2s cubic-bezier(.4,0,.2,1) .3s forwards}

@keyframes plSpin{
  0%{transform:rotate(0deg)}
  100%{transform:rotate(360deg)}
}
@keyframes plPulse{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.08);opacity:.8}
}
@keyframes plFadeUp{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:none}
}
@keyframes plProgress{
  0%{width:0}
  60%{width:70%}
  100%{width:100%}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  .pl-hex,.pl-dots,.pl-r{animation:none}
  .pl-bar-fill{animation:plProgress 1s linear .1s forwards}
}
