
/* NOVA SAFI — Redesign Institucional */

body{
    margin:0;
    font-family: Arial, Helvetica, sans-serif;
    background:#f4f7fb;
    color:#1a2b3c;
}

header{
    background:#0b3c66;
    color:#fff;
    padding:12px 18px;
    display:flex;
    justify-content:space-between;
    align-items:center;
}

header img{height:40px;}
/* override logo size */
header img.site-logo{height:95px !important; width:auto !important;}

/* Logo principal (estilo mock) */
header img.site-logo{
    height:95px !important;
    width:auto;
    display:block;
    background:#fff;
    padding:10px 14px;
    border-radius:12px;
    box-shadow:0 12px 28px rgba(0,0,0,0.22);
}
@media (max-width: 900px){
  header img.site-logo{height:75px !important; padding:10px 14px;}
}
@media (max-width: 520px){
  header img.site-logo{height:120px !important; padding:12px 14px;}
}

/* Logo principal (mock do Photoshop) */

/* Responsivo */
@media (max-width: 900px){
  
}
@media (max-width: 520px){
  
}
/* Logo grande com fundo branco (conforme mock) */
/* Em telas menores, reduz um pouco */
@media (max-width: 900px){
  }
@media (max-width: 520px){
  header{padding:10px 14px;}
  nav a{margin-left:12px;}
  }


nav a{
    color:#fff;
    text-decoration:none;
    margin-left:20px;
    font-weight:600;
}


/* Banner (com fotos) */
.hero{
    position: relative;
    background-image: url('../assets/banner-family.jpg');
    background-size: cover;
    background-position: center 20%;
    padding: 110px 40px;
    overflow:hidden;
}

.hero::before{
    content:'';
    position:absolute;
    inset:0;
    background: linear-gradient(90deg, rgba(11,60,102,0.92) 0%, rgba(11,60,102,0.72) 45%, rgba(11,60,102,0.35) 100%);
}

.hero > *{
    position: relative;
    z-index: 1;
}

.hero .cta{
    box-shadow: 0 12px 28px rgba(0,0,0,0.25);
}

/* Seção banner secundária */
.banner{
    position: relative;
    border-radius: 18px;
    overflow:hidden;
    min-height: 280px;
    display:flex;
    align-items:center;
    padding: 46px 42px;
    background-size: cover;
    background-position:center 20%;
    box-shadow: 0 14px 34px rgba(0,0,0,0.10);
}

.banner::before{
    content:'';
    position:absolute;
    inset:0;
    background: linear-gradient(90deg, rgba(11,60,102,0.92) 0%, rgba(11,60,102,0.70) 55%, rgba(11,60,102,0.25) 100%);
}

.banner > *{ position:relative; z-index:1; }

.banner h2{
    color:#fff;
    margin:0 0 10px 0;
    font-size: 34px;
    max-width: 720px;
}

.banner p{
    color: rgba(255,255,255,0.92);
    max-width: 640px;
    margin:0 0 18px 0;
    font-size: 16px;
}

.banner .cta{
    background:#ffb400;
    color:#0b3c66;
}


.hero h1{
    font-size:42px;
    max-width:600px;
    margin-bottom:10px;
}

.hero p{
    max-width:520px;
    opacity:0.9;
}

.cta{
    display:inline-block;
    margin-top:20px;
    background:#ffb400;
    color:#0b3c66;
    padding:14px 26px;
    border-radius:30px;
    font-weight:bold;
    text-decoration:none;
}

.section{
    padding:60px 40px;
    background:#fff;
}

.section.alt{
    background:#eef3f8;
}

.grid-3{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:25px;
}

.box{
    background:#fff;
    padding:25px;
    border-radius:14px;
    box-shadow:0 8px 24px rgba(0,0,0,0.06);
}

footer{
    background:#0b3c66;
    color:#fff;
    text-align:center;
    padding:30px;
    margin-top:40px;
}



/* --- Elementos inspirados em seguradoras (topbar, números, diferenciais, atendimento flutuante) --- */
.topbar{
    background:#072a48;
    color:#fff;
    padding:10px 40px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:18px;
    font-size:14px;
}

