/* ============================================================
   Dr. Felippe Rolim — v3 — Minimalismo Médico Premium
   Instrument Serif + Inter · Branco dominante · Azul profundo
   Sistema de 8px rigoroso
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Inter:wght@300;400;500;600;700&display=swap');

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:#0C1E35;
  background:#FAFBFC;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer}

/* ════════════════════════════════════════════════════════════
   TOKENS — SISTEMA DE 8PX
════════════════════════════════════════════════════════════ */
:root{
  /* spacing */
  --s1:8px; --s2:16px; --s3:24px; --s4:32px;
  --s5:40px; --s6:48px; --s7:56px; --s8:64px;
  --s10:80px; --s12:96px; --s15:120px; --s20:160px;

  /* layout */
  --max-w:1120px;
  --px:var(--s4);

  /* radius */
  --r-sm:4px; --r-md:8px; --r-lg:12px;
  --r-xl:16px; --r-2xl:24px; --r-pill:999px;

  /* paleta */
  --navy:     #0F2E5F;   /* azul marinho profundo — primário */
  --navy-2:   #1A4480;   /* variante hover */
  --navy-3:   #0A2149;   /* variante escura */
  --ink:      #0C1E35;   /* texto principal */
  --ink-2:    #3A546E;   /* texto secundário */
  --ink-3:    #7A90A4;   /* texto terciário */
  --ink-4:    #B0C2D4;   /* placeholder */
  --paper:    #FAFBFC;   /* background principal */
  --white:    #FFFFFF;
  --surface:  #F2F5F8;   /* superfícies */
  --surface-2:#E8EDF3;   /* bordas visíveis */
  --gold:     #C2922A;   /* acento premium — uso pontual */
  --gold-2:   #D9A83C;   /* hover do acento */
  --gold-pale:#FDF6E8;

  /* sombras */
  --sh-xs:0 1px 3px rgba(12,30,53,.06);
  --sh-sm:0 2px 8px rgba(12,30,53,.08),0 1px 3px rgba(12,30,53,.05);
  --sh-md:0 8px 24px rgba(12,30,53,.09),0 3px 8px rgba(12,30,53,.05);
  --sh-lg:0 20px 48px rgba(12,30,53,.11),0 8px 16px rgba(12,30,53,.06);
  --sh-xl:0 40px 80px rgba(12,30,53,.13),0 16px 32px rgba(12,30,53,.07);
  --sh-navy:0 8px 32px rgba(15,46,95,.28),0 2px 8px rgba(15,46,95,.14);
  --sh-navy-lg:0 16px 48px rgba(15,46,95,.36),0 4px 16px rgba(15,46,95,.16);

  /* transições */
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-std:cubic-bezier(.4,0,.2,1);
  --t1:.16s; --t2:.28s; --t3:.48s; --t4:.8s;
}

/* ════════════════════════════════════════════════════════════
   TIPOGRAFIA
   Instrument Serif — display, títulos grandes (elegância médica)
   Inter — todo o resto (legibilidade, modernidade)
════════════════════════════════════════════════════════════ */
.t-display{
  font-family:'Instrument Serif',Georgia,serif;
  font-weight:400; /* serif já tem peso visual próprio */
  letter-spacing:-.02em;
  line-height:1.08;
}
.t-serif{
  font-family:'Instrument Serif',Georgia,serif;
  font-weight:400;
}

/* ── SCROLL REVEAL ── */
[data-reveal]{
  opacity:0;transform:translateY(28px);
  transition:opacity var(--t4) var(--ease),transform var(--t4) var(--ease);
}
[data-reveal="blur"]{
  opacity:0;transform:translateY(16px);filter:blur(6px);
  transition:opacity var(--t4) var(--ease),transform var(--t4) var(--ease),filter var(--t4) var(--ease);
}
[data-reveal="left"]{
  opacity:0;transform:translateX(-28px);
  transition:opacity var(--t4) var(--ease),transform var(--t4) var(--ease);
}
[data-reveal="right"]{
  opacity:0;transform:translateX(28px);
  transition:opacity var(--t4) var(--ease),transform var(--t4) var(--ease);
}
[data-reveal="scale"]{
  opacity:0;transform:scale(.95);
  transition:opacity var(--t4) var(--ease),transform var(--t4) var(--ease);
}
[data-reveal].revealed{opacity:1;transform:none;filter:none}
[data-reveal-delay="1"]{transition-delay:.06s}
[data-reveal-delay="2"]{transition-delay:.12s}
[data-reveal-delay="3"]{transition-delay:.18s}
[data-reveal-delay="4"]{transition-delay:.24s}
[data-reveal-delay="5"]{transition-delay:.30s}
[data-reveal-delay="6"]{transition-delay:.36s}

