:root{
  --petroleo:#123F45;
  --petroleo-2:#0B2B30;
  --petroleo-3:#1B5960;
  --salvia:#A9BDA8;
  --salvia-2:#DDE7D8;
  --salvia-3:#EEF3EA;
  --areia:#F8F5EE;
  --branco:#FFFFFF;
  --texto:#102327;
  --muted:#5D6D70;
  --line:rgba(18,63,69,.16);
  --shadow:0 22px 70px rgba(10,38,42,.17);
  --radius:28px;
  --radius-sm:18px;
  --max:1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--texto);
  background:var(--areia);
  line-height:1.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,select{font:inherit}
.container{width:min(var(--max), calc(100% - 40px)); margin-inline:auto}
.skip-link{position:absolute;left:-999px;top:10px;background:var(--petroleo);color:white;padding:10px 14px;border-radius:8px;z-index:999}
.skip-link:focus{left:10px}

.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(248,245,238,.82);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(18,63,69,.10);
}
.header-grid{height:76px;display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:28px}
.brand{display:inline-flex;align-items:center;gap:12px}
.brand-mark{
  width:44px;height:44px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--petroleo); color:var(--salvia-2);
  font-weight:800;letter-spacing:-.06em;
}
.brand strong{display:block;line-height:1.1}
.brand small{display:block;color:var(--muted);font-size:13px}
.nav{display:flex;gap:22px;color:var(--muted);font-size:14px}
.nav a:hover{color:var(--petroleo)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:10px;border:0;border-radius:999px;
  min-height:52px;padding:0 24px;
  font-weight:800;letter-spacing:-.01em;
  cursor:pointer;transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--petroleo); color:white; box-shadow:0 14px 30px rgba(18,63,69,.24)}
.btn-primary:hover{background:var(--petroleo-2)}
.btn-secondary{background:rgba(255,255,255,.72); color:var(--petroleo); border:1px solid var(--line)}
.btn-small{min-height:42px;padding:0 18px;font-size:14px}
.btn-full{width:100%}

.hero{
  position:relative;overflow:hidden;
  padding:88px 0 64px;
  background:
    radial-gradient(circle at 16% 14%, rgba(169,189,168,.36), transparent 32%),
    linear-gradient(135deg, var(--salvia-3), var(--areia) 45%, #fff 100%);
}
.hero-bg{
  position:absolute;inset:auto -20% -35% 45%;height:720px;
  background:url('/assets/bg-pattern.svg') center/cover no-repeat;
  opacity:.08;transform:rotate(-8deg);border-radius:80px;
}
.hero-grid{position:relative;display:grid;grid-template-columns:1.02fr .78fr;gap:62px;align-items:center}
.eyebrow{
  margin:0 0 14px;
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--petroleo-3);font-size:12px;font-weight:900;
}
h1,h2,h3{margin:0;line-height:1.02;letter-spacing:-.045em;color:var(--petroleo-2)}
h1{font-size:clamp(44px, 7vw, 82px);max-width:800px}
h2{font-size:clamp(34px, 4.2vw, 56px)}
h3{font-size:24px}
.lead{
  margin:22px 0 0;
  font-size:clamp(18px,2vw,22px);
  color:#34484C;max-width:650px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}
.trust-row{
  margin-top:34px;display:flex;flex-wrap:wrap;gap:10px;
}
.trust-row span{
  padding:10px 14px;border:1px solid rgba(18,63,69,.15);
  background:rgba(255,255,255,.62);border-radius:999px;
  color:var(--petroleo);font-weight:700;font-size:14px;
}
.hero-card{
  position:relative;isolation:isolate;border-radius:var(--radius);
  padding:12px;background:linear-gradient(145deg, rgba(255,255,255,.95), rgba(221,231,216,.7));
  box-shadow:var(--shadow);
}
.hero-card img{
  width:100%;aspect-ratio:3/4.35;object-fit:cover;border-radius:22px;
  object-position:center top;
}
.floating-card{
  position:absolute;left:-28px;bottom:40px;
  max-width:260px;background:rgba(255,255,255,.92);
  backdrop-filter:blur(18px);border:1px solid rgba(18,63,69,.12);
  box-shadow:0 18px 40px rgba(10,38,42,.18);
  border-radius:22px;padding:18px;
}
.floating-card strong{display:block;color:var(--petroleo);font-size:18px}
.floating-card span{display:block;color:var(--muted);font-size:14px;margin-top:4px}


.icon{
  width:48px;height:48px;border-radius:16px;
  background:var(--salvia-2);display:grid;place-items:center;
  color:var(--petroleo);font-weight:900;margin-bottom:26px;
}
.pain-card p{color:var(--muted);margin:16px 0 24px}
.pain-card a{margin-top:auto;color:var(--petroleo);font-weight:900}

.split{display:grid;grid-template-columns:1fr .46fr;gap:54px;align-items:start}
.check-list{list-style:none;padding:0;margin:26px 0;display:grid;gap:14px}
.check-list li{
  position:relative;padding-left:36px;color:#233E42;font-weight:650;
}
.check-list li:before{
  content:"";position:absolute;left:0;top:2px;width:24px;height:24px;
  border-radius:50%;background:var(--salvia);
}
.check-list li:after{
  content:"";position:absolute;left:8px;top:9px;width:8px;height:4px;
  border-left:2px solid var(--petroleo);border-bottom:2px solid var(--petroleo);
  transform:rotate(-45deg);
}
.mini-disclaimer{
  padding:16px 18px;background:rgba(18,63,69,.06);
  border-left:4px solid var(--salvia);
  border-radius:14px;color:#45595D;
}
.offer-card{
  background:var(--petroleo);color:white;border-radius:var(--radius);
  padding:32px;box-shadow:var(--shadow);position:sticky;top:104px;
}
.offer-card h3{color:white;margin-top:10px}
.offer-card p,.offer-card .muted{color:rgba(255,255,255,.72)}
.tag{
  display:inline-flex;background:rgba(169,189,168,.22);
  border:1px solid rgba(221,231,216,.24);
  color:var(--salvia-2);padding:8px 12px;border-radius:999px;
  font-size:12px;text-transform:uppercase;font-weight:900;letter-spacing:.08em;
}
.price-note{
  margin:24px 0;padding:18px;border-radius:20px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
}
.price-note small{display:block;color:rgba(255,255,255,.68)}
.price-note strong{display:block;font-size:34px;line-height:1.1;margin-top:4px;color:white}

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.step{
  background:white;border-radius:var(--radius-sm);
  padding:24px;border:1px solid var(--line);
}
.step span{
  width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:var(--petroleo);color:white;font-weight:900;margin-bottom:22px;
}
.step h3{font-size:20px}
.step p{color:var(--muted);font-size:15px}

.authority{background:var(--petroleo-2);color:white;overflow:hidden;position:relative}
.authority:before{
  content:"";position:absolute;inset:0;background:url('/assets/bg-pattern.svg') center/cover no-repeat;opacity:.07;
}
.authority-grid{position:relative;display:grid;grid-template-columns:.55fr 1fr;gap:60px;align-items:center}
.authority h2,.authority h3{color:white}
.authority .section-text{color:rgba(255,255,255,.72)}
.authority .eyebrow{color:var(--salvia-2)}
.authority-photo img{border-radius:var(--radius);box-shadow:0 30px 80px rgba(0,0,0,.28);object-fit:cover}
.credential-box{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:30px 0;
}
.credential-box div{
  padding:18px;border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.07);border-radius:18px;
}
.credential-box strong{display:block;color:var(--salvia-2);font-size:12px;text-transform:uppercase;letter-spacing:.09em}
.credential-box span{display:block;margin-top:6px;color:white;font-weight:800}

.conversion-grid{display:grid;grid-template-columns:.78fr 1fr;gap:50px;align-items:start}
.whatsapp-box{
  margin-top:28px;padding:24px;border-radius:var(--radius-sm);
  background:white;border:1px solid var(--line);
}
.whatsapp-box h3{font-size:24px}
.whatsapp-box p{color:var(--muted)}
.lead-form{
  background:white;border-radius:var(--radius);border:1px solid var(--line);
  padding:28px;box-shadow:0 18px 55px rgba(18,63,69,.10);
}
.lead-form label{display:grid;gap:8px;margin-bottom:16px;font-weight:800;color:var(--petroleo)}
.lead-form input,.lead-form select{
  width:100%;min-height:52px;border:1px solid rgba(18,63,69,.18);
  border-radius:14px;padding:0 14px;background:#FAFCF8;color:var(--texto);
}
.lead-form input:focus,.lead-form select:focus{outline:3px solid rgba(169,189,168,.45);border-color:var(--petroleo)}
.lead-form small{display:block;color:var(--muted);font-size:12px;margin-top:14px}
.hidden{display:none}

