/* ============================================================
   FlowData Website UI Kit — component styles
   Recreated from flowdata-reports/static/intake.css
   Tokens come from ../../colors_and_type.css
   ============================================================ */

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg); color: var(--fg1); font-family: var(--font-body); -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; }

.shell { width: min(var(--shell), calc(100% - 2rem)); margin: 0 auto; }

/* ---------------- COSMIC HERO (canvas particle field + glowing ribbons) ---------------- */
.cosmic {
  position: relative; overflow: hidden; isolation: isolate; color: #fff;
  background:
    radial-gradient(75% 60% at 50% 96%, rgba(20,90,170,0.40) 0%, rgba(6,22,46,0.5) 36%, transparent 68%),
    radial-gradient(140% 100% at 50% 104%, rgba(10,50,110,0.30), transparent 60%),
    linear-gradient(180deg, #010209 0%, #02060f 50%, #01030a 100%);
}
.cosmic__canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; z-index: 0; }
.cosmic__ribbons { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; mix-blend-mode: screen; pointer-events: none; }
.cosmic__ribbons .crib { animation: ribDrift 20s ease-in-out infinite; }
.cosmic__ribbons .crib2 { animation-duration: 26s; animation-delay: -6s; }
.cosmic__ribbons .crib3 { animation-duration: 23s; animation-delay: -3s; }
.cosmic__ribbons .crib4 { animation-duration: 29s; animation-delay: -9s; }
.cosmic__ribbons .ccomet { animation: cometBreath 6s ease-in-out infinite; }
.cosmic__veil { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(58% 46% at 50% 40%, rgba(2,6,15,0.5), transparent 70%),
    linear-gradient(180deg, rgba(2,5,12,0.4) 0%, transparent 26%, transparent 64%, rgba(2,5,12,0.22) 100%); }
.cosmic > .shell { position: relative; z-index: 2; }

@keyframes ribDrift { 0%,100%{ transform: translate3d(0,0,0); } 50%{ transform: translate3d(-1.2%,0.6%,0); } }
@keyframes cometBreath { 0%,100%{ opacity: 0.35; } 50%{ opacity: 0.9; } }
@media (prefers-reduced-motion: reduce) { .cosmic__ribbons .crib, .cosmic__ribbons .ccomet { animation: none; } }

/* ---------------- HEADER ---------------- */
.site-header { position: sticky; top: 0; z-index: 30; padding: 1rem 0; backdrop-filter: blur(10px); }
.header-shell {
  width: min(var(--shell), calc(100% - 2rem)); margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
  padding: 0.78rem 1.1rem; background: rgba(255,255,255,0.78);
  border: 1px solid rgba(13,17,23,0.08); border-radius: var(--radius-lg); box-shadow: var(--shadow-nav);
}
.brand-lockup { display: inline-flex; align-items: center; gap: 0.7rem; }
.brand-mark { width: 2.2rem; height: 2.2rem; object-fit: contain; }
.brand-wordmark { font-family: var(--font-display); font-weight: 800; font-size: 1rem; line-height: 1; color: var(--fg1); }
.site-nav { display: flex; align-items: center; gap: 1rem; }
.site-nav-links { display: flex; align-items: center; gap: 1rem; }
.site-nav-links a {
  font-family: var(--font-display); font-weight: 700; font-size: 0.95rem; color: var(--fg2);
  background: none; border: none; padding: 0; transition: color 0.15s var(--ease);
}
.site-nav-links a:hover, .site-nav-links a.is-active { color: var(--fg1); }
.site-nav-account { display: flex; align-items: center; gap: 0.55rem; }

