/* ================================================================
   Pro Cleaning — Sessão Estratégica v3
   SaaS dark — Linear/Vercel aesthetic
   ================================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Montserrat:wght@700;800;900&family=Caveat:wght@700&display=swap');

/* ---- Design Tokens ---- */
:root {
  --bg:            #010658;
  --bg-elevated:   #0A1070;
  --bg-deep:       #000340;
  --bg-soft:       #E8EEF6;
  --blue:          #0583F2;
  --blue-dk:       #0670CC;
  --blue-glow:     rgba(5,131,242,.15);
  --blue-glow-md:  rgba(5,131,242,.08);
  --red:           #FF3B3B;
  --white:         #FFFFFF;
  --text-sec:      rgba(255,255,255,.65);
  --text-dark:     #1a1a2e;
  --text-dark-sec: rgba(26,26,46,.7);
  --border:        rgba(255,255,255,.08);
  --border-dark:   rgba(26,26,46,.12);
  --radius-sm:     4px;
  --radius:        8px;
  --radius-lg:     12px;
  --radius-xl:     16px;
  --shadow-card:   0 1px 3px rgba(0,0,0,.3), 0 8px 32px rgba(0,0,0,.25);
  --shadow-glow:   0 0 40px rgba(5,131,242,.2);
  --font-ui:       'Inter', 'Montserrat', system-ui, sans-serif;
  --font-sign:     'Caveat', cursive;
  --transition:    200ms ease;
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;-webkit-text-size-adjust:100%;
  scrollbar-width:thin;
  scrollbar-color:rgba(5,131,242,.5) rgba(255,255,255,.04);
}
html::-webkit-scrollbar{width:10px}
html::-webkit-scrollbar-track{background:rgba(255,255,255,.03)}
html::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,#0583F2,#60b0ff);
  border-radius:999px;border:2px solid transparent;
  background-clip:padding-box;
}
html::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,#60b0ff,#0583F2);
  background-clip:padding-box;border:2px solid transparent;
}
body{
  font-family:var(--font-ui);
  background:var(--bg);
  color:var(--white);
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul,ol{list-style:none}

/* ---- Skip link ---- */
.skip-link{
  position:absolute;top:-100%;left:1rem;
  background:var(--blue);color:#fff;
  padding:.5rem 1rem;border-radius:var(--radius);
  font-weight:700;z-index:9999;
  transition:top var(--transition);
}
.skip-link:focus{top:1rem}

/* ---- Container ---- */
.container{width:100%;max-width:1080px;margin-inline:auto;padding-inline:24px}
.container--narrow{max-width:720px}

/* ---- Typography helpers ---- */
.eyebrow{
  display:inline-block;
  font-size:11px;font-weight:700;letter-spacing:2px;
  text-transform:uppercase;color:var(--blue);
  margin-bottom:.75rem;
}
.eyebrow--red{color:var(--red)}
.eyebrow--modal{color:var(--blue)}

.section-title{
  font-size:clamp(26px,4vw,40px);
  font-weight:800;line-height:1.1;
  letter-spacing:-1px;
  margin-bottom:1.5rem;
}
.section-title--light{color:var(--white)}
.section-title--dark{color:var(--text-dark)}

/* ---- Brand Name ---- */
.brand-name{
  display:inline-flex;align-items:center;gap:.25rem;
  font-weight:900;font-size:20px;letter-spacing:-.5px;
  text-decoration:none;color:var(--white);
}
.brand-name .sparkle{color:var(--blue);font-size:14px}
.brand-name .pro{color:var(--blue)}
.brand-name .cleaning{color:var(--white)}
.brand-inline .pro{color:var(--blue)}
.brand-inline .cleaning{color:inherit}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  border-radius:var(--radius);
  font-weight:700;font-size:14px;letter-spacing:.3px;
  text-decoration:none;
  min-height:48px;padding:0 24px;
  transition:background var(--transition),transform var(--transition),box-shadow var(--transition);
}
.btn--primary{
  background:#25D366;color:#fff;
  font-weight:800;
}
.btn--primary:hover{background:#1DA851;transform:translateY(-1px);box-shadow:0 6px 24px rgba(37,211,102,.35)}
.btn--primary:active{transform:translateY(0)}
.btn--ghost{
  background:transparent;color:var(--white);
  border:1.5px solid var(--border);
}
.btn--ghost:hover{border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.05)}
.btn--xl{min-height:68px;padding:0 44px;font-size:19px;letter-spacing:.4px}
.btn--form{width:100%;min-height:64px;font-size:18px;margin-top:.5rem;letter-spacing:.4px}
.btn:focus-visible{outline:3px solid #25D366;outline-offset:3px}

/* ---- Badge ---- */
.badge{
  display:inline-block;
  background:var(--red);color:#fff;
  font-size:10px;font-weight:800;letter-spacing:2px;
  text-transform:uppercase;border-radius:var(--radius-sm);
  padding:5px 12px;
}
.badge--lg{font-size:11px;padding:7px 16px}

/* ================================================================
   NAV
   ================================================================ */
.site-nav{
  position:sticky;top:0;z-index:100;
  background:transparent;
  transition:background var(--transition),border-color var(--transition);
  --scroll-progress:0;
}
.back-to-top{
  position:fixed;right:24px;bottom:24px;
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  background:var(--blue);color:#fff;
  border:0;border-radius:50%;
  box-shadow:0 8px 24px -6px rgba(5,131,242,.55),0 2px 6px rgba(0,0,0,.3);
  cursor:pointer;
  opacity:0;transform:translateY(12px) scale(.85);pointer-events:none;
  transition:opacity .3s ease,transform .3s cubic-bezier(.34,1.56,.64,1),background .2s ease;
  z-index:90;
}
.back-to-top.is-visible{
  opacity:1;transform:translateY(0) scale(1);pointer-events:auto;
}
.back-to-top:hover{
  background:var(--blue-dk);
  box-shadow:0 10px 28px -4px rgba(5,131,242,.7),0 3px 8px rgba(0,0,0,.35);
  transform:translateY(-2px) scale(1);
}
.back-to-top:focus-visible{
  outline:2px solid #fff;outline-offset:3px;
}
@media(max-width:520px){
  .back-to-top{right:16px;bottom:16px;width:44px;height:44px}
}
@media(prefers-reduced-motion:reduce){
  .back-to-top{transition:opacity .2s ease}
  .back-to-top.is-visible{transform:none}
}
.site-nav__progress{
  position:absolute;left:0;right:0;bottom:0;
  height:3px;
  transform:scaleX(var(--scroll-progress));
  transform-origin:left center;
  background:linear-gradient(90deg,#0583F2 0%,#60b0ff 50%,#00E5FF 100%);
  box-shadow:0 0 10px rgba(0,229,255,.55),0 0 20px rgba(5,131,242,.4);
  will-change:transform;
  pointer-events:none;
  transition:transform .12s linear;
}
.site-nav.scrolled{
  background:rgba(1,6,88,.92);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.site-nav__inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:1080px;margin-inline:auto;
  padding:20px 24px;
}
.site-nav__right{display:flex;align-items:center;gap:20px}
.site-nav__link{
  font-size:13px;font-weight:500;color:var(--text-sec);
  text-decoration:none;transition:color var(--transition);
}
.site-nav__link:hover{color:var(--white)}
.site-nav__cta{
  background:#25D366;color:#fff;
  border-radius:var(--radius);padding:9px 18px;
  font-size:13px;font-weight:700;letter-spacing:.3px;
  transition:background var(--transition),transform var(--transition);
  min-height:40px;
}
.site-nav__cta:hover{background:#1DA851;transform:translateY(-1px)}

/* ================================================================
   HERO — centered SaaS style
   ================================================================ */
.hero{
  position:relative;
  padding:80px 24px 0;
  text-align:center;
  overflow:hidden;
}
/* Radial glow behind headline */
.hero::before{
  content:'';
  position:absolute;top:-80px;left:50%;transform:translateX(-50%);
  width:700px;height:500px;
  background:radial-gradient(ellipse at center, rgba(5,131,242,.18) 0%, transparent 70%);
  pointer-events:none;
}
/* Grid texture */
.hero::after{
  content:'';
  position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 39px, var(--border) 40px),
    repeating-linear-gradient(90deg, transparent, transparent 39px, var(--border) 40px);
  opacity:.35;pointer-events:none;
}
.hero__inner{position:relative;z-index:1;max-width:860px;margin-inline:auto}
.hero__eyebrow-wrap{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:1rem;line-height:1}
.hero__eyebrow{font-size:14px;margin:0;line-height:1}
.hero__eyebrow-sparkle{
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--blue);font-size:16px;opacity:.85;
  line-height:1;transform:translateY(1px);
}
.hero__edition{font-size:11px;color:var(--text-sec);letter-spacing:1px}
.hero__headline{
  font-size:clamp(30px,5.4vw,60px);
  font-weight:800;line-height:1.08;letter-spacing:-1.5px;
  color:var(--white);margin-bottom:1.5rem;
}
.hero__headline-accent{color:var(--blue)}
.hero__sub{
  font-size:clamp(16px,2vw,20px);
  font-weight:400;color:var(--text-sec);
  max-width:620px;margin-inline:auto;margin-bottom:2.5rem;
  line-height:1.65;
}
.hero__cta-row{
  display:flex;align-items:center;justify-content:center;gap:12px;
  flex-wrap:wrap;margin-bottom:1rem;
}
.hero__progress{
  max-width:520px;margin:0 auto 1rem;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  opacity:0;transform:translateY(8px);
  transition:opacity .6s ease,transform .6s ease;
}
.hero__progress.is-visible{opacity:1;transform:translateY(0)}
.hero__progress-bar{
  position:relative;
  width:100%;height:14px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;overflow:hidden;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.25);
}
.hero__progress-fill{
  position:relative;
  height:100%;width:0;
  background:var(--red);
  border-radius:999px;
  box-shadow:0 0 10px rgba(255,59,59,.55),0 0 22px rgba(255,59,59,.35);
  transition:width 1.4s cubic-bezier(.22,.9,.32,1);
}
.hero__progress.is-visible .hero__progress-fill{
  animation:progressGlow 2.4s ease-in-out infinite;
}
.hero__progress-fill.pulse{
  animation:progressGlow 2.4s ease-in-out infinite,progressFlash 1.2s ease-out;
}
@keyframes progressGlow{
  0%,100%{box-shadow:0 0 10px rgba(255,59,59,.55),0 0 22px rgba(255,59,59,.35)}
  50%    {box-shadow:0 0 14px rgba(255,59,59,.75),0 0 32px rgba(255,59,59,.55)}
}
@keyframes progressFlash{
  0%  {box-shadow:0 0 10px rgba(255,59,59,.55),0 0 22px rgba(255,59,59,.35)}
  30% {box-shadow:0 0 22px rgba(255,107,107,.95),0 0 48px rgba(255,59,59,.7)}
  100%{box-shadow:0 0 10px rgba(255,59,59,.55),0 0 22px rgba(255,59,59,.35)}
}
.hero__progress-label{
  font-size:12px;font-weight:800;color:var(--red);
  letter-spacing:1.2px;text-transform:uppercase;
  transition:color .3s ease;
}
.hero__progress-label .pct{
  display:inline-block;min-width:2.2ch;
  font-size:14px;
  will-change:transform;
}
.hero__progress-label.bump{
  animation:labelBump 1s ease;
}
.hero__progress-label.bump .pct{
  animation:pctBump 1s cubic-bezier(.34,1.56,.64,1);
}
@keyframes labelBump{
  0%,100%{color:var(--red)}
  30%    {color:#FFD0D0}
}
@keyframes pctBump{
  0%  {transform:scale(1) translateY(0);color:var(--red);text-shadow:none}
  25% {transform:scale(1.7) translateY(-2px);color:#fff;text-shadow:0 0 18px rgba(255,59,59,.95),0 0 36px rgba(255,59,59,.7)}
  55% {transform:scale(1.35) translateY(0);color:#FFD0D0;text-shadow:0 0 12px rgba(255,59,59,.7)}
  100%{transform:scale(1) translateY(0);color:var(--red);text-shadow:none}
}
@media(prefers-reduced-motion:reduce){
  .hero__progress,
  .hero__progress.is-visible .hero__progress-fill,
  .hero__progress-fill.pulse,
  .hero__progress-label.bump,
  .hero__progress-label.bump .pct{
    animation:none;transition:none;
  }
}
.hero__micro{
  font-size:13px;color:var(--text-sec);
  margin-bottom:2rem;
}
.hero__authority-line{
  font-size:13px;color:var(--text-sec);
  padding-top:1.5rem;
  border-top:1px solid var(--border);
  max-width:560px;margin-inline:auto;
  padding-bottom:2.5rem;
}
.hero__free{color:var(--blue);font-weight:700}

/* ================================================================
   ABOUT SESSION — standalone block between hero and pattern interrupt
   ================================================================ */
.about-session{
  padding:72px 0 56px;
  position:relative;
}
.about-session::before{
  content:"";
  position:absolute;left:50%;top:0;
  width:120px;height:1px;
  transform:translateX(-50%);
  background:linear-gradient(90deg,transparent,rgba(5,131,242,.6),transparent);
}
.about-session__card{
  position:relative;
  background:linear-gradient(180deg,rgba(5,131,242,.06) 0%,rgba(5,131,242,.02) 100%);
  border:1px solid rgba(5,131,242,.18);
  border-radius:20px;
  padding:56px 48px;
  box-shadow:
    0 1px 0 rgba(255,255,255,.04) inset,
    0 24px 60px -24px rgba(0,0,0,.6);
  overflow:hidden;
}
.about-session__card::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(ellipse at top,rgba(5,131,242,.15),transparent 60%);
  pointer-events:none;
}
.about-session__eyebrow-row{
  display:flex;align-items:center;justify-content:center;gap:12px;
  margin-bottom:1.75rem;position:relative;
  line-height:1;
}
.about-session__sparkle{
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--blue);font-size:18px;opacity:.85;
  line-height:1;
  transform:translateY(1px);
}
.about-session__eyebrow{
  color:var(--blue);
  font-size:15px;letter-spacing:2.5px;
  margin:0;
  line-height:1;
}
.about-session__lead{
  position:relative;
  font-size:clamp(17px,2vw,21px);
  line-height:1.6;font-weight:400;
  color:var(--white);
  text-align:center;
  max-width:720px;margin:0 auto;
}
.about-session__lead strong{font-weight:700;color:#fff}
.about-session__divider{
  display:flex;align-items:center;justify-content:center;gap:14px;
  margin:2.75rem auto 2rem;max-width:420px;
  position:relative;
}
.about-session__divider-line{
  flex:1;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
}
.about-session__divider-mark{
  color:var(--blue);font-size:16px;opacity:.9;
}
.about-session__grid{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  margin:0;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  overflow:hidden;
}
.about-session__item{
  padding:22px 20px;
  text-align:center;
  position:relative;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  transition:background .3s ease,transform .3s ease;
}
.about-session__item:hover{
  background:rgba(5,131,242,.06);
  transform:translateY(-2px);
}
.about-session__item:hover .about-session__value{
  color:#60b0ff;
}
.about-session__value{transition:color .25s ease}
.about-session__item + .about-session__item{
  border-left:1px solid rgba(255,255,255,.06);
}
.about-session__item--highlight{
  background:linear-gradient(180deg,rgba(5,131,242,.12),rgba(5,131,242,.04));
}
.about-session__label{
  font-size:10px;font-weight:800;letter-spacing:2px;
  text-transform:uppercase;
  color:var(--text-sec);
  margin:0 0 6px;
}
.about-session__value{
  font-size:16px;font-weight:700;color:#fff;
  margin:0;line-height:1.2;
}
.about-session__meta{
  font-size:12px;color:var(--text-sec);
  margin:auto 0 0;line-height:1.4;
}
.about-session__value-strike{
  display:block;
  font-size:13px;font-weight:500;
  color:var(--text-sec);
  text-decoration:line-through;
  text-decoration-color:rgba(255,255,255,.35);
  margin-bottom:2px;
}
.about-session__value-free{
  display:block;
  color:var(--blue);font-weight:800;
  font-size:15px;
}
@media(max-width:720px){
  .about-session{padding:56px 0 40px}
  .about-session__card{padding:40px 24px;border-radius:16px}
  .about-session__grid{grid-template-columns:repeat(2,1fr)}
  .about-session__item:nth-child(n+3){border-top:1px solid rgba(255,255,255,.06)}
  .about-session__item:nth-child(2n+1){border-left:none}
  .about-session__item:nth-child(2n){border-left:1px solid rgba(255,255,255,.06)}
}
@media(max-width:420px){
  .about-session__grid{grid-template-columns:1fr}
  .about-session__item{border-left:none !important}
  .about-session__item + .about-session__item{border-top:1px solid rgba(255,255,255,.06)}
}

/* Hero mockup card — floating */
.hero__mockup-wrap{
  position:relative;z-index:1;
  margin-top:4rem;margin-bottom:5rem;
  display:flex;justify-content:center;
}
.hero__mockup-card{
  width:100%;max-width:680px;
  background:var(--bg-elevated);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-card),var(--shadow-glow);
  overflow:hidden;
}
/* Chrome bar */
.mockup-chrome{
  display:flex;align-items:center;gap:8px;
  padding:12px 16px;
  background:rgba(255,255,255,.04);
  border-bottom:1px solid var(--border);
}
.mockup-chrome__dots{display:flex;gap:5px}
.mockup-chrome__dot{
  width:10px;height:10px;border-radius:50%;
  background:rgba(255,255,255,.15);
}
.mockup-chrome__dot:first-child{background:#FF5F57}
.mockup-chrome__dot:nth-child(2){background:#FFBD2E}
.mockup-chrome__dot:nth-child(3){background:#28CA41}
.mockup-chrome__title{
  flex:1;text-align:center;
  font-size:12px;color:var(--text-sec);font-weight:500;
}
/* Mockup body */
.mockup-body{padding:20px 24px 24px}
.mockup-header-row{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;
}
.mockup-header-row__name{
  font-size:14px;font-weight:700;color:var(--white);
}
.mockup-header-row__name span{color:var(--blue)}
.mockup-header-row__date{font-size:11px;color:var(--text-sec)}

/* Stats grid */
.mockup-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
  margin-bottom:16px;
}
.mockup-stat{
  background:rgba(5,131,242,.08);
  border:1px solid rgba(5,131,242,.2);
  border-radius:var(--radius);
  padding:10px 12px;
  transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease,background .25s ease;
}
.mockup-stat:hover{
  transform:translateY(-2px);
  border-color:rgba(5,131,242,.5);
  background:rgba(5,131,242,.14);
  box-shadow:0 6px 24px -8px rgba(5,131,242,.5);
}
.mockup-stat__label{font-size:10px;color:var(--text-sec);margin-bottom:4px;font-weight:500}
.mockup-stat__val{
  font-size:18px;font-weight:800;color:var(--white);
  font-variant-numeric:tabular-nums;
}
.mockup-stat__val--red{color:var(--red)}
.mockup-stat__val--blue{color:var(--blue)}

/* Progress bar */
.mockup-progress-row{margin-bottom:16px}
.mockup-progress-label{
  display:flex;justify-content:space-between;
  font-size:11px;color:var(--text-sec);margin-bottom:6px;
}
.mockup-progress-track{
  height:6px;background:rgba(255,255,255,.1);
  border-radius:3px;overflow:hidden;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.25);
}
.mockup-progress-fill{
  height:100%;width:0;
  background:linear-gradient(90deg,var(--blue),#60b0ff);
  border-radius:3px;
  box-shadow:0 0 10px rgba(5,131,242,.55);
  transition:width 1.6s cubic-bezier(.22,.9,.32,1);
}

/* Mini chart */
.mockup-chart{
  margin-bottom:16px;
  background:var(--bg-deep);
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius);
  padding:14px 14px 10px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.mockup-chart__label{font-size:10px;color:var(--text-sec);margin-bottom:10px;text-align:center}
.mockup-chart__plot{position:relative;height:160px}
.mockup-chart__plot canvas{display:block;width:100%!important;height:100%!important}

/* Checklist */
.mockup-checklist{
  border-top:1px solid var(--border);
  padding-top:14px;
}
.mockup-checklist__label{font-size:10px;color:var(--text-sec);margin-bottom:8px;font-weight:600;text-transform:uppercase;letter-spacing:1px}
.mockup-check{
  display:flex;align-items:center;gap:10px;
  width:100%;
  font-size:12px;color:var(--text-sec);
  padding:6px 4px;
  background:transparent;border:0;
  text-align:left;cursor:pointer;
  border-radius:4px;
  transition:background .2s ease,color .2s ease;
}
.mockup-check:hover{background:rgba(5,131,242,.08);color:#fff}
.mockup-check__box{
  width:16px;height:16px;
  border:1.5px solid rgba(5,131,242,.5);
  border-radius:4px;
  background:rgba(5,131,242,.1);
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s ease,border-color .2s ease,transform .2s ease;
}
.mockup-check__box svg{
  opacity:0;transform:scale(.4);
  transition:opacity .2s ease,transform .3s cubic-bezier(.34,1.56,.64,1);
}
.mockup-check[aria-pressed="true"] .mockup-check__box{
  background:var(--blue);
  border-color:var(--blue);
}
.mockup-check[aria-pressed="true"] .mockup-check__box svg{
  opacity:1;transform:scale(1);
}
.mockup-check[aria-pressed="true"] .mockup-check__text{
  color:rgba(255,255,255,.5);
  text-decoration:line-through;
}
@media(prefers-reduced-motion:reduce){
  .mockup-progress-fill{transition:none}
}

/* ================================================================
   TRUST BAR
   ================================================================ */
.trust-bar{
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:rgba(255,255,255,.02);
}
.trust-bar__inner{
  max-width:1080px;margin-inline:auto;
  padding:14px 24px;
  display:flex;align-items:center;justify-content:center;
  gap:0;flex-wrap:wrap;
}
.trust-bar__item{
  display:flex;align-items:center;gap:10px;
  font-size:16px;color:var(--text-sec);
  padding:10px 24px;
}
.trust-bar__icon{color:var(--blue);font-size:10px}
.trust-bar__divider{
  width:1px;height:20px;background:var(--border);
  flex-shrink:0;
}

/* ================================================================
   SECTION DEFAULTS
   ================================================================ */
section{padding:80px 0}

/* ================================================================
   BLOCO 2 — CALLOUT / PATTERN INTERRUPT
   ================================================================ */
.callout-section{
  background:var(--red);
  border-top:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12);
  position:relative;overflow:hidden;
}
.callout-section::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:4px;background:linear-gradient(180deg,rgba(255,255,255,.6),transparent);
}
.callout-section__inner{
  position:relative;padding:8px 0 8px 28px;
}
.callout-section__quote{
  display:flex;align-items:center;gap:18px;
  margin-bottom:1.25rem;
}
.callout-section__opening-mark{
  display:inline-block;
  font-size:90px;line-height:.7;
  color:#fff;opacity:.45;
  font-family:Georgia,'Times New Roman',serif;
  font-weight:700;
  flex-shrink:0;
  transform:translateY(10px);
}
.callout-section__pull{
  font-family:Georgia,'Times New Roman',serif;
  font-style:italic;
  font-weight:600;
  font-size:clamp(22px,3vw,30px);
  line-height:1.2;
  color:#fff;
}
.callout-section__text p{
  font-size:clamp(16px,2vw,19px);
  color:rgba(255,255,255,.88);
  line-height:1.7;margin-bottom:1rem;
}
.callout-section__text p:last-child{margin-bottom:0}
.callout-section__text strong{color:var(--white)}
.callout-section__close{color:var(--white)!important;font-weight:600}

/* ================================================================
   BLOCO 3 — DORES
   ================================================================ */
.pain-section{
  background:var(--bg-soft);
}
.pain-section .eyebrow{color:var(--red)}
.pain-section__header{text-align:center;margin-bottom:3rem}
.pain-section__header .section-title{color:var(--text-dark)}
.pain-section__header .eyebrow{font-size:15px;letter-spacing:2.5px;margin-bottom:1rem}

.pain-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
  margin-bottom:2rem;
}
.pain-item{
  display:flex;align-items:stretch;gap:0;
  background:#fff;border-radius:var(--radius);
  border:1px solid var(--border-dark);
  overflow:hidden;
  transition:border-color var(--transition),box-shadow var(--transition);
}
.pain-item:hover{border-color:rgba(255,59,59,.3);box-shadow:0 2px 12px rgba(255,59,59,.08)}
.pain-item__number{
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  min-width:64px;padding:0 14px;
  font-size:32px;font-weight:800;
  color:var(--red);letter-spacing:-1px;
  font-variant-numeric:tabular-nums;
  background:rgba(255,59,59,.08);
  border-right:1px solid rgba(255,59,59,.15);
}
.pain-item__text{
  font-size:15px;color:var(--text-dark);line-height:1.55;
  padding:16px 18px;
  flex:1;
}
.pain-section__transition{
  text-align:center;
  font-size:17px;font-weight:700;color:var(--text-dark);
  font-style:italic;
}

/* ================================================================
   BLOCO 4 — DIAGNÓSTICO
   ================================================================ */
.diagnosis-section{
  background:var(--bg-deep);
  position:relative;overflow:hidden;
}
.diagnosis-section::after{
  content:'';position:absolute;
  bottom:-120px;right:-80px;
  width:400px;height:400px;
  background:radial-gradient(circle, rgba(5,131,242,.1) 0%, transparent 60%);
  pointer-events:none;
}
.diagnosis-section__header{text-align:center;margin-bottom:3rem}
.diagnosis-section__header .eyebrow{font-size:15px;letter-spacing:2.5px;margin-bottom:1rem}
.diagnosis-section__body{max-width:720px;margin-inline:auto}
.diagnosis-section__text p{
  font-size:clamp(15px,1.6vw,17px);
  color:var(--text-sec);
  line-height:1.75;margin-bottom:1.25rem;
}
.diagnosis-section__text p:last-child{margin-bottom:0}
.diagnosis-section__text strong{color:var(--white)}

.diagnosis-pullquote{
  border-left:3px solid var(--blue);
  padding:20px 24px;
  margin:2rem 0;
  background:rgba(5,131,242,.06);
  border-radius:0 var(--radius) var(--radius) 0;
  font-size:clamp(17px,2vw,21px);
  font-style:italic;
  color:var(--white);
  line-height:1.6;
  font-weight:500;
}

/* ================================================================
   BLOCO 5 — SOLUÇÃO
   ================================================================ */
.solution-section{
  background:var(--bg-soft);
}
.solution-section__header{text-align:center;margin-bottom:2.5rem}
.solution-section__header .eyebrow{font-size:15px;letter-spacing:2.5px;margin-bottom:1rem}
.solution-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:24px;margin-top:4.5rem;margin-bottom:2.5rem;
}
.solution-box{
  position:relative;
  border-radius:16px;
  padding:36px 32px 32px;
  border:1px solid var(--border-dark);
  overflow:hidden;
  transition:transform .3s ease,box-shadow .3s ease;
}
.solution-box::before{
  content:"";position:absolute;top:0;left:0;right:0;
  height:4px;
  border-radius:16px 16px 0 0;
}
.solution-box--yes{
  background:linear-gradient(180deg,#fff 0%,rgba(5,131,242,.05) 100%);
  border-color:rgba(5,131,242,.2);
  box-shadow:0 4px 16px -8px rgba(5,131,242,.3),0 1px 3px rgba(0,0,0,.04);
}
.solution-box--yes::before{
  background:linear-gradient(90deg,var(--blue),#60b0ff);
  box-shadow:0 0 14px rgba(5,131,242,.5);
}
.solution-box--yes:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 36px -12px rgba(5,131,242,.4),0 2px 6px rgba(0,0,0,.06);
}
.solution-box--no{
  background:#fff;
  border-color:var(--border-dark);
  box-shadow:0 1px 3px rgba(0,0,0,.04);
}
.solution-box--no::before{
  background:linear-gradient(90deg,var(--red),#ff7070);
  opacity:.7;
}
.solution-box--no:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 32px -14px rgba(255,59,59,.25),0 2px 6px rgba(0,0,0,.05);
}
.solution-box__head{
  display:flex;align-items:center;gap:12px;
  margin-bottom:1.75rem;padding-bottom:1.25rem;
  border-bottom:1px solid var(--border-dark);
}
.solution-box__badge{
  width:40px;height:40px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.solution-box__badge--yes{
  background:var(--blue);
  box-shadow:0 4px 14px rgba(5,131,242,.4),inset 0 1px 0 rgba(255,255,255,.25);
}
.solution-box__badge--no{
  background:var(--red);
  box-shadow:0 4px 14px rgba(255,59,59,.35),inset 0 1px 0 rgba(255,255,255,.25);
}
.solution-box__label{
  font-size:15px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  color:var(--text-dark-sec);line-height:1.2;
}
.solution-box__label strong{
  display:block;font-size:20px;font-weight:900;letter-spacing:0;
  color:var(--text-dark);margin-top:2px;
}
.solution-box--yes .solution-box__label strong{color:var(--blue)}
.solution-box--no  .solution-box__label strong{color:var(--red)}
.solution-list{display:flex;flex-direction:column;gap:14px}
.solution-list li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:15px;color:var(--text-dark);line-height:1.5;
}
.solution-list__text{flex:1}
.solution-list__text strong{font-weight:700;color:var(--text-dark)}
.solution-icon{
  width:22px;height:22px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:1px;
}
.solution-icon--yes{
  background:var(--blue);
  box-shadow:0 2px 6px rgba(5,131,242,.35);
}
.solution-icon--no{
  background:rgba(255,59,59,.15);
}
.solution-icon--no svg path{stroke:var(--red)}
.solution-box--no .solution-list li{color:var(--text-dark-sec)}
.solution-section__footer{
  text-align:center;
  font-size:16px;color:var(--text-dark-sec);
  font-style:italic;max-width:680px;margin-inline:auto;
  line-height:1.6;
}

/* Zoom mockup bloco 5 */
.zoom-mockup{
  max-width:720px;margin:2.5rem auto 0;
  background:var(--bg);
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;overflow:hidden;
  box-shadow:
    0 1px 0 rgba(255,255,255,.08) inset,
    0 20px 60px -20px rgba(0,0,0,.7),
    0 8px 24px -8px rgba(0,0,0,.5);
}
.zoom-mockup__chrome{
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  padding:12px 16px;
  display:flex;align-items:center;gap:8px;
  border-bottom:1px solid rgba(255,255,255,.08);
  position:relative;
}
.zoom-mockup__chrome-dot{
  width:12px;height:12px;border-radius:50%;
  box-shadow:inset 0 0 0 .5px rgba(0,0,0,.25);
}
.zoom-mockup__chrome-dot--close{background:#FF5F57}
.zoom-mockup__chrome-dot--min  {background:#FEBC2E}
.zoom-mockup__chrome-dot--max  {background:#28C840}
.zoom-mockup__chrome-title{
  font-size:13px;font-weight:500;color:rgba(255,255,255,.75);
  flex:1;text-align:center;
  letter-spacing:.2px;
  padding-right:60px;
}
.zoom-mockup__frames{
  display:grid;grid-template-columns:1fr 1fr;gap:3px;
  background:rgba(0,0,0,.4);
}
.zoom-frame{
  aspect-ratio:4/3;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-elevated);
}
.zoom-frame--marcel img{
  width:100%;height:100%;object-fit:cover;
}
.zoom-frame--client{
  background:linear-gradient(135deg,#1a2a6c,#2d4080);
}
.zoom-frame__avatar{
  position:relative;
  width:88px;height:88px;border-radius:50%;
  background:var(--blue);
  display:flex;align-items:center;justify-content:center;
  font-size:34px;font-weight:700;color:#fff;
  box-shadow:0 6px 24px rgba(5,131,242,.45);
  animation:avatarBreath 2.2s ease-in-out infinite;
}
.zoom-frame__avatar::before,
.zoom-frame__avatar::after{
  content:"";
  position:absolute;inset:0;
  border-radius:50%;
  border:2px solid rgba(96,176,255,.55);
  pointer-events:none;
  animation:sonarPulse 2.6s cubic-bezier(.4,0,.2,1) infinite;
}
.zoom-frame__avatar::after{
  animation-delay:1.3s;
  border-color:rgba(5,131,242,.5);
}
@keyframes sonarPulse{
  0%  {transform:scale(1);opacity:.7}
  80% {opacity:0}
  100%{transform:scale(2.1);opacity:0}
}
@keyframes avatarBreath{
  0%,100%{box-shadow:0 6px 24px rgba(5,131,242,.45)}
  50%    {box-shadow:0 6px 28px rgba(5,131,242,.7),0 0 0 2px rgba(96,176,255,.15)}
}
@media(prefers-reduced-motion:reduce){
  .zoom-frame__avatar,
  .zoom-frame__avatar::before,
  .zoom-frame__avatar::after{
    animation:none;
  }
}
.zoom-frame__name{
  position:absolute;bottom:10px;left:12px;
  font-size:12px;font-weight:600;color:rgba(255,255,255,.95);
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(4px);
  border-radius:4px;padding:4px 9px;
}
.zoom-mockup__label{
  padding:14px 16px;
  text-align:center;
  font-size:13px;font-weight:600;
  color:rgba(255,255,255,.75);
  letter-spacing:.5px;
  border-top:1px solid rgba(255,255,255,.06);
  background:rgba(0,0,0,.15);
}
.zoom-mockup__label span{
  margin:0 10px;color:rgba(255,255,255,.3);
}

/* ================================================================
   BLOCO 6 — ENTREGÁVEIS
   ================================================================ */
.deliverables-section{background:var(--bg-deep)}

.deliverables-section__header{text-align:center;margin-bottom:2rem}
.deliverables-section__header .eyebrow{font-size:15px;letter-spacing:2.5px;margin-bottom:1rem}

/* Hero mockup repurposed in deliverables */
.plan-mockup-hero{
  max-width:660px;margin-inline:auto;margin-bottom:3rem;
  /* styles live in .hero__mockup-card */
}

.deliverables-list{
  display:flex;flex-direction:column;gap:0;
  max-width:700px;margin-inline:auto;
  counter-reset:del;
}
.deliverable-item{
  display:flex;gap:28px;align-items:flex-start;
  padding:32px 0;
  border-bottom:1px solid var(--border);
}
.deliverable-item:last-child{border-bottom:none}
.deliverable-item__number{
  font-size:52px;font-weight:800;color:rgba(5,131,242,.4);
  line-height:.95;flex-shrink:0;width:72px;text-align:right;
  font-variant-numeric:tabular-nums;
  letter-spacing:-1px;
}
.deliverable-item__body strong{
  display:block;font-size:20px;font-weight:700;color:var(--white);
  margin-bottom:.55rem;line-height:1.3;
}
.deliverable-item__body p{
  font-size:17px;color:var(--text-sec);line-height:1.6;
}

.deliverables-cta{text-align:center;padding-top:3rem}
.deliverables-cta__micro{font-size:12px;color:var(--text-sec);margin-top:.75rem}

/* ================================================================
   BLOCO 7 — PROVA SOCIAL
   ================================================================ */
.proof-section{background:var(--bg-soft)}
.proof-section__header{text-align:center;margin-bottom:2.5rem}
.proof-section__header .eyebrow{font-size:15px;letter-spacing:2.5px;margin-bottom:1rem}

/* Timeline SVG Juliana */
.timeline-wrap{
  display:flex;align-items:center;gap:36px;
  max-width:860px;margin:0 auto 3.5rem;
  flex-wrap:wrap;justify-content:center;
}
.timeline-point{text-align:center}
.timeline-point__date{font-size:14px;color:var(--text-dark-sec);margin-bottom:8px;font-weight:700;letter-spacing:.5px}
.timeline-point__num{
  font-size:64px;font-weight:800;line-height:1;
  color:var(--text-dark);letter-spacing:-2px;
  font-variant-numeric:tabular-nums;
}
.timeline-point__num--accent{color:var(--blue)}
.timeline-point__label{font-size:15px;color:var(--text-dark-sec);margin-top:8px;font-weight:500}
.timeline-arrow{flex:1;min-width:140px;position:relative;display:flex;flex-direction:column;align-items:center;gap:8px}
.timeline-arrow svg{width:100%;max-width:180px;height:auto}
.timeline-growth{
  font-size:17px;font-weight:800;color:var(--blue);
  background:rgba(5,131,242,.12);border-radius:999px;padding:8px 18px;
  box-shadow:0 2px 8px rgba(5,131,242,.15);
}

.case-study{
  background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--border-dark);
  padding:40px 44px;margin-bottom:24px;
  max-width:780px;margin-inline:auto;
}
.case-study__location{
  font-size:14px;font-weight:800;color:var(--blue);
  text-transform:uppercase;letter-spacing:2px;
  margin-bottom:1.25rem;
}
.case-study__body p,
.case-study__result p{
  font-size:18px;color:var(--text-dark);
  line-height:1.7;margin-bottom:1.1rem;
}
.case-study__quote{
  border-left:5px solid var(--blue);
  padding:24px 28px 24px 56px;margin:1.75rem 0;
  background:rgba(5,131,242,.07);
  border-radius:0 12px 12px 0;
  font-style:italic;
  font-size:24px;font-weight:600;
  color:var(--blue);
  line-height:1.45;
  position:relative;
}
.case-study__quote-mark{
  font-size:64px;line-height:.7;color:var(--blue);opacity:.55;
  font-family:Georgia,serif;font-weight:700;
  position:absolute;top:18px;left:22px;
}
.case-study__result strong{font-size:22px;color:var(--text-dark)}

.testimonials-grid{
  display:grid;grid-template-columns:1fr;
  gap:24px;margin-top:2rem;
  max-width:780px;margin-inline:auto;
}
.testimonial-card{
  background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--border-dark);
  padding:28px 28px 24px;
}
.testimonial-card__stars{
  color:var(--blue);font-size:13px;letter-spacing:4px;
  margin-bottom:1rem;
}
.testimonial-card__quote{
  font-size:17px;color:var(--text-dark);
  line-height:1.65;margin-bottom:1.25rem;
  font-style:italic;
}
.testimonial-card__author{display:flex;align-items:center;gap:12px}
.testimonial-card__avatar{
  width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0;
}
.testimonial-card__name{
  display:block;font-size:15px;font-weight:700;color:var(--text-dark);
}
.testimonial-card__location{
  display:block;font-size:13px;color:var(--text-dark-sec);
}

/* ================================================================
   BLOCO 8 — AUTORIDADE
   ================================================================ */
.authority-section{background:var(--bg)}
.authority-section .eyebrow{font-size:15px;letter-spacing:2.5px;margin-bottom:1rem}
.authority-section__inner{
  display:grid;grid-template-columns:1fr 520px;
  gap:56px;align-items:stretch;
}
.authority-section__bio{
  font-size:18px;color:var(--text-sec);
  line-height:1.7;margin-bottom:1.1rem;
}
.authority-section__bio strong{color:var(--white)}
.authority-section__closing{
  font-size:17px;color:var(--text-sec);
  line-height:1.7;margin-top:1.25rem;
  font-style:italic;
}
.authority-section__photo{
  position:relative;
  min-height:100%;
  border-radius:var(--radius-xl);
  overflow:hidden;
  border:1px solid var(--border);
  box-shadow:var(--shadow-card);
}
.authority-section__img{
  display:block;
  width:100%;height:100%;
  object-fit:cover;object-position:20% 30%;
}
.authority-section__photo::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(1,6,88,.55) 100%);
  pointer-events:none;
}