.faq-grid{display:grid;grid-template-columns:.42fr 1fr;gap:48px}
.faq-list{display:grid;gap:12px}
details{
  background:white;border:1px solid var(--line);border-radius:18px;padding:18px 20px;
}
summary{font-weight:900;color:var(--petroleo);cursor:pointer}
details p{color:var(--muted);margin-bottom:0}

.final-cta{padding:0 0 92px}
.final-card{
  background:linear-gradient(135deg, var(--petroleo), #1e676f);
  color:white;border-radius:34px;padding:42px;
  display:flex;align-items:center;justify-content:space-between;gap:32px;
  box-shadow:var(--shadow);
}
.final-card-content{max-width:860px}
.final-card h2{color:white;max-width:840px}
.final-card p{color:rgba(255,255,255,.82);margin-bottom:0;max-width:860px}
.final-card .eyebrow{color:var(--salvia-2)}
.final-contact-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:22px}
.final-contact-chip{
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);
  border-radius:18px;padding:14px 18px;min-width:210px;
  backdrop-filter:blur(3px);
}
.final-contact-chip strong{display:block;color:white;font-size:13px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}
.final-contact-chip span{display:block;color:rgba(255,255,255,.92);font-weight:700}
.final-card-actions{display:flex;flex-direction:column;align-items:flex-end;gap:14px;min-width:280px}
.final-badge{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:999px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
  color:#fff;font-size:13px;font-weight:800;letter-spacing:.02em;text-align:center;
}
.final-card-actions .btn{min-width:220px;text-align:center}

.footer{background:#071D20;color:rgba(255,255,255,.72);padding:34px 0}
.footer-grid{display:flex;align-items:flex-start;justify-content:space-between;gap:28px}
.footer strong{display:block;color:white}
.footer span{display:block}

.sticky-whatsapp{
  position:fixed;right:18px;bottom:18px;z-index:80;
  width:74px;height:74px;display:flex;align-items:center;justify-content:center;
  background:transparent;border-radius:0;
  box-shadow:none;
  transition:transform .22s ease, filter .22s ease;
}
.sticky-whatsapp:hover{transform:translateY(-2px) scale(1.03);filter:drop-shadow(0 10px 18px rgba(0,0,0,.20))}
.sticky-whatsapp img{width:56px;height:56px;display:block;object-fit:contain;filter:drop-shadow(0 8px 16px rgba(0,0,0,.16))}

.reveal{opacity:0;transform:translateY(18px);transition:opacity .65s ease, transform .65s ease}
.reveal.is-visible{opacity:1;transform:none}
.delay-1{transition-delay:.1s}.delay-2{transition-delay:.18s}.delay-3{transition-delay:.26s}

@media (max-width: 980px){
  .nav{display:none}
  .header-grid{grid-template-columns:1fr auto}
  .hero{padding-top:54px}
  .hero-grid,.split,.authority-grid,.conversion-grid,.faq-grid{grid-template-columns:1fr}
  .hero-card{max-width:520px;margin-inline:auto}
  .pain-grid,.steps{grid-template-columns:1fr 1fr}
  .offer-card{position:relative;top:auto}
  .credential-box{grid-template-columns:1fr}
  .floating-card{left:18px;bottom:26px}
}

@media (max-width: 640px){
  .container{width:min(100% - 28px, var(--max))}
  .site-header .btn-small{display:none}
  .brand small{font-size:12px}
  .hero-actions{display:grid}
  .pain-grid,.steps{grid-template-columns:1fr}
  .strip-grid,.final-card,.footer-grid{display:grid}
  .text-link{white-space:normal}
  .section{padding:64px 0}
  .final-card{padding:30px;gap:22px}
  .final-card-actions{align-items:stretch;min-width:0}
  .final-card-actions .btn{width:100%;min-width:0}
  .final-badge{text-align:center}
  .final-contact-row{display:grid;gap:12px}
  .final-contact-chip{min-width:0}
  .sticky-whatsapp{left:auto;right:14px;bottom:14px}
}


/* === Correção v3: imagens reais + hero estável === */
.hero{
  padding:112px 0 72px;
}
.hero-grid{
  align-items:center;
}
.hero-copy{
  align-self:center;
}
.hero-card{
  max-width:430px;
  justify-self:end;
  overflow:visible;
}
.hero-card img{
  width:100%;
  height:clamp(520px, 58vw, 680px);
  aspect-ratio:auto;
  object-fit:cover;
  object-position:center center;
}
.authority-photo{
  max-width:420px;
}
.authority-photo img{
  width:100%;
  height:560px;
  object-fit:cover;
  object-position:center top;
}
@media (max-width: 980px){
  .hero{
    padding:86px 0 56px;
  }
  .hero-card{
    justify-self:center;
    max-width:440px;
  }
  .hero-card img{
    height:min(640px, 135vw);
  }
  .authority-photo{
    max-width:440px;
    margin-inline:auto;
  }
  .authority-photo img{
    height:min(620px, 136vw);
  }
}
@media (max-width: 640px){
  .hero{
    padding-top:72px;
  }
  .hero-card img{
    height:560px;
  }
}

/* =========================================================
   Ajuste v4 — Hero com copy mais clara + moldura premium
   Objetivo: explicar osteopatia em linguagem de dor/rotina e
   integrar melhor a foto à primeira dobra da landing page.
========================================================= */
.hero{
  min-height:calc(100vh - 82px);
  display:flex;
  align-items:center;
  padding:96px 0 74px;
  background:
    radial-gradient(circle at 12% 18%, rgba(169,189,168,.42), transparent 30%),
    radial-gradient(circle at 82% 76%, rgba(18,63,69,.08), transparent 34%),
    linear-gradient(135deg, #EEF4EB 0%, #F7F4EC 48%, #FFFFFF 100%);
}
.hero-grid{
  grid-template-columns:minmax(0, .98fr) minmax(360px, .72fr);
  gap:78px;
}
.hero-copy{
  padding-top:8px;
}
.hero .lead{
  max-width:690px;
  margin-top:24px;
  font-size:clamp(18px,1.35vw,21px);
  line-height:1.72;
  color:#2B4549;
}

/* A foto deixa de parecer “quadro colado” e vira um bloco editorial */
.hero-card{
  width:min(100%, 444px);
  max-width:444px;
  min-height:650px;
  justify-self:end;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:40px;
  background:transparent;
  box-shadow:none;
  isolation:isolate;
}
.hero-card::before{
  content:"";
  position:absolute;
  inset:9% -4% 4% 11%;
  z-index:-2;
  border-radius:46px 46px 120px 46px;
  background:
    linear-gradient(155deg, rgba(255,255,255,.78), rgba(221,231,216,.58)),
    radial-gradient(circle at 20% 18%, rgba(169,189,168,.44), transparent 46%);
  border:1px solid rgba(18,63,69,.10);
  box-shadow:0 34px 90px rgba(10,38,42,.15);
}
.hero-card::after{
  content:"";
  position:absolute;
  z-index:-3;
  width:78%;
  height:68%;
  right:-17%;
  bottom:8%;
  border-radius:999px 0 0 999px;
  background:linear-gradient(160deg, rgba(18,63,69,.08), rgba(169,189,168,.13));
  transform:rotate(-7deg);
}
.hero-card picture{
  display:block;
  width:86%;
  transform:translateY(-6px) rotate(.45deg);
  border-radius:34px;
  overflow:hidden;
  background:#fff;
  border:9px solid rgba(255,255,255,.86);
  box-shadow:0 28px 70px rgba(8,35,38,.22);
}
.hero-card img{
  display:block;
  width:100%;
  height:610px;
  aspect-ratio:auto;
  object-fit:cover;
  object-position:50% 35%;
  border-radius:24px;
}
.floating-card{
  left:-4px;
  bottom:42px;
  max-width:276px;
  padding:18px 20px;
  border-radius:24px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(18,63,69,.10);
  box-shadow:0 22px 52px rgba(10,38,42,.16);
}
.floating-card::before{
  content:"";
  display:block;
  width:34px;
  height:4px;
  border-radius:999px;
  background:var(--salvia);
  margin-bottom:12px;
}
.floating-card strong{
  font-size:18px;
}
.floating-card span{
  line-height:1.55;
}

@media (max-width: 1100px){
  .hero-grid{
    gap:52px;
    grid-template-columns:minmax(0,1fr) minmax(320px,.78fr);
  }
  .hero-card{
    max-width:410px;
    min-height:610px;
  }
  .hero-card img{
    height:570px;
  }
}

@media (max-width: 980px){
  .hero{
    min-height:auto;
    padding:58px 0 68px;
  }
  .hero-grid{
    grid-template-columns:1fr;
    gap:42px;
  }
  .hero-card{
    justify-self:center;
    width:min(100%, 430px);
    max-width:430px;
    min-height:auto;
  }
  .hero-card picture{
    width:88%;
  }
  .hero-card img{
    height:min(620px, 128vw);
  }
  .floating-card{
    left:18px;
    bottom:28px;
  }
}

@media (max-width: 640px){
  .hero{
    padding-top:48px;
  }
  .hero .lead{
    font-size:17px;
    line-height:1.64;
  }
  .hero-card{
    width:min(100%, 360px);
    border-radius:32px;
  }
  .hero-card::before{
    inset:10% -2% 3% 7%;
    border-radius:34px 34px 80px 34px;
  }
  .hero-card picture{
    width:90%;
    border-width:7px;
    border-radius:28px;
  }
  .hero-card img{
    height:min(540px, 142vw);
    border-radius:20px;
    object-position:50% 32%;
  }
  .floating-card{
    left:12px;
    right:12px;
    bottom:18px;
    max-width:none;
    padding:15px 16px;
  }
}


/* =========================================================
   Ajuste v5 — Hero mais humano na copy + foto mais integrada
========================================================= */
.hero .lead{
  max-width:720px;
  margin-top:24px;
  font-size:clamp(18px,1.35vw,21px);
  line-height:1.68;
  color:#2A4549;
}
.hero-card{
  width:min(100%, 456px);
  max-width:456px;
  min-height:0;
  justify-self:end;
  padding:0;
  background:transparent;
  box-shadow:none;
  border-radius:0;
  overflow:visible;
}
.hero-card::before{
  content:"";
  position:absolute;
  inset:7% -2% -5% 8%;
  z-index:-2;
  border-radius:36px 110px 36px 110px;
  background:linear-gradient(160deg, rgba(221,231,216,.98), rgba(238,243,234,.92));
  border:1px solid rgba(18,63,69,.08);
  box-shadow:0 28px 74px rgba(10,38,42,.12);
}
.hero-card::after{
  content:"";
  position:absolute;
  width:120px;
  height:120px;
  right:-10px;
  top:34px;
  z-index:-3;
  border-radius:28px;
  background:linear-gradient(160deg, rgba(18,63,69,.09), rgba(169,189,168,.18));
}
.hero-card picture{
  display:block;
  width:100%;
  border-radius:34px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(18,63,69,.08);
  box-shadow:0 26px 68px rgba(8,35,38,.18);
  transform:none;
}
.hero-card img{
  width:100%;
  height:640px;
  border-radius:34px;
  object-fit:cover;
  object-position:52% 24%;
}
.floating-card{
  left:22px;
  bottom:24px;
  max-width:260px;
  padding:16px 18px;
  border-radius:20px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(18,63,69,.10);
  box-shadow:0 18px 42px rgba(10,38,42,.15);
}
.floating-card::before{
  content:"";
  display:block;
  width:42px;
  height:4px;
  margin-bottom:10px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--petroleo), var(--salvia));
}
.floating-card strong{font-size:17px;color:var(--petroleo)}
.floating-card span{font-size:13px;line-height:1.55;color:var(--muted)}

