:root{
  --p:#10b981;--p2:#059669;--p3:#34d399;--accent-b:#60a5fa;--accent-p:#a78bfa;
  --dark:#070e12;--dark-2:#0d1721;--card:#0f1b26;--panel:rgba(15,27,38,0.72);
  --bg:#f4f8ff;--w:#fff;--t:#0f172a;--td:#64748b;
  --bd:rgba(255,255,255,0.08);--bd-strong:rgba(255,255,255,0.14);--bgl:rgba(15,23,42,0.08);
  --r:16px;--sh:0 12px 40px -8px rgba(15,23,42,.15);--shg:0 14px 36px -10px rgba(16,185,129,.35);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Outfit',system-ui,sans-serif;background:var(--bg);color:var(--t);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}

/* ── PRELOADER ───────────────────────────────────── */
.page-loader{position:fixed;inset:0;background:var(--dark);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,visibility .6s ease}
.page-loader.loaded{opacity:0;visibility:hidden}
.loader-content{position:relative;display:flex;align-items:center;justify-content:center}
.loader-logo{width:70px;height:70px;object-fit:contain;animation:loader-pulse 2s cubic-bezier(.4,0,.6,1) infinite}
.loader-ring{position:absolute;width:110px;height:110px;border-radius:50%;border:2px solid transparent;border-top-color:var(--p);border-left-color:rgba(16,185,129,.3);animation:loader-spin 1.2s cubic-bezier(.68,-.55,.265,1.55) infinite}
@keyframes loader-spin{to{transform:rotate(360deg)}}
@keyframes loader-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.9);opacity:.6}}

