/* ═══════════════════════════════════════════════════
   Atomi — Hero Section (migrated from v4.8)
   ═══════════════════════════════════════════════════ */

.hero {
  width: 100%;
  min-height: 100vh;
  min-height: 100svh;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: var(--ivory);
}

.hero-bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 52% 82% at 76% 38%, oklch(0.9 0.075 42 / 0.34), transparent 67%),
    radial-gradient(ellipse 52% 70% at 74% 78%, oklch(0.74 0.14 294 / 0.18), transparent 70%),
    radial-gradient(ellipse 34% 38% at 46% 36%, oklch(0.96 0.05 312 / 0.15), transparent 68%),
    linear-gradient(105deg, var(--ivory-clean) 0 35%, oklch(0.988 0.012 82 / 0.9) 50%, var(--ivory-warm) 100%);
}
.hero-bg::before {
  content: ""; position: absolute; inset: 0; opacity: 0.035;
  background:
    linear-gradient(to right, oklch(0.35 0.03 286 / 0.024) 1px, transparent 1px),
    linear-gradient(to bottom, oklch(0.35 0.03 286 / 0.018) 1px, transparent 1px);
  background-size: 74px 74px;
  mask-image: radial-gradient(ellipse at 56% 44%, black 0 38%, transparent 84%);
}
.hero::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(circle at 69% 28%, oklch(0.96 0.1 72 / 0.1), transparent 12%),
    radial-gradient(ellipse 30% 52% at 71% 56%, oklch(0.84 0.16 33 / 0.05), transparent 64%),
    linear-gradient(90deg, oklch(0.992 0.01 82 / 0.9) 0 29%, oklch(0.992 0.01 82 / 0.62) 38%, oklch(0.992 0.01 82 / 0.18) 49%, transparent 62%),
    radial-gradient(ellipse 42% 88% at 100% 92%, oklch(0.66 0.12 294 / 0.055), transparent 70%);
}

.hero-inner {
  position: relative; z-index: 5;
  --hero-top-pad: clamp(64px, 7vh, 82px);
  --visual-lift: clamp(-78px, -7vh, -62px);
  width: min(1760px, 100%);
  min-height: 100vh; min-height: 100svh;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(430px, 42%) minmax(680px, 58%);
  align-items: start;
  column-gap: clamp(0px, 1.2vw, 24px);
  padding:
    var(--hero-top-pad)
    clamp(42px, 4.8vw, 82px)
    clamp(30px, 5vh, 54px)
    clamp(118px, 8.9vw, 154px);
}

/* ── Hero Copy ─────────────────────────────────────── */
.hero-content {
  position: relative; z-index: 5; isolation: isolate;
  width: min(650px, 100%);
  align-self: center;
  transform: translateY(18px);
  opacity: 0;
  animation: copy-in 0.9s var(--ease) 0.08s forwards;
}
.hero-content::before {
  content: ""; position: absolute;
  left: -88px; top: -54px; z-index: -1;
  width: 530px; height: 780px; pointer-events: none;
  background:
    linear-gradient(90deg, oklch(0.992 0.01 82 / 0.98) 0 66%, oklch(0.992 0.01 82 / 0.52) 82%, transparent 100%),
    radial-gradient(ellipse at 30% 52%, oklch(0.992 0.01 82 / 0.88), oklch(0.992 0.01 82 / 0.42) 58%, transparent 80%);
  filter: blur(13px);
}
@keyframes copy-in {
  from { opacity: 0; transform: translateY(44px); }
  to { opacity: 1; transform: translateY(18px); }
}

.hero-kicker {
  display: inline-flex; align-items: center; gap: 16px;
  margin-bottom: 10px; color: var(--violet);
}
.kicker-signal {
  width: 28px; height: 1px;
  background: linear-gradient(90deg, oklch(0.62 0.18 292 / 0.12), oklch(0.64 0.18 292 / 0.72));
  box-shadow: 20px 0 24px oklch(0.7 0.15 302 / 0.22);
}
.hero-kicker p {
  font-size: 0.78rem; font-weight: 650;
  text-transform: uppercase; letter-spacing: 0.26em;
}

