:root{
  --blue:#1f5b8f; --blue-2:#174667; --blue-3:#e7f0f8; --blue-soft:#f2f7fc;
  --accent:#d98c2b; --ink:#16242f; --body:#33424f; --muted:#5d6e7b;
  --white:#ffffff; --gray:#f4f6f8; --line:#dde5ec;
  --serif:'Source Serif 4',Georgia,serif; --sans:'Open Sans',system-ui,sans-serif;
  --radius:16px; --shadow:0 14px 40px rgba(23,70,103,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:18px}
body{font-family:var(--sans);color:var(--body);background:var(--white);line-height:1.7;font-size:1rem;font-weight:400}
h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);line-height:1.2;font-weight:700}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
section{padding:90px 0}
.eyebrow{display:inline-block;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);font-weight:700;background:var(--blue-3);padding:6px 16px;border-radius:99px;margin-bottom:18px}
.head{max-width:720px;margin:0 auto 56px;text-align:center}
.head h2{font-size:clamp(2rem,4vw,2.9rem);margin-bottom:16px}
.head p{font-size:1.12rem;color:var(--muted)}

/* botões — grandes, alto contraste */
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--blue);color:#fff;padding:17px 34px;border-radius:12px;font-weight:700;font-size:1.08rem;transition:.18s;border:none;cursor:pointer;font-family:var(--sans)}
.btn:hover{background:var(--blue-2);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn svg{width:22px;height:22px}
.btn-accent{background:var(--accent);color:#231405}
.btn-accent:hover{background:#c47e22}
.btn-ghost{background:#fff;color:var(--blue);border:2px solid var(--blue)}
.btn-ghost:hover{background:var(--blue-3);transform:translateY(-2px);box-shadow:none}

/* barra demo */
.demobar{background:var(--blue-2);color:#dce8f3;font-size:.95rem;padding:11px 0;position:sticky;top:0;z-index:60}
.demobar .wrap{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;text-align:center}
.demobar b{color:#fff}
.demobar a{background:#25d366;color:#04210f;padding:8px 18px;border-radius:99px;font-weight:700;font-size:.92rem;white-space:nowrap}

/* topbar contato */
.topbar{background:var(--gray);border-bottom:1px solid var(--line);font-size:.94rem;color:var(--muted)}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:46px;flex-wrap:wrap;gap:10px}
.topbar span{display:inline-flex;align-items:center;gap:8px}
.topbar svg{width:16px;height:16px;color:var(--blue)}
@media(max-width:760px){.topbar{display:none}}

/* header */
header.nav{position:sticky;top:43px;z-index:50;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 2px 14px rgba(23,70,103,.05)}
header.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:88px}
.logo{display:flex;align-items:center;gap:12px}
.logo .mark{width:50px;height:50px;border-radius:14px;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.4rem;font-weight:700;flex:none}
.logo b{font-family:var(--serif);font-size:1.5rem;color:var(--ink);font-weight:700;line-height:1}
.logo small{display:block;font-family:var(--sans);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:3px}
nav ul{display:flex;gap:8px;list-style:none;font-size:1.02rem;font-weight:600}
nav a{display:inline-flex;align-items:center;gap:9px;padding:10px 16px;border-radius:10px;transition:.16s;color:var(--body)}
nav a svg{width:20px;height:20px;color:var(--blue)}
nav a:hover{background:var(--blue-soft)}
nav a.active{background:var(--blue);color:#fff}
nav a.active svg{color:#fff}
.nav-cta{display:inline-flex}
.burger{display:none;font-size:2rem;background:none;border:none;color:var(--blue);cursor:pointer;line-height:1}
@media(max-width:1040px){nav ul,.nav-cta{display:none}.burger{display:block}}
nav.open ul{display:flex;position:absolute;top:88px;left:0;right:0;flex-direction:column;gap:0;background:#fff;border-bottom:1px solid var(--line);padding:12px 26px;box-shadow:var(--shadow)}
nav.open ul li{padding:6px 0}
nav.open ul a{font-size:1.1rem;padding:14px 16px}

/* hero split claro */
.hero{background:linear-gradient(180deg,var(--blue-soft),#fff);padding:70px 0 80px;overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.hero h1{font-size:clamp(2.4rem,4.6vw,3.7rem);color:var(--ink);max-width:15ch}
.hero h1 em{color:var(--blue);font-style:normal}
.hero .lead{font-size:1.28rem;color:var(--body);margin:24px 0 32px;max-width:48ch}
.hero .actions{display:flex;gap:16px;flex-wrap:wrap}
.hero .reassure{margin-top:26px;display:flex;align-items:center;gap:12px;font-size:1rem;color:var(--muted)}
.hero .reassure svg{width:24px;height:24px;color:#1f9d55;flex:none}
.hero-art{position:relative}
.hero-art img{border-radius:24px;box-shadow:var(--shadow);width:100%;height:480px;object-fit:cover}
.hero-art .badge{position:absolute;left:-22px;bottom:34px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 22px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px;max-width:260px}
.hero-art .badge .ic{width:46px;height:46px;border-radius:12px;background:var(--blue-3);color:var(--blue);display:flex;align-items:center;justify-content:center;flex:none}
.hero-art .badge .ic svg{width:26px;height:26px}
.hero-art .badge b{font-family:var(--serif);font-size:1.05rem;color:var(--ink)}
.hero-art .badge span{font-size:.88rem;color:var(--muted);display:block}
@media(max-width:960px){.hero .wrap{grid-template-columns:1fr;gap:40px}.hero-art img{height:360px}.hero-art .badge{left:14px}}

/* faixa confiança */
.trust{background:var(--blue);color:#fff;padding:0}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:40px 26px;text-align:center}
.trust .num{font-family:var(--serif);font-size:2.6rem;font-weight:700;color:#fff}
.trust .lbl{font-size:.98rem;color:#cfe0ef;margin-top:4px}
@media(max-width:720px){.trust .wrap{grid-template-columns:1fr 1fr;gap:30px 16px}}

/* como funciona — steps */
.steps{background:var(--gray)}
.steps .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 26px 30px;position:relative}
.step .n{width:48px;height:48px;border-radius:50%;background:var(--blue);color:#fff;font-family:var(--serif);font-size:1.5rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.step h3{font-size:1.35rem;margin-bottom:8px}
.step p{font-size:1rem;color:var(--muted)}
@media(max-width:900px){.steps .grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.steps .grid{grid-template-columns:1fr}}

/* split sobre */
.split .wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split.rev .wrap{direction:rtl}.split.rev .wrap>*{direction:ltr}
.split img{border-radius:20px;box-shadow:var(--shadow);width:100%;height:440px;object-fit:cover}
.split h2{font-size:clamp(1.9rem,3.4vw,2.6rem);margin-bottom:20px}
.split p{font-size:1.1rem;color:var(--body);margin-bottom:18px}
.split .chk{list-style:none;margin:8px 0 26px}
.split .chk li{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;font-size:1.06rem;color:var(--body)}
.split .chk svg{width:24px;height:24px;color:var(--blue);flex:none;margin-top:3px}
@media(max-width:860px){.split .wrap{grid-template-columns:1fr;gap:36px}.split img{height:320px}.split.rev .wrap{direction:ltr}}

/* cards áreas */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:920px){.cards{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.cards{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:36px 30px;transition:.18s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--blue)}
.card .ic{width:60px;height:60px;border-radius:16px;background:var(--blue-3);color:var(--blue);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.card .ic svg{width:32px;height:32px}
.card h3{font-size:1.45rem;margin-bottom:10px}
.card p{font-size:1.04rem;color:var(--muted)}

/* page hero interno */
.page-hero{background:var(--blue);color:#fff;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;background:rgba(255,255,255,.06)}
.page-hero .wrap{padding:72px 26px;position:relative;z-index:1}
.page-hero h1{color:#fff;font-size:clamp(2.1rem,4.2vw,3.2rem)}
.page-hero p{color:#d2e2f0;font-size:1.18rem;margin-top:14px;max-width:60ch}
.page-hero .crumb{font-size:.96rem;color:#aecae3;margin-bottom:14px}
.page-hero .crumb a:hover{color:#fff}

/* FAQ */
.faq{max-width:840px;margin:0 auto}
details{background:#fff;border:1px solid var(--line);border-radius:14px;padding:6px 26px;margin-bottom:16px;transition:.16s}
details[open]{border-color:var(--blue);box-shadow:var(--shadow)}
summary{font-family:var(--serif);font-size:1.25rem;color:var(--ink);cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:18px;align-items:center;padding:20px 0;font-weight:700}
summary::-webkit-details-marker{display:none}
summary::after{content:'+';color:var(--blue);font-weight:400;font-size:1.9rem;line-height:1;flex:none}
details[open] summary::after{content:'–'}
details .ans{color:var(--body);font-size:1.06rem;padding:0 0 22px}

/* depoimentos */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:880px){.quotes{grid-template-columns:1fr}}
.quote{background:var(--blue-soft);border:1px solid var(--blue-3);border-radius:var(--radius);padding:32px 30px}
.quote .stars{color:var(--accent);letter-spacing:3px;font-size:1.1rem;margin-bottom:14px}
.quote p{font-size:1.1rem;color:var(--ink);line-height:1.55;margin-bottom:16px}
.quote .who{font-size:.95rem;color:var(--muted);font-weight:600}

/* pessoa (equipe — texto) */
.team{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
@media(max-width:780px){.team{grid-template-columns:1fr}}
.person{background:#fff;border:1px solid var(--line);border-top:5px solid var(--blue);border-radius:var(--radius);padding:34px 34px}
.person .mono{width:70px;height:70px;border-radius:18px;background:var(--blue);color:#fff;font-family:var(--serif);font-size:1.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.person h3{font-size:1.55rem;margin-bottom:4px}
.person .oab{font-size:.95rem;color:var(--blue);font-weight:700;margin-bottom:4px}
.person .role{font-size:.86rem;color:var(--accent);font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px}
.person p{font-size:1.04rem;color:var(--body);margin-bottom:16px}
.person .tags{display:flex;flex-wrap:wrap;gap:9px}
.person .tags span{font-size:.85rem;background:var(--blue-soft);border:1px solid var(--blue-3);color:var(--blue);padding:6px 14px;border-radius:99px;font-weight:600}

/* valores */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:820px){.values{grid-template-columns:1fr}}
.value{padding:30px 28px;background:#fff;border:1px solid var(--line);border-radius:var(--radius)}
.value .ic{width:54px;height:54px;border-radius:14px;background:var(--blue-3);color:var(--blue);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.value .ic svg{width:30px;height:30px}
.value h3{font-size:1.35rem;margin-bottom:8px}
.value p{font-size:1.02rem;color:var(--muted)}

/* CTA */
.cta-band{background:linear-gradient(120deg,var(--blue),var(--blue-2));color:#fff;text-align:center}
.cta-band h2{color:#fff;font-size:clamp(2rem,4vw,2.8rem);margin-bottom:16px}
.cta-band p{color:#d6e5f2;font-size:1.18rem;max-width:56ch;margin:0 auto 30px}
.cta-band .actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta-band .btn-ghost{background:transparent;border-color:#fff;color:#fff}
.cta-band .btn-ghost:hover{background:rgba(255,255,255,.12)}

/* contato */
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:56px}
@media(max-width:880px){.contact .wrap{grid-template-columns:1fr;gap:40px}}
.contact .info{list-style:none}
.contact .info li{display:flex;gap:16px;margin-bottom:24px}
.contact .info .ic{width:50px;height:50px;border-radius:14px;background:var(--blue-3);color:var(--blue);display:flex;align-items:center;justify-content:center;flex:none}
.contact .info .ic svg{width:26px;height:26px}
.contact .info b{display:block;font-family:var(--serif);font-size:1.15rem;color:var(--ink)}
.contact .info span{font-size:1.04rem;color:var(--muted)}
form{background:var(--gray);border:1px solid var(--line);border-radius:20px;padding:34px}
form label{display:block;font-size:.95rem;color:var(--ink);font-weight:600;margin:0 0 8px}
form input,form textarea{width:100%;background:#fff;border:2px solid var(--line);border-radius:12px;padding:15px 16px;color:var(--ink);font-family:inherit;font-size:1.05rem;margin-bottom:20px}
form input:focus,form textarea:focus{outline:none;border-color:var(--blue)}
form .btn{width:100%;justify-content:center}
.map{margin-top:46px;border-radius:20px;overflow:hidden;border:1px solid var(--line)}
.map iframe{width:100%;height:320px;border:0;display:block}

/* footer */
footer{background:var(--blue-2);color:#bcd2e5;font-size:1rem;padding:60px 0 30px}
footer .cols{display:grid;grid-template-columns:2fr 1fr 1.3fr;gap:40px;margin-bottom:40px}
footer .flogo{display:flex;align-items:center;gap:12px;margin-bottom:16px}
footer .flogo .mark{width:46px;height:46px;border-radius:12px;background:#fff;color:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.3rem;font-weight:700}
footer .flogo b{color:#fff;font-family:var(--serif);font-size:1.35rem}
footer p{max-width:42ch;color:#bcd2e5}
footer h4{color:#fff;font-family:var(--sans);font-size:.92rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}
footer a{display:flex;align-items:center;gap:9px;margin-bottom:11px;color:#bcd2e5}
footer a svg{width:18px;height:18px;color:#7fb0d6}
footer a:hover{color:#fff}
.legal{border-top:1px solid #285a82;padding-top:26px;font-size:.9rem;color:#8fb2cd;line-height:1.7}
.legal .credit{color:#bcd2e5;margin-top:12px}
.legal .credit a{color:#fff;text-decoration:underline}
@media(max-width:760px){footer .cols{grid-template-columns:1fr;gap:30px}}

/* whatsapp flutuante */
.wa{position:fixed;right:22px;bottom:22px;z-index:80;background:#25d366;color:#04210f;width:66px;height:66px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px rgba(0,0,0,.28);transition:.18s}
.wa:hover{transform:scale(1.08)}
.wa svg{width:34px;height:34px}