.proof-list{display:flex;flex-direction:column;gap:14px;margin-top:1.75rem}
.proof-list__item{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius);padding:16px 18px;
}
.proof-list__num{
  font-size:22px;font-weight:800;color:var(--blue);
  white-space:nowrap;line-height:1.2;
}
.proof-list__icon{color:var(--blue);font-size:16px;margin-top:3px}
.proof-list__desc{font-size:16px;color:var(--text-sec);line-height:1.55}

.authority-signature{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.authority-signature__text{
  font-family:var(--font-sign);
  font-size:30px;color:var(--white);display:block;
}
.authority-signature__title{
  font-size:14px;color:var(--text-sec);display:block;margin-top:4px;
}

/* ================================================================
   BLOCO 9 — POR QUE É GRATUITO
   ================================================================ */
.why-free-section{background:var(--bg-elevated)}
.why-free-section__header{text-align:center;margin-bottom:2rem}
.why-free-section__header .eyebrow{font-size:15px;letter-spacing:2.5px;margin-bottom:1rem}
.why-free-section__body p{
  font-size:18px;color:var(--text-sec);
  line-height:1.7;margin-bottom:1.1rem;
}
.why-free-section__body strong{color:var(--white)}
.why-free-section__note{
  background:rgba(5,131,242,.08);
  border:1px solid rgba(5,131,242,.2);
  border-radius:var(--radius-lg);
  padding:24px 28px;
  font-size:17px;color:var(--text-sec);
  line-height:1.7;margin-top:1.75rem;
}
.why-free-section__note strong{color:var(--white)}

/* ================================================================
   BLOCO 10 — QUALIFICAÇÃO
   ================================================================ */
.qualification-section{background:var(--bg-soft)}
.qualification-section__header{text-align:center;margin-bottom:2.5rem}
.qualification-section__header .eyebrow{font-size:15px;letter-spacing:2.5px;margin-bottom:1rem}
.qualification-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;
  max-width:860px;margin-inline:auto;
}
.qual-col{
  position:relative;
  border-radius:16px;
  padding:36px 32px 32px;
  overflow:hidden;
  transition:transform .3s ease,box-shadow .3s ease;
}
.qual-col--yes{
  background:linear-gradient(145deg,var(--blue) 0%,var(--blue-dk) 100%);
  color:#fff;
  box-shadow:0 4px 16px -8px rgba(5,131,242,.4);
}
.qual-col--yes:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 36px -12px rgba(5,131,242,.5);
}
.qual-col--no{
  background:var(--bg);border:1px solid var(--border);
  color:var(--white);
  box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.qual-col--no:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 32px -14px rgba(0,0,0,.5);
}
.qual-col__header{
  display:flex;align-items:center;gap:12px;
  margin-bottom:1.75rem;padding-bottom:1.25rem;
}
.qual-col--yes .qual-col__header{border-bottom:1px solid rgba(255,255,255,.2)}
.qual-col--no  .qual-col__header{border-bottom:1px solid var(--border)}
.qual-col__badge{
  width:40px;height:40px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.qual-col__badge--yes{
  background:#fff;
  box-shadow:0 4px 14px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.4);
}
.qual-col__badge--no{
  background:var(--red);
  box-shadow:0 4px 14px rgba(255,59,59,.4),inset 0 1px 0 rgba(255,255,255,.25);
}
.qual-col__title{font-size:20px;font-weight:900;letter-spacing:.2px;line-height:1.2}
.qual-list{display:flex;flex-direction:column;gap:14px}
.qual-list li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:15px;line-height:1.5;
}
.qual-list__text{flex:1}
.qual-col--yes .qual-list li{color:rgba(255,255,255,.92)}
.qual-col--no  .qual-list li{color:var(--text-sec)}
.qual-icon{
  width:22px;height:22px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:1px;
}
.qual-icon--yes{
  background:#fff;
  box-shadow:0 2px 6px rgba(0,0,0,.12);
}
.qual-icon--no{
  background:var(--red);
  box-shadow:0 2px 6px rgba(255,59,59,.3);
}

