/* ============================================================
   INCODATA — Sistema de Design
   Sora (display) + IBM Plex Sans (texto)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600&display=swap');

:root{
  /* Marca */
  --navy:        #0D2F4F;
  --navy-deep:   #0A2440;
  --navy-700:    #123A5E;
  --ink:         #0E2336;
  --teal:        #16A6A6;
  --teal-bright: #19B8B8;
  --teal-700:    #128F8F;
  --green:       #9FC97F;
  --green-soft:  #B7D89C;

  /* Neutros (frios, levemente azulados) */
  --white:   #FFFFFF;
  --paper:   #F4F8FB;
  --paper-2: #EDF3F8;
  --line:    #E2EAF1;
  --line-2:  #D3DEE9;
  --slate:   #5C6F80;
  --slate-2: #7E8F9D;
  --muted:   #93A3B1;

  /* Tipografia */
  --font-display: 'Space Grotesk', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;

  /* Espaçamento */
  --maxw: 1200px;
  --maxw-narrow: 820px;
  --radius: 14px;
  --radius-sm: 10px;
  --radius-lg: 22px;

  /* Sombras */
  --shadow-sm: 0 1px 2px rgba(13,47,79,.06), 0 2px 8px rgba(13,47,79,.05);
  --shadow:    0 4px 14px rgba(13,47,79,.08), 0 12px 34px rgba(13,47,79,.07);
  --shadow-lg: 0 18px 50px rgba(13,47,79,.16);

  --grad-brand: linear-gradient(120deg, var(--green) 0%, var(--teal) 60%, var(--teal-700) 100%);
  --grad-line: linear-gradient(90deg, var(--green), var(--teal));
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--white);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

h1,h2,h3,h4,h5{font-family:var(--font-display);color:var(--navy);font-weight:700;line-height:1.12;margin:0;letter-spacing:-.02em}
h1{font-size:clamp(2.4rem,4.8vw,3.9rem);font-weight:700}
h2{font-size:clamp(1.9rem,3.4vw,2.75rem);font-weight:700}
h3{font-size:1.38rem}