@media (max-width: 1100px){
  .hero-grid{gap:50px;}
  .hero-card{max-width:418px;}
  .hero-card img{height:592px;}
}

@media (max-width: 980px){
  .hero-card{justify-self:center; width:min(100%, 430px); max-width:430px;}
  .hero-card::before{inset:6% 1% -4% 7%;}
  .hero-card img{height:min(610px, 126vw); object-position:50% 22%;}
  .floating-card{left:16px; bottom:18px;}
}

@media (max-width: 640px){
  .hero .lead{font-size:17px; line-height:1.62;}
  .hero-card{width:min(100%, 360px);}
  .hero-card::before{inset:8% 1% -3% 6%; border-radius:28px 70px 28px 70px;}
  .hero-card::after{width:76px;height:76px;top:18px;right:-4px;border-radius:22px;}
  .hero-card picture{border-radius:26px;}
  .hero-card img{height:min(530px, 138vw); border-radius:26px; object-position:52% 20%;}
  .floating-card{left:12px; right:12px; bottom:14px; max-width:none; padding:14px 15px;}
}


/* =========================================================
   Ajuste v6 — Primeira dobra estilo hero full-screen
   Referência: imagem como background, texto à esquerda, profissional à direita
========================================================= */
body{
  background:var(--areia);
}

.site-header{
  position:absolute;
  top:0;
  left:0;
  right:0;
  z-index:60;
  background:linear-gradient(180deg, rgba(8,26,29,.46), rgba(8,26,29,0));
  backdrop-filter:none;
  border-bottom:0;
  box-shadow:none !important;
}
.site-header .header-grid{
  height:92px;
}
.site-header .brand strong,
.site-header .brand small,
.site-header .nav a{
  color:#fff;
  text-shadow:0 2px 18px rgba(0,0,0,.35);
}
.site-header .brand small{
  opacity:.82;
}
.site-header .brand-mark{
  background:rgba(255,255,255,.14);
  color:#fff;
  border:1px solid rgba(255,255,255,.28);
  backdrop-filter:blur(10px);
}
.site-header .nav a:hover{
  color:var(--salvia-2);
}
.site-header .btn-small{
  background:#fff;
  color:var(--petroleo);
  box-shadow:0 14px 34px rgba(0,0,0,.18);
}
.site-header .btn-small:hover{
  transform:translateY(-2px);
  background:var(--salvia-2);
}

.hero.hero-cover{
  min-height:100vh;
  min-height:100svh;
  padding:0;
  position:relative;
  overflow:hidden;
  color:#fff;
  background:#08262B;
  display:flex;
  align-items:center;
}
.hero-cover-bg{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(90deg,
      rgba(5,20,23,.92) 0%,
      rgba(8,33,37,.84) 28%,
      rgba(8,33,37,.58) 48%,
      rgba(8,33,37,.18) 70%,
      rgba(8,33,37,0) 100%),
    linear-gradient(180deg, rgba(0,0,0,.28) 0%, rgba(0,0,0,0) 24%, rgba(0,0,0,.18) 100%),
    url('/assets/hero-guilherme-osteopatia-wide-v6.webp?v=6');
  background-size:cover;
  background-position:center center;
  transform:scale(1.01);
}
.hero-cover-bg::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 78% 45%, rgba(169,189,168,.12), transparent 28%),
    radial-gradient(circle at 8% 85%, rgba(255,255,255,.08), transparent 26%);
  pointer-events:none;
}
.hero-cover-content{
  position:relative;
  z-index:2;
  width:100%;
  padding-top:110px;
  padding-bottom:70px;
}
.hero-cover .hero-copy{
  max-width:650px;
}
.hero-cover .eyebrow{
  color:var(--salvia-2);
  letter-spacing:.17em;
  font-size:13px;
  margin-bottom:22px;
  text-shadow:0 2px 14px rgba(0,0,0,.35);
}
.hero-cover h1{
  color:#fff;
  font-size:clamp(54px, 6.1vw, 92px);
  line-height:.96;
  letter-spacing:-.065em;
  margin:0 0 26px;
  text-shadow:0 18px 44px rgba(0,0,0,.32);
}
.hero-cover .lead{
  color:rgba(255,255,255,.90);
  max-width:650px;
  margin:0;
  font-size:clamp(18px, 1.3vw, 22px);
  line-height:1.58;
  text-shadow:0 2px 18px rgba(0,0,0,.32);
}
.hero-cover .hero-actions{
  margin-top:34px;
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}
.hero-cover .btn{
  min-height:58px;
  border-radius:10px;
  padding:0 30px;
  font-size:15px;
}
.hero-cover .btn-primary{
  background:#E88A55;
  color:#fff;
  box-shadow:0 18px 38px rgba(232,138,85,.28);
}
.hero-cover .btn-primary:hover{
  background:#F09A67;
  box-shadow:0 24px 46px rgba(232,138,85,.34);
}
.hero-cover .btn-secondary{
  background:rgba(255,255,255,.10);
  color:#fff;
  border-color:rgba(255,255,255,.35);
  backdrop-filter:blur(10px);
}
.hero-cover .btn-secondary:hover{
  background:rgba(255,255,255,.18);
  border-color:rgba(255,255,255,.52);
}
.hero-cover .trust-row{
  margin-top:30px;
}
.hero-cover .trust-row span{
  background:rgba(255,255,255,.10);
  color:#fff;
  border-color:rgba(255,255,255,.26);
  backdrop-filter:blur(10px);
  box-shadow:0 10px 30px rgba(0,0,0,.16);
}
.hero-cover + .pain-strip{
  margin-top:0;
}

