:root {
  --bg: #071a24;
  --bg-2: #0a2430;
  --card: rgba(255,255,255,.075);
  --card-strong: rgba(255,255,255,.12);
  --line: rgba(255,255,255,.14);
  --text: #f6fbfb;
  --muted: #b8c9ce;
  --gold: #d6b675;
  --gold-2: #f1dca3;
  --cyan: #36d7d3;
  --cyan-2: #7cf3ee;
  --dark: #041016;
  --shadow: 0 24px 80px rgba(0,0,0,.34);
  --radius: 28px;
  --max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 18% 10%, rgba(54,215,211,.18), transparent 28%),
    radial-gradient(circle at 90% 12%, rgba(214,182,117,.14), transparent 26%),
    linear-gradient(180deg, #061821 0%, #09232f 48%, #06171f 100%);
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
p { color: var(--muted); line-height: 1.75; }
.container { width: min(var(--max), calc(100% - 40px)); margin: 0 auto; }
.section-pad { padding: 96px 0; position: relative; }

.topbar {
  display: flex; justify-content: center; gap: 28px; flex-wrap: wrap;
  padding: 10px 20px; font-size: .82rem; color: #d7f7f5;
  background: rgba(4,16,22,.72); border-bottom: 1px solid var(--line);
}
.topbar span::before { content: "•"; color: var(--gold); margin-right: 9px; }

.site-header {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  width: min(1240px, calc(100% - 28px)); margin: 14px auto 0;
  padding: 14px 16px 14px 18px;
  border: 1px solid var(--line); border-radius: 999px;
  background: rgba(7, 26, 36, .76); backdrop-filter: blur(18px); box-shadow: var(--shadow);
}
.brand { display: inline-flex; align-items: center; gap: 12px; min-width: max-content; }
.brand-logo {
  width: 230px;
  height: auto;
  max-height: 78px;
  display: block;
  object-fit: contain;
  border-radius: 0;
}
.footer-logo { width: 230px; max-height: 78px; }
.main-nav { display: flex; align-items: center; gap: 20px; color: #dcecee; font-size: .92rem; }
.main-nav a:not(.nav-cta):hover { color: var(--cyan-2); }
.nav-cta { padding: 12px 17px; border-radius: 999px; color: #041016; background: linear-gradient(135deg, var(--cyan-2), var(--cyan)); font-weight: 800; }
.menu-toggle { display:none; width:44px; height:44px; border:0; border-radius:50%; background:rgba(255,255,255,.1); }
.menu-toggle span { display:block; width:18px; height:2px; background:#fff; margin:4px auto; border-radius:99px; }

.hero { min-height: 790px; display: grid; align-items: center; padding-top: 84px; }
.hero-content { display: grid; grid-template-columns: 1.04fr .86fr; gap: 56px; align-items: center; }
.eyebrow { color: var(--cyan-2); text-transform: uppercase; letter-spacing: .16em; font-weight: 800; font-size: .76rem; margin: 0 0 16px; }
h1, h2, h3 { margin: 0; color: var(--text); }
h1 { font-family: "Playfair Display", serif; font-size: clamp(3rem, 7vw, 5.9rem); line-height: .95; letter-spacing: -.05em; max-width: 850px; }
h2 { font-family: "Playfair Display", serif; font-size: clamp(2.15rem, 4vw, 4rem); line-height: 1; letter-spacing: -.04em; }
h3 { font-size: 1.12rem; }
.hero-subtitle { max-width: 640px; font-size: 1.18rem; margin: 24px 0 34px; }
.hero-actions { display:flex; gap: 14px; flex-wrap: wrap; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:10px; border:0; cursor:pointer; padding: 16px 22px; border-radius: 999px; font-weight: 800; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.btn:hover { transform: translateY(-2px); }
.btn-primary { color: #041016; background: linear-gradient(135deg, var(--gold-2), var(--gold)); box-shadow: 0 18px 34px rgba(214,182,117,.18); }
.btn-secondary { color: var(--text); border:1px solid var(--line); background:rgba(255,255,255,.07); }
.btn-light { background:#fff; color:#061821; }
.trust-row { display:flex; gap:10px; flex-wrap:wrap; margin-top:28px; }
.trust-row span { padding: 10px 14px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.055); color: #dcecee; font-size:.92rem; }
.hero-card { position: relative; }
.hero-card-inner { position: relative; min-height: 530px; border:1px solid var(--line); border-radius: 36px; padding: 34px; background: linear-gradient(160deg, rgba(255,255,255,.13), rgba(255,255,255,.04)); box-shadow: var(--shadow); overflow:hidden; }
.hero-card-inner::before { content:""; position:absolute; inset:1px; border-radius:35px; background: radial-gradient(circle at 40% 10%, rgba(54,215,211,.22), transparent 28%), linear-gradient(180deg, rgba(255,255,255,.08), transparent); pointer-events:none; }
.card-orbit { position:absolute; width:440px; height:440px; border:1px solid rgba(124,243,238,.32); border-radius:50%; right:-170px; top:-80px; }
.card-orbit::after { content:""; position:absolute; width:16px; height:16px; border-radius:50%; background:var(--cyan-2); left:55px; top:58px; box-shadow:0 0 38px var(--cyan); }
.card-label { position:relative; display:inline-block; padding:9px 13px; color:#041016; border-radius:999px; background:var(--cyan-2); font-weight:800; font-size:.8rem; }
.hero-card h2 { position:relative; font-size: clamp(2rem, 4vw, 3.2rem); max-width: 430px; margin: 80px 0 28px; }
.approval-box, .metric-grid { position:relative; }
.approval-box { display:flex; gap:14px; padding:18px; border-radius:22px; background:rgba(4,16,22,.56); border:1px solid var(--line); }
.approval-icon { width:38px; height:38px; border-radius:50%; display:grid; place-items:center; color:#041016; background:var(--gold-2); font-weight:900; flex:0 0 auto; }
.approval-box small, .metric-grid small { display:block; color:var(--muted); margin-top:5px; line-height:1.4; }
.metric-grid { display:grid; grid-template-columns: 1fr 1fr; gap:14px; margin-top:14px; }
.metric-grid div { padding:20px; border-radius:22px; background:rgba(255,255,255,.07); border:1px solid var(--line); }
.metric-grid strong { font-size:2rem; color:var(--gold-2); }
.glow { position:absolute; width:520px; height:520px; border-radius:50%; filter: blur(80px); opacity:.23; pointer-events:none; }
.glow-one { background:var(--cyan); right:-220px; top:100px; }

.two-columns { display:grid; grid-template-columns:.78fr 1.22fr; gap:44px; align-items:start; }
.section-heading p { max-width: 500px; }
.comparison { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.compare-card, .feature-card, .testimonial, .step, .lead-form, .faq-list details { border:1px solid var(--line); background: var(--card); border-radius: var(--radius); box-shadow: 0 18px 60px rgba(0,0,0,.16); }
.compare-card { padding:28px; }
.compare-card.positive { background: linear-gradient(160deg, rgba(54,215,211,.16), rgba(255,255,255,.06)); }
ul { margin: 18px 0 0; padding: 0; list-style: none; }
li { position:relative; padding-left: 24px; color: var(--muted); line-height:1.65; margin: 12px 0; }
li::before { content:""; position:absolute; left:0; top:.72em; width:9px; height:9px; border-radius:50%; background:var(--gold); }
.positive li::before, .check-list li::before { background:var(--cyan-2); }
.center-heading { text-align:center; max-width:780px; margin: 0 auto 42px; }
.feature-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.feature-card { padding: 30px; }
.icon { width:50px; height:50px; display:grid; place-items:center; border-radius:18px; background:rgba(54,215,211,.12); color:var(--cyan-2); font-size:1.4rem; margin-bottom:22px; }

.specialist-grid { display:grid; grid-template-columns:.85fr 1.15fr; gap:54px; align-items:center; }
.portrait-card {
  min-height: 560px;
  border-radius: 36px;
  padding: 18px;
  border: 1px solid var(--line);
  background: var(--card);
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow);
}
.portrait-photo {
  position: absolute;
  inset: 18px;
  width: calc(100% - 36px);
  height: calc(100% - 36px);
  object-fit: cover;
  object-position: center 10%;
  transform: scale(1.18);
  transform-origin: center top;
  border-radius: 28px;
}
.portrait-overlay { position:absolute; inset:18px; border-radius:28px; background:linear-gradient(180deg, rgba(4,16,22,.06) 18%, rgba(4,16,22,.22) 48%, rgba(4,16,22,.72) 76%, rgba(4,16,22,.92) 100%); }
.portrait-content {
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 28px;
  padding: 22px 24px;
  border-radius: 24px;
  background: rgba(4,16,22,.58);
  border: 1px solid var(--line);
  backdrop-filter: blur(14px);
}
.portrait-content h2 { font-size:2.7rem; }
.specialist-copy .btn { margin-top:24px; }

.audience-card, .stats-card { border:1px solid var(--line); border-radius:36px; padding: 44px; background: linear-gradient(135deg, rgba(255,255,255,.12), rgba(54,215,211,.08)); box-shadow: var(--shadow); }
.audience-card { display:grid; grid-template-columns:.8fr 1.2fr; gap:34px; align-items:center; }
.audience-list { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.audience-list span { padding:16px; border-radius:18px; background:rgba(4,16,22,.38); border:1px solid var(--line); color:#dcecee; }
.timeline { display:grid; grid-template-columns: repeat(3, 1fr); gap:18px; }
.step { padding: 28px; }
.step span { display:inline-flex; width:44px; height:44px; align-items:center; justify-content:center; border-radius:16px; background:rgba(214,182,117,.14); color:var(--gold-2); font-weight:900; margin-bottom:18px; }
.stats-card { display:flex; align-items:center; justify-content:space-between; gap:30px; background:linear-gradient(135deg, #d6b675, #f1dca3); }
.stats-card .eyebrow, .stats-card h2 { color:#061821; }
.stats-card h2 { max-width:760px; }

.testimonial-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:18px; }
.testimonial { padding: 28px; }
.testimonial p { color:#e3eff0; }
.testimonial strong { display:block; margin-top:20px; }
.testimonial small { color:var(--muted); }
.lead-grid { display:grid; grid-template-columns:.92fr 1.08fr; gap:42px; align-items:start; }
.security-note { padding:16px; border-radius:18px; background:rgba(124,243,238,.08); color:#d7f7f5; border:1px solid rgba(124,243,238,.18); margin-top:24px; line-height:1.6; }
.lead-form { padding:28px; display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.lead-form label { display:grid; gap:8px; color:#dcecee; font-weight:700; font-size:.9rem; }
.lead-form input, .lead-form select { width:100%; border:1px solid var(--line); background:rgba(4,16,22,.62); color:#fff; border-radius:16px; padding:16px; outline:none; font:inherit; }
.lead-form input:focus, .lead-form select:focus { border-color:var(--cyan-2); box-shadow:0 0 0 4px rgba(54,215,211,.12); }
.lead-form button { grid-column:1 / -1; width:100%; }
.faq-grid { display:grid; grid-template-columns:.74fr 1.26fr; gap:38px; }
.faq-list { display:grid; gap:12px; background:transparent; border:0; box-shadow:none; }
.faq-list details { padding: 20px 22px; }
.faq-list summary { cursor:pointer; font-weight:800; list-style:none; }
.faq-list summary::-webkit-details-marker { display:none; }
.faq-list p { margin-bottom:0; }

.site-footer { padding:58px 0 28px; background:rgba(4,16,22,.72); border-top:1px solid var(--line); }
.footer-grid { display:grid; grid-template-columns:1.4fr .8fr .8fr; gap:30px; align-items:start; }
.footer-links { display:grid; gap:12px; color:var(--muted); }
.footer-links a:hover { color:var(--cyan-2); }
.copyright { margin-top:36px; padding-top:22px; border-top:1px solid var(--line); color:var(--muted); font-size:.9rem; }
.floating-whatsapp { position:fixed; right:22px; bottom:22px; z-index:60; padding:16px 19px; border-radius:999px; color:#041016; background:linear-gradient(135deg, #7cf3ee, #36d7d3); font-weight:900; box-shadow:0 20px 44px rgba(54,215,211,.24); }

.reveal { opacity:0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in-view { opacity:1; transform: translateY(0); }
.delay-1 { transition-delay: .12s; }
.delay-2 { transition-delay: .22s; }

@media (max-width: 980px) {
  .site-header { border-radius: 28px; align-items:center; }
  .menu-toggle { display:block; }
  .main-nav { position:absolute; left:0; right:0; top: calc(100% + 10px); display:none; flex-direction:column; align-items:stretch; gap:0; padding:12px; border:1px solid var(--line); border-radius:24px; background:rgba(7,26,36,.96); backdrop-filter: blur(18px); }
  .main-nav.open { display:flex; }
  .main-nav a { padding:14px; border-radius:16px; }
  .nav-cta { text-align:center; }
  .hero-content, .two-columns, .specialist-grid, .audience-card, .lead-grid, .faq-grid { grid-template-columns:1fr; }
  .hero { min-height: auto; padding-top: 70px; }
  .hero-card-inner { min-height:460px; }
  .comparison, .feature-grid, .timeline, .testimonial-grid { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr; }
}
@media (max-width: 660px) {
  .container { width: min(var(--max), calc(100% - 28px)); }
  .section-pad { padding:72px 0; }
  .topbar { justify-content:flex-start; gap:8px 14px; }
  .topbar span { font-size:.76rem; }
  .brand-logo { width: 176px; max-height: 62px; }
  h1 { font-size: clamp(2.65rem, 16vw, 4.2rem); }
  h2 { font-size: clamp(2rem, 10vw, 3rem); }
  .hero-actions .btn, .specialist-copy .btn { width:100%; }
  .hero-card-inner { min-height:auto; padding:26px; }
  .hero-card h2 { margin: 80px 0 24px; }
  .comparison, .feature-grid, .timeline, .testimonial-grid, .audience-list, .lead-form { grid-template-columns:1fr; }
  .audience-card, .stats-card { padding: 28px; border-radius:28px; }
  .stats-card { align-items:flex-start; flex-direction:column; }
  .portrait-card {
  min-height: 560px;
  border-radius: 36px;
  padding: 18px;
  border: 1px solid var(--line);
  background: var(--card);
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow);
}
  .portrait-content {
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 28px;
  padding: 22px 24px;
  border-radius: 24px;
  background: rgba(4,16,22,.58);
  border: 1px solid var(--line);
  backdrop-filter: blur(14px);
}
  .floating-whatsapp { left:18px; right:18px; text-align:center; }
}


@media (max-width: 660px) {
  .portrait-photo {
    object-position: center 8%;
    transform: scale(1.12);
  }

  .portrait-content {
    left: 22px;
    right: 22px;
    bottom: 22px;
    padding: 20px;
  }
}


/* ===============================
   Mobile V2 — responsividade real
   =============================== */

* {
  box-sizing: border-box;
}

html,
body {
  overflow-x: hidden;
}

img,
svg,
video {
  max-width: 100%;
  height: auto;
}

@media (max-width: 980px) {
  .hero-content,
  .comparison,
  .feature-grid,
  .specialist-grid,
  .audience-card,
  .timeline,
  .testimonial-grid,
  .lead-grid,
  .faq-grid,
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .hero-card {
    display: none;
  }
}

@media (max-width: 760px) {
  :root {
    --container: 100%;
  }

  body {
    min-width: 0;
    padding-bottom: 86px;
  }

  .container {
    width: 100%;
    padding-inline: 22px;
  }

  .topbar {
    display: none;
  }

  .site-header {
    top: 14px;
    left: 14px;
    right: 14px;
    width: auto;
    min-height: 66px;
    padding: 10px 12px;
    border-radius: 22px;
  }

  .brand-logo {
    width: 150px;
    max-height: 44px;
    object-fit: contain;
  }

  .menu-toggle {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    border-radius: 50%;
  }

  .main-nav {
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    padding: 10px;
    border-radius: 20px;
  }

  .main-nav a {
    padding: 13px 14px;
  }

  .nav-cta {
    text-align: center;
  }

  .section-pad {
    padding: 58px 0;
  }

  .hero {
    min-height: auto;
    padding-top: 118px;
    padding-bottom: 48px;
  }

  .hero-content {
    gap: 24px;
  }

  .eyebrow {
    font-size: .72rem;
    line-height: 1.55;
    letter-spacing: .14em;
    max-width: 100%;
    overflow-wrap: anywhere;
  }

  h1 {
    font-size: clamp(2.45rem, 12.2vw, 3.35rem);
    line-height: .95;
    letter-spacing: -.045em;
    max-width: 100%;
    text-wrap: balance;
  }

  h2,
  .specialist-copy h2,
  .center-heading h2,
  .audience-card h2,
  .lead-copy h2,
  .faq-copy h2,
  .stats-card h2 {
    font-size: clamp(2rem, 9.4vw, 2.75rem);
    line-height: 1;
    letter-spacing: -.04em;
    max-width: 100%;
    text-wrap: balance;
    overflow-wrap: break-word;
  }

  h3 {
    font-size: 1.1rem;
  }

  .hero-subtitle,
  p {
    font-size: .98rem;
    line-height: 1.68;
    max-width: 100%;
  }

  .hero-actions {
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 26px;
  }

  .btn {
    width: 100%;
    min-height: 50px;
    justify-content: center;
    text-align: center;
    padding: 14px 17px;
    border-radius: 999px;
  }

  .trust-row {
    gap: 8px;
    margin-top: 22px;
  }

  .trust-row span {
    font-size: .78rem;
    padding: 8px 10px;
  }

  .problem,
  .benefits,
  .specialist,
  .audience,
  .process,
  .testimonials,
  .lead,
  .faq {
    padding-top: 56px;
    padding-bottom: 56px;
  }

  .card,
  .feature-card,
  .audience-card,
  .stats-card,
  .lead-form,
  .faq-list details {
    border-radius: 22px;
  }

  .feature-grid,
  .comparison,
  .timeline,
  .testimonial-grid,
  .audience-list {
    gap: 14px;
  }

  .feature-card,
  .testimonial,
  .step,
  .lead-form {
    padding: 22px;
  }

  .audience-card,
  .stats-card {
    padding: 24px;
  }

  .audience-list {
    grid-template-columns: 1fr;
  }

  .portrait-card {
    min-height: 500px;
    border-radius: 28px;
    margin-bottom: 8px;
  }

  .portrait-photo {
    inset: 12px;
    width: calc(100% - 24px);
    height: calc(100% - 24px);
    object-fit: cover;
    object-position: center 8%;
    transform: scale(1.12);
    transform-origin: center top;
    border-radius: 22px;
  }

  .portrait-overlay {
    inset: 12px;
    border-radius: 22px;
  }

  .portrait-content {
    left: 20px;
    right: 20px;
    bottom: 20px;
    padding: 18px;
    border-radius: 20px;
  }

  .portrait-content p {
    font-size: .92rem;
    line-height: 1.45;
  }

  .portrait-content h2 {
    font-size: 2rem;
    line-height: 1;
  }

  .specialist-copy {
    min-width: 0;
  }

  .specialist-copy .btn {
    width: 100%;
    margin-top: 20px;
  }

  .check-list li,
  li {
    padding-left: 20px;
    line-height: 1.58;
    overflow-wrap: break-word;
  }

  .lead-form {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .lead-form input,
  .lead-form select {
    min-width: 0;
    padding: 14px;
    border-radius: 14px;
  }

  .floating-whatsapp {
    left: 22px;
    right: 22px;
    bottom: 16px;
    z-index: 80;
    padding: 14px 18px;
    min-height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    box-shadow: 0 14px 32px rgba(54,215,211,.22);
  }

  .site-footer {
    padding-bottom: 96px;
  }
}

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

  .site-header {
    top: 12px;
    left: 12px;
    right: 12px;
    min-height: 64px;
    padding: 9px 11px;
  }

  .brand-logo {
    width: 140px;
    max-height: 42px;
  }

  .menu-toggle {
    width: 42px;
    height: 42px;
    flex-basis: 42px;
  }

  .hero {
    padding-top: 108px;
    padding-bottom: 42px;
  }

  .section-pad,
  .problem,
  .benefits,
  .specialist,
  .audience,
  .process,
  .testimonials,
  .lead,
  .faq {
    padding-top: 48px;
    padding-bottom: 48px;
  }

  h1 {
    font-size: clamp(2.32rem, 11.5vw, 2.85rem);
    line-height: .96;
  }

  h2,
  .specialist-copy h2,
  .center-heading h2,
  .audience-card h2,
  .lead-copy h2,
  .faq-copy h2,
  .stats-card h2 {
    font-size: clamp(1.78rem, 8.8vw, 2.35rem);
    line-height: 1.02;
  }

  .hero-subtitle,
  p {
    font-size: .95rem;
    line-height: 1.62;
  }

  .eyebrow {
    font-size: .68rem;
  }

  .portrait-card {
    min-height: 455px;
  }

  .portrait-content h2 {
    font-size: 1.9rem;
  }

  .floating-whatsapp {
    left: 18px;
    right: 18px;
    bottom: 14px;
    min-height: 48px;
    padding: 13px 16px;
  }
}

@media (max-width: 360px) {
  .container {
    padding-inline: 16px;
  }

  h1 {
    font-size: 2.12rem;
  }

  h2,
  .specialist-copy h2,
  .center-heading h2,
  .audience-card h2,
  .lead-copy h2,
  .faq-copy h2,
  .stats-card h2 {
    font-size: 1.72rem;
  }

  .brand-logo {
    width: 126px;
  }

  .menu-toggle {
    width: 40px;
    height: 40px;
    flex-basis: 40px;
  }

  .portrait-card {
    min-height: 420px;
  }
}


/* ===============================
   Mobile V3 — refinamento de leitura
   =============================== */

@media (max-width: 760px) {
  .problem,
  .benefits,
  .specialist,
  .audience,
  .process,
  .testimonials,
  .lead,
  .faq {
    padding-top: 42px;
    padding-bottom: 42px;
  }

  .section-pad {
    padding-top: 42px;
    padding-bottom: 42px;
  }

  .audience-card,
  .stats-card,
  .card,
  .feature-card,
  .testimonial,
  .step {
    padding: 22px;
  }

  .audience-card {
    gap: 24px;
  }

  .audience-card h2,
  .stats-card h2 {
    font-size: clamp(1.72rem, 7.8vw, 2.18rem);
    line-height: 1.04;
    letter-spacing: -.035em;
  }

  .center-heading {
    margin-bottom: 26px;
  }

  .center-heading h2,
  .specialist-copy h2,
  .lead-copy h2,
  .faq-copy h2 {
    font-size: clamp(1.8rem, 8vw, 2.35rem);
    line-height: 1.03;
  }

  .audience-list span {
    padding: 14px 16px;
    line-height: 1.35;
  }

  .stats-card {
    gap: 22px;
    align-items: stretch;
  }

  .stats-card .btn {
    background: #ffffff;
    color: #041016;
  }

  .testimonial-grid {
    gap: 14px;
  }

  .testimonial {
    padding-bottom: 24px;
  }

  .testimonial p {
    font-size: .94rem;
    line-height: 1.55;
  }

  .floating-whatsapp {
    opacity: .94;
    left: 24px;
    right: 24px;
    bottom: 12px;
  }
}

@media (max-width: 430px) {
  body {
    padding-bottom: 0;
  }

  .problem,
  .benefits,
  .specialist,
  .audience,
  .process,
  .testimonials,
  .lead,
  .faq,
  .section-pad {
    padding-top: 38px;
    padding-bottom: 38px;
  }

  .audience-card,
  .stats-card {
    padding: 20px;
    border-radius: 22px;
  }

  .audience-card h2,
  .stats-card h2 {
    font-size: clamp(1.55rem, 7.2vw, 1.95rem);
    line-height: 1.06;
  }

  .center-heading h2,
  .specialist-copy h2,
  .lead-copy h2,
  .faq-copy h2 {
    font-size: clamp(1.62rem, 7.6vw, 2.05rem);
  }

  .eyebrow {
    font-size: .63rem;
    letter-spacing: .13em;
  }

  .audience-list span {
    font-size: .92rem;
    padding: 13px 15px;
  }

  .stats-card .btn {
    min-height: 48px;
  }

  .floating-whatsapp {
    position: static;
    margin: 28px 18px 0;
    width: auto;
    box-shadow: none;
  }

  .site-footer {
    padding-bottom: 32px;
  }
}

@media (max-width: 390px) {
  h1 {
    font-size: 2.18rem;
  }

  .hero-subtitle,
  p {
    font-size: .92rem;
  }

  .audience-card h2,
  .stats-card h2 {
    font-size: 1.48rem;
  }

  .center-heading h2,
  .specialist-copy h2,
  .lead-copy h2,
  .faq-copy h2 {
    font-size: 1.56rem;
  }
}


/* ===============================
   Mobile V4 — header e foto corrigidos
   =============================== */

@media (max-width: 760px) {
  .site-header {
    top: 16px;
    left: 18px;
    right: 18px;
    width: auto;
    min-height: 62px;
    padding: 9px 10px 9px 12px;
    border-radius: 21px;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .brand {
    min-width: 0;
    display: flex;
    align-items: center;
  }

  .brand-logo {
    width: 142px;
    max-height: 40px;
    object-fit: contain;
    display: block;
  }

  .menu-toggle {
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    border-radius: 50%;
  }

  .menu-toggle span {
    width: 17px;
  }

  .hero {
    padding-top: 106px;
  }

  .portrait-card {
    min-height: 500px;
    padding: 14px;
    border-radius: 28px;
  }

  .portrait-photo {
    inset: 14px;
    width: calc(100% - 28px);
    height: calc(100% - 28px);
    border-radius: 22px;
    object-fit: cover;
    object-position: center 4%;
    transform: scale(1.18);
    transform-origin: center top;
  }

  .portrait-overlay {
    inset: 14px;
    border-radius: 22px;
    background: linear-gradient(
      180deg,
      rgba(4,16,22,.04) 18%,
      rgba(4,16,22,.08) 42%,
      rgba(4,16,22,.54) 72%,
      rgba(4,16,22,.92) 100%
    );
  }

  .portrait-content {
    left: 28px;
    right: 28px;
    bottom: 28px;
    padding: 16px 18px;
    border-radius: 19px;
    background: rgba(4,16,22,.76);
  }

  .portrait-content p {
    margin-bottom: 12px;
    font-size: .86rem;
    line-height: 1.4;
  }

  .portrait-content h2 {
    font-size: 1.85rem;
    line-height: 1;
  }

  .portrait-content small {
    font-size: .82rem;
  }
}

@media (max-width: 430px) {
  .site-header {
    top: 14px;
    left: 14px;
    right: 14px;
    min-height: 58px;
    padding: 8px 9px 8px 11px;
    border-radius: 19px;
  }

  .brand-logo {
    width: 132px;
    max-height: 38px;
  }

  .menu-toggle {
    width: 38px;
    height: 38px;
    flex-basis: 38px;
  }

  .hero {
    padding-top: 96px;
  }

  .portrait-card {
    min-height: 468px;
    padding: 12px;
  }

  .portrait-photo {
    inset: 12px;
    width: calc(100% - 24px);
    height: calc(100% - 24px);
    object-position: center 3%;
    transform: scale(1.2);
  }

  .portrait-overlay {
    inset: 12px;
  }

  .portrait-content {
    left: 22px;
    right: 22px;
    bottom: 22px;
    padding: 15px 16px;
  }

  .portrait-content h2 {
    font-size: 1.72rem;
  }
}

@media (max-width: 360px) {
  .brand-logo {
    width: 118px;
  }

  .menu-toggle {
    width: 36px;
    height: 36px;
    flex-basis: 36px;
  }

  .portrait-card {
    min-height: 440px;
  }
}


/* ===============================
   Mobile V5 — acabamento fino
   =============================== */

@media (max-width: 760px) {
  .site-header {
    left: 20px;
    right: 20px;
    padding-right: 14px;
  }

  .menu-toggle {
    margin-left: 10px;
  }

  .hero .container,
  .hero-content {
    padding-inline: 0;
  }

  .stats-card {
    padding: 24px 22px;
    border-radius: 24px;
  }

  .stats-card h2 {
    font-size: clamp(1.55rem, 7.1vw, 2rem);
    line-height: 1.08;
    letter-spacing: -.035em;
  }

  .stats-card .btn {
    margin-top: 4px;
  }

  .portrait-card {
    min-height: 490px;
  }

  .portrait-content {
    background: rgba(4,16,22,.68);
    box-shadow: 0 18px 40px rgba(0,0,0,.18);
  }

  .portrait-content p {
    max-width: 230px;
  }

  .specialist-copy {
    padding-top: 4px;
  }
}

@media (max-width: 430px) {
  .site-header {
    left: 16px;
    right: 16px;
    padding-right: 12px;
  }

  .brand-logo {
    width: 128px;
  }

  .menu-toggle {
    width: 36px;
    height: 36px;
    flex-basis: 36px;
    margin-left: 8px;
  }

  .menu-toggle span {
    width: 15px;
  }

  h1 {
    font-size: clamp(2.18rem, 10.7vw, 2.68rem);
    line-height: .98;
  }

  .stats-card {
    padding: 22px 20px;
    border-radius: 22px;
  }

  .stats-card h2 {
    font-size: clamp(1.42rem, 6.7vw, 1.75rem);
  }

  .stats-card .btn {
    min-height: 46px;
    font-size: .9rem;
  }

  .portrait-card {
    min-height: 452px;
  }

  .portrait-photo {
    object-position: center 2%;
    transform: scale(1.22);
  }

  .portrait-content {
    left: 20px;
    right: 20px;
    bottom: 20px;
    padding: 14px 15px;
  }

  .portrait-content p {
    font-size: .82rem;
    line-height: 1.38;
    margin-bottom: 10px;
    max-width: 215px;
  }

  .portrait-content h2 {
    font-size: 1.62rem;
  }

  .portrait-content small {
    font-size: .78rem;
  }
}

@media (max-width: 390px) {
  .site-header {
    left: 14px;
    right: 14px;
  }

  .brand-logo {
    width: 122px;
  }

  h1 {
    font-size: 2.08rem;
  }

  .stats-card h2 {
    font-size: 1.36rem;
  }

  .portrait-card {
    min-height: 438px;
  }
}


/* ===============================
   Mobile V6 — correção conservadora
   =============================== */

@media (max-width: 760px) {
  .container {
    width: 100%;
    padding-inline: 24px;
  }

  .hero .container,
  .hero-content {
    padding-inline: 24px;
  }

  .hero {
    padding-top: 112px;
    padding-bottom: 46px;
  }

  .site-header {
    left: 18px;
    right: 18px;
    top: 16px;
    padding: 10px 12px;
  }

  h1 {
    font-size: clamp(2.15rem, 9.8vw, 2.85rem);
    line-height: 1.02;
    letter-spacing: -.04em;
    max-width: 100%;
  }

  .hero-subtitle {
    max-width: 34rem;
    font-size: .98rem;
    line-height: 1.62;
  }

  .hero-actions {
    margin-top: 24px;
  }

  .btn {
    min-height: 48px;
  }

  .trust-row {
    margin-top: 20px;
  }

  .problem {
    padding-top: 38px;
  }
}

@media (max-width: 430px) {
  .container {
    padding-inline: 20px;
  }

  .hero .container,
  .hero-content {
    padding-inline: 20px;
  }

  .site-header {
    left: 14px;
    right: 14px;
    top: 14px;
    min-height: 58px;
  }

  .brand-logo {
    width: 126px;
  }

  .menu-toggle {
    width: 36px;
    height: 36px;
    flex: 0 0 36px;
  }

  .hero {
    padding-top: 102px;
    padding-bottom: 40px;
  }

  .eyebrow {
    font-size: .64rem;
    line-height: 1.5;
    letter-spacing: .12em;
  }

  h1 {
    font-size: clamp(1.95rem, 9.2vw, 2.38rem);
    line-height: 1.03;
    letter-spacing: -.035em;
  }

  .hero-subtitle,
  p {
    font-size: .92rem;
    line-height: 1.6;
  }

  .hero-actions {
    margin-top: 22px;
    gap: 10px;
  }

  .trust-row span {
    font-size: .74rem;
    padding: 7px 9px;
  }

  .problem,
  .benefits,
  .specialist,
  .audience,
  .process,
  .testimonials,
  .lead,
  .faq,
  .section-pad {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}

@media (max-width: 390px) {
  .container,
  .hero .container,
  .hero-content {
    padding-inline: 18px;
  }

  h1 {
    font-size: 1.9rem;
  }

  .brand-logo {
    width: 118px;
  }

  .hero-subtitle,
  p {
    font-size: .9rem;
  }
}

/* ===============================
   Mobile V7 — menu e cards com respiro
   =============================== */

@media (max-width: 760px) {
  *, *::before, *::after { box-sizing: border-box; }

  .site-header {
    width: auto;
    max-width: calc(100% - 32px);
    left: 16px;
    right: 16px;
    gap: 10px;
    padding: 10px 12px;
    overflow: hidden;
  }

  .brand {
    min-width: 0;
    flex: 1 1 auto;
    display: flex;
    align-items: center;
  }

  .brand-logo {
    width: 124px;
    max-width: 100%;
    max-height: 38px;
    object-fit: contain;
    display: block;
  }

  .menu-toggle {
    margin-left: 6px;
    flex: 0 0 34px;
    width: 34px;
    height: 34px;
  }

  .menu-toggle span { width: 14px; }

  .audience .container.audience-card,
  .stats .container.stats-card {
    width: auto;
    margin-left: 12px;
    margin-right: 12px;
    padding-left: 18px;
    padding-right: 18px;
    border-radius: 22px;
  }

  .stats-card h2,
  .audience-card h2 {
    font-size: clamp(1.38rem, 6.4vw, 1.78rem);
    line-height: 1.08;
  }
}

@media (max-width: 430px) {
  .site-header {
    max-width: calc(100% - 24px);
    left: 12px;
    right: 12px;
    padding: 9px 10px;
    border-radius: 18px;
  }

  .brand-logo {
    width: 116px;
    max-height: 34px;
  }

  .menu-toggle {
    flex-basis: 32px;
    width: 32px;
    height: 32px;
    margin-left: 4px;
  }

  .menu-toggle span { width: 13px; }

  .audience .container.audience-card,
  .stats .container.stats-card {
    margin-left: 14px;
    margin-right: 14px;
    padding-left: 16px;
    padding-right: 16px;
    border-radius: 20px;
  }
}

@media (max-width: 390px) {
  .site-header {
    left: 10px;
    right: 10px;
    max-width: calc(100% - 20px);
  }

  .brand-logo { width: 108px; }

  .audience .container.audience-card,
  .stats .container.stats-card {
    margin-left: 12px;
    margin-right: 12px;
  }
}

/* ===============================
   Mobile V8 — menu dropdown visível
   =============================== */

@media (max-width: 980px) {
  .site-header {
    overflow: visible !important;
  }

  .menu-toggle {
    cursor: pointer;
    position: relative;
    z-index: 92;
  }

  .main-nav {
    z-index: 91;
    box-shadow: 0 18px 40px rgba(0,0,0,.22);
  }

  .main-nav.open {
    display: flex;
  }
}

@media (max-width: 760px) {
  .site-header {
    overflow: visible !important;
  }

  .main-nav {
    top: calc(100% + 10px);
  }
}



/* ===============================
   V9 — otimizações de performance
   =============================== */

.problem,
.benefits,
.specialist,
.audience,
.process,
.stats,
.testimonials,
.lead,
.faq,
.site-footer {
  content-visibility: auto;
  contain-intrinsic-size: 800px;
}

.portrait-photo,
.brand-logo,
.footer-logo {
  will-change: auto;
}


/* ===============================
   V10 — WhatsApp fixo no mobile
   =============================== */

@media (max-width: 760px) {
  body {
    padding-bottom: 92px;
  }

  .floating-whatsapp {
    position: fixed !important;
    left: auto !important;
    right: 18px !important;
    bottom: 18px !important;
    width: auto !important;
    min-width: 158px;
    margin: 0 !important;
    padding: 13px 18px;
    border-radius: 999px;
    z-index: 9999;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 14px 32px rgba(54,215,211,.24);
  }

  .site-footer {
    padding-bottom: 110px;
  }
}

@media (max-width: 430px) {
  body {
    padding-bottom: 88px;
  }

  .floating-whatsapp {
    right: 16px !important;
    bottom: 16px !important;
    min-width: 148px;
    padding: 12px 16px;
    font-size: .92rem;
  }
}

@media (max-width: 360px) {
  .floating-whatsapp {
    right: 12px !important;
    bottom: 12px !important;
    min-width: 136px;
    padding: 11px 14px;
    font-size: .88rem;
  }
}


/* ===============================
   V11 — foto da Dandara sem faixa superior
   =============================== */

@media (max-width: 760px) {
  .portrait-card {
    padding: 10px;
    overflow: hidden;
  }

  .portrait-photo {
    top: 0 !important;
    left: 10px !important;
    right: 10px !important;
    bottom: 10px !important;
    inset: auto !important;
    width: calc(100% - 20px) !important;
    height: calc(100% - 10px) !important;
    object-fit: cover;
    object-position: center 2%;
    transform: scale(1.18);
    transform-origin: center top;
    border-radius: 22px;
  }

  .portrait-overlay {
    top: 0 !important;
    left: 10px !important;
    right: 10px !important;
    bottom: 10px !important;
    inset: auto !important;
    border-radius: 22px;
    background: linear-gradient(
      180deg,
      rgba(4,16,22,.02) 12%,
      rgba(4,16,22,.08) 38%,
      rgba(4,16,22,.54) 72%,
      rgba(4,16,22,.92) 100%
    );
  }
}

@media (max-width: 430px) {
  .portrait-card {
    padding: 8px;
  }

  .portrait-photo {
    top: 0 !important;
    left: 8px !important;
    right: 8px !important;
    bottom: 8px !important;
    width: calc(100% - 16px) !important;
    height: calc(100% - 8px) !important;
    object-position: center 1%;
    transform: scale(1.2);
    border-radius: 22px;
  }

  .portrait-overlay {
    top: 0 !important;
    left: 8px !important;
    right: 8px !important;
    bottom: 8px !important;
    border-radius: 22px;
  }
}


/* ===============================
   V12 — foto da Dandara corrigida também no desktop
   =============================== */

/* Desktop/tablet: remove a faixa superior vazia mantendo moldura lateral */
.portrait-card {
  padding: 10px;
  overflow: hidden;
}

.portrait-photo {
  top: 0 !important;
  left: 10px !important;
  right: 10px !important;
  bottom: 10px !important;
  inset: auto !important;
  width: calc(100% - 20px) !important;
  height: calc(100% - 10px) !important;
  object-fit: cover;
  object-position: center 2%;
  transform: scale(1.08);
  transform-origin: center top;
  border-radius: 26px;
}

.portrait-overlay {
  top: 0 !important;
  left: 10px !important;
  right: 10px !important;
  bottom: 10px !important;
  inset: auto !important;
  border-radius: 26px;
  background: linear-gradient(
    180deg,
    rgba(4,16,22,.02) 12%,
    rgba(4,16,22,.08) 38%,
    rgba(4,16,22,.54) 72%,
    rgba(4,16,22,.92) 100%
  );
}

/* Mobile mantém o ajuste mais fechado */
@media (max-width: 760px) {
  .portrait-photo {
    object-position: center 2%;
    transform: scale(1.18);
    border-radius: 22px;
  }

  .portrait-overlay {
    border-radius: 22px;
  }
}

@media (max-width: 430px) {
  .portrait-card {
    padding: 8px;
  }

  .portrait-photo {
    top: 0 !important;
    left: 8px !important;
    right: 8px !important;
    bottom: 8px !important;
    width: calc(100% - 16px) !important;
    height: calc(100% - 8px) !important;
    object-position: center 1%;
    transform: scale(1.2);
    border-radius: 22px;
  }

  .portrait-overlay {
    top: 0 !important;
    left: 8px !important;
    right: 8px !important;
    bottom: 8px !important;
    border-radius: 22px;
  }
}
