/* Caminho: public_html/SUBPASTA/assets/css/style.css
   Design System JEFLUB 2026 · Light Industrial-Tech
   Marca: Azul #2A2A90 e Vermelho #A21B10 sobre superfícies claras de vidro */

:root {
    --azul: #2A2A90;
    --azul-vivo: #4150E0;
    --azul-profundo: #1E1E6B;
    --vermelho: #A21B10;
    --vermelho-vivo: #C82619;

    --fundo: #F7F9FD;
    --fundo-2: #EEF2FA;
    --vidro: rgba(255, 255, 255, 0.72);
    --vidro-forte: rgba(255, 255, 255, 0.92);
    --linha: rgba(27, 31, 42, 0.09);
    --linha-viva: rgba(65, 80, 224, 0.35);

    --texto: #161A26;
    --texto-suave: #525A70;
    --texto-apagado: #8A91A6;

    --grad-marca: linear-gradient(100deg, #4150E0 0%, #2A2A90 38%, #7D3BBE 68%, #C82619 100%);
    --grad-quente: linear-gradient(120deg, #C82619, #A21B10);
    --grad-fria: linear-gradient(135deg, #4150E0, #2A2A90);

    --raio: 18px;
    --raio-g: 26px;
    --transicao: cubic-bezier(.22, 1, .36, 1);
    --sombra-suave: 0 10px 36px rgba(30, 30, 107, .09);
    --sombra-alta: 0 28px 70px rgba(30, 30, 107, .16);
    --fonte-titulo: 'Space Grotesk', 'Sora', 'Segoe UI', sans-serif;
    --fonte-texto: 'Inter', 'Segoe UI', sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    font-family: var(--fonte-texto);
    background: var(--fundo);
    color: var(--texto);
    line-height: 1.7;
    font-size: 16.5px;
    overflow-x: hidden;
}

/* Grade técnica sutil ao fundo */
body::before {
    content: '';
    position: fixed; inset: 0; z-index: -2; pointer-events: none;
    background-image:
        linear-gradient(rgba(42, 42, 144, .045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(42, 42, 144, .045) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(ellipse 95% 70% at 50% 0%, #000 25%, transparent 75%);
    -webkit-mask-image: radial-gradient(ellipse 95% 70% at 50% 0%, #000 25%, transparent 75%);
}

::selection { background: rgba(65, 80, 224, .25); }

h1, h2, h3, h4 { font-family: var(--fonte-titulo); line-height: 1.12; letter-spacing: -.02em; color: var(--texto); }
h1 { font-size: clamp(2.4rem, 6vw, 4.5rem); font-weight: 700; }
h2 { font-size: clamp(1.7rem, 3.6vw, 2.7rem); font-weight: 700; margin-bottom: .5em; }
h3 { font-size: 1.18rem; margin-bottom: .45em; font-weight: 600; }
p { margin-bottom: 1em; }
a { color: var(--azul-vivo); text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }

.container { width: min(1200px, 92%); margin: 0 auto; }
.centro { text-align: center; }

.texto-gradiente {
    background: var(--grad-marca);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; color: transparent;
}

.pular-conteudo { position: absolute; left: -9999px; top: 0; background: var(--azul-profundo); color: #fff; padding: 10px 16px; z-index: 200; border-radius: 0 0 10px 0; }
.pular-conteudo:focus { left: 0; }

/* ---------- Barra de progresso de leitura ---------- */
.progresso-scroll {
    position: fixed; top: 0; left: 0; height: 3px; width: 0%;
    background: var(--grad-marca); z-index: 120;
    box-shadow: 0 1px 10px rgba(65, 80, 224, .5);
}

/* ---------- Cabeçalho flutuante glass ---------- */
.cabecalho {
    position: sticky; top: 0; z-index: 100;
    background: rgba(255, 255, 255, .68);
    backdrop-filter: blur(18px) saturate(1.5);
    -webkit-backdrop-filter: blur(18px) saturate(1.5);
    border-bottom: 1px solid var(--linha);
    transition: background .4s, box-shadow .4s;
}
.cabecalho.rolado { background: rgba(255, 255, 255, .92); box-shadow: 0 10px 36px rgba(30, 30, 107, .1); }
.cabecalho .container { width: min(1380px, 96%); }
.cabecalho-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 12px 0; }
.marca img { width: 150px; height: auto; transition: transform .4s var(--transicao); }
.marca:hover img { transform: scale(1.04); }

.menu { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.menu a {
    color: var(--texto-suave); font-weight: 500; font-size: .9rem;
    padding: 9px 0; position: relative; white-space: nowrap;
    transition: color .25s;
}
@media (min-width: 861px) and (max-width: 1280px) {
    .menu { gap: 12px; }
    .menu a { font-size: .84rem; }
    .menu .menu-parceiro { padding: 10px 14px !important; }
    .menu-cta { padding: 11px 16px; }
}
/* Sublinhado de fluido: linha em gradiente da marca que escorre da esquerda */
.menu a:not(.menu-cta):not(.menu-parceiro)::after {
    content: ''; position: absolute; left: 0; bottom: 2px; height: 2px; width: 100%;
    background: var(--grad-marca); border-radius: 99px;
    transform: scaleX(0); transform-origin: left center;
    transition: transform .38s var(--transicao);
}
.menu a:hover { color: var(--azul); text-decoration: none; }
.menu a:not(.menu-cta):hover::after { transform: scaleX(1); }
.menu-botao {
    display: none; align-items: center; gap: 9px;
    background: #fff; border: 1px solid var(--linha); color: var(--azul);
    border-radius: 12px; padding: 9px 16px; cursor: pointer; box-shadow: var(--sombra-suave);
    font-family: var(--fonte-titulo); font-weight: 600; font-size: .85rem;
    transition: border-color .3s, box-shadow .3s;
}
.menu-botao:hover { border-color: var(--linha-viva); box-shadow: var(--sombra-alta); }
.menu-rotulo { letter-spacing: .04em; text-transform: uppercase; }
/* Hambúrguer animado: 3 barras que viram um X ao abrir */
.hamburguer { display: inline-flex; flex-direction: column; justify-content: center; gap: 4px; width: 20px; height: 16px; }
.hamburguer span {
    display: block; height: 2.4px; width: 100%; border-radius: 99px;
    background: linear-gradient(90deg, var(--azul), var(--vermelho-vivo));
    transition: transform .35s var(--transicao), opacity .25s;
    transform-origin: center;
}
.menu-botao.aberto .hamburguer span:nth-child(1) { transform: translateY(6.4px) rotate(45deg); }
.menu-botao.aberto .hamburguer span:nth-child(2) { opacity: 0; transform: scaleX(.2); }
.menu-botao.aberto .hamburguer span:nth-child(3) { transform: translateY(-6.4px) rotate(-45deg); }

/* ---------- Botões ---------- */
.botao {
    display: inline-flex; align-items: center; gap: 9px;
    padding: 15px 30px; border-radius: 99px;
    font-family: var(--fonte-titulo); font-weight: 600; font-size: .95rem;
    text-decoration: none; border: 1px solid transparent; cursor: pointer;
    position: relative; overflow: hidden; isolation: isolate;
    transition: transform .35s var(--transicao), box-shadow .35s, border-color .35s, background .35s, color .35s;
    will-change: transform;
}
.botao:hover { text-decoration: none; transform: translateY(-3px); }
.botao:active { transform: translateY(-1px) scale(.98); }

.botao-primario { background: var(--grad-quente); color: #fff; box-shadow: 0 10px 28px rgba(200, 38, 25, .32); }
.botao-primario::after {
    content: ''; position: absolute; inset: 0; z-index: -1;
    background: linear-gradient(120deg, transparent 30%, rgba(255, 255, 255, .4) 50%, transparent 70%);
    transform: translateX(-130%); transition: transform .7s var(--transicao);
}
.botao-primario:hover { box-shadow: 0 16px 42px rgba(200, 38, 25, .42); color: #fff; }
.botao-primario:hover::after { transform: translateX(130%); }

.botao-contorno {
    border-color: rgba(42, 42, 144, .35); color: var(--azul); background: rgba(255, 255, 255, .6);
    backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.botao-contorno:hover { border-color: var(--azul); background: var(--azul); color: #fff; box-shadow: 0 12px 32px rgba(42, 42, 144, .3); }
.botao-contorno-claro { border-color: rgba(255, 255, 255, .65); color: #fff; background: rgba(255, 255, 255, .14); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
.botao-contorno-claro:hover { background: #fff; color: var(--azul); box-shadow: 0 12px 32px rgba(255, 255, 255, .35); }
.botao-bloco { display: flex; justify-content: center; width: 100%; margin-bottom: 12px; }
.menu-cta {
    padding: 12px 22px; margin-left: 8px; color: #fff !important;
    font-size: .9rem; font-weight: 700; letter-spacing: .02em; white-space: nowrap;
    border-radius: 14px; line-height: 1;
    box-shadow: 0 4px 14px rgba(200, 38, 25, .28);
}
.menu-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(200, 38, 25, .36); }
.botoes { display: flex; gap: 16px; flex-wrap: wrap; }
.botoes-centro { justify-content: center; }

/* ---------- Hero cinético ---------- */
.hero {
    position: relative; min-height: 88vh; display: flex; align-items: center;
    overflow: hidden; padding: 90px 0 80px;
    background: linear-gradient(180deg, #FFFFFF 0%, var(--fundo) 100%);
}
#campo-fluxo { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.hero-orbita {
    position: absolute; border-radius: 50%; filter: blur(100px); z-index: 0; pointer-events: none;
    animation: orbitar 14s ease-in-out infinite alternate;
}
.orbita-azul { width: 560px; height: 560px; background: rgba(65, 80, 224, .18); top: -200px; left: -140px; }
.orbita-vermelha { width: 460px; height: 460px; background: rgba(200, 38, 25, .14); bottom: -180px; right: -100px; animation-delay: -7s; }
@keyframes orbitar { from { transform: translate(0, 0) scale(1); } to { transform: translate(60px, 40px) scale(1.15); } }

.hero-inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.35fr 1fr; gap: 56px; align-items: center; }
.hero h1 { margin-bottom: .35em; }
.hero h1 .palavra { display: inline-block; opacity: 0; transform: translateY(36px) rotate(2deg); animation: subir .9s var(--transicao) forwards; }
@keyframes subir { to { opacity: 1; transform: none; } }

.hero-selo {
    display: inline-flex; align-items: center; gap: 9px;
    background: var(--vidro-forte); border: 1px solid var(--linha);
    padding: 8px 18px; border-radius: 99px; font-size: .82rem; margin-bottom: 22px;
    color: var(--texto-suave); box-shadow: var(--sombra-suave);
}
.hero-selo::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: var(--vermelho-vivo); box-shadow: 0 0 10px rgba(200, 38, 25, .8); animation: pulsar 2.2s infinite; }
@keyframes pulsar { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: .45; transform: scale(.72); } }

.hero-sub { font-size: 1.18rem; color: var(--texto-suave); margin-bottom: 34px; max-width: 560px; }
.hero-sub-destaque {
    font-family: var(--fonte-titulo); font-weight: 700; color: var(--azul);
    background: var(--grad-marca);
    -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
    border-bottom: 2px solid rgba(65, 80, 224, .35);
    transition: border-color .3s;
}
.hero-sub-destaque:hover { border-color: var(--vermelho-vivo); text-decoration: none; }

.hero-cartao {
    background: var(--vidro); border: 1px solid rgba(255, 255, 255, .9);
    border-radius: var(--raio-g); padding: 32px;
    backdrop-filter: blur(22px); -webkit-backdrop-filter: blur(22px);
    box-shadow: var(--sombra-alta);
    position: relative; overflow: hidden;
}
.hero-cartao::before { content: ''; position: absolute; top: 0; left: 8%; right: 8%; height: 2.5px; border-radius: 99px; background: var(--grad-marca); }
.hero-cartao h2 { font-size: .92rem; margin-bottom: 16px; color: var(--texto-apagado); font-weight: 600; text-transform: uppercase; letter-spacing: .14em; }
.hero-cartao ul { list-style: none; }
.hero-cartao li {
    padding: 12px 0; border-bottom: 1px solid var(--linha);
    display: flex; align-items: center; gap: 13px; font-weight: 500;
    transition: padding-left .3s var(--transicao);
}
.hero-cartao li:hover { padding-left: 8px; }
.hero-cartao li:last-child { border-bottom: none; }
.hero-cartao li::before {
    content: ''; width: 22px; height: 22px; border-radius: 7px; flex-shrink: 0;
    background: linear-gradient(135deg, rgba(65, 80, 224, .16), rgba(200, 38, 25, .14));
    border: 1px solid rgba(65, 80, 224, .3);
}

/* ---------- Produto protagonista no hero: foto livre, sem card ---------- */
.hero-produto {
    position: relative; display: flex; flex-direction: column;
    align-items: center; justify-content: center; text-decoration: none;
    isolation: isolate;
}
/* Aura de luz da marca atrás do produto, deixando o canvas visível ao redor */
.hero-produto::before {
    content: ''; position: absolute; z-index: -1;
    width: 120%; aspect-ratio: 1; border-radius: 50%;
    background: radial-gradient(circle,
        rgba(65, 80, 224, .16) 0%,
        rgba(200, 38, 25, .10) 38%,
        transparent 68%);
    filter: blur(6px);
    animation: respirar 6s ease-in-out infinite alternate;
}
@keyframes respirar { from { transform: scale(.94); opacity: .8; } to { transform: scale(1.06); opacity: 1; } }
.hero-produto-foto {
    width: min(440px, 100%); height: auto;
    filter: drop-shadow(0 34px 38px rgba(30, 30, 107, .28));
    animation: flutuar 5.5s ease-in-out infinite alternate;
    transition: transform .5s var(--transicao), filter .5s;
}
@keyframes flutuar { from { transform: translateY(0) rotate(-1.2deg); } to { transform: translateY(-16px) rotate(1.2deg); } }
.hero-produto:hover .hero-produto-foto {
    transform: scale(1.045);
    filter: drop-shadow(0 42px 46px rgba(30, 30, 107, .34));
}
.hero-produto-legenda {
    margin-top: 22px; font-family: var(--fonte-titulo); font-weight: 600;
    font-size: 1.02rem; color: var(--texto-suave);
    display: inline-flex; align-items: center; gap: 8px;
    opacity: 0; transform: translateY(6px);
    transition: opacity .4s var(--transicao), transform .4s var(--transicao), color .3s;
}
.hero-produto:hover .hero-produto-legenda { opacity: 1; transform: none; color: var(--azul); }
@media (hover: none) { .hero-produto-legenda { opacity: 1; transform: none; } }

/* ---------- Tabela de especificações técnicas ---------- */
.tabela-especificacoes {
    width: 100%; border-collapse: collapse; margin-bottom: 1.6em;
    background: var(--vidro-forte); border: 1px solid var(--linha);
    border-radius: 14px; overflow: hidden; box-shadow: var(--sombra-suave);
}
.tabela-especificacoes th, .tabela-especificacoes td {
    padding: 13px 18px; text-align: left; border-bottom: 1px solid var(--linha); font-size: .95rem;
}
.tabela-especificacoes tr:last-child th, .tabela-especificacoes tr:last-child td { border-bottom: none; }
.tabela-especificacoes th { color: var(--texto); font-family: var(--fonte-titulo); font-weight: 600; width: 42%; background: rgba(65, 80, 224, .04); }
.tabela-especificacoes td { color: var(--texto-suave); }

.hero-indicador {
    position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%);
    z-index: 2; color: var(--texto-apagado); font-size: .72rem; letter-spacing: .22em;
    text-transform: uppercase; display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.hero-indicador::after {
    content: ''; width: 1.5px; height: 34px;
    background: linear-gradient(var(--azul-vivo), transparent);
    animation: descer 1.8s ease-in-out infinite;
}
@keyframes descer { 0% { transform: scaleY(0); transform-origin: top; } 50% { transform: scaleY(1); transform-origin: top; } 51% { transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }

/* ---------- Marquee de segmentos ---------- */
.marquee { overflow: hidden; border-block: 1px solid var(--linha); padding: 20px 0; background: #fff; position: relative; }
.marquee::before, .marquee::after { content: ''; position: absolute; top: 0; bottom: 0; width: 120px; z-index: 2; pointer-events: none; }
.marquee::before { left: 0; background: linear-gradient(90deg, #fff, transparent); }
.marquee::after { right: 0; background: linear-gradient(-90deg, #fff, transparent); }
.marquee-faixa { display: flex; gap: 38px; width: max-content; animation: deslizar 36s linear infinite; }
.marquee:hover .marquee-faixa { animation-play-state: paused; }
@keyframes deslizar { to { transform: translateX(-50%); } }
/* Ticker tipográfico: texto corrido de letreiro, sem aparência de botão */
.marquee-item {
    display: inline-flex; align-items: center; gap: 38px; white-space: nowrap;
    font-family: var(--fonte-titulo); font-weight: 600; font-size: 1.05rem;
    text-transform: uppercase; letter-spacing: .16em; color: var(--texto-apagado);
    transition: color .3s;
}
.marquee-item:hover { color: var(--azul); text-decoration: none; }
.marquee-item::before { content: '◆'; font-size: .5rem; color: var(--vermelho-vivo); opacity: .75; }

/* ---------- Seções ---------- */
.secao { padding: 96px 0; position: relative; }
.secao-clara { background: linear-gradient(180deg, var(--fundo-2), #fff); border-block: 1px solid var(--linha); }
.rotulo-secao {
    display: inline-flex; align-items: center; gap: 10px;
    color: var(--vermelho-vivo); font-family: var(--fonte-titulo); font-weight: 700;
    text-transform: uppercase; letter-spacing: .18em; font-size: .76rem; margin-bottom: 14px;
}
.rotulo-secao::before { content: ''; width: 28px; height: 2px; border-radius: 99px; background: var(--grad-marca); }

.cabecalho-pagina {
    position: relative; padding: 84px 0 60px; overflow: hidden;
    background: linear-gradient(135deg, var(--azul-profundo) 0%, var(--azul) 70%, #3A3AA8 100%);
    color: #fff;
}
.cabecalho-pagina::before {
    content: ''; position: absolute; width: 560px; height: 560px; border-radius: 50%;
    background: rgba(200, 38, 25, .3); filter: blur(130px); top: -240px; right: -140px;
    animation: orbitar 12s ease-in-out infinite alternate;
}
.cabecalho-pagina::after {
    content: ''; position: absolute; inset: 0; pointer-events: none;
    background-image:
        linear-gradient(rgba(255, 255, 255, .05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, .05) 1px, transparent 1px);
    background-size: 48px 48px;
}
.cabecalho-pagina .container { position: relative; z-index: 1; }
.cabecalho-pagina h1 { font-size: clamp(2.1rem, 5vw, 3.4rem); margin-bottom: .25em; color: #fff; }
.cabecalho-pagina p { color: #D6DAF7; margin: 0; font-size: 1.12rem; max-width: 640px; }
.voltar-produtos { display: inline-flex; align-items: center; gap: 7px; color: #fff; opacity: .82; font-weight: 600; font-size: .9rem; margin-bottom: 16px; transition: opacity .2s, gap .2s; }
.voltar-produtos:hover { opacity: 1; gap: 11px; color: #fff; text-decoration: none; }
.voltar-produtos span { font-size: 1.1rem; line-height: 1; }

/* ---------- Reveal por scroll ---------- */
.revelar { opacity: 0; transform: translateY(34px); transition: opacity .8s var(--transicao), transform .8s var(--transicao); }
.revelar.visivel { opacity: 1; transform: none; }

/* ---------- Grades e cartões glass ---------- */
.grade { display: grid; gap: 22px; margin-top: 34px; }
.grade-2 { grid-template-columns: repeat(2, 1fr); }
.grade-3 { grid-template-columns: repeat(3, 1fr); }

.cartao {
    background: var(--vidro-forte); border: 1px solid var(--linha); border-radius: var(--raio);
    padding: 30px; position: relative; overflow: hidden;
    box-shadow: var(--sombra-suave);
    transition: transform .45s var(--transicao), border-color .45s, box-shadow .45s;
    --mx: 50%; --my: 50%;
}
.cartao::before {
    content: ''; position: absolute; inset: 0; pointer-events: none; opacity: 0;
    background: radial-gradient(420px circle at var(--mx) var(--my), rgba(65, 80, 224, .09), transparent 65%);
    transition: opacity .4s;
}
.cartao:hover { transform: translateY(-7px); border-color: var(--linha-viva); box-shadow: var(--sombra-alta); }
.cartao:hover::before { opacity: 1; }
.cartao p { color: var(--texto-suave); }
/* Cards de produto: flex column para alinhar as ações no rodapé de TODOS os cards,
   independentemente do tamanho da descrição. */
.cartao-produto { display: flex; flex-direction: column; height: 100%; }
/* o flex-column não pode esticar a pílula de categoria nem encolher os blocos de texto */
.cartao-produto .etiqueta { align-self: flex-start; }
.cartao-produto > p:last-of-type { margin-bottom: 0; }
.cartao-produto .cartao-acoes { margin-top: auto; padding-top: 16px; }

.cartao-icone {
    width: 56px; height: 56px; border-radius: 16px; display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem; margin-bottom: 18px;
    background: linear-gradient(135deg, rgba(65, 80, 224, .1), rgba(200, 38, 25, .08));
    border: 1px solid rgba(65, 80, 224, .22);
    transition: transform .4s var(--transicao);
}
.cartao:hover .cartao-icone { transform: scale(1.12) rotate(-6deg); }
.cartao-icone svg { width: 26px; height: 26px; color: var(--azul-profundo); }
.bloco-solucao h2 svg { width: 30px; height: 30px; color: var(--azul-profundo); flex-shrink: 0; }
.icone-secao svg { width: 21px; height: 21px; color: var(--azul-profundo); }
.aba-botao .aba-icone svg { width: 21px; height: 21px; color: var(--azul-profundo); }
.aba-botao.ativa .aba-icone svg { color: #fff; }

.titulo-cartao a { color: var(--texto); }
.titulo-cartao a:hover { color: var(--azul-vivo); text-decoration: none; }

/* ---------- Imagens: thumbs, fotos e figura de produto ---------- */
.cartao-thumb {
    display: block; aspect-ratio: 4 / 3; border-radius: 14px; overflow: hidden;
    background: transparent; border: 0; margin-bottom: 18px; padding: 10px;
}
.cartao-thumb img {
    width: 100%; height: 100%; object-fit: contain;
    transition: transform .5s var(--transicao);
}
.cartao:hover .cartao-thumb img { transform: scale(1.07) rotate(-1.5deg); }

.cartao-foto {
    border-radius: 14px; overflow: hidden; margin-bottom: 18px;
    border: 1px solid var(--linha); aspect-ratio: 16 / 9; background: var(--fundo-2);
}
.cartao-foto img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--transicao); }
.cartao-foto:hover img, .cartao:hover .cartao-foto img { transform: scale(1.05); }
.cartao-foto-larga { aspect-ratio: 21 / 9; margin-bottom: 30px; box-shadow: var(--sombra-alta); }

/* Fotos de produto em alta resolução com fundo transparente: sem card */
.produto-figura {
    display: flex; align-items: center; justify-content: center;
    background: transparent; border: 0; box-shadow: none;
    padding: 10px; margin-bottom: 30px;
}
.produto-figura img {
    max-height: 420px; width: auto; max-width: 100%;
    filter: drop-shadow(0 26px 30px rgba(30, 30, 107, .22));
}

.etiqueta {
    display: inline-block; background: rgba(65, 80, 224, .08); color: var(--azul);
    font-size: .73rem; font-weight: 700; padding: 5px 13px; border-radius: 99px; margin-bottom: 12px;
    border: 1px solid rgba(65, 80, 224, .2); letter-spacing: .04em;
}
.etiqueta-clara { background: rgba(255, 255, 255, .16); color: #fff; border-color: rgba(255, 255, 255, .35); }

.link-seta { font-weight: 600; color: var(--vermelho-vivo); display: inline-flex; align-items: center; gap: 6px; transition: gap .3s var(--transicao), color .3s; }
.link-seta:hover { gap: 12px; color: var(--vermelho); text-decoration: none; }

.grade-selos { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.selo-segmento {
    background: #fff; border: 1px solid var(--linha); border-radius: 99px;
    padding: 12px 24px; font-weight: 600; color: var(--texto-suave); font-size: .94rem;
    font-family: var(--fonte-titulo); box-shadow: var(--sombra-suave);
    transition: all .3s var(--transicao);
}
.selo-segmento:hover { border-color: var(--vermelho-vivo); color: var(--vermelho-vivo); transform: translateY(-3px); box-shadow: 0 14px 30px rgba(200, 38, 25, .16); text-decoration: none; }

/* ---------- Números animados ---------- */
.faixa-numeros { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.faixa-numeros > div {
    text-align: center; padding: 34px 18px; border-radius: var(--raio);
    background: var(--vidro-forte); border: 1px solid var(--linha); position: relative; overflow: hidden;
    box-shadow: var(--sombra-suave);
}
.faixa-numeros > div::after {
    content: ''; position: absolute; bottom: 0; left: 20%; right: 20%; height: 3px;
    background: var(--grad-marca); border-radius: 99px 99px 0 0;
}
.faixa-numeros strong {
    display: block; font-family: var(--fonte-titulo); font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700; line-height: 1.1;
    background: var(--grad-fria); -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
}
.faixa-numeros span { color: var(--texto-suave); font-size: .9rem; }

/* ---------- Painel de vídeo ---------- */
.painel-video {
    position: relative; border-radius: var(--raio-g); overflow: hidden;
    border: 1px solid var(--linha); margin-top: 36px; aspect-ratio: 21 / 9;
    box-shadow: var(--sombra-alta);
    background: linear-gradient(135deg, #10103F, var(--azul-profundo) 60%, #2B1B4E);
}
.painel-video video { width: 100%; height: 100%; object-fit: cover; }
.painel-video-fundo { position: absolute; inset: 0; width: 100%; height: 100%; }
.painel-video-conteudo {
    position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column;
    align-items: center; justify-content: center; text-align: center; padding: 24px;
    background: radial-gradient(ellipse at center, rgba(30, 30, 107, .18), rgba(30, 30, 107, .6));
}
.painel-video-conteudo h3 { font-size: clamp(1.3rem, 3vw, 2rem); color: #fff; }
.painel-video-conteudo p { color: #D6DAF7; max-width: 540px; }

/* ---------- Carrossel de produtos (estilo stories: setas, sem barra) ---------- */
.carrossel-moldura { position: relative; }
.carrossel {
    display: flex; gap: 20px; overflow-x: auto; padding: 34px 6px 24px;
    scroll-snap-type: x mandatory;
    scrollbar-width: none; -ms-overflow-style: none;
}
.carrossel::-webkit-scrollbar { display: none; }
.carrossel .cartao { min-width: clamp(260px, 30vw, 350px); scroll-snap-align: start; }
.carrossel-seta {
    position: absolute; top: 50%; transform: translateY(-50%); z-index: 6;
    width: 52px; height: 52px; border-radius: 50%; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    background: rgba(255, 255, 255, .92); color: var(--azul-profundo);
    border: 1px solid var(--linha);
    box-shadow: 0 10px 28px rgba(30, 30, 107, .22);
    backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
    transition: background .3s, color .3s, transform .25s, opacity .3s, box-shadow .3s;
}
.carrossel-seta svg { width: 24px; height: 24px; }
.carrossel-seta:hover {
    background: var(--azul); color: #fff;
    transform: translateY(-50%) scale(1.08);
    box-shadow: 0 14px 34px rgba(30, 30, 107, .35);
}
.carrossel-seta:focus-visible { outline: 3px solid rgba(65, 80, 224, .45); outline-offset: 2px; }
.seta-anterior { left: -14px; }
.seta-proxima { right: -14px; }
.carrossel-seta[disabled] { opacity: .25; pointer-events: none; }
@media (max-width: 760px) {
    .carrossel-seta { width: 44px; height: 44px; }
    .seta-anterior { left: 4px; }
    .seta-proxima { right: 4px; }
}

/* ---------- Página Seja um Representante ---------- */
.hero-rep {
    position: relative; overflow: hidden; color: #fff;
    background: linear-gradient(125deg, #10103F, #1E1E6B 45%, #3A2A8E 75%, #5A2E8E);
    padding: 84px 0 90px;
}
.hero-rep::before {
    content: ''; position: absolute; inset: 0; pointer-events: none;
    background-image: linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 54px 54px;
    -webkit-mask-image: radial-gradient(ellipse 90% 80% at 60% 20%, #000 30%, transparent 78%);
    mask-image: radial-gradient(ellipse 90% 80% at 60% 20%, #000 30%, transparent 78%);
}
.hero-rep::after {
    content: ''; position: absolute; width: 520px; height: 520px; border-radius: 50%;
    background: rgba(200, 38, 25, .35); filter: blur(130px); top: -220px; right: -120px;
}
.hero-rep .container { position: relative; z-index: 1; display: grid; grid-template-columns: 1.25fr 1fr; gap: 48px; align-items: center; }
.hero-rep .selo-hero {
    display: inline-flex; align-items: center; gap: 8px; margin-bottom: 18px;
    padding: 8px 18px; border-radius: 99px; font-size: .8rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    background: rgba(255, 255, 255, .1); border: 1px solid rgba(255, 255, 255, .25); color: #D6DAF7;
}
.hero-rep h1 { font-size: clamp(2.2rem, 4.6vw, 3.5rem); line-height: 1.08; color: #fff; margin: 0 0 18px; }
.hero-rep h1 em { font-style: normal; color: #FFB1A6; }
.hero-rep .hero-rep-texto p { color: #C9CDEC; font-size: 1.1rem; max-width: 560px; }
.hero-rep .botoes { margin-top: 28px; }
.hero-rep .botao-claro { background: #fff; color: var(--azul-profundo); box-shadow: 0 14px 40px rgba(0,0,0,.3); }
.hero-rep .botao-claro:hover { color: var(--azul); transform: translateY(-2px); }
.cartao-hero-rep {
    background: rgba(255, 255, 255, .08); border: 1px solid rgba(255, 255, 255, .2);
    border-radius: var(--raio); padding: 28px; backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
}
.cartao-hero-rep h3 { color: #fff; margin: 0 0 16px; font-size: 1.05rem; }
.cartao-hero-rep ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 14px; }
.cartao-hero-rep li { display: flex; gap: 12px; align-items: flex-start; color: #D6DAF7; font-size: .95rem; }
.cartao-hero-rep li strong { color: #fff; display: block; font-size: 1.05rem; }
.cartao-hero-rep li svg { width: 22px; height: 22px; flex: 0 0 auto; color: #FFB1A6; margin-top: 2px; }
@media (max-width: 900px) { .hero-rep .container { grid-template-columns: 1fr; } }

/* passos "como funciona" */
.passos-rep { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 30px; }
@media (max-width: 820px) { .passos-rep { grid-template-columns: 1fr; } }
.passo-rep {
    position: relative; padding: 26px 22px 24px; border-radius: var(--raio);
    background: var(--vidro-forte); border: 1px solid var(--linha); box-shadow: var(--sombra-suave);
    transition: transform .4s var(--transicao), box-shadow .4s;
}
.passo-rep:hover { transform: translateY(-6px); box-shadow: 0 20px 46px rgba(30, 30, 107, .14); }
.passo-rep .passo-num {
    display: inline-flex; align-items: center; justify-content: center;
    width: 44px; height: 44px; border-radius: 14px; margin-bottom: 14px;
    font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 1.15rem; color: #fff;
    background: linear-gradient(135deg, var(--azul-profundo), var(--azul));
    box-shadow: 0 8px 20px rgba(30, 30, 107, .3);
}
.passo-rep h3 { margin: 0 0 6px; font-size: 1.05rem; }
.passo-rep p { margin: 0; color: var(--texto-suave); font-size: .92rem; }

/* títulos de etapa dentro do formulário */
.form-etapa {
    display: flex; align-items: center; gap: 12px;
    margin: 26px 0 16px; padding-top: 22px; border-top: 1px solid #EEF1F8;
}
.form-etapa:first-of-type { margin-top: 8px; padding-top: 0; border-top: none; }
.cadeado-campos .form-etapa { grid-column: 1 / -1; }
.form-etapa .etapa-num {
    display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto;
    width: 30px; height: 30px; border-radius: 10px; font-weight: 700; font-size: .85rem; color: #fff;
    background: linear-gradient(135deg, var(--azul-profundo), var(--azul));
}
.form-etapa h3 { margin: 0; font-size: 1rem; color: var(--azul-profundo); }
.form-etapa small { color: #8A91A6; }

/* ---------- Variações de embalagem do produto ---------- */
.variacoes-produto {
    display: flex; flex-direction: column; align-items: flex-start; gap: 12px;
    margin: 14px 0 22px; padding: 14px 16px;
    background: var(--vidro-forte); border: 1px solid var(--linha);
    border-radius: 14px;
}
.variacoes-titulo {
    font-size: .76rem; font-weight: 700; letter-spacing: .6px;
    text-transform: uppercase; color: #7A8095;
}
.variacoes-chips { display: flex; flex-wrap: wrap; gap: 10px; width: 100%; }
.variacao-chip {
    cursor: pointer; font: inherit; font-size: .9rem; font-weight: 600;
    display: inline-flex; align-items: center; gap: 9px;
    padding: 6px 16px 6px 6px; border-radius: 99px;
    border: 1.5px solid var(--linha); background: #FBFCFF; color: var(--texto-suave);
    transition: all .25s var(--transicao);
}
.variacao-thumb {
    width: 38px; height: 38px; object-fit: contain; flex: 0 0 auto;
    background: transparent; border: 0;
    filter: drop-shadow(0 2px 3px rgba(30, 30, 107, .20));
}
.variacao-chip:not(:has(.variacao-thumb)) { padding: 9px 18px; }
.variacao-chip:hover { border-color: var(--azul); color: var(--azul-profundo); transform: translateY(-1px); }
.variacao-chip.ativa {
    border-color: var(--azul); color: #fff;
    background: linear-gradient(135deg, var(--azul-profundo), var(--azul));
    box-shadow: 0 8px 20px rgba(30, 30, 107, .25);
}
#foto-produto { transition: opacity .25s ease; }
.linha-embalagens {
    margin: 10px 0 0; padding: 10px 14px; border-radius: 10px; font-size: .88rem;
    background: #F4F6FE; border: 1px solid var(--linha); color: var(--texto-suave);
}
.linha-embalagens strong { color: var(--azul-profundo); }

/* ---------- Impressão do documento oficial (mesmo conteúdo do PDF) ---------- */
#area-impressao { display: none; }
@media print {
    body.imprimindo-doc > *:not(#area-impressao) { display: none !important; }
    body.imprimindo-doc #area-impressao { display: block !important; }
    body.imprimindo-doc #area-impressao .aba-conteudo { display: block !important; }
    body.imprimindo-doc #area-impressao .revelar { opacity: 1 !important; transform: none !important; }
}

/* ---------- Números da JEFLUB (resultados que se medem) ---------- */
.painel-numeros {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 18px; margin: 34px 0 30px;
}
.numero-card {
    position: relative; overflow: hidden; text-align: left;
    display: flex; align-items: center; gap: 16px;
    background: var(--vidro-forte); border: 1px solid var(--linha);
    border-radius: var(--raio); padding: 24px 22px 28px;
    box-shadow: var(--sombra-suave);
    transition: transform .45s var(--transicao), box-shadow .45s;
}
.numero-card:hover { transform: translateY(-7px); box-shadow: 0 22px 50px rgba(30, 30, 107, .16); }
.numero-icone {
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0; width: 52px; height: 52px; border-radius: 16px;
    background: linear-gradient(135deg, #F4F6FE, #E9EDFB);
    border: 1px solid var(--linha);
    transition: transform .45s var(--transicao);
}
.numero-card:hover .numero-icone { transform: scale(1.12) rotate(-6deg); }
.numero-icone svg { width: 25px; height: 25px; color: var(--azul-profundo); }
.numero-info { display: block; min-width: 0; }
.numero-card strong {
    display: block; font-family: 'Space Grotesk', sans-serif; font-weight: 700;
    font-size: clamp(1.9rem, 3.8vw, 2.5rem); line-height: 1.1; letter-spacing: -.02em;
    background: var(--grad-marca); -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; color: transparent;
}
.numero-card strong.numero-texto { font-size: clamp(1.2rem, 2.4vw, 1.45rem); }
.numero-rotulo { display: block; margin-top: 3px; color: var(--texto-suave); font-size: .88rem; }
.numero-barra {
    position: absolute; left: 14%; right: 14%; bottom: 0; height: 4px;
    border-radius: 99px 99px 0 0; background: var(--grad-marca);
    background-size: 220% 100%; animation: barraVida 4.5s linear infinite;
}
@keyframes barraVida { from { background-position: 0% 0; } to { background-position: 220% 0; } }

/* ---------- Botão Solicitar Cotação (topo) modernizado ---------- */
.menu-cta {
    position: relative; overflow: hidden;
    background: linear-gradient(120deg, var(--vermelho-vivo), #A21B10) !important;
    box-shadow: 0 8px 24px rgba(200, 38, 25, .32);
    border: 0; cursor: pointer; font: inherit; font-weight: 700;
    transition: transform .35s var(--transicao), box-shadow .35s;
}
.menu-cta::after {
    content: ''; position: absolute; top: 0; bottom: 0; width: 44px;
    background: linear-gradient(100deg, transparent, rgba(255, 255, 255, .45), transparent);
    left: -60px; transform: skewX(-18deg);
    animation: brilhoCta 3.6s ease-in-out infinite;
}
@keyframes brilhoCta { 0%, 55% { left: -60px; } 85%, 100% { left: 130%; } }
.menu-cta:hover { transform: translateY(-2px) scale(1.03); box-shadow: 0 12px 32px rgba(200, 38, 25, .45); }

/* botão "Seja um Representante": mesma geometria do CTA, na cor institucional */
.menu .menu-parceiro {
    padding: 12px 22px !important; border-radius: 14px; line-height: 1;
    font-size: .9rem; font-weight: 700; letter-spacing: .02em; white-space: nowrap;
    color: var(--azul-profundo); border: 1.5px solid rgba(42, 42, 144, .4);
    background: linear-gradient(135deg, #F4F6FE, #EDF0FB);
    box-shadow: 0 4px 14px rgba(30, 30, 107, .12);
    transition: all .3s var(--transicao);
}
.menu .menu-parceiro:hover {
    color: var(--azul-profundo); border-color: var(--azul);
    background: linear-gradient(135deg, #EDF1FE, #E3E9FB);
    box-shadow: 0 8px 20px rgba(30, 30, 107, .18);
    transform: translateY(-2px);
}

/* ---------- Pop-up de cotação (anamnese) ---------- */
.modal-acesso .painel-cotar { margin-top: 0; background: #fff; border-radius: var(--raio);
    border: 1px solid var(--linha); padding: 28px; box-shadow: var(--sombra-suave); }
.painel-cotar h2 { font-size: 1.3rem; margin: 0 0 4px; }
.painel-cotar > p { color: var(--texto-suave); font-size: .92rem; margin: 0 0 18px; }
.campo-acesso select {
    width: 100%; padding: 12px 14px; border-radius: 10px; font: inherit;
    border: 1px solid var(--linha); background: #FBFCFF; color: var(--texto);
    transition: border-color .25s, box-shadow .25s;
}
.campo-acesso select:focus { outline: none; border-color: var(--azul); box-shadow: 0 0 0 3px rgba(65, 80, 224, .14); }
/* opções limpas, sem caixa de fundo: texto puro que acende quando marcado */
.canais-contato { display: flex; gap: 6px 22px; flex-wrap: wrap; }
.canais-contato input { position: absolute; opacity: 0; pointer-events: none; }
.canais-contato > label {
    display: inline-flex; align-items: baseline; cursor: pointer;
    padding: 6px 2px; margin: 0; border: none; background: none; box-shadow: none;
    font-size: .93rem; font-weight: 600; line-height: 1.5;
    white-space: normal; text-transform: none; letter-spacing: 0;
    color: var(--texto-suave);
    transition: color .25s;
}
.canais-contato > label span::before {
    content: ''; display: inline-block; width: 9px; height: 9px;
    margin-right: 9px; border-radius: 50%;
    border: 2px solid #C9CFE4; background: transparent;
    transition: all .25s;
}
.canais-contato > label:hover { color: var(--azul-profundo); }
.canais-contato > label:hover span::before { border-color: var(--azul); }
.canais-contato > label:has(input:checked) { color: var(--azul-profundo); font-weight: 700; }
.canais-contato > label:has(input:checked) span::before {
    border-color: var(--azul); background: var(--azul);
    box-shadow: 0 0 0 3px rgba(65, 80, 224, .18);
}

/* ---------- Chips de produtos na cotação (multi-seleção, sem scroll) ---------- */
.chips-produtos { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; margin-top: 6px; }
.chips-produtos > label { position: relative; cursor: pointer; margin: 0; }
.chips-produtos input { position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none; }
.chips-produtos span {
    display: flex; align-items: center; gap: 10px; height: 100%; box-sizing: border-box;
    padding: 12px 14px; border-radius: 13px;
    border: 1.5px solid var(--linha, #E2E8F0); background: #fff;
    color: var(--azul-profundo, #1E1E6B); font-weight: 600; font-size: .9rem; line-height: 1.25;
    transition: border-color .18s, background .18s, color .18s, box-shadow .18s, transform .1s;
}
.chips-produtos span::before {
    content: ''; width: 20px; height: 20px; border-radius: 7px; flex: none;
    border: 2px solid #C7C9EE; background-color: #fff;
    background-position: center; background-repeat: no-repeat; background-size: 13px; transition: all .18s;
}
.chips-produtos > label:hover span { box-shadow: 0 4px 14px rgba(30, 30, 107, .10); border-color: #C7C9EE; }
.chips-produtos > label:active span { transform: scale(.97); }
.chips-produtos input:checked + span {
    border-color: var(--azul-profundo, #1E1E6B); background: var(--azul-profundo, #1E1E6B);
    color: #fff; box-shadow: 0 6px 18px rgba(30, 30, 107, .26);
}
.chips-produtos input:checked + span::before {
    border-color: var(--vermelho, #C82619); background-color: var(--vermelho, #C82619);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5L20 7'/%3E%3C/svg%3E");
}
.chips-produtos input:focus-visible + span { outline: 2px solid var(--azul, #2A2A90); outline-offset: 2px; }
@media (max-width: 560px) {
    .chips-produtos { grid-template-columns: repeat(2, 1fr); gap: 8px; }
    .chips-produtos span { padding: 12px 12px; font-size: .85rem; gap: 8px; }
    .chips-produtos span::before { width: 18px; height: 18px; }
}

/* ---------- Acesso restrito à documentação técnica ---------- */
.painel-cadeado {
    margin-top: 26px; padding: 28px; border-radius: var(--raio);
    background: var(--vidro-forte); border: 1px solid var(--linha);
    box-shadow: var(--sombra-suave);
}
.cadeado-topo { display: flex; gap: 16px; align-items: flex-start; margin-bottom: 14px; }
.cadeado-icone {
    flex: 0 0 auto; width: 52px; height: 52px; border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, #F4F6FE, #E9EDFB);
    border: 1px solid var(--linha); color: var(--azul-profundo);
}
.cadeado-icone svg { width: 26px; height: 26px; }
.cadeado-topo h2 { font-size: 1.25rem; margin: 2px 0 6px; }
.cadeado-topo p { color: var(--texto-suave); margin: 0; font-size: .95rem; }
.cadeado-grade { display: grid; grid-template-columns: 1fr 1.4fr; gap: 18px; margin-top: 14px; }
@media (max-width: 860px) { .cadeado-grade { grid-template-columns: 1fr; } }
.cadeado-cartao {
    background: #fff; border: 1px solid var(--linha); border-radius: 14px;
    padding: 22px; position: relative;
}
.cadeado-cartao h3 { font-size: 1.02rem; margin: 0 0 6px; color: var(--azul-profundo); }
.cadeado-cartao > p { color: var(--texto-suave); font-size: .88rem; margin: 0 0 14px; }
.cadeado-campos { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px; }
@media (max-width: 600px) { .cadeado-campos { grid-template-columns: 1fr; } }
.campo-acesso { display: block; }
.campo-acesso.campo-largo { grid-column: 1 / -1; }
.campo-acesso > span, .campo-radios legend {
    display: block; font-size: .76rem; font-weight: 600; letter-spacing: .4px;
    text-transform: uppercase; color: #7A8095; margin-bottom: 5px;
}
.campo-acesso input[type="text"], .campo-acesso input[type="email"], .campo-acesso input[type="tel"] {
    width: 100%; padding: 12px 14px; border-radius: 10px; font: inherit;
    border: 1px solid var(--linha); background: #FBFCFF; color: var(--texto);
    transition: border-color .25s, box-shadow .25s;
}
.campo-acesso input:focus {
    outline: none; border-color: var(--azul);
    box-shadow: 0 0 0 3px rgba(65, 80, 224, .14);
}
.campo-acesso + .botao { margin-top: 4px; }
.campo-radios { border: none; padding: 0; margin: 0; }
.campo-radios label {
    display: flex; align-items: center; gap: 8px; font-size: .9rem;
    color: var(--texto); padding: 4px 0; cursor: pointer; text-transform: none;
}
.aviso-acesso { padding: 12px 16px; border-radius: 10px; font-size: .92rem; margin: 4px 0 10px; }
.aviso-ok { background: #E9F9EF; color: #14683B; border: 1px solid #BFE8CE; }
.aviso-erro { background: #FDEEEC; color: #9C2114; border: 1px solid #F2C7C1; }
.selo-acesso-liberado {
    display: flex; align-items: center; gap: 9px; flex-wrap: wrap;
    margin: 22px 0 0; padding: 11px 16px; border-radius: 99px; font-size: .88rem;
    background: #E9F9EF; color: #14683B; border: 1px solid #BFE8CE;
}
.selo-acesso-liberado svg { width: 17px; height: 17px; flex: 0 0 auto; }

/* nota de cadeado dentro da aba pública */
.nota-cadeado {
    display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
    margin-top: 26px; padding: 18px 20px; border-radius: 14px;
    background: linear-gradient(135deg, #F4F6FE, #EDF0FB);
    border: 1px dashed rgba(42, 42, 144, .35); color: var(--texto-suave);
    font-size: .92rem;
}
.nota-cadeado svg { width: 22px; height: 22px; color: var(--azul-profundo); flex: 0 0 auto; }
.nota-cadeado span { flex: 1; min-width: 220px; }
.nota-cadeado .botao { padding: 11px 22px; }

/* pop-up de acesso (modal do site) */
.modal-acesso {
    position: fixed; inset: 0; z-index: 99999; display: none;
    align-items: flex-start; justify-content: center;
    padding: 46px 16px; overflow-y: auto;
    background: rgba(10, 12, 34, .58);
    backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.modal-acesso.aberto { display: flex; animation: acessoFundo .25s ease; }
@keyframes acessoFundo { from { opacity: 0; } }
.modal-acesso-caixa {
    position: relative; width: min(680px, 100%);
    animation: acessoEntra .45s cubic-bezier(.22, 1, .36, 1);
}
@keyframes acessoEntra { from { opacity: 0; transform: translateY(26px) scale(.98); } }
.modal-acesso .painel-cadeado { margin-top: 0; background: #fff; }
.modal-acesso-fechar {
    position: absolute; top: 14px; right: 14px; z-index: 2;
    width: 40px; height: 40px; border-radius: 12px; cursor: pointer;
    border: 1px solid var(--linha); background: #fff; color: #8A91A6;
    font-size: 1.05rem; transition: color .25s, transform .3s, border-color .25s;
}
.modal-acesso-fechar:hover { color: var(--vermelho-vivo); border-color: #F2C7C0; transform: rotate(90deg); }

/* passo 1 compacto: senha + botão lado a lado */
.linha-senha-acesso { display: flex; gap: 12px; align-items: flex-end; flex-wrap: wrap; }
.linha-senha-acesso .botao { padding: 13px 26px; white-space: nowrap; }

/* passo 2: cadastro recolhido até clicar em "Solicitar acesso" */
.cadeado-divisor {
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
    flex-wrap: wrap; margin: 16px 0; padding: 0 4px; color: var(--texto-suave); font-size: .92rem;
}
.cadeado-divisor .botao { padding: 11px 22px; }
.cadeado-cadastro { display: none; animation: acessoEntra .4s cubic-bezier(.22, 1, .36, 1); }
.cadeado-cadastro.aberto { display: block; }
.cadeado-cartao + .cadeado-divisor { margin-top: 18px; }

/* ---------- Vídeo demonstrativo nos cartões de solução ---------- */
.cartao-video {
    margin: -30px -30px 20px; overflow: hidden; position: relative;
    border-radius: var(--raio) var(--raio) 0 0;
    background: linear-gradient(135deg, #EEF1FB, #E3E7F7);
}
.cartao-video video {
    display: block; width: 100%; aspect-ratio: 16 / 9; object-fit: cover;
}
.cartao-video::after {
    content: ''; position: absolute; inset: 0; pointer-events: none;
    background: linear-gradient(180deg, transparent 72%, rgba(255, 255, 255, .25));
}
.cartao-produto { transform-style: preserve-3d; }

/* ---------- Soluções ---------- */
.bloco-solucao {
    display: grid; grid-template-columns: 1.1fr 1fr; gap: 38px;
    padding: 42px 0; border-bottom: 1px solid var(--linha); scroll-margin-top: 130px;
}
.bloco-solucao:last-child { border-bottom: none; }
.bloco-solucao h2 { display: flex; align-items: center; gap: 14px; }
.bloco-solucao p { color: var(--texto-suave); }
.mini-produto {
    display: block; background: #fff; border: 1px solid var(--linha); border-radius: 14px;
    padding: 16px 20px; margin-bottom: 12px; border-left: 3px solid var(--vermelho-vivo);
    box-shadow: var(--sombra-suave);
    transition: transform .35s var(--transicao), border-color .35s, box-shadow .35s;
}
.mini-produto strong { display: block; color: var(--texto); font-family: var(--fonte-titulo); }
.mini-produto span { font-size: .88rem; color: var(--texto-suave); }
.mini-produto:hover { transform: translateX(8px); border-color: var(--linha-viva); border-left-color: var(--vermelho-vivo); box-shadow: var(--sombra-alta); text-decoration: none; }

/* ---------- Catálogo de produtos: busca + filtros por categoria ---------- */
.catalogo-barra { display: flex; flex-wrap: wrap; align-items: center; gap: 14px 24px; margin-bottom: 16px; }
.catalogo-busca { position: relative; flex: 1 1 280px; min-width: 220px; }
.catalogo-busca svg { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); width: 18px; height: 18px; color: #8A91A6; pointer-events: none; }
.catalogo-busca input { width: 100%; padding: 13px 16px 13px 44px; border: 1.5px solid var(--linha); border-radius: 99px; font: inherit; font-size: .95rem; background: #fff; transition: border-color .2s, box-shadow .2s; }
.catalogo-busca input:focus { outline: none; border-color: var(--azul); box-shadow: 0 0 0 4px rgba(42, 42, 144, .12); }
.catalogo-filtro { position: relative; flex: 0 0 auto; }
.catalogo-filtro-botao { cursor: pointer; font: inherit; font-size: .92rem; font-weight: 600; display: inline-flex; align-items: center; gap: 9px; padding: 12px 18px; border-radius: 99px; border: 1.5px solid var(--linha); background: #fff; color: var(--azul-profundo); transition: all .2s var(--transicao); }
.catalogo-filtro-botao:hover { border-color: var(--azul); }
.catalogo-filtro.aberto .catalogo-filtro-botao { border-color: var(--azul); box-shadow: 0 0 0 4px rgba(42, 42, 144, .12); }
.catalogo-filtro-botao svg { width: 18px; height: 18px; flex: 0 0 auto; }
.filtro-txt-curto { display: none; }
.filtro-chevron { transition: transform .2s; }
.catalogo-filtro.aberto .filtro-chevron { transform: rotate(180deg); }
.filtro-contador { font-size: .72rem; font-weight: 700; min-width: 18px; text-align: center; padding: 1px 7px; border-radius: 99px; background: var(--vermelho-vivo); color: #fff; }
.catalogo-filtro-menu { position: absolute; top: calc(100% + 8px); right: 0; z-index: 40; width: 300px; max-width: 88vw; max-height: 60vh; overflow-y: auto; background: #fff; border: 1px solid var(--linha); border-radius: 16px; box-shadow: var(--sombra-alta); padding: 8px; }
.filtro-menu-topo { display: flex; align-items: center; justify-content: space-between; padding: 8px 10px 6px; border-bottom: 1px solid var(--linha); margin-bottom: 4px; }
.filtro-menu-topo strong { font-size: .74rem; text-transform: uppercase; letter-spacing: .5px; color: #7A8095; }
.filtro-limpar { cursor: pointer; font: inherit; font-size: .8rem; font-weight: 700; color: var(--vermelho-vivo); background: none; border: 0; padding: 2px 6px; }
.filtro-opcao { display: flex; align-items: center; gap: 11px; padding: 10px; border-radius: 10px; cursor: pointer; transition: background .15s; }
.filtro-opcao:hover { background: var(--nevoa); }
.filtro-opcao input { width: 18px; height: 18px; accent-color: var(--azul-profundo); flex: 0 0 auto; cursor: pointer; }
.filtro-opcao-nome { flex: 1; font-size: .9rem; color: var(--texto-suave); }
.filtro-opcao-qtd { font-size: .74rem; font-weight: 700; color: #8A91A6; }
@media (max-width: 560px) {
    .catalogo-barra { flex-wrap: nowrap; gap: 10px; }
    .catalogo-busca { flex: 1 1 auto; min-width: 0; }
    .catalogo-filtro { flex: 0 0 auto; }
    .catalogo-filtro-botao { padding: 12px 15px; }
    /* mobile: rótulo curto "Filtros" (deixa claro que é filtro) + ícone + seta + selo */
    .filtro-txt-longo { display: none; }
    .filtro-txt-curto { display: inline; }
    .catalogo-filtro-menu { right: 0; left: auto; width: 84vw; max-width: 320px; }
}
.catalogo-contador { font-size: .82rem; color: #7A8095; font-weight: 600; margin: 2px 0 18px; }
.catalogo-vazio { text-align: center; color: #7A8095; padding: 40px 0; font-size: 1rem; }

/* ---------- Carrinho de cotação (sem preços) ---------- */
.carrinho-fab { position: fixed; right: 24px; bottom: 24px; z-index: 1200; display: none; align-items: center; gap: 9px; padding: 13px 20px 13px 16px; border: 0; border-radius: 99px; cursor: pointer; background: linear-gradient(135deg, var(--azul-profundo), var(--azul)); color: #fff; font: inherit; font-weight: 700; font-size: .92rem; box-shadow: 0 12px 30px rgba(30, 30, 107, .42); transition: transform .2s, box-shadow .2s; }
.carrinho-fab:hover { transform: translateY(-2px); box-shadow: 0 16px 38px rgba(30, 30, 107, .52); }
.carrinho-fab svg { width: 22px; height: 22px; }
.carrinho-fab-badge { min-width: 22px; height: 22px; padding: 0 6px; border-radius: 99px; background: var(--vermelho-vivo); color: #fff; font-size: .76rem; font-weight: 800; display: inline-flex; align-items: center; justify-content: center; }
.carrinho-fab.pulsa { animation: carrPulso .5s ease; }
@keyframes carrPulso { 0% { transform: scale(1); } 35% { transform: scale(1.13); } 100% { transform: scale(1); } }
/* com itens no carrinho, o carrinho assume o lugar do WhatsApp flutuante (sem sobreposição):
   o WhatsApp some e o carrinho aparece — nunca os dois ao mesmo tempo. */
body.com-carrinho .whatsapp-flutuante { display: none; }
body.com-carrinho .carrinho-fab { display: inline-flex; }

.carrinho-overlay { position: fixed; inset: 0; z-index: 1300; background: rgba(15, 17, 30, .55); }
.carrinho-gaveta { position: fixed; z-index: 1310; top: 0; right: 0; height: 100%; width: 420px; max-width: 92vw; background: #fff; display: flex; flex-direction: column; box-shadow: -20px 0 50px rgba(15, 17, 30, .25); transform: translateX(105%); transition: transform .32s cubic-bezier(.4, 0, .2, 1); }
.carrinho-gaveta.aberta { transform: none; }
.carrinho-topo { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; border-bottom: 1px solid var(--linha); flex: 0 0 auto; }
.carrinho-topo-tit strong { display: block; font-size: 1.1rem; color: var(--azul-profundo); }
.carrinho-topo-tit span { font-size: .8rem; color: var(--texto-apagado); }
.carrinho-fechar { border: 0; background: var(--nevoa); width: 34px; height: 34px; border-radius: 50%; cursor: pointer; font-size: 1rem; color: var(--azul-profundo); flex: 0 0 auto; }
.carrinho-corpo { flex: 1; overflow-y: auto; padding: 14px 16px; }
.carrinho-itens { display: flex; flex-direction: column; gap: 10px; }
.carrinho-item { display: grid; grid-template-columns: 54px 1fr auto auto; align-items: center; gap: 10px; padding: 10px; border: 1px solid var(--linha); border-radius: 14px; }
.carrinho-thumb { width: 54px; height: 54px; display: flex; align-items: center; justify-content: center; }
.carrinho-thumb img { max-width: 100%; max-height: 54px; object-fit: contain; }
.carrinho-thumb-x { width: 40px; height: 40px; border-radius: 8px; background: var(--nevoa); display: block; }
.carrinho-item-info { min-width: 0; }
.carrinho-item-info strong { display: block; font-size: .9rem; color: var(--azul-profundo); line-height: 1.25; }
.carrinho-emb { margin-top: 5px; max-width: 100%; font: inherit; font-size: .8rem; padding: 4px 8px; border: 1px solid var(--linha); border-radius: 8px; background: #fff; color: var(--texto-suave); }
.carrinho-emb-fixa { display: inline-block; margin-top: 5px; font-size: .78rem; color: var(--texto-apagado); }
.carrinho-qtd { display: inline-flex; align-items: center; gap: 2px; border: 1px solid var(--linha); border-radius: 99px; padding: 2px; }
.carrinho-qtd button { width: 26px; height: 26px; border: 0; background: var(--nevoa); border-radius: 50%; cursor: pointer; font-size: 1.05rem; font-weight: 700; color: var(--azul-profundo); line-height: 1; }
.carrinho-qtd span { min-width: 22px; text-align: center; font-weight: 700; font-size: .85rem; }
.carrinho-remover { border: 0; background: none; color: var(--texto-apagado); cursor: pointer; font-size: .82rem; padding: 4px; }
.carrinho-remover:hover { color: var(--vermelho-vivo); }
.carrinho-vazio { text-align: center; padding: 40px 16px; color: var(--texto-apagado); display: flex; flex-direction: column; align-items: center; gap: 8px; }
.carrinho-vazio svg { width: 52px; height: 52px; color: var(--linha-viva); }
.carrinho-vazio strong { color: var(--azul-profundo); font-size: 1rem; }
.carrinho-vazio span { font-size: .85rem; max-width: 240px; }
.carrinho-vazio .botao { margin-top: 8px; }
.carrinho-checkout { padding: 16px; overflow-y: auto; flex: 1; }
.carrinho-checkout h3 { margin: 6px 0 14px; font-size: 1.05rem; color: var(--azul-profundo); }
.carrinho-checkout label { display: block; font-size: .8rem; font-weight: 600; color: var(--texto-suave); margin-bottom: 12px; }
.carrinho-checkout input[type=text], .carrinho-checkout input[type=tel], .carrinho-checkout input[type=email] { width: 100%; margin-top: 5px; padding: 11px 13px; border: 1.5px solid var(--linha); border-radius: 10px; font: inherit; font-size: .95rem; }
.carrinho-checkout input:focus { outline: none; border-color: var(--azul); }
.carrinho-canais { margin: 4px 0; }
.carrinho-canais > span { display: block; font-size: .8rem; font-weight: 600; color: var(--texto-suave); margin-bottom: 6px; }
.carrinho-canais label { display: inline-flex; align-items: center; gap: 6px; font-weight: 600; margin: 0 16px 0 0; }
.carrinho-voltar { border: 0; background: none; color: var(--azul); font: inherit; font-weight: 600; cursor: pointer; padding: 0 0 10px; }
.carrinho-sucesso { text-align: center; padding: 38px 22px; display: flex; flex-direction: column; align-items: center; gap: 8px; }
.carrinho-sucesso-emoji { font-size: 3rem; margin: 0; }
.carrinho-sucesso strong { font-size: 1.2rem; color: var(--azul-profundo); }
.carrinho-sucesso span { color: var(--texto-suave); font-size: .9rem; }
.carrinho-sucesso .botao { margin-top: 8px; width: 100%; }
.carrinho-rodape { padding: 14px 16px; border-top: 1px solid var(--linha); display: flex; align-items: center; gap: 12px; flex: 0 0 auto; }
.carrinho-limpar { border: 0; background: none; color: var(--texto-apagado); font: inherit; font-size: .85rem; font-weight: 600; cursor: pointer; }
.carrinho-limpar:hover { color: var(--vermelho-vivo); }
.carrinho-rodape .botao { flex: 1; }
.carrinho-gaveta[data-passo="itens"] .carrinho-checkout, .carrinho-gaveta[data-passo="itens"] .carrinho-sucesso { display: none; }
.carrinho-gaveta[data-passo="checkout"] .carrinho-corpo, .carrinho-gaveta[data-passo="checkout"] .carrinho-rodape, .carrinho-gaveta[data-passo="checkout"] .carrinho-sucesso { display: none; }
.carrinho-gaveta[data-passo="sucesso"] .carrinho-corpo, .carrinho-gaveta[data-passo="sucesso"] .carrinho-rodape, .carrinho-gaveta[data-passo="sucesso"] .carrinho-checkout { display: none; }
@media (max-width: 640px) {
    .carrinho-gaveta { top: auto; bottom: 0; right: 0; left: 0; width: 100%; max-width: 100%; height: auto; max-height: 90vh; border-radius: 22px 22px 0 0; transform: translateY(105%); }
    .carrinho-gaveta.aberta { transform: none; }
    .carrinho-fab { right: 16px; bottom: 20px; padding: 12px 18px 12px 14px; }
}
/* Catálogo: ações do card — "Ver detalhes" + botão compacto "Adicionar", lado a lado */
.cartao-acoes { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 12px; }
.cartao-acoes .link-seta { margin: 0; }
.add-mini { display: inline-flex; align-items: center; gap: 6px; flex: 0 0 auto; cursor: pointer; font: inherit; font-weight: 700; font-size: .8rem; padding: 7px 14px; border-radius: 99px; border: 1.5px solid var(--azul-profundo); background: #fff; color: var(--azul-profundo); transition: all .18s var(--transicao); white-space: nowrap; }
.add-mini svg { width: 15px; height: 15px; flex: 0 0 auto; }
.add-mini:hover { background: var(--azul-profundo); color: #fff; transform: translateY(-1px); }
.add-mini.feito { background: #047857; border-color: #047857; color: #fff; }

/* Página do produto: CTA sólido e destacado para adicionar à cotação */
.botao-add-cotacao { display: inline-flex; align-items: center; justify-content: center; gap: 9px; width: 100%; cursor: pointer; font: inherit; font-weight: 700; font-size: .95rem; padding: 14px 20px; border-radius: 14px; border: 0; background: linear-gradient(135deg, var(--azul-profundo), var(--azul)); color: #fff; box-shadow: 0 10px 24px rgba(30, 30, 107, .25); transition: all .2s var(--transicao); }
.botao-add-cotacao svg { width: 19px; height: 19px; }
.botao-add-cotacao:hover { transform: translateY(-2px); box-shadow: 0 14px 30px rgba(30, 30, 107, .34); }
.botao-add-cotacao.feito { background: linear-gradient(135deg, #047857, #059669); box-shadow: 0 10px 24px rgba(4, 120, 87, .3); }

/* ---------- Produto / Contato ---------- */
.produto-detalhe { display: grid; grid-template-columns: 1.6fr 1fr; gap: 44px; align-items: start; margin-bottom: 30px; }
/* permite que as colunas do grid encolham: evita que conteúdo largo (fluxograma mermaid,
   tabelas) estoure as margens e derrube a barra lateral. Padrão para TODOS os produtos. */
.produto-detalhe > * { min-width: 0; }
.painel-cotacao {
    background: var(--vidro-forte); border: 1px solid var(--linha); border-radius: var(--raio-g);
    padding: 30px; position: sticky; top: 110px;
    backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
    box-shadow: var(--sombra-alta); border-top: 3px solid transparent;
    background-clip: padding-box;
}
.painel-cotacao::before { content: ''; position: absolute; top: -3px; left: 12px; right: 12px; height: 3px; border-radius: 99px; background: var(--grad-marca); }
.painel-cotacao { position: sticky; }
.painel-cotacao h3 { margin-top: 18px; font-size: .82rem; color: var(--texto-apagado); text-transform: uppercase; letter-spacing: .12em; }
.painel-cotacao p { color: var(--texto-suave); }
.painel-nota { font-size: .85rem; color: var(--texto-apagado); margin-top: 8px; }

/* Títulos de seção do produto: cápsula de ícone + linha de gradiente */
.titulo-secao-prod { display: flex; align-items: center; gap: 13px; margin: 2.1rem 0 1rem; }
.icone-secao {
    width: 44px; height: 44px; border-radius: 13px; flex-shrink: 0;
    display: inline-flex; align-items: center; justify-content: center; font-size: 1.25rem;
    background: linear-gradient(135deg, rgba(65, 80, 224, .1), rgba(200, 38, 25, .08));
    border: 1px solid rgba(65, 80, 224, .22);
}
.titulo-secao-prod::after {
    content: ''; flex: 1; height: 2px; margin-left: 4px; border-radius: 99px;
    background: linear-gradient(90deg, rgba(65, 80, 224, .3), rgba(200, 38, 25, .18), transparent);
}

/* Aplicações e benefícios: grade de mini-cards (adeus, lista de Word) */
.lista-check {
    list-style: none; display: grid; grid-template-columns: repeat(2, 1fr);
    gap: 10px; margin: 0 0 1.6em;
}
.lista-check li {
    position: relative; padding: 13px 16px 13px 48px;
    background: var(--vidro-forte); border: 1px solid var(--linha); border-radius: 13px;
    color: var(--texto-suave); line-height: 1.5; box-shadow: var(--sombra-suave);
    transition: transform .3s var(--transicao), border-color .3s, box-shadow .3s;
}
.lista-check li:hover { transform: translateY(-3px); border-color: var(--linha-viva); box-shadow: var(--sombra-alta); }
.lista-check li::before {
    content: '✓'; position: absolute; left: 14px; top: 13px;
    width: 22px; height: 22px; border-radius: 8px; font-size: .76rem;
    display: flex; align-items: center; justify-content: center;
    color: #fff; background: var(--grad-fria);
}
@media (max-width: 700px) { .lista-check { grid-template-columns: 1fr; } }
.conteudo-texto h2 { margin-top: 1.3em; }
.conteudo-texto p { color: var(--texto-suave); }
.lista-valores { list-style: none; }
.lista-valores li { padding: 12px 0; border-bottom: 1px solid var(--linha); color: var(--texto-suave); }
.lista-valores strong { color: var(--texto); }
.aviso-tecnico { margin-top: 30px; color: var(--texto-apagado); font-size: .92rem; }
.conteudo-artigo { max-width: 780px; }
.conteudo-artigo p { font-size: 1.06rem; }
.caixa-cta-artigo {
    background: var(--fundo-2); border: 1px solid var(--linha); border-radius: var(--raio-g);
    padding: 32px; margin: 36px 0; position: relative; overflow: hidden;
}
.caixa-cta-artigo::before { content: ''; position: absolute; top: 0; left: 0; bottom: 0; width: 4px; background: var(--grad-marca); }

/* ---------- Formulário ---------- */
.formulario { max-width: 660px; }
.campo { margin-bottom: 20px; }
.campo-duplo { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.campo label { display: block; font-weight: 600; margin-bottom: 8px; font-size: .9rem; }
.campo small { font-weight: 400; color: var(--texto-apagado); }
.campo input, .campo textarea {
    width: 100%; padding: 14px 16px; border: 1px solid var(--linha); border-radius: 13px;
    font-family: var(--fonte-texto); font-size: 1rem; color: var(--texto);
    background: #fff; transition: border-color .3s, box-shadow .3s;
}
.campo input:focus, .campo textarea:focus {
    outline: none; border-color: var(--azul-vivo);
    box-shadow: 0 0 0 4px rgba(65, 80, 224, .13);
}
.campo-honeypot { position: absolute; left: -9999px; opacity: 0; }
.alerta { padding: 15px 19px; border-radius: 13px; margin-bottom: 16px; border: 1px solid transparent; }
.alerta-sucesso { background: #E7F6EC; color: #1D5E2C; border-color: #BFE5CB; }
.alerta-erro { background: #FCEAE7; color: #8C2418; border-color: #F2C7C0; }

/* ---------- CTA final ---------- */
.cta-final {
    position: relative; padding: 100px 0; overflow: hidden; color: #fff;
    background: linear-gradient(135deg, var(--azul-profundo) 0%, var(--azul) 55%, #5A2E8E 100%);
}
.cta-final::before {
    content: ''; position: absolute; width: 620px; height: 620px; border-radius: 50%;
    background: rgba(200, 38, 25, .42); filter: blur(130px);
    right: -180px; top: -200px; animation: orbitar 12s ease-in-out infinite alternate;
}
.cta-final::after {
    content: ''; position: absolute; inset: 0; pointer-events: none;
    background-image:
        linear-gradient(rgba(255, 255, 255, .05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, .05) 1px, transparent 1px);
    background-size: 48px 48px;
}
.cta-final .container { position: relative; z-index: 1; }
.cta-final h2 { font-size: clamp(1.8rem, 4vw, 3rem); color: #fff; }
.cta-final p { color: #D6DAF7; max-width: 600px; margin-inline: auto; }
.cta-final .botoes { justify-content: center; margin-top: 28px; }
.cta-final .botao-primario { background: #fff; color: var(--azul); box-shadow: 0 14px 40px rgba(0, 0, 0, .3); }
.cta-final .botao-primario:hover { color: var(--azul-profundo); }

/* ---------- Rodapé ---------- */
.rodape { background: var(--azul-profundo); color: #B9BEE5; }
.rodape-grade { display: grid; grid-template-columns: 1.3fr 1fr 1.3fr; gap: 40px; padding: 64px 0 40px; }
.rodape h3 { color: #fff; font-size: .88rem; margin-bottom: 16px; text-transform: uppercase; letter-spacing: .16em; }
.rodape ul { list-style: none; }
.rodape li { padding: 6px 0; font-size: .93rem; }
.rodape a { color: #C9CDEC; transition: color .25s, padding-left .25s; }
.rodape a:hover { color: #fff; text-decoration: none; padding-left: 4px; }
.rodape-texto { font-size: .93rem; margin-top: 16px; }
.rodape-base { border-top: 1px solid rgba(255, 255, 255, .12); padding: 18px 0; font-size: .82rem; color: #8F95C6; }
.rodape-base p { margin: 0; }

/* ---------- WhatsApp flutuante ---------- */
.whatsapp-flutuante {
    position: fixed; right: 24px; bottom: 24px; z-index: 110;
    width: 60px; height: 60px; border-radius: 50%;
    background: #25D366; color: #fff; display: flex; align-items: center; justify-content: center;
    box-shadow: 0 10px 30px rgba(37, 211, 102, .45);
    transition: transform .3s var(--transicao);
}
.whatsapp-flutuante::before {
    content: ''; position: absolute; inset: -6px; border-radius: 50%;
    border: 2px solid rgba(37, 211, 102, .55); animation: eco 2s ease-out infinite;
}
@keyframes eco { from { transform: scale(.85); opacity: 1; } to { transform: scale(1.35); opacity: 0; } }
.whatsapp-flutuante:hover { transform: scale(1.1) rotate(8deg); }

/* ---------- Abas do produto: seletor segmentado de cartões (destaque máximo) ---------- */
.abas {
    display: flex; gap: 14px; flex-wrap: wrap; margin: 6px 0 28px;
}
.aba-botao {
    appearance: none; cursor: pointer; flex: 1 1 180px; min-width: 170px;
    display: flex; align-items: center; gap: 12px; text-align: left;
    background: var(--vidro-forte); border: 1px solid var(--linha); border-radius: 18px;
    padding: 16px 20px; box-shadow: var(--sombra-suave); position: relative; overflow: hidden;
    transition: transform .35s var(--transicao), box-shadow .35s, border-color .35s;
}
.aba-botao .aba-icone {
    width: 44px; height: 44px; border-radius: 13px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center; font-size: 1.25rem;
    background: linear-gradient(135deg, rgba(65, 80, 224, .1), rgba(200, 38, 25, .08));
    border: 1px solid rgba(65, 80, 224, .22);
    transition: transform .35s var(--transicao);
}
.aba-botao strong {
    display: block; font-family: var(--fonte-titulo); font-weight: 700; font-size: .96rem;
    color: var(--texto); line-height: 1.2;
}
.aba-botao small { display: block; color: var(--texto-apagado); font-size: .74rem; margin-top: 2px; }
.aba-botao:hover { transform: translateY(-4px); border-color: var(--linha-viva); box-shadow: var(--sombra-alta); }
.aba-botao:hover .aba-icone { transform: scale(1.1) rotate(-5deg); }
.aba-botao.ativa {
    background: linear-gradient(135deg, var(--azul-profundo) 0%, var(--azul) 70%, #5A2E8E 130%);
    border-color: transparent;
    box-shadow: 0 16px 40px rgba(30, 30, 107, .35);
}
.aba-botao.ativa::after {
    content: ''; position: absolute; top: 0; left: 10%; right: 10%; height: 3px;
    border-radius: 99px; background: linear-gradient(90deg, #FF8A75, #fff);
}
.aba-botao.ativa strong { color: #fff; }
.aba-botao.ativa small { color: #C9CDEC; }
.aba-botao.ativa .aba-icone { background: rgba(255, 255, 255, .14); border-color: rgba(255, 255, 255, .3); }
@media (max-width: 600px) { .aba-botao { flex: 1 1 100%; } }
.botao-doc-acao { padding: 10px 18px !important; font-size: .83rem !important; gap: 7px; }
.botao-doc-acao svg { width: 15px; height: 15px; }
.aba-conteudo { display: none; }
.aba-conteudo.ativa { display: block; animation: abaEntra .45s var(--transicao); }
@keyframes abaEntra { from { opacity: 0; transform: translateY(14px); } }
.aba-acoes { display: flex; justify-content: flex-end; margin-bottom: 6px; }

/* ---------- Páginas de documento (ficha técnica, FISPQ, boletim) ---------- */
.acoes-doc { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; margin-bottom: 18px; }
.btn-acao-doc {
    width: 46px; height: 46px; border-radius: 50%; border: 1px solid var(--linha); background: #fff; color: var(--azul);
    display: inline-flex; align-items: center; justify-content: center; cursor: pointer;
    transition: transform .25s var(--transicao), box-shadow .25s;
}
.btn-acao-doc:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(42, 42, 144, .18); }
.btn-acao-doc svg { width: 18px; height: 18px; }
.btn-acao-doc.quente { background: var(--grad-quente); color: #fff; border: 0; box-shadow: 0 8px 22px rgba(200, 38, 25, .3); }
.btn-acao-doc.zap { color: #1faa53; }

.folha-doc { background: #fff; border-radius: 20px; overflow: hidden; box-shadow: var(--sombra-alta); border: 1px solid var(--linha); }
.folha-doc-topo { display: flex; justify-content: space-between; align-items: center; gap: 18px; padding: 24px 32px 16px; flex-wrap: wrap; }
.folha-doc-topo img { width: 160px; height: auto; }
.folha-doc-topo .contato-doc { text-align: right; font-size: .72rem; color: var(--texto-suave); line-height: 1.55; }
.faixa-doc { height: 9px; background: var(--grad-marca); }
.folha-doc-miolo { padding: 26px 32px 30px; }
.selo-tipo-doc {
    display: inline-block; font-size: .68rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
    color: var(--vermelho-vivo); border: 1px solid #F2C7C0; background: #FCEAE7; border-radius: 99px; padding: 4px 14px; margin-right: 6px;
}
.selo-data-doc {
    display: inline-block; font-size: .68rem; font-weight: 600; color: var(--azul-p, #1E1E6B);
    border: 1px solid var(--nevoa); background: var(--nevoa); border-radius: 99px; padding: 4px 14px;
}
.folha-doc-miolo h1 { font-size: clamp(1.7rem, 4vw, 2.3rem); color: var(--azul-profundo); margin: 8px 0 2px; }
.subtitulo-doc { color: var(--texto-suave); margin-bottom: 20px; }
.rodape-doc {
    margin-top: 26px; padding-top: 14px; border-top: 1px solid var(--nevoa); font-size: .72rem; color: var(--texto-apagado);
    display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap;
}

/* prosa dos documentos (conteúdo do banco) */
.doc-prosa { color: #3a4154; min-width: 0; max-width: 100%; }
.doc-prosa :where(h2) { font-size: 1.35rem; font-weight: 700; color: var(--azul-profundo); margin: 2rem 0 .7rem; position: relative; padding-left: 1rem; font-family: var(--fonte-titulo); }
.doc-prosa :where(h2)::before { content: ''; position: absolute; left: 0; top: .28rem; bottom: .28rem; width: 4px; border-radius: 99px; background: var(--grad-marca); }
.doc-prosa :where(h3) { font-size: 1.02rem; font-weight: 700; color: var(--vermelho-vivo); margin: 1.4rem 0 .5rem; }
.doc-prosa :where(p) { margin: .55rem 0; line-height: 1.7; }
.doc-prosa :where(ul) { list-style: none; padding: 0; margin: .7rem 0; }
.doc-prosa :where(ul li) { position: relative; padding: .28rem 0 .28rem 1.55rem; line-height: 1.6; }
.doc-prosa :where(ul li)::before { content: ''; position: absolute; left: 0; top: .68rem; width: .5rem; height: .5rem; border-radius: .14rem; background: linear-gradient(135deg, var(--azul), var(--vermelho-vivo)); }
.doc-prosa :where(.not-prose li)::before { content: none; }
.doc-prosa :where(.not-prose p, .not-prose li) { padding: 0; margin: 0; }
.doc-prosa :where(table) { width: 100%; border-collapse: collapse; font-size: .92rem; margin: .8rem 0; }
.doc-prosa :where(th, td) { text-align: left; padding: 9px 14px; border-bottom: 1px solid #EEF1F8; }
.doc-prosa :where(th) { color: var(--azul-profundo); background: #F7F9FE; font-weight: 600; width: 42%; }
.doc-prosa .mermaid { background: #fff; border: 1px solid var(--nevoa); border-radius: 1.1rem; padding: 1.3rem; margin: .9rem 0; display: flex; justify-content: center; overflow-x: auto; max-width: 100%; }
.doc-prosa .mermaid svg { max-width: 100%; height: auto; }
.doc-prosa :where(table) { display: block; overflow-x: auto; }

/* impressão: o documento vira A4 limpo, sem o site ao redor */
@media print {
    body { background: #fff !important; }
    body::before, .cabecalho, .rodape, .cta-final, .whatsapp-flutuante, .progresso-scroll,
    .acoes-doc, .hero-indicador, .menu-botao { display: none !important; }
    .secao { padding: 0 !important; }
    .folha-doc { box-shadow: none !important; border: 0 !important; border-radius: 0 !important; }
    .container { width: 100% !important; }
    /* Papel A4 (padrão brasileiro) e proteção contra cortes de conteúdo */
    .doc-prosa div[class*="rounded-2xl"], .doc-prosa div[class*="rounded-3xl"],
    .doc-prosa .mermaid, .doc-prosa tr, .doc-prosa li,
    .lista-check li, .tabela-especificacoes tr, .titulo-secao-prod,
    .produto-figura, .folha-doc-topo, .rodape-doc {
        break-inside: avoid !important; page-break-inside: avoid !important;
    }
    h1, h2, h3 { break-after: avoid; page-break-after: avoid; }
    p { orphans: 3; widows: 3; }
    /* grades viram empilhamento na impressão: cada card quebra inteiro */
    .doc-prosa div[class*="grid"], .lista-check { display: block !important; }
    .doc-prosa div[class*="grid"] > div, .lista-check li { margin-bottom: 8px !important; }

    /* Controle de versão do documento: numeração de páginas "X de Y" */
    @page {
        size: A4;
        margin: 14mm 13mm 18mm;
        @bottom-right {
            content: "Página " counter(page) " de " counter(pages);
            font-family: Inter, Arial, sans-serif; font-size: 8.5px; color: #777;
        }
    }

    /* página de produto: imprime apenas o cabeçalho do produto e a aba ativa */
    .abas, .aba-acoes, .painel-cotacao, .link-seta { display: none !important; }
    .produto-detalhe { display: block !important; }
    .cabecalho-pagina { background: none !important; padding: 0 0 14px !important; border-bottom: 2px solid #1E1E6B; }
    .cabecalho-pagina::before, .cabecalho-pagina::after { display: none !important; }
    .cabecalho-pagina h1 { color: #1E1E6B !important; }
    .cabecalho-pagina p { color: #333 !important; }
    .cabecalho-pagina .etiqueta-clara { background: none !important; border: 1px solid #999 !important; color: #333 !important; }
    .produto-figura { padding: 0 !important; margin-bottom: 14px !important; }
    .produto-figura img { max-height: 200px !important; filter: none !important; }
    .revelar { opacity: 1 !important; transform: none !important; }
    .lista-check li { box-shadow: none !important; background: #fff !important; }
    .titulo-secao-prod::after { background: #ddd !important; }
}

/* ---------- Acessibilidade: movimento reduzido ---------- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
    .revelar { opacity: 1; transform: none; }
    html { scroll-behavior: auto; }
}

/* ---------- Responsividade ---------- */
@media (max-width: 1020px) {
    .hero-inner, .produto-detalhe, .bloco-solucao { grid-template-columns: 1fr; }
    .grade-3 { grid-template-columns: repeat(2, 1fr); }
    .faixa-numeros { grid-template-columns: repeat(2, 1fr); }
    .rodape-grade { grid-template-columns: 1fr 1fr; }
    .painel-cotacao { position: static; }
    .hero { min-height: auto; }
    .painel-video { aspect-ratio: 16 / 9; }
}

@media (max-width: 700px) {
    .grade-2, .grade-3, .campo-duplo, .rodape-grade { grid-template-columns: 1fr; }
    .menu-botao { display: inline-flex; }
    .menu { display: none; width: 100%; flex-direction: column; align-items: stretch; gap: 4px; padding: 14px 0; }
    .menu.aberto { display: flex; animation: surgirMenu .4s var(--transicao); }
    @keyframes surgirMenu { from { opacity: 0; transform: translateY(-12px); } }
    .menu a { padding: 13px 14px; border-radius: 12px; }
    .menu-cta { justify-content: center; margin-top: 10px; }
    .cabecalho-inner { flex-wrap: wrap; }
    .marca img { width: 142px; }
    .hero { padding: 64px 0 80px; }
    .secao { padding: 64px 0; }
    .painel-video { aspect-ratio: 4 / 5; }
    .hero-indicador { display: none; }
}

/* ---------- PARIDADE FORÇADA dos botões do menu (fica por último de
   propósito: vence qualquer herança da classe .botao) ---------- */
.menu .menu-cta,
.menu .menu-parceiro {
    box-sizing: border-box;
    padding: 12px 22px !important;
    border-radius: 14px !important;
    font-size: .9rem !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    letter-spacing: .02em !important;
    margin: 0 !important;
    display: inline-flex; align-items: center; justify-content: center;
}
@media (max-width: 860px) {
    .menu .menu-cta, .menu .menu-parceiro { width: 100%; margin-top: 8px !important; }
}
