/* ============================================================
   Claude sem Código — estilos não-críticos
   Estética: Apple-refined. Tipografia protagonista, alternância
   cromática, respiração cinematográfica.
   ============================================================ */

/* ============================================================
   HERO — trust row + retrato com badges flutuantes
   ============================================================ */

.hero-trust{
  display:flex;align-items:center;gap:14px;
  margin-top:clamp(28px,3vw,36px);
  flex-wrap:wrap;
  font-size:14px;color:var(--text-soft);
}
.stars{display:inline-flex;align-items:center;gap:2px;color:var(--accent)}
.trust-score{color:var(--text);letter-spacing:-0.005em}
.trust-score b{font-weight:700;font-variant-numeric:tabular-nums}
.trust-label{letter-spacing:-0.005em}
.trust-label b{color:var(--text);font-weight:700;font-variant-numeric:tabular-nums}
.trust-sep{width:1px;height:14px;background:var(--line);display:inline-block}

/* -------- Retrato -------- */
.hero-visual{
  position:relative;
  display:flex;justify-content:center;align-items:center;
  min-height:420px;
}
.portrait{
  position:relative;
  width:min(100%,380px);
  aspect-ratio:4/5.2;
  margin:0;
}
.portrait-frame{
  position:relative;
  width:100%;height:100%;
  border-radius:32px;
  overflow:hidden;
  background:linear-gradient(160deg,#F0E9DE 0%,#E8DED0 50%,#DACDB8 100%);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.7) inset,
    0 40px 80px -30px rgba(29,29,31,0.35),
    0 20px 40px -20px rgba(217,119,87,0.25);
  transform:translateZ(0);
}
.portrait-frame::before{
  /* moldura interna */
  content:"";position:absolute;inset:0;
  border-radius:inherit;
  border:1px solid rgba(255,255,255,0.6);
  pointer-events:none;z-index:2;
}
.portrait-frame::after{
  /* highlight sutil topo */
  content:"";position:absolute;inset:0;
  border-radius:inherit;
  background:linear-gradient(180deg,rgba(255,255,255,0.18) 0%,transparent 30%);
  pointer-events:none;z-index:2;
}
.portrait-frame img{
  display:block;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 18%;
  filter:saturate(1.02) contrast(1.02);
}

/* Glow coral por trás da moldura */
.portrait::before{
  content:"";position:absolute;
  inset:-8% -12% -6% -8%;
  background:radial-gradient(ellipse at 70% 30%,rgba(217,119,87,0.35) 0%,rgba(217,119,87,0.12) 40%,transparent 70%);
  filter:blur(30px);
  z-index:-1;
  pointer-events:none;
}

/* ---- Badges flutuantes ---- */
.badge{
  position:absolute;
  background:rgba(255,255,255,0.85);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  backdrop-filter:saturate(180%) blur(16px);
  border:1px solid rgba(255,255,255,0.9);
  border-radius:16px;
  padding:12px 16px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.8) inset,
    0 12px 32px -12px rgba(29,29,31,0.22),
    0 4px 12px -4px rgba(29,29,31,0.1);
  z-index:3;
}