@media (max-width: 980px){
  .site-header{
    position:absolute;
  }
  .site-header .nav{
    display:none;
  }
  .site-header .btn-small{
    display:none;
  }
  .site-header .header-grid{
    grid-template-columns:1fr;
    height:82px;
  }
  .hero.hero-cover{
    min-height:820px;
    align-items:flex-end;
  }
  .hero-cover-bg{
    background-position:64% center;
  }
  .hero-cover-bg{
    background-image:
      linear-gradient(180deg,
        rgba(5,20,23,.22) 0%,
        rgba(5,20,23,.12) 34%,
        rgba(5,20,23,.84) 72%,
        rgba(5,20,23,.95) 100%),
      url('/assets/hero-guilherme-osteopatia-wide-v6.webp?v=6');
  }
  .hero-cover-content{
    padding-top:120px;
    padding-bottom:52px;
  }
  .hero-cover .hero-copy{
    max-width:680px;
  }
  .hero-cover h1{
    font-size:clamp(46px, 13vw, 76px);
  }
  .hero-cover .lead{
    max-width:620px;
  }
}

@media (max-width: 640px){
  .site-header .brand-mark{
    width:40px;
    height:40px;
  }
  .site-header .brand strong{
    font-size:15px;
  }
  .site-header .brand small{
    font-size:12px;
  }
  .hero.hero-cover{
    min-height:760px;
  }
  .hero-cover-bg{
    background-position:61% top;
  }
  .hero-cover-content{
    padding-top:108px;
    padding-bottom:42px;
  }
  .hero-cover .eyebrow{
    font-size:11px;
    line-height:1.4;
    letter-spacing:.12em;
    margin-bottom:16px;
  }
  .hero-cover h1{
    font-size:clamp(42px, 15vw, 62px);
    margin-bottom:20px;
  }
  .hero-cover .lead{
    font-size:16px;
    line-height:1.55;
  }
  .hero-cover .hero-actions{
    gap:12px;
    margin-top:26px;
  }
  .hero-cover .btn{
    width:100%;
    justify-content:center;
    min-height:56px;
  }
  .hero-cover .trust-row{
    gap:8px;
    margin-top:22px;
  }
  .hero-cover .trust-row span{
    font-size:11px;
    padding:10px 12px;
  }
}


/* =========================================================
   Ajuste v7 — copy da primeira dobra mais encaixada
   - corrige o container que estava 100% e jogava o texto na borda
   - reduz escala do H1
   - melhora largura de leitura do subtítulo
========================================================= */
.hero-cover-content{
  width:min(var(--max), calc(100% - 64px));
  margin-inline:auto;
  padding-top:clamp(128px, 14vh, 178px);
  padding-bottom:clamp(72px, 9vh, 112px);
  padding-left:clamp(0px, 1.2vw, 18px);
  padding-right:clamp(0px, 1.2vw, 18px);
}

.hero-cover .hero-copy{
  width:min(100%, 610px);
  max-width:610px;
}

.hero-cover .eyebrow{
  font-size:12px;
  letter-spacing:.16em;
  margin-bottom:18px;
}

.hero-cover h1{
  max-width:590px;
  margin:0;
  font-size:clamp(54px, 5.15vw, 84px);
  line-height:.98;
  letter-spacing:-.055em;
  text-wrap:balance;
}

.hero-cover .lead{
  width:min(100%, 570px);
  max-width:570px;
  margin-top:26px;
  font-size:clamp(18px, 1.16vw, 21px);
  line-height:1.58;
  color:rgba(255,255,255,.88);
}

.hero-cover .hero-actions{
  margin-top:32px;
}

.hero-cover .btn{
  min-height:58px;
  padding-inline:30px;
}

.hero-cover .trust-row{
  margin-top:28px;
  max-width:610px;
}

.hero-cover .trust-row span{
  font-size:13px;
  padding:11px 15px;
}

/* melhora a leitura do texto sem escurecer demais o profissional */
.hero.hero-cover::before{
  background:
    linear-gradient(90deg,
      rgba(5,31,36,.92) 0%,
      rgba(5,31,36,.86) 27%,
      rgba(5,31,36,.57) 47%,
      rgba(5,31,36,.18) 68%,
      rgba(5,31,36,.06) 100%
    ),
    linear-gradient(180deg, rgba(5,31,36,.34), rgba(5,31,36,.24));
}

@media (max-width: 1180px){
  .hero-cover-content{
    width:min(100% - 44px, var(--max));
    padding-top:132px;
  }
  .hero-cover .hero-copy{
    max-width:560px;
  }
  .hero-cover h1{
    font-size:clamp(50px, 6vw, 72px);
    max-width:520px;
  }
  .hero-cover .lead{
    max-width:520px;
  }
}

@media (max-width: 760px){
  .hero-cover-content{
    width:min(100% - 28px, var(--max));
    padding-top:118px;
    padding-bottom:58px;
  }
  .hero-cover .hero-copy{
    max-width:100%;
  }
  .hero-cover .eyebrow{
    font-size:10.5px;
    letter-spacing:.13em;
    margin-bottom:14px;
  }
  .hero-cover h1{
    font-size:clamp(42px, 14vw, 58px);
    line-height:1;
    letter-spacing:-.05em;
  }
  .hero-cover .lead{
    margin-top:20px;
    font-size:16.5px;
    line-height:1.52;
    max-width:100%;
  }
  .hero-cover .hero-actions{
    margin-top:24px;
  }
  .hero-cover .btn{
    width:100%;
    justify-content:center;
  }
  .hero-cover .trust-row{
    margin-top:20px;
  }
}


/* =========================================================
   Ajuste v8 — header centralizado + CTA único na hero
========================================================= */
.site-header{
  background:rgba(8,28,31,.42);
  border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
}
.site-header .brand{
  color:#fff;
}
.site-header .brand-mark{
  background:rgba(255,255,255,.14);
  color:#fff;
  border:1px solid rgba(255,255,255,.28);
}
.site-header .brand small{
  color:rgba(255,255,255,.78);
}
.site-header .nav{
  color:rgba(255,255,255,.88);
}
.site-header .nav a:hover{
  color:#fff;
}
.header-grid{
  grid-template-columns:1fr auto 1fr;
}
.header-grid::after{
  content:"";
  display:block;
}
.nav{
  justify-self:center;
  align-items:center;
  gap:34px;
}
.nav a{
  white-space:nowrap;
}
.hero-cover .hero-actions{
  margin-top:34px;
}
.hero-cover .hero-actions .btn-primary{
  min-width:298px;
  min-height:64px;
  padding:0 38px;
  text-transform:uppercase;
  letter-spacing:.02em;
  border-radius:12px;
}
.hero-cover .hero-actions .btn-secondary{
  display:none !important;
}
.hero-cover .trust-row{
  display:none !important;
}

@media (max-width: 980px){
  .header-grid{
    grid-template-columns:1fr;
  }
  .header-grid::after{
    display:none;
  }
  .nav{
    display:none;
  }
}