/* ================================================================
   BLOCO 11 — FAQ
   ================================================================ */
.faq-section{background:var(--bg-soft)}
.faq-section__header{text-align:center;margin-bottom:2.5rem}
.faq-section__header .eyebrow{font-size:15px;letter-spacing:2.5px;margin-bottom:1rem}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--border-dark)}
.faq-trigger{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:20px 0;
  font-size:16px;font-weight:600;color:var(--text-dark);
  text-align:left;
  transition:color var(--transition);
}
.faq-trigger:hover{color:var(--blue)}
.faq-trigger__icon{
  flex-shrink:0;color:var(--blue);
  transition:transform var(--transition);
}
.faq-trigger[aria-expanded="true"] .faq-trigger__icon{transform:rotate(45deg)}
.faq-icon-v{transition:opacity var(--transition)}
.faq-trigger[aria-expanded="true"] .faq-icon-v{opacity:0}

/* Accordion grid trick */
.faq-body{
  display:grid;grid-template-rows:0fr;
  transition:grid-template-rows 280ms ease;
}
.faq-body[aria-hidden="false"],.faq-body.open{grid-template-rows:1fr}
.faq-body__inner{
  overflow:hidden;
}
.faq-body__inner p{
  font-size:15px;color:var(--text-dark-sec);
  line-height:1.7;padding-bottom:20px;
}