/* badge top-right: avaliação */
.badge-tr{
  top:16px;right:-14px;
  display:flex;flex-direction:column;align-items:flex-start;
  min-width:112px;
}
.badge-tr .badge-kicker{
  font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--text-mute);
  margin-bottom:4px;
}
.badge-tr .badge-value{
  font-size:22px;font-weight:700;letter-spacing:-0.02em;color:var(--text);
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.badge-tr .badge-value small{
  font-size:12px;font-weight:500;color:var(--text-mute);margin-left:2px;
}

/* badge bottom-left: alunos */
.badge-bl{
  bottom:56px;left:-22px;
  display:flex;align-items:center;gap:12px;
}
.badge-bl .badge-icon{
  width:36px;height:36px;border-radius:10px;
  background:rgba(217,119,87,0.12);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.badge-bl .badge-value{
  display:block;font-size:20px;font-weight:700;letter-spacing:-0.02em;color:var(--text);
  font-variant-numeric:tabular-nums;line-height:1;
}
.badge-bl .badge-kicker{
  display:block;font-size:11px;font-weight:500;color:var(--text-mute);
  margin-top:3px;
}

/* pill inferior: outcome */
.badge-pill{
  position:absolute;
  bottom:-18px;left:50%;transform:translateX(-50%);
  background:var(--bg-dark);color:#fff;
  padding:10px 18px;
  border-radius:999px;
  font-size:13px;font-weight:500;letter-spacing:-0.005em;
  display:inline-flex;align-items:center;gap:8px;
  box-shadow:
    0 14px 32px -10px rgba(29,29,31,0.45),
    0 0 0 1px rgba(255,255,255,0.08) inset;
  white-space:nowrap;
  z-index:4;
}
.badge-pill b{color:var(--accent);font-weight:700}
.badge-pill .pill-arrow{
  color:var(--accent);font-size:14px;font-weight:700;
  display:inline-block;transform:translateY(-0.5px);
}

/* ---- Mobile tweaks do retrato ---- */
@media (max-width:979px){
  .hero{min-height:auto}
  .hero-visual{order:-1;min-height:0;margin-bottom:4px}
  .portrait{width:min(60vw,280px)}
  .badge-tr{top:8px;right:-4px;padding:9px 13px;min-width:auto}
  .badge-tr .badge-kicker{font-size:10px}
  .badge-tr .badge-value{font-size:17px}
  .badge-bl{bottom:32px;left:-6px;padding:9px 12px;gap:10px}
  .badge-bl .badge-icon{width:28px;height:28px}
  .badge-bl .badge-icon svg{width:15px;height:15px}
  .badge-bl .badge-value{font-size:15px}
  .badge-bl .badge-kicker{font-size:10px}
  .badge-pill{bottom:-12px;font-size:11px;padding:8px 13px;gap:6px}
}

@media (max-width:560px){
  .hero{padding:clamp(36px,5vh,60px) 0 clamp(40px,5vh,64px)}
  .hero-inner{gap:22px}
  .portrait{width:min(52vw,220px)}
  .badge-tr{top:4px;right:-2px;padding:7px 11px}
  .badge-tr .badge-kicker{font-size:9px;letter-spacing:0.04em}
  .badge-tr .badge-value{font-size:15px}
  .badge-tr .badge-value small{font-size:10px}
  .badge-bl{bottom:22px;left:-4px;padding:7px 10px;gap:8px}
  .badge-bl .badge-icon{width:24px;height:24px;border-radius:8px}
  .badge-bl .badge-icon svg{width:13px;height:13px}
  .badge-bl .badge-value{font-size:13px}
  .badge-bl .badge-kicker{font-size:9px;margin-top:1px}
  .badge-pill{bottom:-10px;font-size:10.5px;padding:7px 12px;letter-spacing:-0.01em}
  .eyebrow{margin-bottom:18px}
  .hero-sub{margin-bottom:22px}
}

/* -------- Section frame genérica -------- */
.sec{
  padding:clamp(72px,12vw,160px) 0;
  position:relative;
}
.sec-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.sec-soft{background:var(--bg-soft);color:var(--text)}
.sec-dark{background:var(--bg-dark);color:var(--text-on-dark)}
.sec-dark .eyebrow{color:#E8826A}
.sec-dark .note{color:var(--text-on-dark-soft)}
.sec-dark strong{color:#fff}

/* -------- Tipografia -------- */
.h2{
  font-size:clamp(2rem, 3.5vw + 0.6rem, 4.25rem);
  line-height:1.06;
  letter-spacing:-0.025em;
  font-weight:600;
  text-wrap:balance;
  max-width:22ch;
  margin-bottom:clamp(24px,3vw,40px);
}
.h2 em{color:var(--accent);font-style:normal;font-weight:600}
.h2 .dim{color:var(--text-mute);font-weight:500}
.sec-dark .h2 .dim{color:#8E8E93}

.h1-like{
  font-size:clamp(3rem, 6vw + 0.6rem, 6rem);
  line-height:1.02;
  letter-spacing:-0.03em;
  font-weight:700;
  text-wrap:balance;
  margin-bottom:clamp(22px,3vw,32px);
}
.h1-like em{color:var(--accent);font-style:normal}

.eyebrow.center,.h2.center,.lead{display:block;text-align:center;margin-left:auto;margin-right:auto}
.lead{
  max-width:56ch;
  font-size:clamp(1.05rem,0.4vw + 0.95rem,1.35rem);
  line-height:1.5;
  color:var(--text-soft);
  font-weight:400;
  margin-bottom:clamp(48px,6vw,80px);
}
.sec-dark .lead{color:var(--text-on-dark-soft)}

.note{
  margin-top:clamp(40px,5vw,64px);
  max-width:64ch;
  margin-left:auto;margin-right:auto;
  text-align:center;
  font-size:15px;color:var(--text-soft);
  font-style:italic;
}

.center-text{text-align:center}
.center-actions{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:clamp(36px,5vw,56px)}
.trust{font-size:14px;color:var(--text-mute);letter-spacing:-0.005em}
.trust.on-dark{color:var(--text-on-dark-soft)}
.trust.on-dark b{color:var(--accent);font-variant-numeric:tabular-nums;font-weight:600}

/* -------- Pitch (seção dark) -------- */
#pitch .pitch-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(18px,2vw,28px);
  margin-top:clamp(40px,5vw,64px);
  max-width:64ch;
}
#pitch p{
  font-size:clamp(1.1rem,0.4vw + 1rem,1.35rem);
  color:var(--text-on-dark-soft);
  line-height:1.55;
  letter-spacing:-0.005em;
}
#pitch strong{color:#fff;font-weight:600}

/* -------- Trinca (3 cards) -------- */
.trinca{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:clamp(16px,2vw,24px);
  margin-bottom:clamp(32px,4vw,56px);
}
.tri-card{
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:var(--radius-l);
  padding:clamp(28px,3vw,40px);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
}
.tri-card:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 48px -20px rgba(0,0,0,0.12);
  border-color:rgba(217,119,87,0.35);
}
.tri-num{
  font-size:13px;font-weight:600;letter-spacing:0.08em;
  color:var(--accent);
  margin-bottom:clamp(40px,5vw,72px);
}
.tri-title{
  font-size:clamp(1.5rem,1vw + 1.2rem,2rem);
  font-weight:600;
  letter-spacing:-0.02em;
  line-height:1.15;
  margin-bottom:14px;
}
.tri-desc{
  font-size:16px;
  line-height:1.55;
  color:var(--text-soft);
}

/* -------- Stack de oferta -------- */
.stack{
  display:flex;flex-direction:column;gap:0;
  margin:clamp(32px,4vw,56px) auto 0;
  max-width:900px;
  border-top:1px solid var(--line);
}
.stack-row{
  display:grid;
  grid-template-columns:140px 1fr auto;
  gap:clamp(16px,3vw,32px);
  align-items:start;
  padding:clamp(24px,3vw,32px) 0;
  border-bottom:1px solid var(--line);
  transition:background .3s var(--ease);
}
.stack-row.is-bonus{
  background:linear-gradient(135deg,rgba(217,119,87,0.08) 0%,rgba(217,119,87,0.02) 100%);
  border:1px solid rgba(217,119,87,0.18);
  border-radius:var(--radius-m);
  padding:clamp(22px,2.8vw,28px) clamp(18px,2.2vw,24px);
  margin:10px calc(-1 * clamp(18px,2.2vw,24px));
}
.stack-row.is-bonus + .stack-row.is-bonus{margin-top:10px}
/* A última row (bônus 2) não deve ter a border-bottom do grid base */
.stack-row.is-bonus{border-bottom-color:transparent}
/* Tira o border-bottom do Módulo 04 (row anterior ao primeiro bônus) pra não criar linha dupla com o card */
.stack-row:has(+ .stack-row.is-bonus){border-bottom-color:transparent}
.stack-side{padding-top:4px}
.stack-kicker{
  font-size:12px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--text-mute);
}
.stack-kicker.accent{color:var(--accent)}
.stack-main h3{
  font-size:clamp(1.2rem,0.5vw + 1rem,1.5rem);
  font-weight:600;letter-spacing:-0.015em;
  line-height:1.25;
  margin-bottom:8px;
}
.stack-main h3 .meta{
  font-size:13px;font-weight:500;letter-spacing:0.02em;
  color:var(--text-mute);
  margin-left:10px;
  padding:3px 10px;border-radius:999px;
  background:var(--bg-soft);
  vertical-align:2px;
}
.stack-main p{
  font-size:15px;line-height:1.5;color:var(--text-soft);
  max-width:52ch;
}
.stack-price{
  font-size:14px;font-weight:500;color:var(--text-mute);
  font-variant-numeric:tabular-nums;
  text-align:right;
  padding-top:4px;
  white-space:nowrap;
}

@media (max-width:640px){
  .stack-row{
    grid-template-columns:1fr auto;
    gap:12px;
    padding:22px 0;
  }
  .stack-side{grid-column:1 / -1;padding-top:0;margin-bottom:-2px}
  .stack-main{grid-column:1}
  .stack-price{grid-column:2;grid-row:2;align-self:start}
  .stack-main h3 .meta{display:inline-block;margin-left:0;margin-top:6px}
}

/* -------- Ancoragem de preço -------- */
.anchor{
  max-width:520px;margin:clamp(40px,5vw,64px) auto 0;
  background:var(--bg-dark);color:var(--text-on-dark);
  border-radius:var(--radius-m);
  padding:clamp(20px,2vw,28px) clamp(24px,3vw,32px);
}
.anchor-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:10px 0;font-size:15px;color:var(--text-on-dark-soft);
  letter-spacing:-0.005em;
}
.anchor-row .old{text-decoration:line-through;color:rgba(245,245,247,0.5);font-variant-numeric:tabular-nums}
.anchor-row.strong{
  border-top:1px solid rgba(255,255,255,0.12);
  margin-top:6px;padding-top:16px;
  font-weight:500;color:#fff;font-size:16px;
}
.anchor-row.strong .new{
  color:var(--accent);font-size:clamp(1.4rem,1vw + 1rem,1.75rem);
  font-weight:700;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;
}