@media (max-width: 640px){
  .hero-cover .hero-actions .btn-primary{
    min-width:0;
    width:100%;
    min-height:58px;
  }
}


/* =========================================================
   Ajuste solicitado — cabeçalho integrado à hero
   Remove a faixa/linha separada e coloca o menu direto sobre a primeira dobra.
========================================================= */
.site-header{
  position:absolute !important;
  top:0; left:0; right:0;
  z-index:80;
  background:transparent !important;
  backdrop-filter:none !important;
  border-bottom:0 !important;
  box-shadow:none !important;
}
.header-grid{
  height:92px;
}
.header-grid::after,
.site-header::before,
.site-header::after{
  display:none !important;
  content:none !important;
}
.site-header .brand strong,
.site-header .brand small,
.site-header .nav a{
  color:#fff;
}
.site-header .brand small{
  color:rgba(255,255,255,.78);
}
.site-header .brand-mark{
  background:rgba(255,255,255,.14);
  color:#fff;
  border:1px solid rgba(255,255,255,.28);
  backdrop-filter:blur(10px);
}
.site-header .nav a:hover{
  color:var(--salvia-2);
}
.hero.hero-cover{
  padding-top:0;
}
.hero-cover-content{
  padding-top:120px;
}

/* =========================================================
   Ajuste solicitado — seção de benefícios da osteopatia
   Substitui os cards de "buscas" por uma seção mais emocional e conversiva.
========================================================= */
.benefits-section{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 8% 12%, rgba(180,198,176,.22), transparent 30%),
    radial-gradient(circle at 92% 18%, rgba(18,63,69,.08), transparent 28%),
    linear-gradient(180deg, #FCFCF9 0%, #F5F6F2 100%);
}
.benefits-section::before{
  content:"";
  position:absolute;
  inset:90px auto auto -90px;
  width:260px;
  height:260px;
  border-radius:50%;
  background:rgba(169,189,168,.18);
  filter:blur(4px);
}
.benefits-head{
  max-width:960px;
  position:relative;
  z-index:1;
}
.benefits-head h2{
  max-width:980px;
}
.benefits-head p{
  max-width:860px;
}
.benefits-layout{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(320px, .9fr) minmax(0, 1.45fr);
  gap:28px;
  align-items:start;
}
.benefits-story{
  position:sticky;
  top:104px;
  padding:34px;
  background:
    radial-gradient(circle at 100% 100%, rgba(221,231,216,.18), transparent 42%),
    linear-gradient(180deg, rgba(18,63,69,.99), rgba(10,43,48,.98));
  border:1px solid rgba(255,255,255,.08);
  border-radius:32px;
  color:#fff;
  box-shadow:0 26px 70px rgba(8,35,38,.18);
  overflow:hidden;
}
.story-badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  color:var(--salvia-2);
  font-weight:900;
  font-size:12px;
  letter-spacing:.11em;
  text-transform:uppercase;
}
.benefits-story h3{
  color:#fff;
  margin:20px 0 14px;
  font-size:clamp(30px, 2.5vw, 42px);
  letter-spacing:-.055em;
}
.benefits-story p{
  color:rgba(255,255,255,.82);
  line-height:1.72;
  margin:0 0 20px;
  font-size:17px;
}
.story-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:14px;
}
.story-list li{
  position:relative;
  padding-left:32px;
  color:#F4F8F2;
  line-height:1.55;
  font-weight:650;
}
.story-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:7px;
  width:16px;
  height:16px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--salvia-2), #F4FAF1);
  box-shadow:0 0 0 6px rgba(221,231,216,.12);
}
.story-cta-box{
  margin-top:24px;
  padding:22px;
  border-radius:24px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.11);
}
.story-cta-box strong{
  display:block;
  color:#fff;
  line-height:1.55;
  margin-bottom:16px;
}
.story-cta-box .btn{
  width:100%;
  justify-content:center;
}
.benefit-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:18px;
}
.benefit-card{
  background:rgba(255,255,255,.94);
  border:1px solid rgba(18,63,69,.10);
  border-radius:28px;
  padding:30px;
  box-shadow:0 14px 38px rgba(18,63,69,.07);
  min-height:236px;
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.benefit-card:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 48px rgba(18,63,69,.11);
  border-color:rgba(18,63,69,.20);
}
.benefit-icon{
  width:56px;
  height:56px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, #DCE6D8, #F0F5EE);
  color:var(--petroleo);
  font-weight:950;
  font-size:20px;
  margin-bottom:22px;
}
.benefit-card h3{
  font-size:clamp(24px, 2.1vw, 31px);
  line-height:1.08;
  margin-bottom:14px;
  color:#082F35;
}
.benefit-card p{
  color:var(--muted);
  line-height:1.72;
  margin:0;
  font-size:16px;
}
.benefit-card.accent{
  background:
    radial-gradient(circle at 100% 0, rgba(169,189,168,.24), transparent 34%),
    linear-gradient(180deg, #F5F9F3 0%, #FFFFFF 100%);
  border-color:rgba(169,189,168,.50);
}

@media (max-width:1080px){
  .benefits-layout{
    grid-template-columns:1fr;
    gap:22px;
  }
  .benefits-story{
    position:relative;
    top:auto;
  }
}

@media (max-width:980px){
  .site-header{
    position:absolute !important;
  }
  .hero-cover-content{
    padding-top:104px;
  }
  .site-header .nav{
    display:none;
  }
}

@media (max-width:720px){
  .benefit-grid{
    grid-template-columns:1fr;
  }
  .benefits-story,
  .benefit-card{
    padding:24px;
  }
  .benefit-card{
    min-height:auto;
  }
  .benefits-story h3{
    font-size:30px;
  }
}

@media (max-width:640px){
  .header-grid{
    height:82px;
  }
  .hero-cover-content{
    padding-top:92px;
  }
}

/* Ajuste v10 — remove título acima dos benefícios e aproxima a seção */
.benefits-section{padding-top:72px;}
@media (max-width: 720px){
  .benefits-section{padding-top:56px;}
}


/* =========================================================
   v12 — Benefícios em pequenos cards diretos
========================================================= */
.benefits-head-simple{max-width:860px; margin:0 auto 34px; text-align:center;}
.benefits-head-simple p{max-width:760px; margin-inline:auto;}
.mini-benefits-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:18px;
}
.mini-benefit-card{
  background:#fff;
  border:1px solid rgba(18,63,69,.10);
  border-radius:18px;
  padding:24px 20px;
  box-shadow:0 10px 26px rgba(10,38,42,.05);
  text-align:center;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.mini-benefit-card:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 32px rgba(10,38,42,.08);
  border-color:rgba(18,63,69,.18);
}
.mini-benefit-card h3{
  font-size:18px;
  line-height:1.22;
  margin:0 0 10px;
  color:#0A3035;
}
.mini-benefit-card p{
  margin:0;
  color:var(--muted);
  line-height:1.5;
  font-size:15px;
}
.mini-benefits-cta{
  display:flex; justify-content:center; margin-top:30px;
}
@media (max-width: 1100px){
  .mini-benefits-grid{grid-template-columns:repeat(2, minmax(0,1fr));}
}
@media (max-width: 640px){
  .mini-benefits-grid{grid-template-columns:1fr; gap:14px;}
  .mini-benefit-card{padding:20px 18px;}
  .mini-benefit-card h3{font-size:17px;}
}


/* =========================================================
   v14 — Correção de espaçamento entre "Como funciona" e autoridade
   Evita que os cards encostem/entrem na próxima seção.
========================================================= */
main > section.section{
  padding-top:96px;
  padding-bottom:96px;
}

.benefits-section{
  padding-top:84px !important;
  padding-bottom:92px !important;
}

#processo{
  position:relative;
  z-index:2;
  background:var(--areia);
  padding-top:86px !important;
  padding-bottom:118px !important;
  overflow:visible;
}

#processo .section-head{
  margin-bottom:34px;
}

#processo .steps{
  margin-top:0;
  align-items:stretch;
}

#processo .step{
  min-height:236px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}

.authority{
  position:relative;
  z-index:1;
  margin-top:0 !important;
  padding-top:104px !important;
  padding-bottom:104px !important;
}

.authority-grid{
  align-items:center;
}