/* header on dark pages */
.theme-dark .header-shell { background: rgba(5,10,16,0.82); border-color: rgba(120,224,255,0.1); box-shadow: none; }
.theme-dark .brand-wordmark, .theme-dark .site-nav-links a { color: rgba(255,255,255,0.86); }
.theme-dark .site-nav-links a:hover, .theme-dark .site-nav-links a.is-active { color: #fff; }

/* ---------------- BUTTONS ---------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; min-height: 3rem;
  padding: 0.9rem 1.25rem; border-radius: var(--radius-card); border: 1px solid transparent;
  font-family: var(--font-display); font-weight: 800; font-size: 0.95rem;
  transition: transform 0.2s var(--ease), box-shadow 0.2s var(--ease), border-color 0.2s var(--ease);
}
.btn:hover { transform: translateY(-1px); }
.btn--primary { background: var(--color-ink); color: #fff; box-shadow: var(--shadow-btn); }
.btn--secondary { background: transparent; color: var(--color-ink); border-color: var(--line-strong); }
.btn--nav { min-height: 2.7rem; padding: 0.55rem 0.95rem; font-size: 0.9rem; }
.btn--nav.btn--quiet { box-shadow: none; }
/* inverted on dark */
.on-dark .btn--primary, .btn--on-dark-primary { background: #fff; color: var(--color-ink); box-shadow: 0 14px 32px rgba(0,0,0,0.2); }
.on-dark .btn--secondary, .btn--on-dark-secondary { color: #fff; border-color: rgba(255,255,255,0.18); background: rgba(255,255,255,0.04); }
.theme-dark .site-nav-account .btn--secondary { color: rgba(255,255,255,0.86); border-color: rgba(255,255,255,0.2); background: rgba(255,255,255,0.03); }
.theme-dark .site-nav-account .btn--secondary:hover { color:#fff; border-color: rgba(255,255,255,0.35); }

.text-link { display: inline-flex; align-items: center; gap: 0.35rem; font-family: var(--font-display); font-weight: 700; color: var(--accent-2); }
.text-link::after { content: "\2197"; }
.text-link--on-dark { color: var(--color-atlas-cyan); }

/* ---------------- EYEBROW / LABELS ---------------- */
.eyebrow {
  display: inline-flex; align-items: center; margin: 0 0 1rem; padding: 0.45rem 0.82rem;
  border: 1px solid rgba(13,17,23,0.12); border-radius: 999px; background: rgba(255,255,255,0.9);
  font-family: var(--font-display); font-size: 0.78rem; font-weight: 800; letter-spacing: -0.01em; color: var(--accent-2);
}
.eyebrow--on-dark { border-color: rgba(255,255,255,0.14); background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.86); }

/* ---------------- SECTIONS ---------------- */
.section { padding: clamp(4rem, 8vw, 7rem) 0; background: #fff; }
.section--light { background: var(--bg); }
.section--dark { background: var(--color-charcoal); color: #fff; }
.section-heading { max-width: 760px; margin-bottom: 2.5rem; }
.section-heading--center { margin-inline: auto; text-align: center; }
.section-heading h2 { line-height: 1; }
.section-heading p { color: var(--fg2); font-size: 1rem; line-height: 1.7; margin: 1rem 0 0; }
.section--dark .section-heading p { color: var(--fg-on-dark); }

/* ---------------- GRIDS ---------------- */
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1.25rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 1.25rem; }

/* ---------------- PANELS / CARDS ---------------- */
.panel { border: 1px solid rgba(13,17,23,0.1); border-radius: var(--radius-card); background: #fff;
  box-shadow: var(--shadow-card); padding: 1.7rem; }
.panel--accent { border-left: 3px solid var(--accent); }
.panel h3 { margin: 0 0 0.6rem; }
.panel p { color: var(--fg2); margin: 0; font-size: 0.95rem; line-height: 1.6; }
.panel-dark { padding: 1.65rem; border: 1px solid rgba(0,234,255,0.18); border-radius: var(--radius-card); background: rgba(255,255,255,0.045); }
.panel-dark h3 { margin: 0 0 0.5rem; }
.panel-dark p { color: var(--fg-on-dark); margin: 0; font-size: 0.95rem; line-height: 1.6; }

.feature-points { list-style: none; margin: 0.3rem 0 0; padding: 0; display: grid; gap: 0.5rem; }
.feature-points li { position: relative; padding-left: 1.2rem; color: var(--fg2); font-size: 0.95rem; }
.feature-points li::before { content: ""; position: absolute; left: 0; top: 0.6em; width: 6px; height: 6px; border-radius: 2px; background: var(--accent-2); }
.section--dark .feature-points li { color: var(--fg-on-dark); }

/* ---------------- CHART CARD ---------------- */
.chart-card { border: 1px solid rgba(13,17,23,0.1); border-radius: var(--radius-card); background: #fff; box-shadow: var(--shadow-card); overflow: hidden; }
.chart-card img { width: 100%; aspect-ratio: 16/10; object-fit: cover; background: #fff; border-bottom: 1px solid rgba(13,17,23,0.08); }
.chart-card__body { padding: 1.25rem; }
.chart-card__body h3 { font-size: 1.05rem; margin: 0.5rem 0; }
.chart-caption { margin: 0.6rem 0 0; font-weight: 700; font-size: 0.9rem; color: var(--fg1); }
.source-label { margin: 0.7rem 0 0; font-family: var(--font-mono); font-size: 0.76rem; font-weight: 700; color: var(--color-blue-link); }

/* ---------------- PROOF / ATLAS HERO ---------------- */
.proof-hero { position: relative; overflow: hidden; isolation: isolate; color: #fff;
  background:
    radial-gradient(circle at 18% 12%, rgba(57,245,255,0.22), transparent 28rem),
    radial-gradient(circle at 76% 8%, rgba(4,119,255,0.22), transparent 26rem),
    radial-gradient(ellipse 70% 40% at 50% 100%, rgba(4,80,180,0.38), transparent 56%),
    linear-gradient(135deg, var(--color-atlas-void) 0%, #040F1C 46%, #071222 100%);
}
.atlas-hero { padding: clamp(2.6rem, 4.5vw, 3.8rem) 0 clamp(2rem, 3.4vw, 3rem); }
.proof-hero--page { padding: clamp(3.6rem, 6vw, 4.8rem) 0; }
.atlas-field { position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.055) 0 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,0.045) 0 1px, transparent 1px);
  background-size: 72px 72px; opacity: 0.72; }
.atlas-field::before { content: ""; position: absolute; inset: -12% -8%;
  background:
    radial-gradient(circle at 18% 28%, rgba(57,245,255,0.18), transparent 18rem),
    radial-gradient(circle at 78% 18%, rgba(4,119,255,0.16), transparent 22rem),
    radial-gradient(circle at 50% 88%, rgba(57,245,255,0.08), transparent 28rem);
  filter: blur(8px); }
.atlas-orbit { position: absolute; right: -12vw; bottom: -14rem; width: min(76rem, 88vw); height: 26rem;
  border: 1px solid rgba(57,245,255,0.36); border-radius: 100% 0 0 0; transform: rotate(-18deg);
  transform-origin: right bottom; box-shadow: 0 0 34px rgba(57,245,255,0.16); }
.atlas-orbit--2 { right: -18vw; bottom: -18rem; width: min(92rem, 100vw); opacity: 0.72; transform: rotate(-10deg); }
.atlas-orbit--3 { right: 8vw; bottom: -20rem; width: min(60rem, 82vw); border-color: rgba(4,119,255,0.34); opacity: 0.56; transform: rotate(-26deg); }

.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0,0.88fr) minmax(340px,1.12fr); gap: clamp(2rem,4.6vw,4rem); align-items: center; }
.hero-grid--proof { grid-template-columns: minmax(0,0.92fr) minmax(280px,0.72fr); }
.hero-copy h1 { max-width: 13ch; font-size: clamp(2.6rem, 4.25vw, 4.4rem); line-height: 0.98; letter-spacing: -0.02em; }
.hero-subhead { max-width: 37rem; margin: 1rem 0 0; color: rgba(248,249,250,0.82); font-size: clamp(0.98rem,1.1vw,1.06rem); line-height: 1.6; }
.hero-kicker { max-width: 37rem; margin: 0.7rem 0 0; color: rgba(255,255,255,0.94); font-family: var(--font-display); font-weight: 800; font-size: clamp(1.05rem,1.4vw,1.2rem); line-height: 1.3; }
.hero-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 0.9rem; margin-top: 1.6rem; }

/* centered cinematic hero (home) */
.cosmic-hero { min-height: min(86vh, 760px); display: flex; align-items: center; padding: 7rem 0 5.5rem; }
.hero-center { width: min(60rem, 92%); margin: 0 auto; display: flex; flex-direction: column; align-items: center; text-align: center; }
.hero-center .eyebrow { margin-bottom: 1.5rem; }
.hero-center h1 { max-width: 17ch; font-size: clamp(2.8rem, 6vw, 5.4rem); line-height: 0.96; letter-spacing: -0.03em; }
.hero-center .lede { margin: 1.3rem 0 0; max-width: 36ch; font-family: var(--font-display); font-weight: 500;
  font-size: clamp(1.1rem, 1.7vw, 1.5rem); line-height: 1.3; color: rgba(214,232,255,0.82); }
.hero-tagstrip { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.7rem 1.6rem; margin-top: 2.6rem;
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(150,200,255,0.66); }
.hero-tagstrip span { display: inline-flex; align-items: center; gap: 0.55rem; }
.hero-tagstrip span::before { content: ""; width: 5px; height: 5px; border-radius: 999px; background: rgba(110,190,255,0.85); box-shadow: 0 0 8px rgba(80,170,255,0.8); }

.proof-strip { display: flex; flex-wrap: wrap; gap: 0.55rem; margin-top: 1rem; }
.proof-strip span { display: inline-flex; align-items: center; min-height: 2rem; padding: 0.42rem 0.68rem;
  border: 1px solid rgba(57,245,255,0.28); border-radius: 999px; background: rgba(57,245,255,0.07);
  color: rgba(248,249,250,0.9); font-family: var(--font-mono); font-size: 0.72rem; font-weight: 800; line-height: 1.1; }

/* report frame (glass) */
.report-frame { margin: 0; padding: 0.85rem; border: 1px solid rgba(0,234,255,0.26); border-radius: 12px;
  background: rgba(255,255,255,0.05); box-shadow: var(--shadow-dark); }
.report-frame--light { border-color: rgba(13,17,23,0.1); background: #fff; box-shadow: var(--shadow-card); }
.report-frame--light figcaption span { color: var(--fg2); }
.report-frame--light figcaption strong { color: var(--accent-2); }
.report-frame img { width: 100%; border-radius: 8px; object-fit: cover; }
.report-frame figcaption { display: grid; gap: 0.3rem; padding: 0.7rem 0.3rem 0.1rem; }
.report-frame figcaption span { font-size: 0.85rem; color: rgba(255,255,255,0.8); }
.report-frame figcaption strong { font-family: var(--font-mono); font-size: 0.72rem; font-weight: 700; color: var(--accent); }

/* ---------------- TIERS ---------------- */
.tier-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1.25rem; align-items: stretch; }
.tier-card { display: flex; flex-direction: column; justify-content: space-between; gap: 1.4rem; padding: 1.75rem;
  border: 1px solid var(--line); border-radius: var(--radius-card); background: #fff; box-shadow: var(--shadow-card); }
.tier-card--featured { border-color: var(--accent); box-shadow: var(--shadow-raised); }
.popular-badge { display: inline-flex; width: fit-content; margin-bottom: 0.9rem; padding: 0.25rem 0.6rem;
  border: 1px solid var(--accent); border-radius: 999px; color: var(--accent-2); font-family: var(--font-display);
  font-size: 0.72rem; font-weight: 900; letter-spacing: 0.12em; }
.tier-price { margin: 0.9rem 0 0; color: var(--color-ink); font-family: var(--font-display); font-size: 2.4rem; font-weight: 900; line-height: 1; }
.tier-subtitle { margin: 0.7rem 0 0; font-weight: 800; }
.tier-input { margin: 1rem 0 0; font-size: 0.92rem; color: var(--fg2); }
.tier-footer { display: grid; gap: 1rem; margin-top: auto; }
.tier-footer p { margin: 0; font-size: 0.92rem; color: var(--fg2); }

.compact-tier-row { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1.25rem; }
.compact-tier-card { padding: 1rem; border: 1px solid rgba(13,17,23,0.1); border-radius: var(--radius-card); background: #fff; }
.compact-tier-card span { display:block; color: var(--color-blue-link); font-family: var(--font-display); font-size: 0.76rem; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; }
.compact-tier-card strong { display:block; font-family: var(--font-display); font-size: 1.6rem; font-weight: 900; margin: 0.2rem 0; }
.compact-tier-card p { margin: 0; color: var(--fg2); font-size: 0.9rem; }

/* ---------------- PROOF GRID (chart + copy) ---------------- */
.proof-grid { display: grid; grid-template-columns: minmax(0,1.08fr) minmax(300px,0.92fr); gap: clamp(2rem,4vw,4rem); align-items: center; }
.proof-chart { margin: 0; padding: 0.9rem; border: 1px solid rgba(13,17,23,0.1); border-radius: 10px; background: #fff; box-shadow: var(--shadow-card); }
.proof-chart img { width: 100%; border-radius: 6px; }
.proof-chart figcaption { display: grid; gap: 0.4rem; padding: 0.8rem 0.3rem 0.1rem; }
.proof-chart figcaption span { font-weight: 700; font-size: 0.92rem; color: var(--fg1); }
.proof-chart figcaption strong { font-family: var(--font-mono); font-size: 0.74rem; font-weight: 700; color: var(--accent-2); }
.section--dark .proof-chart figcaption span { color: #fff; }

/* ---------------- SAMPLE PAGES ---------------- */
.sample-strip { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1.25rem; align-items: start; }
.sample-card { overflow: hidden; border: 1px solid rgba(13,17,23,0.1); border-radius: var(--radius-card); background: #fff; box-shadow: var(--shadow-card); }
.sample-card img { width: 100%; aspect-ratio: 1075/1390; object-fit: cover; background: #fff; }
.sample-card figcaption { padding: 0.95rem 1rem 1.1rem; font-size: 0.9rem; line-height: 1.5; color: var(--fg2); }

/* consent steps */
.consent-flow { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 1.25rem; }
.step { padding: 1.4rem 0; border-top: 1px solid rgba(0,136,204,0.3); }
.step span { display: block; margin-bottom: 0.6rem; color: rgba(0,136,204,0.42); font-family: var(--font-display); font-size: clamp(3rem,6vw,4.6rem); font-weight: 900; line-height: 0.9; }
.step h3 { font-size: 1.1rem; margin: 0 0 0.4rem; }
.step p { margin: 0; color: var(--fg2); font-size: 0.92rem; }

/* secondary offer + final cta */
.secondary-offer { display: grid; gap: 1.4rem; padding: clamp(1.4rem,3vw,2rem); border: 1px solid rgba(13,17,23,0.1); border-radius: var(--radius-card); background: #fff; }
.band-inner { display: grid; gap: 1.4rem; max-width: 760px; }
.final-actions { display: flex; flex-wrap: wrap; gap: 0.9rem; }

/* waitlist */
.waitlist-panel { display: grid; gap: 1.4rem; }
.waitlist-form { display: flex; gap: 0.7rem; flex-wrap: wrap; max-width: 30rem; }
.waitlist-form .field { flex: 1; min-width: 14rem; display: grid; gap: 0.3rem; }
.waitlist-form input { padding: 0.85rem 1rem; border-radius: var(--radius-card); border: 1px solid rgba(255,255,255,0.18); background: rgba(255,255,255,0.06); color: #fff; }
.waitlist-form input::placeholder { color: rgba(255,255,255,0.5); }
.waitlist-success { font-family: var(--font-mono); font-size: 0.85rem; color: var(--accent); }

/* ---------------- FOOTER ---------------- */
.site-footer { padding: 0 0 2rem; background: #fff; }
.section--dark + .site-footer, .footer--on-dark { background: var(--color-charcoal); color: #fff; }
.footer-shell { width: min(var(--shell), calc(100% - 2rem)); margin: 0 auto; display: flex; align-items: end; justify-content: space-between; gap: 2rem; padding: 2.2rem 0 1.4rem; border-top: 1px solid var(--line); }
.footer--on-dark .footer-shell { border-top-color: rgba(255,255,255,0.12); }
.footer-brand { max-width: 24rem; }
.footer-brand p { color: var(--fg2); font-size: 0.92rem; }
.footer--on-dark .footer-brand p { color: var(--fg-on-dark); }
.footer-tagline { font-family: var(--font-display); font-weight: 800; color: var(--accent-2) !important; letter-spacing: -0.01em; }
.footer-links { display: flex; flex-wrap: wrap; gap: 1rem 1.3rem; }
.footer-links a { color: var(--fg2); font-size: 0.95rem; }
.footer--on-dark .footer-links a { color: var(--fg-on-dark); }
.footer-meta { width: min(var(--shell), calc(100% - 2rem)); margin: 0 auto; display: flex; justify-content: space-between; gap: 1rem; font-size: 0.92rem; color: var(--fg3); }

/* reveal — resting state is ALWAYS visible (no dependence on a transition/
   animation completing, so static captures, print, paused-timeline, no-JS and
   reduced-motion all render content). Entrance motion is a one-shot transform
   animation that does NOT hide content at its start frame. */
.reveal { opacity: 1; }
.reveal.is-visible { animation: reveal-up 0.55s var(--ease) both; }
@keyframes reveal-up { from { transform: translateY(16px); } to { transform: none; } }
.reveal-1.is-visible { animation-delay: 0.07s; }
.reveal-2.is-visible { animation-delay: 0.14s; }
@media (prefers-reduced-motion: reduce) { .reveal.is-visible { animation: none; } }

/* ============================================================
   HOME HERO — brand manifesto, atlas motif + cosmic atmosphere
   ============================================================ */

.home-hero {
  position: relative; overflow: hidden; isolation: isolate; color: #fff;
  min-height: min(90vh, 880px);
  display: flex; align-items: center; padding: 8rem 0 6rem;
  background:
    radial-gradient(ellipse 112% 58% at 50% 100%, rgba(4,105,235,0.76) 0%, rgba(3,14,50,0.66) 34%, transparent 63%),
    radial-gradient(ellipse 46% 35% at 14% 30%, rgba(57,245,255,0.13) 0%, transparent 48%),
    radial-gradient(ellipse 54% 36% at 87% 16%, rgba(4,80,210,0.17) 0%, transparent 50%),
    linear-gradient(180deg, #020D1C 0%, #030F22 58%, #020910 100%);
}

/* Top-edge fade — blends hero into floating nav bar */
.home-hero::after {
  content: ""; position: absolute; inset: 0 0 auto 0;
  height: 110px; z-index: 3; pointer-events: none;
  background: linear-gradient(180deg, rgba(2,13,28,0.78) 0%, transparent 100%);
}

/* Atlas grid overlay */
.home-hero::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.038) 0 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,0.030) 0 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(ellipse 100% 90% at 50% 60%, rgba(0,0,0,0.6) 0%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 100% 90% at 50% 60%, rgba(0,0,0,0.6) 0%, transparent 80%);
}

/* Atlas orbit arc container */
.home-hero__atlas { position: absolute; inset: 0; z-index: 2; pointer-events: none; }

/* Orbit arcs */
.home-orbit {
  position: absolute; right: -10vw; bottom: -16rem;
  width: min(80rem, 92vw); height: 28rem;
  border: 1px solid rgba(57,245,255,0.28); border-radius: 100% 0 0 0;
  transform: rotate(-18deg); transform-origin: right bottom;
  box-shadow: 0 0 30px rgba(57,245,255,0.14), inset 0 0 20px rgba(57,245,255,0.04);
}
.home-orbit--2 {
  right: -18vw; bottom: -20rem;
  width: min(98rem, 108vw); height: 33rem;
  border-color: rgba(57,245,255,0.16); opacity: 0.7;
  transform: rotate(-10deg);
  box-shadow: 0 0 18px rgba(57,245,255,0.07);
}
.home-orbit--3 {
  right: 6vw; bottom: -23rem;
  width: min(60rem, 82vw); height: 24rem;
  border-color: rgba(4,119,255,0.25); opacity: 0.50;
  transform: rotate(-28deg);
  box-shadow: 0 0 20px rgba(4,119,255,0.09);
}

/* CosmicBg z-index overrides inside home-hero */
.home-hero .cosmic__canvas { z-index: 1; }
.home-hero .cosmic__ribbons { z-index: 1; }
.home-hero .cosmic__veil { z-index: 3; }

/* Content shell */
.home-hero__center {
  position: relative; z-index: 4;
  display: flex; flex-direction: column; align-items: center; text-align: center;
}

/* Mono eyebrow label */
.home-hero__label {
  display: inline-flex; align-items: center; gap: 0.58rem;
  margin: 0 0 1.8rem; padding: 0.38rem 0.88rem;
  border: 1px solid rgba(57,245,255,0.20); border-radius: var(--radius-pill);
  background: rgba(57,245,255,0.065);
  font-family: var(--font-mono); font-size: 0.69rem; font-weight: 700;
  letter-spacing: 0.15em; color: rgba(186,234,255,0.74);
}
.home-hero__label::before {
  content: ""; width: 5px; height: 5px; border-radius: 999px; flex-shrink: 0;
  background: var(--color-atlas-cyan);
  box-shadow: 0 0 6px rgba(57,245,255,1);
}

/* Brand manifesto headline */
.home-hero__manifesto {
  margin: 0; display: flex; flex-direction: column; align-items: center;
  font-family: var(--font-display); font-weight: 900; text-wrap: balance;
}
.home-hero__line1 {
  display: block;
  font-size: clamp(2.6rem, 5.0vw, 5.0rem);
  font-weight: 800; line-height: 1.0; letter-spacing: -0.036em;
  color: rgba(222,241,255,0.90); margin-bottom: 0.06em;
}
.home-hero__champions {
  display: block;
  font-size: clamp(4rem, 8.4vw, 8rem);
  font-weight: 900; line-height: 0.88; letter-spacing: -0.056em;
  color: var(--color-atlas-cyan);
  text-shadow:
    0 0 34px rgba(57,245,255,0.72),
    0 0 80px rgba(57,245,255,0.34),
    0 0 160px rgba(57,245,255,0.15);
}

/* Descriptor */
.home-hero__desc {
  margin: 1.55rem 0 0; max-width: 42ch;
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(1rem, 1.38vw, 1.2rem); line-height: 1.5;
  color: rgba(190,228,255,0.68);
}

.home-hero__actions { margin-top: 2.4rem; justify-content: center; }

/* responsive */
@media (max-width: 900px) {
  .home-hero { padding: 6rem 0 4rem; min-height: min(88vh, 720px); }
  .hero-grid, .hero-grid--proof, .proof-grid { grid-template-columns: 1fr; }
  .grid-3, .grid-4, .tier-grid, .sample-strip, .compact-tier-row, .consent-flow { grid-template-columns: 1fr; }
  .footer-shell { flex-direction: column; align-items: flex-start; }
  .site-nav-links { display: none; }
}
