/* ============================================================
   Verify Me — landing page styles
   Built on Planet Solara tokens. Motif: authenticity = light.
   You are a body in the dark; every truth you CHOOSE to verify
   and reveal is a ring of light. The more you show, the brighter
   you glow, the easier your people find you. You hold the dial.
   ============================================================ */

:root {
  --vm-max: 1200px;
  --vm-gutter: clamp(20px, 5vw, 64px);
}

html { scroll-behavior: smooth; }
body { background: var(--bg-void); overflow-x: hidden; }

/* faint star/HUD wash behind everything */
.vm-stage {
  position: relative;
  min-height: 100vh;
  isolation: isolate;
}
.vm-stage::before {
  content: "";
  position: fixed; inset: 0; z-index: -2;
  background:
    radial-gradient(140% 90% at 80% -10%, color-mix(in oklab, var(--solar-500) 13%, transparent) 0%, transparent 46%),
    radial-gradient(120% 80% at -10% 110%, color-mix(in oklab, var(--ember-600) 12%, transparent) 0%, transparent 50%),
    var(--bg-void);
}
.vm-stage::after { /* drifting starfield */
  content: "";
  position: fixed; inset: -200px; z-index: -1; opacity: .5;
  background-image:
    radial-gradient(1.5px 1.5px at 20% 30%, color-mix(in oklab,var(--white) 60%,transparent), transparent),
    radial-gradient(1.5px 1.5px at 70% 60%, color-mix(in oklab,var(--white) 45%,transparent), transparent),
    radial-gradient(1px 1px at 40% 80%, color-mix(in oklab,var(--white) 50%,transparent), transparent),
    radial-gradient(1px 1px at 85% 20%, color-mix(in oklab,var(--white) 40%,transparent), transparent),
    radial-gradient(1.5px 1.5px at 55% 12%, color-mix(in oklab,var(--amber-400) 55%,transparent), transparent),
    radial-gradient(1px 1px at 12% 65%, color-mix(in oklab,var(--white) 35%,transparent), transparent),
    radial-gradient(1px 1px at 92% 78%, color-mix(in oklab,var(--white) 40%,transparent), transparent);
  background-size: 540px 540px, 420px 420px, 360px 360px, 480px 480px, 600px 600px, 300px 300px, 450px 450px;
  animation: vm-drift 140s linear infinite;
}
@keyframes vm-drift { to { transform: translate3d(-120px, -80px, 0); } }
@media (prefers-reduced-motion: reduce){ .vm-stage::after{ animation:none; } }

.vm-wrap { max-width: var(--vm-max); margin: 0 auto; padding-inline: var(--vm-gutter); }

/* ---------------- Topbar ---------------- */
.vm-top {
  position: sticky; top: 0; z-index: 40;
  display: flex; align-items: center; justify-content: space-between;
  height: 68px;
  background: color-mix(in oklab, var(--space-void) 62%, transparent);
  backdrop-filter: var(--blur-md); -webkit-backdrop-filter: var(--blur-md);
  border-bottom: 1px solid var(--border-subtle);
}
.vm-brand { display: flex; align-items: center; gap: 12px; }
.vm-mark { width: 26px; height: 26px; position: relative; flex: none; }
.vm-mark .core {
  position: absolute; inset: 7px; border-radius: 50%;
  background: radial-gradient(circle at 38% 34%, var(--plasma), var(--solar-500) 58%, var(--ember-600) 100%);
  box-shadow: var(--glow-solar-md);
}
.vm-mark .ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 1.5px solid color-mix(in oklab, var(--amber-400) 70%, transparent);
  transform: rotate(-18deg) scaleY(.42);
}
.vm-wordmark {
  font-family: var(--font-display); font-size: 14px;
  letter-spacing: var(--tracking-widest); color: var(--text-strong);
}
.vm-nav { display: flex; align-items: center; gap: 4px; }
.vm-nav a {
  padding: 8px 14px; border-radius: var(--radius-md);
  font-size: var(--text-sm); color: var(--text-muted);
  transition: var(--transition-color);
}
.vm-nav a:hover { color: var(--text-strong); background: var(--surface-raised); }
@media (max-width: 820px){ .vm-nav .vm-nav-links { display: none; } }