/* ── CONTAINER ── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--px)}

/* ── EYEBROW / BADGE ── */
.section-badge{
  display:inline-flex;align-items:center;gap:var(--s1);
  font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--navy);margin-bottom:var(--s3);
}
.section-badge::before{
  content:'';width:20px;height:1.5px;background:var(--gold);flex-shrink:0;
  border-radius:2px;
}
.section-badge.light{color:rgba(255,255,255,.5)}
.section-badge.light::before{background:var(--gold)}

/* ════════════════════════════════════════════════════════════
   BOTÕES
════════════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:var(--s2);
  font-family:inherit;font-weight:600;font-size:14px;
  letter-spacing:.01em;border:none;cursor:pointer;
  transition:background var(--t2) var(--ease),transform var(--t2) var(--ease),
    box-shadow var(--t2) var(--ease),color var(--t2);
  white-space:nowrap;text-decoration:none;
  -webkit-font-smoothing:antialiased;
}

/* Primário: azul marinho — principal */
.btn-primary{
  background:var(--navy);color:#fff;
  padding:var(--s2) var(--s4);
  border-radius:var(--r-pill);
  box-shadow:var(--sh-navy);
}
.btn-primary:hover{
  background:var(--navy-2);
  transform:translateY(-2px);
  box-shadow:var(--sh-navy-lg);
}
.btn-primary:active{transform:translateY(0)}

.btn-primary-lg{padding:18px var(--s6);font-size:15px}

/* Ghost: contorno azul */
.btn-outline{
  background:transparent;color:var(--navy);
  padding:14px var(--s4);
  border-radius:var(--r-pill);
  border:1.5px solid var(--surface-2);
}
.btn-outline:hover{border-color:var(--navy);background:rgba(15,46,95,.04)}

/* Ícone arrow */
.btn-arrow{
  width:32px;height:32px;
  background:rgba(255,255,255,.15);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:transform var(--t2) var(--ease),background var(--t2);
}
.btn-primary:hover .btn-arrow{background:rgba(255,255,255,.25);transform:translateX(3px)}

/* ════════════════════════════════════════════════════════════
   NAVBAR
════════════════════════════════════════════════════════════ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:var(--s3) 0;
  transition:background var(--t3) var(--ease),box-shadow var(--t3),padding var(--t3) var(--ease);
}
.navbar.scrolled{
  background:rgba(250,251,252,.94);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  box-shadow:0 1px 0 var(--surface-2),0 4px 24px rgba(12,30,53,.06);
  padding:var(--s2) 0;
}
.navbar .container{display:flex;align-items:center;justify-content:space-between}
.navbar-logo{display:flex;align-items:center;gap:var(--s2)}
.navbar-logo-icon{
  width:40px;height:40px;border-radius:var(--r-lg);
  background:var(--navy);
  display:flex;align-items:center;justify-content:center;
  color:#fff;flex-shrink:0;
  box-shadow:var(--sh-navy);
}
.navbar-logo-text{line-height:1.2}
.navbar-logo-name{font-size:15px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.navbar-logo-title{font-size:11px;color:var(--ink-3);font-weight:400}

/* Navbar branca no início */
.navbar:not(.scrolled) .navbar-logo-name{color:#fff}
.navbar:not(.scrolled) .navbar-logo-title{color:rgba(255,255,255,.5)}
.navbar:not(.scrolled) .navbar-logo-icon{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);box-shadow:none}

.navbar-cta .btn-primary{padding:10px var(--s3);font-size:13px}
.navbar:not(.scrolled) .navbar-cta .btn-primary{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.25);
  box-shadow:none;
}
.navbar:not(.scrolled) .navbar-cta .btn-primary:hover{
  background:rgba(255,255,255,.22);
}

/* ════════════════════════════════════════════════════════════
   HERO — fundo azul marinho profundo + foto direita
════════════════════════════════════════════════════════════ */
.hero{
  min-height:100vh;
  background:var(--navy-3);
  position:relative;display:flex;align-items:center;
  overflow:hidden;padding-top:80px;
}