.hero-title {
  position: relative; max-width: 690px;
  font-family: var(--font-display);
  font-size: clamp(5.5rem, 7.08vw, 8.32rem);
  line-height: 0.94; font-weight: 500; color: var(--ink);
  text-shadow: 0 20px 52px oklch(0.3 0.06 292 / 0.1);
}
.title-verified { display: inline-block; font-size: 0.965em; }
.title-verified-letters span {
  color: var(--letter-color);
  text-shadow:
    0 22px 44px oklch(0.68 0.16 305 / 0.12),
    0 0 1px oklch(0.84 0.11 30 / 0.22);
}
.title-verified-letters span:nth-child(1) { --letter-color: oklch(0.66 0.16 288); }
.title-verified-letters span:nth-child(2) { --letter-color: oklch(0.67 0.16 294); }
.title-verified-letters span:nth-child(3) { --letter-color: oklch(0.69 0.15 304); }
.title-verified-letters span:nth-child(4) { --letter-color: oklch(0.71 0.14 312); }
.title-verified-letters span:nth-child(5) { --letter-color: oklch(0.72 0.13 323); }
.title-verified-letters span:nth-child(6) { --letter-color: oklch(0.72 0.12 337); }
.title-verified-letters span:nth-child(7) { --letter-color: oklch(0.71 0.11 354); }
.title-verified-letters span:nth-child(8) { --letter-color: oklch(0.68 0.1 18); }

.title-spark {
  display: inline-block;
  width: clamp(18px, 1.55vw, 27px); height: clamp(18px, 1.55vw, 27px);
  margin: 0 -0.06em 0 0.04em; vertical-align: 0.66em;
  background: oklch(0.69 0.18 292 / 0.9);
  clip-path: polygon(50% 0, 61% 38%, 100% 50%, 61% 62%, 50% 100%, 39% 62%, 0 50%, 39% 38%);
  filter:
    drop-shadow(0 0 12px oklch(0.7 0.18 292 / 0.24))
    drop-shadow(0 0 22px oklch(0.86 0.12 72 / 0.18));
  transform: translate(0.14em, -0.03em) scale(0.94);
}
.title-dot { color: var(--coral); }

.hero-lead {
  margin-top: 22px;
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 1.8vw, 1.7rem);
  line-height: 1.12; font-weight: 600;
}
.hero-sub {
  max-width: 390px; margin-top: 8px;
  color: var(--ink-soft);
  font-size: clamp(0.98rem, 1.1vw, 1.1rem);
  line-height: 1.58;
}
.hero-cta {
  display: flex; gap: 14px; flex-wrap: wrap; margin-top: 32px;
}

/* ═══════════════════════════════════════════════════
   HERO VISUAL STAGE
   ═══════════════════════════════════════════════════ */
.hero-visual {
  position: relative; z-index: 3;
  width: 1120px; height: 900px; min-height: 900px;
  align-self: start; justify-self: end;
  margin-top: var(--visual-lift);
  margin-right: clamp(-58px, -3vw, -38px);
  --mx: 0; --my: 0;
  opacity: 0;
  animation: stage-in 1.1s var(--ease) 0.05s forwards;
  transform: scale(0.97);
  transform-origin: center right;
}
@keyframes stage-in {
  from { opacity: 0; }
  to { opacity: 1; }
}
.visual-layer, .visual-asset, .ui-float { position: absolute; }

.portal-glow {
  left: 11%; top: 4%; width: 70%; height: 84%; z-index: 0;
  border-radius: 50%;
  background:
    radial-gradient(circle at 56% 31%, oklch(0.86 0.13 34 / 0.26), transparent 30%),
    radial-gradient(circle at 50% 65%, oklch(0.7 0.15 300 / 0.14), transparent 48%);
  filter: blur(34px); opacity: 0.78;
  transform: translate(calc(var(--mx) * 0.04px), calc(var(--my) * 0.04px));
}