/* ================================================================
   BLOCO 12 — CTA FINAL
   ================================================================ */
.cta-final-section{
  background:var(--bg);
  position:relative;overflow:hidden;
}
.cta-final-section::before{
  content:'';position:absolute;
  top:-100px;left:50%;transform:translateX(-50%);
  width:600px;height:400px;
  background:radial-gradient(ellipse, rgba(5,131,242,.15) 0%,transparent 70%);
  pointer-events:none;
}
.cta-final-section__inner{
  position:relative;z-index:1;
  text-align:center;max-width:700px;margin-inline:auto;
}
.cta-final-section__inner .eyebrow{font-size:15px;letter-spacing:2.5px;margin-bottom:1rem}
.cta-final-section__body p{
  font-size:16px;color:var(--text-sec);
  line-height:1.7;margin-bottom:.9rem;
}
.cta-final-section__highlight{
  font-weight:700;color:var(--white)!important;
  font-size:18px!important;
}
.cta-final-section .vacancy-eyebrow{
  display:flex;justify-content:center;align-items:center;gap:12px;
  margin:.5rem 0 1.25rem;
  font-size:14px;font-weight:800;
  letter-spacing:3px;text-transform:uppercase;
  color:var(--red);
  background:transparent;padding:0;border:0;
  line-height:1;
}
.vacancy-eyebrow__sparkle{
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--red);font-size:16px;opacity:.9;
  line-height:1;transform:translateY(1px);
}
.cta-final-section .btn--xl{margin-top:2.75rem;margin-bottom:.25rem}
.cta-final-section__micro{font-size:12px;color:var(--text-sec);margin-bottom:3rem}