/* Textura sutil de fundo */
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 70% at 100% 50%,rgba(26,68,128,.6) 0%,transparent 65%),
    radial-gradient(ellipse 40% 60% at 0% 100%,rgba(9,26,58,.8) 0%,transparent 60%),
    radial-gradient(ellipse 80% 40% at 50% 0%,rgba(15,46,95,.4) 0%,transparent 70%);
  pointer-events:none;
}

/* Linhas finas de grade — muito sutis */
.hero-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:80px 80px;
}

.hero .container{
  display:grid;
  grid-template-columns:55fr 45fr;
  gap:var(--s8);
  align-items:center;
  position:relative;z-index:2;
  padding-top:var(--s6);
  padding-bottom:var(--s10);
}

/* Eyebrow pill — linha discreta */
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:var(--s2);
  margin-bottom:var(--s5);
}
.hero-eyebrow-line{
  width:32px;height:1px;background:var(--gold);flex-shrink:0;
}
.hero-eyebrow-text{
  font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.45);
}
.hero-eyebrow-dot{
  width:4px;height:4px;border-radius:50%;
  background:var(--gold);flex-shrink:0;
  animation:blink 2.5s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:.5}50%{opacity:1}}

/* Headline principal */
.hero h1{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:clamp(3rem,5.5vw,5rem);
  font-weight:400;
  color:#fff;
  line-height:1.06;
  letter-spacing:-.025em;
  margin-bottom:var(--s3);
}
.hero h1 em{
  font-style:italic;
  color:rgba(255,255,255,.65); /* em itálico suave — mais elegante que amarelo */
}

/* Linha âmbar sutil sob o headline */
.hero-headline-accent{
  width:48px;height:2px;
  background:var(--gold);
  border-radius:2px;
  margin-bottom:var(--s4);
}

.hero-body{
  font-size:17px;color:rgba(255,255,255,.55);
  line-height:1.75;margin-bottom:var(--s6);
  max-width:440px;font-weight:400;
}
.hero-body strong{color:rgba(255,255,255,.75);font-weight:600}

.hero-actions{
  display:flex;align-items:center;gap:var(--s2);
  flex-wrap:wrap;margin-bottom:var(--s8);
}

/* Social proof */
.hero-social-proof{
  display:flex;align-items:center;gap:var(--s4);flex-wrap:wrap;
  padding-top:var(--s5);
  border-top:1px solid rgba(255,255,255,.08);
}
.hero-proof-item{text-align:left}
.hero-proof-num{
  font-size:22px;font-weight:700;color:#fff;
  letter-spacing:-.04em;line-height:1;
  font-family:'Instrument Serif',Georgia,serif;
  font-weight:400;
}
.hero-proof-label{font-size:12px;color:rgba(255,255,255,.4);margin-top:3px;font-weight:400}
.hero-proof-divider{width:1px;height:32px;background:rgba(255,255,255,.1);flex-shrink:0}

/* Foto do médico — painel direito */
.hero-visual{
  position:relative;
  display:flex;flex-direction:column;gap:var(--s3);
  align-items:center;
}
.hero-photo-wrap{position:relative;width:100%;max-width:380px}

.hero-photo-frame{
  border-radius:var(--r-2xl);
  overflow:hidden;
  aspect-ratio:3/4;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--sh-xl),inset 0 1px 0 rgba(255,255,255,.06);
  position:relative;
}
.hero-photo-frame img{
  width:100%;height:100%;object-fit:cover;object-position:top center;
  display:block;
}