.topbar .left{
    display:flex;
    align-items:center;
    gap:16px;
    flex-wrap:wrap;
    opacity:0.95;
}

.topbar .pill{
    background:rgba(255,255,255,0.10);
    padding:6px 10px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,0.16);
    font-weight:600;
}

.topbar .actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
}

.topbar a{
    color:#fff;
    text-decoration:none;
    font-weight:700;
}

.topbar .btn-mini{
    background:rgba(255,255,255,0.12);
    padding:8px 12px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,0.18);
}

.topbar .btn-mini.primary{
    background:#ffb400;
    color:#0b3c66;
    border-color:transparent;
}

.stats{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:18px;
    margin-top:18px;
}

.stat{
    background:#fff;
    border-radius:16px;
    padding:22px;
    box-shadow:0 10px 28px rgba(0,0,0,0.06);
}

.stat .num{
    font-size:34px;
    font-weight:900;
    color:#0b3c66;
    line-height:1;
}

.stat .label{
    margin-top:10px;
    color:#29455f;
    font-weight:700;
}

.stat .sub{
    margin-top:6px;
    color:#5a738b;
    font-size:14px;
}

.features{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:18px;
    margin-top:18px;
}

.feature{
    background:#fff;
    border-radius:16px;
    padding:20px;
    box-shadow:0 10px 28px rgba(0,0,0,0.06);
    display:flex;
    gap:14px;
    align-items:flex-start;
}

.feature .ico{
    width:44px;
    height:44px;
    border-radius:14px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(11,60,102,0.08);
    color:#0b3c66;
    font-size:20px;
    flex:0 0 auto;
}

.feature h4{
    margin:0 0 6px 0;
    font-size:16px;
    color:#1a2b3c;
}

.feature p{
    margin:0;
    color:#5a738b;
    font-size:14px;
}

/* Atendimento flutuante */
.fab{
    position:fixed;
    right:18px;
    bottom:18px;
    z-index:999;
    display:flex;
    flex-direction:column;
    gap:10px;
    align-items:flex-end;
}

.fab button{
    border:none;
    cursor:pointer;
    border-radius:999px;
    padding:12px 16px;
    font-weight:900;
    box-shadow:0 12px 28px rgba(0,0,0,0.18);
}

.fab .main{
    background:#ffb400;
    color:#0b3c66;
}

.fab .hint{
    background:#0b3c66;
    color:#fff;
    opacity:0.92;
    font-size:12px;
    padding:10px 14px;
    font-weight:800;
}

.modal-overlay{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,0.45);
    display:none;
    align-items:center;
    justify-content:center;
    z-index:1000;
    padding:18px;
}

.modal{
    width:min(560px, 100%);
    background:#fff;
    border-radius:18px;
    overflow:hidden;
    box-shadow:0 18px 60px rgba(0,0,0,0.25);
}

.modal header{
    background:#0b3c66;
    color:#fff;
    padding:16px 18px;
    display:flex;
    justify-content:space-between;
    align-items:center;
}

.modal header h3{
    margin:0;
    font-size:16px;
}

.modal header .close{
    background:rgba(255,255,255,0.14);
    border:1px solid rgba(255,255,255,0.22);
    color:#fff;
    border-radius:12px;
    padding:8px 10px;
    cursor:pointer;
}

.modal .content{
    padding:18px;
}

.modal .grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
    gap:12px;
}

.modal a{
    text-decoration:none;
    display:block;
    border:1px solid rgba(11,60,102,0.14);
    border-radius:16px;
    padding:14px;
    background:#fff;
}

.modal a:hover{
    background:#eef3f8;
}

.modal .title{
    font-weight:900;
    color:#0b3c66;
}

.modal .desc{
    margin-top:6px;
    color:#5a738b;
    font-size:13px;
}



/* --- Ajustes de legibilidade (Hero) --- */
.hero h1,
.hero p{
    color:#ffffff;
}

.hero h1{
    text-shadow: 0 2px 18px rgba(0,0,0,0.45);
}