/* ---------------- Hero ---------------- */
.vm-hero { padding-top: clamp(48px, 8vw, 96px); padding-bottom: clamp(56px, 9vw, 110px); }
.vm-hero-grid {
  display: grid; grid-template-columns: 1.05fr 1fr;
  gap: clamp(32px, 6vw, 80px); align-items: center;
}
@media (max-width: 940px){ .vm-hero-grid { grid-template-columns: 1fr; gap: 56px; } }

.vm-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-display); font-size: 11px;
  letter-spacing: var(--tracking-wider); text-transform: uppercase;
  color: var(--amber-400);
}
.vm-eyebrow::before { content:""; width: 22px; height:1px; background: currentColor; opacity:.6; }

.vm-h1 {
  font-family: var(--font-sans); font-weight: 600;
  font-size: clamp(2.6rem, 6vw, 4.6rem); line-height: 1.04;
  letter-spacing: -0.025em; margin-top: 20px; color: var(--text-strong);
}
.vm-h1 .glow {
  background: linear-gradient(180deg, var(--plasma), var(--solar-400) 70%, var(--solar-600));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: 0 0 38px color-mix(in oklab, var(--solar-500) 45%, transparent);
}
.vm-sub {
  margin-top: 22px; max-width: 46ch;
  font-size: var(--text-md); line-height: var(--leading-relaxed); color: var(--text-muted);
}
.vm-cta-row { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.vm-trust-line {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px 18px; margin-top: 30px;
  font-family: var(--font-mono); font-size: var(--text-2xs);
  letter-spacing: .08em; text-transform: uppercase; color: var(--text-faint);
}
.vm-trust-line .dot { width:5px; height:5px; border-radius:50%; background: var(--aurora-500); box-shadow: var(--glow-aurora); }

/* ---------------- The orb instrument ---------------- */
.vm-orb-stage {
  position: relative; aspect-ratio: 1; width: 100%; max-width: 520px; margin-inline: auto;
  display: grid; place-items: center;
}
.vm-orbit {
  position: absolute; border-radius: 50%;
  border: 1px solid var(--border-subtle);
}
.vm-orbit.spin { animation: solara-orbit 60s linear infinite; }
.vm-orbit.spin.rev { animation-direction: reverse; animation-duration: 90s; }
@media (prefers-reduced-motion: reduce){ .vm-orbit.spin{ animation:none; } }

.vm-orb {
  position: relative; width: 42%; aspect-ratio: 1; border-radius: 50%;
  background:
    radial-gradient(circle at 38% 32%,
      var(--plasma) 0%,
      var(--solar-400) 38%,
      var(--solar-600) 66%,
      var(--ember-700) 100%);
  --orb-glow: 26px;
  box-shadow:
    0 0 var(--orb-glow) color-mix(in oklab, var(--solar-500) 75%, transparent),
    0 0 calc(var(--orb-glow) * 2.4) color-mix(in oklab, var(--solar-500) 40%, transparent),
    inset -6px -8px 22px color-mix(in oklab, var(--ember-700) 80%, transparent),
    inset 8px 6px 18px color-mix(in oklab, var(--plasma) 30%, transparent);
  transition: box-shadow var(--dur-slow) var(--ease-out), filter var(--dur-slow) var(--ease-out);
}
.vm-orb::after { /* slow surface shimmer */
  content:""; position:absolute; inset:0; border-radius:50%;
  background: radial-gradient(circle at 70% 75%, color-mix(in oklab,var(--amber-400) 40%, transparent), transparent 55%);
  mix-blend-mode: screen; opacity:.7;
}

/* category nodes sit on the rim of the outer orbit */
.vm-node {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%) rotate(var(--a)) translateY(calc(var(--r) * -1)) rotate(calc(var(--a) * -1));
  display: flex; flex-direction: column; align-items: center; gap: 7px;
  width: 92px; text-align: center;
  opacity: .28; filter: grayscale(.6);
  transition: opacity var(--dur-slow) var(--ease-out), filter var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out);
}
.vm-node .pip {
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--surface-overlay); border: 1px solid var(--border-strong);
  transition: var(--transition-color);
}
.vm-node .lbl {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--text-muted); line-height: 1.2;
}
.vm-node.lit { opacity: 1; filter: none; }
.vm-node.lit .pip {
  background: radial-gradient(circle at 40% 35%, var(--plasma), var(--solar-500));
  border-color: var(--amber-400);
  box-shadow: var(--glow-solar-sm);
}
.vm-node.lit .lbl { color: var(--text-strong); }