.cta-recap{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:16px;margin:0 auto 2.5rem;max-width:720px;
}
.cta-recap__item{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:24px 20px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  text-align:center;
  transition:transform .25s ease,border-color .25s ease,background .25s ease;
}
.cta-recap__item:hover{
  transform:translateY(-2px);
  border-color:rgba(5,131,242,.3);
  background:rgba(5,131,242,.06);
}
.cta-recap__item--accent{
  background:linear-gradient(180deg,rgba(5,131,242,.15),rgba(5,131,242,.05));
  border-color:rgba(5,131,242,.35);
  box-shadow:0 4px 20px -8px rgba(5,131,242,.4);
}
.cta-recap__item--accent:hover{
  border-color:rgba(5,131,242,.55);
  background:linear-gradient(180deg,rgba(5,131,242,.22),rgba(5,131,242,.08));
}
.cta-recap__icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:50%;
  background:rgba(5,131,242,.12);
  color:var(--blue);
  margin-bottom:4px;
}
.cta-recap__item--accent .cta-recap__icon{
  background:var(--blue);color:#fff;
  box-shadow:0 4px 14px rgba(5,131,242,.5);
}
.cta-recap__label{
  display:block;font-size:16px;font-weight:800;color:var(--white);
  letter-spacing:.2px;
}
.cta-recap__desc{
  display:block;font-size:13px;color:var(--text-sec);line-height:1.5;
}
.cta-recap__strike{
  text-decoration:line-through;
  text-decoration-color:rgba(255,255,255,.4);
  color:rgba(255,255,255,.5);
  margin-right:6px;
}

