/* ===== Home · Leonardo Sommariva — estilos exclusivos das seções da home =====
   Componentes reutilizados por outras páginas (about, services, metodo,
   palestras, book, mídia, insights, page-hero, cards, cta-band) vivem em
   css/site.css. Aqui ficam apenas hero, impulse/growth-chart e final. */

/* ===== HERO ===== */
.hero{position:relative;overflow:hidden;padding:90px 0 120px;isolation:isolate}
@media(max-width:760px){.hero{padding:56px 0 72px}}
.hero-grid{display:grid;grid-template-columns:1.08fr 0.92fr;gap:60px;align-items:center}
.ticker{display:flex;flex-wrap:wrap;gap:10px 0;font-family:'Space Mono',monospace;font-size:12.5px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);margin-bottom:32px}
.ticker span{display:inline-flex;align-items:center}
.ticker span:not(:last-child)::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent);margin:0 16px;box-shadow:var(--glow);animation:pulse 4.8s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}

.lines .line{display:block;overflow:visible}
.lines .line>span{display:block}
h1.hero-title{font-size:clamp(42px,5.6vw,76px);margin-bottom:30px}
.hero-sub{font-size:clamp(16px,2.6vw,20px);color:var(--ink-soft);max-width:520px;margin-bottom:38px}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stat{background:var(--glass);border:1px solid var(--glass-line);border-radius:4px;padding:18px 18px;backdrop-filter:blur(6px);transition:transform .3s,border-color .3s}
.stat:hover{transform:translateY(-3px);border-color:var(--accent)}
.stat .n{font-family:'Space Grotesk';font-weight:700;font-size:28px;color:var(--ink);letter-spacing:-0.03em;line-height:1}
.stat .l{font-size:12px;color:var(--ink-faint);font-weight:500;margin-top:7px;line-height:1.3}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;gap:50px}.hero-media{order:-1;max-width:440px}}
@media(max-width:480px){.hero-stats{grid-template-columns:1fr 1fr}}

.hero-media{position:relative}
.hero-photo{position:relative;border-radius:4px;overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow);border:1px solid var(--line)}
.hero-photo img{width:100%;height:100%;object-fit:cover;filter:saturate(1.04) contrast(1.04);transform:translateY(var(--py,0)) scale(1.06);transition:transform .2s linear}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(8,17,14,0.6) 100%)}
.hero-tag{position:absolute;left:-20px;bottom:38px;z-index:3;background:var(--accent);color:var(--accent-ink);font-family:'Space Mono',monospace;font-weight:700;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;padding:13px 19px;box-shadow:var(--glow)}
.hero-frame{position:absolute;inset:-14px -14px auto auto;width:110px;height:110px;border-top:2px solid var(--accent);border-right:2px solid var(--accent);opacity:.75}

/* ===== IMPULSE ===== */
.impulse{position:relative;overflow:hidden}
.impulse h2{font-size:clamp(32px,3.8vw,50px);max-width:780px;margin-bottom:24px}
.impulse .lead{font-size:clamp(16px,2.4vw,19px);color:var(--ink-soft);max-width:640px}
.impulse strong{color:var(--ink);font-weight:600}
/* ===== GROWTH CHART (outcomes) ===== */
.growth-chart{--zone:260px;position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:74px}
.growth-chart::after{content:"";position:absolute;left:0;right:0;top:var(--zone);height:2px;background:var(--line-strong)}
.gc-item{min-width:0}
.gc-barzone{height:var(--zone);display:flex;align-items:flex-end}
.gc-bar{position:relative;width:100%;height:calc(var(--p) * 2.6px);min-height:54px;
  display:flex;justify-content:center;align-items:flex-start;padding-top:15px}
.gc-bar::before{content:"";position:absolute;inset:0;z-index:0;border-radius:8px 8px 0 0;transform-origin:bottom;
  background:linear-gradient(180deg,var(--accent) 0%,color-mix(in srgb,var(--accent) 18%,transparent) 100%);box-shadow:var(--glow)}
.gc-bar .gc-n{position:relative;z-index:1;font-family:'Space Grotesk';font-weight:700;font-size:23px;letter-spacing:-0.02em;color:var(--accent-ink)}
.gc-label{padding-top:24px}
.gc-label h3{font-size:19px;margin-bottom:8px}
.gc-label p{font-size:14px;color:var(--ink-soft);text-wrap:pretty}
/* mobile: vira uma timeline numerada (badge à esquerda + conteúdo à direita) */
@media(max-width:640px){
  .growth-chart{display:block;grid-template-columns:none;gap:0;margin-top:44px}
  .growth-chart::after{display:none}
  .gc-item{position:relative;display:grid;grid-template-columns:52px 1fr;gap:20px;align-items:start;padding-bottom:30px}
  .gc-item:last-child{padding-bottom:0}
  .gc-item:not(:last-child)::after{content:"";position:absolute;left:25px;top:62px;bottom:8px;width:2px;
    background:linear-gradient(180deg,var(--accent),color-mix(in srgb,var(--accent) 4%,transparent));opacity:.4}
  .gc-barzone{height:auto;display:block}
  .gc-bar{position:relative;width:52px;height:52px;min-width:0;border-radius:14px;align-items:center;justify-content:center;padding:0}
  .gc-bar::before{inset:0;border-radius:14px;transform-origin:center}
  .gc-bar .gc-n{font-size:20px}
  .gc-label{padding-top:5px}
  .gc-label h3{font-size:18px;margin-bottom:7px}
  .gc-label p{font-size:14px;max-width:none}
}

/* ===== FINAL ===== */
.final{position:relative;text-align:center;overflow:hidden;isolation:isolate}
.final .hero-bg{z-index:-2}
.final h2{font-size:clamp(36px,5.2vw,68px);max-width:900px;margin:0 auto 24px}
.final h2 em{font-style:normal;color:var(--accent)}
.final p{font-size:clamp(16px,2.6vw,20px);color:var(--ink-soft);max-width:560px;margin:0 auto 42px}

@media(prefers-reduced-motion:reduce){
  .lines .line>span{transform:none!important}
  .ticker span:not(:last-child)::after{animation:none!important}
  .hero-photo img{transform:none!important}
}