.hero p{
    opacity: 0.95;
    text-shadow: 0 2px 14px rgba(0,0,0,0.40);
}

/* Degradê um pouco mais forte para texto ficar sempre visível */
.hero::before{
    background: linear-gradient(90deg, rgba(11,60,102,0.94) 0%, rgba(11,60,102,0.78) 48%, rgba(11,60,102,0.42) 100%);
}

/* --- Logo no topo --- */
/* Pequeno refinamento de botões/links */
nav a{
    transition: background 0.2s ease, transform 0.05s ease;
}
nav a:hover{
    transform: translateY(-1px);
}
.cta{
    transition: transform 0.08s ease, box-shadow 0.2s ease;
}
.cta:hover{
    transform: translateY(-1px);
    box-shadow: 0 14px 30px rgba(0,0,0,0.20);
}

/* Melhor respiro em telas pequenas */
@media (max-width: 900px){
    .hero{
        padding: 86px 22px;
    }
    header{
        padding: 16px 18px;
        flex-wrap: wrap;
        gap: 10px;
    }
    nav a{
        margin-left: 12px;
    }
}


/* ====== V5 PREMIUM UI ====== */
.fade-in{
    opacity:0;
    transform: translateY(16px);
    animation: fadeInUp 0.7s ease forwards;
}
@keyframes fadeInUp{
    to{opacity:1; transform: translateY(0);}
}