.portal-ring {
  left: 0; top: 0; width: 100%; height: 100%; z-index: 1;
  overflow: visible; pointer-events: none;
}
.portal-ring::before {
  content: ""; position: absolute;
  left: 22.4%; top: 5%; width: 52%; height: 70%; z-index: 2;
  border-radius: 50%;
  background:
    radial-gradient(circle at 52% 31%, oklch(0.99 0.01 84 / 0.18), transparent 22%),
    radial-gradient(circle at 58% 44%, oklch(0.85 0.14 36 / 0.1), transparent 35%),
    radial-gradient(circle at 44% 62%, oklch(0.68 0.16 302 / 0.05), transparent 54%);
  filter: blur(18px);
  mix-blend-mode: screen;
  animation: portal-pulse 6.8s ease-in-out infinite;
}
.portal-ring::after {
  content: ""; position: absolute;
  inset: -2% -2% -3% -6%; z-index: 3; pointer-events: none;
  background:
    linear-gradient(180deg, transparent 0 72%, oklch(0.992 0.01 82 / 0.28) 91%, oklch(0.992 0.01 82 / 0.52) 100%),
    linear-gradient(90deg, oklch(0.992 0.01 82 / 0.72) 0 8%, oklch(0.992 0.01 82 / 0.24) 19%, transparent 33% 86%, oklch(0.992 0.01 82 / 0.2) 100%),
    radial-gradient(ellipse 42% 34% at 82% 79%, oklch(0.992 0.01 82 / 0.16), transparent 70%);
}
@keyframes portal-pulse {
  0%, 100% { opacity: 0.72; transform: scale(1); }
  50% { opacity: 0.98; transform: scale(1.035); }
}
.portal-artwork {
  position: absolute; left: -31%; top: -5.8%;
  width: 134%; height: auto; max-width: none; opacity: 1;
  filter: saturate(1.08) contrast(1.045) brightness(1.025);
  mask-image:
    linear-gradient(90deg, transparent 0%, black 25%, black 100%),
    radial-gradient(ellipse 72% 82% at 64% 50%, black 0 80%, transparent 100%),
    linear-gradient(180deg, black 0 86%, transparent 100%);
  -webkit-mask-image:
    linear-gradient(90deg, transparent 0%, black 25%, black 100%),
    radial-gradient(ellipse 72% 82% at 64% 50%, black 0 80%, transparent 100%),
    linear-gradient(180deg, black 0 86%, transparent 100%);
  transform: translate(calc(var(--mx) * 0.07px), calc(var(--my) * 0.05px)) scale(1.01);
}

.atom-watermark {
  left: 4%; top: -8%; width: 78%; height: 78%; z-index: 2;
  color: oklch(0.68 0.14 292 / 0);
  transform: translate(calc(var(--mx) * 0.04px), calc(var(--my) * 0.03px)) rotate(-16deg);
}
.visual-main-glow {
  left: 23.8%; top: 16.5%; width: 36%; height: 60%; z-index: 3;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 28%, oklch(0.96 0.09 42 / 0.22), transparent 38%),
    radial-gradient(circle at 50% 55%, oklch(0.75 0.16 304 / 0.06), transparent 58%);
  filter: blur(34px);
  animation: core-breathe 5.8s ease-in-out infinite;
  transform: translate(calc(var(--mx) * 0.12px), calc(var(--my) * 0.1px));
}
@keyframes core-breathe {
  0%, 100% { opacity: 0.58; transform: scale(1); }
  50% { opacity: 0.82; transform: scale(1.045); }
}
.visual-shadow {
  left: 24.4%; top: 89%; width: 37%; height: 9%; z-index: 3;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at center, oklch(0.76 0.12 73 / 0.24), transparent 72%),
    radial-gradient(ellipse at center, oklch(0.62 0.09 304 / 0.1), transparent 64%);
  filter: blur(10px);
  transform: translate(calc(var(--mx) * 0.04px), calc(var(--my) * 0.03px));
}

.orbit-lines {
  inset: 0; pointer-events: none;
  mask-image: linear-gradient(90deg, transparent 0 27%, black 39%, black 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0 27%, black 39%, black 100%);
  transform: translate(calc(var(--mx) * 0.08px), calc(var(--my) * 0.06px));
}
.orbit-lines path {
  stroke-linecap: round; stroke-width: 1.35; stroke-dasharray: 720;
  animation: signal-draw 1.8s var(--ease) forwards;
}
.orbit-lines circle {
  fill: oklch(0.88 0.08 74 / 0.58); stroke: oklch(0.99 0.01 82 / 0.52);
  stroke-width: 2;
  filter: drop-shadow(0 0 10px oklch(0.77 0.12 67 / 0.38));
}
.orbit-lines--back { z-index: 2; display: none; }
.orbit-lines--back path { stroke: oklch(0.68 0.13 302 / 0.022); }
.orbit-lines--front { z-index: 4; }
.orbit-lines--front path {
  stroke: oklch(0.82 0.1 76 / 0.145); stroke-width: 0.76;
  filter:
    drop-shadow(0 0 4px oklch(0.99 0.01 82 / 0.2))
    drop-shadow(0 0 10px oklch(0.82 0.12 76 / 0.12));
}
.orbit-front-high { opacity: 0; }
.orbit-front-low { opacity: 0.38; }