/* Gradient text utility */
.grad-text{background:var(--grad-line);-webkit-background-clip:text;background-clip:text;color:transparent}
.grad-text-cool{background:linear-gradient(120deg,#fff 20%,var(--teal-bright) 60%,var(--green-soft) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
p{margin:0}
::selection{background:var(--teal);color:#fff}

/* ---------- Layout ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.narrow{max-width:var(--maxw-narrow);margin-inline:auto}
.section{padding:96px 0}
.section-sm{padding:64px 0}
.bg-paper{background:var(--paper)}
.bg-navy{background:var(--navy);color:#E8F0F7}
.bg-navy h1,.bg-navy h2,.bg-navy h3{color:#fff}
.center{text-align:center}

.grid{display:grid;gap:24px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}

/* ---------- Eyebrow / section head ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-display);font-weight:600;font-size:.74rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--teal-700);
  margin-bottom:18px;
  padding:5px 12px 5px 8px;border-radius:999px;
  background:rgba(22,166,166,.08);border:1px solid rgba(22,166,166,.18);
}
.bg-navy .eyebrow{color:var(--teal-bright);background:rgba(22,166,166,.12);border-color:rgba(22,166,166,.3)}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--grad-line);flex:none;box-shadow:0 0 6px rgba(22,166,166,.7)}
.section-head{max-width:680px;margin-bottom:48px}
.section-head.center{margin-inline:auto}
.section-head p{color:var(--slate);font-size:1.12rem;margin-top:16px}
.bg-navy .section-head p{color:#AFC2D4}
.lead{font-size:1.18rem;color:var(--slate);line-height:1.6}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;font-size:.98rem;
  padding:14px 26px;border-radius:999px;border:1.5px solid transparent;
  transition:transform .18s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn-sm{padding:10px 20px;font-size:.88rem}
.btn-sm svg{width:16px;height:16px}
.btn-primary{background:var(--teal);color:#fff;box-shadow:0 6px 18px rgba(22,166,166,.32)}
.btn-primary:hover{background:var(--teal-700);transform:translateY(-2px);box-shadow:0 10px 26px rgba(22,166,166,.4)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:var(--navy-700);transform:translateY(-2px)}
.btn-outline{border-color:var(--line-2);color:var(--navy);background:#fff}
.btn-outline:hover{border-color:var(--teal);color:var(--teal-700);transform:translateY(-2px)}
.bg-navy .btn-outline{background:transparent;border-color:rgba(255,255,255,.28);color:#fff}
.bg-navy .btn-outline:hover{border-color:var(--green-soft);color:#fff}
.btn-ghost{color:var(--teal-700);padding-left:0;padding-right:0}
.btn-ghost:hover{gap:14px;color:var(--navy)}
.btn-lg{padding:17px 32px;font-size:1.05rem}

.link-arrow{display:inline-flex;align-items:center;gap:8px;color:var(--teal-700);font-weight:600;font-family:var(--font-display);font-size:.95rem;transition:gap .18s}
.link-arrow:hover{gap:13px}
.link-arrow svg{width:16px;height:16px}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 3px rgba(13,47,79,.05),0 3px 14px rgba(13,47,79,.06);
}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:34px;height:34px;flex:none}
.brand .word{font-family:var(--font-display);font-weight:700;font-size:1.42rem;color:var(--navy);letter-spacing:-.02em}
.nav{display:flex;align-items:center;gap:2px}
.nav-item{position:relative}
.nav-link{
  display:flex;align-items:center;gap:6px;padding:10px 15px;border-radius:9px;
  font-weight:500;font-size:.97rem;color:var(--ink);transition:.15s;
}
.nav-link:hover,.nav-item:hover .nav-link{color:var(--teal-700);background:var(--paper)}
.nav-link svg{width:13px;height:13px;opacity:.5;transition:.15s}
.nav-item:hover .nav-link svg{opacity:1}
.dropdown{
  position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);
  background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-lg);
  padding:10px;min-width:250px;opacity:0;visibility:hidden;transition:.18s;
}
.nav-item:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown a{display:block;padding:11px 14px;border-radius:9px;font-size:.95rem;color:var(--ink);transition:.13s}
.dropdown a small{display:block;color:var(--slate-2);font-size:.8rem;margin-top:2px}
.dropdown a:hover{background:var(--paper);color:var(--teal-700)}
.header-actions{display:flex;align-items:center;gap:10px}
.icon-btn{
  display:grid;place-items:center;width:42px;height:42px;border-radius:10px;
  border:1px solid var(--line);background:#fff;color:var(--navy);transition:.15s;
}
.icon-btn:hover{border-color:var(--teal);color:var(--teal-700)}
.icon-btn svg{width:19px;height:19px}
.menu-toggle{display:none}
.nav-cta{padding:11px 20px}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--navy);color:#fff}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(900px 480px at 78% -10%, rgba(22,166,166,.28), transparent 60%),
  radial-gradient(700px 420px at 10% 110%, rgba(159,201,127,.14), transparent 60%);
}
.hero-grid-bg{position:absolute;inset:0;background-image:
  linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:54px 54px;mask-image:linear-gradient(180deg,#000,transparent 85%)}
.hero .container{position:relative;z-index:2}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding:84px 0 96px}
.hero h1{color:#fff;letter-spacing:-.025em}
.hero h1 .hl{background:var(--grad-line);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{color:#B7C8D7;font-size:1.22rem;margin-top:22px;max-width:540px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hero-trust{margin-top:40px;display:flex;align-items:center;gap:20px;color:#8FA6B8;font-size:.9rem}
.hero-trust .dot{width:5px;height:5px;border-radius:50%;background:var(--green)}

/* ---------- Data bars motif ---------- */
.bars{display:flex;flex-direction:column;gap:7px}
.bars span{height:9px;border-radius:6px;background:var(--grad-line);opacity:.9}

/* ---------- Cards ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;transition:transform .2s ease, box-shadow .2s ease, border-color .2s}
.card:hover{transform:translateY(-5px);box-shadow:0 20px 50px rgba(13,47,79,.13),0 0 0 1px rgba(22,166,166,.15);border-color:rgba(22,166,166,.25)}
.card-icon{width:52px;height:52px;border-radius:13px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(22,166,166,.12),rgba(159,201,127,.14));color:var(--teal-700);margin-bottom:20px}
.card-icon svg{width:26px;height:26px}
.card h3{margin-bottom:10px;font-size:1.22rem}
.card p{color:var(--slate);font-size:.99rem}
.card-link{margin-top:18px}

.solution-card{display:flex;flex-direction:column;height:100%}
.solution-card .num{font-family:var(--font-display);font-weight:700;font-size:.85rem;color:var(--teal);letter-spacing:.05em;margin-bottom:14px}

/* tag/pill */
.tag{display:inline-flex;align-items:center;gap:6px;font-size:.76rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--teal-700);background:rgba(22,166,166,.09);padding:6px 12px;border-radius:999px}
.tag.green{color:#5b7d3a;background:rgba(159,201,127,.18)}
.tag.slate{color:var(--slate);background:var(--paper-2)}

/* stat */
.stat{padding:8px 0}
.stat .n{font-family:var(--font-display);font-weight:800;font-size:clamp(2.4rem,4vw,3.2rem);line-height:1;letter-spacing:-.03em;background:var(--grad-line);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .l{color:var(--slate);margin-top:10px;font-size:.98rem}
.bg-navy .stat .l{color:#A8BCCD}

/* partner card */
.partner-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;display:flex;flex-direction:column;gap:16px}
.partner-logo{font-family:var(--font-display);font-weight:800;font-size:1.7rem;color:var(--navy);letter-spacing:-.02em}
.partner-card .badge{align-self:flex-start}

/* ---------- Forms ---------- */
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:.9rem;color:var(--navy);margin-bottom:7px}
.field .req{color:var(--teal-700)}
.input,select.input,textarea.input{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  padding:13px 15px;border:1.5px solid var(--line-2);border-radius:11px;background:#fff;transition:.15s;
}
.input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px rgba(22,166,166,.13)}
textarea.input{min-height:130px;resize:vertical}
.checkbox{display:flex;gap:11px;align-items:flex-start;font-size:.9rem;color:var(--slate)}
.checkbox input{margin-top:3px;width:17px;height:17px;accent-color:var(--teal)}
.rd-badge{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;color:var(--slate-2);margin-top:6px}
.rd-badge::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green)}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:38px;box-shadow:var(--shadow)}