/* spokes from orb to lit nodes */
.vm-spoke {
  position: absolute; top: 50%; left: 50%; height: 1px; transform-origin: left center;
  background: linear-gradient(90deg, color-mix(in oklab,var(--solar-500) 70%, transparent), transparent);
  opacity: 0; transition: opacity var(--dur-slow) var(--ease-out);
  pointer-events: none;
}
.vm-spoke.lit { opacity: .55; }

/* readout chip floating on the instrument */
.vm-readout {
  position: absolute; left: 50%; bottom: -6px; transform: translateX(-50%);
  display: flex; align-items: center; gap: 12px;
  padding: 8px 16px; border-radius: var(--radius-pill);
  background: var(--glass-bg); backdrop-filter: var(--blur-md); -webkit-backdrop-filter: var(--blur-md);
  border: 1px solid var(--glass-border); box-shadow: var(--shadow-lg);
  white-space: nowrap;
}
.vm-readout .pct {
  font-family: var(--font-mono); font-variant-numeric: tabular-nums;
  font-size: var(--text-md); color: var(--solar-300); font-weight: 600;
}
.vm-readout .state {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--text-muted);
  padding-left: 12px; border-left: 1px solid var(--border-strong);
}

/* the dial control under the copy */
.vm-dial { margin-top: 32px; max-width: 420px; }
.vm-dial__top {
  display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 10px;
}
.vm-dial__label {
  font-family: var(--font-mono); font-size: var(--text-2xs);
  letter-spacing: .14em; text-transform: uppercase; color: var(--text-faint);
}
.vm-dial__hint { font-size: var(--text-xs); color: var(--text-muted); }
.vm-range { width: 100%; -webkit-appearance: none; appearance: none; height: 6px;
  border-radius: var(--radius-pill); background: var(--surface-inset); outline: none; cursor: pointer; }
.vm-range::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none; width: 22px; height: 22px; border-radius: 50%;
  background: radial-gradient(circle at 38% 34%, var(--plasma), var(--solar-500));
  border: 2px solid var(--space-900); box-shadow: var(--glow-solar-md); cursor: grab;
}
.vm-range::-moz-range-thumb {
  width: 22px; height: 22px; border-radius: 50%; border: 2px solid var(--space-900);
  background: var(--solar-500); box-shadow: var(--glow-solar-md); cursor: grab;
}
.vm-range:active::-webkit-slider-thumb { cursor: grabbing; }
.vm-dial__scale {
  display: flex; justify-content: space-between; margin-top: 8px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em;
  text-transform: uppercase; color: var(--text-faint);
}

/* ---------------- Section scaffold ---------------- */
.vm-section { padding-block: clamp(64px, 11vw, 132px); position: relative; }
.vm-section--edge { border-top: 1px solid var(--border-subtle); }
.vm-shead { max-width: 660px; }
.vm-shead.center { margin-inline: auto; text-align: center; }
.vm-h2 {
  font-size: clamp(2rem, 4.2vw, 3.1rem); line-height: 1.08; letter-spacing: -0.025em;
  color: var(--text-strong); margin-top: 16px; font-weight: 600;
}
.vm-lead { margin-top: 18px; font-size: var(--text-md); line-height: var(--leading-relaxed); color: var(--text-muted); }