.hand-focus-veil {
  left: 8.8%; top: 17.8%; width: 33.5%; height: 37%; z-index: 4;
  pointer-events: none;
  border-radius: 48% 52% 58% 42%;
  background:
    radial-gradient(ellipse 60% 38% at 48% 70%, oklch(0.992 0.01 82 / 0.9), oklch(0.992 0.01 82 / 0.5) 54%, transparent 78%),
    radial-gradient(ellipse 62% 56% at 56% 56%, oklch(0.992 0.01 82 / 0.76), oklch(0.992 0.01 82 / 0.34) 58%, transparent 82%),
    radial-gradient(ellipse 76% 70% at 40% 40%, oklch(0.992 0.01 82 / 0.48), transparent 76%);
  filter: blur(18px);
}
@keyframes signal-draw {
  from { stroke-dashoffset: 720; opacity: 0; }
  to { stroke-dashoffset: 0; opacity: 1; }
}

.visual-main {
  left: 14.6%; top: 9.4%; z-index: 5;
  height: 81.4%; width: auto; pointer-events: none;
  transform: translate(calc(var(--mx) * 0.18px), calc(var(--my) * 0.16px));
}
.visual-main-image {
  width: auto; height: 100%; max-width: none;
  filter:
    saturate(1.02) contrast(1.035) brightness(1.018)
    drop-shadow(0 20px 28px oklch(0.28 0.06 288 / 0.13))
    drop-shadow(0 0 32px oklch(0.96 0.08 72 / 0.34));
}
.visual-main::before {
  content: ""; position: absolute; pointer-events: none; border-radius: 50%;
  left: -11%; top: 7%; z-index: -1; width: 70%; height: 70%;
  background:
    radial-gradient(ellipse at 42% 26%, oklch(0.99 0.01 84 / 0.62), transparent 28%),
    radial-gradient(ellipse at 52% 52%, oklch(0.88 0.1 46 / 0.24), transparent 64%);
  filter: blur(18px);
}
.visual-main::after {
  content: ""; position: absolute; pointer-events: none;
  right: -6%; top: 11%; z-index: 2; width: 42%; height: 64%;
  background: linear-gradient(90deg, transparent, oklch(0.99 0.012 82 / 0.18));
  mix-blend-mode: screen; filter: blur(18px);
}

/* ═══════════════════════════════════════════════════
   HERO STEP CARDS
   ═══════════════════════════════════════════════════ */
.ui-float { z-index: 12; }
.step-card {
  min-height: 128px; padding: 20px 20px 18px 66px;
  border: 1px solid oklch(0.78 0.04 76 / 0.2);
  border-radius: 19px;
  background:
    radial-gradient(circle at 9% 10%, oklch(0.99 0.01 84 / 0.54), transparent 30%),
    linear-gradient(150deg, oklch(0.994 0.01 82 / 0.46), oklch(0.96 0.018 76 / 0.16)),
    oklch(0.99 0.012 82 / 0.28);
  backdrop-filter: blur(14px) saturate(1.06);
  -webkit-backdrop-filter: blur(14px) saturate(1.06);
  box-shadow:
    0 18px 46px oklch(0.32 0.05 288 / 0.06),
    inset 0 1px 0 oklch(0.99 0.01 82 / 0.48),
    inset 0 -18px 42px oklch(0.77 0.08 74 / 0.04);
  color: var(--ink); overflow: hidden;
  transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease), border-color 0.35s var(--ease);
}
.step-card::before {
  content: ""; position: absolute; inset: 1px; border-radius: inherit;
  background:
    linear-gradient(135deg, oklch(0.99 0.01 82 / 0.32), transparent 42%),
    linear-gradient(90deg, transparent 0 82%, oklch(0.86 0.1 72 / 0.1));
  pointer-events: none;
}
.step-card::after {
  content: ""; position: absolute;
  right: 13px; top: 21px; width: 8px; height: 8px; z-index: 1;
  border-radius: 50%;
  background: oklch(0.86 0.11 76 / 0.54);
  box-shadow: 0 0 15px oklch(0.82 0.13 72 / 0.3);
}
.step-card:hover {
  transform: translateY(-4px);
  border-color: oklch(0.82 0.12 74 / 0.48);
  box-shadow:
    0 30px 84px oklch(0.32 0.05 288 / 0.14),
    0 0 38px oklch(0.82 0.13 72 / 0.17),
    inset 0 1px 0 oklch(0.99 0.01 82 / 0.66);
}