.credential-badges{
  display:flex;align-items:center;justify-content:center;
  gap:10px;flex-wrap:wrap;
}
.credential-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:500;color:var(--text-sec);
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;padding:7px 14px;
}
.credential-badge svg{opacity:.75}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{
  background:var(--bg-deep);
  border-top:3px solid var(--blue);
  padding:48px 0 32px;
}
.site-footer__inner{max-width:1080px;margin-inline:auto;padding-inline:24px}
.site-footer__top{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:16px;margin-bottom:1.5rem;
}
.site-footer__contact{font-size:13px;color:var(--text-sec)}
.site-footer__contact a{
  color:var(--text-sec);text-decoration:none;
  transition:color var(--transition);
}
.site-footer__contact a:hover{color:var(--blue)}
.site-footer__divider{
  height:1px;background:var(--border);margin-bottom:1.5rem;
}
.site-footer__links{
  display:flex;gap:24px;margin-bottom:1.5rem;flex-wrap:wrap;
}
.site-footer__links a{
  font-size:13px;color:var(--text-sec);text-decoration:none;
  transition:color var(--transition);
}
.site-footer__links a:hover{color:var(--white)}
.site-footer__disclaimer{
  font-size:12px;color:var(--text-sec);
  line-height:1.6;margin-bottom:1rem;
  opacity:.7;
}
.site-footer__copy{
  font-size:12px;color:var(--text-sec);opacity:.5;
}

