/* HERO */
#hero{min-height:100vh;padding:68px 5vw 0;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.hero-left{padding:0 0 60px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--g100);border:1px solid var(--g200);border-radius:100px;padding:6px 14px;font-size:12px;font-weight:500;letter-spacing:0.04em;color:var(--g500);margin-bottom:32px}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;flex-shrink:0}
h1{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:clamp(40px,5vw,64px);line-height:1.08;letter-spacing:-0.03em;color:var(--black);margin-bottom:24px}
h1 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--yellow)}
.hero-sub{font-size:16px;font-weight:300;line-height:1.75;color:var(--g500);max-width:420px;margin-bottom:36px}
.hero-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:48px}
.btn-ghost{display:inline-flex;align-items:center;gap:6px;color:var(--black);font-size:14px;font-weight:400;text-decoration:none;transition:color .2s}
.btn-ghost:hover{color:var(--g500)}
.hero-proof{display:flex;align-items:center;gap:20px;padding-top:28px;border-top:1px solid var(--g200)}
.proof-item{display:flex;flex-direction:column;gap:4px}
.proof-number{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:26px;color:var(--black);letter-spacing:-0.02em}
.proof-label{font-size:12px;color:var(--g500);line-height:1.4;font-weight:300}
.proof-divider{width:1px;height:40px;background:var(--g200);flex-shrink:0}
.hero-right{display:flex;align-items:center;justify-content:center;padding:68px 0 60px;position:relative}

/* HERO VISUAL — integrated into page */
.hero-visual{width:100%;max-width:560px;display:flex;flex-direction:column;gap:20px}

.hero-chart-card{padding:0}

.hc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.hc-title{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:15px;color:var(--black);letter-spacing:-0.01em}
.hc-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:500;color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:100px;padding:4px 12px}
.hc-badge-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;flex-shrink:0;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.55;transform:scale(0.8)}}

.hc-chart{margin-bottom:16px}
.hc-chart svg{width:100%;display:block;overflow:visible}

/* Line draws itself */
.hc-line{stroke-dasharray:700;stroke-dashoffset:700;animation:drawLine 2s ease-out forwards;animation-delay:0.5s}
@keyframes drawLine{to{stroke-dashoffset:0}}

/* Area fades in after line */
.hc-area{opacity:0;animation:fadeUp 0.6s ease-out forwards;animation-delay:2.2s}
@keyframes fadeUp{to{opacity:1}}

/* Dots pop in sequentially */
.hc-dot{opacity:0;transform-origin:center;animation:popIn 0.25s ease-out forwards}
.hc-dot-1{animation-delay:1.1s}
.hc-dot-2{animation-delay:1.5s}
.hc-dot-3{animation-delay:1.85s}
@keyframes popIn{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}

/* Peak dot + ring */
.hc-peak{opacity:0;animation:popIn 0.3s ease-out forwards;animation-delay:2s}
.hc-peak-ring{opacity:0;animation:ringPulse 1.5s ease-out infinite;animation-delay:2.3s}
@keyframes ringPulse{0%{opacity:0.6;transform:scale(1)}100%{opacity:0;transform:scale(2.2)}}

/* X axis labels */
.hc-x-labels{display:flex;justify-content:space-between;padding:0 2px}
.hc-x-labels span{font-size:11px;color:var(--g400);font-weight:300}

/* Pill tags */
.hc-tags{display:flex;gap:10px;flex-wrap:wrap}
.hc-tag{display:inline-flex;align-items:center;background:var(--g100);border:1px solid var(--g200);border-radius:100px;padding:10px 20px;font-size:14px;font-weight:500;color:var(--black)}
.hc-tag-yellow{background:var(--yellow);border-color:var(--yellow)}


/* TICKER */
.ticker-bar{background:var(--black);overflow:hidden;white-space:nowrap}
.ticker-inner{display:inline-flex;animation:ticker 26s linear infinite}
.ticker-item{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(22px,3vw,38px);font-weight:700;color:var(--white);padding:20px 36px;display:inline-flex;align-items:center;gap:28px}
.ticker-item .dot{color:var(--yellow);font-size:0.55em}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* SECTIONS */
section{padding:96px 5vw}
h2{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:clamp(34px,4vw,54px);line-height:1.08;letter-spacing:-0.02em;color:var(--black);margin-bottom:16px}
h2 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--yellow)}
h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:20px;color:var(--black);margin-bottom:8px}

/* PROCESS */
#process{background:var(--white)}
.process-intro{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:52px}
.process-desc{font-size:15px;font-weight:300;line-height:1.75;color:var(--g500);max-width:360px;margin-bottom:18px}
.process-link{font-size:13px;font-weight:500;color:var(--black);text-decoration:none;display:inline-flex;align-items:center;gap:6px;border-bottom:1px solid var(--g200);padding-bottom:1px;transition:border-color .2s}
.process-link:hover{border-color:var(--black)}
.process-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--g200);border:1px solid var(--g200);border-radius:14px;overflow:hidden}
.process-card{background:var(--white);padding:36px 32px;transition:background .2s}
.process-card:hover{background:var(--g50)}
.pc-num{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:12px;letter-spacing:0.12em;color:var(--yellow);margin-bottom:18px}
.pc-title{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:20px;color:var(--black);margin-bottom:10px}
.pc-body{font-size:14px;font-weight:300;color:var(--g500);line-height:1.65}

/* SERVICES */
#services{background:var(--g50);border-top:1px solid var(--g200);border-bottom:1px solid var(--g200)}
.services-head{margin-bottom:48px}
.services-list{border:1px solid var(--g200);border-radius:14px;overflow:hidden;background:var(--white)}
.service-row{display:grid;grid-template-columns:220px 1fr 200px;gap:0;padding:40px 36px;border-bottom:1px solid var(--g200);transition:background .2s}
.service-row:last-child{border-bottom:none}
.service-row:hover{background:var(--g50)}
.sr-num{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:12px;letter-spacing:0.12em;color:var(--yellow);margin-bottom:10px}
.sr-left h3{font-size:22px;margin-bottom:5px}
.sr-left em{font-family:'Instrument Serif',serif;font-style:italic;font-size:14px;color:var(--g500)}
.sr-mid{padding:0 36px;font-size:14px;font-weight:300;color:var(--g500);line-height:1.75;align-self:center}
.sr-right{align-self:center}
.sr-tags{display:flex;flex-direction:column;gap:7px}
.sr-tag{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--g500);font-weight:300}
.sr-tag::before{content:'';width:5px;height:5px;background:var(--yellow);border-radius:50%;flex-shrink:0}

/* CLOSING CTA */
#cta-band{background:var(--g100);border-top:1px solid var(--g200);text-align:center;padding:100px 5vw}
.cta-band-inner{max-width:700px;margin:0 auto}
#cta-band h2{font-size:clamp(36px,5vw,60px);margin-bottom:12px}
#cta-band p{font-size:16px;font-weight:300;color:var(--g500);line-height:1.7;margin-bottom:36px;max-width:480px;margin-left:auto;margin-right:auto}

@media(max-width:960px){
  #hero{grid-template-columns:1fr}
  .hero-right{display:none}
  .process-intro{grid-template-columns:1fr}
  .process-cards{grid-template-columns:1fr}
.service-row{grid-template-columns:1fr}
  .sr-mid{padding:12px 0 0}
  .sr-right{padding-top:12px}
}