.planos{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
    gap:24px;
    margin-top:28px;
}
.plano{
    background:#ffffff;
    border-radius:20px;
    padding:28px;
    box-shadow:0 16px 42px rgba(0,0,0,0.08);
    border:1px solid rgba(11,60,102,0.06);
    transition:transform .15s ease, box-shadow .2s ease;
}
.plano:hover{
    transform: translateY(-6px);
    box-shadow:0 20px 55px rgba(0,0,0,0.14);
}
.plano h3{margin:0 0 10px 0; color:#0b3c66;}
.plano ul{padding-left:18px; color:#45627b;}

.diferenciais{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:20px;
    margin-top:24px;
}
.diferencial{
    background:#f7fbff;
    border-radius:16px;
    padding:22px;
    border:1px solid rgba(11,60,102,0.08);
}

.depoimentos{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:22px;
    margin-top:24px;
}
.depo{
    background:#fff;
    border-radius:18px;
    padding:24px;
    box-shadow:0 14px 34px rgba(0,0,0,0.08);
}
.depo strong{color:#0b3c66;}

.whatsapp-float{
    position:fixed;
    left:18px;
    bottom:18px;
    background:#25d366;
    color:#fff;
    border-radius:999px;
    padding:10px 14px;
    font-weight:900;
    box-shadow:0 14px 30px rgba(0,0,0,0.25);
    text-decoration:none;
    z-index:999;
}



/* --- PRO MASTER: Ajuste do banner (evita cortar cabeças) --- */
.hero{
    background-position: center 18% !important;
}
@media (max-width: 900px){
    .hero{
        background-position: center 10% !important;
    }
}
@media (max-width: 520px){
    .hero{
        background-position: center 6% !important;
    }
}



/* ====== V6 PRO MASTER ====== */
html{scroll-behavior:smooth}

.topbar{
    position:relative;
    z-index:60;
}

header{
    position:sticky;
    top:44px; /* abaixo da topbar */
    z-index:59;
    background: rgba(11,60,102,0.88);
    backdrop-filter: blur(10px);
    border-bottom:1px solid rgba(255,255,255,0.10);
}

@media (max-width: 820px){
    header{ top: 56px; }
}

.hero{
    padding: 120px 40px 96px 40px;
}

.hero h1{
    font-size: 48px;
    letter-spacing: -0.6px;
    max-width: 720px;
}

.hero p{
    font-size: 17px;
    max-width: 620px;
}

.section{
    position:relative;
}

.section::before{
    content:'';
    position:absolute;
    left:40px;
    right:40px;
    top:0;
    height:1px;
    background: linear-gradient(90deg, rgba(11,60,102,0.0), rgba(11,60,102,0.12), rgba(11,60,102,0.0));
}

.section:first-of-type::before{
    display:none;
}

.box{
    border:1px solid rgba(11,60,102,0.06);
}

.cta{
    font-size: 15px;
    padding: 15px 28px;
}

/* CTA duplo no hero */
.hero-actions{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
    margin-top:22px;
}
.hero-actions .cta.secondary{
    background: rgba(255,255,255,0.14);
    color:#fff;
    border:1px solid rgba(255,255,255,0.22);
}
.hero-actions .cta.secondary:hover{
    box-shadow: 0 14px 30px rgba(0,0,0,0.18);
}

/* Números com visual premium */
.stats .stat{
    border:1px solid rgba(11,60,102,0.08);
}
.stats .num{
    display:flex;
    align-items:baseline;
    gap:6px;
}
.stats .num small{
    font-size:14px;
    opacity:0.8;
    font-weight:800;
}

/* Ajustes mobile */
@media (max-width: 900px){
    .hero{ padding: 92px 18px 72px 18px; }
    .section::before{ left:18px; right:18px; }
    .hero h1{ font-size: 36px; }
}


/* Evita conflito visual entre botões flutuantes */
.whatsapp-float{
    bottom: 92px;
}



/* =========================
   Base Layout / Components
   ========================= */
*{box-sizing:border-box}
a{color:#0b3c66}
a:hover{opacity:0.9}

.container{
    max-width:1100px;
    margin:0 auto;
    padding:0 40px;
}

@media (max-width: 900px){
  .container{padding:0 18px;}
}

/* Topbar */
.topbar{
    background:#072a48;
    color:#fff;
    padding:10px 0;
    font-size:14px;
}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:18px;}

.topbar .left{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.topbar .pill{
    background:rgba(255,255,255,0.10);
    padding:6px 10px;border-radius:999px;
    border:1px solid rgba(255,255,255,0.16);
    font-weight:700;
}
.topbar .actions{display:flex;gap:10px;flex-wrap:wrap;}
.topbar a{color:#fff;text-decoration:none;font-weight:800}
.topbar .btn-mini{
    padding:8px 12px;border-radius:999px;
    border:1px solid rgba(255,255,255,0.18);
    background:rgba(255,255,255,0.10);
}
.topbar .btn-mini.primary{
    background:#ffb400;color:#0b3c66;border-color:transparent;
}

/* Nav (subpáginas) */
.nav{
    position:sticky;
    top:44px;
    z-index:60;
    background: rgba(11,60,102,0.92);
    backdrop-filter: blur(10px);
    border-bottom:1px solid rgba(255,255,255,0.10);
}
.nav-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:14px 0;
    gap:18px;
}
.brand img{height:58px; width:auto; display:block}

/* ===== LOGO BOOST NAS SUBPÁGINAS (Benefícios/Coberturas/Dúvidas/Contato) ===== */
.nav .brand img{
  height:110px;
  background: rgba(255,255,255,0.96);
  padding:10px 14px;
  border-radius:14px;
  box-shadow: 0 10px 22px rgba(0,0,0,0.20), 0 0 0 2px rgba(255,255,255,0.70);
  filter: drop-shadow(0 6px 14px rgba(0,0,0,0.22));
}
@media (max-width: 520px){
  .nav .brand img{height:54px; padding:8px 12px; border-radius:12px;}
}

.menu{display:flex;gap:18px;flex-wrap:wrap}
.menu a{
    color:#fff;text-decoration:none;
    font-weight:800;
    opacity:0.95;
    padding:10px 10px;border-radius:999px;
}
.menu a:hover{background:rgba(255,255,255,0.10)}
.menu a.active{background:rgba(255,255,255,0.14)}
.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* Buttons */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    padding:12px 16px;
    border-radius:999px;
    font-weight:900;
    text-decoration:none;
    border:1px solid rgba(255,255,255,0.18);
    background:rgba(255,255,255,0.10);
    color:#fff;
}
.btn:hover{transform: translateY(-1px)}
.btn-primary{background:#ffb400;color:#0b3c66;border-color:transparent}
.btn-green{background:#14b86a;border-color:transparent;color:#08321c}
.cta{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    padding:14px 22px;
    border-radius:999px;
    font-weight:900;
    text-decoration:none;
    background:#ffb400;
    color:#0b3c66;
    border:none;
}

/* Sections */
.section{
    padding:46px 0;
}
.section.alt{
    background:#eef3f8;
}
.section h2{
    margin:0 0 8px 0;
    color:#0b3c66;
    letter-spacing:-0.2px;
}
.section p{color:#5a738b; margin:0 0 14px 0}

/* Page hero (subpages) */
.page-hero{
    padding:44px 0 28px 0;
    background: radial-gradient(1200px 400px at 10% 0%, rgba(11,60,102,0.18), rgba(11,60,102,0.00)),
                linear-gradient(180deg, rgba(11,60,102,0.08), rgba(11,60,102,0));
}
.breadcrumb{
    font-size:13px;
    color:#5a738b;
    display:flex;
    gap:8px;
    align-items:center;
}
.breadcrumb a{color:#0b3c66;text-decoration:none;font-weight:800}
.page-title{
    margin:10px 0 8px 0;
    font-size:40px;
    letter-spacing:-0.6px;
}
.page-lead{
    max-width:720px;
    font-size:16px;
    color:#45627b;
}

@media (max-width: 900px){
  .page-title{font-size:32px;}
}

/* Cards / Panels */
.card, .panel{
    background:#fff;
    border-radius:18px;
    padding:22px;
    box-shadow:0 14px 34px rgba(0,0,0,0.08);
    border:1px solid rgba(11,60,102,0.06);
}
.section-wrap{padding:26px 0 46px 0}
.split2{
    display:grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap:22px;
    align-items:start;
}
@media (max-width: 900px){
  .split2{grid-template-columns:1fr;}
}

/* Lists */
.biglist{list-style:none;padding:0;margin:0}
.biglist li{
    display:flex;gap:14px;
    padding:14px 0;
    border-top:1px solid rgba(11,60,102,0.08);
}
.biglist li:first-child{border-top:none}
.biglist .mark{
    width:36px;height:36px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;
    background:rgba(11,60,102,0.08);
    color:#0b3c66;
    font-weight:900;
    flex:0 0 auto;
}
.biglist b{color:#0b3c66}
.biglist span{display:block;color:#5a738b;margin-top:4px}

/* Badges / kicker */
.kicker{
    display:inline-block;
    font-weight:900;
    letter-spacing:1.2px;
    color:#0b3c66;
    opacity:0.8;
    font-size:12px;
}

/* FAQ (details/summary) */
.faq details{
    background:#fff;
    border:1px solid rgba(11,60,102,0.10);
    border-radius:14px;
    padding:14px 16px;
    box-shadow:0 10px 24px rgba(0,0,0,0.06);
}
.faq details + details{margin-top:12px}
.faq summary{
    cursor:pointer;
    font-weight:900;
    color:#0b3c66;
}
.faq p{margin:10px 0 0 0;color:#5a738b}

/* Forms */
.form{display:grid;gap:10px;margin-top:14px}
.input{
    width:100%;
    padding:12px 14px;
    border-radius:14px;
    border:1px solid rgba(11,60,102,0.14);
    background:#fff;
    outline:none;
}
.input:focus{border-color:rgba(11,60,102,0.42); box-shadow:0 0 0 4px rgba(11,60,102,0.12)}
.small{font-size:13px;color:#5a738b;margin-top:6px}
.p{color:#5a738b}

/* Footer */
.footer{
    background:#eef3f8;
    padding:30px 0;
    border-top:1px solid rgba(11,60,102,0.08);
}
.footer-grid{
    display:grid;
    grid-template-columns: 1.2fr 1fr 1fr;
    gap:18px;
    align-items:start;
}
.footer-grid a{color:#0b3c66;text-decoration:none;font-weight:800}
.footer h4{margin:0 0 10px 0;color:#0b3c66}
.footer p{margin:0;color:#5a738b}
@media (max-width: 900px){
  .footer-grid{grid-template-columns:1fr}
}


/* Accordion (Dúvidas) */
.acc details{
    background:#fff;
    border:1px solid rgba(11,60,102,0.10);
    border-radius:14px;
    padding:14px 16px;
    box-shadow:0 10px 24px rgba(0,0,0,0.06);
}
.acc details + details{margin-top:12px}
.acc summary{
    list-style:none;
    cursor:pointer;
    font-weight:900;
    color:#0b3c66;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:10px;
}
.acc summary::-webkit-details-marker{display:none}
.acc .chev{
    display:inline-flex;
    width:28px;height:28px;
    border-radius:10px;
    align-items:center;justify-content:center;
    background:rgba(11,60,102,0.08);
    color:#0b3c66;
    font-weight:900;
}
.acc .ans{
    margin-top:10px;
    color:#5a738b;
    line-height:1.55;
}


/* V8: alinhamento e grid consistente nas subpáginas */
.page-hero .breadcrumb{margin-top:4px}
.page-hero{border-bottom:1px solid rgba(11,60,102,0.06)}
.nav-inner{padding-left:0;padding-right:0}
.brand{display:flex;align-items:center;gap:12px}
.brand .brand-name{display:flex;flex-direction:column;line-height:1.05}
.brand .brand-name strong{color:#fff;letter-spacing:0.4px}
.brand .brand-name span{color:rgba(255,255,255,0.72);font-size:11px;font-weight:800;letter-spacing:1.1px}
@media (max-width: 900px){
  .menu{gap:10px}
  .menu a{padding:8px 10px}
}


/* ================= V9 FINAL VISUAL MASTER ================= */
.page-hero{
    padding:60px 0 40px 0;
    background: linear-gradient(180deg, rgba(11,60,102,0.18), rgba(11,60,102,0.05));
}
.page-title{
    font-size:44px;
    font-weight:900;
}
.section-wrap{
    padding:60px 0 70px 0;
}
.card, .panel{
    border-radius:22px;
    padding:28px;
}
.card:hover, .panel:hover{
    transform: translateY(-3px);
    transition:0.25s ease;
}
.nav{
    box-shadow:0 8px 24px rgba(0,0,0,0.12);
}
.menu a{
    font-size:15px;
    letter-spacing:0.3px;
}
.biglist li{
    padding:18px 0;
}

.container{max-width:1180px;}


/* V10.1 FIX: padding lateral e blocos dentro do container */
.section{padding:42px 0;}
.section .grid-3, .section .grid-2{margin-top:18px;}
@media (max-width: 768px){
  .container{padding:0 18px;}
  .page-title{font-size:36px;}
}

/* V10.2: override respiro lateral */
.container{padding-left:24px;padding-right:24px;}
@media (max-width: 520px){.container{padding-left:16px;padding-right:16px;}}

/* V10.2: alinhamento e espaçamento das seções da Home */
.section{padding:64px 0;}
.section .section-title{margin-left:0;margin-right:0;}
.section .section-lead{max-width:740px;}


/* V10.3: Menu fixo (sticky) */
header{
  position: sticky;
  top: 0;
  z-index: 9999;
  box-shadow: 0 10px 28px rgba(0,0,0,0.18);
}


/* ===== V11 CLEAN: confiança na Home + limpeza Benefícios ===== */
.section-alt{ background: linear-gradient(180deg, rgba(11,60,102,0.06), rgba(11,60,102,0.02)); }
.cards-grid{ display:grid; gap:22px; }
.cards-3{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 980px){ .cards-3{ grid-template-columns:1fr; } }
.btn{ display:inline-flex; align-items:center; justify-content:center; padding:12px 18px; border-radius:999px; font-weight:800; text-decoration:none; }
.btn-whatsapp{ background:#1DB954; color:#0b1a24; }
.btn-whatsapp:hover{ filter:brightness(0.95); }
.mini-note{ margin-top:12px; font-size:12px; opacity:0.75; }


/* ===== Área do Cliente + Admin (Sistema) ===== */
.badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;font-weight:900;font-size:12px;border:1px solid rgba(11,60,102,0.12);background:#fff}
.dot{width:10px;height:10px;border-radius:999px;display:inline-block}
.badge.ok .dot{background:#1db954}
.badge.warn .dot{background:#ffb400}
.badge.bad .dot{background:#e64545}
.badge.gray .dot{background:#97a6b2}
.table{width:100%;border-collapse:separate;border-spacing:0 10px}
.table th{font-size:12px;text-transform:uppercase;letter-spacing:1.2px;color:#5a738b;text-align:left;padding:6px 10px}
.table td{background:#fff;border:1px solid rgba(11,60,102,0.08);padding:12px 10px}
.table tr td:first-child{border-top-left-radius:14px;border-bottom-left-radius:14px}
.table tr td:last-child{border-top-right-radius:14px;border-bottom-right-radius:14px}
.table .actions{display:flex;gap:8px;flex-wrap:wrap}
.kbd{font-family:ui-monospace, Menlo, Monaco, Consolas, "Liberation Mono","Courier New", monospace;
     font-size:12px;background:rgba(11,60,102,0.06);padding:4px 8px;border-radius:10px;border:1px solid rgba(11,60,102,0.10)}
.alert{background:linear-gradient(180deg, rgba(255,180,0,0.18), rgba(255,180,0,0.06));
       border:1px solid rgba(255,180,0,0.35);padding:14px;border-radius:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width: 900px){.grid2{grid-template-columns:1fr}}

@media (max-width: 520px){}

/* Header buttons: deixa 'Área do Cliente' mais discreto e mantém CTA amarelo em destaque */
header .actions .btn-mini{
  padding:10px 14px;
  border-radius:999px;
}
header .actions .btn-mini:not(.btn-yellow):not(.btn-primary):not(.btn-cta){
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.35);
  color:#fff;
}
header .actions .btn-mini:not(.btn-yellow):not(.btn-primary):not(.btn-cta):hover{
  background:rgba(255,255,255,0.16);
}

header img.site-logo{max-width:420px;}


/* ===== LOGO VISUAL BOOST (mais viva nas páginas internas) ===== */
header img,
.navbar img,
.logo img {
    background: rgba(255,255,255,0.92);
    padding: 10px 14px;
    border-radius: 14px;
    box-shadow:
        0 6px 18px rgba(0,0,0,0.18),
        0 0 0 2px rgba(255,255,255,0.65);
    filter: drop-shadow(0 4px 10px rgba(0,0,0,0.25));
    transition: all .25s ease;
}

header img:hover,
.navbar img:hover,
.logo img:hover {
    transform: translateY(-2px) scale(1.02);
    box-shadow:
        0 10px 24px rgba(0,0,0,0.22),
        0 0 0 2px rgba(255,255,255,0.85);
}



/* ===== AJUSTES PREMIUM: TOPO MAIS RESPIRADO + HIERARQUIA ===== */

/* 1) Barra superior (0800 / Área do Cliente / Solicitar cotação) com respiro lateral */
.topbar, .top-bar, .header-top{
  padding-left: 24px !important;
  padding-right: 24px !important;
}

/* Se existir container interno, centraliza e dá espaçamento */
.topbar .container, .top-bar .container, .header-top .container{
  max-width: 1200px;
  margin: 0 auto;
  padding-left: 24px;
  padding-right: 24px;
}

/* 2) Barra superior um pouco mais baixa (menos “grossa”) */
.topbar, .top-bar, .header-top{
  min-height: 44px;
}
.topbar *, .top-bar *, .header-top *{
  line-height: 1.2;
}

/* 3) Menu principal com leve destaque (mais “premium”) */
header{
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}
nav a{
  margin-left: 20px !important;
  font-weight: 600;
}
@media (max-width: 520px){
  .topbar, .top-bar, .header-top{
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
}



/* ===== 1) HIERARQUIA DE BOTÕES (AMARELO = PRINCIPAL / WHATSAPP = SECUNDÁRIO) ===== */
a[href*="whatsapp"], a[href*="wa.me"], a[href*="api.whatsapp.com"], .btn-whatsapp, .whatsapp{
  background: rgba(255,255,255,0.10) !important;
  border: 1px solid rgba(255,255,255,0.35) !important;
  color: #fff !important;
  box-shadow: none !important;
}
a[href*="whatsapp"]:hover, a[href*="wa.me"]:hover, a[href*="api.whatsapp.com"]:hover,
.btn-whatsapp:hover, .whatsapp:hover{
  background: rgba(255,255,255,0.16) !important;
  transform: translateY(-1px);
}



/* ===== 2) HEADER CONSISTENTE EM TODAS AS PÁGINAS ===== */
header img.site-logo,
.navbar .brand img,
.nav .brand img,
.brand img{
  background: rgba(255,255,255,0.96);
  padding: 10px 14px;
  border-radius: 16px;
  box-shadow: 0 10px 24px rgba(0,0,0,0.22);
  filter: drop-shadow(0 6px 14px rgba(0,0,0,0.25));
}



/* ===== 3) TIPOGRAFIA (LEITURA + PREMIUM) ===== */
body{
  font-size: 16px;
  line-height: 1.55;
}
p, li, .muted, .subtitle{
  line-height: 1.65;
}
h1{ letter-spacing: -0.02em; }
h2{ letter-spacing: -0.01em; }



/* ===== 4) CARDS MAIS "PRO" ===== */
.card, .box, .panel, .feature, .pricing-card, .benefit-card{
  border-radius: 18px;
  box-shadow: 0 14px 30px rgba(0,0,0,0.08);
}
.card .content, .box .content, .panel .content{
  padding: 22px;
}



/* ===== FIX BOTÃO "POSSO TE AJUDAR" TRANSPARENTE ===== */
.posso-ajudar,
.help-button,
.floating-help,
.chat-button{
  background:#22c55e !important;
  color:#fff !important;
  opacity:1 !important;
  backdrop-filter:none !important;
  border:none !important;
  box-shadow:0 10px 25px rgba(0,0,0,0.18);
}

.posso-ajudar:hover,
.help-button:hover,
.floating-help:hover,
.chat-button:hover{
  background:#16a34a !important;
  transform:translateY(-2px);
}



/* ===== FIX DEFINITIVO: BOTÃO FLUTUANTE "POSSO TE AJUDAR" (whatsapp-float) ===== */
a.whatsapp-float{
  background:#22c55e !important;
  border:none !important;
  color:#ffffff !important;
  opacity:1 !important;
  box-shadow:0 12px 28px rgba(0,0,0,0.22) !important;
}
a.whatsapp-float:hover{
  background:#16a34a !important;
  transform:translateY(-2px);
}



/* ===== V2 PREMIUM — Header glass + sticky + microinterações ===== */
header{
  position: sticky;
  top: 0;
  z-index: 1200;
  background: rgba(11, 60, 102, 0.78);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,0.10);
  transition: background .25s ease, box-shadow .25s ease, padding .25s ease;
}

header.scrolled{
  background: rgba(11, 60, 102, 0.88);
  box-shadow: 0 18px 45px rgba(0,0,0,0.22);
}

header img.site-logo{
  height: 54px;
  padding: 10px 14px;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 12px 30px rgba(0,0,0,0.22);
}

@media (max-width: 760px){
  header{ padding: 14px 16px; }
  header img.site-logo{ height: 44px; padding: 8px 10px; border-radius: 12px; }
  nav{ gap: 10px; }
}

/* Cards hover */
.feature, .stat, .card, .plano{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.feature:hover, .stat:hover, .card:hover, .plano:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 44px rgba(0,0,0,0.12);
  border-color: rgba(11,60,102,0.14);
}

/* Hero trust badges */
.hero-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top: 16px;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.14);
  border: 1px solid rgba(255,255,255,0.20);
  color: #fff;
  font-weight: 800;
  letter-spacing: .2px;
}
.badge small{
  font-weight: 700;
  opacity: .92;
}
@media (max-width: 760px){
  .hero-badges{ margin-top: 12px; }
  .badge{ padding: 8px 10px; font-size: 13px; }
}


@media (max-width: 760px){ nav{ flex-wrap: wrap; } nav a{ font-size: 14px; padding: 8px 10px; } }