/* Placeholder mais elegante */
.hero-photo-placeholder{
  width:100%;height:100%;
  background:linear-gradient(160deg,rgba(26,68,128,.3) 0%,rgba(10,33,73,.6) 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:var(--s2);color:rgba(255,255,255,.2);
  font-size:12px;font-weight:500;text-align:center;padding:var(--s3);
  letter-spacing:.02em;
}
.hero-photo-placeholder svg{opacity:.15;width:56px;height:56px}

/* Credencial — badge sobre a foto */
.hero-credential-badge{
  position:absolute;bottom:var(--s3);left:var(--s3);right:var(--s3);
  background:rgba(9,26,58,.88);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-xl);
  padding:var(--s2) var(--s3);
  display:flex;align-items:center;justify-content:space-between;gap:var(--s2);
  box-shadow:0 8px 24px rgba(0,0,0,.4);
}
.credential-name{font-size:14px;font-weight:700;color:#fff;letter-spacing:-.02em}
.credential-title{font-size:11px;color:rgba(255,255,255,.4);margin-top:2px;font-weight:400}
.credential-badges{display:flex;gap:5px;flex-direction:column;align-items:flex-end}
.credential-rqe{
  font-size:10px;font-weight:700;letter-spacing:.04em;
  color:var(--gold-2);
  background:rgba(194,146,42,.1);border:1px solid rgba(194,146,42,.2);
  border-radius:var(--r-sm);padding:3px 8px;white-space:nowrap;
}

/* VSL card */
.hero-vsl-card{
  width:100%;max-width:380px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--sh-lg);
}
.vsl-placeholder{
  aspect-ratio:16/9;
  background:linear-gradient(135deg,rgba(15,46,95,.8),rgba(9,26,58,.9));
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;position:relative;
}
.vsl-play-btn{
  width:56px;height:56px;background:#fff;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:transform var(--t2) var(--ease),box-shadow var(--t2);
  animation:pulse-play 3s ease-in-out infinite;
  color:var(--navy);
}
.vsl-play-btn svg{color:var(--navy);margin-left:3px}
@keyframes pulse-play{
  0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.2)}
  50%{box-shadow:0 0 0 16px rgba(255,255,255,0)}
}
.vsl-placeholder:hover .vsl-play-btn{transform:scale(1.08);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.vsl-label{
  padding:var(--s2) var(--s3);
  font-size:13px;color:rgba(255,255,255,.4);
  display:flex;align-items:center;gap:var(--s1);
}
.vsl-label strong{color:rgba(255,255,255,.65);font-weight:600}
.vsl-frame{width:100%;aspect-ratio:16/9;border:none;display:none}

/* ════════════════════════════════════════════════════════════
   TICKER
════════════════════════════════════════════════════════════ */
.ticker-band{
  background:#fff;
  border-top:1px solid var(--surface-2);
  border-bottom:1px solid var(--surface-2);
  padding:14px 0;overflow:hidden;
}
.ticker-track{
  display:flex;gap:var(--s8);
  animation:ticker-scroll 40s linear infinite;width:max-content;
}
.ticker-band:hover .ticker-track{animation-play-state:paused}
@keyframes ticker-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-item{
  display:flex;align-items:center;gap:var(--s2);
  font-size:11px;font-weight:600;color:var(--ink-3);
  white-space:nowrap;letter-spacing:.1em;text-transform:uppercase;
}
.ticker-dot{
  width:3px;height:3px;border-radius:50%;
  background:var(--gold);flex-shrink:0;
}

/* ════════════════════════════════════════════════════════════
   SECTION DOR — branco limpo, texto grande
════════════════════════════════════════════════════════════ */
.section-pain{
  background:#fff;
  padding:var(--s15) 0;
  position:relative;
  text-align:center;
}
.section-pain::after{
  content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:80px;height:1px;background:var(--surface-2);
}
.pain-headline{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:clamp(2rem,4vw,3.5rem);
  color:var(--ink-3);font-weight:400;
  line-height:1.25;letter-spacing:-.025em;
  max-width:760px;margin:0 auto var(--s8);
}
.pain-headline strong{color:var(--ink);font-weight:400} /* peso visual no serif */
.pain-statement-main{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:clamp(2.4rem,5vw,4rem);
  color:var(--navy);font-weight:400;
  letter-spacing:-.03em;line-height:1.1;
  margin-bottom:var(--s2);
}
.pain-statement-sub{
  font-size:clamp(1rem,2vw,1.3rem);
  color:var(--ink-3);font-weight:400;letter-spacing:-.01em;
}

/* ════════════════════════════════════════════════════════════
   STATS — barra horizontal clean
════════════════════════════════════════════════════════════ */
.section-stats{
  background:var(--navy);
  padding:var(--s8) 0;
}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
}
.stat-item{
  text-align:center;padding:var(--s5) var(--s4);
  border-right:1px solid rgba(255,255,255,.08);
}
.stat-item:last-child{border-right:none}
.stat-number{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:clamp(2.5rem,3.5vw,3.75rem);
  font-weight:400;color:#fff;
  line-height:1;letter-spacing:-.04em;margin-bottom:var(--s1);
}
.stat-number .accent{color:var(--gold-2)}
.stat-label{
  font-size:12px;color:rgba(255,255,255,.4);
  line-height:1.5;font-weight:500;letter-spacing:.02em;
}