/* ================================================================
   MODAL
   ================================================================ */
.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(0,2,30,.75);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  padding:16px;
}
.modal-overlay[hidden]{display:none}
.modal{
  background:var(--bg-elevated);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  width:100%;max-width:520px;
  max-height:90vh;overflow-y:auto;
  box-shadow:0 24px 80px rgba(0,0,0,.6);
  position:relative;
  scrollbar-width:thin;
  scrollbar-color:rgba(5,131,242,.45) transparent;
}
.modal::-webkit-scrollbar{width:8px}
.modal::-webkit-scrollbar-track{background:transparent;margin:8px 0}
.modal::-webkit-scrollbar-thumb{
  background:rgba(5,131,242,.45);
  border-radius:999px;
  border:2px solid transparent;background-clip:padding-box;
}
.modal::-webkit-scrollbar-thumb:hover{background:rgba(5,131,242,.65);background-clip:padding-box;border:2px solid transparent}
.modal__close{
  position:absolute;top:16px;right:16px;
  color:var(--text-sec);padding:6px;
  border-radius:var(--radius);
  transition:color var(--transition),background var(--transition);
  z-index:10;
}
.modal__close:hover{color:var(--white);background:rgba(255,255,255,.08)}
.modal__inner{padding:32px 32px 28px}
.modal__header{margin-bottom:1.5rem}
.modal__title{
  font-size:22px;font-weight:800;color:var(--white);
  letter-spacing:-.5px;margin-bottom:.5rem;line-height:1.2;
}
.modal__subtitle{font-size:14px;color:var(--text-sec);line-height:1.6}