/* -------- Prova / depoimentos -------- */
.quotes{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:clamp(16px,2vw,24px);
  margin-top:clamp(40px,5vw,64px);
  max-width:1000px;margin-left:auto;margin-right:auto;
}
.quote{
  background:var(--bg);
  border-radius:var(--radius-l);
  padding:clamp(28px,3vw,36px);
  position:relative;
}
.quote::before{
  content:"\201C";
  position:absolute;
  top:clamp(12px,2vw,20px);left:clamp(18px,2vw,24px);
  font-size:72px;line-height:1;font-weight:400;
  color:var(--accent);opacity:0.3;
  font-family:"Georgia","Times New Roman",serif;
}
.quote blockquote{
  font-size:clamp(1rem,0.3vw + 0.95rem,1.125rem);
  line-height:1.55;color:var(--text);
  margin-bottom:16px;
  position:relative;z-index:1;
}
.quote figcaption{
  font-size:14px;color:var(--text-mute);
  font-weight:500;letter-spacing:-0.005em;
}

/* -------- Autor -------- */
.author-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(40px,6vw,72px);
  align-items:center;
}
@media (min-width:820px){
  .author-grid{grid-template-columns:minmax(0,440px) 1fr}
}
.author-visual{
  position:relative;
  aspect-ratio:4/5;
  width:100%;
  max-width:440px;margin:0 auto;
  border-radius:var(--radius-l);
  background:linear-gradient(160deg,#EDE4D4 0%,#D9C9B0 55%,#B89A74 100%);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.4) inset,
    0 30px 60px -20px rgba(0,0,0,0.5),
    0 10px 30px -10px rgba(217,119,87,0.35);
}
.author-visual::before{
  /* moldura interna */
  content:"";position:absolute;inset:0;
  border-radius:inherit;
  border:1px solid rgba(255,255,255,0.45);
  pointer-events:none;z-index:2;
}
.author-visual::after{
  /* glow coral externo */
  content:"";position:absolute;
  inset:-14% -12% -10% -14%;
  background:radial-gradient(ellipse at 70% 30%,rgba(217,119,87,0.45) 0%,rgba(217,119,87,0.15) 40%,transparent 70%);
  filter:blur(28px);
  z-index:-1;pointer-events:none;
}
.author-visual img{
  display:block;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 18%;
  border-radius:inherit;
  filter:saturate(1.02) contrast(1.02);
}
.author-tag{
  position:absolute;
  left:16px;bottom:16px;
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px 8px 12px;
  background:rgba(29,29,31,0.72);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  backdrop-filter:saturate(180%) blur(14px);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:999px;
  font-size:12px;font-weight:600;letter-spacing:0.05em;
  color:#fff;
  z-index:3;
}
.author-tag .live-dot{background:var(--accent)}
.author-body h2{margin-top:14px}
.author-body p{
  font-size:clamp(1rem,0.3vw + 0.95rem,1.15rem);
  line-height:1.6;
  color:var(--text-on-dark-soft);
  margin-bottom:16px;
  max-width:58ch;
}
.author-body p:last-child{margin-bottom:0}

/* -------- Garantia -------- */
.guarantee{text-align:center}
.guard{max-width:640px;margin:0 auto}
.guard .shield{color:var(--accent);margin:0 auto 24px;display:block}
.guard h2{margin-bottom:24px;max-width:none}
.guard h2 .dim{color:var(--text-mute)}
.guard p{
  font-size:clamp(1rem,0.3vw + 0.95rem,1.2rem);
  color:var(--text-soft);
  margin-bottom:12px;
  max-width:52ch;margin-left:auto;margin-right:auto;
}
.guard p.small{font-size:14px;color:var(--text-mute);margin-top:8px}

/* -------- FAQ -------- */
.qa{
  max-width:820px;margin:clamp(32px,4vw,56px) auto 0;
  border-top:1px solid var(--line);
}
.qa details{
  border-bottom:1px solid var(--line);
}
.qa summary{
  padding:clamp(20px,2.5vw,28px) 8px;
  font-size:clamp(1.05rem,0.3vw + 1rem,1.25rem);
  font-weight:500;letter-spacing:-0.01em;
  color:var(--text);
  cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  transition:color .3s var(--ease);
}
.qa summary::-webkit-details-marker{display:none}
.qa summary:hover{color:var(--accent)}
.qa .plus{
  flex:0 0 24px;width:24px;height:24px;
  position:relative;
  transition:transform .3s var(--ease);
}
.qa .plus::before,.qa .plus::after{
  content:"";position:absolute;background:currentColor;
  top:50%;left:50%;transform:translate(-50%,-50%);
}
.qa .plus::before{width:14px;height:2px}
.qa .plus::after{width:2px;height:14px;transition:transform .3s var(--ease)}
.qa details[open] .plus::after{transform:translate(-50%,-50%) scaleY(0)}
.qa .answer{
  padding:0 8px clamp(20px,2.5vw,28px);
}
.qa .answer p{
  font-size:16px;line-height:1.6;
  color:var(--text-soft);
  max-width:64ch;
}

/* -------- CTA final -------- */
.cta-final .sec-inner{max-width:720px}
.cta-final .big{
  font-size:clamp(1.1rem,0.4vw + 1rem,1.4rem);
  color:var(--text-on-dark-soft);
  line-height:1.5;
  max-width:56ch;margin:0 auto clamp(28px,3vw,40px);
}
.chip-dark{
  background:rgba(255,255,255,0.08);
  border-color:rgba(255,255,255,0.15);
  color:var(--text-on-dark-soft);
  margin:0 auto clamp(24px,3vw,32px);
  display:inline-flex;
}
.chip-dark .old{color:rgba(245,245,247,0.5)}
.chip-dark .new{color:#fff}

/* -------- Footer -------- */
footer{
  background:var(--bg-dark);
  color:var(--text-on-dark-soft);
  padding:clamp(40px,6vw,60px) 0 clamp(32px,4vw,40px);
  border-top:1px solid var(--line-on-dark);
}
.foot-inner{
  max-width:var(--max);margin:0 auto;
  padding:0 var(--gutter);
  text-align:center;
}
.foot-mark{
  font-size:15px;font-weight:600;letter-spacing:-0.01em;
  color:#fff;margin-bottom:16px;
}
.foot-mark em{color:var(--accent);font-style:normal;font-weight:700}
.foot-copy{font-size:13px;margin-bottom:10px}
.foot-legal{font-size:12px;color:var(--text-mute);max-width:48ch;margin:0 auto;line-height:1.5}

/* ============================================================
   Scroll reveal (ativado por IntersectionObserver em app.js)
   ============================================================ */
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .8s var(--ease),transform .8s var(--ease);
  will-change:opacity,transform;
}
.reveal.is-in{
  opacity:1;
  transform:none;
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none}
}