@media (max-width: 980px){
  main > section.section{
    padding-top:74px;
    padding-bottom:74px;
  }

  #processo{
    padding-top:74px !important;
    padding-bottom:92px !important;
  }

  #processo .steps{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:16px;
  }

  .authority{
    padding-top:84px !important;
    padding-bottom:84px !important;
  }
}

@media (max-width: 640px){
  main > section.section{
    padding-top:62px;
    padding-bottom:62px;
  }

  #processo{
    padding-top:62px !important;
    padding-bottom:76px !important;
  }

  #processo .steps{
    grid-template-columns:1fr;
  }

  #processo .step{
    min-height:auto;
  }

  .authority{
    padding-top:72px !important;
    padding-bottom:72px !important;
  }
}


/* =========================================================
   v16 — seção "O que torna nosso tratamento diferente?"
========================================================= */
.difference-section{
  position:relative;
  overflow:hidden;
  padding-top:92px !important;
  padding-bottom:108px !important;
  background:
    radial-gradient(circle at 8% 8%, rgba(155,177,154,.26), transparent 30%),
    linear-gradient(180deg, #F8F5EE 0%, #F1F4EF 100%);
}
.difference-section:before{
  content:"";
  position:absolute;
  inset:auto -8% -35% auto;
  width:520px;
  height:520px;
  border-radius:50%;
  background:rgba(18,63,69,.08);
  filter:blur(4px);
  pointer-events:none;
}
.difference-header{
  max-width:1040px;
  margin:0 0 38px;
}
.difference-header h2{
  max-width:1020px;
  font-size:clamp(40px, 5.4vw, 82px);
  line-height:.98;
  letter-spacing:-.065em;
  margin:12px 0 20px;
  color:#092F34;
}
.difference-header p{
  max-width:820px;
  color:#4D6267;
  font-size:20px;
  line-height:1.55;
}
.difference-layout{
  display:grid;
  grid-template-columns:.9fr 1.35fr;
  gap:24px;
  align-items:stretch;
  position:relative;
  z-index:1;
}
.difference-main-card{
  min-height:100%;
  border-radius:32px;
  padding:34px;
  background:
    linear-gradient(145deg, rgba(18,63,69,.98), rgba(8,47,52,.96)),
    var(--petroleo);
  color:#fff;
  box-shadow:0 24px 70px rgba(8,47,52,.22);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.difference-tag{
  width:max-content;
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:9px 14px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  color:#DDEBDD;
  font-weight:900;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.difference-main-card h3{
  color:#fff;
  font-size:clamp(30px, 3.1vw, 46px);
  line-height:1.02;
  letter-spacing:-.04em;
  margin:24px 0 16px;
}
.difference-main-card p{
  color:rgba(255,255,255,.82);
  font-size:17px;
  line-height:1.65;
  margin:0 0 22px;
}
.difference-main-card ul{
  list-style:none;
  padding:0;
  margin:0 0 28px;
  display:grid;
  gap:12px;
}
.difference-main-card li{
  position:relative;
  padding-left:28px;
  color:#fff;
  font-weight:800;
  line-height:1.45;
}
.difference-main-card li:before{
  content:"";
  position:absolute;
  left:0;
  top:.42em;
  width:12px;
  height:12px;
  border-radius:50%;
  background:#DDEBDD;
  box-shadow:0 0 0 6px rgba(221,235,221,.12);
}
.difference-main-card .btn{
  width:100%;
  justify-content:center;
  background:#fff;
  color:#0B3D43;
  box-shadow:none;
}
.difference-cards{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:18px;
}
.difference-card{
  min-height:238px;
  border-radius:28px;
  background:#fff;
  border:1px solid rgba(18,63,69,.10);
  padding:28px;
  box-shadow:0 14px 38px rgba(8,47,52,.06);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.difference-card:hover{
  transform:translateY(-4px);
  border-color:rgba(18,63,69,.20);
  box-shadow:0 20px 48px rgba(8,47,52,.10);
}
.difference-card span{
  width:46px;
  height:46px;
  border-radius:15px;
  display:grid;
  place-items:center;
  background:#DDEBDD;
  color:#073136;
  font-weight:950;
  margin-bottom:28px;
}
.difference-card h3{
  color:#072F34;
  font-size:25px;
  line-height:1.08;
  letter-spacing:-.035em;
  margin:0 0 14px;
}
.difference-card p{
  color:#52666B;
  line-height:1.65;
  margin:0;
  font-size:16px;
}
@media (max-width: 980px){
  .difference-section{padding-top:76px !important;padding-bottom:84px !important;}
  .difference-layout{grid-template-columns:1fr;}
  .difference-main-card{min-height:auto;}
}
@media (max-width: 720px){
  .difference-header h2{font-size:42px;}
  .difference-header p{font-size:17px;}
  .difference-cards{grid-template-columns:1fr;}
  .difference-main-card{padding:28px;border-radius:26px;}
  .difference-card{min-height:auto;padding:24px;border-radius:22px;}
}

/* =========================================================
   v17 — remove título e subtítulo da seção de diferenciais
========================================================= */
.difference-header{
  margin:0 0 24px !important;
}
.difference-header h2,
.difference-header p{
  display:none !important;
}
@media (max-width: 720px){
  .difference-header{
    margin-bottom:18px !important;
  }
}


/* =========================================================
   v18 — seção "Quem vai atender você" mais completa e visual
========================================================= */
.authority{
  background:
    radial-gradient(circle at 14% 10%, rgba(155,177,154,.10), transparent 24%),
    linear-gradient(180deg, #08343A 0%, #062F34 100%);
}
.authority-grid-v2{
  grid-template-columns:minmax(320px, .62fr) minmax(0, 1fr);
  gap:64px;
  align-items:center;
}
.authority-photo{
  position:relative;
  max-width:490px;
  margin-inline:auto;
}
.authority-photo picture{display:block}
.authority-photo img{
  width:100%;
  height:700px;
  object-fit:cover;
  object-position:50% 28%;
  border-radius:34px;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 34px 90px rgba(0,0,0,.28);
}
.authority-photo-badge{
  position:absolute;
  left:24px; right:24px; bottom:22px;
  padding:18px 20px;
  border-radius:20px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(18,63,69,.08);
  box-shadow:0 18px 45px rgba(0,0,0,.14);
}
.authority-photo-badge strong{display:block; color:var(--petroleo); font-size:17px; margin-bottom:6px;}
.authority-photo-badge span{display:block; color:#466368; line-height:1.5; font-size:14px;}
.authority-content h2{
  font-size:clamp(42px, 5vw, 74px);
  line-height:.98;
  margin-bottom:18px;
}
.authority-lead{
  font-size:clamp(20px, 1.65vw, 24px);
  line-height:1.58;
  color:#F5F6F3;
  max-width:980px;
  margin-bottom:22px;
}
.authority-story{
  display:grid; gap:14px;
  margin-bottom:26px;
}
.authority-story p{
  color:rgba(255,255,255,.78);
  line-height:1.72;
  margin:0;
  font-size:17px;
}
.authority-highlights{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
  margin:28px 0 30px;
}
.authority-highlights article{
  padding:22px 20px;
  border-radius:22px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.09);
  backdrop-filter:blur(2px);
}
.authority-highlights strong{
  display:block;
  color:#fff;
  font-size:18px;
  line-height:1.25;
  margin-bottom:8px;
}
.authority-highlights span{
  display:block;
  color:rgba(255,255,255,.72);
  line-height:1.55;
  font-size:15px;
}
.authority-credentials{
  margin:0 0 28px;
}
.authority-credentials div{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.13);
}
.authority-cta-row{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}
.authority-mini-note{
  padding:14px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  min-width:260px;
  max-width:420px;
}
.authority-mini-note strong{display:block; color:#fff; font-size:14px; margin-bottom:4px;}
.authority-mini-note span{display:block; color:rgba(255,255,255,.72); font-size:13px; line-height:1.5;}

@media (max-width: 1200px){
  .authority-grid-v2{gap:44px;}
  .authority-highlights{grid-template-columns:1fr;}
}
@media (max-width: 980px){
  .authority-grid-v2{grid-template-columns:1fr; gap:32px;}
  .authority-photo{max-width:440px;}
  .authority-photo img{height:min(640px, 130vw);}
  .authority-content h2{font-size:clamp(36px, 7vw, 58px);}
  .authority-lead{font-size:19px;}
}
@media (max-width: 640px){
  .authority-photo{max-width:360px;}
  .authority-photo img{height:min(560px, 142vw); border-radius:28px;}
  .authority-photo-badge{left:14px; right:14px; bottom:14px; padding:15px 16px;}
  .authority-story p{font-size:16px;}
  .authority-cta-row{align-items:stretch;}
  .authority-mini-note{max-width:none;}
}


/* =========================================================
   v20 — seção "Quem vai atender" com nome na foto
========================================================= */
.authority-grid-v2{
  align-items:center;
  gap:54px;
}
.authority-photo{
  position:relative;
  max-width:540px;
  width:100%;
  margin-inline:auto;
}
.authority-photo::before{
  content:"";
  position:absolute;
  inset:-16px;
  border-radius:38px;
  background:linear-gradient(145deg, rgba(155,177,154,.18), rgba(255,255,255,.05));
  z-index:0;
  filter:blur(0.5px);
}
.authority-photo picture, .authority-photo-name{position:relative; z-index:1;}
.authority-photo img{
  width:100%;
  height:710px;
  object-fit:cover;
  object-position:50% 26%;
  border-radius:34px;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 34px 90px rgba(0,0,0,.26);
}
.authority-photo-badge{display:none !important;}
.authority-photo-name{
  position:absolute;
  left:24px; right:24px; bottom:24px;
  padding:18px 22px 19px;
  border-radius:22px;
  background:rgba(255,255,255,.95);
  border:1px solid rgba(18,63,69,.10);
  box-shadow:0 16px 44px rgba(0,0,0,.14);
}
.authority-photo-name span{
  display:block;
  font-size:12px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#5B6F73;
  margin-bottom:8px;
}
.authority-photo-name strong{
  display:block;
  color:var(--petroleo);
  font-size:clamp(28px, 3.2vw, 38px);
  line-height:1.02;
  letter-spacing:-.03em;
}
.authority-content-compact .authority-lead{margin-top:0;}
.authority-content-compact h2,
.authority-content-compact .eyebrow{display:none !important;}
.authority-highlights-compact{margin-top:26px;}
.authority-highlights-compact article{min-height:100%;}
.authority-credentials{margin-top:28px;}

@media (max-width: 1200px){
  .authority-grid-v2{gap:42px;}
}
@media (max-width: 980px){
  .authority-photo{max-width:440px;}
  .authority-photo img{height:min(640px, 128vw);}
  .authority-photo-name{left:16px; right:16px; bottom:16px; padding:16px 18px;}
}
@media (max-width: 640px){
  .authority-grid-v2{gap:28px;}
  .authority-photo{max-width:360px;}
  .authority-photo::before{inset:-10px; border-radius:30px;}
  .authority-photo img{height:min(560px, 144vw); border-radius:28px;}
  .authority-photo-name strong{font-size:30px;}
}


/* =========================================================
   v21 — FAQ mais bonita e focada em objeções
========================================================= */
.faq-section{
  background:
    radial-gradient(circle at 10% 15%, rgba(184,202,178,.18), transparent 26%),
    linear-gradient(180deg, #FBFBF8 0%, #F4F5EF 100%);
}
.faq-grid-v2{
  align-items:start;
  gap:42px;
}
.faq-head{
  position:sticky;
  top:104px;
  max-width:430px;
}
.faq-head h2{max-width:420px;}
.faq-head p{
  color:var(--muted);
  line-height:1.72;
  max-width:400px;
}
.faq-helper-card{
  margin-top:24px;
  padding:22px 22px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(18,63,69,.98), rgba(11,47,52,.98));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 22px 56px rgba(8,35,38,.16);
}
.faq-helper-card strong{
  display:block;
  color:#fff;
  font-size:18px;
  margin-bottom:8px;
}
.faq-helper-card span{
  display:block;
  color:rgba(255,255,255,.80);
  line-height:1.6;
}
.faq-list-v2{
  display:grid;
  gap:14px;
}
.faq-item{
  background:#fff;
  border:1px solid rgba(18,63,69,.10);
  border-radius:22px;
  box-shadow:0 12px 30px rgba(8,35,38,.05);
  overflow:hidden;
  transition:border-color .22s ease, box-shadow .22s ease, transform .22s ease;
}
.faq-item:hover{
  transform:translateY(-2px);
  border-color:rgba(18,63,69,.18);
  box-shadow:0 18px 38px rgba(8,35,38,.08);
}
.faq-item[open]{
  border-color:rgba(18,63,69,.18);
  box-shadow:0 18px 40px rgba(8,35,38,.08);
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  position:relative;
  padding:24px 62px 24px 26px;
  font-size:17px;
  line-height:1.4;
  font-weight:900;
  color:#0A3035;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::before{
  content:"+";
  position:absolute;
  right:24px; top:50%; transform:translateY(-50%);
  width:32px; height:32px; border-radius:50%;
  display:grid; place-items:center;
  background:linear-gradient(135deg, #DCE6D8, #F1F5EF);
  color:var(--petroleo);
  font-size:22px; font-weight:900;
}
.faq-item[open] summary::before{content:"–";}
.faq-item p{
  margin:0;
  padding:0 26px 24px;
  color:var(--muted);
  line-height:1.72;
  font-size:16px;
  max-width:92%;
}
@media (max-width: 980px){
  .faq-head{position:relative; top:auto; max-width:none;}
  .faq-head p{max-width:none;}
}
@media (max-width: 640px){
  .faq-item summary{padding:20px 56px 20px 18px; font-size:16px;}
  .faq-item summary::before{right:16px; width:28px; height:28px; font-size:20px;}
  .faq-item p{padding:0 18px 20px; max-width:none; font-size:15px;}
  .faq-helper-card{padding:18px;}
}


/* =========================================================
   v22 — exibir pergunta pequena acima dos cards
========================================================= */
.difference-header{
  margin:0 0 26px !important;
}
.difference-header h2,
.difference-header p{
  display:none !important;
}
.difference-label{
  display:inline-block;
  color:#0D5B67;
  font-size:15px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  line-height:1.2;
}
@media (max-width: 720px){
  .difference-label{font-size:13px; letter-spacing:.12em;}
}


/* =========================================================
   v23 — FAQ minimal apenas com título pequeno
========================================================= */
.faq-head-minimal{
  max-width:260px;
  align-self:start;
}
.faq-head-minimal .eyebrow{
  margin:0;
}
.faq-head-minimal h2,
.faq-head-minimal p,
.faq-head-minimal .faq-helper-card{
  display:none !important;
}
@media (max-width: 980px){
  .faq-head-minimal{max-width:none;}
}


/* =========================================================
   v24 — FAQ centralizado e todos os cards fechados
========================================================= */
.faq-grid-v2{
  grid-template-columns:1fr !important;
  gap:24px;
  justify-items:center;
}
.faq-head-minimal{
  width:100%;
  max-width:none;
  text-align:center;
  justify-self:center;
  margin-bottom:4px;
}
.faq-head-minimal .eyebrow{
  display:block;
  text-align:center;
  font-size:15px;
  letter-spacing:.14em;
}
.faq-list-v2{
  width:min(100%, 1080px);
  margin:0 auto;
}
.faq-item summary{
  display:flex;
  align-items:center;
  min-height:88px;
}
.faq-item p{
  max-width:100%;
}
@media (max-width: 980px){
  .faq-grid-v2{gap:18px;}
  .faq-list-v2{width:100%;}
}


/* =========================================================
   v25 — FAQ refeita com título visível e cards mais compactos
========================================================= */
.faq-section{
  padding-top:96px;
  padding-bottom:96px;
  background:
    radial-gradient(circle at 12% 12%, rgba(184,202,178,.14), transparent 24%),
    radial-gradient(circle at 88% 86%, rgba(13,91,103,.07), transparent 22%),
    linear-gradient(180deg, #F9FAF6 0%, #F1F3ED 100%);
}
.faq-grid-v2{
  width:100%;
  max-width:1120px;
  margin:0 auto;
  gap:26px;
}
.faq-title-centered{
  width:100%;
  text-align:center;
  margin-bottom:8px;
}
.faq-title-centered h2{
  display:block !important;
  margin:0;
  color:var(--petroleo);
  font-size:clamp(38px, 5vw, 56px);
  line-height:1.04;
  letter-spacing:-.03em;
}
.faq-title-centered .eyebrow,
.faq-title-centered p,
.faq-title-centered .faq-helper-card{
  display:none !important;
}
.faq-list-v2{
  width:min(100%, 1040px);
  gap:16px;
}
.faq-item{
  border-radius:24px;
  border:1px solid rgba(18,63,69,.09);
  box-shadow:0 10px 28px rgba(8,35,38,.04);
}
.faq-item:hover,
.faq-item[open]{
  transform:none;
  border-color:rgba(18,63,69,.14);
  box-shadow:0 14px 34px rgba(8,35,38,.07);
}
.faq-item summary{
  padding:22px 72px 22px 28px;
  min-height:auto;
  font-size:16px;
  line-height:1.45;
}
.faq-item p{
  padding:0 28px 22px;
  font-size:15px;
  line-height:1.72;
  color:#53686C;
}
.faq-item summary::before{
  right:22px;
  width:40px;
  height:40px;
  font-size:24px;
  background:linear-gradient(135deg, #E3EBDD, #F8FBF5);
  box-shadow:inset 0 0 0 1px rgba(18,63,69,.04);
}
@media (max-width: 980px){
  .faq-section{padding-top:78px; padding-bottom:78px;}
  .faq-grid-v2{gap:22px;}
  .faq-title-centered h2{font-size:clamp(34px, 8vw, 46px);}
  .faq-list-v2{width:100%;}
}
@media (max-width: 640px){
  .faq-section{padding-top:64px; padding-bottom:64px;}
  .faq-title-centered h2{font-size:clamp(30px, 10vw, 40px);}
  .faq-item{border-radius:22px;}
  .faq-item summary{
    padding:18px 60px 18px 20px;
    font-size:15px;
  }
  .faq-item p{
    padding:0 20px 18px;
    font-size:14px;
  }
  .faq-item summary::before{
    right:16px;
    width:34px;
    height:34px;
    font-size:22px;
  }
}


/* =========================================================
   v26 — título do FAQ igual referência e fixo
========================================================= */
.faq-head,
.faq-head-minimal,
.faq-title-centered,
.faq-title-strip{
  position:static !important;
  top:auto !important;
  transform:none !important;
}
.faq-title-strip{
  width:min(100%, 1040px);
  margin:0 auto 14px;
  text-align:left;
}
.faq-title-strip .eyebrow{
  display:block !important;
  margin:0;
  color:#0D5B67;
  font-size:14px;
  font-weight:900;
  letter-spacing:.18em;
  line-height:1.2;
  text-transform:uppercase;
}
.faq-title-strip h2,
.faq-title-strip p:not(.eyebrow),
.faq-title-strip .faq-helper-card{
  display:none !important;
}
.faq-list-v2{
  width:min(100%, 1040px) !important;
  margin:0 auto;
}
@media (max-width: 640px){
  .faq-title-strip{
    margin-bottom:12px;
  }
  .faq-title-strip .eyebrow{
    font-size:13px;
    letter-spacing:.14em;
  }
}


/* =========================================================
   v27 — FAQ cards mais compactos
========================================================= */
.faq-list-v2{
  gap: 12px !important;
}

.faq-item{
  border-radius: 20px !important;
}

.faq-item summary{
  padding: 16px 64px 16px 24px !important;
  min-height: 68px !important;
  font-size: 15px !important;
  line-height: 1.35 !important;
}

.faq-item p{
  padding: 0 24px 16px !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
}

.faq-item summary::before{
  width: 34px !important;
  height: 34px !important;
  right: 18px !important;
  font-size: 22px !important;
}

@media (max-width: 640px){
  .faq-list-v2{
    gap: 10px !important;
  }

  .faq-item{
    border-radius: 18px !important;
  }

  .faq-item summary{
    padding: 14px 56px 14px 18px !important;
    min-height: 60px !important;
    font-size: 14px !important;
  }

  .faq-item p{
    padding: 0 18px 14px !important;
    font-size: 13px !important;
  }

  .faq-item summary::before{
    width: 30px !important;
    height: 30px !important;
    right: 14px !important;
    font-size: 20px !important;
  }
}



/* =========================================================
   v28 — FAQ realmente compacta e centralizada
   Pedido: reduzir a “grossura” dos cards, manter título fixo e visual limpo
========================================================= */
.faq-section{
  padding: 74px 0 84px !important;
  background:
    radial-gradient(circle at 10% 12%, rgba(184,202,178,.18), transparent 25%),
    linear-gradient(180deg, #fbfaf5 0%, #f7f8f3 100%) !important;
  overflow: hidden !important;
}

.faq-section .container.faq-grid,
.faq-section .container.faq-grid-v2{
  display: block !important;
  max-width: 100% !important;
  width: 100% !important;
  padding-left: clamp(18px, 5vw, 72px) !important;
  padding-right: clamp(18px, 5vw, 72px) !important;
}

.faq-title-strip{
  position: static !important;
  top: auto !important;
  transform: none !important;
  width: 100% !important;
  max-width: 920px !important;
  margin: 0 auto 24px !important;
  text-align: center !important;
}

.faq-title-strip .eyebrow{
  display: block !important;
  margin: 0 !important;
  color: #0D5B67 !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  letter-spacing: .20em !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
}

.faq-list-v2{
  width: min(100%, 920px) !important;
  max-width: 920px !important;
  margin: 0 auto !important;
  display: grid !important;
  gap: 10px !important;
}

.faq-item{
  border-radius: 18px !important;
  border: 1px solid rgba(18,63,69,.10) !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 12px 28px rgba(8,35,38,.045) !important;
  overflow: hidden !important;
  transform: none !important;
}

.faq-item:hover{
  transform: translateY(-1px) !important;
  box-shadow: 0 16px 32px rgba(8,35,38,.065) !important;
}

.faq-item summary{
  min-height: 58px !important;
  padding: 0 58px 0 22px !important;
  display: flex !important;
  align-items: center !important;
  list-style: none !important;
  cursor: pointer !important;
  position: relative !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  font-weight: 900 !important;
  color: #062f35 !important;
}

.faq-item summary::-webkit-details-marker{
  display: none !important;
}

.faq-item summary::before{
  content: "+" !important;
  width: 30px !important;
  height: 30px !important;
  right: 18px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  border-radius: 999px !important;
  background: #E5EEE1 !important;
  color: #0B4A52 !important;
  display: grid !important;
  place-items: center !important;
  font-size: 20px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

.faq-item[open] summary::before{
  content: "–" !important;
}

.faq-item p{
  padding: 0 58px 18px 22px !important;
  margin: 0 !important;
  max-width: 780px !important;
  font-size: 14px !important;
  line-height: 1.58 !important;
  color: #51676d !important;
}

@media (max-width: 760px){
  .faq-section{
    padding: 56px 0 64px !important;
  }

  .faq-section .container.faq-grid,
  .faq-section .container.faq-grid-v2{
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .faq-title-strip{
    margin-bottom: 18px !important;
  }

  .faq-list-v2{
    gap: 9px !important;
  }

  .faq-item{
    border-radius: 16px !important;
  }

  .faq-item summary{
    min-height: 54px !important;
    padding: 0 52px 0 16px !important;
    font-size: 14px !important;
  }

  .faq-item summary::before{
    width: 28px !important;
    height: 28px !important;
    right: 14px !important;
    font-size: 19px !important;
  }

  .faq-item p{
    padding: 0 16px 15px !important;
    font-size: 13px !important;
  }
}



.brand-logo{gap:0}
.brand-logo img{display:block;height:58px;width:auto;max-width:min(46vw,260px);object-fit:contain}
@media (max-width: 768px){
  .header-grid{height:82px;gap:14px;grid-template-columns:1fr auto}
  .brand-logo img{height:50px;max-width:210px}
  .nav{display:none}
}


.brand-logo-text{display:inline-flex;align-items:center;gap:12px}
.brand-icon-logo{width:52px;height:52px;object-fit:contain;display:block;filter:drop-shadow(0 4px 10px rgba(0,0,0,.12));}
.brand-logo-text strong{display:block;line-height:1.1;color:#fff;font-size:18px;letter-spacing:-.02em}
.brand-logo-text small{display:none}
@media (max-width: 768px){
  .brand-icon-logo{width:46px;height:46px}
  .brand-logo-text strong{font-size:16px}
}
