/* KonectaconCon V3 Premium | Preto + Azul */
:root{
    --black:#030712;
    --black-2:#060b18;
    --black-3:#0b1220;
    --blue:#2563eb;
    --blue-2:#38bdf8;
    --blue-3:#1d4ed8;
    --text:#0f172a;
    --muted:#64748b;
    --line:#dbe5f2;
    --soft:#f5f8ff;
    --white:#ffffff;
    --shadow:0 30px 80px rgba(2,6,23,.18);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:Inter, Montserrat, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color:var(--text);
    background:#fff;
}
a{text-decoration:none;color:inherit}
/* Layout fluido: remove o limite de container centralizado e deixa o site respirar na tela inteira */
.container{
    width:100%;
    max-width:none;
    margin:0;
    padding-inline:clamp(24px,6vw,110px);
}

.topbar{
    position:sticky;top:0;z-index:80;
    background:rgba(255,255,255,.88);
    backdrop-filter:blur(18px);
    border-bottom:1px solid rgba(219,229,242,.86);
}
.nav{height:82px;display:flex;align-items:center;justify-content:space-between;gap:22px}
.brand{display:flex;align-items:center;gap:12px;font-weight:900}
.brand.center{justify-content:center}
.word{font-size:25px;letter-spacing:-.9px;color:var(--black)}
.word span{color:var(--blue)}
nav{display:flex;align-items:center;gap:24px;font-weight:800;font-size:14px;color:#334155}
nav a:hover{color:var(--blue)}
.nav-actions{display:flex;align-items:center;gap:10px}
.mobile{display:none;border:0;width:42px;height:42px;border-radius:12px;background:#eff6ff;font-size:20px}

.btn, button{
    border:0;min-height:44px;padding:0 18px;border-radius:999px;
    display:inline-flex;align-items:center;justify-content:center;
    font-weight:900;font-size:14px;cursor:pointer;transition:.2s ease;
}
.btn.primary, button.primary, .finder button{
    color:#fff;background:linear-gradient(135deg,var(--black),var(--blue));
    box-shadow:0 16px 38px rgba(37,99,235,.25);
}
.btn.primary:hover,.finder button:hover{transform:translateY(-1px);box-shadow:0 22px 50px rgba(37,99,235,.34)}
.btn.ghost{background:#eef5ff;color:#0f2b55}
.btn.dark{background:var(--black);color:#fff}
.btn.big{min-height:56px;padding:0 26px}

.mark{
    width:54px;height:64px;position:relative;display:inline-block;flex:0 0 auto;
    filter:drop-shadow(0 12px 20px rgba(37,99,235,.22));
}
.mark.small{width:44px;height:52px}
.dot{
    position:absolute;width:13px;height:13px;border-radius:50%;z-index:2;
    background:var(--blue);
}
.mark.small .dot{width:11px;height:11px}
.d1{left:0;top:0;background:var(--blue-2)}
.d2{right:0;top:8px;background:var(--blue)}
.d3{left:0;bottom:7px;background:var(--blue-3)}
.d4{right:2px;bottom:0;background:#0f172a}
.line{
    position:absolute;height:4px;border-radius:99px;background:linear-gradient(90deg,var(--blue-2),var(--blue));
    transform-origin:left center;z-index:1;
}
.mark.small .line{height:3px}
.a{width:56px;left:7px;top:9px;transform:rotate(48deg)}
.b{width:62px;left:7px;bottom:16px;transform:rotate(-50deg)}
.c{width:50px;left:15px;top:33px;transform:rotate(-32deg)}
.d{width:57px;left:20px;top:31px;transform:rotate(43deg);background:linear-gradient(90deg,var(--blue),#020617)}

.hero{
    position:relative;overflow:hidden;
    padding:100px 0 84px;
    background:
        radial-gradient(circle at 85% 10%, rgba(37,99,235,.22), transparent 35%),
        linear-gradient(135deg,#f8fbff 0%,#eef5ff 42%,#fff 100%);
}
.mesh{
    position:absolute;inset:0;opacity:.20;pointer-events:none;
    background-image:
        radial-gradient(circle at 14% 22%, var(--blue) 0 3px, transparent 4px),
        radial-gradient(circle at 34% 70%, var(--blue-2) 0 3px, transparent 4px),
        radial-gradient(circle at 72% 28%, var(--blue) 0 3px, transparent 4px),
        radial-gradient(circle at 90% 72%, var(--blue-2) 0 3px, transparent 4px),
        linear-gradient(35deg, transparent 0 48%, rgba(37,99,235,.55) 49% 50%, transparent 51%),
        linear-gradient(150deg, transparent 0 48%, rgba(56,189,248,.35) 49% 50%, transparent 51%);
    background-size:260px 220px;
}
.hero-grid{position:relative;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);gap:clamp(42px,6vw,110px);align-items:center}
.tag{
    display:inline-flex;align-items:center;gap:8px;
    font-size:12px;letter-spacing:.22em;font-weight:1000;text-transform:uppercase;color:var(--blue);
}
.tag:before{content:"";width:34px;height:2px;border-radius:10px;background:var(--blue)}
.tag.blue{color:var(--blue-2)}.tag.blue:before{background:var(--blue-2)}
h1,h2,h3,p{margin-top:0}
.hero h1{
    font-size:clamp(46px,7vw,82px);
    line-height:.96;letter-spacing:-4px;margin:18px 0 20px;color:var(--black);
}
.subtitle{font-size:20px;line-height:1.75;color:#475569;max-width:720px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}
.trust-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px;color:#334155;font-weight:800;font-size:13px}
.trust-row span{background:#fff;border:1px solid var(--line);padding:10px 14px;border-radius:999px;box-shadow:0 8px 24px rgba(15,23,42,.06)}

.product-window{
    position:relative;background:linear-gradient(180deg,#050814,#0b1220);
    border:1px solid rgba(255,255,255,.12);
    border-radius:34px;padding:24px;color:#fff;box-shadow:var(--shadow);overflow:hidden;
}
.product-window:after{
    content:"";position:absolute;right:-90px;bottom:-90px;width:270px;height:270px;border-radius:50%;
    background:radial-gradient(circle,rgba(37,99,235,.40),transparent 70%);
}
.window-bar{display:flex;gap:8px;margin-bottom:32px}.window-bar span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.24)}
.window-head{display:flex;justify-content:space-between;gap:20px;align-items:center;margin-bottom:20px}
.window-head small{display:block;color:#93a4bd;font-weight:700;margin-bottom:4px}.window-head strong{font-size:24px}
.status{background:rgba(56,189,248,.15);border:1px solid rgba(56,189,248,.35);color:#7dd3fc;border-radius:999px;padding:8px 12px;font-weight:900;font-size:12px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.stats article{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:18px}
.stats b{display:block;font-size:32px}.stats span{color:#bfdbfe;font-size:13px;font-weight:700}
.timeline{display:grid;gap:12px;margin-top:20px}
.timeline div{display:flex;gap:12px;align-items:center;background:rgba(255,255,255,.05);border-radius:16px;padding:14px;color:#dbeafe}
.timeline i{width:10px;height:10px;border-radius:50%;background:var(--blue-2);box-shadow:0 0 0 6px rgba(56,189,248,.12)}
.panel-footer{display:flex;align-items:center;gap:12px;margin-top:20px;color:#cbd5e1}
.mini-mark{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,var(--blue-2),var(--blue));display:inline-block}

.proof{padding:26px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.proof-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.proof-grid div{padding:18px;background:#f8fbff;border:1px solid var(--line);border-radius:18px}
.proof-grid strong{display:block;color:var(--black);font-size:18px}.proof-grid span{display:block;color:var(--muted);font-size:14px;margin-top:6px;line-height:1.5}

.section{padding:92px 0;position:relative;overflow:hidden}
.section.soft{background:var(--soft)}
.section-head{text-align:center;max-width:780px;margin:0 auto 44px}
.section h2{font-size:clamp(34px,4.8vw,56px);line-height:1.04;letter-spacing:-2px;color:var(--black);margin:12px 0 18px}
.section p{font-size:18px;line-height:1.75;color:var(--muted)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:center}
.checklist{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:12px}
.checklist li{position:relative;padding-left:34px;color:#334155;font-weight:700;line-height:1.55}
.checklist li:before{content:"✓";position:absolute;left:0;top:0;width:22px;height:22px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-size:13px}
.dark-card{background:linear-gradient(180deg,#050814,#0b1220);color:#fff;border-radius:32px;padding:34px;box-shadow:var(--shadow)}
.dark-card h3{font-size:32px;margin-bottom:22px}
.flow{display:grid;gap:12px}.flow span{padding:18px;border-radius:18px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);font-weight:900}
.module-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.module-grid article{background:#fff;border:1px solid var(--line);border-radius:26px;padding:28px;box-shadow:0 18px 50px rgba(15,23,42,.07)}
.module-grid span{display:inline-flex;width:42px;height:42px;border-radius:14px;background:#eff6ff;color:var(--blue);align-items:center;justify-content:center;font-weight:1000;margin-bottom:20px}
.module-grid h3{font-size:24px;margin-bottom:10px}.module-grid p{font-size:16px}
.dark-section{background:linear-gradient(135deg,#030712,#0b1220);color:#fff}
.dark-section h2{color:#fff}.dark-section p{color:#cbd5e1}
.security-list{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.security-list div{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:22px}
.security-list b{display:block;font-size:20px;margin-bottom:8px}.security-list span{color:#cbd5e1;line-height:1.6}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.steps div{border:1px solid var(--line);border-radius:24px;padding:26px;background:#fff;box-shadow:0 18px 50px rgba(15,23,42,.06)}
.steps strong{display:grid;place-items:center;width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,var(--black),var(--blue));color:#fff;margin-bottom:20px}
.steps h3{font-size:22px;margin-bottom:8px}.steps p{font-size:16px}
.cta-section{background:#f8fbff}
.cta{
    display:grid;grid-template-columns:.95fr 1.05fr;gap:42px;align-items:start;
    background:linear-gradient(135deg,#050814,#0b1220);
    color:#fff;border-radius:36px;padding:46px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.cta h2{color:#fff}.cta p{color:#cbd5e1}
.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-form input,.contact-form textarea,.finder input{
    width:100%;border:1px solid rgba(219,229,242,.9);border-radius:16px;padding:16px 18px;font:inherit;outline:none;background:#fff;
}
.contact-form textarea{grid-column:1/-1;min-height:124px;resize:vertical}
.contact-form button{grid-column:1/-1}

.footer{background:#030712;color:#fff;padding:42px 0}
.footer-grid{display:flex;justify-content:space-between;gap:28px;align-items:flex-start}
.footer p{color:#94a3b8;margin:8px 0 0}.footer strong{display:block;font-size:18px}

.access-page{min-height:100vh;display:grid;place-items:center;padding:40px 20px;position:relative;overflow:hidden;background:linear-gradient(135deg,#030712,#0b1220)}
.access-card{width:min(760px,100%);position:relative;background:rgba(255,255,255,.97);border-radius:34px;padding:44px;text-align:center;box-shadow:var(--shadow)}
.access-card h1{font-size:46px;letter-spacing:-1.8px;margin:14px 0 10px}.access-card p{color:var(--muted);font-size:17px}
.pill{display:inline-flex;border:1px solid var(--line);background:#eff6ff;color:var(--blue);border-radius:999px;padding:8px 12px;font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.12em}
.finder{display:flex;gap:12px;margin-top:30px}.finder input{min-height:56px}.finder button{padding:0 24px}
.results{display:grid;gap:12px;margin-top:24px;text-align:left}
.result-item{display:flex;justify-content:space-between;align-items:center;gap:16px;background:#f8fbff;border:1px solid var(--line);border-radius:20px;padding:18px}
.result-item span{display:block;color:var(--muted);font-size:14px;margin-top:4px}.result-item a{background:var(--black);color:#fff;border-radius:999px;padding:12px 18px;font-weight:900}
.empty{background:#eff6ff;color:#1d4ed8;border-radius:18px;padding:16px}

@media (max-width: 980px){
    nav{display:none;position:absolute;top:82px;left:20px;right:20px;background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:var(--shadow);flex-direction:column;align-items:flex-start}
    nav.open{display:flex}.mobile{display:inline-flex;align-items:center;justify-content:center}.btn.ghost{display:none}
    .hero-grid,.split,.cta{grid-template-columns:1fr}.proof-grid,.module-grid,.steps{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
    .container{width:min(100% - 28px,1180px)}
    .nav{height:74px}.word{font-size:20px}.mark{width:44px;height:52px}
    .hero{padding:70px 0}.hero h1{letter-spacing:-2px}
    .proof-grid,.module-grid,.steps,.security-list,.contact-form{grid-template-columns:1fr}
    .finder,.result-item{flex-direction:column}.access-card{padding:28px}
}

/* V5 | Hero com telas reais do sistema */
.system-showcase{
    position:relative;
    min-height:560px;
    display:grid;
    place-items:center;
    isolation:isolate;
}
.showcase-glow{
    position:absolute;
    inset:8% 0 0 10%;
    border-radius:46px;
    background:radial-gradient(circle at 78% 20%, rgba(37,99,235,.24), transparent 42%),
               radial-gradient(circle at 20% 82%, rgba(56,189,248,.20), transparent 36%);
    filter:blur(18px);
    z-index:-1;
}
.screen-card{
    position:absolute;
    background:rgba(255,255,255,.92);
    border:1px solid rgba(203,213,225,.88);
    border-radius:28px;
    padding:12px;
    box-shadow:0 30px 80px rgba(15,23,42,.18);
    overflow:hidden;
}
.screen-card img,
.screen-card picture{
    display:block;
    width:100%;
}
.screen-card img{
    border-radius:20px;
    object-fit:cover;
    object-position:top left;
}
.screen-main{
    width:min(100%,760px);
    right:2%;
    top:52px;
    transform:rotate(.3deg);
}
.screen-main img{height:330px;}
.screen-float{
    width:min(62%,520px);
    z-index:2;
}
.screen-float.top{
    left:0;
    top:0;
    transform:rotate(-3deg);
}
.screen-float.bottom{
    right:0;
    bottom:4px;
    transform:rotate(2deg);
}
.screen-float img{height:230px;}
.screen-label{
    position:absolute;
    left:24px;
    top:22px;
    z-index:3;
    color:#fff;
    display:grid;
    gap:3px;
    padding:10px 14px;
    border-radius:16px;
    background:rgba(3,7,18,.74);
    backdrop-filter:blur(10px);
    max-width:72%;
}
.screen-label strong{font-size:14px;letter-spacing:.01em}
.screen-label span{font-size:11px;color:#dbeafe;font-weight:700;line-height:1.3}

@media (max-width: 1180px){
    .system-showcase{min-height:480px}
    .screen-main{width:min(100%,650px)}
    .screen-main img{height:285px}
    .screen-float{width:min(64%,450px)}
    .screen-float img{height:200px}
}
@media (max-width: 980px){
    .system-showcase{min-height:650px;margin-top:24px}
    .screen-main{left:50%;right:auto;transform:translateX(-50%);top:170px;width:92%}
    .screen-float.top{left:2%;top:0;width:58%}
    .screen-float.bottom{right:2%;bottom:0;width:58%}
}
@media (max-width: 640px){
    .system-showcase{min-height:auto;display:grid;gap:16px;place-items:stretch}
    .screen-card{position:relative;inset:auto!important;width:100%!important;transform:none!important}
    .screen-main img,.screen-float img{height:210px}
    .screen-label{left:18px;top:18px}
}

/* V7 Premium | Hero escuro com conexões, pontos e mockups reais */
:root{
    --deep:#020716;
    --deep-2:#061124;
    --electric:#1f6fff;
    --cyan:#38d9ff;
}

body{
    background:#f4f8ff;
}

.topbar{
    background:rgba(255,255,255,.86);
    backdrop-filter:blur(18px);
}

.word span,
.accent-word{
    color:var(--electric);
    background:linear-gradient(135deg,#38d9ff 0%,#2f7cff 48%,#1d4ed8 100%);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
}

.hero{
    min-height:calc(100vh - 86px);
    padding:clamp(76px,8vw,128px) 0 clamp(52px,6vw,90px);
    background:
        radial-gradient(circle at 75% 26%, rgba(37,99,235,.46), transparent 28%),
        radial-gradient(circle at 36% 74%, rgba(56,217,255,.16), transparent 26%),
        linear-gradient(110deg,#020716 0%,#061124 43%,#0b2f76 100%);
    color:#fff;
}
.hero .mesh{
    opacity:.86;
    background-image:
        linear-gradient(90deg, rgba(2,7,22,.28), rgba(2,7,22,.08)),
        url('../img/hero-network-bg.webp');
    background-size:cover;
    background-position:center;
    mix-blend-mode:screen;
}
.hero:before{
    content:"";
    position:absolute;
    inset:0;
    background:
        linear-gradient(90deg, rgba(2,7,22,.90) 0%, rgba(2,7,22,.72) 36%, rgba(2,7,22,.35) 100%),
        radial-gradient(circle at 90% 50%, rgba(47,124,255,.24), transparent 32%);
    pointer-events:none;
    z-index:0;
}
.hero-grid{z-index:1;grid-template-columns:minmax(420px,.9fr) minmax(560px,1.1fr);gap:clamp(36px,5vw,82px)}
.hero-copy{position:relative;z-index:3;max-width:780px}
.hero .tag{color:#4aa3ff;text-shadow:0 0 22px rgba(56,217,255,.36)}
.hero .tag:before{background:#2f7cff;box-shadow:0 0 18px rgba(47,124,255,.8)}
.hero h1{
    color:#fff;
    font-size:clamp(48px,5.9vw,86px);
    letter-spacing:-4.6px;
    text-shadow:0 18px 60px rgba(0,0,0,.36);
}
.hero .subtitle{color:#dce9ff;max-width:760px;text-shadow:0 10px 32px rgba(0,0,0,.24)}
.hero .btn.primary{background:linear-gradient(135deg,#2f7cff,#1d4ed8);box-shadow:0 18px 46px rgba(37,99,235,.36)}
.hero .btn.dark{background:rgba(3,7,18,.72);border:1px solid rgba(255,255,255,.18);color:#fff;backdrop-filter:blur(14px)}
.hero .trust-row span{
    background:rgba(3,7,18,.42);
    border:1px solid rgba(191,219,254,.20);
    color:#eef6ff;
    box-shadow:0 16px 48px rgba(0,0,0,.18);
    backdrop-filter:blur(14px);
}
.hero .trust-row span:before{
    content:"✓";
    display:inline-grid;
    place-items:center;
    width:18px;height:18px;
    margin-right:8px;
    border-radius:50%;
    background:linear-gradient(135deg,#38d9ff,#1d4ed8);
    font-size:11px;
}

.system-showcase{min-height:620px;perspective:1300px}
.showcase-glow{
    inset:0;
    background:
        radial-gradient(circle at 72% 30%, rgba(56,217,255,.30), transparent 36%),
        radial-gradient(circle at 30% 76%, rgba(47,124,255,.24), transparent 34%);
    filter:blur(34px);
}
.screen-card{
    background:rgba(255,255,255,.12);
    border:10px solid rgba(255,255,255,.92);
    border-radius:30px;
    padding:0;
    box-shadow:0 34px 90px rgba(0,0,0,.45), 0 0 0 1px rgba(96,165,250,.20);
    backdrop-filter:blur(16px);
    transition:transform .32s ease, box-shadow .32s ease;
}
.screen-card:hover{box-shadow:0 44px 110px rgba(0,0,0,.55),0 0 60px rgba(47,124,255,.24)}
.screen-card img{border-radius:18px;filter:saturate(1.04) contrast(1.02)}
.screen-main{
    width:min(86%,820px);
    right:0;
    top:108px;
    transform:rotate(.4deg) translateZ(-20px);
    opacity:.96;
}
.screen-main img{height:330px;object-position:top left}
.screen-float.top{
    width:min(58%,560px);
    left:0;
    top:26px;
    transform:rotate(-3.6deg) translateZ(90px);
}
.screen-float.bottom{
    width:min(60%,560px);
    right:6%;
    bottom:34px;
    transform:rotate(2.2deg) translateZ(110px);
}
.screen-float img{height:250px;object-position:top left}
.screen-label{
    left:18px;
    top:18px;
    border:1px solid rgba(255,255,255,.16);
    background:rgba(2,7,22,.72);
    box-shadow:0 14px 36px rgba(0,0,0,.22);
}

.proof{
    background:#061124;
    border-color:rgba(148,163,184,.16);
}
.proof-grid div{
    background:rgba(255,255,255,.06);
    border-color:rgba(255,255,255,.12);
}
.proof-grid strong{color:#fff}.proof-grid span{color:#bdd1ee}

@media (max-width:1180px){
    .hero-grid{grid-template-columns:1fr}
    .hero-copy{max-width:900px}
    .system-showcase{min-height:600px}
}
@media (max-width:640px){
    .hero{min-height:auto;padding-top:56px}
    .hero:before{background:linear-gradient(90deg,rgba(2,7,22,.92),rgba(2,7,22,.68))}
    .hero h1{letter-spacing:-2px}
    .system-showcase{min-height:auto}
    .screen-card{border-width:7px}
    .screen-main img,.screen-float img{height:210px}
}

/* V8 Premium | Hero com uma tela real grande da Presidência Light */
.single-showcase{
    min-height:640px;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px 0;
}
.single-showcase .showcase-glow{
    inset:4% -4% 2% 2%;
    border-radius:54px;
    background:
        radial-gradient(circle at 56% 34%, rgba(56,217,255,.34), transparent 35%),
        radial-gradient(circle at 78% 76%, rgba(47,124,255,.30), transparent 38%),
        linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.02));
    filter:blur(30px);
}
.single-showcase .screen-card{
    position:relative;
    inset:auto;
    width:min(100%,980px);
    max-width:none;
    transform:rotate(1.2deg) translateY(4px);
    border:12px solid rgba(255,255,255,.94);
    border-radius:34px;
    background:rgba(255,255,255,.18);
    box-shadow:
        0 42px 110px rgba(0,0,0,.52),
        0 0 0 1px rgba(96,165,250,.24),
        0 0 78px rgba(47,124,255,.18);
}
.single-showcase .screen-card:hover{
    transform:rotate(.4deg) translateY(-4px) scale(1.01);
}
.single-showcase .screen-card img{
    width:100%;
    height:clamp(390px,42vw,620px);
    object-fit:cover;
    object-position:top left;
    border-radius:21px;
}
.single-showcase .screen-label{
    top:20px;
    left:20px;
    padding:12px 16px;
    border-radius:18px;
}
.single-showcase .screen-label strong{font-size:15px}
.single-showcase .screen-label span{font-size:12px}

@media (max-width:1180px){
    .single-showcase{min-height:auto;padding-top:14px}
    .single-showcase .screen-card{width:100%;transform:rotate(.6deg)}
    .single-showcase .screen-card img{height:clamp(330px,58vw,560px)}
}
@media (max-width:640px){
    .single-showcase .screen-card{border-width:7px;border-radius:24px;transform:none}
    .single-showcase .screen-card img{height:270px;border-radius:16px}
    .single-showcase .screen-label{left:14px;top:14px;max-width:82%}
}

/* V8.4 Premium | Tela do sistema maior no Hero */
@media (min-width:1181px){
    .hero{
        min-height:calc(100vh - 82px);
        padding:clamp(70px,7vw,112px) 0 clamp(64px,7vw,104px);
    }
    .hero-grid{
        grid-template-columns:minmax(360px,.66fr) minmax(720px,1.34fr);
        gap:clamp(24px,3vw,52px);
        align-items:center;
    }
    .hero-copy{
        max-width:650px;
    }
    .hero h1{
        font-size:clamp(52px,5.45vw,86px);
        letter-spacing:-4.4px;
    }
    .hero .subtitle{
        max-width:640px;
        font-size:19px;
    }
    .single-showcase{
        position:relative;
        min-height:720px;
        overflow:visible;
        justify-content:flex-start;
        align-items:center;
        padding:0;
    }
    .single-showcase .showcase-glow{
        inset:2% -20% 0 -8%;
        filter:blur(42px);
        background:
            radial-gradient(circle at 48% 28%, rgba(56,217,255,.28), transparent 34%),
            radial-gradient(circle at 82% 70%, rgba(47,124,255,.42), transparent 43%),
            radial-gradient(circle at 22% 78%, rgba(37,99,235,.22), transparent 38%);
    }
    .single-showcase .screen-card{
        position:absolute;
        left:-34px;
        top:50%;
        width:min(1380px,78vw);
        max-width:none;
        transform:translateY(-50%) rotate(.65deg);
        border-width:13px;
        border-radius:36px;
        box-shadow:
            0 44px 120px rgba(0,0,0,.54),
            0 0 0 1px rgba(96,165,250,.24),
            0 0 100px rgba(47,124,255,.26);
    }
    .single-showcase .screen-card:hover{
        transform:translateY(calc(-50% - 6px)) rotate(.25deg) scale(1.006);
    }
    .single-showcase .screen-card img{
        display:block;
        width:100%;
        height:auto;
        max-height:none;
        object-fit:contain;
        object-position:top left;
    }
    .single-showcase .screen-label{
        top:22px;
        left:22px;
        padding:13px 17px;
    }
}

@media (min-width:1600px){
    .single-showcase .screen-card{
        left:-58px;
        width:min(1460px,76vw);
    }
}


/* V8.5 Premium | Hero com imagem frontal, reta e sem etiqueta sobreposta */
@media (min-width:1181px){
    .single-showcase .screen-card{
        transform:translateY(-50%) !important;
        border-width:12px;
        border-radius:34px;
    }
    .single-showcase .screen-card:hover{
        transform:translateY(calc(-50% - 4px)) scale(1.004) !important;
    }
    .single-showcase .screen-label{
        display:none !important;
    }
}

.screen-card,
.screen-card:hover{
    cursor:default;
}

/* V8.7 Premium | Responsividade refinada, hero equilibrado e formulário compacto */
.proof{
    display:none !important;
}

@media (min-width:1181px){
    .hero{
        min-height:auto;
        padding:clamp(64px,6vw,104px) 0 clamp(56px,5vw,84px);
        overflow:hidden;
    }
    .hero-grid{
        grid-template-columns:minmax(360px,.72fr) minmax(620px,1.28fr) !important;
        gap:clamp(28px,4vw,70px) !important;
        align-items:center;
    }
    .hero-copy{
        max-width:620px;
    }
    .hero h1{
        font-size:clamp(48px,4.25vw,74px) !important;
        line-height:1.02;
        letter-spacing:-3.3px !important;
        max-width:620px;
    }
    .hero .subtitle{
        font-size:17px !important;
        line-height:1.72;
        max-width:560px;
    }
    .single-showcase{
        min-height:560px !important;
        justify-content:center;
        overflow:visible;
    }
    .single-showcase .screen-card{
        position:relative !important;
        left:auto !important;
        top:auto !important;
        width:min(1040px,60vw) !important;
        transform:none !important;
        border:3px solid rgba(74,163,255,.92) !important;
        border-radius:26px !important;
        box-shadow:
            0 0 0 1px rgba(255,255,255,.38),
            0 0 26px rgba(56,217,255,.55),
            0 0 72px rgba(47,124,255,.34),
            0 36px 96px rgba(0,0,0,.45) !important;
        overflow:hidden;
    }
    .single-showcase .screen-card:hover{
        transform:translateY(-4px) !important;
    }
    .single-showcase .screen-card img{
        width:100% !important;
        height:auto !important;
        max-height:560px;
        object-fit:contain !important;
        object-position:top left !important;
        border-radius:22px !important;
    }
}

@media (min-width:1500px){
    .single-showcase .screen-card{
        width:min(1120px,62vw) !important;
    }
}

@media (max-width:1180px){
    .hero{
        min-height:auto;
        padding:64px 0 52px;
    }
    .hero-grid{
        grid-template-columns:1fr !important;
        gap:34px !important;
    }
    .hero-copy{
        max-width:760px;
    }
    .hero h1{
        font-size:clamp(42px,8vw,70px) !important;
        line-height:1.02;
        letter-spacing:-2.6px !important;
    }
    .single-showcase{
        min-height:auto !important;
        padding:6px 0 0;
    }
    .single-showcase .screen-card{
        width:100% !important;
        transform:none !important;
        border:3px solid rgba(74,163,255,.86) !important;
        border-radius:24px !important;
        box-shadow:0 0 30px rgba(47,124,255,.32), 0 24px 70px rgba(0,0,0,.42) !important;
    }
    .single-showcase .screen-card:hover{
        transform:none !important;
    }
    .single-showcase .screen-card img{
        height:auto !important;
        max-height:none !important;
        object-fit:contain !important;
    }
}

.cta-section{
    padding:clamp(52px,5vw,78px) 0 !important;
    background:#061124;
}
.cta{
    background:transparent !important;
    box-shadow:none !important;
    border-radius:0 !important;
    padding:0 !important;
    grid-template-columns:minmax(300px,.42fr) minmax(620px,.58fr) !important;
    gap:clamp(34px,5vw,72px) !important;
}
.cta h2 .accent-word,
.cta h2 span,
#contato h2 .accent-word{
    color:var(--electric);
    background:linear-gradient(135deg,#38d9ff 0%,#2f7cff 50%,#1d4ed8 100%);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
}
.contact-form{
    display:grid;
    grid-template-columns:repeat(4,minmax(170px,1fr));
    gap:14px;
    align-items:start;
}
.contact-form input,
.contact-form textarea{
    background:#ffffff !important;
    color:#0f172a !important;
    border:1px solid rgba(219,229,242,.92) !important;
    border-radius:16px !important;
    padding:15px 18px !important;
    box-shadow:0 12px 26px rgba(0,0,0,.12);
}
.contact-form input::placeholder,
.contact-form textarea::placeholder{
    color:#64748b;
}
.contact-form textarea{
    grid-column:1 / 4 !important;
    min-height:112px !important;
}
.contact-form button{
    grid-column:4 / 5 !important;
    align-self:center;
    min-height:60px;
    border-radius:999px;
}

@media (max-width:1180px){
    .cta{
        grid-template-columns:1fr !important;
    }
    .contact-form{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
    .contact-form textarea{
        grid-column:1 / -1 !important;
    }
    .contact-form button{
        grid-column:1 / -1 !important;
        width:min(320px,100%);
    }
}
@media (max-width:640px){
    .hero h1{
        font-size:clamp(38px,12vw,54px) !important;
        letter-spacing:-1.8px !important;
    }
    .hero .subtitle{
        font-size:16px !important;
    }
    .hero-actions .btn{
        width:100%;
        justify-content:center;
    }
    .trust-row span{
        width:100%;
    }
    .contact-form{
        grid-template-columns:1fr;
    }
    .contact-form textarea,
    .contact-form button{
        grid-column:1 / -1 !important;
    }
}

/* V8.8 Premium | Plataforma com ciclo em ação + portal da transparência integrado */
#plataforma .split{
    grid-template-columns:minmax(0,1.05fr) minmax(420px,.95fr);
    gap:clamp(42px,5vw,82px);
}
#plataforma h2{
    max-width:1100px;
}
.governance-visual{
    position:relative;
    display:grid;
    gap:18px;
    align-items:start;
}
.cycle-card{
    position:relative;
    z-index:2;
    padding:30px;
}
.cycle-card .flow span{
    font-size:18px;
}
.portal-preview{
    position:relative;
    overflow:hidden;
    border-radius:28px;
    border:3px solid rgba(37,99,235,.60);
    background:#fff;
    box-shadow:
        0 0 0 1px rgba(255,255,255,.52),
        0 0 32px rgba(56,217,255,.38),
        0 30px 90px rgba(15,23,42,.24);
}
.portal-preview img{
    display:block;
    width:100%;
    height:clamp(260px,22vw,360px);
    object-fit:cover;
    object-position:top left;
}
.portal-caption{
    position:absolute;
    left:18px;
    top:18px;
    z-index:2;
    display:grid;
    gap:4px;
    max-width:min(460px,calc(100% - 36px));
    padding:12px 14px;
    border-radius:16px;
    color:#fff;
    background:rgba(3,7,18,.76);
    border:1px solid rgba(255,255,255,.14);
    backdrop-filter:blur(12px);
    box-shadow:0 18px 44px rgba(0,0,0,.22);
}
.portal-caption strong{font-size:14px;line-height:1.2}
.portal-caption span{font-size:12px;color:#dbeafe;line-height:1.35}
@media (max-width:1180px){
    #plataforma .split{
        grid-template-columns:1fr;
    }
    .governance-visual{
        grid-template-columns:1fr;
    }
}
@media (max-width:640px){
    .cycle-card{padding:24px}
    .portal-preview img{height:230px}
}

/* V9.2 Premium | Hero dinâmico refinado: telas grandes, próximas e dots discretos */
.proof{
    display:block !important;
    padding:32px 0 38px !important;
    background:#f7fbff !important;
    border-top:1px solid rgba(226,232,240,.86) !important;
    border-bottom:1px solid rgba(226,232,240,.86) !important;
}
.proof-grid{
    max-width:1380px;
    margin-inline:auto;
}
.proof-grid div{
    background:#fff !important;
    border:1px solid rgba(226,232,240,.9) !important;
    box-shadow:0 16px 42px rgba(15,23,42,.08) !important;
    border-radius:20px !important;
    min-height:96px;
}
.proof-grid strong{color:#0f172a !important}.proof-grid span{color:#64748b !important}

.hero-copy-slide{
    display:none;
    animation:heroFade .42s ease both;
}
.hero-copy-slide.is-active{display:block}
@keyframes heroFade{
    from{opacity:0;transform:translateY(8px)}
    to{opacity:1;transform:translateY(0)}
}

.hero-slider{
    position:relative;
}
.hero-slides{
    position:relative;
    width:100%;
    display:grid;
    align-items:center;
}
.hero-slide{
    grid-area:1 / 1;
    opacity:0;
    pointer-events:none;
    transition:opacity .55s ease, transform .55s ease;
}
.hero-slide.is-active{
    opacity:1;
    pointer-events:auto;
}
.hero-dots{
    position:absolute;
    left:50%;
    bottom:14px;
    transform:translateX(-50%);
    z-index:10;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:9px;
    padding:6px 8px;
    border-radius:999px;
    background:rgba(3,7,18,.10);
    border:1px solid rgba(255,255,255,.12);
    backdrop-filter:blur(10px);
}
.hero-dot{
    width:9px;
    height:9px;
    padding:0;
    border-radius:50%;
    border:1px solid rgba(255,255,255,.65);
    background:rgba(255,255,255,.14);
    cursor:pointer;
    opacity:.65;
    transition:background .2s ease, transform .2s ease, opacity .2s ease;
}
.hero-dot.is-active{
    background:#1687ff;
    border-color:#1687ff;
    opacity:1;
    transform:scale(1.08);
    box-shadow:0 0 14px rgba(22,135,255,.55);
}

@media (min-width:1181px){
    .hero{
        padding:clamp(44px,4.4vw,72px) 0 clamp(26px,3vw,48px) !important;
    }
    .hero-grid{
        grid-template-columns:minmax(360px,.74fr) minmax(720px,1.26fr) !important;
        gap:clamp(18px,2vw,34px) !important;
        max-width:1540px;
    }
    .hero-copy{max-width:520px !important;}
    .hero h1{
        font-size:clamp(48px,4.45vw,78px) !important;
        line-height:1.02 !important;
        letter-spacing:-3.2px !important;
        max-width:540px !important;
    }
    .hero .subtitle{
        max-width:510px !important;
        font-size:18px !important;
    }
    .single-showcase.hero-slider{
        min-height:560px !important;
        justify-content:center !important;
        align-items:center !important;
        padding:0 0 42px !important;
        overflow:visible !important;
    }
    .hero-slides{
        width:min(1120px,64vw) !important;
    }
    .hero-slider .screen-card{
        position:relative !important;
        left:auto !important;
        top:auto !important;
        width:100% !important;
        height:clamp(410px,34vw,560px) !important;
        transform:none !important;
        border:3px solid rgba(74,163,255,.94) !important;
        border-radius:26px !important;
        padding:0 !important;
        background:#ffffff !important;
        box-shadow:
            0 0 0 1px rgba(255,255,255,.38),
            0 0 26px rgba(56,217,255,.58),
            0 0 74px rgba(47,124,255,.36),
            0 34px 90px rgba(0,0,0,.44) !important;
        overflow:hidden !important;
    }
    .hero-slider .screen-card:hover{transform:none !important;}
    .hero-slider .screen-card img{
        width:100% !important;
        height:100% !important;
        max-height:none !important;
        object-fit:cover !important;
        object-position:top left !important;
        border-radius:22px !important;
    }
    .hero-slider .showcase-glow{
        inset:0 -3% 8% -3% !important;
        filter:blur(34px) !important;
    }
}

@media (min-width:1500px){
    .hero-grid{max-width:1660px;}
    .hero-slides{width:min(1210px,65vw) !important;}
    .hero-slider .screen-card{height:clamp(440px,34vw,600px) !important;}
}

@media (max-width:1180px){
    .hero-grid{gap:26px !important;}
    .hero-copy{max-width:760px !important;}
    .single-showcase.hero-slider{
        padding-bottom:38px !important;
    }
    .hero-slides{width:100%;}
    .hero-slider .screen-card{
        height:clamp(300px,52vw,520px) !important;
        padding:0 !important;
        overflow:hidden !important;
    }
    .hero-slider .screen-card img{
        width:100% !important;
        height:100% !important;
        object-fit:cover !important;
        object-position:top left !important;
    }
    .hero-dots{bottom:8px;}
}

@media (max-width:640px){
    .proof{padding:22px 0 !important;}
    .hero-slider .screen-card{height:270px !important;}
    .hero-dots{bottom:4px;gap:8px;padding:5px 7px;}
    .hero-dot{width:8px;height:8px;}
}

/* V9.3 Premium | Correção do botão/dots e responsividade mais suave */
.hero-dots,
.hero-dots *{
    box-sizing:border-box !important;
}
.hero-dots{
    position:absolute !important;
    left:50% !important;
    bottom:10px !important;
    transform:translateX(-50%) !important;
    z-index:20 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:8px !important;
    width:auto !important;
    min-width:0 !important;
    height:auto !important;
    min-height:0 !important;
    padding:4px 6px !important;
    border-radius:999px !important;
    background:rgba(3,7,18,.18) !important;
    border:1px solid rgba(255,255,255,.10) !important;
    box-shadow:none !important;
    backdrop-filter:blur(8px) !important;
}
.hero-dot,
button.hero-dot{
    all:unset;
    display:block !important;
    width:8px !important;
    height:8px !important;
    min-width:8px !important;
    max-width:8px !important;
    min-height:8px !important;
    max-height:8px !important;
    padding:0 !important;
    margin:0 !important;
    border-radius:50% !important;
    border:1px solid rgba(255,255,255,.58) !important;
    background:rgba(255,255,255,.22) !important;
    opacity:.55 !important;
    cursor:pointer !important;
    box-shadow:none !important;
    transform:none !important;
    transition:opacity .2s ease, background .2s ease, border-color .2s ease !important;
}
.hero-dot.is-active,
button.hero-dot.is-active{
    width:8px !important;
    height:8px !important;
    min-width:8px !important;
    min-height:8px !important;
    background:#1687ff !important;
    border-color:#1687ff !important;
    opacity:1 !important;
    box-shadow:0 0 10px rgba(22,135,255,.52) !important;
}

/* Evita saltos grandes entre telas: o hero escala em degraus mais naturais */
@media (min-width:1181px){
    .hero{
        min-height:clamp(640px,42vw,780px) !important;
        padding-top:clamp(42px,4vw,68px) !important;
        padding-bottom:clamp(18px,2vw,34px) !important;
        overflow:hidden !important;
    }
    .hero-grid{
        grid-template-columns:minmax(390px,.78fr) minmax(680px,1.22fr) !important;
        gap:clamp(18px,2.4vw,44px) !important;
        align-items:center !important;
    }
    .single-showcase.hero-slider{
        min-height:clamp(420px,34vw,600px) !important;
        padding-bottom:28px !important;
    }
    .hero-slides{
        width:min(1100px,61vw) !important;
    }
    .hero-slider .screen-card{
        height:clamp(390px,31.5vw,555px) !important;
    }
}

@media (min-width:1500px){
    .hero-grid{
        grid-template-columns:minmax(420px,.74fr) minmax(760px,1.26fr) !important;
        gap:clamp(24px,2.8vw,58px) !important;
    }
    .hero-slides{
        width:min(1160px,62vw) !important;
    }
    .hero-slider .screen-card{
        height:clamp(430px,31vw,585px) !important;
    }
}

@media (max-width:1180px){
    .hero{
        padding-top:clamp(42px,7vw,72px) !important;
        padding-bottom:30px !important;
        min-height:auto !important;
    }
    .hero-grid{
        grid-template-columns:1fr !important;
        gap:22px !important;
    }
    .hero-copy{
        max-width:760px !important;
    }
    .single-showcase.hero-slider{
        min-height:auto !important;
        padding-bottom:24px !important;
    }
    .hero-slider .screen-card{
        height:clamp(300px,48vw,500px) !important;
        border-radius:22px !important;
    }
    .hero-dots{
        bottom:0 !important;
        padding:3px 5px !important;
        gap:7px !important;
    }
}

@media (max-width:760px){
    .hero-slider .screen-card{
        height:clamp(230px,58vw,360px) !important;
    }
    .hero-slider .screen-card img{
        object-fit:cover !important;
        object-position:top left !important;
    }
    .proof-grid{
        grid-template-columns:1fr !important;
        gap:14px !important;
    }
}

@media (max-width:480px){
    .hero{
        padding-top:34px !important;
    }
    .hero h1{
        font-size:clamp(34px,11vw,46px) !important;
        line-height:1.05 !important;
    }
    .hero-actions{
        gap:10px !important;
    }
    .hero-slider .screen-card{
        height:230px !important;
    }
}

/* V9.4 Premium | Responsividade fluida do hero/slider
   - remove largura fixa por viewport que causava deslocamento em telas grandes
   - cards do sistema e portal escalam conforme a coluna disponível
   - os dois slides mantêm exatamente o mesmo tamanho visual */
@media (min-width:1181px){
    .hero{
        min-height:clamp(620px,42vw,760px) !important;
        padding-top:clamp(40px,3.8vw,66px) !important;
        padding-bottom:clamp(24px,2.4vw,42px) !important;
    }
    .hero-grid{
        display:grid !important;
        grid-template-columns:minmax(360px,32%) minmax(0,68%) !important;
        gap:clamp(18px,2.2vw,42px) !important;
        align-items:center !important;
        width:100% !important;
        max-width:none !important;
    }
    .hero-copy{
        max-width:560px !important;
    }
    .hero h1{
        font-size:clamp(48px,4.25vw,76px) !important;
        max-width:560px !important;
        line-height:1.03 !important;
    }
    .hero .subtitle{
        max-width:520px !important;
    }
    .single-showcase.hero-slider{
        width:100% !important;
        min-width:0 !important;
        min-height:auto !important;
        display:flex !important;
        align-items:center !important;
        justify-content:center !important;
        padding:0 0 28px !important;
        overflow:visible !important;
    }
    .hero-slides{
        width:100% !important;
        max-width:1280px !important;
        min-width:0 !important;
        margin:0 auto !important;
        display:grid !important;
    }
    .hero-slider .screen-card{
        width:100% !important;
        height:auto !important;
        aspect-ratio:16 / 7.25 !important;
        min-height:0 !important;
        max-height:none !important;
        position:relative !important;
        inset:auto !important;
        transform:none !important;
    }
    .hero-slider .screen-card:hover{
        transform:none !important;
    }
    .hero-slider .screen-card img{
        position:absolute !important;
        inset:0 !important;
        width:100% !important;
        height:100% !important;
        max-height:none !important;
        object-fit:cover !important;
        object-position:top left !important;
    }
    .hero-dots{
        bottom:0 !important;
        transform:translate(-50%, calc(100% + 8px)) !important;
        opacity:.72 !important;
    }
    .hero-dots:hover,
    .hero-dots:focus-within{
        opacity:1 !important;
    }
}

@media (min-width:1600px){
    .hero-grid{
        grid-template-columns:minmax(390px,31%) minmax(0,69%) !important;
        gap:clamp(22px,2vw,48px) !important;
    }
    .hero-slides{
        max-width:1360px !important;
    }
}

@media (min-width:1900px){
    .hero-grid{
        grid-template-columns:minmax(420px,30%) minmax(0,70%) !important;
    }
    .hero-slides{
        max-width:1480px !important;
    }
}

@media (max-width:1180px){
    .hero-grid{
        grid-template-columns:1fr !important;
        gap:24px !important;
    }
    .single-showcase.hero-slider{
        width:100% !important;
        padding-bottom:28px !important;
    }
    .hero-slides{
        width:100% !important;
        max-width:100% !important;
    }
    .hero-slider .screen-card{
        width:100% !important;
        height:auto !important;
        aspect-ratio:16 / 8.8 !important;
    }
    .hero-slider .screen-card img{
        position:absolute !important;
        inset:0 !important;
        width:100% !important;
        height:100% !important;
        object-fit:cover !important;
        object-position:top left !important;
    }
    .hero-dots{
        bottom:0 !important;
        transform:translate(-50%, calc(100% + 7px)) !important;
    }
}

@media (max-width:760px){
    .hero-slider .screen-card{
        aspect-ratio:16 / 10.5 !important;
    }
}

@media (max-width:520px){
    .hero-slider .screen-card{
        aspect-ratio:4 / 3 !important;
        border-radius:18px !important;
    }
    .hero-slider .screen-card img{
        object-position:top left !important;
    }
    .hero-dots{
        transform:translate(-50%, calc(100% + 6px)) !important;
    }
}

/* V10 Premium | Seção A Plataforma limpa + timeline de governança */
.platform-flow-section{
    padding:clamp(76px,7vw,118px) 0 0 !important;
    background:
        radial-gradient(circle at 92% 42%, rgba(37,99,235,.08), transparent 24%),
        linear-gradient(180deg,#f7fbff 0%,#ffffff 52%,#f7fbff 100%) !important;
    border-top:1px solid rgba(226,232,240,.86);
}
.platform-flow-grid{
    display:grid;
    grid-template-columns:minmax(360px,.86fr) minmax(760px,1.55fr);
    gap:clamp(42px,5vw,82px);
    align-items:center;
}
.platform-copy{max-width:640px;}
.platform-copy h2{
    font-size:clamp(38px,4.2vw,62px) !important;
    line-height:1.04 !important;
    letter-spacing:-2.4px !important;
    margin:18px 0 24px !important;
}
.platform-copy h2 span{
    color:#2563eb;
    background:linear-gradient(135deg,#38bdf8,#2563eb 54%,#1d4ed8);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
}
.platform-copy p{
    max-width:560px;
    font-size:clamp(17px,1.12vw,20px) !important;
    color:#44546a !important;
    line-height:1.7 !important;
}
.compact-checklist{
    margin-top:26px !important;
    gap:14px !important;
}
.compact-checklist li{
    font-size:clamp(15px,1vw,17px) !important;
    color:#26364b !important;
    font-weight:800 !important;
}
.compact-checklist li:before{
    background:linear-gradient(135deg,#38bdf8,#2563eb) !important;
    box-shadow:0 8px 18px rgba(37,99,235,.18);
}
.governance-timeline{
    position:relative;
    display:grid;
    grid-template-columns:repeat(5,minmax(140px,1fr));
    gap:clamp(18px,2vw,34px);
    align-items:stretch;
}
.governance-timeline:before{
    content:"";
    position:absolute;
    left:8%;
    right:8%;
    top:104px;
    height:3px;
    background:linear-gradient(90deg,transparent,rgba(37,99,235,.18),rgba(37,99,235,.9),rgba(56,189,248,.8),rgba(37,99,235,.18),transparent);
    box-shadow:0 0 22px rgba(37,99,235,.34);
    z-index:0;
}
.flow-step{
    position:relative;
    z-index:1;
    min-height:300px;
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    background:rgba(255,255,255,.92);
    border:1px solid rgba(226,232,240,.92);
    border-radius:22px;
    padding:30px 22px 26px;
    box-shadow:0 20px 54px rgba(15,23,42,.08);
}
.flow-step:not(:last-child):after{
    content:"";
    position:absolute;
    right:calc(-1 * clamp(22px,2vw,38px));
    top:97px;
    width:clamp(34px,3vw,58px);
    height:14px;
    background:
        radial-gradient(circle at 25% 50%, #fff 0 4px, #2563eb 4.5px 7px, transparent 7.5px),
        radial-gradient(circle at 75% 50%, #fff 0 4px, #2563eb 4.5px 7px, transparent 7.5px),
        linear-gradient(90deg,rgba(37,99,235,.15),rgba(37,99,235,.9),rgba(37,99,235,.15));
    border-radius:999px;
    filter:drop-shadow(0 0 10px rgba(37,99,235,.42));
}
.step-icon{
    width:92px;
    height:92px;
    border-radius:50%;
    display:grid;
    place-items:center;
    margin-bottom:24px;
    color:#2563eb;
    background:linear-gradient(180deg,#eaf2ff,#f7fbff);
    border:1px solid rgba(219,234,254,.95);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 16px 38px rgba(37,99,235,.10);
    font-size:46px;
    font-weight:900;
    line-height:1;
}
.flow-step h3{
    font-size:clamp(20px,1.35vw,25px);
    margin:0 0 12px;
    letter-spacing:-.4px;
    color:#0f172a;
}
.flow-step p{
    margin:0;
    font-size:clamp(15px,.98vw,17px) !important;
    line-height:1.55 !important;
    color:#3c4b60 !important;
}

.modules-clean-section{
    padding:clamp(68px,5.8vw,100px) 0 clamp(78px,7vw,118px) !important;
    background:linear-gradient(180deg,#f7fbff 0%,#ffffff 100%) !important;
    border-top:1px solid rgba(226,232,240,.84);
}
.modules-head-clean{
    max-width:820px;
    margin-bottom:36px;
}
.modules-head-clean h2{
    font-size:clamp(30px,3vw,44px) !important;
    line-height:1.1 !important;
    letter-spacing:-1.2px !important;
    margin:14px 0 10px !important;
}
.modules-head-clean p{
    font-size:18px !important;
    color:#64748b !important;
}
.clean-module-grid{
    display:grid !important;
    grid-template-columns:repeat(6,minmax(0,1fr)) !important;
    gap:clamp(18px,1.5vw,28px) !important;
}
.clean-module-grid article{
    min-height:250px;
    background:#fff !important;
    border:1px solid rgba(226,232,240,.95) !important;
    border-radius:18px !important;
    padding:30px 26px 24px !important;
    box-shadow:0 18px 46px rgba(15,23,42,.07) !important;
    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.clean-module-grid article:hover{
    transform:translateY(-4px);
    border-color:rgba(37,99,235,.24) !important;
    box-shadow:0 24px 60px rgba(37,99,235,.12) !important;
}
.clean-module-grid .module-icon{
    width:64px !important;
    height:64px !important;
    border-radius:50% !important;
    background:linear-gradient(180deg,#eaf2ff,#f7fbff) !important;
    color:#2563eb !important;
    display:grid !important;
    place-items:center !important;
    font-size:34px !important;
    font-weight:900 !important;
    margin:0 0 28px !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 12px 30px rgba(37,99,235,.10);
}
.clean-module-grid h3{
    font-size:clamp(20px,1.45vw,25px) !important;
    margin:0 0 12px !important;
    color:#0f172a !important;
}
.clean-module-grid p{
    font-size:clamp(15px,1vw,17px) !important;
    line-height:1.55 !important;
    color:#475569 !important;
    margin:0 0 18px !important;
}
.clean-module-grid a{
    display:inline-flex;
    color:#2563eb;
    font-size:34px;
    line-height:1;
    font-weight:700;
}

@media (max-width:1500px){
    .platform-flow-grid{grid-template-columns:1fr;gap:46px;}
    .platform-copy{max-width:860px;}
    .governance-timeline{grid-template-columns:repeat(5,minmax(130px,1fr));}
    .clean-module-grid{grid-template-columns:repeat(3,1fr) !important;}
}
@media (max-width:980px){
    .platform-flow-section{padding-top:64px !important;}
    .governance-timeline{grid-template-columns:1fr;gap:18px;}
    .governance-timeline:before{display:none;}
    .flow-step{
        min-height:0;
        display:grid;
        grid-template-columns:72px 1fr;
        gap:18px;
        text-align:left;
        align-items:center;
        padding:22px;
    }
    .flow-step:not(:last-child):after{display:none;}
    .step-icon{width:72px;height:72px;font-size:34px;margin:0;grid-row:span 2;}
    .flow-step h3{margin-bottom:4px;}
    .clean-module-grid{grid-template-columns:repeat(2,1fr) !important;}
}
@media (max-width:640px){
    .platform-flow-grid{gap:32px;}
    .platform-copy h2 br{display:none;}
    .flow-step{grid-template-columns:1fr;text-align:center;justify-items:center;}
    .step-icon{grid-row:auto;}
    .clean-module-grid{grid-template-columns:1fr !important;}
    .clean-module-grid article{min-height:0;}
}

/* V10.1 Premium | Header dinâmico: branco no Hero e azul-marinho após o Hero */
.topbar{
    transition: background .28s ease, border-color .28s ease, box-shadow .28s ease, backdrop-filter .28s ease;
}
.topbar .brand .word,
.topbar nav a,
.topbar .btn,
.topbar .mobile{
    transition: color .28s ease, background .28s ease, border-color .28s ease, box-shadow .28s ease;
}
.topbar.is-scrolled{
    background:rgba(2,7,22,.94);
    border-bottom:1px solid rgba(96,165,250,.18);
    box-shadow:0 16px 45px rgba(2,7,22,.22);
    backdrop-filter:blur(18px);
}
.topbar.is-scrolled .word{
    color:#ffffff;
}
.topbar.is-scrolled nav a{
    color:#f8fbff;
}
.topbar.is-scrolled nav a:hover{
    color:#60a5fa;
}
.topbar.is-scrolled .btn.ghost{
    display:inline-flex;
    color:#f8fbff;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.22);
}
.topbar.is-scrolled .btn.ghost:hover{
    background:rgba(255,255,255,.11);
}
.topbar.is-scrolled .btn.primary{
    background:linear-gradient(135deg,#2f7cff,#1d4ed8);
    color:#fff;
    box-shadow:0 16px 40px rgba(37,99,235,.32);
}
.topbar.is-scrolled .mobile{
    background:rgba(255,255,255,.08);
    color:#fff;
    border:1px solid rgba(255,255,255,.16);
}
@media (max-width:980px){
    .topbar.is-scrolled nav{
        background:#061124;
        border-color:rgba(96,165,250,.24);
    }
    .topbar.is-scrolled nav a{
        color:#fff;
    }
}

/* V10.3 Premium | Segurança e Auditoria fiel ao layout de referência */
.audit-section{
    position:relative;
    min-height:clamp(760px,66vw,1024px);
    padding:clamp(118px,9vw,178px) 0 clamp(96px,7vw,138px) !important;
    overflow:hidden;
    background:#020817 !important;
    color:#fff;
    isolation:isolate;
}
.audit-photo{
    position:absolute;
    inset:0 0 0 auto;
    width:72%;
    height:100%;
    object-fit:cover;
    object-position:center right;
    filter:blur(5px) saturate(.78) brightness(.54) contrast(1.04);
    opacity:.72;
    transform:scale(1.035);
    z-index:-4;
}
.audit-network{
    position:absolute;
    inset:0 auto 0 0;
    width:55%;
    pointer-events:none;
    opacity:.58;
    background-image:
        radial-gradient(circle at 0% 36%, rgba(37,99,235,.95) 0 3px, transparent 4px),
        radial-gradient(circle at 9% 62%, rgba(56,189,248,.70) 0 2px, transparent 3px),
        radial-gradient(circle at 15% 91%, rgba(37,99,235,.9) 0 3px, transparent 4px),
        radial-gradient(circle at 28% 76%, rgba(37,99,235,.55) 0 2px, transparent 3px),
        linear-gradient(34deg, transparent 0 48.6%, rgba(37,99,235,.46) 49.2% 50.2%, transparent 51%),
        linear-gradient(154deg, transparent 0 48.6%, rgba(56,189,248,.24) 49.2% 50.2%, transparent 51%);
    background-size:285px 238px;
    mask-image:linear-gradient(90deg,#000 0%,#000 72%,transparent 100%);
    z-index:-3;
}
.audit-overlay{
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 0% 78%, rgba(37,99,235,.30), transparent 31%),
        linear-gradient(180deg, rgba(2,8,23,.84) 0%, rgba(2,8,23,.20) 18%, rgba(2,8,23,.18) 70%, rgba(2,8,23,.58) 100%),
        linear-gradient(90deg,
            rgba(2,8,23,1) 0%,
            rgba(2,8,23,.99) 31%,
            rgba(2,8,23,.90) 48%,
            rgba(2,8,23,.64) 66%,
            rgba(2,8,23,.34) 100%);
    z-index:-2;
}
.audit-grid{
    position:relative;
    display:block;
}
.audit-copy{
    max-width:780px;
}
.audit-copy h2{
    color:#fff !important;
    font-size:clamp(42px,4.3vw,64px) !important;
    line-height:1.08 !important;
    letter-spacing:-2px !important;
    margin:24px 0 26px !important;
    max-width:790px;
    text-wrap:balance;
}
.audit-copy p{
    max-width:760px;
    color:#e0e9f6 !important;
    font-size:clamp(17px,1.1vw,20px) !important;
    line-height:1.75 !important;
}
.audit-cards{
    margin-top:clamp(36px,4.2vw,58px);
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:20px !important;
    max-width:720px;
    justify-self:start;
}
.audit-cards div{
    min-height:122px;
    display:grid;
    grid-template-columns:74px 1fr;
    grid-template-rows:auto auto;
    column-gap:18px;
    align-items:center;
    padding:22px 26px !important;
    background:linear-gradient(135deg,rgba(15,23,42,.66),rgba(15,23,42,.34)) !important;
    border:1px solid rgba(148,163,184,.22) !important;
    border-radius:20px !important;
    box-shadow:0 24px 62px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.055);
    backdrop-filter:blur(12px);
}
.audit-cards i{
    grid-row:1 / span 2;
    width:62px;
    height:62px;
    border-radius:50%;
    display:grid;
    place-items:center;
    color:#2377ff;
    background:rgba(37,99,235,.12);
    border:1px solid rgba(96,165,250,.13);
    font-size:32px;
    font-style:normal;
    font-weight:900;
    box-shadow:0 0 30px rgba(37,99,235,.13);
}
.audit-cards b{
    font-size:clamp(20px,1.35vw,25px) !important;
    line-height:1.15;
    margin:0 0 5px !important;
    color:#fff;
}
.audit-cards span{
    color:#dce7f5 !important;
    font-size:clamp(15px,.95vw,17px) !important;
    line-height:1.55 !important;
}
@media (min-width:1600px){
    .audit-copy{max-width:820px;}
    .audit-cards{max-width:760px;}
}
@media (max-width:1200px){
    .audit-section{min-height:auto;padding:92px 0 !important;}
    .audit-photo{width:100%;opacity:.40;filter:blur(6px) brightness(.48) saturate(.8);}
    .audit-network{width:100%;opacity:.34;mask-image:none;}
    .audit-overlay{background:linear-gradient(90deg,rgba(2,8,23,.98),rgba(2,8,23,.86));}
    .audit-cards{max-width:100%;}
}
@media (max-width:760px){
    .audit-section{padding:72px 0 !important;}
    .audit-copy h2{font-size:clamp(34px,10vw,46px) !important;letter-spacing:-1.2px !important;}
    .audit-cards{grid-template-columns:1fr !important;}
    .audit-cards div{grid-template-columns:58px 1fr;min-height:112px;padding:20px !important;}
    .audit-cards i{width:50px;height:50px;font-size:26px;}
}

/* V10.7 Premium | Segurança e Auditoria com background gerado + conteúdo em código */
.audit-section{
    position:relative;
    min-height:clamp(720px,56vw,920px);
    padding:clamp(116px,8vw,154px) 0 clamp(96px,7vw,128px) !important;
    overflow:hidden;
    background:#020817 !important;
    color:#fff;
    isolation:isolate;
}
.audit-photo{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center center;
    filter:none;
    opacity:1;
    transform:none;
    z-index:-4;
}
.audit-network{
    display:none !important;
}
.audit-overlay{
    position:absolute;
    inset:0;
    background:
        linear-gradient(180deg, rgba(2,8,23,.16) 0%, rgba(2,8,23,.04) 42%, rgba(2,8,23,.34) 100%),
        linear-gradient(90deg, rgba(2,8,23,.48) 0%, rgba(2,8,23,.26) 38%, rgba(2,8,23,.08) 64%, rgba(2,8,23,.12) 100%);
    z-index:-2;
    pointer-events:none;
}
.audit-grid{
    position:relative;
    display:grid;
    grid-template-columns:minmax(420px,720px) 1fr;
    align-items:center;
    gap:clamp(40px,5vw,86px);
}
.audit-copy{
    max-width:720px;
}
.audit-copy .tag{
    letter-spacing:.28em;
}
.audit-copy h2{
    color:#fff !important;
    font-size:clamp(44px,4.25vw,70px) !important;
    line-height:1.05 !important;
    letter-spacing:-2.4px !important;
    margin:26px 0 24px !important;
    max-width:760px;
    text-wrap:balance;
    text-shadow:0 10px 32px rgba(0,0,0,.42);
}
.audit-copy p{
    max-width:760px;
    color:#e5edf9 !important;
    font-size:clamp(17px,1.08vw,21px) !important;
    line-height:1.72 !important;
    text-shadow:0 6px 24px rgba(0,0,0,.35);
}
.audit-cards{
    margin:0 0 0 auto;
    display:grid !important;
    grid-template-columns:repeat(2,minmax(230px,1fr)) !important;
    gap:22px !important;
    width:min(680px,42vw);
    align-self:center;
}
.audit-cards div{
    min-height:132px;
    display:grid;
    grid-template-columns:76px 1fr;
    grid-template-rows:auto auto;
    column-gap:18px;
    align-items:center;
    padding:24px 26px !important;
    background:linear-gradient(135deg,rgba(15,23,42,.76),rgba(15,23,42,.50)) !important;
    border:1px solid rgba(148,163,184,.24) !important;
    border-radius:22px !important;
    box-shadow:0 28px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.06);
    backdrop-filter:blur(14px);
}
.audit-cards i{
    grid-row:1 / span 2;
    width:62px;
    height:62px;
    border-radius:50%;
    display:grid;
    place-items:center;
    color:#1677ff;
    background:rgba(37,99,235,.14);
    border:1px solid rgba(96,165,250,.16);
    font-size:32px;
    font-style:normal;
    font-weight:900;
    box-shadow:0 0 34px rgba(37,99,235,.14);
}
.audit-cards b{
    font-size:clamp(19px,1.22vw,24px) !important;
    line-height:1.15;
    margin:0 0 5px !important;
    color:#fff;
}
.audit-cards span{
    color:#dce7f5 !important;
    font-size:clamp(14px,.86vw,16px) !important;
    line-height:1.55 !important;
}
@media (max-width:1280px){
    .audit-section{min-height:auto;padding:94px 0 !important;}
    .audit-grid{grid-template-columns:1fr;gap:40px;}
    .audit-cards{width:100%;max-width:760px;margin:0;}
    .audit-overlay{background:linear-gradient(90deg,rgba(2,8,23,.78),rgba(2,8,23,.42));}
}
@media (max-width:760px){
    .audit-section{padding:72px 0 !important;}
    .audit-copy h2{font-size:clamp(34px,10vw,48px) !important;letter-spacing:-1.2px !important;}
    .audit-cards{grid-template-columns:1fr !important;gap:14px !important;}
    .audit-cards div{grid-template-columns:58px 1fr;min-height:110px;padding:20px !important;}
    .audit-cards i{width:50px;height:50px;font-size:26px;}
}


/* V10.8 Premium | Parallax suave na seção Segurança e Auditoria */
.audit-section{
    --audit-parallax: 0px;
}
.audit-section .audit-photo{
    inset:-8% 0;
    height:116%;
    transform:translate3d(0,var(--audit-parallax),0) scale(1.06);
    will-change:transform;
    transition:transform .08s linear;
}
@media (prefers-reduced-motion: reduce){
    .audit-section .audit-photo{
        transform:none !important;
        transition:none !important;
    }
}
@media (max-width:900px){
    .audit-section .audit-photo{
        inset:0;
        height:100%;
        transform:none !important;
    }
}


/* V10.9 Premium | Parallax real e mais perceptível na seção Segurança e Auditoria */
.audit-section{
    --audit-parallax: 0px;
}
.audit-section .audit-photo{
    top:-18% !important;
    bottom:auto !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    height:136% !important;
    max-width:none !important;
    object-fit:cover !important;
    object-position:center center !important;
    transform:translate3d(0,var(--audit-parallax),0) scale(1.08) !important;
    will-change:transform;
    transition:none !important;
}
@media (max-width:900px), (prefers-reduced-motion: reduce){
    .audit-section .audit-photo{
        top:0 !important;
        height:100% !important;
        transform:none !important;
    }
}


/* V10.10 Premium | Parallax mais forte e visível */
.audit-section{
    --audit-parallax: 0px;
}
.audit-section .audit-photo{
    top:-30% !important;
    bottom:auto !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    height:160% !important;
    max-width:none !important;
    object-fit:cover !important;
    object-position:center center !important;
    transform:translate3d(0,var(--audit-parallax),0) scale(1.16) !important;
    will-change:transform;
    transition:none !important;
    backface-visibility:hidden;
}
@media (max-width:900px), (prefers-reduced-motion: reduce){
    .audit-section .audit-photo{
        top:0 !important;
        height:100% !important;
        transform:none !important;
    }
}


/* V11.5 | Acesso à plataforma premium full-width e responsivo */
.access-premium-section{
    padding:clamp(54px,6vw,96px) clamp(18px,3vw,56px) !important;
    background:
        radial-gradient(circle at 83% 12%, rgba(37,99,235,.12), transparent 34%),
        radial-gradient(circle at 8% 92%, rgba(14,165,233,.14), transparent 32%),
        linear-gradient(180deg,#f8fbff 0%,#eef6ff 100%) !important;
    overflow:hidden;
}
.access-premium-shell{
    width:100%;
    max-width:none;
    min-height:clamp(520px,48vw,760px);
    margin:0;
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(440px,.92fr);
    align-items:center;
    gap:clamp(36px,5vw,96px);
    padding:clamp(42px,5.4vw,92px) clamp(28px,5vw,92px);
    border:1px solid rgba(37,99,235,.28);
    border-radius:32px;
    background:
        radial-gradient(circle at 92% 8%, rgba(255,255,255,.98) 0 8%, transparent 28%),
        radial-gradient(circle at 52% 42%, rgba(37,99,235,.10) 0 1px, transparent 1.5px),
        linear-gradient(135deg,rgba(255,255,255,.98),rgba(255,255,255,.82));
    background-size:auto,16px 16px,auto;
    box-shadow:0 34px 90px rgba(15,23,42,.10);
    position:relative;
}
.access-premium-shell:before{
    content:"";
    position:absolute;
    left:-10%;
    bottom:-24%;
    width:46%;
    height:52%;
    opacity:.55;
    background:repeating-radial-gradient(ellipse at center, rgba(37,99,235,.18) 0 1px, transparent 2px 14px);
    border-radius:50%;
    pointer-events:none;
}
.access-premium-copy,
.access-contact-form{position:relative;z-index:1}
.access-premium-copy{max-width:760px}
.access-premium-copy .tag{margin-bottom:26px}
.access-premium-copy h2{
    margin:0 0 24px;
    max-width:780px;
    color:#071225;
    font-size:clamp(42px,4.8vw,78px);
    line-height:1.02;
    letter-spacing:-.055em;
}
.access-premium-copy h2 span{
    color:#2563eb;
    background:linear-gradient(135deg,#2563eb,#38bdf8);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
}
.access-premium-copy p{
    max-width:720px;
    color:#475569;
    font-size:clamp(16px,1.15vw,21px);
    line-height:1.75;
    margin:0 0 32px;
}
.access-benefits{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:clamp(16px,1.7vw,26px);
}
.access-benefits article{
    min-height:176px;
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    padding:clamp(20px,1.6vw,28px);
    border:1px solid rgba(37,99,235,.18);
    border-radius:22px;
    background:rgba(255,255,255,.74);
    box-shadow:0 18px 46px rgba(15,23,42,.06);
}
.access-benefits article:before{
    content:"";
    width:62px;
    height:4px;
    margin:-20px 0 22px;
    border-radius:999px;
    background:#2563eb;
}
.access-benefits i{
    color:#2563eb;
    font-style:normal;
    font-size:32px;
    line-height:1;
    margin-bottom:14px;
}
.access-benefits strong{
    display:block;
    color:#0f3fae;
    font-size:clamp(18px,1.4vw,26px);
    line-height:1.12;
    margin-bottom:8px;
}
.access-benefits small{
    color:#475569;
    font-weight:700;
    line-height:1.65;
    font-size:14px;
}
.access-contact-form{
    width:100%;
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:16px;
    padding:clamp(28px,3vw,54px);
    border:1px solid rgba(203,213,225,.9);
    border-radius:28px;
    background:rgba(255,255,255,.94);
    box-shadow:0 28px 74px rgba(15,23,42,.12);
}
.access-contact-form h3{
    grid-column:1/-1;
    margin:0;
    color:#071225;
    font-size:clamp(28px,2.1vw,42px);
    line-height:1.05;
    letter-spacing:-.045em;
}
.form-title-line{
    grid-column:1/-1;
    width:70px;
    height:4px;
    border-radius:999px;
    background:#2563eb;
    margin:0 0 10px;
}
.access-contact-form label{display:block;margin:0}
.access-contact-form label span{position:absolute;width:1px;height:1px;margin:-1px;overflow:hidden;clip:rect(0,0,0,0)}
.access-contact-form input,
.access-contact-form textarea{
    width:100%;
    border:1px solid rgba(203,213,225,.95);
    border-radius:14px;
    background:#fff;
    color:#0f172a;
    font:inherit;
    font-weight:700;
    padding:18px 20px;
    outline:none;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.9);
    transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.access-contact-form input:focus,
.access-contact-form textarea:focus{
    border-color:#2563eb;
    box-shadow:0 0 0 4px rgba(37,99,235,.12);
}
.access-contact-form input::placeholder,
.access-contact-form textarea::placeholder{color:#64748b;font-weight:700}
.access-contact-form .full{grid-column:1/-1}
.access-contact-form textarea{min-height:170px;resize:vertical}
.access-contact-form button{
    grid-column:1/-1;
    min-height:64px;
    border-radius:14px;
    font-weight:1000;
    box-shadow:0 18px 42px rgba(37,99,235,.28);
}
.form-safe{
    grid-column:1/-1;
    margin:0 !important;
    text-align:center;
    color:#64748b !important;
    font-size:14px !important;
    font-weight:900;
    line-height:1.45 !important;
}

@media (max-width:1280px){
    .access-premium-shell{
        grid-template-columns:1fr;
        align-items:start;
        padding:clamp(34px,5vw,64px);
    }
    .access-premium-copy{max-width:none}
    .access-premium-copy h2,
    .access-premium-copy p{max-width:100%}
    .access-contact-form{max-width:none}
}
@media (max-width:820px){
    .access-premium-section{padding:34px 14px !important}
    .access-premium-shell{border-radius:24px;padding:28px 18px;gap:30px}
    .access-benefits{grid-template-columns:1fr}
    .access-benefits article{min-height:auto}
    .access-contact-form{grid-template-columns:1fr;border-radius:22px;padding:22px 16px}
    .access-contact-form textarea{min-height:132px}
}
@media (max-width:520px){
    .access-premium-copy h2{font-size:clamp(34px,12vw,48px)}
    .access-premium-copy .tag{font-size:10px;letter-spacing:.18em}
    .access-contact-form h3{font-size:26px}
}

/* V11.6 | Implantação nacional em todo o Brasil */
.implantacao-brasil-section{
    width:100%;
    padding:clamp(72px,8vw,132px) clamp(24px,4vw,76px) clamp(70px,7vw,112px) !important;
    background:
        radial-gradient(circle at 82% 18%, rgba(37,99,235,.08), transparent 30%),
        radial-gradient(circle at 13% 72%, rgba(14,165,233,.08), transparent 34%),
        linear-gradient(180deg,#f8fbff 0%,#ffffff 54%,#f5f9ff 100%);
    overflow:hidden;
}
.implantacao-brasil-wrap{
    width:100%;
    max-width:none;
    margin:0 auto;
    display:grid;
    grid-template-columns:minmax(410px,.76fr) minmax(0,1.24fr);
    gap:clamp(38px,5vw,88px);
    align-items:center;
}
.implantacao-brasil-mapcol{
    position:relative;
    min-width:0;
}
.brasil-map-card{
    position:relative;
    width:min(100%,720px);
    margin:0 auto 10px 0;
    filter:drop-shadow(0 28px 34px rgba(15,63,174,.16));
}
.brasil-map-card:before{
    content:"";
    position:absolute;
    inset:10% 6% 0 8%;
    border-radius:50%;
    background:repeating-radial-gradient(ellipse at center, rgba(37,99,235,.12) 0 1px, transparent 2px 17px);
    transform:scale(1.05);
    opacity:.55;
    z-index:0;
}
.brasil-map-card img{
    position:relative;
    z-index:1;
    display:block;
    width:100%;
    height:auto;
    mix-blend-mode:multiply;
}
.implantacao-brasil-callout{
    position:relative;
    z-index:2;
    max-width:520px;
    margin-top:-10px;
}
.implantacao-brasil-callout h2{
    margin:22px 0 18px;
    color:#071225;
    font-size:clamp(40px,4vw,68px);
    line-height:1.05;
    letter-spacing:-.055em;
}
.implantacao-brasil-callout h2 span,
.implantacao-brasil-head h2 span{
    color:#2563eb;
    background:linear-gradient(135deg,#0b57e3,#38bdf8);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
}
.implantacao-brasil-callout p{
    color:#475569;
    font-size:clamp(16px,1.12vw,20px);
    line-height:1.7;
    max-width:500px;
}
.implantacao-brasil-content{
    min-width:0;
}
.implantacao-brasil-head{
    text-align:center;
    max-width:900px;
    margin:0 auto clamp(42px,4vw,70px);
}
.implantacao-brasil-head .tag{justify-content:center;}
.implantacao-brasil-head h2{
    margin:18px 0 22px;
    color:#071225;
    font-size:clamp(42px,4.8vw,74px);
    line-height:1.02;
    letter-spacing:-.06em;
}
.implantacao-brasil-head p{
    color:#475569;
    font-size:clamp(17px,1.25vw,22px);
    line-height:1.7;
    max-width:780px;
    margin:0 auto;
}
.implantacao-services{
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:clamp(16px,1.35vw,24px);
    width:100%;
}
.implantacao-services article{
    min-height:clamp(250px,22vw,355px);
    padding:clamp(24px,2.2vw,40px) clamp(18px,1.7vw,30px);
    border:1px solid rgba(203,213,225,.9);
    border-radius:24px;
    background:rgba(255,255,255,.92);
    box-shadow:0 22px 56px rgba(15,23,42,.075), inset 0 1px 0 rgba(255,255,255,.9);
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    justify-content:flex-start;
    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.implantacao-services article:hover{
    transform:translateY(-5px);
    border-color:rgba(37,99,235,.34);
    box-shadow:0 28px 74px rgba(37,99,235,.13);
}
.implantacao-services i{
    width:clamp(82px,7vw,120px);
    height:clamp(82px,7vw,120px);
    border-radius:50%;
    display:grid;
    place-items:center;
    margin-bottom:clamp(22px,2vw,32px);
    color:#1664f4;
    background:linear-gradient(135deg,#f2f7ff,#edf4ff);
    font-size:clamp(42px,3.4vw,64px);
    line-height:1;
    font-style:normal;
    font-weight:900;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.95);
}
.implantacao-services h3{
    margin:0 0 16px;
    color:#071225;
    font-size:clamp(20px,1.45vw,28px);
    line-height:1.16;
    letter-spacing:-.03em;
}
.implantacao-services p{
    margin:0;
    color:#475569;
    font-size:clamp(15px,1vw,19px);
    line-height:1.72;
}
.implantacao-support-banner{
    margin-top:clamp(26px,2.6vw,42px);
    display:grid;
    grid-template-columns:auto minmax(0,1fr) minmax(120px,190px);
    align-items:center;
    gap:clamp(22px,2.2vw,36px);
    padding:clamp(26px,2.6vw,42px) clamp(28px,3vw,56px);
    border:1px solid rgba(203,213,225,.9);
    border-radius:26px;
    background:rgba(255,255,255,.72);
    box-shadow:0 18px 50px rgba(15,23,42,.055);
}
.support-seal{
    width:clamp(70px,5vw,96px);
    height:clamp(70px,5vw,96px);
    border-radius:50%;
    display:grid;
    place-items:center;
    color:#1664f4;
    background:#f0f6ff;
    font-size:clamp(40px,3vw,62px);
    font-weight:900;
}
.implantacao-support-banner strong{
    display:block;
    color:#071225;
    font-size:clamp(20px,1.35vw,28px);
    line-height:1.25;
    margin-bottom:8px;
}
.implantacao-support-banner p{
    margin:0;
    color:#475569;
    font-size:clamp(16px,1.05vw,20px);
    line-height:1.7;
}
.mini-brasil-dots{
    justify-self:end;
    width:150px;
    height:120px;
    opacity:.42;
    background:
        radial-gradient(circle, rgba(37,99,235,.62) 0 2px, transparent 2.6px);
    background-size:10px 10px;
    clip-path:polygon(27% 7%,45% 0,66% 9%,78% 24%,98% 30%,89% 48%,81% 57%,79% 72%,66% 78%,60% 92%,45% 100%,36% 85%,25% 77%,18% 66%,4% 55%,12% 42%,0 32%,15% 20%);
}

@media (max-width:1500px){
    .implantacao-brasil-wrap{grid-template-columns:minmax(360px,.7fr) minmax(0,1.3fr);gap:42px;}
    .implantacao-services{gap:14px;}
    .implantacao-services article{padding:26px 18px;}
}
@media (max-width:1220px){
    .implantacao-brasil-wrap{grid-template-columns:1fr;}
    .brasil-map-card{width:min(720px,100%);margin:0 auto;}
    .implantacao-brasil-callout{text-align:center;margin:0 auto;}
    .implantacao-brasil-callout .tag{justify-content:center;}
    .implantacao-services{grid-template-columns:repeat(3,minmax(0,1fr));}
}
@media (max-width:860px){
    .implantacao-brasil-section{padding:60px 16px 68px !important;}
    .implantacao-services{grid-template-columns:repeat(2,minmax(0,1fr));}
    .implantacao-services article{min-height:auto;}
    .implantacao-support-banner{grid-template-columns:1fr;text-align:center;justify-items:center;}
    .mini-brasil-dots{justify-self:center;}
}
@media (max-width:560px){
    .implantacao-services{grid-template-columns:1fr;}
    .implantacao-brasil-head h2,
    .implantacao-brasil-callout h2{font-size:clamp(34px,11vw,46px);letter-spacing:-.045em;}
    .brasil-map-card{width:112%;margin-left:-6%;}
    .implantacao-brasil-head{margin-bottom:32px;}
}


/* V12.4 - troca segura: mantém a seção original e substitui apenas a imagem do mapa por SVG */
.brasil-map-card .konecta-brasil-svg{
    position:relative;
    z-index:2;
    display:block;
    width:100%;
    height:auto;
    overflow:visible;
}
.brasil-map-card .kb-orbits ellipse{
    fill:none;
    stroke:rgba(37,99,235,.14);
    stroke-width:1.35;
}
.brasil-map-card .kb-region{
    fill:url(#kbGrad);
    stroke:rgba(255,255,255,.58);
    stroke-width:2.1;
    cursor:pointer;
    transform-box:fill-box;
    transform-origin:center;
    transition:transform .22s ease, filter .22s ease, opacity .22s ease;
}
.brasil-map-card .kb-region:hover,
.brasil-map-card .kb-region.active{
    transform:translateY(-3px) scale(1.012);
    filter:drop-shadow(0 0 18px rgba(56,189,248,.82));
}
.brasil-map-card .kb-map:hover .kb-region:not(:hover):not(.active){
    opacity:.72;
}
.brasil-map-card .kb-state-lines path{
    fill:none;
    stroke:rgba(255,255,255,.34);
    stroke-width:1.1;
}
.brasil-map-card .kb-lines path{
    fill:none;
    stroke:#7dd3fc;
    stroke-width:2;
    stroke-linecap:round;
    stroke-dasharray:9 12;
    opacity:.76;
    animation:kbFlow 9s linear infinite;
    filter:drop-shadow(0 0 6px rgba(56,189,248,.9));
}
.brasil-map-card .kb-lines path:nth-child(2n){animation-duration:12s;}
.brasil-map-card .kb-lines path:nth-child(3n){animation-duration:7s;}
.brasil-map-card .kb-nodes circle{
    fill:#fff;
    stroke:#38bdf8;
    stroke-width:4.5;
    filter:drop-shadow(0 0 12px rgba(255,255,255,.95)) drop-shadow(0 0 16px rgba(56,189,248,.8));
    animation:kbPulse 2.4s ease-in-out infinite;
}
.brasil-map-card .kb-nodes circle:nth-child(2n){animation-delay:.35s;}
.brasil-map-card .kb-nodes circle:nth-child(3n){animation-delay:.7s;}
@keyframes kbFlow{to{stroke-dashoffset:-220;}}
@keyframes kbPulse{0%,100%{r:6;opacity:1;}50%{r:8;opacity:.78;}}


/* V12.6 - SVG real do Brasil implementado de fato */
.brasil-map-card .konecta-real-brasil-map{
    position:relative;
    z-index:2;
    display:block;
    width:100%;
    height:auto;
    overflow:visible;
    filter:drop-shadow(0 24px 30px rgba(15,63,174,.20));
}
.brasil-map-card .konecta-real-brasil-map path{
    fill:url(#konectaBrasilGradient) !important;
    stroke:rgba(255,255,255,.72) !important;
    stroke-width:1.05 !important;
    transition:fill .22s ease, filter .22s ease, opacity .22s ease, transform .22s ease;
    transform-box:fill-box;
    transform-origin:center;
}
.brasil-map-card .konecta-real-brasil-map a:hover path,
.brasil-map-card .konecta-real-brasil-map path:hover{
    fill:#38bdf8 !important;
    filter:url(#konectaMapGlow) drop-shadow(0 0 12px rgba(56,189,248,.95));
    transform:translateY(-1.5px);
    cursor:pointer;
}
.brasil-map-card .konecta-real-brasil-map text{
    fill:#fff !important;
    font:700 10px Inter, Arial, sans-serif !important;
    pointer-events:none;
    text-shadow:0 1px 2px rgba(0,0,0,.35);
}
.brasil-map-card .konecta-real-brasil-map .circle{
    fill:#0f52dc !important;
    stroke:#fff !important;
    stroke-width:1 !important;
}
.brasil-map-card .konecta-network-lines path{
    fill:none !important;
    stroke:#7dd3fc !important;
    stroke-width:1.45 !important;
    stroke-linecap:round;
    stroke-dasharray:7 9;
    opacity:.78;
    animation:konectaSvgFlow 8s linear infinite;
    filter:drop-shadow(0 0 5px rgba(56,189,248,.95));
    pointer-events:none;
}
.brasil-map-card .konecta-network-lines path:nth-child(2n){animation-duration:11s;}
.brasil-map-card .konecta-capital-nodes circle{
    fill:#fff !important;
    stroke:#38bdf8 !important;
    stroke-width:3.5 !important;
    animation:konectaSvgPulse 2.2s ease-in-out infinite;
    filter:drop-shadow(0 0 8px rgba(255,255,255,.95)) drop-shadow(0 0 12px rgba(56,189,248,.85));
    pointer-events:none;
}
.brasil-map-card .konecta-capital-nodes circle:nth-child(2n){animation-delay:.32s;}
.brasil-map-card .konecta-capital-nodes circle:nth-child(3n){animation-delay:.66s;}
.konecta-region-status{
    margin-top:18px;
    width:min(100%,520px);
    padding:14px 16px;
    border:1px solid rgba(191,219,254,.9);
    border-radius:16px;
    background:rgba(255,255,255,.78);
    box-shadow:0 12px 28px rgba(15,23,42,.06);
    backdrop-filter:blur(10px);
}
.konecta-region-status strong{display:block;color:#071225;font-size:14px;margin-bottom:3px;}
.konecta-region-status span{display:block;color:#475569;font-size:13px;line-height:1.45;}
@keyframes konectaSvgFlow{to{stroke-dashoffset:-180;}}
@keyframes konectaSvgPulse{0%,100%{r:4;opacity:1;}50%{r:6;opacity:.72;}}
@media (max-width:560px){
    .brasil-map-card .konecta-real-brasil-map{width:112%;margin-left:-6%;}
}


/* V12.7 - Rede viva: pontos em todos os estados + partículas viajando nas rotas */
.brasil-map-card .konecta-all-state-network{
    pointer-events:none;
}
.brasil-map-card .konecta-state-routes path{
    fill:none !important;
    stroke:#93c5fd !important;
    stroke-width:1.05 !important;
    stroke-linecap:round !important;
    stroke-dasharray:6 10;
    opacity:.42;
    animation:konectaRouteBreath 4s ease-in-out infinite;
    filter:drop-shadow(0 0 4px rgba(56,189,248,.55));
}
.brasil-map-card .konecta-state-routes path:nth-child(3n){
    opacity:.28;
}
.brasil-map-card .konecta-all-state-nodes circle{
    fill:#ffffff !important;
    stroke:#38bdf8 !important;
    stroke-width:2.2 !important;
    opacity:.92;
    filter:drop-shadow(0 0 7px rgba(255,255,255,.95)) drop-shadow(0 0 10px rgba(56,189,248,.7));
    animation:konectaNodeBlink 3.2s ease-in-out infinite;
}
.brasil-map-card .konecta-all-state-nodes circle:nth-child(2n){animation-delay:.25s;}
.brasil-map-card .konecta-all-state-nodes circle:nth-child(3n){animation-delay:.55s;}
.brasil-map-card .konecta-all-state-nodes circle:nth-child(5n){animation-delay:.9s;}
.brasil-map-card .konecta-moving-packets circle{
    fill:#ffffff !important;
    stroke:#7dd3fc !important;
    stroke-width:2.5 !important;
    filter:drop-shadow(0 0 8px rgba(255,255,255,1)) drop-shadow(0 0 14px rgba(56,189,248,.95));
    opacity:.98;
}
@keyframes konectaRouteBreath{
    0%,100%{opacity:.30;stroke-dashoffset:0;}
    50%{opacity:.62;stroke-dashoffset:-28;}
}
@keyframes konectaNodeBlink{
    0%,100%{opacity:.72;}
    50%{opacity:1;}
}
@media (max-width:560px){
    .brasil-map-card .konecta-state-routes path{stroke-width:.85 !important;opacity:.35;}
    .brasil-map-card .konecta-all-state-nodes circle{r:2.6;}
}


/* V12.8 - Fluxos adicionais solicitados, sem alterar rotas existentes */
.brasil-map-card .konecta-extra-state-flows{
    pointer-events:none;
}
.brasil-map-card .konecta-extra-routes path{
    fill:none !important;
    stroke:#ffffff !important;
    stroke-width:1.35 !important;
    stroke-linecap:round;
    stroke-dasharray:5 10;
    opacity:.24;
    filter:drop-shadow(0 0 5px rgba(56,189,248,.72));
    animation:konectaExtraRouteSoft 5s ease-in-out infinite;
}
.brasil-map-card .konecta-extra-packets circle{
    fill:#e0f2fe !important;
    stroke:#38bdf8 !important;
    stroke-width:2.8 !important;
    opacity:.98;
    filter:drop-shadow(0 0 8px rgba(255,255,255,1)) drop-shadow(0 0 16px rgba(56,189,248,1));
}
@keyframes konectaExtraRouteSoft{
    0%,100%{opacity:.18;stroke-dashoffset:0;}
    50%{opacity:.44;stroke-dashoffset:-22;}
}


/* V12.9 - Fluxo circular nacional: todos os 27 estados disparam para pelo menos um vizinho */
.brasil-map-card .konecta-fluxo-circular-estados{
    pointer-events:none;
}
.brasil-map-card .fluxo-vivo-routes path{
    fill:none !important;
    stroke:#bae6fd !important;
    stroke-width:.95 !important;
    stroke-linecap:round;
    stroke-dasharray:3 12;
    opacity:.18;
    filter:drop-shadow(0 0 4px rgba(56,189,248,.55));
    animation:konectaCircularRoute 6.5s ease-in-out infinite;
}
.brasil-map-card .fluxo-vivo-routes path:nth-child(2n){
    opacity:.24;
    animation-duration:7.8s;
}
.brasil-map-card .fluxo-vivo-routes path:nth-child(3n){
    opacity:.14;
    animation-duration:5.9s;
}
.brasil-map-card .fluxo-vivo-packets circle{
    fill:#ffffff !important;
    stroke:#22d3ee !important;
    stroke-width:2.2 !important;
    opacity:.96;
    filter:
        drop-shadow(0 0 7px rgba(255,255,255,1))
        drop-shadow(0 0 13px rgba(34,211,238,.95));
}
@keyframes konectaCircularRoute{
    0%,100%{stroke-dashoffset:0;opacity:.14;}
    50%{stroke-dashoffset:-34;opacity:.34;}
}
@media (max-width:560px){
    .brasil-map-card .fluxo-vivo-routes path{stroke-width:.75 !important;opacity:.16;}
    .brasil-map-card .fluxo-vivo-packets circle{r:2.4;}
}


/* V12.14 - Sem ponto fantasma e com fluxos funcionando */
.konecta-region-status,
.region-info,
.region-info-inline,
.map-help-pill{
    display:none !important;
}

#konecta-real-brasil-map a,
#konecta-real-brasil-map .estado,
#konecta-real-brasil-map .estado-wrap,
#konecta-real-brasil-map path,
#konecta-real-brasil-map text,
#konecta-real-brasil-map circle{
    cursor:default !important;
}

#konecta-real-brasil-map .estado:hover path,
#konecta-real-brasil-map g:hover path,
#konecta-real-brasil-map path:hover{
    transform:none !important;
}

/* As partículas continuam visíveis e animadas. 
   Como agora têm cx/cy no início da rota, não aparecem mais no canto 0,0. */
#konecta-real-brasil-map .fluxo-vivo-packets,
#konecta-real-brasil-map .konecta-moving-packets,
#konecta-real-brasil-map .konecta-extra-packets{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:none !important;
}

#konecta-real-brasil-map .fluxo-vivo-packets circle,
#konecta-real-brasil-map .konecta-moving-packets circle,
#konecta-real-brasil-map .konecta-extra-packets circle{
    display:inline !important;
    visibility:visible !important;
}

#konecta-real-brasil-map .konecta-all-state-network,
#konecta-real-brasil-map .konecta-fluxo-circular-estados,
#konecta-real-brasil-map .konecta-extra-state-flows,
#konecta-real-brasil-map .konecta-state-routes,
#konecta-real-brasil-map .fluxo-vivo-routes,
#konecta-real-brasil-map .konecta-moving-packets,
#konecta-real-brasil-map .fluxo-vivo-packets,
#konecta-real-brasil-map .konecta-extra-packets{
    pointer-events:none !important;
}


/* V12.15 - Correção dos pontos "ilhas" vazando pela tela */
.brasil-map-card{
    overflow:hidden !important;
    contain:paint !important;
}

.brasil-map-card:before{
    overflow:hidden !important;
}

#konecta-real-brasil-map,
.brasil-map-card .konecta-real-brasil-map{
    overflow:hidden !important;
    clip-path: inset(0 0 0 0) !important;
}

/* Partículas continuam se movendo, mas só dentro do mapa */
#konecta-real-brasil-map .fluxo-vivo-packets,
#konecta-real-brasil-map .konecta-moving-packets,
#konecta-real-brasil-map .konecta-extra-packets{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:none !important;
}

#konecta-real-brasil-map .fluxo-vivo-packets circle,
#konecta-real-brasil-map .konecta-moving-packets circle,
#konecta-real-brasil-map .konecta-extra-packets circle{
    display:inline !important;
    visibility:visible !important;
}

/* Sem clique e sem tooltip */
#konecta-real-brasil-map a,
#konecta-real-brasil-map .estado,
#konecta-real-brasil-map .estado-wrap,
#konecta-real-brasil-map path,
#konecta-real-brasil-map text,
#konecta-real-brasil-map circle{
    cursor:default !important;
}

.konecta-region-status,
.region-info,
.region-info-inline,
.map-help-pill{
    display:none !important;
}


/* V12.16 - Correção cirúrgica do ponto fantasma
   Causa: animateMotion com begin atrasado renderizava a partícula em (0,0).
   Solução: todos os packets iniciam imediatamente na própria rota, mantendo durações diferentes. */
.konecta-region-status,
.region-info,
.region-info-inline,
.map-help-pill{
    display:none !important;
}

#konecta-real-brasil-map a,
#konecta-real-brasil-map .estado,
#konecta-real-brasil-map .estado-wrap,
#konecta-real-brasil-map path,
#konecta-real-brasil-map text,
#konecta-real-brasil-map circle{
    cursor:default !important;
}

#konecta-real-brasil-map .estado:hover path,
#konecta-real-brasil-map g:hover path,
#konecta-real-brasil-map path:hover{
    transform:none !important;
}

/* Mantém as partículas animadas e restritas ao desenho do mapa */
.brasil-map-card{
    overflow:hidden !important;
    contain:paint !important;
}

#konecta-real-brasil-map,
.brasil-map-card .konecta-real-brasil-map{
    overflow:hidden !important;
}

#konecta-real-brasil-map .fluxo-vivo-packets,
#konecta-real-brasil-map .konecta-moving-packets,
#konecta-real-brasil-map .konecta-extra-packets{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:none !important;
    animation:none !important;
}

#konecta-real-brasil-map .fluxo-vivo-packets circle,
#konecta-real-brasil-map .konecta-moving-packets circle,
#konecta-real-brasil-map .konecta-extra-packets circle{
    display:inline !important;
    visibility:visible !important;
}

/* SAVE POINT V12.16+ | Footer premium integrado */
.footer.konecta-premium-footer{
    position:relative;
    overflow:hidden;
    isolation:isolate;
    width:calc(100% - clamp(20px,2vw,36px));
    max-width:none;
    margin:54px auto 32px;
    padding:0;
    border-radius:22px;
    color:#f8fbff;
    background:
        radial-gradient(circle at 88% 18%, rgba(37,99,235,.28), transparent 33%),
        radial-gradient(circle at 72% 82%, rgba(14,165,233,.12), transparent 30%),
        linear-gradient(120deg,#030711 0%,#07101f 42%,#06163a 100%);
    border:1px solid rgba(148,163,184,.18);
    box-shadow:0 18px 38px rgba(2,6,23,.28),0 0 0 1px rgba(255,255,255,.03) inset;
}
.footer.konecta-premium-footer:before,
.footer.konecta-premium-footer:after{
    content:"";
    position:absolute;
    pointer-events:none;
    z-index:-1;
}
.footer.konecta-premium-footer:before{
    inset:0 0 auto auto;
    width:min(560px,42vw);
    height:100%;
    opacity:.34;
    background:
        repeating-radial-gradient(ellipse at 100% 0%, rgba(37,99,235,.72) 0 1px, transparent 1px 8px);
    mask-image:linear-gradient(90deg,transparent,black 42%,black);
}
.footer.konecta-premium-footer:after{
    right:-160px;
    bottom:-220px;
    width:520px;
    height:520px;
    border-radius:50%;
    background:radial-gradient(circle,rgba(37,99,235,.22),transparent 64%);
    filter:blur(10px);
}
.footer-orbital-bg{
    position:absolute;
    inset:auto -90px -150px auto;
    width:460px;
    height:460px;
    border-radius:50%;
    opacity:.18;
    background:repeating-radial-gradient(circle, rgba(56,189,248,.74) 0 1px, transparent 1px 10px);
    transform:rotate(-12deg);
    pointer-events:none;
}
.footer-premium-shell{
    padding-block:58px 0;
}
.footer-premium-main{
    display:grid;
    grid-template-columns:minmax(230px,1.35fr) minmax(145px,.75fr) minmax(230px,1fr) minmax(190px,.86fr) minmax(220px,.95fr) minmax(300px,1.28fr);
    gap:clamp(22px,3.4vw,58px);
    align-items:start;
}
.footer-brand-logo{
    align-items:center;
    gap:16px;
    margin-bottom:22px;
}
.footer-brand-logo .footer-mark{
    width:56px;
    height:66px;
    filter:drop-shadow(0 12px 22px rgba(37,99,235,.32));
}
.footer-word{
    display:grid;
    line-height:1.03;
    letter-spacing:-.6px;
}
.footer-word strong{
    color:#2f7cff;
    font-size:30px;
    display:block;
}
.footer-word span{
    color:#f8fafc;
    font-size:22px;
    font-weight:500;
}
.footer-premium-brand p,
.footer-newsletter p,
.footer-contact p,
.footer-premium-bottom p{
    color:rgba(226,232,240,.82);
    line-height:1.72;
    font-size:15px;
    margin:0;
}
.footer-social{
    display:flex;
    gap:14px;
    margin-top:30px;
}
.footer-social a{
    display:grid;
    place-items:center;
    width:46px;
    height:46px;
    border-radius:50%;
    color:#20a7ff;
    background:rgba(30,64,175,.18);
    border:1px solid rgba(96,165,250,.08);
    box-shadow:0 10px 26px rgba(2,6,23,.24) inset;
    font-weight:950;
    font-size:18px;
    transition:.2s ease;
}
.footer-social a:hover{
    transform:translateY(-2px);
    color:#fff;
    background:linear-gradient(135deg,#0ea5e9,#2563eb);
}
.footer-col,
.footer-newsletter{
    display:grid;
    gap:0;
}
.footer-col h3,
.footer-newsletter h3{
    position:relative;
    color:#fff;
    font-size:18px;
    letter-spacing:-.2px;
    margin:0 0 32px;
    font-weight:950;
}
.footer-col h3:after,
.footer-newsletter h3:after{
    content:"";
    position:absolute;
    left:0;
    bottom:-16px;
    width:35px;
    height:2px;
    border-radius:999px;
    background:linear-gradient(90deg,#38bdf8,#2563eb);
    box-shadow:0 0 16px rgba(56,189,248,.55);
}
.footer-col a,
.footer-contact p{
    display:flex;
    align-items:flex-start;
    gap:11px;
    color:rgba(241,245,249,.82);
    font-size:15px;
    line-height:1.45;
    margin:0 0 17px;
    transition:.2s ease;
}
.footer-col a:before{
    content:"›";
    color:#19b8ff;
    font-size:30px;
    line-height:.56;
    font-weight:900;
    margin-right:2px;
}
.footer-col a span,
.footer-contact p span{
    color:#1998ff;
    width:18px;
    flex:0 0 18px;
    text-align:center;
    font-weight:900;
}
.footer-col a:hover{
    color:#fff;
    transform:translateX(3px);
}
.footer-contact small{
    color:rgba(226,232,240,.82);
    font-size:14px;
}
.footer-news-form{
    display:flex;
    gap:8px;
    margin:26px 0 30px;
}
.footer-news-form input{
    min-width:0;
    width:100%;
    height:50px;
    border-radius:12px;
    border:1px solid rgba(148,163,184,.25);
    background:rgba(2,6,23,.38);
    color:#fff;
    padding:0 16px;
    font:inherit;
    outline:none;
    box-shadow:0 10px 24px rgba(2,6,23,.24) inset;
}
.footer-news-form input::placeholder{
    color:rgba(226,232,240,.62);
}
.footer-news-form input:focus{
    border-color:rgba(56,189,248,.72);
    box-shadow:0 0 0 4px rgba(56,189,248,.12);
}
.footer-news-form button{
    height:50px;
    border-radius:12px;
    padding:0 25px;
    color:#fff;
    font-weight:950;
    background:linear-gradient(135deg,#38bdf8,#2563eb 58%,#1d4ed8);
    box-shadow:0 16px 34px rgba(37,99,235,.33);
}
.footer-data-safe{
    display:flex;
    align-items:center;
    gap:13px;
}
.footer-data-safe>span{
    width:42px;
    height:48px;
    display:grid;
    place-items:center;
    color:#2f7cff;
    font-size:28px;
    filter:drop-shadow(0 0 18px rgba(37,99,235,.45));
}
.footer-data-safe strong{
    color:#fff;
}
.footer-premium-bottom{
    margin-top:42px;
    padding:34px 0 32px;
    border-top:1px solid rgba(226,232,240,.15);
    display:grid;
    grid-template-columns:minmax(260px,1fr) minmax(300px,.9fr) minmax(420px,1.25fr);
    align-items:center;
    gap:28px;
}
.footer-legal{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:18px;
    color:rgba(226,232,240,.62);
}
.footer-legal a{
    color:#1fb6ff;
    font-weight:800;
}
.footer-legal a:hover{
    color:#fff;
}
.footer-seals{
    display:flex;
    justify-content:flex-end;
    gap:34px;
    align-items:center;
}
.footer-seal{
    display:flex;
    align-items:center;
    gap:14px;
    min-width:0;
}
.footer-seal>span{
    width:48px;
    height:58px;
    display:grid;
    place-items:center;
    color:#2f7cff;
    font-size:33px;
    filter:drop-shadow(0 0 18px rgba(37,99,235,.45));
}
.footer-seal p{
    display:grid;
    line-height:1.3;
}
.footer-seal strong{
    color:#fff;
    font-size:15px;
}
.footer-seal small{
    color:rgba(226,232,240,.72);
    font-size:13px;
    margin-top:3px;
}
.iso-seal b{
    width:52px;
    height:52px;
    display:grid;
    place-items:center;
    color:#fff;
    font-size:24px;
    font-weight:1000;
    letter-spacing:-1px;
    border:2px solid rgba(255,255,255,.82);
    border-radius:50%;
    box-shadow:0 0 0 5px rgba(255,255,255,.05) inset;
}
@media (max-width: 1320px){
    .footer-premium-main{grid-template-columns:repeat(3,1fr)}
    .footer-newsletter{grid-column:span 2}
    .footer-premium-bottom{grid-template-columns:1fr;justify-items:center;text-align:center}
    .footer-seals{justify-content:center;flex-wrap:wrap}
}
@media (max-width: 860px){
    .footer.konecta-premium-footer{width:calc(100% - 24px);margin-block:34px 24px;border-radius:18px}
    .footer-premium-shell{padding-block:38px 0;padding-inline:22px}
    .footer-premium-main{grid-template-columns:1fr 1fr;gap:34px 24px}
    .footer-premium-brand,.footer-newsletter{grid-column:1/-1}
    .footer-news-form{flex-direction:column}
    .footer-news-form button{width:100%}
    .footer-premium-bottom{padding-bottom:28px}
    .footer-legal{flex-wrap:wrap;gap:10px 14px}
}
@media (max-width: 560px){
    .footer-premium-main{grid-template-columns:1fr}
    .footer-word strong{font-size:28px}
    .footer-social a{width:42px;height:42px}
    .footer-seals{align-items:flex-start;justify-content:flex-start;text-align:left}
    .footer-seal{width:100%}
}
.footer.konecta-premium-footer .footer-col{
    position:static !important;
    inset:auto !important;
    width:auto !important;
    box-shadow:none !important;
    border:0 !important;
    padding:0 !important;
    background:transparent !important;
    flex-direction:unset !important;
    align-items:unset !important;
}


/* SAVE POINT V12.23 - Logo oficial aprovada aplicada como imagem fiel */
.konecta-brand-mark{
    width:54px;
    height:64px;
    object-fit:contain;
    display:inline-block;
    flex:0 0 auto;
    filter:drop-shadow(0 12px 20px rgba(37,99,235,.22));
}
.brand.center .konecta-brand-mark{
    width:72px;
    height:82px;
}
.footer-brand-logo .konecta-brand-mark,
.konecta-brand-mark.footer-mark-img{
    width:56px;
    height:66px;
    filter:drop-shadow(0 12px 22px rgba(37,99,235,.32));
}
@media(max-width:680px){
    .konecta-brand-mark{width:44px;height:52px;}
    .brand.center .konecta-brand-mark{width:60px;height:68px;}
}


/* SAVE POINT V12.25 | Correção responsiva do footer premium
   Ajuste criado após validação visual: coluna "Receba novidades" e selos ISO/Segurança
   não podem ser cortados em telas com escala/zoom do Windows ou larguras intermediárias. */
.footer.konecta-premium-footer{
    box-sizing:border-box;
}
.footer.konecta-premium-footer *,
.footer.konecta-premium-footer *::before,
.footer.konecta-premium-footer *::after{
    box-sizing:border-box;
}
.footer-premium-shell{
    width:100%;
    max-width:1760px;
    margin-inline:auto;
    padding-inline:clamp(26px,4.4vw,82px);
}
.footer-premium-main{
    grid-template-columns:
        minmax(210px,1.18fr)
        minmax(130px,.68fr)
        minmax(205px,.92fr)
        minmax(170px,.78fr)
        minmax(210px,.90fr)
        minmax(320px,1.12fr);
    gap:clamp(20px,2.6vw,48px);
}
.footer-col,
.footer-contact,
.footer-newsletter,
.footer-premium-brand{
    min-width:0;
}
.footer-col a,
.footer-contact p,
.footer-newsletter p{
    max-width:100%;
    overflow-wrap:anywhere;
}
.footer-news-form{
    width:100%;
    max-width:100%;
}
.footer-news-form input{
    flex:1 1 0;
    min-width:0;
}
.footer-news-form button{
    flex:0 0 auto;
    white-space:nowrap;
}
.footer-premium-bottom{
    grid-template-columns:minmax(230px,1fr) minmax(280px,.8fr) minmax(360px,1fr);
}
.footer-seals{
    min-width:0;
    flex-wrap:wrap;
    row-gap:18px;
}
.footer-seal{
    min-width:0;
}
.iso-seal{
    flex:0 1 230px;
}

/* Telas largas com escala do sistema operacional podem ter viewport CSS menor.
   Aqui o footer vira 3 colunas antes de qualquer conteúdo escapar pela direita. */
@media (max-width: 1680px){
    .footer-premium-main{
        grid-template-columns:1.2fr 1fr 1fr;
        gap:38px clamp(26px,4vw,56px);
    }
    .footer-premium-brand{
        grid-column:1 / 2;
    }
    .footer-newsletter{
        grid-column:2 / 4;
    }
    .footer-news-form{
        max-width:520px;
    }
    .footer-premium-bottom{
        grid-template-columns:1fr;
        justify-items:center;
        text-align:center;
        gap:24px;
    }
    .footer-seals{
        justify-content:center;
    }
}

/* Tablet e notebooks menores */
@media (max-width: 1040px){
    .footer-premium-main{
        grid-template-columns:1fr 1fr;
        gap:34px 28px;
    }
    .footer-premium-brand,
    .footer-newsletter{
        grid-column:1 / -1;
    }
    .footer-news-form{
        max-width:100%;
    }
}

/* Mobile */
@media (max-width: 640px){
    .footer.konecta-premium-footer{
        width:calc(100% - 18px);
        margin-block:30px 20px;
        border-radius:18px;
    }
    .footer-premium-shell{
        padding-inline:20px;
        padding-block:34px 0;
    }
    .footer-premium-main{
        grid-template-columns:1fr;
        gap:30px;
    }
    .footer-newsletter{
        grid-column:auto;
    }
    .footer-news-form{
        flex-direction:column;
        gap:10px;
    }
    .footer-news-form button{
        width:100%;
    }
    .footer-premium-bottom{
        margin-top:34px;
        padding-block:28px;
    }
    .footer-seals{
        width:100%;
        justify-content:flex-start;
        text-align:left;
    }
    .footer-seal,
    .iso-seal{
        width:100%;
        flex-basis:100%;
    }
}


/* SAVE POINT V12.26 | Footer premium acompanha telas grandes como o Hero
   Correção: em monitores largos o rodapé estava ficando comprimido no centro.
   Agora o footer usa largura ampla, grid de 6 colunas em telas grandes e quebra
   apenas quando realmente necessário. */
.footer.konecta-premium-footer{
    width:min(100% - clamp(24px,2.2vw,56px), 1960px) !important;
    max-width:1960px !important;
    margin-inline:auto !important;
}
.footer.konecta-premium-footer .container,
.footer-premium-shell{
    width:100% !important;
    max-width:none !important;
}
.footer-premium-shell{
    padding-inline:clamp(44px,5.2vw,118px) !important;
}
.footer-premium-main{
    grid-template-columns:
        minmax(250px,1.26fr)
        minmax(150px,.70fr)
        minmax(245px,.98fr)
        minmax(210px,.88fr)
        minmax(230px,.92fr)
        minmax(340px,1.10fr) !important;
    gap:clamp(28px,3.2vw,72px) !important;
    align-items:start !important;
}
.footer-newsletter{
    grid-column:auto !important;
}
.footer-news-form{
    max-width:none !important;
}
.footer-premium-bottom{
    grid-template-columns:minmax(300px,1fr) minmax(340px,.85fr) minmax(430px,1.15fr) !important;
    justify-items:stretch !important;
    text-align:left !important;
}
.footer-seals{
    justify-content:flex-end !important;
}

/* Larguras intermediárias: mantém 3 colunas, mas sem esmagar conteúdo. */
@media (max-width: 1420px){
    .footer-premium-shell{
        padding-inline:clamp(30px,4vw,64px) !important;
    }
    .footer-premium-main{
        grid-template-columns:1.25fr 1fr 1fr !important;
        gap:38px 46px !important;
    }
    .footer-newsletter{
        grid-column:2 / 4 !important;
    }
    .footer-premium-bottom{
        grid-template-columns:1fr !important;
        justify-items:center !important;
        text-align:center !important;
        gap:24px !important;
    }
    .footer-seals{
        justify-content:center !important;
    }
}

/* Tablet */
@media (max-width: 1040px){
    .footer-premium-main{
        grid-template-columns:1fr 1fr !important;
        gap:34px 28px !important;
    }
    .footer-premium-brand,
    .footer-newsletter{
        grid-column:1 / -1 !important;
    }
}

/* Mobile */
@media (max-width: 640px){
    .footer.konecta-premium-footer{
        width:calc(100% - 18px) !important;
    }
    .footer-premium-shell{
        padding-inline:20px !important;
    }
    .footer-premium-main{
        grid-template-columns:1fr !important;
        gap:30px !important;
    }
    .footer-newsletter{
        grid-column:auto !important;
    }
}


/* SAVE POINT V12.27 | Footer full width real
   Correção solicitada: o rodapé não deve ficar centralizado como um card.
   Ele deve se estender por toda a largura da tela, igual uma faixa final do site. */
.footer.konecta-premium-footer{
    width:100vw !important;
    max-width:none !important;
    margin-left:calc(50% - 50vw) !important;
    margin-right:calc(50% - 50vw) !important;
    margin-top:54px !important;
    margin-bottom:0 !important;
    border-radius:0 !important;
    border-left:0 !important;
    border-right:0 !important;
}

/* O conteúdo interno continua alinhado com o restante da landing,
   mas o fundo do footer ocupa a tela inteira. */
.footer.konecta-premium-footer .footer-premium-shell{
    width:min(100% - clamp(32px,5vw,120px), 1760px) !important;
    max-width:1760px !important;
    margin-inline:auto !important;
    padding-inline:0 !important;
}

/* Em desktop grande, o conteúdo volta para seis colunas elegantes. */
.footer.konecta-premium-footer .footer-premium-main{
    grid-template-columns:
        minmax(250px,1.30fr)
        minmax(150px,.70fr)
        minmax(245px,1fr)
        minmax(210px,.88fr)
        minmax(230px,.92fr)
        minmax(340px,1.12fr) !important;
    gap:clamp(30px,3.4vw,78px) !important;
}

.footer.konecta-premium-footer .footer-newsletter{
    grid-column:auto !important;
}

.footer.konecta-premium-footer .footer-premium-bottom{
    grid-template-columns:minmax(300px,1fr) minmax(340px,.85fr) minmax(430px,1.15fr) !important;
    justify-items:stretch !important;
    text-align:left !important;
}

.footer.konecta-premium-footer .footer-seals{
    justify-content:flex-end !important;
}

/* Larguras intermediárias */
@media (max-width: 1420px){
    .footer.konecta-premium-footer .footer-premium-shell{
        width:min(100% - 48px, 1180px) !important;
    }
    .footer.konecta-premium-footer .footer-premium-main{
        grid-template-columns:1.25fr 1fr 1fr !important;
        gap:38px 46px !important;
    }
    .footer.konecta-premium-footer .footer-newsletter{
        grid-column:2 / 4 !important;
    }
    .footer.konecta-premium-footer .footer-premium-bottom{
        grid-template-columns:1fr !important;
        justify-items:center !important;
        text-align:center !important;
        gap:24px !important;
    }
    .footer.konecta-premium-footer .footer-seals{
        justify-content:center !important;
    }
}

/* Tablet */
@media (max-width: 1040px){
    .footer.konecta-premium-footer .footer-premium-shell{
        width:calc(100% - 36px) !important;
    }
    .footer.konecta-premium-footer .footer-premium-main{
        grid-template-columns:1fr 1fr !important;
        gap:34px 28px !important;
    }
    .footer.konecta-premium-footer .footer-premium-brand,
    .footer.konecta-premium-footer .footer-newsletter{
        grid-column:1 / -1 !important;
    }
}

/* Mobile */
@media (max-width: 640px){
    .footer.konecta-premium-footer{
        margin-top:34px !important;
    }
    .footer.konecta-premium-footer .footer-premium-shell{
        width:calc(100% - 32px) !important;
    }
    .footer.konecta-premium-footer .footer-premium-main{
        grid-template-columns:1fr !important;
        gap:30px !important;
    }
    .footer.konecta-premium-footer .footer-newsletter{
        grid-column:auto !important;
    }
}


/* SAVE POINT V12.28 | Footer full width com tipografia fluida
   Correção: manter o footer de ponta a ponta, mas reduzir letras, espaçamentos
   e ícones em telas menores para evitar corte lateral. */
.footer.konecta-premium-footer{
    width:100vw !important;
    max-width:none !important;
    margin-left:calc(50% - 50vw) !important;
    margin-right:calc(50% - 50vw) !important;
    margin-bottom:0 !important;
    border-radius:0 !important;
    overflow:hidden !important;
}

.footer.konecta-premium-footer .footer-premium-shell{
    width:min(100% - clamp(24px,4vw,96px), 1760px) !important;
    max-width:1760px !important;
    margin-inline:auto !important;
    padding-inline:0 !important;
    padding-block:clamp(36px,4vw,58px) 0 !important;
}

.footer.konecta-premium-footer .footer-premium-main{
    grid-template-columns:
        minmax(220px,1.25fr)
        minmax(130px,.68fr)
        minmax(210px,.95fr)
        minmax(180px,.82fr)
        minmax(210px,.90fr)
        minmax(300px,1.08fr) !important;
    gap:clamp(18px,2.5vw,58px) !important;
}

.footer.konecta-premium-footer .footer-word strong{
    font-size:clamp(22px,1.55vw,30px) !important;
}
.footer.konecta-premium-footer .footer-word span{
    font-size:clamp(17px,1.2vw,22px) !important;
}
.footer.konecta-premium-footer .footer-col h3,
.footer.konecta-premium-footer .footer-newsletter h3{
    font-size:clamp(15px,1vw,18px) !important;
    margin-bottom:clamp(22px,2vw,32px) !important;
}
.footer.konecta-premium-footer .footer-premium-brand p,
.footer.konecta-premium-footer .footer-newsletter p,
.footer.konecta-premium-footer .footer-contact p,
.footer.konecta-premium-footer .footer-col a,
.footer.konecta-premium-footer .footer-premium-bottom p{
    font-size:clamp(12.5px,.86vw,15px) !important;
    line-height:1.55 !important;
}
.footer.konecta-premium-footer .footer-col a,
.footer.konecta-premium-footer .footer-contact p{
    gap:clamp(7px,.75vw,11px) !important;
    margin-bottom:clamp(10px,1.05vw,17px) !important;
}
.footer.konecta-premium-footer .footer-col a:before{
    font-size:clamp(20px,1.7vw,30px) !important;
}
.footer.konecta-premium-footer .footer-social{
    gap:clamp(8px,.9vw,14px) !important;
    margin-top:clamp(18px,2vw,30px) !important;
}
.footer.konecta-premium-footer .footer-social a{
    width:clamp(34px,2.7vw,46px) !important;
    height:clamp(34px,2.7vw,46px) !important;
    font-size:clamp(14px,1vw,18px) !important;
}
.footer.konecta-premium-footer .konecta-brand-mark,
.footer.konecta-premium-footer .footer-brand-logo .konecta-brand-mark,
.footer.konecta-premium-footer .konecta-brand-mark.footer-mark-img{
    width:clamp(42px,3.4vw,56px) !important;
    height:clamp(50px,4vw,66px) !important;
}
.footer.konecta-premium-footer .footer-news-form{
    gap:8px !important;
    margin:clamp(18px,2vw,26px) 0 clamp(20px,2vw,30px) !important;
}
.footer.konecta-premium-footer .footer-news-form input,
.footer.konecta-premium-footer .footer-news-form button{
    height:clamp(42px,3vw,50px) !important;
    font-size:clamp(12.5px,.86vw,15px) !important;
}
.footer.konecta-premium-footer .footer-news-form button{
    padding-inline:clamp(16px,1.6vw,25px) !important;
}
.footer.konecta-premium-footer .footer-premium-bottom{
    grid-template-columns:minmax(260px,1fr) minmax(300px,.85fr) minmax(360px,1.08fr) !important;
    gap:clamp(18px,2.2vw,28px) !important;
    padding:clamp(24px,2.8vw,34px) 0 clamp(24px,2.8vw,32px) !important;
}
.footer.konecta-premium-footer .footer-legal{
    gap:clamp(9px,1.2vw,18px) !important;
    flex-wrap:wrap !important;
}
.footer.konecta-premium-footer .footer-legal a{
    font-size:clamp(12.5px,.86vw,15px) !important;
}
.footer.konecta-premium-footer .footer-seals{
    gap:clamp(18px,2.2vw,34px) !important;
    flex-wrap:wrap !important;
}
.footer.konecta-premium-footer .footer-seal>span{
    width:clamp(36px,3vw,48px) !important;
    height:clamp(42px,3.5vw,58px) !important;
    font-size:clamp(24px,2vw,33px) !important;
}
.footer.konecta-premium-footer .iso-seal b{
    width:clamp(42px,3.1vw,52px) !important;
    height:clamp(42px,3.1vw,52px) !important;
    font-size:clamp(18px,1.55vw,24px) !important;
}

/* Notebook e telas com zoom: 3 colunas com letras menores, sem corte. */
@media (max-width: 1420px){
    .footer.konecta-premium-footer .footer-premium-shell{
        width:calc(100% - 40px) !important;
    }
    .footer.konecta-premium-footer .footer-premium-main{
        grid-template-columns:1.15fr .95fr 1.1fr !important;
        gap:34px 34px !important;
    }
    .footer.konecta-premium-footer .footer-premium-brand{
        grid-column:auto !important;
    }
    .footer.konecta-premium-footer .footer-newsletter{
        grid-column:2 / 4 !important;
    }
    .footer.konecta-premium-footer .footer-premium-bottom{
        grid-template-columns:1fr !important;
        justify-items:center !important;
        text-align:center !important;
    }
    .footer.konecta-premium-footer .footer-seals{
        justify-content:center !important;
    }
}

/* Tablet: 2 colunas */
@media (max-width: 980px){
    .footer.konecta-premium-footer .footer-premium-shell{
        width:calc(100% - 32px) !important;
    }
    .footer.konecta-premium-footer .footer-premium-main{
        grid-template-columns:1fr 1fr !important;
        gap:30px 24px !important;
    }
    .footer.konecta-premium-footer .footer-premium-brand,
    .footer.konecta-premium-footer .footer-newsletter{
        grid-column:1 / -1 !important;
    }
    .footer.konecta-premium-footer .footer-news-form{
        max-width:100% !important;
    }
}

/* Mobile: 1 coluna */
@media (max-width: 620px){
    .footer.konecta-premium-footer .footer-premium-shell{
        width:calc(100% - 28px) !important;
        padding-block:32px 0 !important;
    }
    .footer.konecta-premium-footer .footer-premium-main{
        grid-template-columns:1fr !important;
        gap:28px !important;
    }
    .footer.konecta-premium-footer .footer-newsletter{
        grid-column:auto !important;
    }
    .footer.konecta-premium-footer .footer-news-form{
        flex-direction:column !important;
    }
    .footer.konecta-premium-footer .footer-news-form button{
        width:100% !important;
    }
    .footer.konecta-premium-footer .footer-seals{
        justify-content:flex-start !important;
        text-align:left !important;
    }
}


/* SAVE POINT V12.29 | Ajustes Mobile do Header, CTA e Menu
   Correção após teste real em celular:
   - botão "Solicitar acesso à plataforma" não estoura mais o cabeçalho;
   - menu mobile não cobre a tela como bloco largo;
   - hero ganha respiro e tipografia mais adequada;
   - header fica compacto, fixo e utilizável. */

@media (max-width: 760px){

    body{
        overflow-x:hidden !important;
    }

    .topbar,
    .header,
    .site-header,
    .navbar,
    .nav-wrap{
        max-width:100vw !important;
        overflow:hidden !important;
    }

    header .container,
    .topbar .container,
    .site-header .container,
    .nav-wrap,
    .navbar .container{
        width:100% !important;
        max-width:100% !important;
        padding-inline:14px !important;
        display:flex !important;
        align-items:center !important;
        justify-content:space-between !important;
        gap:10px !important;
        box-sizing:border-box !important;
    }

    .brand,
    .brand.center,
    .logo,
    .site-logo{
        min-width:0 !important;
        flex:1 1 auto !important;
        max-width:58vw !important;
    }

    .brand .konecta-brand-mark,
    .konecta-brand-mark{
        width:42px !important;
        height:48px !important;
        flex:0 0 auto !important;
    }

    .brand-word,
    .brand-text,
    .footer-word,
    .brand span,
    .brand strong{
        min-width:0 !important;
    }

    .brand-word strong,
    .brand-text strong,
    .brand strong{
        font-size:clamp(20px,5.5vw,26px) !important;
        line-height:1 !important;
        white-space:nowrap !important;
    }

    .brand-word span,
    .brand-text span,
    .brand span{
        font-size:clamp(16px,4.6vw,21px) !important;
        line-height:1 !important;
        white-space:nowrap !important;
    }

    /* CTA do topo: evita sair do escopo no mobile */
    .header-actions,
    .nav-actions,
    .topbar-actions{
        flex:0 0 auto !important;
        display:flex !important;
        align-items:center !important;
        gap:8px !important;
        min-width:0 !important;
    }

    .header-actions .btn,
    .nav-actions .btn,
    .topbar-actions .btn,
    .btn-access,
    .btn-header-access,
    .top-access,
    a[href*="acesso-plataforma"],
    a[href*="acesso à plataforma"],
    a[href="#contato"].btn,
    a[href="#acesso"].btn{
        max-width:132px !important;
        min-width:0 !important;
        padding:9px 14px !important;
        border-radius:999px !important;
        font-size:0 !important;
        line-height:1 !important;
        white-space:nowrap !important;
        overflow:hidden !important;
        text-overflow:clip !important;
    }

    .header-actions .btn::after,
    .nav-actions .btn::after,
    .topbar-actions .btn::after,
    .btn-access::after,
    .btn-header-access::after,
    .top-access::after,
    a[href*="acesso-plataforma"]::after,
    a[href*="acesso à plataforma"]::after,
    a[href="#contato"].btn::after,
    a[href="#acesso"].btn::after{
        content:"Acessar plataforma";
        font-size:13px !important;
        font-weight:900 !important;
    }

    .menu-toggle,
    .hamburger,
    .nav-toggle,
    button[aria-label*="menu" i]{
        flex:0 0 42px !important;
        width:42px !important;
        height:42px !important;
        display:grid !important;
        place-items:center !important;
        padding:0 !important;
        margin:0 !important;
        border-radius:14px !important;
        z-index:1002 !important;
    }

    /* Menu mobile estilo drawer compacto */
    .nav-menu,
    .menu,
    .main-nav,
    .mobile-menu{
        max-width:min(86vw,320px) !important;
    }

    .nav-menu.is-open,
    .nav-menu.active,
    .menu.is-open,
    .menu.active,
    .main-nav.is-open,
    .main-nav.active,
    .mobile-menu.is-open,
    .mobile-menu.active,
    body.menu-open .nav-menu,
    body.nav-open .nav-menu{
        position:fixed !important;
        top:74px !important;
        right:12px !important;
        left:auto !important;
        width:min(86vw,320px) !important;
        max-width:320px !important;
        height:auto !important;
        max-height:calc(100vh - 92px) !important;
        overflow:auto !important;
        padding:18px !important;
        border-radius:22px !important;
        background:rgba(2,8,23,.96) !important;
        border:1px solid rgba(148,163,184,.22) !important;
        box-shadow:0 22px 60px rgba(2,6,23,.42) !important;
        backdrop-filter:blur(16px) !important;
        display:flex !important;
        flex-direction:column !important;
        gap:10px !important;
        z-index:1000 !important;
    }

    .nav-menu a,
    .menu a,
    .main-nav a,
    .mobile-menu a{
        font-size:15px !important;
        line-height:1.2 !important;
        padding:12px 14px !important;
        border-radius:14px !important;
        white-space:normal !important;
    }

    .nav-menu a:hover,
    .menu a:hover,
    .main-nav a:hover,
    .mobile-menu a:hover{
        background:rgba(59,130,246,.16) !important;
    }

    /* Hero mobile com menos quebra visual */
    .hero,
    .hero-section,
    .hero-premium,
    section[id="home"]{
        overflow:hidden !important;
    }

    .hero .container,
    .hero-section .container,
    .hero-premium .container{
        padding-inline:22px !important;
        max-width:100% !important;
    }

    .hero h1,
    .hero-title,
    .hero-premium h1,
    section[id="home"] h1{
        font-size:clamp(39px,10.6vw,52px) !important;
        line-height:1.05 !important;
        letter-spacing:-1.6px !important;
        max-width:100% !important;
    }

    .hero p,
    .hero-subtitle,
    .hero-premium p,
    section[id="home"] p{
        font-size:clamp(16px,4.6vw,20px) !important;
        line-height:1.58 !important;
        max-width:100% !important;
    }

    .hero-actions,
    .hero-buttons,
    .cta-row{
        width:100% !important;
        display:grid !important;
        grid-template-columns:1fr !important;
        gap:12px !important;
    }

    .hero-actions .btn,
    .hero-buttons .btn,
    .cta-row .btn{
        width:100% !important;
        max-width:100% !important;
        justify-content:center !important;
        font-size:15px !important;
        padding:15px 18px !important;
    }

    .hero-checks,
    .hero-badges,
    .trust-list{
        width:100% !important;
        display:grid !important;
        grid-template-columns:1fr !important;
        gap:12px !important;
    }
}

@media (max-width: 420px){
    header .container,
    .topbar .container,
    .site-header .container,
    .nav-wrap,
    .navbar .container{
        padding-inline:10px !important;
        gap:7px !important;
    }

    .brand,
    .brand.center,
    .logo,
    .site-logo{
        max-width:54vw !important;
    }

    .brand .konecta-brand-mark,
    .konecta-brand-mark{
        width:38px !important;
        height:44px !important;
    }

    .brand-word strong,
    .brand-text strong,
    .brand strong{
        font-size:20px !important;
    }

    .brand-word span,
    .brand-text span,
    .brand span{
        font-size:17px !important;
    }

    .header-actions .btn,
    .nav-actions .btn,
    .topbar-actions .btn,
    .btn-access,
    .btn-header-access,
    .top-access,
    a[href*="acesso-plataforma"],
    a[href*="acesso à plataforma"],
    a[href="#contato"].btn,
    a[href="#acesso"].btn{
        max-width:92px !important;
        padding:9px 12px !important;
    }

    .header-actions .btn::after,
    .nav-actions .btn::after,
    .topbar-actions .btn::after,
    .btn-access::after,
    .btn-header-access::after,
    .top-access::after,
    a[href*="acesso-plataforma"]::after,
    a[href*="acesso à plataforma"]::after,
    a[href="#contato"].btn::after,
    a[href="#acesso"].btn::after{
        content:"Acessar plataforma";
        font-size:12px !important;
    }

    .menu-toggle,
    .hamburger,
    .nav-toggle,
    button[aria-label*="menu" i]{
        width:38px !important;
        height:38px !important;
        flex-basis:38px !important;
    }

    .hero h1,
    .hero-title,
    .hero-premium h1,
    section[id="home"] h1{
        font-size:clamp(34px,10.2vw,44px) !important;
    }
}


/* SAVE POINT V12.30 | Correção do CTA mobile
   Ajuste após validação real:
   - remove o botão duplicado no topo mobile;
   - troca antiga removida: topo mobile usa "Acessar plataforma";
   - mantém apenas logo + Solicitar + menu hambúrguer;
   - evita sobreposição do texto da marca com botões. */

@media (max-width: 760px){

    /* Some o acesso do topo no mobile para não duplicar CTA.
       O acesso continua disponível no botão principal do Hero/menu. */
    header a[href*="portal" i],
    header a[href*="login" i],
    header a[href*="cliente" i],
    .topbar a[href*="portal" i],
    .topbar a[href*="login" i],
    .topbar a[href*="cliente" i],
    .site-header a[href*="portal" i],
    .site-header a[href*="login" i],
    .site-header a[href*="cliente" i],
    .nav-actions a[href*="portal" i],
    .nav-actions a[href*="login" i],
    .nav-actions a[href*="cliente" i],
    .header-actions a[href*="portal" i],
    .header-actions a[href*="login" i],
    .header-actions a[href*="cliente" i]{
        display:none !important;
    }

    /* Header mobile: logo + CTA + menu */
    header .container,
    .topbar .container,
    .site-header .container,
    .nav-wrap,
    .navbar .container{
        display:grid !important;
        grid-template-columns:minmax(0,1fr) auto auto !important;
        align-items:center !important;
        gap:10px !important;
    }

    .brand,
    .brand.center,
    .logo,
    .site-logo{
        max-width:none !important;
        width:100% !important;
        min-width:0 !important;
        overflow:hidden !important;
    }

    .brand-word,
    .brand-text{
        min-width:0 !important;
        overflow:hidden !important;
    }

    .brand-word strong,
    .brand-text strong,
    .brand strong{
        font-size:clamp(19px,5vw,24px) !important;
        white-space:nowrap !important;
    }

    .brand-word span,
    .brand-text span,
    .brand span{
        font-size:clamp(17px,4.8vw,23px) !important;
        white-space:nowrap !important;
    }

    /* CTA de acesso à plataforma no topo mobile */
    header a[href*="acesso-plataforma" i],
    header a[href*="acesso à plataforma" i],
    header a[href="#contato"].btn,
    header a[href="#acesso"].btn,
    .topbar a[href*="acesso-plataforma" i],
    .topbar a[href*="acesso à plataforma" i],
    .site-header a[href*="acesso-plataforma" i],
    .site-header a[href*="acesso à plataforma" i],
    .nav-actions a[href*="acesso-plataforma" i],
    .nav-actions a[href*="acesso à plataforma" i],
    .header-actions a[href*="acesso-plataforma" i],
    .header-actions a[href*="acesso à plataforma" i]{
        display:inline-flex !important;
        align-items:center !important;
        justify-content:center !important;
        width:auto !important;
        max-width:116px !important;
        min-width:92px !important;
        height:46px !important;
        padding:0 18px !important;
        border-radius:999px !important;
        font-size:0 !important;
        line-height:1 !important;
        white-space:nowrap !important;
        overflow:hidden !important;
        flex:0 0 auto !important;
    }

    header a[href*="acesso-plataforma" i]::after,
    header a[href*="acesso à plataforma" i]::after,
    header a[href="#contato"].btn::after,
    header a[href="#acesso"].btn::after,
    .topbar a[href*="acesso-plataforma" i]::after,
    .topbar a[href*="acesso à plataforma" i]::after,
    .site-header a[href*="acesso-plataforma" i]::after,
    .site-header a[href*="acesso à plataforma" i]::after,
    .nav-actions a[href*="acesso-plataforma" i]::after,
    .nav-actions a[href*="acesso à plataforma" i]::after,
    .header-actions a[href*="acesso-plataforma" i]::after,
    .header-actions a[href*="acesso à plataforma" i]::after{
        content:"Solicitar" !important;
        font-size:13px !important;
        font-weight:950 !important;
        letter-spacing:-.2px !important;
    }

    .menu-toggle,
    .hamburger,
    .nav-toggle,
    button[aria-label*="menu" i]{
        width:46px !important;
        height:46px !important;
        flex:0 0 46px !important;
        border-radius:14px !important;
    }
}

@media (max-width: 420px){
    header .container,
    .topbar .container,
    .site-header .container,
    .nav-wrap,
    .navbar .container{
        grid-template-columns:minmax(0,1fr) auto auto !important;
        gap:8px !important;
        padding-inline:10px !important;
    }

    .brand .konecta-brand-mark,
    .konecta-brand-mark{
        width:36px !important;
        height:42px !important;
    }

    .brand-word strong,
    .brand-text strong,
    .brand strong{
        font-size:18px !important;
    }

    .brand-word span,
    .brand-text span,
    .brand span{
        font-size:16px !important;
    }

    header a[href*="acesso-plataforma" i],
    header a[href*="acesso à plataforma" i],
    header a[href="#contato"].btn,
    header a[href="#acesso"].btn,
    .topbar a[href*="acesso-plataforma" i],
    .topbar a[href*="acesso à plataforma" i],
    .site-header a[href*="acesso-plataforma" i],
    .site-header a[href*="acesso à plataforma" i],
    .nav-actions a[href*="acesso-plataforma" i],
    .nav-actions a[href*="acesso à plataforma" i],
    .header-actions a[href*="acesso-plataforma" i],
    .header-actions a[href*="acesso à plataforma" i]{
        min-width:84px !important;
        max-width:94px !important;
        height:42px !important;
        padding:0 12px !important;
    }

    header a[href*="acesso-plataforma" i]::after,
    header a[href*="acesso à plataforma" i]::after,
    header a[href="#contato"].btn::after,
    header a[href="#acesso"].btn::after,
    .topbar a[href*="acesso-plataforma" i]::after,
    .topbar a[href*="acesso à plataforma" i]::after,
    .site-header a[href*="acesso-plataforma" i]::after,
    .site-header a[href*="acesso à plataforma" i]::after,
    .nav-actions a[href*="acesso-plataforma" i]::after,
    .nav-actions a[href*="acesso à plataforma" i]::after,
    .header-actions a[href*="acesso-plataforma" i]::after,
    .header-actions a[href*="acesso à plataforma" i]::after{
        content:"Solicitar" !important;
        font-size:12px !important;
    }

    .menu-toggle,
    .hamburger,
    .nav-toggle,
    button[aria-label*="menu" i]{
        width:42px !important;
        height:42px !important;
        flex-basis:42px !important;
    }
}


/* SAVE POINT V12.32 | Correção definitiva do texto "Acessar plataforma" no mobile
   Validação real: o botão de acesso estava aparecendo com nomenclatura antiga.
   Agora o header mobile fica: Logo + Acessar + Solicitar + Menu.
   O botão "Acessar plataforma" é abreviado visualmente para "Acessar" no mobile
   para caber sem estourar a largura. */

@media (max-width: 760px){

    /* Reativa o acesso no topo mobile e força nome correto */
    header a[href*="acesso" i],
    header a[href*="portal" i],
    header a[href*="login" i],
    header a[href*="cliente" i],
    .topbar a[href*="acesso" i],
    .topbar a[href*="portal" i],
    .topbar a[href*="login" i],
    .topbar a[href*="cliente" i],
    .site-header a[href*="acesso" i],
    .site-header a[href*="portal" i],
    .site-header a[href*="login" i],
    .site-header a[href*="cliente" i],
    .nav-actions a[href*="acesso" i],
    .nav-actions a[href*="portal" i],
    .nav-actions a[href*="login" i],
    .nav-actions a[href*="cliente" i],
    .header-actions a[href*="acesso" i],
    .header-actions a[href*="portal" i],
    .header-actions a[href*="login" i],
    .header-actions a[href*="cliente" i]{
        display:inline-flex !important;
        align-items:center !important;
        justify-content:center !important;
        width:auto !important;
        min-width:88px !important;
        max-width:104px !important;
        height:46px !important;
        padding:0 14px !important;
        border-radius:999px !important;
        font-size:0 !important;
        line-height:1 !important;
        white-space:nowrap !important;
        overflow:hidden !important;
        flex:0 0 auto !important;
    }

    header a[href*="acesso" i]::after,
    header a[href*="portal" i]::after,
    header a[href*="login" i]::after,
    header a[href*="cliente" i]::after,
    .topbar a[href*="acesso" i]::after,
    .topbar a[href*="portal" i]::after,
    .topbar a[href*="login" i]::after,
    .topbar a[href*="cliente" i]::after,
    .site-header a[href*="acesso" i]::after,
    .site-header a[href*="portal" i]::after,
    .site-header a[href*="login" i]::after,
    .site-header a[href*="cliente" i]::after,
    .nav-actions a[href*="acesso" i]::after,
    .nav-actions a[href*="portal" i]::after,
    .nav-actions a[href*="login" i]::after,
    .nav-actions a[href*="cliente" i]::after,
    .header-actions a[href*="acesso" i]::after,
    .header-actions a[href*="portal" i]::after,
    .header-actions a[href*="login" i]::after,
    .header-actions a[href*="cliente" i]::after{
        content:"Acessar" !important;
        font-size:13px !important;
        font-weight:950 !important;
        letter-spacing:-.2px !important;
    }

    /* Acesso à plataforma continua como Solicitar */
    header a[href*="acesso-plataforma" i],
    header a[href*="acesso à plataforma" i],
    header a[href="#contato"].btn,
    header a[href="#acesso"].btn,
    .topbar a[href*="acesso-plataforma" i],
    .topbar a[href*="acesso à plataforma" i],
    .site-header a[href*="acesso-plataforma" i],
    .site-header a[href*="acesso à plataforma" i],
    .nav-actions a[href*="acesso-plataforma" i],
    .nav-actions a[href*="acesso à plataforma" i],
    .header-actions a[href*="acesso-plataforma" i],
    .header-actions a[href*="acesso à plataforma" i]{
        display:inline-flex !important;
        align-items:center !important;
        justify-content:center !important;
        width:auto !important;
        min-width:88px !important;
        max-width:104px !important;
        height:46px !important;
        padding:0 14px !important;
        border-radius:999px !important;
        font-size:0 !important;
        line-height:1 !important;
        white-space:nowrap !important;
        overflow:hidden !important;
        flex:0 0 auto !important;
    }

    header a[href*="acesso-plataforma" i]::after,
    header a[href*="acesso à plataforma" i]::after,
    header a[href="#contato"].btn::after,
    header a[href="#acesso"].btn::after,
    .topbar a[href*="acesso-plataforma" i]::after,
    .topbar a[href*="acesso à plataforma" i]::after,
    .site-header a[href*="acesso-plataforma" i]::after,
    .site-header a[href*="acesso à plataforma" i]::after,
    .nav-actions a[href*="acesso-plataforma" i]::after,
    .nav-actions a[href*="acesso à plataforma" i]::after,
    .header-actions a[href*="acesso-plataforma" i]::after,
    .header-actions a[href*="acesso à plataforma" i]::after{
        content:"Solicitar" !important;
        font-size:13px !important;
        font-weight:950 !important;
        letter-spacing:-.2px !important;
    }

    /* Header com 4 itens: marca + acesso + solicitar + menu */
    header .container,
    .topbar .container,
    .site-header .container,
    .nav-wrap,
    .navbar .container{
        display:grid !important;
        grid-template-columns:minmax(0,1fr) auto auto auto !important;
        align-items:center !important;
        gap:8px !important;
        padding-inline:10px !important;
    }

    .brand,
    .brand.center,
    .logo,
    .site-logo{
        max-width:none !important;
        min-width:0 !important;
        overflow:hidden !important;
    }

    .brand .konecta-brand-mark,
    .konecta-brand-mark{
        width:38px !important;
        height:44px !important;
    }

    .brand-word strong,
    .brand-text strong,
    .brand strong{
        font-size:clamp(18px,4.6vw,23px) !important;
        white-space:nowrap !important;
    }

    .brand-word span,
    .brand-text span,
    .brand span{
        font-size:clamp(16px,4.3vw,21px) !important;
        white-space:nowrap !important;
    }

    .menu-toggle,
    .hamburger,
    .nav-toggle,
    button[aria-label*="menu" i]{
        width:46px !important;
        height:46px !important;
        flex:0 0 46px !important;
    }
}

@media (max-width: 430px){
    header .container,
    .topbar .container,
    .site-header .container,
    .nav-wrap,
    .navbar .container{
        gap:6px !important;
        padding-inline:8px !important;
    }

    header a[href*="acesso" i],
    header a[href*="portal" i],
    header a[href*="login" i],
    header a[href*="cliente" i],
    header a[href*="acesso-plataforma" i],
    header a[href*="acesso à plataforma" i],
    header a[href="#contato"].btn,
    header a[href="#acesso"].btn,
    .topbar a[href*="acesso" i],
    .topbar a[href*="portal" i],
    .topbar a[href*="login" i],
    .topbar a[href*="cliente" i],
    .topbar a[href*="acesso-plataforma" i],
    .topbar a[href*="acesso à plataforma" i],
    .site-header a[href*="acesso" i],
    .site-header a[href*="portal" i],
    .site-header a[href*="login" i],
    .site-header a[href*="cliente" i],
    .site-header a[href*="acesso-plataforma" i],
    .site-header a[href*="acesso à plataforma" i],
    .nav-actions a[href*="acesso" i],
    .nav-actions a[href*="portal" i],
    .nav-actions a[href*="login" i],
    .nav-actions a[href*="cliente" i],
    .nav-actions a[href*="acesso-plataforma" i],
    .nav-actions a[href*="acesso à plataforma" i],
    .header-actions a[href*="acesso" i],
    .header-actions a[href*="portal" i],
    .header-actions a[href*="login" i],
    .header-actions a[href*="cliente" i],
    .header-actions a[href*="acesso-plataforma" i],
    .header-actions a[href*="acesso à plataforma" i]{
        min-width:78px !important;
        max-width:82px !important;
        height:42px !important;
        padding:0 10px !important;
    }

    header a[href*="acesso" i]::after,
    header a[href*="portal" i]::after,
    header a[href*="login" i]::after,
    header a[href*="cliente" i]::after,
    header a[href*="acesso-plataforma" i]::after,
    header a[href*="acesso à plataforma" i]::after,
    header a[href="#contato"].btn::after,
    header a[href="#acesso"].btn::after,
    .topbar a::after,
    .site-header a::after,
    .nav-actions a::after,
    .header-actions a::after{
        font-size:11.5px !important;
    }

    .menu-toggle,
    .hamburger,
    .nav-toggle,
    button[aria-label*="menu" i]{
        width:42px !important;
        height:42px !important;
        flex-basis:42px !important;
    }

    .brand .konecta-brand-mark,
    .konecta-brand-mark{
        width:34px !important;
        height:40px !important;
    }

    .brand-word strong,
    .brand-text strong,
    .brand strong{
        font-size:17px !important;
    }

    .brand-word span,
    .brand-text span,
    .brand span{
        font-size:15px !important;
    }
}



/* CHECKPOINT V12.33 | Limpeza final de nomenclatura mobile
   Remove definitivamente textos visuais nomenclatura antiga/Solicitar no topo e padroniza CTA como Acessar plataforma. */
@media (max-width: 760px){
    .topbar .nav-actions{
        display:flex !important;
        align-items:center !important;
        justify-content:flex-end !important;
        gap:6px !important;
        min-width:0 !important;
        flex:0 1 auto !important;
    }

    .topbar .nav-actions a.btn{
        display:inline-flex !important;
        align-items:center !important;
        justify-content:center !important;
        width:auto !important;
        min-width:112px !important;
        max-width:128px !important;
        height:42px !important;
        padding:0 10px !important;
        border-radius:999px !important;
        font-size:0 !important;
        line-height:1 !important;
        white-space:nowrap !important;
        overflow:hidden !important;
        flex:0 0 auto !important;
    }

    .topbar .nav-actions a.btn::after{
        content:"Acessar plataforma" !important;
        font-size:10.8px !important;
        font-weight:950 !important;
        letter-spacing:-.35px !important;
        line-height:1 !important;
    }

    .topbar .nav-actions a.btn.primary{
        display:none !important;
    }

    .topbar .brand .word{display:none !important;}
    .topbar .brand{min-width:auto !important; flex:0 0 auto !important;}
    .topbar .konecta-brand-mark{width:34px !important;height:40px !important;}
    .topbar button.mobile{flex:0 0 42px !important;width:42px !important;height:42px !important;}
}


/* CHECKPOINT V12.34 | Acessibilidade + WhatsApp flutuante
   Botões discretos, responsivos e preservando a landing aprovada. */
.floating-tools{
    position:fixed;
    right:clamp(14px,2vw,24px);
    bottom:clamp(14px,2vw,24px);
    z-index:9999;
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    gap:12px;
    pointer-events:none;
}
.floating-tools button,
.floating-tools a{pointer-events:auto}
.floating-accessibility,
.floating-whatsapp{
    border:0;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-height:54px;
    padding:0 18px;
    border-radius:999px;
    font:800 14px/1.1 inherit;
    letter-spacing:.01em;
    cursor:pointer;
    text-decoration:none;
    box-shadow:0 18px 42px rgba(15,23,42,.22);
    transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;
    backdrop-filter:blur(14px);
}
.floating-accessibility span,
.floating-whatsapp span{
    width:34px;
    height:34px;
    border-radius:50%;
    display:grid;
    place-items:center;
    font-size:20px;
    flex:0 0 auto;
}
.floating-accessibility{
    color:#0f172a;
    background:rgba(255,255,255,.94);
    border:1px solid rgba(15,23,42,.10);
}
.floating-accessibility span{background:#e0f2fe;color:#0369a1}
.floating-whatsapp{
    color:#fff;
    background:linear-gradient(135deg,#16a34a,#22c55e);
}
.floating-whatsapp span{background:rgba(255,255,255,.18);color:#fff}
.floating-accessibility:hover,
.floating-whatsapp:hover,
.floating-accessibility:focus-visible,
.floating-whatsapp:focus-visible{
    transform:translateY(-3px);
    box-shadow:0 22px 54px rgba(15,23,42,.28);
    outline:3px solid rgba(59,130,246,.28);
    outline-offset:3px;
}
.accessibility-panel{
    width:min(330px,calc(100vw - 28px));
    background:rgba(255,255,255,.98);
    color:#0f172a;
    border:1px solid rgba(15,23,42,.12);
    border-radius:24px;
    padding:16px;
    box-shadow:0 24px 70px rgba(15,23,42,.26);
    backdrop-filter:blur(18px);
    pointer-events:auto;
}
.accessibility-panel-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-bottom:12px;
}
.accessibility-panel-head strong{font-size:18px;letter-spacing:-.02em}
.accessibility-panel-head button{
    width:34px;
    height:34px;
    border:0;
    border-radius:12px;
    background:#eff6ff;
    color:#1d4ed8;
    font-size:24px;
    line-height:1;
    cursor:pointer;
}
.accessibility-actions{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
}
.accessibility-actions button{
    min-height:44px;
    border:1px solid rgba(37,99,235,.16);
    border-radius:14px;
    background:#f8fafc;
    color:#0f172a;
    font-weight:800;
    cursor:pointer;
    padding:10px;
    text-align:center;
}
.accessibility-actions button:hover,
.accessibility-actions button:focus-visible{
    background:#e0f2fe;
    outline:2px solid rgba(37,99,235,.26);
    outline-offset:2px;
}
html.konecta-font-lg body{font-size:18px}
html.konecta-font-xl body{font-size:20px}
html.konecta-high-contrast body{background:#000!important;color:#fff!important}
html.konecta-high-contrast .topbar,
html.konecta-high-contrast .section,
html.konecta-high-contrast .footer,
html.konecta-high-contrast .access-premium-shell,
html.konecta-high-contrast .access-contact-form,
html.konecta-high-contrast .screen-card,
html.konecta-high-contrast .card,
html.konecta-high-contrast article{filter:none!important;background:#000!important;color:#fff!important;border-color:#fff!important}
html.konecta-high-contrast a,
html.konecta-high-contrast button,
html.konecta-high-contrast .btn{outline-color:#facc15!important}
html.konecta-high-contrast p,
html.konecta-high-contrast small,
html.konecta-high-contrast span{color:inherit!important}
html.konecta-grayscale body{filter:grayscale(1)}
html.konecta-underline-links a{text-decoration:underline!important;text-underline-offset:4px}
@media (max-width:720px){
    .floating-tools{right:12px;bottom:12px;gap:10px}
    .floating-accessibility,
    .floating-whatsapp{min-height:50px;padding:0 12px}
    .floating-accessibility strong,
    .floating-whatsapp strong{display:none}
    .floating-accessibility span,
    .floating-whatsapp span{width:38px;height:38px;font-size:21px}
    .accessibility-panel{border-radius:20px;padding:14px}
    .accessibility-actions{grid-template-columns:1fr}
}

/* CHECKPOINT V12.35 | Barra de acessibilidade no topo + WhatsApp no estilo chat */
.accessibility-topbar{
    position:relative;
    z-index:10050;
    width:100%;
    background:#f4f7fb;
    border-bottom:1px solid rgba(15,23,42,.08);
    box-shadow:0 2px 10px rgba(15,23,42,.04);
}
.accessibility-topbar-inner{
    width:min(1180px,calc(100% - 28px));
    margin:0 auto;
    min-height:56px;
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:10px;
    flex-wrap:wrap;
}
.accessibility-topbar button{
    border:1px solid rgba(15,23,42,.10);
    background:#fff;
    color:#020617;
    min-height:42px;
    padding:0 18px;
    border-radius:999px;
    font:900 clamp(15px,2.2vw,20px)/1 inherit;
    letter-spacing:-.03em;
    cursor:pointer;
    box-shadow:0 8px 20px rgba(15,23,42,.05);
    transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.accessibility-topbar button:hover,
.accessibility-topbar button:focus-visible{
    transform:translateY(-1px);
    border-color:rgba(37,99,235,.35);
    box-shadow:0 12px 28px rgba(15,23,42,.10);
    outline:3px solid rgba(37,99,235,.18);
    outline-offset:2px;
}
.floating-tools,
.floating-accessibility,
.accessibility-panel{display:none!important}
.floating-whatsapp{
    position:fixed!important;
    right:clamp(20px,3vw,38px)!important;
    bottom:clamp(20px,3vw,38px)!important;
    z-index:10040!important;
    width:92px!important;
    height:92px!important;
    min-height:92px!important;
    padding:0!important;
    border-radius:50%!important;
    display:grid!important;
    place-items:center!important;
    background:#03d366!important;
    color:#fff!important;
    border:8px solid rgba(255,255,255,.92)!important;
    box-shadow:0 18px 45px rgba(15,23,42,.24)!important;
    text-decoration:none!important;
    overflow:visible!important;
}
.floating-whatsapp:before{
    content:"";
    position:absolute;
    inset:-22px;
    border-radius:50%;
    background:rgba(255,255,255,.40);
    z-index:-1;
}
.floating-whatsapp span{
    width:auto!important;
    height:auto!important;
    background:transparent!important;
    color:#fff!important;
    font-size:0!important;
    line-height:1!important;
}
.floating-whatsapp span:before{
    content:"";
    display:block;
    width:48px;
    height:48px;
    background:currentColor;
    -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath d='M380.9 97.1C339 55.1 283.2 32 223.9 32 101.4 32 1.9 131.5 1.9 254c0 39.1 10.2 77.3 29.6 111L0 480l117.7-30.9c32.4 17.7 68.9 27 106.1 27h.1c122.5 0 222-99.5 222-222 0-59.3-23.1-115-65-157zm-157 341.6h-.1c-33.2 0-65.7-8.9-94-25.7l-6.7-4-69.8 18.3L72 359.2l-4.4-7c-18.5-29.4-28.2-63.3-28.2-98.2 0-101.7 82.8-184.5 184.6-184.5 49.3 0 95.6 19.2 130.4 54.1 34.8 34.9 54 81.2 53.9 130.5 0 101.8-82.8 184.6-184.4 184.6zm101.2-138.2c-5.5-2.8-32.8-16.2-37.9-18-5.1-1.9-8.8-2.8-12.5 2.8-3.7 5.5-14.3 18-17.6 21.8-3.2 3.7-6.5 4.2-12 1.4-32.6-16.3-54-29.1-75.5-66-5.7-9.8 5.7-9.1 16.3-30.3 1.8-3.7.9-6.9-.5-9.7-1.4-2.8-12.5-30.1-17.1-41.2-4.5-10.8-9.1-9.3-12.5-9.5-3.2-.2-6.9-.2-10.6-.2-3.7 0-9.7 1.4-14.8 6.9-5.1 5.5-19.4 19-19.4 46.3 0 27.3 19.9 53.7 22.6 57.4 2.8 3.7 39.1 59.7 94.8 83.8 35.2 15.2 49 16.5 66.6 13.9 10.7-1.6 32.8-13.4 37.4-26.4 4.6-13 4.6-24.1 3.2-26.4-1.3-2.5-5-3.9-10.6-6.6z'/%3E%3C/svg%3E") center/contain no-repeat;
            mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath d='M380.9 97.1C339 55.1 283.2 32 223.9 32 101.4 32 1.9 131.5 1.9 254c0 39.1 10.2 77.3 29.6 111L0 480l117.7-30.9c32.4 17.7 68.9 27 106.1 27h.1c122.5 0 222-99.5 222-222 0-59.3-23.1-115-65-157zm-157 341.6h-.1c-33.2 0-65.7-8.9-94-25.7l-6.7-4-69.8 18.3L72 359.2l-4.4-7c-18.5-29.4-28.2-63.3-28.2-98.2 0-101.7 82.8-184.5 184.6-184.5 49.3 0 95.6 19.2 130.4 54.1 34.8 34.9 54 81.2 53.9 130.5 0 101.8-82.8 184.6-184.4 184.6zm101.2-138.2c-5.5-2.8-32.8-16.2-37.9-18-5.1-1.9-8.8-2.8-12.5 2.8-3.7 5.5-14.3 18-17.6 21.8-3.2 3.7-6.5 4.2-12 1.4-32.6-16.3-54-29.1-75.5-66-5.7-9.8 5.7-9.1 16.3-30.3 1.8-3.7.9-6.9-.5-9.7-1.4-2.8-12.5-30.1-17.1-41.2-4.5-10.8-9.1-9.3-12.5-9.5-3.2-.2-6.9-.2-10.6-.2-3.7 0-9.7 1.4-14.8 6.9-5.1 5.5-19.4 19-19.4 46.3 0 27.3 19.9 53.7 22.6 57.4 2.8 3.7 39.1 59.7 94.8 83.8 35.2 15.2 49 16.5 66.6 13.9 10.7-1.6 32.8-13.4 37.4-26.4 4.6-13 4.6-24.1 3.2-26.4-1.3-2.5-5-3.9-10.6-6.6z'/%3E%3C/svg%3E") center/contain no-repeat;
}
.floating-whatsapp:hover,
.floating-whatsapp:focus-visible{
    transform:translateY(-4px) scale(1.03)!important;
    box-shadow:0 24px 58px rgba(15,23,42,.30)!important;
    outline:3px solid rgba(3,211,102,.25)!important;
    outline-offset:5px!important;
}
[vw] [vw-access-button]{
    width:58px!important;
    height:58px!important;
    border-radius:12px!important;
    box-shadow:0 14px 34px rgba(37,99,235,.28)!important;
}
@media (max-width:720px){
    .accessibility-topbar-inner{justify-content:center;gap:8px;min-height:58px;width:calc(100% - 16px)}
    .accessibility-topbar button{min-height:38px;padding:0 13px;font-size:16px}
    .floating-whatsapp{width:74px!important;height:74px!important;min-height:74px!important;right:18px!important;bottom:18px!important;border-width:6px!important}
    .floating-whatsapp:before{inset:-14px}
    .floating-whatsapp span:before{width:38px;height:38px}
}


/* CHECKPOINT V12.36 | Acessibilidade discreta integrada ao menu + WhatsApp padrão */
.accessibility-topbar{display:none!important}
.nav-actions{position:relative;align-items:center}
.nav-accessibility{position:relative;display:inline-flex;align-items:center;z-index:90;flex:0 0 auto}
.accessibility-menu-toggle{
    width:38px!important;height:38px!important;min-width:38px!important;min-height:38px!important;
    padding:0!important;border:0!important;background:transparent!important;box-shadow:none!important;
    color:#0b63f6!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:3px!important;
    border-radius:14px!important;cursor:pointer!important;font-weight:950!important;line-height:1!important;
}
.accessibility-menu-toggle:hover,.accessibility-menu-toggle:focus-visible{background:#eef5ff!important;outline:2px solid rgba(37,99,235,.18)!important;outline-offset:2px!important}
.accessibility-symbol{font-size:22px;line-height:1;color:#0b63f6!important}
.accessibility-caret{font-size:14px;line-height:1;color:#0b63f6!important;margin-top:-2px}
.accessibility-dropdown{
    position:absolute;top:calc(100% + 16px);right:-34px;width:260px;background:#fff;border:1px solid rgba(15,23,42,.08);
    border-radius:16px;box-shadow:0 24px 70px rgba(15,23,42,.18);overflow:hidden;opacity:0;visibility:hidden;
    transform:translateY(-6px);transition:.18s ease;z-index:1000;
}
.accessibility-dropdown:before{content:"";position:absolute;top:-8px;right:46px;width:16px;height:16px;background:#fff;transform:rotate(45deg);border-left:1px solid rgba(15,23,42,.06);border-top:1px solid rgba(15,23,42,.06)}
.nav-accessibility.is-open .accessibility-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.accessibility-dropdown button{
    width:100%;height:58px;border:0;border-bottom:1px solid rgba(15,23,42,.07);background:#fff;color:#071832;
    display:flex;align-items:center;gap:18px;padding:0 20px;text-align:left;cursor:pointer;font:inherit;font-weight:850;
}
.accessibility-dropdown button:last-child{border-bottom:0}
.accessibility-dropdown button strong{min-width:28px;color:#0b63f6;font-size:19px;font-weight:950;text-align:center}
.accessibility-dropdown button span{font-size:16px;color:#10213d;font-weight:850}
.accessibility-dropdown button:hover,.accessibility-dropdown button:focus-visible{background:#f4f8ff;outline:0}

/* WhatsApp: verde vivo, limpo, sem aro cinza */
.floating-whatsapp{
    position:fixed!important;right:28px!important;bottom:28px!important;width:62px!important;height:62px!important;min-height:62px!important;
    padding:0!important;border:0!important;border-radius:999px!important;background:#25D366!important;
    color:#fff!important;display:flex!important;align-items:center!important;justify-content:center!important;
    box-shadow:0 14px 30px rgba(7,94,84,.32)!important;z-index:999!important;text-decoration:none!important;transform:none!important;
}
.floating-whatsapp:before{display:none!important;content:none!important}
.floating-whatsapp span{width:34px!important;height:34px!important;background:transparent!important;color:transparent!important;border-radius:0!important;box-shadow:none!important;display:block!important;position:relative!important}
.floating-whatsapp span:before{
    content:""!important;display:block!important;width:34px!important;height:34px!important;background:#fff!important;
    -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Cpath d='M16.03 3.2A12.74 12.74 0 0 0 5.22 22.7L3.7 28.8l6.24-1.46A12.75 12.75 0 1 0 16.03 3.2Zm0 2.35a10.4 10.4 0 1 1-5.29 19.35l-.37-.22-3.62.85.88-3.5-.24-.38A10.4 10.4 0 0 1 16.03 5.55Zm-4.23 5.31c-.24-.55-.5-.56-.73-.57h-.62c-.22 0-.57.08-.87.41-.3.33-1.14 1.11-1.14 2.7s1.17 3.14 1.33 3.36c.16.22 2.25 3.6 5.58 4.9 2.76 1.08 3.33.86 3.93.8.6-.05 1.95-.8 2.23-1.56.27-.76.27-1.41.19-1.55-.08-.14-.3-.22-.63-.38-.33-.16-1.95-.96-2.25-1.07-.3-.11-.52-.16-.74.16-.22.33-.85 1.07-1.04 1.29-.19.22-.38.24-.71.08-.33-.16-1.38-.51-2.63-1.62-.97-.86-1.63-1.93-1.82-2.26-.19-.33-.02-.51.14-.67.15-.15.33-.38.49-.57.16-.19.22-.33.33-.55.11-.22.05-.41-.03-.57-.08-.16-.72-1.76-.99-2.43Z'/%3E%3C/svg%3E") center/contain no-repeat!important;
    mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Cpath d='M16.03 3.2A12.74 12.74 0 0 0 5.22 22.7L3.7 28.8l6.24-1.46A12.75 12.75 0 1 0 16.03 3.2Zm0 2.35a10.4 10.4 0 1 1-5.29 19.35l-.37-.22-3.62.85.88-3.5-.24-.38A10.4 10.4 0 0 1 16.03 5.55Zm-4.23 5.31c-.24-.55-.5-.56-.73-.57h-.62c-.22 0-.57.08-.87.41-.3.33-1.14 1.11-1.14 2.7s1.17 3.14 1.33 3.36c.16.22 2.25 3.6 5.58 4.9 2.76 1.08 3.33.86 3.93.8.6-.05 1.95-.8 2.23-1.56.27-.76.27-1.41.19-1.55-.08-.14-.3-.22-.63-.38-.33-.16-1.95-.96-2.25-1.07-.3-.11-.52-.16-.74.16-.22.33-.85 1.07-1.04 1.29-.19.22-.38.24-.71.08-.33-.16-1.38-.51-2.63-1.62-.97-.86-1.63-1.93-1.82-2.26-.19-.33-.02-.51.14-.67.15-.15.33-.38.49-.57.16-.19.22-.33.33-.55.11-.22.05-.41-.03-.57-.08-.16-.72-1.76-.99-2.43Z'/%3E%3C/svg%3E") center/contain no-repeat!important;
}
.floating-whatsapp:hover,.floating-whatsapp:focus-visible{transform:translateY(-3px)!important;background:#22c55e!important;box-shadow:0 18px 38px rgba(7,94,84,.38)!important;outline:none!important}

/* VLibras oficial sempre visível na lateral esquerda */
[vw-access-button]{left:0!important;right:auto!important;top:50%!important;bottom:auto!important;transform:translateY(-50%)!important;border-radius:0 12px 12px 0!important;z-index:998!important}

@media (max-width: 980px){
    .accessibility-dropdown{right:-10px;width:242px}
    .accessibility-dropdown:before{right:26px}
}
@media (max-width: 760px){
    .nav-accessibility{order:2}
    .accessibility-menu-toggle{width:34px!important;height:34px!important;min-width:34px!important;min-height:34px!important}
    .accessibility-symbol{font-size:19px}.accessibility-caret{font-size:12px}
    .accessibility-dropdown{position:fixed;top:78px;right:14px;width:min(260px,calc(100vw - 28px));border-radius:16px}
    .accessibility-dropdown:before{display:none}
    .floating-whatsapp{width:54px!important;height:54px!important;min-height:54px!important;right:18px!important;bottom:18px!important}
    .floating-whatsapp span,.floating-whatsapp span:before{width:30px!important;height:30px!important}
}

/* CHECKPOINT V12.38 | Menu de acessibilidade alinhado + ícone de mãos VLibras */
.accessibility-menu-toggle{
    width:32px!important;
    height:32px!important;
    min-width:32px!important;
    min-height:32px!important;
    border-radius:10px!important;
    gap:4px!important;
}
.accessibility-symbol{
    width:22px!important;
    height:22px!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    font-size:0!important;
    line-height:1!important;
}
.accessibility-symbol img{
    width:22px!important;
    height:22px!important;
    display:block!important;
    object-fit:contain!important;
}
.accessibility-caret{
    font-size:12px!important;
    margin-top:1px!important;
    color:#0b63f6!important;
}
.accessibility-menu-toggle:hover,
.accessibility-menu-toggle:focus-visible{
    background:#eef5ff!important;
    outline:1px solid rgba(11,99,246,.18)!important;
    outline-offset:2px!important;
}
.accessibility-dropdown{
    width:246px!important;
    border-radius:14px!important;
    box-shadow:0 18px 48px rgba(15,23,42,.16)!important;
}
.accessibility-dropdown button{
    height:54px!important;
    justify-content:flex-start!important;
    align-items:center!important;
    gap:14px!important;
    padding:0 18px!important;
    text-align:left!important;
}
.accessibility-dropdown button strong{
    flex:0 0 36px!important;
    width:36px!important;
    min-width:36px!important;
    max-width:36px!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:flex-start!important;
    text-align:left!important;
    color:#0b63f6!important;
    font-size:18px!important;
    line-height:1!important;
}
.accessibility-dropdown button span{
    flex:1 1 auto!important;
    text-align:left!important;
    font-size:15px!important;
    line-height:1.2!important;
    color:#10213d!important;
    font-weight:850!important;
}
.vlibras-mini-icon img{
    width:24px!important;
    height:24px!important;
    display:block!important;
    object-fit:contain!important;
}
/* fallback visual para o botão lateral oficial do VLibras enquanto o plugin carrega */
[vw] [vw-access-button],
[vw-access-button]{
    width:56px!important;
    height:56px!important;
    border-radius:0 12px 12px 0!important;
    background:#2f80ed!important;
    box-shadow:0 14px 30px rgba(37,99,235,.26)!important;
    overflow:hidden!important;
}
[vw] [vw-access-button] img,
[vw-access-button] img{display:none!important}
[vw] [vw-access-button]::before,
[vw-access-button]::before{
    content:""!important;
    position:absolute!important;
    inset:10px!important;
    background:#fff!important;
    -webkit-mask:url('../img/vlibras-maos-azul.svg') center/contain no-repeat!important;
            mask:url('../img/vlibras-maos-azul.svg') center/contain no-repeat!important;
}
@media (max-width:760px){
    .accessibility-menu-toggle{width:30px!important;height:30px!important;min-width:30px!important;min-height:30px!important}
    .accessibility-symbol,.accessibility-symbol img{width:20px!important;height:20px!important}
    .accessibility-dropdown{width:min(246px,calc(100vw - 28px))!important}
    .accessibility-dropdown button{height:52px!important;padding:0 16px!important}
}


/* CHECKPOINT V12.39 | VLibras oficial funcionando: sem cobrir o botão real do plugin */
[vw] [vw-access-button],
[vw-access-button]{
    left:0!important;
    right:auto!important;
    top:50%!important;
    bottom:auto!important;
    transform:translateY(-50%)!important;
    width:54px!important;
    height:54px!important;
    border-radius:0 12px 12px 0!important;
    background:#2f80ed!important;
    box-shadow:0 12px 28px rgba(37,99,235,.24)!important;
    z-index:999!important;
    cursor:pointer!important;
    pointer-events:auto!important;
}
[vw] [vw-access-button]::before,
[vw-access-button]::before{
    display:none!important;
    content:none!important;
}
[vw] [vw-access-button] img,
[vw-access-button] img{
    display:block!important;
    opacity:1!important;
    visibility:visible!important;
}
[vw-plugin-wrapper]{
    z-index:1000!important;
}
.accessibility-dropdown button{
    justify-content:flex-start!important;
}


/* CHECKPOINT V12.40 | VLibras oficial sem interferência visual pesada */
/* Mantém o botão oficial funcionando e apenas reposiciona com discrição. */
[vw] {
    z-index: 999 !important;
}
div[vw-access-button],
[vw] div[vw-access-button],
[vw-access-button] {
    position: fixed !important;
    left: 0 !important;
    right: auto !important;
    top: 50% !important;
    bottom: auto !important;
    transform: translateY(-50%) !important;
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    min-height: 48px !important;
    border-radius: 0 12px 12px 0 !important;
    z-index: 9999 !important;
    pointer-events: auto !important;
    cursor: pointer !important;
}
[vw] div[vw-access-button]::before,
div[vw-access-button]::before,
[vw-access-button]::before {
    content: none !important;
    display: none !important;
}
[vw] div[vw-access-button] img,
div[vw-access-button] img,
[vw-access-button] img {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
}
[vw-plugin-wrapper] {
    z-index: 10000 !important;
}
.accessibility-dropdown button {
    justify-content: flex-start !important;
    text-align: left !important;
}
.accessibility-dropdown button strong {
    justify-content: flex-start !important;
    text-align: left !important;
}
@media (max-width:760px){
    div[vw-access-button],
    [vw] div[vw-access-button],
    [vw-access-button] {
        width: 44px !important;
        height: 44px !important;
        min-width: 44px !important;
        min-height: 44px !important;
    }
}

/* CHECKPOINT V12.41 | Acessibilidade alinhada + VLibras apenas com mãozinhas */
.nav-accessibility{
    display:inline-flex!important;
    align-items:center!important;
}
.accessibility-menu-toggle{
    width:32px!important;
    height:32px!important;
    min-width:32px!important;
    min-height:32px!important;
    padding:0!important;
    background:transparent!important;
    border:0!important;
    box-shadow:none!important;
    outline:none!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    gap:4px!important;
}
.accessibility-menu-toggle:hover,
.accessibility-menu-toggle:focus-visible{
    background:rgba(11,99,246,.08)!important;
    border-radius:10px!important;
}
.accessibility-symbol,
.accessibility-symbol img{
    width:22px!important;
    height:22px!important;
    min-width:22px!important;
    min-height:22px!important;
    display:block!important;
}
.accessibility-caret{
    font-size:12px!important;
    color:#0b63f6!important;
    line-height:1!important;
    margin:0!important;
}
.accessibility-dropdown{
    width:248px!important;
    padding:0!important;
    border-radius:14px!important;
    overflow:hidden!important;
}
.accessibility-dropdown button{
    width:100%!important;
    height:54px!important;
    padding:0 18px!important;
    display:grid!important;
    grid-template-columns:38px 1fr!important;
    align-items:center!important;
    justify-items:start!important;
    column-gap:0!important;
    text-align:left!important;
    border-radius:0!important;
}
.accessibility-dropdown button strong,
.accessibility-dropdown button span{
    justify-self:start!important;
    text-align:left!important;
}
.accessibility-dropdown button strong{
    width:38px!important;
    min-width:38px!important;
    max-width:38px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:flex-start!important;
}
.accessibility-dropdown button span{
    display:block!important;
    width:100%!important;
    font-size:15px!important;
    font-weight:850!important;
    color:#10213d!important;
}
.vlibras-mini-icon img{
    width:22px!important;
    height:22px!important;
}

/* Botão oficial do VLibras: remove qualquer imagem/avatar injetado e deixa só as mãozinhas */
[vw],
[vw].enabled{
    z-index:9999!important;
}
div[vw-access-button],
[vw] div[vw-access-button],
[vw-access-button]{
    position:fixed!important;
    left:0!important;
    right:auto!important;
    top:50%!important;
    bottom:auto!important;
    transform:translateY(-50%)!important;
    width:52px!important;
    height:52px!important;
    min-width:52px!important;
    min-height:52px!important;
    border-radius:0 12px 12px 0!important;
    background:#2f80ed!important;
    box-shadow:0 12px 28px rgba(37,99,235,.25)!important;
    overflow:hidden!important;
    cursor:pointer!important;
    pointer-events:auto!important;
}
[vw-access-button] *,
[vw] div[vw-access-button] *,
div[vw-access-button] *{
    display:none!important;
    opacity:0!important;
    visibility:hidden!important;
}
[vw] div[vw-access-button]::before,
div[vw-access-button]::before,
[vw-access-button]::before{
    content:""!important;
    display:block!important;
    position:absolute!important;
    inset:10px!important;
    background:#fff!important;
    -webkit-mask:url('../img/vlibras-maos-azul.svg') center/contain no-repeat!important;
            mask:url('../img/vlibras-maos-azul.svg') center/contain no-repeat!important;
}
[vw-plugin-wrapper]{
    z-index:10000!important;
}
@media (max-width:760px){
    div[vw-access-button],
    [vw] div[vw-access-button],
    [vw-access-button]{
        width:48px!important;
        height:48px!important;
        min-width:48px!important;
        min-height:48px!important;
    }
    [vw] div[vw-access-button]::before,
    div[vw-access-button]::before,
    [vw-access-button]::before{inset:9px!important}
}

/* CHECKPOINT V12.42 | VLibras com botão próprio: apenas mãozinhas visíveis */
/* O botão oficial fica oculto para não sobrepor avatar/imagem do plugin. A abertura continua sendo feita via JS. */
div[vw-access-button],
[vw] div[vw-access-button],
[vw-access-button]{
    position:fixed!important;
    left:-9999px!important;
    top:50%!important;
    width:1px!important;
    height:1px!important;
    min-width:1px!important;
    min-height:1px!important;
    opacity:0!important;
    visibility:hidden!important;
    pointer-events:none!important;
    overflow:hidden!important;
}
div[vw-access-button] *,
[vw] div[vw-access-button] *,
[vw-access-button] *,
div[vw-access-button]::before,
[vw] div[vw-access-button]::before,
[vw-access-button]::before{
    display:none!important;
    content:none!important;
}
.vlibras-side-trigger{
    position:fixed!important;
    left:0!important;
    top:50%!important;
    transform:translateY(-50%)!important;
    width:52px!important;
    height:52px!important;
    min-width:52px!important;
    min-height:52px!important;
    padding:0!important;
    border:0!important;
    border-radius:0 12px 12px 0!important;
    background:linear-gradient(135deg,#2f80ed,#0057e7)!important;
    box-shadow:0 12px 28px rgba(37,99,235,.25)!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    cursor:pointer!important;
    z-index:9998!important;
}
.vlibras-side-trigger span{
    width:34px!important;
    height:34px!important;
    display:block!important;
    background:#fff!important;
    -webkit-mask:url('../img/vlibras-maos-azul.svg') center/contain no-repeat!important;
            mask:url('../img/vlibras-maos-azul.svg') center/contain no-repeat!important;
}
.vlibras-side-trigger:hover,
.vlibras-side-trigger:focus-visible{
    transform:translateY(-50%) translateX(2px)!important;
    outline:2px solid rgba(47,128,237,.25)!important;
    outline-offset:3px!important;
}
[vw-plugin-wrapper]{
    z-index:10000!important;
}
@media (max-width:760px){
    .vlibras-side-trigger{
        width:48px!important;
        height:48px!important;
        min-width:48px!important;
        min-height:48px!important;
    }
    .vlibras-side-trigger span{
        width:31px!important;
        height:31px!important;
    }
}

/* CHECKPOINT V12.43 | Símbolo oficial de acessibilidade exatamente como imagem enviada */
.accessibility-symbol,
.accessibility-symbol img{
    width:24px!important;
    height:24px!important;
    min-width:24px!important;
    min-height:24px!important;
}
.accessibility-symbol img{
    object-fit:contain!important;
    object-position:center!important;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    filter:none!important;
}
.accessibility-menu-toggle{
    width:42px!important;
    min-width:42px!important;
}
@media (max-width:760px){
    .accessibility-symbol,
    .accessibility-symbol img{
        width:22px!important;
        height:22px!important;
        min-width:22px!important;
        min-height:22px!important;
    }
}

/* V12.44 | Retorno do formulário de contato */
.contact-form-alert{
    display:flex;
    align-items:center;
    width:100%;
    margin:0 0 16px;
    padding:12px 14px;
    border-radius:14px;
    font-weight:800;
    font-size:.9rem;
    line-height:1.35;
}
.contact-form-alert.is-success{
    color:#065f46;
    background:#ecfdf5;
    border:1px solid rgba(16,185,129,.28);
}
.contact-form-alert.is-error{
    color:#991b1b;
    background:#fef2f2;
    border:1px solid rgba(239,68,68,.28);
}
#contato-nome:focus{
    border-color:#2563eb;
    box-shadow:0 0 0 4px rgba(37,99,235,.18);
}

/* KONЕCTA | destaque visual quando Solicitar contato posiciona no campo Seu nome */
#contato-nome.contact-autofocus-ready,
#contato-nome:focus{
    border-color:#2563eb!important;
    box-shadow:0 0 0 4px rgba(37,99,235,.16)!important;
    outline:0!important;
}

/* CHECKPOINT V12.45 | Ícone oficial de acessibilidade em PNG transparente no tema claro/escuro */
.accessibility-menu-toggle{
    background:transparent!important;
    border:0!important;
    box-shadow:none!important;
    padding:0!important;
    gap:5px!important;
}
.accessibility-symbol{
    background:transparent!important;
    border:0!important;
    box-shadow:none!important;
    overflow:visible!important;
}
.accessibility-symbol img{
    width:24px!important;
    height:24px!important;
    min-width:24px!important;
    min-height:24px!important;
    display:block!important;
    object-fit:contain!important;
    background:transparent!important;
    mix-blend-mode:normal!important;
}
body.dark-mode .accessibility-symbol,
body.dark-mode .accessibility-symbol img,
html.konecta-high-contrast .accessibility-symbol,
html.konecta-high-contrast .accessibility-symbol img{
    background:transparent!important;
    box-shadow:none!important;
    border:0!important;
}

/* CHECKPOINT V12.46 | Ícone oficial de acessibilidade com contraste correto no menu escuro */
.accessibility-symbol img{
    content:url('../img/acessibilidade-oficial.png')!important;
}
.topbar.is-scrolled .accessibility-symbol img,
body.dark-mode .accessibility-symbol img,
html.konecta-high-contrast .accessibility-symbol img{
    content:url('../img/acessibilidade-oficial-light.png')!important;
}
.topbar.is-scrolled .accessibility-menu-toggle:hover,
.topbar.is-scrolled .accessibility-menu-toggle:focus-visible{
    background:rgba(96,165,250,.12)!important;
    outline-color:rgba(96,165,250,.24)!important;
}
.topbar.is-scrolled .accessibility-caret,
body.dark-mode .accessibility-caret,
html.konecta-high-contrast .accessibility-caret{
    color:#60a5fa!important;
}


/* KONЕCTA | acesso administrativo discreto no rodapé */
.footer-legal .admin-access-link{
    opacity:.46;
    font-size:.78rem;
    font-weight:700;
    letter-spacing:.01em;
}
.footer-legal .admin-access-link:hover,
.footer-legal .admin-access-link:focus-visible{
    opacity:1;
    color:#93c5fd;
}


/* KONЕCTA | Rodapé legal em linha única e acesso administrativo discreto */
.footer.konecta-premium-footer .footer-legal,
.footer-legal{
    display:flex!important;
    flex-direction:row!important;
    align-items:center!important;
    justify-content:center!important;
    flex-wrap:nowrap!important;
    gap:10px!important;
    white-space:nowrap!important;
    line-height:1!important;
}
.footer.konecta-premium-footer .footer-legal a,
.footer-legal a{
    display:inline-flex!important;
    align-items:center!important;
    white-space:nowrap!important;
}
.footer.konecta-premium-footer .footer-legal span,
.footer-legal span{
    display:inline-flex!important;
    align-items:center!important;
    opacity:.72!important;
}
.footer.konecta-premium-footer .footer-legal .admin-access-link,
.footer-legal .admin-access-link{
    opacity:.42!important;
    font-size:.74rem!important;
    font-weight:700!important;
    color:#67a7d8!important;
    text-decoration:none!important;
}
.footer.konecta-premium-footer .footer-legal .admin-access-link:hover,
.footer.konecta-premium-footer .footer-legal .admin-access-link:focus-visible,
.footer-legal .admin-access-link:hover,
.footer-legal .admin-access-link:focus-visible{
    opacity:.9!important;
    color:#93c5fd!important;
}
@media (max-width: 640px){
    .footer.konecta-premium-footer .footer-legal,
    .footer-legal{
        flex-wrap:wrap!important;
        gap:8px 10px!important;
        line-height:1.35!important;
    }
}

/* KONЕCTA | Rodapé legal uniforme - todos os links com mesmo padrão */
.footer.konecta-premium-footer .footer-legal,
.footer-legal{
    display:flex!important;
    flex-direction:row!important;
    align-items:center!important;
    justify-content:center!important;
    flex-wrap:nowrap!important;
    gap:10px!important;
    white-space:nowrap!important;
    line-height:1.1!important;
}
.footer.konecta-premium-footer .footer-legal a,
.footer-legal a,
.footer.konecta-premium-footer .footer-legal .admin-access-link,
.footer-legal .admin-access-link{
    display:inline-flex!important;
    align-items:center!important;
    white-space:nowrap!important;
    color:#1fb6ff!important;
    font-size:15px!important;
    font-weight:800!important;
    font-family:inherit!important;
    letter-spacing:0!important;
    opacity:1!important;
    text-decoration:none!important;
    line-height:1.1!important;
    transition:color .2s ease!important;
}
.footer.konecta-premium-footer .footer-legal a:hover,
.footer.konecta-premium-footer .footer-legal a:focus-visible,
.footer-legal a:hover,
.footer-legal a:focus-visible,
.footer.konecta-premium-footer .footer-legal .admin-access-link:hover,
.footer.konecta-premium-footer .footer-legal .admin-access-link:focus-visible,
.footer-legal .admin-access-link:hover,
.footer-legal .admin-access-link:focus-visible{
    color:#fff!important;
    opacity:1!important;
    text-decoration:none!important;
}
.footer.konecta-premium-footer .footer-legal span,
.footer-legal span{
    color:rgba(226,232,240,.62)!important;
    font-size:15px!important;
    font-weight:800!important;
    display:inline-flex!important;
    align-items:center!important;
    opacity:.72!important;
    line-height:1.1!important;
}
@media (max-width: 640px){
    .footer.konecta-premium-footer .footer-legal,
    .footer-legal{
        flex-wrap:wrap!important;
        gap:10px!important;
        white-space:normal!important;
    }
}