.step-card--review {
  right: 3.4%; top: 20.6%; width: 158px;
  min-height: 112px; padding: 17px 16px 15px 55px;
}
.step-card--sandbox {
  right: 2.9%; top: 39.2%; width: 194px;
  min-height: 128px; padding: 18px 17px 16px 62px;
}
.step-card--release {
  right: 2.8%; top: 58.5%; width: 232px;
  min-height: 204px; padding-top: 50px; padding-left: 76px;
  background:
    radial-gradient(circle at 16% 18%, oklch(0.99 0.01 82 / 0.82), transparent 24%),
    radial-gradient(circle at 82% 78%, oklch(0.88 0.14 61 / 0.36), transparent 44%),
    linear-gradient(145deg, oklch(0.994 0.012 82 / 0.66), oklch(0.93 0.052 67 / 0.52));
  border-color: oklch(0.84 0.14 73 / 0.58);
  box-shadow:
    0 28px 70px oklch(0.76 0.13 48 / 0.2),
    0 0 0 1px oklch(0.86 0.13 74 / 0.34) inset,
    0 0 62px oklch(0.84 0.13 73 / 0.26);
}
.step-card--release::after {
  width: 11px; height: 11px;
  right: 24px; top: 62px;
  background: oklch(0.91 0.13 72 / 0.86);
}

.step-icon {
  position: absolute; left: 17px; top: 18px;
  width: 37px; height: 37px;
  display: grid; place-items: center;
  color: oklch(0.28 0.13 292); z-index: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 34% 24%, oklch(0.99 0.01 84), transparent 34%),
    linear-gradient(145deg, oklch(0.98 0.012 82 / 0.8), oklch(0.86 0.075 300 / 0.2));
  box-shadow:
    0 0 0 1px oklch(0.66 0.15 294 / 0.2),
    0 12px 28px oklch(0.5 0.12 294 / 0.15),
    inset 0 1px 0 oklch(0.99 0.01 84 / 0.66);
}
.step-icon::before {
  content: ""; position: absolute; inset: -7px; z-index: -1; border-radius: inherit;
  background: conic-gradient(from 20deg, oklch(0.72 0.17 294 / 0.12), oklch(0.86 0.13 72 / 0.28), transparent 64%, oklch(0.72 0.17 294 / 0.12));
  filter: blur(2px);
}
.step-icon svg {
  width: 25px; height: 25px;
  filter: drop-shadow(0 3px 8px oklch(0.32 0.11 292 / 0.16));
}
.step-icon--review { color: oklch(0.22 0.12 286); }
.step-icon--sandbox { color: oklch(0.34 0.15 286); }
.step-icon--release {
  left: 18px; top: 25px; width: 56px; height: 56px;
  color: oklch(0.76 0.13 53);
  background:
    radial-gradient(circle at 36% 25%, oklch(0.99 0.01 84), transparent 34%),
    linear-gradient(145deg, oklch(0.99 0.012 82 / 0.88), oklch(0.9 0.11 72 / 0.42));
  box-shadow:
    0 0 0 9px oklch(0.82 0.12 70 / 0.15),
    0 0 44px oklch(0.82 0.15 62 / 0.52),
    inset 0 1px 0 oklch(0.99 0.01 84 / 0.76);
}
.step-icon--release svg {
  width: 35px; height: 35px;
  filter:
    drop-shadow(0 4px 8px oklch(0.68 0.14 48 / 0.18))
    drop-shadow(0 0 18px oklch(0.82 0.14 62 / 0.36));
}

.step-num {
  position: relative; z-index: 1; display: block;
  margin-bottom: 10px;
  color: oklch(0.66 0.13 294 / 0.76);
  font-size: 0.82rem; font-weight: 650;
}
.step-card h3 {
  position: relative; z-index: 1;
  font-family: var(--font-display);
  font-size: 1.02rem; line-height: 1.1; font-weight: 650;
  text-shadow: 0 14px 28px oklch(0.25 0.06 288 / 0.08);
}
.step-card p {
  position: relative; z-index: 1; margin-top: 9px;
  color: oklch(0.45 0.035 282 / 0.82);
  font-size: 0.68rem; line-height: 1.5;
}
.step-card--release h3 { font-size: 1.52rem; }
.step-card--release p { font-size: 0.9rem; }