/* ════════════════════════════════════════════════════════════
   COMO FUNCIONA — branco, layout editorial
════════════════════════════════════════════════════════════ */
.section-how{background:#fff;padding:var(--s15) 0}
.section-header{margin-bottom:var(--s10)}
.section-header.center{text-align:center}

.section-title{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:clamp(2.2rem,4vw,3.5rem);
  color:var(--ink);font-weight:400;
  line-height:1.1;letter-spacing:-.03em;
  margin-bottom:var(--s2);
}
.section-title.on-dark{color:#fff}
.section-title em{font-style:italic;color:var(--navy)}
.section-desc{
  font-size:16px;color:var(--ink-2);
  max-width:540px;line-height:1.75;font-weight:400;
}
.section-header.center .section-desc{margin:0 auto}
.section-desc.on-dark{color:rgba(255,255,255,.45)}

.how-steps{}
.how-step{
  display:grid;
  grid-template-columns:64px 1fr 1fr;
  gap:var(--s6);align-items:start;
  padding:var(--s8) 0;
  border-bottom:1px solid var(--surface);
}
.how-step:last-child{border-bottom:none}
.how-step-num{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:2.75rem;font-weight:400;
  color:var(--surface-2);line-height:1;
  letter-spacing:-.04em;padding-top:4px;
  transition:color var(--t3) var(--ease);
}
.how-step:hover .how-step-num{color:rgba(194,146,42,.35)}
.how-step-subtitle{
  font-size:11px;font-weight:600;color:var(--gold);
  text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--s1);
}
.how-step-title{
  font-size:21px;font-weight:700;color:var(--ink);
  margin-bottom:var(--s2);letter-spacing:-.025em;line-height:1.25;
}
.how-step-text{
  font-size:15px;color:var(--ink-2);line-height:1.75;margin-bottom:var(--s3);
}
.how-step-tags{display:flex;flex-wrap:wrap;gap:var(--s1)}
.tag{
  font-size:12px;font-weight:500;color:var(--navy);
  background:rgba(15,46,95,.05);
  border:1px solid rgba(15,46,95,.1);
  border-radius:var(--r-sm);padding:4px var(--s2);
}
.how-step-visual{
  background:var(--surface);border-radius:var(--r-2xl);
  aspect-ratio:4/3;overflow:hidden;
  border:1px solid var(--surface-2);
}
.how-step-visual img{width:100%;height:100%;object-fit:cover}
.how-step-visual-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  color:var(--surface-2);
}

/* ════════════════════════════════════════════════════════════
   PARA QUEM É — fundo levemente cinza
════════════════════════════════════════════════════════════ */
.section-for-whom{
  background:var(--surface);padding:var(--s15) 0;
  position:relative;
}
.for-whom-intro{
  font-size:16px;color:var(--ink-2);margin-bottom:var(--s8);
  max-width:460px;line-height:1.75;
}
.for-whom-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s2);
}
.for-whom-card{
  position:relative;border-radius:var(--r-2xl);overflow:hidden;
  aspect-ratio:.72;cursor:pointer;
  background:var(--navy-3);
  border:1px solid rgba(15,46,95,.1);
  transition:transform var(--t3) var(--ease),box-shadow var(--t3) var(--ease);
  box-shadow:var(--sh-md);
}
.for-whom-card:hover{transform:translateY(-8px);box-shadow:var(--sh-xl)}
.for-whom-card-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform var(--t3) var(--ease),opacity var(--t3);opacity:.3;
}
.for-whom-card:hover .for-whom-card-bg{transform:scale(1.05);opacity:.45}
.for-whom-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(9,26,58,.97) 30%,rgba(9,26,58,.2) 100%);
}
.for-whom-card-content{
  position:relative;z-index:2;height:100%;
  display:flex;flex-direction:column;justify-content:flex-end;padding:var(--s4);
}
.for-whom-card-icon{
  width:40px;height:40px;
  background:rgba(194,146,42,.1);border:1px solid rgba(194,146,42,.18);
  border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:var(--s2);color:var(--gold-2);
}
.for-whom-card-title{
  font-size:16px;font-weight:700;color:#fff;
  line-height:1.3;margin-bottom:var(--s1);letter-spacing:-.02em;
}
.for-whom-card-text{
  font-size:13px;color:rgba(255,255,255,.45);
  line-height:1.6;margin-bottom:var(--s2);
}
.for-whom-card-cta{
  display:inline-flex;align-items:center;gap:var(--s1);
  font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold-2);opacity:0;transform:translateY(8px);
  transition:opacity var(--t2) var(--ease),transform var(--t2) var(--ease);
}
.for-whom-card:hover .for-whom-card-cta{opacity:1;transform:translateY(0)}

