/* ============================================================
   SoulRefresh — shared design system
   One source of truth for the hub + every project.
   ============================================================ */
:root {
  --bg: #0b1026;
  --bg-deep: #070a18;
  --ink: #eaf2ff;
  --muted: rgba(234, 242, 255, 0.62);
  --faint: rgba(234, 242, 255, 0.4);
  --good: #5eead4;
  --accent: #818cf8;
  --violet: #c4b5fd;
  --line: rgba(255, 255, 255, 0.1);
  --card: rgba(255, 255, 255, 0.045);
  --display: "Bricolage Grotesque", "Trebuchet MS", system-ui, sans-serif;
  --body: "Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --radius: 22px;
}

* { margin: 0; padding: 0; box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { min-height: 100%; }
body {
  background: var(--bg); color: var(--ink); font-family: var(--body);
  min-height: 100dvh; overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; }

/* ---- Ambient backdrop (shared) ---- */
.soul-bg { position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.soul-bg .glow {
  position: absolute; border-radius: 50%; filter: blur(80px); opacity: 0.5;
  animation: soul-float 18s ease-in-out infinite;
}
.soul-bg .a { width: 46vmax; height: 46vmax; left: -12vmax; top: -14vmax;
  background: radial-gradient(circle, rgba(94,234,212,0.42), transparent 70%); }
.soul-bg .b { width: 52vmax; height: 52vmax; right: -16vmax; bottom: -18vmax;
  background: radial-gradient(circle, rgba(129,140,248,0.5), transparent 70%); animation-delay: -7s; }
.soul-bg .c { width: 30vmax; height: 30vmax; left: 38%; top: 28%;
  background: radial-gradient(circle, rgba(196,181,253,0.34), transparent 70%); animation-delay: -12s; }
@keyframes soul-float {
  0%,100% { transform: translate3d(0,0,0) scale(1); }
  33% { transform: translate3d(4vmax,-3vmax,0) scale(1.08); }
  66% { transform: translate3d(-3vmax,4vmax,0) scale(0.95); }
}
.soul-stars { position: fixed; inset: 0; z-index: 0; pointer-events: none; }

/* ---- Brand wordmark ---- */
.soul-brand {
  font-family: var(--display); font-weight: 800; letter-spacing: 0.5px; line-height: 1;
  background: linear-gradient(120deg, var(--good), var(--accent) 55%, var(--violet));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.soul-kicker {
  font-family: var(--display); letter-spacing: 0.34em; text-transform: uppercase;
  font-size: 0.72rem; color: var(--muted);
}

/* ---- Layout shell ---- */
.soul-wrap { position: relative; z-index: 1; }
.soul-center { min-height: 100dvh; display: grid; place-items: center; padding: 40px 22px; }

/* ---- Glass card ---- */
.soul-card {
  position: relative; z-index: 1;
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: 0 30px 80px rgba(0,0,0,0.5);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
}

/* ---- Badge / pill ---- */
.soul-badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--display); font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--good); padding: 6px 14px; border-radius: 999px;
  background: rgba(94,234,212,0.08); border: 1px solid rgba(94,234,212,0.22);
}
.soul-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--good);
  box-shadow: 0 0 0 0 rgba(94,234,212,0.6); animation: soul-pulse 2.2s infinite; }
@keyframes soul-pulse {
  0% { box-shadow: 0 0 0 0 rgba(94,234,212,0.55); }
  70% { box-shadow: 0 0 0 9px rgba(94,234,212,0); }
  100% { box-shadow: 0 0 0 0 rgba(94,234,212,0); }
}

/* ---- Buttons ---- */
.soul-btn {
  display: inline-flex; align-items: center; gap: 10px; text-decoration: none; cursor: pointer;
  font-family: var(--display); font-weight: 700; font-size: 1rem; color: #0b1026; border: none;
  padding: 13px 26px; border-radius: 999px;
  background: linear-gradient(120deg, var(--good), var(--accent));
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.soul-btn:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(129,140,248,0.32); }
.soul-btn.ghost {
  color: var(--ink); background: rgba(129,140,248,0.12); border: 1px solid rgba(129,140,248,0.35);
}
.soul-btn.ghost:hover { background: rgba(129,140,248,0.2); }

/* ---- Footer ---- */
.soul-foot { position: relative; z-index: 1; text-align: center; padding: 22px;
  font-size: 0.72rem; color: var(--muted); }
.soul-foot a { text-decoration: none; opacity: 0.8; }
.soul-foot a:hover { opacity: 1; }

@media (prefers-reduced-motion: reduce) {
  .soul-bg .glow, .soul-dot { animation: none; }
}