/* ── Mimi Pill ─────────────────────────────────────── */
.mimi-pill {
  left: 22.4%; top: 90.05%; z-index: 13;
  width: 286px; min-height: 66px;
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: center; gap: 14px;
  padding: 12px 19px;
  border: 1px solid oklch(0.69 0.035 76 / 0.3);
  border-radius: 20px;
  background:
    radial-gradient(circle at 9% 36%, oklch(0.95 0.08 305 / 0.2), transparent 28%),
    oklch(0.99 0.012 82 / 0.68);
  backdrop-filter: blur(18px) saturate(1.12);
  -webkit-backdrop-filter: blur(18px) saturate(1.12);
  box-shadow:
    0 26px 68px oklch(0.3 0.055 288 / 0.13),
    inset 0 1px 0 oklch(0.99 0.01 84 / 0.58);
}
.caption-spark {
  width: 13px; height: 13px;
  background: oklch(0.98 0.012 82);
  clip-path: polygon(50% 0, 61% 38%, 100% 50%, 61% 62%, 50% 100%, 39% 62%, 0 50%, 39% 38%);
  box-shadow: 0 0 18px oklch(0.73 0.17 305 / 0.38);
}
.mimi-caption-name {
  font-family: var(--font-display);
  color: var(--violet); font-size: 1.18rem; font-weight: 600;
}
.mimi-pill span:last-child {
  color: var(--muted); font-size: 0.82rem; line-height: 1.34;
}

/* ── Side Badge ────────────────────────────────────── */
.hero-side-badge {
  position: fixed; left: 18px; top: 47%;
  transform: translateY(-50%); z-index: 30;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  padding: 25px 11px;
  border: 1px solid oklch(0.72 0.035 78 / 0.3);
  border-radius: var(--radius-full);
  color: var(--violet);
  background: oklch(0.99 0.012 82 / 0.54);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 20px 54px oklch(0.26 0.04 288 / 0.06);
}
.side-badge-atom svg { width: 34px; height: 34px; }
.side-badge-text {
  writing-mode: vertical-rl; transform: rotate(180deg);
  font-family: var(--font-display); font-size: 1.08rem;
  color: var(--violet-deep);
}

/* ── Scroll Cue ────────────────────────────────────── */
.scroll-cue {
  position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%);
  z-index: 10; display: flex; flex-direction: column; align-items: center; gap: 8px;
  animation: cue-fade 2s ease-in-out infinite;
}
.scroll-cue span {
  width: 1px; height: 40px;
  background: linear-gradient(to bottom, var(--violet-soft), transparent);
}
@keyframes cue-fade {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 1; }
}
/* hero styles — extracted live from refine.css */

.atomi-wordmark {
  display: none;
}

.atomi-wordmark::before {
  display: none;
}

.aw-outline {
  -webkit-text-stroke-color: oklch(0.66 0.08 295 / 0.08);
}

.aw-fill {
  filter: saturate(0.82);
}

/* Navigation should frame the hero, not compete with it. */
.top-nav {
  padding-top: 18px;
  padding-bottom: 12px;
}

body[data-theme="hero"] .top-nav:not(.scrolled),
body:not([data-theme]) .top-nav:not(.scrolled) {
  padding-top: clamp(38px, 4.6vh, 48px);
}

body[data-theme="hero"] .top-nav:not(.scrolled) .nav-inner,
body:not([data-theme]) .top-nav:not(.scrolled) .nav-inner {
  justify-content: flex-start;
}

.hero-content {
  margin-top: clamp(-36px, -3.4vh, -24px);
}

.hero-title {
  font-family: "Bodoni 72", "Bodoni 72 Display", Didot, var(--font-display);
  letter-spacing: 0;
  max-width: 760px;
  font-size: clamp(5.55rem, 7vw, 8.55rem);
}

.hero-lead {
  font-family: "Bodoni 72", "Bodoni 72 Display", Didot, var(--font-display);
}

.hero-sub {
  max-width: 430px;
}

.hero-kicker {
  margin-left: 2px;
  gap: 0;
}

.hero-kicker .kicker-signal {
  display: none;
}

.hero-kicker p {
  color: oklch(0.53 0.15 292);
}

.hero-cta .btn-ghost {
  background: oklch(0.994 0.01 82 / 0.82);
}

.hero-mobile-action-row {
  display: none;
}

.hero-mobile-action {
  min-width: 0;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  border: 1px solid oklch(0.75 0.055 74 / 0.34);
  border-radius: 12px;
  background: oklch(0.994 0.01 82 / 0.78);
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 650;
  text-decoration: none;
  box-shadow: inset 0 1px 0 oklch(0.99 0.01 84 / 0.58);
}

.hero-mobile-action:focus-visible {
  outline: 2px solid oklch(0.66 0.17 294 / 0.72);
  outline-offset: 3px;
}

.hero-visual {
  width: 1130px;
  height: 900px;
  min-height: 900px;
  margin-top: clamp(-82px, -7vh, -58px);
  margin-right: clamp(-46px, -2.6vw, -22px);
}