/* Form fields */
.form{display:flex;flex-direction:column;gap:16px}
.form-field{position:relative}
.form-field__input{
  width:100%;
  background:#fff;
  border:1.5px solid rgba(26,26,46,.18);
  border-radius:var(--radius);
  color:var(--text-dark);
  font-family:var(--font-ui);
  font-size:15px;
  padding:22px 14px 8px;
  outline:none;
  transition:border-color var(--transition),box-shadow var(--transition);
  min-height:52px;
  appearance:none;
}
.form-field__input:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(5,131,242,.18);
}
.form-field__input::placeholder{color:transparent}
.form-field__label{
  position:absolute;left:14px;top:14px;
  font-size:14px;color:var(--text-dark-sec);
  pointer-events:none;
  transition:all 180ms ease;
  transform-origin:left top;
}
.form-field__input:not(:placeholder-shown) + .form-field__label,
.form-field__input:focus + .form-field__label{
  top:6px;font-size:10px;font-weight:700;letter-spacing:.5px;
  color:var(--blue);
}
.form-field__hint{
  display:block;font-size:11px;color:var(--text-sec);
  margin-top:4px;padding-left:2px;
}
.form-field__error{
  display:block;font-size:11px;color:var(--red);
  margin-top:4px;padding-left:2px;min-height:14px;
}
/* Selects */
.form-field--select{position:relative}
.form-field__select{
  padding:14px 40px 14px 14px;
  background:#fff;
  border:1.5px solid rgba(26,26,46,.18);
  border-radius:var(--radius);
  color:var(--text-dark);
  font-family:var(--font-ui);font-size:14px;
  width:100%;outline:none;
  appearance:none;cursor:pointer;
  min-height:52px;
  transition:border-color var(--transition),box-shadow var(--transition);
}
.form-field__select:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(5,131,242,.18);
}
.form-field__select option{background:#fff;color:var(--text-dark)}
.form-field__select-arrow{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  color:var(--text-dark-sec);pointer-events:none;
}
/* Textarea */
.form-field--textarea .form-field__input{
  padding-top:26px;resize:vertical;min-height:90px;
}
/* Searchable combobox (state selector) */
.form-field--combo{position:relative}
.form-field--combo .form-field__combo-input{
  padding-right:40px;
}
.form-field__combo-icon{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  color:var(--text-dark-sec);pointer-events:none;
  display:flex;align-items:center;justify-content:center;
}
.form-field__combo-list{
  position:absolute;left:0;right:0;top:calc(100% + 4px);
  max-height:240px;overflow-y:auto;
  background:#fff;
  border:1px solid rgba(26,26,46,.18);
  border-radius:var(--radius);
  box-shadow:0 12px 32px -8px rgba(0,0,0,.4);
  z-index:20;
  padding:6px 4px;margin:0;list-style:none;
  scrollbar-width:thin;
  scrollbar-color:rgba(5,131,242,.45) transparent;
}
.form-field__combo-list[hidden]{display:none}
.form-field__combo-list li{
  padding:9px 12px;font-size:14px;color:var(--text-dark);
  border-radius:6px;cursor:pointer;
  transition:background .12s ease,color .12s ease;
}
.form-field__combo-list li:hover,
.form-field__combo-list li.is-active{
  background:rgba(5,131,242,.1);
  color:var(--blue);
}
.form-field__combo-list li[hidden]{display:none}
.form-field__combo-list__empty{
  padding:10px 12px;font-size:13px;color:var(--text-dark-sec);
  font-style:italic;text-align:center;
}
/* WebKit scrollbar (Chrome/Safari/Edge) */
.form-field__combo-list::-webkit-scrollbar{width:8px}
.form-field__combo-list::-webkit-scrollbar-track{
  background:transparent;margin:4px 0;
}
.form-field__combo-list::-webkit-scrollbar-thumb{
  background:rgba(5,131,242,.35);
  border-radius:999px;
  border:2px solid transparent;
  background-clip:padding-box;
}
.form-field__combo-list::-webkit-scrollbar-thumb:hover{
  background:rgba(5,131,242,.6);
  background-clip:padding-box;
  border:2px solid transparent;
}
/* Phone prefix selector */
.form-field--phone{position:relative}
.form-field--phone .form-field__input{
  padding-left:104px;
  padding-top:22px;
  padding-bottom:8px;
  line-height:normal;
}
.form-field--phone .form-field__label{
  left:106px;
  top:14px;
  transform:none;
}
.form-field--phone .form-field__input:not(:placeholder-shown) + .form-field__label,
.form-field--phone .form-field__input:focus + .form-field__label{
  top:6px;
  transform:none;
  font-size:10px;font-weight:700;letter-spacing:.5px;
  color:var(--blue);
}
.phone-prefix__trigger{
  /* override — align with text inside the float-label input */
  top:1.5px;bottom:1.5px;
  padding-top:14px;
  align-items:flex-end;
  padding-bottom:10px;
}
.phone-prefix__trigger{
  position:absolute;left:1.5px;top:1.5px;bottom:1.5px;
  width:94px;
  display:flex;align-items:center;justify-content:center;gap:4px;
  background:rgba(26,26,46,.06);
  border-right:1.5px solid rgba(26,26,46,.18);
  border-radius:calc(var(--radius) - 1px) 0 0 calc(var(--radius) - 1px);
  padding:0 8px;
  color:var(--text-dark);
  font-size:13px;font-weight:600;
  cursor:pointer;
  transition:background var(--transition);
  z-index:2;
  white-space:nowrap;
}
.phone-prefix__trigger:hover{background:rgba(5,131,242,.08)}
.phone-prefix__trigger:focus-visible{
  outline:2px solid var(--blue);outline-offset:-2px;
  border-radius:var(--radius) 0 0 var(--radius);
}
.phone-prefix__flag{
  width:20px;height:14px;flex-shrink:0;
  display:inline-block;
  object-fit:cover;border-radius:2px;
  vertical-align:middle;
}
.phone-prefix__code{font-size:12px;font-weight:700;color:var(--text-dark);line-height:1}
.phone-prefix__arrow{
  color:var(--text-dark-sec);transition:transform 200ms ease;flex-shrink:0;line-height:1;
}
.phone-prefix__trigger[aria-expanded="true"] .phone-prefix__arrow{
  transform:rotate(180deg);
}
/* Dropdown */
.phone-prefix__dropdown{
  position:absolute;left:0;top:calc(100% + 4px);
  width:300px;
  background:#fff;
  border:1px solid rgba(26,26,46,.18);
  border-radius:var(--radius);
  box-shadow:0 12px 32px -8px rgba(0,0,0,.35);
  z-index:50;
  overflow:hidden;
}
.phone-prefix__dropdown[hidden]{display:none}
.phone-prefix__search-wrap{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;
  border-bottom:1px solid rgba(26,26,46,.1);
}
.phone-prefix__search-icon{color:rgba(26,26,46,.4);flex-shrink:0}
.phone-prefix__search{
  width:100%;border:none;outline:none;
  font-family:var(--font-ui);font-size:13px;
  color:var(--text-dark);background:transparent;
}
.phone-prefix__search::placeholder{color:rgba(26,26,46,.4)}
.phone-prefix__list{
  max-height:220px;overflow-y:auto;
  list-style:none;padding:6px 4px;margin:0;
  scrollbar-width:thin;
  scrollbar-color:rgba(5,131,242,.4) transparent;
}
.phone-prefix__list::-webkit-scrollbar{width:6px}
.phone-prefix__list::-webkit-scrollbar-track{background:transparent}
.phone-prefix__list::-webkit-scrollbar-thumb{
  background:rgba(5,131,242,.35);border-radius:999px;
}
.phone-prefix__option{
  display:flex;align-items:center;gap:10px;
  padding:8px 12px;border-radius:6px;
  cursor:pointer;font-size:13px;color:var(--text-dark);
  transition:background .12s ease;
}
.phone-prefix__option:hover,
.phone-prefix__option.is-active{background:rgba(5,131,242,.1);color:var(--blue)}
.phone-prefix__option[hidden]{display:none}
.phone-prefix__option__flag{
  width:22px;height:15px;flex-shrink:0;
  display:inline-block;object-fit:cover;border-radius:2px;
  vertical-align:middle;
}
.phone-prefix__option__name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.phone-prefix__option__dial{font-size:12px;font-weight:700;color:rgba(26,26,46,.5);flex-shrink:0}
.phone-prefix__option.is-active .phone-prefix__option__dial{color:var(--blue)}
.phone-prefix__empty{
  padding:12px;text-align:center;font-size:13px;
  color:var(--text-dark-sec);font-style:italic;
}
/* LGPD */
.form-lgpd{display:flex;flex-direction:column;gap:4px}
.form-lgpd__label{
  display:flex;align-items:flex-start;gap:10px;
  font-size:13px;color:var(--text-sec);
  cursor:pointer;line-height:1.55;
}
.form-lgpd__checkbox{
  position:absolute;opacity:0;width:0;height:0;
}
.form-lgpd__custom{
  width:18px;height:18px;border-radius:4px;
  border:1.5px solid var(--border);
  background:rgba(255,255,255,.06);
  flex-shrink:0;margin-top:1px;
  display:inline-flex;align-items:center;justify-content:center;
  transition:border-color var(--transition),background var(--transition);
}
.form-lgpd__checkbox:checked + .form-lgpd__custom{
  background:var(--blue);border-color:var(--blue);
}
.form-lgpd__checkbox:checked + .form-lgpd__custom::after{
  content:'✓';font-size:11px;color:#fff;font-weight:700;
}
.form-lgpd__label a{color:var(--blue)}
.form__micro{font-size:11px;color:var(--text-sec);text-align:center;margin-top:.5rem;line-height:1.5}
.req{color:var(--red)}
.form-field__optional{
  color:var(--text-sec);
  font-size:.85em;
  font-weight:500;
  margin-left:4px;
  opacity:.75;
}

/* Success */
.form-success{text-align:center;padding:20px 0}
.form-success[hidden]{display:none}
.form-success__icon{font-size:40px;color:var(--blue);margin-bottom:1rem}
.form-success__title{
  font-size:22px;font-weight:800;color:var(--white);margin-bottom:.75rem;
}
.form-success__text{font-size:15px;color:var(--text-sec);line-height:1.7;margin-bottom:1.5rem}

/* ================================================================
   SCROLL REVEAL
   ================================================================ */
.reveal,.reveal-child{
  opacity:0;transform:translateY(16px);
  transition:opacity 500ms ease,transform 500ms ease;
}
.reveal.is-visible,.reveal-child.is-visible{
  opacity:1;transform:translateY(0);
}
@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-child{opacity:1;transform:none;transition:none}
}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:900px){
  .authority-section__inner{grid-template-columns:1fr;gap:40px}
  .authority-section__photo{order:-1;max-width:320px;margin-inline:auto}
}
@media(max-width:720px){
  .pain-grid{grid-template-columns:1fr}
  .solution-grid{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .qualification-grid{grid-template-columns:1fr}
  .mockup-stats{grid-template-columns:repeat(3,1fr)}
  .cta-recap{grid-template-columns:1fr}
  .site-nav__link{display:none}
  .zoom-mockup{max-width:520px}
  .modal__inner{padding:24px 20px 20px}
}
@media(max-width:520px){
  .hero{padding:60px 0 0}
  section{padding:56px 0}
  .hero__headline{letter-spacing:-1px}
  .site-footer__top{flex-direction:column;align-items:flex-start}
  .mockup-stats{grid-template-columns:repeat(3,1fr);gap:6px}
  .mockup-stat__val{font-size:15px}
}