/* ---------- Breadcrumb ---------- */
.breadcrumb{display:flex;gap:9px;align-items:center;font-size:.86rem;color:var(--slate-2);padding:22px 0;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--teal-700)}
.breadcrumb .sep{opacity:.5}

/* ---------- Page hero (interior) ---------- */
.page-hero{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 400px at 85% -20%,rgba(22,166,166,.25),transparent 60%)}
.page-hero .container{position:relative;z-index:2}
.page-hero-inner{padding:72px 0 84px;max-width:760px}
.page-hero h1{color:#fff;margin-bottom:18px}
.page-hero p{color:#B7C8D7;font-size:1.18rem}
.page-hero .breadcrumb{color:#8FA6B8;padding-top:0;padding-bottom:26px}
.page-hero .breadcrumb a:hover{color:#fff}

/* ---------- Article / prose ---------- */
.prose{font-size:1.1rem;color:#26384a;line-height:1.78}
.prose h2{font-size:1.7rem;margin:42px 0 16px}
.prose h3{font-size:1.28rem;margin:32px 0 12px;color:var(--navy)}
.prose p{margin:0 0 20px}
.prose ul{margin:0 0 22px;padding-left:4px;list-style:none}
.prose ul li{position:relative;padding-left:30px;margin-bottom:12px}
.prose ul li::before{content:"";position:absolute;left:4px;top:11px;width:10px;height:10px;border-radius:3px;background:var(--grad-line)}
.prose blockquote{margin:30px 0;padding:22px 28px;border-left:3px solid var(--teal);background:var(--paper);border-radius:0 12px 12px 0;font-size:1.18rem;color:var(--navy);font-weight:500}
.prose strong{color:var(--navy)}

/* ---------- Placeholder media ---------- */
.media{position:relative;border-radius:var(--radius);overflow:hidden;min-width:0;max-width:100%;background:
  repeating-linear-gradient(135deg,#E9F0F6 0 14px,#E2EAF1 14px 28px);
  border:1px solid var(--line);display:grid;place-items:center;color:var(--slate-2)}
.media .ph{font-family:'IBM Plex Mono',ui-monospace,monospace;font-size:.8rem;letter-spacing:.04em;background:rgba(255,255,255,.82);padding:7px 13px;border-radius:8px;border:1px solid var(--line)}
.media.dark{background:repeating-linear-gradient(135deg,#10314f 0 14px,#0d2a45 14px 28px);border-color:rgba(255,255,255,.08)}
.media.dark .ph{background:rgba(13,47,79,.7);color:#9FB6C9;border-color:rgba(255,255,255,.12)}
.ratio-16-9{aspect-ratio:16/9}
.ratio-4-3{aspect-ratio:4/3}
.ratio-3-2{aspect-ratio:3/2}
.ratio-1-1{aspect-ratio:1/1}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-deep);color:#9FB6C9;padding:72px 0 30px}
.site-footer .brand .word{color:#fff}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-top h4{color:#fff;font-size:.95rem;margin-bottom:18px;font-family:var(--font-display);letter-spacing:.02em}
.footer-col a{display:block;padding:7px 0;font-size:.94rem;color:#9FB6C9;transition:.13s}
.footer-col a:hover{color:var(--green-soft)}
.footer-about{font-size:.96rem;line-height:1.7;color:#9FB6C9;margin:20px 0;max-width:330px}
.footer-contact{font-size:.92rem;line-height:1.8}
.footer-social{display:flex;gap:10px;margin-top:18px}
.footer-social a{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#9FB6C9;transition:.16s}
.footer-social a:hover{color:#fff;border-color:var(--teal);background:rgba(22,166,166,.18)}
.footer-social svg{width:18px;height:18px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:26px;font-size:.86rem;color:#7790A6;flex-wrap:wrap}
.footer-bottom a:hover{color:#fff}

/* ---------- WhatsApp FAB ---------- */
.wa-fab{position:fixed;right:24px;bottom:24px;z-index:80;display:flex;align-items:center;gap:0;background:#25D366;color:#fff;border-radius:999px;padding:14px;box-shadow:0 10px 30px rgba(37,211,102,.4);transition:.25s;overflow:hidden}
.wa-fab svg{width:28px;height:28px;flex:none}
.wa-fab .wa-label{max-width:0;opacity:0;white-space:nowrap;font-family:var(--font-display);font-weight:600;font-size:.95rem;transition:.28s}
.wa-fab:hover{padding-right:22px}
.wa-fab:hover .wa-label{max-width:160px;opacity:1;margin-left:11px}

/* ---------- Cookie banner ---------- */
.cookie{position:fixed;left:24px;bottom:24px;z-index:75;max-width:430px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);padding:24px;transform:translateY(140%);transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.cookie.show{transform:translateY(0)}
.cookie h4{font-size:1.05rem;margin-bottom:8px}
.cookie p{font-size:.88rem;color:var(--slate);margin-bottom:16px}
.cookie p a{color:var(--teal-700);text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie .btn{padding:11px 20px;font-size:.9rem}

/* ---------- Search modal ---------- */
.search-modal{position:fixed;inset:0;z-index:100;display:none}
.search-modal.open{display:block}
.search-modal .overlay{position:absolute;inset:0;background:rgba(10,36,64,.55);backdrop-filter:blur(4px)}
.search-panel{position:relative;max-width:680px;margin:9vh auto 0;background:#fff;border-radius:18px;box-shadow:var(--shadow-lg);overflow:hidden;animation:pop .22s ease}
@keyframes pop{from{transform:translateY(14px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.search-head{display:flex;align-items:center;gap:14px;padding:20px 22px;border-bottom:1px solid var(--line)}
.search-head svg{width:22px;height:22px;color:var(--teal-700);flex:none}
.search-head input{flex:1;border:none;outline:none;font-family:var(--font-body);font-size:1.18rem;color:var(--ink)}
.search-head kbd{font-family:var(--font-body);font-size:.72rem;color:var(--slate-2);border:1px solid var(--line-2);border-radius:6px;padding:3px 8px}
.search-results{max-height:54vh;overflow-y:auto;padding:10px}
.search-results .empty{padding:40px 22px;text-align:center;color:var(--slate-2)}
.sr-item{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border-radius:11px;transition:.12s}
.sr-item:hover{background:var(--paper)}
.sr-item .sr-type{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--teal-700);background:rgba(22,166,166,.1);padding:4px 9px;border-radius:6px;flex:none;margin-top:2px}
.sr-item h5{font-family:var(--font-display);font-size:1rem;color:var(--navy);margin:0 0 3px}
.sr-item p{font-size:.88rem;color:var(--slate)}
.search-foot{padding:12px 22px;border-top:1px solid var(--line);font-size:.8rem;color:var(--slate-2);display:flex;gap:16px}

/* ---------- Misc ---------- */
.divider{height:1px;background:var(--line);border:0;margin:0}
.kicker-num{font-family:var(--font-display);font-weight:700;color:var(--teal);font-size:.9rem}
.feature-row{display:flex;gap:16px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--line)}
.feature-row:last-child{border-bottom:0}
.feature-row .fi{width:44px;height:44px;border-radius:11px;flex:none;display:grid;place-items:center;background:linear-gradient(135deg,rgba(22,166,166,.12),rgba(159,201,127,.14));color:var(--teal-700)}
.feature-row .fi svg{width:22px;height:22px}
.feature-row h4{font-size:1.08rem;margin-bottom:4px}
.feature-row p{color:var(--slate);font-size:.96rem}

.chip-row{display:flex;flex-wrap:wrap;gap:10px}
.chip{font-size:.88rem;font-weight:500;color:var(--navy);background:#fff;border:1px solid var(--line-2);padding:9px 16px;border-radius:999px;cursor:pointer;transition:.14s}
.chip:hover{border-color:var(--teal);color:var(--teal-700)}
.chip.active{background:var(--navy);color:#fff;border-color:var(--navy)}

.cta-band{background:var(--navy);color:#fff;border-radius:var(--radius-lg);padding:56px;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 90% 120%,rgba(22,166,166,.3),transparent 60%)}
.cta-band > *{position:relative;z-index:2}
.cta-band h2{color:#fff;max-width:560px}
.cta-band p{color:#B7C8D7;margin-top:14px;max-width:520px;font-size:1.1rem}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s ease}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.12s}
.reveal[data-delay="2"]{transition-delay:.22s}
.reveal[data-delay="3"]{transition-delay:.34s}
.reveal[data-delay="4"]{transition-delay:.46s}
.reveal[data-delay="5"]{transition-delay:.58s}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:40px;padding:60px 0 70px}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .g4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:1040px){
  .nav-cta{display:none}
}
@media (max-width:860px){
  .nav,.nav-cta{display:none}
  .menu-toggle{display:grid}
  .section{padding:68px 0}
  .g3{grid-template-columns:1fr}
  .g2{grid-template-columns:1fr}
  .cta-band{padding:38px 28px}
  .hero-inner .hero-visual{display:none}
}
@media (max-width:560px){
  body{font-size:16px}
  .container{padding:0 20px}
  .g4{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .wa-fab .wa-label{display:none}
  .cookie{left:14px;right:14px;bottom:14px;max-width:none}
}

/* ---------- Mobile drawer ---------- */
.drawer{position:fixed;inset:0;z-index:90;display:none}
.drawer.open{display:block}
.drawer .overlay{position:absolute;inset:0;background:rgba(10,36,64,.5)}
.drawer-panel{position:absolute;top:0;right:0;width:min(86%,360px);height:100%;background:#fff;box-shadow:var(--shadow-lg);padding:24px;overflow-y:auto;animation:slideIn .25s ease}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:none}}
.drawer-panel .d-close{margin-left:auto;display:flex}
.drawer-panel nav{margin-top:18px;display:flex;flex-direction:column}
.drawer-panel nav a{padding:14px 6px;border-bottom:1px solid var(--line);font-family:var(--font-display);font-weight:500;color:var(--navy)}
.drawer-panel nav a.sub{padding-left:22px;font-weight:400;font-size:.95rem;color:var(--slate)}
.drawer-panel .btn{margin-top:22px;width:100%;justify-content:center}

/* ================================================================
   SLIDER + SCROLL INTERACTIVITY + CTA MEGA
   ================================================================ */

/* -- Scroll progress bar (top of page) -- */
.scroll-bar{position:fixed;top:0;left:0;right:0;height:2px;z-index:201;pointer-events:none}
.scroll-bar-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--green),var(--teal));box-shadow:0 0 10px rgba(22,166,166,.55);transition:width .08s linear}

/* -- Header scroll shrink -- */
.site-header{transition:background .3s,box-shadow .3s}
.site-header.scrolled .bar{height:62px}
.site-header.scrolled{background:rgba(255,255,255,.99);box-shadow:0 2px 20px rgba(13,47,79,.1)}

/* -- Hero Slider -- */
.hero-slider{position:relative;overflow:hidden;background:var(--navy-deep)}
.slider-track{display:flex;will-change:transform;transition:transform .75s cubic-bezier(.77,0,.175,1)}
.slide{min-width:100%;position:relative;overflow:hidden;color:#fff}
.slide-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:54px 54px;mask-image:linear-gradient(180deg,#000 60%,transparent 100%);pointer-events:none}
.slide-glow{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none;z-index:0}
.slide-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:70px 0 84px;position:relative;z-index:2}
.slide-copy{max-width:560px}
.slide-copy h1{color:#fff;letter-spacing:-.025em;font-size:clamp(2rem,3.8vw,3rem)}
.slide-copy h1 .hl{background:var(--grad-line);-webkit-background-clip:text;background-clip:text;color:transparent}
.slide-copy p{color:#B7C8D7;font-size:1.1rem;margin-top:16px;line-height:1.6}
.slide .hero-cta{margin-top:28px}
.slide .hero-trust{margin-top:28px}
.slide .btn-outline{background:transparent;border-color:rgba(255,255,255,.3);color:#fff}
.slide .btn-outline:hover{border-color:var(--teal-bright);color:var(--teal-bright);background:rgba(22,166,166,.08)}
.slide-visual{display:flex;justify-content:flex-end;align-items:center}

/* -- Solutions Accordion -- */
.sol-accordion{display:flex;gap:10px;height:480px;border-radius:22px;overflow:hidden;margin-top:8px}
.sol-tab{flex:0 0 72px;position:relative;overflow:hidden;cursor:pointer;border-radius:18px;transition:flex .55s cubic-bezier(.77,0,.175,1);border:1px solid rgba(255,255,255,.06)}
.sol-tab.active{flex:1}
.sol-tab:hover:not(.active){flex:0 0 90px}
.sol-tab-bg{position:absolute;inset:0}
.sol-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:28px;gap:10px;transition:opacity .2s;z-index:2}
.sol-tab.active .sol-label{opacity:0;pointer-events:none}
.sol-label-num{font-family:var(--font-display);font-size:.72rem;font-weight:700;color:rgba(255,255,255,.35);letter-spacing:.1em}
.sol-label-text{font-family:var(--font-display);font-size:.9rem;font-weight:600;color:#fff;writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap}
.sol-detail{position:absolute;inset:0;padding:34px 38px;display:flex;flex-direction:column;opacity:0;transform:translateX(20px);transition:opacity .3s,transform .3s;pointer-events:none;z-index:2;overflow:hidden}
.sol-tab.active .sol-detail{opacity:1;transform:none;pointer-events:auto;transition-delay:.18s}
.sol-detail-icon{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff;margin-bottom:16px;flex:none}
.sol-detail-icon svg{width:24px;height:24px}
.sol-detail h3{color:#fff;font-size:1.5rem;margin-bottom:8px}
.sol-detail p{color:rgba(255,255,255,.7);font-size:.95rem;line-height:1.58;margin-bottom:16px}
.sol-bullets{list-style:none;padding:0;margin:0 0 22px;display:flex;flex-direction:column;gap:8px}
.sol-bullets li{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.82);font-size:.91rem}
.sol-bullets li::before{content:"";width:6px;height:6px;border-radius:2px;flex:none;background:var(--teal-bright);box-shadow:0 0 6px rgba(22,166,166,.6)}
.sol-dec{position:absolute;bottom:-20px;right:-20px;pointer-events:none;opacity:.18}
@media(max-width:860px){
  .sol-accordion{flex-direction:column;height:auto}
  .sol-tab{flex:0 0 58px !important;border-radius:14px}
  .sol-tab.active{flex:0 0 400px !important}
  .sol-label{flex-direction:row;justify-content:flex-start;padding:0 20px;gap:12px;top:0;bottom:auto;height:58px}
  .sol-label-text{writing-mode:horizontal-tb;transform:none}
  .sol-detail{padding:24px 24px 24px}
}

/* Slider nav */
.slider-nav{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:18px;z-index:10}
.slider-dots{display:flex;gap:8px;align-items:center}
.s-dot{width:8px;height:8px;border-radius:999px;border:none;background:rgba(255,255,255,.25);cursor:pointer;transition:.35s ease;padding:0}
.s-dot.active{width:30px;background:var(--teal-bright);box-shadow:0 0 12px rgba(22,166,166,.7)}
.slider-btn{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.07);color:#fff;display:grid;place-items:center;cursor:pointer;transition:.2s;backdrop-filter:blur(10px)}
.slider-btn:hover{background:rgba(22,166,166,.2);border-color:var(--teal)}
.slider-btn svg{width:20px;height:20px}
.slider-prog{position:absolute;bottom:0;left:0;right:0;height:2px;background:rgba(255,255,255,.08);z-index:10}
.slider-prog-fill{height:100%;width:0;background:linear-gradient(90deg,var(--green),var(--teal));box-shadow:0 0 8px rgba(22,166,166,.5);transition:none}

/* -- Slide 2: number grid visual -- */
.slide-num-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;width:100%;max-width:400px}
.slide-num-card{background:rgba(255,255,255,.05);border:1px solid rgba(22,166,166,.18);border-radius:16px;padding:22px 20px;backdrop-filter:blur(10px)}
.slide-num-card .sn-val{font-family:var(--font-display);font-weight:800;font-size:1.9rem;letter-spacing:-.03em;background:var(--grad-line);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;margin-bottom:6px}
.slide-num-card .sn-label{font-size:.82rem;color:#8FA6B8;line-height:1.4}

/* -- Slide 3: ARP stack visual -- */
.arp-stack{display:flex;flex-direction:column;gap:12px;width:100%;max-width:420px}
.arp-card-vis{background:rgba(255,255,255,.06);border:1px solid rgba(22,166,166,.2);border-radius:14px;padding:18px 22px;display:flex;justify-content:space-between;align-items:center;transition:.25s}
.arp-card-vis:hover{background:rgba(22,166,166,.1);border-color:rgba(22,166,166,.45);transform:translateX(4px)}
.arp-card-vis .aname{font-family:var(--font-display);font-weight:600;color:#fff;font-size:.98rem;margin-bottom:3px}
.arp-card-vis .aorg{font-size:.82rem;color:#8FA6B8}
.arp-badge{font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--green-soft);background:rgba(159,201,127,.13);border:1px solid rgba(159,201,127,.28);padding:5px 12px;border-radius:999px;flex:none}
.arp-cta-row{margin-top:6px}
.arp-cta-row .btn{width:100%;justify-content:center}

/* -- Card enhanced hover -- */
.card:hover{transform:translateY(-5px);box-shadow:0 20px 50px rgba(13,47,79,.13),0 0 0 1px rgba(22,166,166,.15);border-color:rgba(22,166,166,.25)}

/* -- CTA Mega -- */
.cta-mega{
  background:linear-gradient(135deg,#050F1E 0%,#0B1E35 45%,#061E1E 100%);
  border-radius:var(--radius-lg);padding:68px 64px;
  position:relative;overflow:hidden;
  border:1px solid rgba(22,166,166,.2);
  box-shadow:0 0 0 1px rgba(22,166,166,.06),0 40px 100px rgba(0,0,0,.4);
}
.cta-mega::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 400px at 85% 130%,rgba(22,166,166,.22),transparent 60%),radial-gradient(500px 300px at 5% -20%,rgba(159,201,127,.1),transparent 60%)}
.cta-mega::after{content:"";position:absolute;top:-1px;left:15%;right:15%;height:1px;background:linear-gradient(90deg,transparent,var(--teal),transparent);opacity:.7}
.cta-mega > *{position:relative;z-index:2}
.cta-mega .eyebrow{color:var(--teal-bright);background:rgba(22,166,166,.12);border-color:rgba(22,166,166,.3)}
.cta-mega h2{color:#fff;font-size:clamp(2rem,3.4vw,3rem);margin-bottom:14px}
.cta-mega h2 .hl{background:var(--grad-line);-webkit-background-clip:text;background-clip:text;color:transparent}
.cta-mega p{color:#AFC2D4;max-width:520px;font-size:1.1rem;margin-bottom:32px}
.cta-mega-row{display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap}
.cta-mega-body{max-width:560px}
.cta-mega-btns{display:flex;gap:14px;flex-wrap:wrap;flex:none}
.cta-mega .btn-primary{box-shadow:0 0 30px rgba(22,166,166,.4)}
.cta-mega .btn-primary:hover{box-shadow:0 0 50px rgba(22,166,166,.6);transform:translateY(-3px)}
.cta-mega .btn-sec{background:transparent;border-color:rgba(255,255,255,.22);color:#fff}
.cta-mega .btn-sec:hover{border-color:var(--teal-bright);color:var(--teal-bright)}

@media(max-width:860px){
  .slide-inner{grid-template-columns:1fr;gap:32px;padding:60px 0 84px}
  .slide-visual{display:none}
  .cta-mega{padding:44px 28px}
  .cta-mega-row{flex-direction:column;align-items:flex-start;gap:28px}
  .cta-mega-btns{flex-direction:column;width:100%}
  .cta-mega-btns .btn{justify-content:center;width:100%}
}