/* ── NAV ─────────────────────────────────────────── */
#header{position:sticky;top:0;z-index:200;background:rgba(7,14,18,.72);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid transparent;transition:all .3s}
#header.scrolled{background:rgba(7,14,18,.92);border-bottom-color:var(--bd)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:72px}
.logo{display:flex;align-items:center;gap:.6rem;font-weight:800;font-size:1.25rem;color:#fff;text-decoration:none;letter-spacing:-.02em}
.main-logo{width:38px;height:38px;object-fit:contain}
.nav-links{display:flex;gap:2.25rem;list-style:none;margin:0 auto}
.nav-links a{text-decoration:none;color:rgba(255,255,255,.6);font-weight:500;font-size:.9rem;letter-spacing:.01em;transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--p);transition:width .25s}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:.65rem}
.lang-btn{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.04);border:1px solid var(--bd);padding:.45rem .75rem;border-radius:9px;font-weight:600;font-size:.78rem;cursor:pointer;color:rgba(255,255,255,.65);letter-spacing:.04em;transition:all .2s}
.lang-btn:hover{background:rgba(255,255,255,.08);color:#fff;border-color:var(--bd-strong)}
.lang-btn svg{width:14px;height:14px}
.btn-nav{background:linear-gradient(135deg,var(--p2) 0%,var(--p) 100%);color:#04120b;padding:.55rem 1.2rem;border-radius:9px;font-weight:700;font-size:.85rem;text-decoration:none;transition:all .2s;box-shadow:0 6px 16px -4px rgba(16,185,129,.45)}
.btn-nav:hover{transform:translateY(-1px);box-shadow:0 10px 22px -4px rgba(16,185,129,.55);filter:brightness(1.05)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.4rem}
.hamburger span{display:block;width:22px;height:2px;background:rgba(255,255,255,.75);border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:190}
.mobile-overlay.show{display:block}

/* ── HERO ────────────────────────────────────────── */
.hero{background:var(--dark);position:relative;overflow:hidden;padding:5.5rem 0 4rem}
.hero-grid-bg{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at center,#000 35%,transparent 85%);
  -webkit-mask-image:radial-gradient(ellipse at center,#000 35%,transparent 85%);
  pointer-events:none;z-index:1
}
.hero-aurora{position:absolute;border-radius:50%;filter:blur(90px);z-index:0;opacity:.5;pointer-events:none;will-change:transform}
.hero-aurora-1{width:560px;height:560px;background:radial-gradient(circle,#10b981 0%,transparent 65%);top:-180px;left:-100px;animation:aurora 20s ease-in-out infinite}
.hero-aurora-2{width:520px;height:520px;background:radial-gradient(circle,#a78bfa 0%,transparent 65%);top:10%;right:-160px;animation:aurora 24s ease-in-out infinite reverse}
.hero-aurora-3{width:480px;height:480px;background:radial-gradient(circle,#60a5fa 0%,transparent 65%);bottom:-180px;left:30%;animation:aurora 28s ease-in-out infinite}
@keyframes aurora{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(60px,-40px) scale(1.08)}
  66%{transform:translate(-40px,50px) scale(.95)}
}
.hero-spotlight{position:absolute;inset:0;pointer-events:none;z-index:2;background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%),rgba(16,185,129,.08),transparent 45%);transition:background .1s}

.hero-inner{display:grid;grid-template-columns:1.05fr 1fr;gap:3.5rem;align-items:center;position:relative;z-index:10}

.hero-badge{display:inline-flex;align-items:center;gap:.45rem;border:1px solid rgba(16,185,129,.3);background:rgba(16,185,129,.07);color:var(--p3);padding:.4rem .85rem;border-radius:99px;font-size:.72rem;font-weight:700;letter-spacing:.08em;margin-bottom:1.25rem;backdrop-filter:blur(8px)}
.hero-badge svg{width:12px;height:12px}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--p3);box-shadow:0 0 10px var(--p3);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

h1{font-size:clamp(2.2rem,4.6vw,3.8rem);line-height:1.02;font-weight:800;color:#fff;letter-spacing:-.04em;margin-bottom:1.35rem;font-family:'Outfit',sans-serif}
.h1-accent{display:block;background:linear-gradient(135deg,#34d399 0%,#60a5fa 50%,#a78bfa 100%);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradShift 9s ease-in-out infinite}
@keyframes gradShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

.hero-content>p{font-size:1.08rem;color:rgba(255,255,255,.6);margin-bottom:2rem;max-width:500px;line-height:1.6}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:1.5rem}
.btn-glow{display:inline-flex;align-items:center;gap:.55rem;background:linear-gradient(135deg,var(--p2) 0%,var(--p) 55%,var(--p3) 100%);background-size:200% 200%;color:#04120b;border:none;padding:.9rem 1.85rem;border-radius:12px;font-weight:800;font-size:.95rem;cursor:pointer;text-decoration:none;transition:all .3s;box-shadow:0 12px 30px -8px rgba(16,185,129,.5),inset 0 1px 0 rgba(255,255,255,.25);position:relative;overflow:hidden}
.btn-glow::after{content:'';position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);transform:translateX(-120%);transition:transform .7s}
.btn-glow:hover{transform:translateY(-2px);background-position:100% 0;box-shadow:0 18px 38px -8px rgba(16,185,129,.6)}
.btn-glow:hover::after{transform:translateX(120%)}
.btn-glow svg{width:17px;height:17px}
.btn-ghost-hero{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.04);color:rgba(255,255,255,.7);border:1px solid var(--bd);padding:.9rem 1.7rem;border-radius:12px;font-weight:600;font-size:.95rem;cursor:pointer;text-decoration:none;transition:all .25s;backdrop-filter:blur(8px)}
.btn-ghost-hero:hover{color:#fff;border-color:var(--bd-strong);background:rgba(255,255,255,.08);transform:translateY(-1px)}
.btn-ghost-hero svg{width:15px;height:15px}

.hero-trust{display:flex;flex-wrap:wrap;gap:.6rem 1.15rem;margin-bottom:2rem}
.hero-trust-item{display:inline-flex;align-items:center;gap:.35rem;color:rgba(255,255,255,.5);font-size:.82rem;font-weight:500}
.hero-trust-item svg{width:13px;height:13px;color:var(--p3)}

.hero-stats{display:flex;align-items:center;gap:1.75rem;padding-top:1.25rem;border-top:1px solid var(--bd)}
.stat-item{display:flex;flex-direction:column}
.stat-item strong{font-size:1.6rem;font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1}
.stat-item strong::after{content:'';display:inline-block;width:8px;height:8px;background:var(--p3);border-radius:50%;margin-left:6px;box-shadow:0 0 10px var(--p3);animation:pulse 2.4s ease-in-out infinite}
.stat-item:nth-child(n+3) strong::after{display:none}
.stat-item span{font-size:.72rem;color:rgba(255,255,255,.4);font-weight:500;text-transform:uppercase;letter-spacing:.06em;margin-top:.2rem}
.divider-v{width:1px;height:34px;background:var(--bd)}

/* Hero mockup */
.hero-visual{position:relative;perspective:1600px}
.hero-glow{position:absolute;inset:-20px;background:radial-gradient(circle at center,rgba(16,185,129,.18),transparent 65%);pointer-events:none;filter:blur(30px)}
.mockup{
  position:relative;background:linear-gradient(180deg,rgba(13,23,33,.92) 0%,rgba(13,23,33,.82) 100%);
  border:1px solid var(--bd-strong);border-radius:18px;overflow:hidden;
  box-shadow:0 40px 80px -30px rgba(0,0,0,.75),0 0 0 1px rgba(255,255,255,.04),inset 0 1px 0 rgba(255,255,255,.08);
  transform:rotateX(4deg) rotateY(-6deg);
  transition:transform .7s cubic-bezier(.16,1,.3,1)
}
.mockup:hover{transform:rotateX(1deg) rotateY(-2deg) translateY(-6px)}
.mockup-bar{display:flex;align-items:center;gap:.4rem;padding:.7rem .9rem;background:rgba(5,10,15,.55);border-bottom:1px solid var(--bd)}
.mockup-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.15)}
.mockup-dot:nth-child(1){background:#f87171}
.mockup-dot:nth-child(2){background:#fbbf24}
.mockup-dot:nth-child(3){background:#34d399}
.mockup-url{margin-left:.6rem;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:.7rem;color:rgba(255,255,255,.4)}
.mockup-body{padding:1rem 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.9rem}
.mockup-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem}
.mkpi{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:.6rem .7rem;display:flex;flex-direction:column;gap:.15rem}
.mkpi-label{display:inline-flex;align-items:center;gap:.3rem;font-size:.64rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.06em;font-weight:500}
.mkpi-label svg{width:11px;height:11px}
.mkpi strong{font-size:1.1rem;color:#fff;letter-spacing:-.02em;font-weight:700}
.mkpi strong em{font-style:normal;font-size:.7rem;color:rgba(255,255,255,.55);font-weight:600;margin-left:2px}
.mkpi-delta{font-size:.66rem;font-weight:700;display:inline-block;width:fit-content;padding:.1rem .4rem;border-radius:5px;margin-top:.15rem}
.mkpi-delta.up{color:#34d399;background:rgba(52,211,153,.14)}
.mkpi-delta.ok{color:#60a5fa;background:rgba(96,165,250,.14)}
.mockup-chart{height:88px}
.mockup-chart svg{width:100%;height:100%;display:block}
.chart-area{fill:url(#chartGrad)}
.chart-line{stroke:#34d399;stroke-width:2;fill:none}
.chart-dot{fill:#34d399;filter:drop-shadow(0 0 6px rgba(52,211,153,.7))}
.mockup-rows{display:flex;flex-direction:column;gap:.3rem}
.mrow{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:.6rem;padding:.45rem .65rem;background:rgba(255,255,255,.02);border-radius:8px;font-size:.76rem}
.mrow-code{font-family:'JetBrains Mono',ui-monospace,monospace;color:rgba(255,255,255,.55);font-size:.7rem}
.mrow-client{color:rgba(255,255,255,.75);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mrow-amt{color:#fff;font-weight:700;font-variant-numeric:tabular-nums}
.mrow-tag{font-size:.6rem;font-weight:700;padding:.12rem .45rem;border-radius:99px;text-transform:uppercase;letter-spacing:.04em}
.mrow-tag.ok{background:rgba(52,211,153,.16);color:#34d399}
.mrow-tag.pending{background:rgba(250,204,21,.16);color:#facc15}

.float-card{position:absolute;display:flex;align-items:center;gap:.7rem;padding:.75rem 1rem;border-radius:13px;border:1px solid var(--bd-strong);box-shadow:0 16px 40px -8px rgba(0,0,0,.5);z-index:5}
.glass{background:rgba(13,23,33,.78);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.fc-top{top:-1rem;right:-1.3rem;animation:floatA 6s ease-in-out infinite}
.fc-bottom{bottom:-1rem;left:-1.5rem;animation:floatA 6s ease-in-out infinite 3s}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.float-card .fc-ic{width:30px;height:30px;border-radius:9px;background:rgba(16,185,129,.14);display:grid;place-items:center;flex-shrink:0}
.float-card .fc-ic svg{width:14px;height:14px;color:var(--p3)}
.float-card strong{display:block;font-size:.82rem;font-weight:700;color:#fff;letter-spacing:-.01em}
.float-card span{font-size:.7rem;color:rgba(255,255,255,.5)}

/* Hero logos strip */
.hero-logos{position:relative;z-index:10;margin-top:4rem;padding-top:2.5rem;border-top:1px solid var(--bd);text-align:center}
.hero-logos-label{display:block;font-size:.72rem;color:rgba(255,255,255,.38);letter-spacing:.14em;text-transform:uppercase;font-weight:600;margin-bottom:1.25rem}
.hero-logos-row{display:flex;justify-content:center;align-items:center;gap:2.5rem;flex-wrap:wrap}
.hlogo{display:inline-flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.45);font-size:.88rem;font-weight:600;transition:color .25s}
.hlogo:hover{color:rgba(255,255,255,.75)}
.hlogo svg{width:16px;height:16px}

/* ── MODULES (Bento) ─────────────────────────────── */
.section-dark{background:var(--dark);padding:6rem 0;border-top:1px solid var(--bd);position:relative;overflow:hidden}
.section-dark::before{content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:900px;height:400px;background:radial-gradient(ellipse at center,rgba(16,185,129,.1),transparent 70%);filter:blur(60px);pointer-events:none}
.sec-badge{margin-bottom:1rem;position:relative;z-index:2}
.sec-badge span,.sec-badge-light span{display:inline-flex;align-items:center;padding:.35rem .95rem;border-radius:99px;background:rgba(16,185,129,.1);color:var(--p3);font-size:.72rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;border:1px solid rgba(16,185,129,.28)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;margin-bottom:3rem;position:relative;z-index:2}
.sec-head h2{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:800;color:#fff;letter-spacing:-.03em;line-height:1.1}
.sec-head p{color:rgba(255,255,255,.42);font-size:.95rem;max-width:320px;text-align:right;line-height:1.5}

.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:auto;gap:1rem;position:relative;z-index:2}
.bento-card{
  background:rgba(255,255,255,.02);border:1px solid var(--bd);border-radius:18px;padding:1.6rem;
  transition:all .3s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;cursor:default
}
.bento-card::before{content:'';position:absolute;inset:0;background:radial-gradient(360px circle at var(--bx,50%) var(--by,50%),rgba(16,185,129,.12),transparent 45%);opacity:0;transition:opacity .3s;pointer-events:none}
.bento-card:hover{border-color:rgba(16,185,129,.35);background:rgba(255,255,255,.035);transform:translateY(-4px);box-shadow:0 20px 48px -12px rgba(0,0,0,.5)}
.bento-card:hover::before{opacity:1}
.bento-card h3{font-size:1rem;font-weight:700;color:#fff;margin-bottom:.4rem;letter-spacing:-.01em}
.bento-card p{font-size:.86rem;color:rgba(255,255,255,.5);line-height:1.55}

.bento-feat{grid-column:span 2;grid-row:span 2;padding:2rem;background:linear-gradient(135deg,rgba(16,185,129,.1) 0%,rgba(96,165,250,.06) 50%,rgba(167,139,250,.04) 100%);border-color:rgba(16,185,129,.25);position:relative}
.bento-feat-glow{position:absolute;top:-30%;right:-10%;width:60%;height:160%;background:radial-gradient(ellipse at center,rgba(16,185,129,.25),transparent 60%);filter:blur(50px);pointer-events:none}
.bento-feat-inner{position:relative;display:flex;flex-direction:column;gap:.75rem;height:100%}
.bento-feat h3{font-size:1.6rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.55rem}
.bento-feat p{font-size:1rem;max-width:460px}
.bento-feat-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:auto;padding-top:1rem}
.bento-feat-chips span{padding:.3rem .7rem;border-radius:8px;background:rgba(16,185,129,.12);color:var(--p3);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:.72rem;font-weight:600;border:1px solid rgba(16,185,129,.22)}

.mod-ic{width:42px;height:42px;border-radius:12px;background:rgba(16,185,129,.12);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;border:1px solid rgba(16,185,129,.2);transition:all .3s}
.bento-card:hover .mod-ic{background:rgba(16,185,129,.2);border-color:rgba(16,185,129,.4);transform:scale(1.05)}
.mod-ic svg{width:19px;height:19px;color:var(--p3)}

.mod-badge{display:inline-flex;align-items:center;width:fit-content;background:linear-gradient(135deg,var(--p) 0%,var(--p3) 100%);color:#04120b;padding:.3rem .8rem;border-radius:99px;font-size:.68rem;font-weight:800;letter-spacing:.05em;margin-bottom:.5rem;box-shadow:0 6px 14px -4px rgba(16,185,129,.4)}

/* SOLICITE */
.solicite-strip{margin-top:2.5rem;background:linear-gradient(135deg,rgba(16,185,129,.15) 0%,rgba(96,165,250,.08) 100%);border:1px solid rgba(16,185,129,.25);border-radius:18px;padding:1.75rem 2.25rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;position:relative;overflow:hidden}
.solicite-strip::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(16,185,129,.2),transparent 60%);pointer-events:none}
.sol-left{display:flex;align-items:center;gap:1.15rem;position:relative;z-index:2}
.sol-icon{width:50px;height:50px;border-radius:14px;background:rgba(16,185,129,.14);border:1px solid rgba(16,185,129,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sol-icon svg{width:22px;height:22px;color:var(--p3)}
.sol-left strong{display:block;font-size:1.15rem;font-weight:800;color:#fff;letter-spacing:-.01em}
.sol-left span{font-size:.88rem;color:rgba(255,255,255,.55)}
.btn-solicite{background:linear-gradient(135deg,var(--p2) 0%,var(--p) 50%,var(--p3) 100%);color:#04120b;padding:.85rem 1.75rem;border-radius:11px;font-weight:800;font-size:.9rem;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:all .25s;box-shadow:0 10px 22px -6px rgba(16,185,129,.5);position:relative;z-index:2}
.btn-solicite:hover{transform:translateY(-2px);box-shadow:0 16px 30px -6px rgba(16,185,129,.6);filter:brightness(1.05)}

/* ── COMO FUNCIONA (Timeline) ────────────────────── */
.section-light{background:#fff;padding:6rem 0;position:relative;overflow:hidden}
.section-light::before{content:'';position:absolute;top:20%;left:-200px;width:500px;height:500px;background:radial-gradient(circle,rgba(16,185,129,.06),transparent 65%);pointer-events:none}
.sec-badge-dark span{background:var(--dark);color:#fff;border:none}
.sec-title-light{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:800;color:var(--t);letter-spacing:-.03em;margin:1rem 0 3.5rem;line-height:1.1;position:relative;z-index:2}

.timeline{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;z-index:2}
.timeline-track{position:absolute;top:20px;left:40px;right:40px;height:2px;background:linear-gradient(90deg,var(--p3) 0%,#60a5fa 50%,#a78bfa 100%);opacity:.22;z-index:0}
.timeline-step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-start;gap:1rem}
.ts-node{width:42px;height:42px;border-radius:50%;background:#fff;border:2px solid var(--p);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--p2);font-size:.88rem;box-shadow:0 0 0 6px rgba(16,185,129,.08),0 8px 18px -4px rgba(16,185,129,.25)}
.ts-card{width:100%;background:#fff;border:1px solid var(--bgl);border-radius:14px;padding:1.35rem 1.4rem;transition:all .3s;position:relative;overflow:hidden}
.ts-card::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(16,185,129,.04),transparent 60%);opacity:0;transition:opacity .3s;pointer-events:none}
.ts-card:hover{border-color:rgba(16,185,129,.35);transform:translateY(-4px);box-shadow:0 18px 40px -10px rgba(16,185,129,.18)}
.ts-card:hover::after{opacity:1}
.ts-ic{width:34px;height:34px;border-radius:9px;background:rgba(16,185,129,.1);display:flex;align-items:center;justify-content:center;margin-bottom:.7rem}
.ts-ic svg{width:17px;height:17px;color:var(--p2)}
.ts-card h3{font-size:1rem;font-weight:700;color:var(--t);margin-bottom:.35rem;letter-spacing:-.01em}
.ts-card p{font-size:.85rem;color:var(--td);line-height:1.55}

/* ── CTA ─────────────────────────────────────────── */
.section-cta{background:var(--dark);padding:6rem 0;border-top:1px solid var(--bd);position:relative;overflow:hidden}
.section-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at bottom right,rgba(167,139,250,.08),transparent 60%);pointer-events:none}
.cta-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:0;border-radius:24px;overflow:hidden;border:1px solid var(--bd-strong);background:rgba(13,23,33,.5);backdrop-filter:blur(10px);position:relative}
.cta-wrap::before{content:'';position:absolute;inset:0;padding:1px;border-radius:24px;background:conic-gradient(from 0deg,rgba(16,185,129,.4),rgba(96,165,250,.2),rgba(167,139,250,.3),rgba(16,185,129,.4));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.35;pointer-events:none}
.cta-left{position:relative;min-height:460px}
.cta-img{width:100%;height:100%;object-fit:cover;object-position:top;display:block}
.cta-img-overlay{position:absolute;inset:0;background:linear-gradient(90deg,transparent 40%,rgba(13,23,33,.85) 90%,var(--dark) 100%)}
.cta-floating-stat{position:absolute;bottom:1.5rem;left:1.5rem;z-index:3;display:flex;align-items:center;gap:.75rem;padding:.85rem 1.1rem;background:rgba(13,23,33,.85);backdrop-filter:blur(14px);border:1px solid var(--bd-strong);border-radius:12px;box-shadow:0 10px 30px -8px rgba(0,0,0,.5)}
.cfs-ic{width:34px;height:34px;border-radius:10px;background:rgba(16,185,129,.15);display:grid;place-items:center}
.cfs-ic svg{width:16px;height:16px;color:var(--p3)}
.cta-floating-stat strong{display:block;font-size:.85rem;color:#fff;font-weight:700}
.cta-floating-stat span{font-size:.72rem;color:rgba(255,255,255,.5)}
.cta-right{padding:3.5rem 3rem;display:flex;flex-direction:column;justify-content:center;gap:1.15rem;position:relative;z-index:2}
.cta-pill{display:inline-flex;align-items:center;background:rgba(16,185,129,.12);color:var(--p3);border:1px solid rgba(16,185,129,.3);padding:.4rem 1rem;border-radius:99px;font-size:.72rem;font-weight:700;letter-spacing:.08em;width:fit-content;text-transform:uppercase}
.cta-right h2{font-size:clamp(1.6rem,2.8vw,2.2rem);font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1.15}
.cta-right p{color:rgba(255,255,255,.55);font-size:.98rem;line-height:1.65}
.cta-list{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-top:.25rem}
.cta-list li{display:flex;align-items:center;gap:.6rem;font-size:.9rem;color:rgba(255,255,255,.72);font-weight:500}
.cta-list li svg{width:16px;height:16px;color:var(--p3);flex-shrink:0}

/* ── CONTACT ─────────────────────────────────────── */
.section-contact{background:linear-gradient(180deg,var(--bg) 0%,#fff 100%);padding:6rem 0;position:relative}
.section-contact::before{content:'';position:absolute;top:-100px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(16,185,129,.06),transparent 65%);pointer-events:none}
.contact-wrap{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;align-items:start;position:relative;z-index:2}
.contact-info .sec-badge{margin-bottom:1.25rem}
.contact-info h2{font-size:clamp(1.6rem,2.6vw,2.15rem);font-weight:800;color:var(--t);letter-spacing:-.02em;margin-bottom:1rem;line-height:1.15}
.contact-info>p{color:var(--td);font-size:.95rem;line-height:1.65;margin-bottom:2rem}
.contact-cards{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}
.cc{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;border-radius:13px;border:1px solid var(--bgl);background:#fff;text-decoration:none;color:inherit;transition:all .25s}
.cc:hover{border-color:var(--p);box-shadow:0 10px 28px -8px rgba(16,185,129,.15);transform:translateY(-2px)}
.cc svg{width:18px;height:18px;color:var(--p2);flex-shrink:0}
.cc strong{display:block;font-size:.72rem;font-weight:700;color:var(--td);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.1rem}
.cc span{font-size:.92rem;font-weight:600;color:var(--t)}
.email-direct{font-size:.85rem;color:var(--td);background:#fff;border:1px dashed var(--bgl);padding:.95rem 1.15rem;border-radius:11px;line-height:1.55}
.email-direct a{color:var(--p2);font-weight:700;text-decoration:none}
.email-direct a:hover{text-decoration:underline}

.contact-form{background:#fff;border-radius:20px;padding:2.25rem;border:1px solid var(--bgl);box-shadow:0 20px 48px -16px rgba(15,23,42,.12);display:flex;flex-direction:column;gap:1.1rem;position:relative}
.contact-form::before{content:'';position:absolute;top:0;left:1.5rem;right:1.5rem;height:2px;background:linear-gradient(90deg,transparent,var(--p),transparent);border-radius:99px;opacity:.5}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.ff{display:flex;flex-direction:column;gap:.4rem}
.ff.full{grid-column:1/-1}
.ff label{font-size:.72rem;font-weight:700;color:var(--td);text-transform:uppercase;letter-spacing:.06em}
.ff input,.ff select,.ff textarea{padding:.85rem 1rem;border:1.5px solid var(--bgl);border-radius:11px;font-family:'Outfit',sans-serif;font-size:.95rem;color:var(--t);background:var(--bg);transition:all .2s;outline:none;resize:vertical}
.ff input:focus,.ff select:focus,.ff textarea:focus{border-color:var(--p);box-shadow:0 0 0 4px rgba(16,185,129,.12);background:#fff}
.ff input::placeholder,.ff textarea::placeholder{color:rgba(15,23,42,.35)}
.btn-submit{display:flex;align-items:center;justify-content:center;gap:.55rem;background:linear-gradient(135deg,var(--p2) 0%,var(--p) 55%,var(--p3) 100%);color:#04120b;border:none;padding:1.05rem;border-radius:12px;font-weight:800;font-size:.95rem;cursor:pointer;transition:all .25s;box-shadow:var(--shg);position:relative;overflow:hidden}
.btn-submit::after{content:'';position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);transform:translateX(-120%);transition:transform .7s}
.btn-submit:hover{transform:translateY(-2px);box-shadow:0 20px 40px -10px rgba(16,185,129,.45)}
.btn-submit:hover::after{transform:translateX(120%)}
.btn-submit:disabled{opacity:1;pointer-events:none}

/* Atom loader */
.nuc-btn-loader{display:inline-flex;align-items:center;justify-content:center;position:relative;width:22px;height:22px;flex-shrink:0}
.nuc-orbit{position:absolute;inset:0;border-radius:50%;border:1.5px solid transparent}
.nuc-o1{border-top-color:rgba(4,18,11,.9);border-right-color:rgba(4,18,11,.2);animation:nuc-o1 1.2s linear infinite}
.nuc-o2{inset:4px;border-bottom-color:rgba(4,18,11,.8);border-left-color:rgba(4,18,11,.15);animation:nuc-o2 .85s linear infinite}
.nuc-o3{inset:8px;border-right-color:rgba(4,18,11,.7);border-top-color:rgba(4,18,11,.1);animation:nuc-o1 .6s linear infinite}
.nuc-electron{position:absolute;width:4px;height:4px;border-radius:50%;background:#04120b;top:-2px;left:50%;transform:translateX(-50%)}
.nuc-o2 .nuc-electron{top:auto;bottom:-2px}
.nuc-core-btn{position:absolute;inset:9px;border-radius:50%;background:#000;display:flex;align-items:center;justify-content:center}
.nuc-core-btn img{width:7px;height:7px;object-fit:contain;filter:brightness(0) invert(1)}
@keyframes nuc-o1{to{transform:rotate(360deg)}}
@keyframes nuc-o2{to{transform:rotate(-360deg)}}

.form-status{padding:.95rem 1.1rem;border-radius:11px;font-weight:600;font-size:.9rem;text-align:center}
.form-status.success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.form-status.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* ── FOOTER ──────────────────────────────────────── */
footer{background:var(--dark);padding:4.5rem 0 0;color:#fff;border-top:1px solid var(--bd);position:relative;overflow:hidden}
footer::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:60%;height:1px;background:linear-gradient(90deg,transparent,var(--p3),transparent);opacity:.4}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:4rem;padding-bottom:3.5rem}
.f-brand .logo-w{color:#fff}
.logo-inv{filter:brightness(0) invert(1)}
.f-brand>p{color:rgba(255,255,255,.38);font-size:.88rem;margin:.75rem 0 1.5rem;line-height:1.6;max-width:320px}
.socials{display:flex;gap:.65rem}
.socials a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);text-decoration:none;transition:all .25s}
.socials a:hover{background:var(--p);border-color:var(--p);color:#04120b;transform:translateY(-2px)}
.socials svg{width:15px;height:15px}
.f-nav h4,.f-contact h4{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.4);margin-bottom:1.15rem}
.f-nav,.f-contact{display:flex;flex-direction:column;gap:.65rem}
.f-nav a,.f-contact a,.f-contact span{color:rgba(255,255,255,.55);text-decoration:none;font-size:.9rem;transition:color .2s}
.f-nav a:hover,.f-contact a:hover{color:var(--p3)}
.footer-bottom{padding:1.5rem 0;border-top:1px solid var(--bd);color:rgba(255,255,255,.3);font-size:.82rem}

/* ── REVEAL ──────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:all .7s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:none}

/* ── RESPONSIVE ──────────────────────────────────── */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:3rem}
  .hero-visual{order:-1;max-width:520px;margin:0 auto}
  .mockup{transform:none}
  .fc-top{right:0;top:-.5rem}
  .fc-bottom{left:0;bottom:-.5rem}
  .hero-content>p{max-width:100%}
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento-feat{grid-column:span 2;grid-row:auto}
  .timeline{grid-template-columns:repeat(2,1fr);gap:2rem}
  .timeline-track{display:none}
  .cta-wrap{grid-template-columns:1fr}
  .cta-left{min-height:280px}
  .cta-right{padding:2.5rem}
  .contact-wrap{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:3rem}
}
@media(max-width:768px){
  .nav-links{display:none;position:fixed;top:72px;left:0;right:0;background:var(--dark);flex-direction:column;gap:0;border-bottom:1px solid var(--bd);z-index:195;margin:0;padding:0}
  .nav-links.open{display:flex}
  .nav-links li a{display:block;padding:1rem 1.5rem;color:rgba(255,255,255,.6);font-size:.95rem;border-bottom:1px solid var(--bd)}
  .hamburger{display:flex}
  .btn-nav{display:none}
  .hero{padding:3rem 0 2.5rem}
  .hero-inner{gap:2.5rem}
  .hero-logos-row{gap:1.25rem}
  .hlogo{font-size:.78rem}
  .hlogo svg{width:14px;height:14px}
  .bento{grid-template-columns:1fr}
  .bento-feat{grid-column:span 1}
  .timeline{grid-template-columns:1fr}
  .sec-head{flex-direction:column;align-items:flex-start}
  .sec-head p{text-align:left;max-width:100%}
  .solicite-strip{flex-direction:column;align-items:flex-start;padding:1.5rem}
  .frow{grid-template-columns:1fr}
  .ff.full{grid-column:1}
  .footer-grid{grid-template-columns:1fr}
  .mockup-kpis{grid-template-columns:1fr}
}
@media(max-width:480px){
  .hero-actions{flex-direction:column}
  .hero-actions .btn-glow,.hero-actions .btn-ghost-hero{width:100%;justify-content:center}
  .hero-stats{flex-wrap:wrap;gap:1rem}
  .divider-v{display:none}
  .mrow{grid-template-columns:auto 1fr auto}
  .mrow-client{display:none}
}

@media(prefers-reduced-motion:reduce){
  .hero-aurora,.h1-accent,.mockup,.float-card,.hero-badge-dot,.stat-item strong::after{animation:none !important}
  .reveal{opacity:1 !important;transform:none !important}
}