/* ════════════════════════════════════════════════════════════
   SOBRE — branco, foto grande, texto editorial
════════════════════════════════════════════════════════════ */
.section-about{background:#fff;padding:var(--s15) 0}
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--s15);align-items:center;
}
.about-photo-wrap{position:relative}
.about-photo-frame{
  border-radius:var(--r-2xl);overflow:hidden;
  border:1px solid var(--surface-2);
  aspect-ratio:4/5;background:var(--surface);
  box-shadow:var(--sh-lg);
}
.about-photo-frame img{width:100%;height:100%;object-fit:cover;object-position:top}
.about-photo-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  color:var(--surface-2);
}

/* Badge circular flutuante */
.about-badge-circular-placeholder{
  position:absolute;bottom:-20px;right:-20px;
  width:112px;height:112px;border-radius:50%;
  background:var(--navy);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:600;color:rgba(255,255,255,.75);
  text-align:center;padding:var(--s2);line-height:1.45;
  letter-spacing:.04em;text-transform:uppercase;
  box-shadow:var(--sh-navy);
}

.about-title{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:clamp(2rem,3.5vw,3rem);
  color:var(--ink);font-weight:400;
  margin-bottom:var(--s1);letter-spacing:-.03em;line-height:1.12;
}
.about-specialty{
  font-size:11px;color:var(--gold);font-weight:700;
  margin-bottom:var(--s5);letter-spacing:.1em;text-transform:uppercase;
}
.about-bio{
  font-size:16px;color:var(--ink-2);
  line-height:1.8;margin-bottom:var(--s6);font-weight:400;
}
.about-credentials{display:flex;flex-wrap:wrap;gap:var(--s1);margin-bottom:var(--s8)}
.credential-chip{
  display:inline-flex;align-items:center;gap:var(--s1);
  background:var(--surface);border:1px solid var(--surface-2);
  border-radius:var(--r-md);padding:7px var(--s2);
  font-size:12px;font-weight:600;color:var(--ink-2);
}
.credential-chip svg{color:var(--navy);flex-shrink:0}

/* ════════════════════════════════════════════════════════════
   DEPOIMENTOS — fundo levemente acinzentado
════════════════════════════════════════════════════════════ */
.section-testimonials{background:var(--surface);padding:var(--s15) 0}
.testimonials-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s3);
}
.testimonial-card{
  background:#fff;border:1px solid var(--surface-2);border-radius:var(--r-2xl);
  padding:var(--s5);
  transition:transform var(--t2) var(--ease),box-shadow var(--t2) var(--ease),border-color var(--t2);
}
.testimonial-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md);border-color:var(--ink-4)}
.testimonial-top{
  display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s3);
}
.testimonial-stars{color:#F59E0B;font-size:14px;letter-spacing:2px}
.google-badge{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-3);font-weight:500}
.google-g{
  width:20px;height:20px;
  background:linear-gradient(135deg,#4285F4 0%,#EA4335 33%,#FBBC05 66%,#34A853 100%);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:11px;font-weight:900;
}
.testimonial-text{font-size:14px;color:var(--ink-2);line-height:1.75;margin-bottom:var(--s3)}
.testimonial-author{display:flex;align-items:center;gap:var(--s2)}
.testimonial-avatar{
  width:40px;height:40px;border-radius:50%;
  background:rgba(15,46,95,.06);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;color:var(--navy);
  flex-shrink:0;overflow:hidden;
}
.testimonial-avatar img{width:100%;height:100%;object-fit:cover}
.testimonial-name{font-size:14px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.testimonial-source{font-size:12px;color:var(--ink-3)}

/* ════════════════════════════════════════════════════════════
   FAQ — branco limpo
════════════════════════════════════════════════════════════ */
.section-faq{background:#fff;padding:var(--s15) 0}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s1)}
.faq-item{
  border:1px solid var(--surface);border-radius:var(--r-xl);
  overflow:hidden;background:#fff;
  transition:border-color var(--t2);
}
.faq-item.open{border-color:var(--surface-2)}
.faq-question{
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--s2);padding:var(--s3) var(--s4);
  cursor:pointer;user-select:none;background:none;border:none;
  width:100%;text-align:left;transition:background var(--t1);
}
.faq-question:hover{background:var(--surface)}
.faq-q-text{
  font-family:inherit;font-weight:600;font-size:14px;
  color:var(--ink);line-height:1.45;letter-spacing:-.01em;
}
.faq-icon{
  width:32px;height:32px;border-radius:50%;
  background:var(--surface);border:1px solid var(--surface-2);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  color:var(--navy);
  transition:background var(--t2),transform var(--t2) var(--ease),border-color var(--t2);
}
.faq-item.open .faq-icon{
  background:var(--navy);color:#fff;
  transform:rotate(45deg);border-color:var(--navy);
}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-answer-inner{
  padding:0 var(--s4) var(--s3);
  font-size:14px;color:var(--ink-2);line-height:1.75;
}

/* ════════════════════════════════════════════════════════════
   LOCALIZAÇÃO — fundo azul marinho
════════════════════════════════════════════════════════════ */
.section-location{
  background:var(--navy-3);padding:var(--s15) 0;
  position:relative;
}
.section-location::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
}
.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3)}
.location-item{
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r-2xl);padding:var(--s6);
  transition:border-color var(--t2);
}
.location-item:hover{border-color:rgba(194,146,42,.2)}
.location-icon{
  width:48px;height:48px;
  background:rgba(194,146,42,.08);border:1px solid rgba(194,146,42,.16);
  border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-2);margin-bottom:var(--s4);
}
.location-city{
  font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);margin-bottom:var(--s1);
}
.location-name{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:22px;color:#fff;margin-bottom:var(--s1);
  letter-spacing:-.025em;line-height:1.3;
}
.location-address{font-size:14px;color:rgba(255,255,255,.4);line-height:1.65}