.portal-glow {
  left: 6%;
  top: 1%;
  width: 88%;
  height: 92%;
  opacity: 0.5;
  filter: blur(28px);
}

.fused-hero-artwork {
  position: absolute;
  inset: 0;
  z-index: 9;
  display: none;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
  object-position: center;
  mask-image: linear-gradient(90deg, transparent 0%, black 6.5%, black 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 6.5%, black 100%);
  pointer-events: none;
}

.hero-visual--fused .fused-hero-artwork {
  display: block;
}

.hero-visual--fused .portal-glow,
.hero-visual--fused .portal-ring,
.hero-visual--fused .atom-watermark,
.hero-visual--fused .visual-main-glow,
.hero-visual--fused .visual-shadow,
.hero-visual--fused .orbit-lines,
.hero-visual--fused .visual-main,
.hero-visual--fused .hero-hand-atom,
.hero-visual--fused .hand-focus-veil,
.hero-visual--fused .mimi-pill {
  display: none;
}

.hero-action-card {
  text-decoration: none;
  cursor: pointer;
  pointer-events: auto;
}

.hero-action-card:focus-visible {
  outline: 2px solid oklch(0.66 0.17 294 / 0.72);
  outline-offset: 4px;
}

.portal-ring::before,
.portal-ring::after {
  display: none;
}

.portal-artwork {
  left: -18%;
  top: -2%;
  width: 141%;
  max-width: none;
  opacity: 0.96;
  filter: saturate(1.03) contrast(1.015) brightness(1.02);
  mask-image:
    linear-gradient(90deg, transparent 0%, black 18%, black 100%),
    linear-gradient(180deg, black 0 90%, transparent 100%);
  -webkit-mask-image:
    linear-gradient(90deg, transparent 0%, black 18%, black 100%),
    linear-gradient(180deg, black 0 90%, transparent 100%);
}

.visual-main-glow {
  left: 33%;
  top: 9%;
  width: 31%;
  height: 66%;
  opacity: 0.38;
  filter: blur(22px);
}

.visual-main {
  left: 14.6%;
  top: 9.2%;
  height: 81.5%;
  z-index: 6;
}

.visual-main-image {
  filter:
    saturate(1.025) contrast(1.02) brightness(1.018)
    drop-shadow(0 18px 24px oklch(0.54 0.045 70 / 0.11))
    drop-shadow(0 0 22px oklch(0.97 0.07 76 / 0.32));
}

.visual-main::before,
.visual-main::after,
.hand-focus-veil {
  display: none;
}

.hero-hand-atom {
  left: 22.5%;
  top: 28%;
  width: 142px;
  height: 142px;
  z-index: 7;
  overflow: visible;
  filter:
    drop-shadow(0 10px 22px oklch(0.74 0.13 55 / 0.18))
    drop-shadow(0 0 16px oklch(0.76 0.18 292 / 0.22));
  transform: rotate(-4deg);
}

.hero-hand-atom-aura {
  fill: oklch(0.96 0.08 76 / 0.2);
  filter: blur(10px);
}

.hero-hand-atom-glow {
  fill: none;
  stroke: oklch(0.99 0.01 82 / 0.48);
  stroke-width: 5.5;
  filter: blur(3px);
}

.hero-hand-atom-orbit {
  fill: none;
  stroke-width: 1.9;
  stroke-linecap: round;
}

.hero-hand-atom-orbit-a {
  stroke: url("#hero-hand-orbit-a");
}

.hero-hand-atom-orbit-b {
  stroke: url("#hero-hand-orbit-b");
}

.hero-hand-atom-shell {
  fill: oklch(0.99 0.01 82 / 0.52);
  stroke: oklch(0.95 0.11 72 / 0.92);
  stroke-width: 1.3;
}

.hero-hand-atom-core {
  fill: url("#hero-hand-core");
  filter: drop-shadow(0 0 13px oklch(0.84 0.15 62 / 0.8));
}

.hero-hand-atom-node {
  fill: oklch(0.97 0.1 74);
  stroke: oklch(0.99 0.01 82 / 0.8);
  stroke-width: 1.1;
}

.hero-hand-atom-node-small {
  fill: oklch(0.75 0.16 292);
}

.orbit-lines {
  mask-image: none;
  -webkit-mask-image: none;
}

.orbit-lines--front path {
  stroke: oklch(0.78 0.12 72 / 0.18);
}