/* covenant band */
.vm-covenant { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; margin-top: 56px;
  background: var(--border-subtle); border: 1px solid var(--border-subtle); border-radius: var(--radius-xl); overflow: hidden; }
@media (max-width: 880px){ .vm-covenant { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 520px){ .vm-covenant { grid-template-columns: 1fr; } }
.vm-cov {
  background: var(--surface-card); padding: 28px 24px;
  display: flex; flex-direction: column; gap: 12px; transition: background var(--dur-base) var(--ease-out);
}
.vm-cov:hover { background: var(--surface-raised); }
.vm-cov__ic {
  width: 38px; height: 38px; border-radius: var(--radius-md);
  display: grid; place-items: center; color: var(--solar-300);
  background: var(--accent-soft); border: 1px solid var(--accent-line);
}
.vm-cov__ic svg { width: 20px; height: 20px; }
.vm-cov__t { font-size: var(--text-base); font-weight: 600; color: var(--text-strong); }
.vm-cov__d { font-size: var(--text-sm); line-height: var(--leading-snug); color: var(--text-muted); }

/* layers / rings of disclosure cards */
.vm-layers { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 56px; }
@media (max-width: 880px){ .vm-layers { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .vm-layers { grid-template-columns: 1fr; } }
.vm-layer {
  position: relative; background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); padding: 24px; overflow: hidden;
  transition: var(--transition-base);
}
.vm-layer:hover { border-color: var(--accent-line); box-shadow: var(--glow-solar-md); transform: translateY(-3px); }
.vm-layer__n {
  font-family: var(--font-mono); font-size: var(--text-2xs); letter-spacing: .14em;
  color: var(--text-faint);
}
.vm-layer__t { margin-top: 14px; font-size: var(--text-lg); color: var(--text-strong); font-weight: 600; }
.vm-layer__d { margin-top: 10px; font-size: var(--text-sm); line-height: var(--leading-snug); color: var(--text-muted); }
.vm-layer__tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 16px; }
.vm-chip {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .06em; text-transform: uppercase;
  padding: 4px 9px; border-radius: var(--radius-sm);
  background: var(--surface-inset); color: var(--text-muted); border: 1px solid var(--border-subtle);
}
.vm-layer__glow { position:absolute; right:-30px; top:-30px; width:120px; height:120px; border-radius:50%;
  background: radial-gradient(circle, color-mix(in oklab,var(--solar-500) 22%,transparent), transparent 70%);
  opacity:0; transition: opacity var(--dur-slow) var(--ease-out); }
.vm-layer:hover .vm-layer__glow { opacity:1; }

/* how it works — steps */
.vm-steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; margin-top: 60px; }
@media (max-width: 820px){ .vm-steps { grid-template-columns: 1fr; gap: 36px; } }
.vm-step { position: relative; padding-left: 0; }
.vm-step__n {
  font-family: var(--font-display); font-size: var(--text-2xl); color: var(--solar-400);
  text-shadow: 0 0 26px color-mix(in oklab,var(--solar-500) 50%, transparent);
}
.vm-step__line { height:1px; background: linear-gradient(90deg, var(--accent-line), transparent); margin: 18px 0; }
.vm-step__t { font-size: var(--text-lg); color: var(--text-strong); font-weight: 600; }
.vm-step__d { margin-top: 10px; font-size: var(--text-sm); line-height: var(--leading-relaxed); color: var(--text-muted); }