/* ════════════════════════════════════════════════════════════
   CTA FINAL — azul marinho + acento âmbar
════════════════════════════════════════════════════════════ */
.section-cta-final{
  background:var(--navy);padding:var(--s20) 0;text-align:center;
  position:relative;overflow:hidden;
}
.section-cta-final::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%,rgba(26,68,128,.4) 0%,transparent 60%),
    radial-gradient(ellipse 40% 40% at 10% 90%,rgba(9,26,58,.6) 0%,transparent 55%);
  pointer-events:none;
}
.cta-final-content{position:relative;z-index:2;max-width:580px;margin:0 auto}
.cta-final-title{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:clamp(2.2rem,4.5vw,3.75rem);
  color:#fff;margin-bottom:var(--s3);
  letter-spacing:-.035em;line-height:1.1;font-weight:400;
}
.cta-final-title em{font-style:italic;color:rgba(255,255,255,.6)}
.cta-final-text{
  font-size:17px;color:rgba(255,255,255,.45);
  margin-bottom:var(--s8);line-height:1.7;
}
/* Botão CTA final — branco no fundo azul */
.cta-final-content .btn-primary{
  background:#fff;color:var(--navy);
  box-shadow:0 8px 32px rgba(0,0,0,.2),0 2px 8px rgba(0,0,0,.1);
}
.cta-final-content .btn-primary:hover{
  background:var(--gold-pale);color:var(--navy);
  box-shadow:0 16px 48px rgba(0,0,0,.25);
}
.cta-final-disclaimer{margin-top:var(--s4);font-size:13px;color:rgba(255,255,255,.2)}

/* ════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════ */
.footer{
  background:#040F20;
  border-top:1px solid rgba(255,255,255,.04);
  padding:var(--s10) 0 var(--s5);
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr;
  gap:var(--s8);margin-bottom:var(--s8);
}
.footer-logo{display:flex;align-items:center;gap:var(--s2);margin-bottom:var(--s3)}
.footer-logo-icon{
  width:32px;height:32px;border-radius:var(--r-md);
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);
}
.footer-logo-name{font-size:14px;font-weight:700;color:rgba(255,255,255,.75);letter-spacing:-.02em}
.footer-tagline{font-size:13px;color:rgba(255,255,255,.22);line-height:1.7;margin-bottom:var(--s3);max-width:280px}
.footer-credentials{display:flex;flex-direction:column;gap:5px}
.footer-cred{font-size:12px;color:rgba(255,255,255,.18);display:flex;align-items:center;gap:6px}
.footer-cred::before{content:'';width:3px;height:3px;border-radius:50%;background:var(--gold);opacity:.35;flex-shrink:0}
.footer-col-title{
  font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.25);margin-bottom:var(--s3);
}
.footer-links{display:flex;flex-direction:column;gap:var(--s1)}
.footer-link{font-size:13px;color:rgba(255,255,255,.3);transition:color var(--t1)}
.footer-link:hover{color:rgba(255,255,255,.7)}
.footer-social{display:flex;gap:var(--s1);margin-bottom:var(--s3)}
.footer-social-link{
  width:34px;height:34px;border-radius:var(--r-md);
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.3);transition:all var(--t2);
}
.footer-social-link:hover{background:rgba(194,146,42,.08);border-color:rgba(194,146,42,.18);color:var(--gold)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.04);padding-top:var(--s4);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:var(--s2);
}
.footer-copyright{font-size:12px;color:rgba(255,255,255,.15)}
.footer-made-by{font-size:12px;color:rgba(255,255,255,.12)}
.footer-made-by a{color:var(--gold);opacity:.55}