.step-card--review {
  right: 2.1%;
  top: 21.4%;
}

.step-card--sandbox {
  right: 2.4%;
  top: 39.2%;
}

.step-card--release {
  right: 2.3%;
  top: 58.7%;
}

.mimi-pill {
  left: 37%;
  top: 90.4%;
}

.step-card {
  border-radius: 14px;
  background:
    radial-gradient(circle at 10% 12%, oklch(0.99 0.01 84 / 0.48), transparent 30%),
    linear-gradient(150deg, oklch(0.994 0.01 82 / 0.52), oklch(0.966 0.018 76 / 0.18)),
    oklch(0.99 0.012 82 / 0.34);
  backdrop-filter: blur(18px) saturate(1.04);
  -webkit-backdrop-filter: blur(18px) saturate(1.04);
  box-shadow:
    0 16px 42px oklch(0.32 0.05 288 / 0.055),
    inset 0 1px 0 oklch(0.99 0.01 82 / 0.54),
    inset 0 -14px 34px oklch(0.77 0.08 74 / 0.035);
}

.step-card::before {
  background:
    linear-gradient(135deg, oklch(0.99 0.01 82 / 0.36), transparent 44%),
    linear-gradient(90deg, transparent 0 82%, oklch(0.86 0.1 72 / 0.07));
}

.step-card::after {
  width: 7px;
  height: 7px;
  background: oklch(0.86 0.11 76 / 0.44);
}

.step-card h3 {
  font-size: 0.98rem;
}

.step-card p {
  color: oklch(0.43 0.035 282 / 0.78);
  font-size: 0.64rem;
}

.step-card--release {
  background:
    radial-gradient(circle at 16% 18%, oklch(0.99 0.01 82 / 0.76), transparent 25%),
    radial-gradient(circle at 83% 80%, oklch(0.88 0.14 61 / 0.28), transparent 46%),
    linear-gradient(145deg, oklch(0.994 0.012 82 / 0.58), oklch(0.93 0.052 67 / 0.42));
  border-color: oklch(0.84 0.14 73 / 0.5);
  box-shadow:
    0 26px 66px oklch(0.76 0.13 48 / 0.16),
    0 0 0 1px oklch(0.86 0.13 74 / 0.28) inset,
    0 0 52px oklch(0.84 0.13 73 / 0.2);
}

.step-card--release h3 {
  font-size: 1.44rem;
}

.step-card--release p {
  font-size: 0.88rem;
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    radial-gradient(circle at 3.6% 33.4%, oklch(0.99 0.01 82 / 0.86) 0 3px, transparent 4px),
    radial-gradient(circle at 94.4% 19.1%, oklch(0.83 0.09 70 / 0.24) 0 5px, transparent 6px),
    radial-gradient(circle at 41% 73%, oklch(0.85 0.11 69 / 0.22) 0 7px, transparent 8px);
}

.scroll-cue {
  display: none;
}

/* Metrics: proof, not decorative hero stats. */
.metrics-strip {
  position: relative;
  overflow: hidden;
  padding-top: clamp(72px, 10vh, 108px);
  padding-bottom: clamp(72px, 10vh, 108px);
  background:
    radial-gradient(ellipse 44% 52% at 10% 26%, oklch(0.73 0.16 294 / 0.08), transparent 70%),
    radial-gradient(ellipse 42% 46% at 91% 70%, oklch(0.84 0.12 72 / 0.14), transparent 68%),
    oklch(0.988 0.01 82);
}

/* Restrained finance pass: keep the approved hero intact, make lower
   sections read as escrow, review, and settlement infrastructure. */
:root {
  --finance-ink: oklch(0.205 0.026 282);
  --finance-copy: oklch(0.31 0.026 282);
  --finance-muted: oklch(0.48 0.018 282);
  --finance-line: oklch(0.7 0.025 82 / 0.22);
  --finance-panel: oklch(0.992 0.007 82 / 0.92);
  --finance-panel-strong: oklch(0.997 0.005 82 / 0.96);
  --finance-green: oklch(0.42 0.07 158);
  --finance-green-soft: oklch(0.91 0.035 154 / 0.5);
  --finance-gold: oklch(0.56 0.075 65);
}

main > section:not(.hero) {
  color: var(--finance-ink);
}

:where(.btn, .fp-cta, .v-cta, .product-row-see-all, .fp-see-all, .pop-tab, .product-link, .pr-card, .hero-action-card, .hero-mobile-action):focus-visible {
  outline: 2px solid var(--violet);
  outline-offset: 3px;
}