/* Stagger nas sequências que se beneficiam (em desktop) */
.trinca .tri-card.reveal:nth-child(1){transition-delay:0ms}
.trinca .tri-card.reveal:nth-child(2){transition-delay:80ms}
.trinca .tri-card.reveal:nth-child(3){transition-delay:160ms}

.stack .stack-row.reveal:nth-child(1){transition-delay:0ms}
.stack .stack-row.reveal:nth-child(2){transition-delay:60ms}
.stack .stack-row.reveal:nth-child(3){transition-delay:120ms}
.stack .stack-row.reveal:nth-child(4){transition-delay:180ms}
.stack .stack-row.reveal:nth-child(5){transition-delay:240ms}
.stack .stack-row.reveal:nth-child(6){transition-delay:300ms}

.quotes .quote.reveal:nth-child(1){transition-delay:0ms}
.quotes .quote.reveal:nth-child(2){transition-delay:80ms}
.quotes .quote.reveal:nth-child(3){transition-delay:160ms}
.quotes .quote.reveal:nth-child(4){transition-delay:240ms}
.quotes .quote.reveal:nth-child(5){transition-delay:320ms}
.quotes .quote.reveal:nth-child(6){transition-delay:400ms}

/* -------- Print (evita quebra) -------- */
@media print{
  .nav,.ticker,.btn,.cta-final{display:none}
  .sec{padding:40px 0}
}