/* tribe / constellation */
.vm-tribe-grid { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,6vw,72px); align-items:center; margin-top: 8px; }
@media (max-width: 880px){ .vm-tribe-grid { grid-template-columns: 1fr; gap:48px; } }
.vm-constellation { position: relative; aspect-ratio: 1; width:100%; max-width: 460px; margin-inline:auto; }
.vm-star {
  position:absolute; width: var(--s, 10px); height: var(--s,10px); border-radius:50%;
  background: radial-gradient(circle at 40% 35%, var(--plasma), var(--solar-500));
  box-shadow: var(--glow-solar-sm);
  animation: vm-breathe 4s var(--ease-in-out) infinite; animation-delay: var(--d, 0s);
}
.vm-star.dim { background: var(--surface-overlay); box-shadow:none; animation:none; opacity:.5; }
@keyframes vm-breathe { 0%,100%{ box-shadow: var(--glow-solar-sm); } 50%{ box-shadow: var(--glow-solar-md); } }
@media (prefers-reduced-motion: reduce){ .vm-star{ animation:none; } }
.vm-constellation svg { position:absolute; inset:0; width:100%; height:100%; overflow:visible; }
.vm-constellation svg line { stroke: color-mix(in oklab,var(--solar-500) 40%, transparent); stroke-width:1; }

/* trust list */
.vm-trust { display:grid; grid-template-columns: repeat(2,1fr); gap: 18px; margin-top: 52px; }
@media (max-width: 760px){ .vm-trust { grid-template-columns:1fr; } }
.vm-trust__item { display:flex; gap:16px; padding: 22px; background: var(--surface-card);
  border:1px solid var(--border-subtle); border-radius: var(--radius-lg); }
.vm-trust__ic { flex:none; width:36px; height:36px; border-radius:var(--radius-md); display:grid; place-items:center;
  color: var(--aurora-400); background: var(--status-nominal-soft); border:1px solid color-mix(in oklab,var(--aurora-500) 30%,transparent); }
.vm-trust__ic svg { width:19px; height:19px; }
.vm-trust__t { font-size: var(--text-base); color: var(--text-strong); font-weight:600; }
.vm-trust__d { margin-top:6px; font-size: var(--text-sm); line-height: var(--leading-snug); color: var(--text-muted); }

/* CTA */
.vm-cta {
  position: relative; text-align:center; padding: clamp(56px,9vw,104px) var(--vm-gutter);
  border-radius: var(--radius-2xl); overflow:hidden;
  background:
    radial-gradient(80% 120% at 50% 0%, color-mix(in oklab,var(--solar-600) 26%, transparent), transparent 60%),
    var(--surface-card);
  border: 1px solid var(--accent-line); box-shadow: var(--shadow-xl), var(--glow-solar-lg);
}
.vm-cta__orb {
  width: 64px; height:64px; border-radius:50%; margin: 0 auto 26px;
  background: radial-gradient(circle at 38% 32%, var(--plasma), var(--solar-400) 50%, var(--ember-700));
  box-shadow: var(--glow-solar-lg); animation: solara-glow-breathe 3.4s var(--ease-in-out) infinite;
}
@media (prefers-reduced-motion: reduce){ .vm-cta__orb{ animation:none; } }
.vm-cta__form { display:flex; gap:12px; max-width: 440px; margin: 30px auto 0; }
@media (max-width: 520px){ .vm-cta__form { flex-direction:column; } }
.vm-cta__form .sol-input { height:48px; }
.vm-cta__note { margin-top:18px; font-family:var(--font-mono); font-size:var(--text-2xs);
  letter-spacing:.06em; color: var(--text-faint); }

/* footer */
.vm-foot { border-top:1px solid var(--border-subtle); padding-block: 44px; }
.vm-foot__row { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:20px; }
.vm-foot__links { display:flex; flex-wrap:wrap; gap: 6px 4px; }
.vm-foot__links a { font-size: var(--text-sm); color: var(--text-muted); padding:6px 12px; border-radius:var(--radius-sm); transition:var(--transition-color); }
.vm-foot__links a:hover { color: var(--text-strong); background: var(--surface-raised); }
.vm-foot__fine { margin-top: 26px; font-size: var(--text-xs); color: var(--text-faint); max-width: 70ch; line-height: var(--leading-relaxed); }

/* scroll-reveal */
.vm-reveal { opacity: 0; transform: translateY(16px); transition: opacity .7s var(--ease-out), transform .7s var(--ease-out); }
.vm-reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){ .vm-reveal { opacity:1; transform:none; } }