/* ════════════════════════════════════════════════════════════
   WHATSAPP FLUTUANTE
════════════════════════════════════════════════════════════ */
.whatsapp-float{
  position:fixed;bottom:var(--s4);right:var(--s4);z-index:999;
  display:flex;flex-direction:column;align-items:flex-end;gap:var(--s1);
}
.whatsapp-float-btn{
  width:56px;height:56px;background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.38);
  transition:transform var(--t2) var(--ease),box-shadow var(--t2);
  text-decoration:none;position:relative;
}
.whatsapp-float-btn:hover{
  transform:scale(1.1);
  box-shadow:0 8px 32px rgba(37,211,102,.48);
}
.whatsapp-float-pulse{
  position:absolute;width:56px;height:56px;border-radius:50%;
  background:rgba(37,211,102,.2);
  animation:float-pulse 3s ease-in-out infinite;pointer-events:none;
}
@keyframes float-pulse{
  0%,100%{transform:scale(1);opacity:.4}
  50%{transform:scale(1.55);opacity:0}
}
.whatsapp-float-tooltip{
  background:rgba(4,15,32,.93);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.07);border-radius:var(--r-lg);
  padding:7px var(--s2);font-size:12px;font-weight:600;
  color:rgba(255,255,255,.65);white-space:nowrap;
  opacity:0;transform:translateX(8px);
  transition:opacity var(--t2),transform var(--t2);pointer-events:none;
}
.whatsapp-float:hover .whatsapp-float-tooltip{opacity:1;transform:translateX(0)}

/* ════════════════════════════════════════════════════════════
   RESPONSIVO
════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .for-whom-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid .stat-item:nth-child(2){border-right:none}
  .stats-grid .stat-item:nth-child(3){
    border-top:1px solid rgba(255,255,255,.08);
    border-right:1px solid rgba(255,255,255,.08);
  }
  .stats-grid .stat-item:nth-child(4){
    border-top:1px solid rgba(255,255,255,.08);border-right:none;
  }
}
@media(max-width:900px){
  :root{--px:var(--s3)}
  .hero .container{
    grid-template-columns:1fr;gap:var(--s6);padding-top:var(--s3);
  }
  .hero-visual{max-width:440px;margin:0 auto;width:100%}
  .about-grid{grid-template-columns:1fr;gap:var(--s8)}
  .how-step{
    grid-template-columns:56px 1fr;gap:var(--s3);padding:var(--s6) 0;
  }
  .how-step-visual{display:none}
  .location-grid,.testimonials-grid,.faq-grid{grid-template-columns:1fr;gap:var(--s2)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:var(--s6)}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:640px){
  :root{--px:var(--s2)}
  .hero{padding-top:88px}
  .navbar-cta .btn-primary{padding:9px var(--s2);font-size:13px}
  .for-whom-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stats-grid .stat-item{
    border-right:none!important;
    border-bottom:1px solid rgba(255,255,255,.08)!important;
    border-top:none!important;
  }
  .stats-grid .stat-item:last-child{border-bottom:none!important}
  .footer-grid{grid-template-columns:1fr;gap:var(--s5)}
  .footer-brand{grid-column:auto}
  .footer-bottom{flex-direction:column;text-align:center}
  .section-cta-final{padding:var(--s15) 0}
  .btn-primary-lg{padding:16px var(--s5);font-size:15px}
  .about-badge-circular-placeholder{right:0;bottom:-16px}
}