/* ─── Fonts ─────────────────────────────────────────────────────────────── */
@font-face {
  font-family: "MonaspaceKrypton";
  src: url("fonts/MonaspaceKrypton-Var.woff2") format("woff2 supports variations"),
       url("fonts/MonaspaceKrypton-Var.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "MonaspaceNeon";
  src: url("fonts/MonaspaceNeon-Var.woff2") format("woff2 supports variations"),
       url("fonts/MonaspaceNeon-Var.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

/* ─── Tokens ─────────────────────────────────────────────────────────────── */
:root {
  --claw-purple:   #7C6FFF;
  --claw-lavender: #A78BFA;
  --claw-mist:     #C4B5FD;
  --bg-void:       #080810;
  --bg-deep:       #0F0F1C;
  --bg-surface:    #16161F;
  --bg-raised:     #1E1E2E;
  --border:        #2A2A3E;
  --text:          #E8E8F4;
  --muted:         #8080A8;
  --green:         #4AE8A0;
  --red:           #FF4466;
  --amber:         #FFB340;

  --font-title: "MonaspaceKrypton", "SF Mono", monospace;
  --font-body:  "MonaspaceNeon", "SF Mono", monospace;
  --radius:     14px;
}

/* ─── Reset ──────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  background: var(--bg-void);
  color: var(--text);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--claw-lavender); text-decoration: none; }
a:hover { text-decoration: underline; }
.container { max-width: 1040px; margin: 0 auto; padding: 0 24px; }

/* ─── Buttons ────────────────────────────────────────────────────────────── */
.btn {
  font-family: var(--font-title);
  font-weight: 600;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 24px;
  border-radius: 999px;
  border: none; cursor: pointer;
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  transition: opacity .15s, transform .1s;
}
.btn:hover { opacity: .82; transform: translateY(-1px); text-decoration: none; }
.btn-lg { padding: 14px 32px; font-size: 0.95rem; }
.btn-sm { padding: 8px 18px; font-size: 0.8rem; }
.btn:not(.btn-outline) { background: var(--claw-purple); color: #fff; }
.btn-outline {
  background: transparent;
  border: 1.5px solid var(--border);
  color: var(--text);
}

/* ─── Nav ────────────────────────────────────────────────────────────────── */
nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(8,8,16,.88);
  backdrop-filter: blur(16px) saturate(1.4);
  border-bottom: 1px solid var(--border);
}
.nav-inner {
  max-width: 1040px; margin: 0 auto; padding: 14px 24px;
  display: flex; align-items: center; gap: 24px;
}
.logo {
  font-family: var(--font-title);
  font-weight: 700;
  font-size: 1.1rem;
  letter-spacing: -0.02em;
  margin-right: auto;
  color: var(--text);
}
.logo .mark { color: var(--claw-purple); }
.nav-link { font-family: var(--font-title); font-size: 0.82rem; color: var(--muted); font-weight: 500; }
.nav-link:hover { color: var(--text); text-decoration: none; }

/* ─── Hero ───────────────────────────────────────────────────────────────── */
.hero {
  padding: 110px 24px 80px;
  background:
    radial-gradient(ellipse 70% 45% at 50% 0%, rgba(124,111,255,.13) 0%, transparent 70%);
}
.hero-inner { max-width: 1040px; margin: 0 auto; }

.hero-badge {
  font-family: var(--font-title);
  display: inline-block;
  padding: 4px 14px;
  border-radius: 999px;
  border: 1px solid var(--border);
  font-size: 0.72rem;
  color: var(--muted);
  margin-bottom: 28px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

h1 {
  font-family: var(--font-title);
  font-size: clamp(2.6rem, 6vw, 4.2rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.04em;
  margin-bottom: 22px;
}
.accent { color: var(--claw-lavender); }
.grad {
  background: linear-gradient(135deg, var(--claw-purple), var(--claw-mist));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-sub {
  font-family: var(--font-body);
  font-size: 1.05rem;
  color: var(--muted);
  max-width: 500px;
  margin-bottom: 40px;
  line-height: 1.8;
}
.hero-cta { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 72px; }

/* Watch art */
.hero-art { display: flex; justify-content: center; }
.watch-frame {
  width: 148px; height: 178px;
  border-radius: 46px;
  background: linear-gradient(145deg, var(--bg-raised), var(--bg-void));
  border: 2px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 80px rgba(124,111,255,.18), 0 0 0 1px rgba(124,111,255,.08);
}
.watch-screen {
  width: 114px; height: 138px;
  border-radius: 34px;
  background: var(--bg-surface);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px;
}
.watch-logo {
  font-family: var(--font-title);
  font-size: 9px;
  font-weight: 700;
  color: var(--claw-purple);
  letter-spacing: 0.06em;
}
.watch-dot {
  width: 38px; height: 38px; border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, var(--claw-lavender), var(--claw-purple));
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(124,111,255,.45); }
  50%      { box-shadow: 0 0 0 12px rgba(124,111,255,0); }
}
.watch-text {
  font-family: var(--font-body);
  font-size: 8.5px;
  color: var(--muted);
  text-align: center;
  padding: 0 10px;
}
.watch-btn {
  width: 30px; height: 30px; border-radius: 50%;
  border: 1.5px solid var(--claw-purple);
  background: rgba(124,111,255,.08);
}

/* ─── Features ───────────────────────────────────────────────────────────── */
.features { padding: 88px 24px; background: var(--bg-deep); }
h2 {
  font-family: var(--font-title);
  font-size: clamp(1.6rem, 4vw, 2.2rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  margin-bottom: 48px;
  text-align: center;
}
.features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
  gap: 18px;
}
.feature-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 30px;
  transition: border-color .2s;
}
.feature-card:hover { border-color: var(--claw-purple); }
.feature-icon { font-size: 1.7rem; margin-bottom: 14px; }
.feature-card h3 {
  font-family: var(--font-title);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin-bottom: 8px;
}
.feature-card p { font-size: 0.88rem; color: var(--muted); line-height: 1.75; }

/* ─── How it works ───────────────────────────────────────────────────────── */
.how { padding: 88px 24px; }
.steps { list-style: none; display: flex; flex-direction: column; gap: 30px; max-width: 680px; margin: 0 auto; }
.steps li { display: flex; gap: 22px; align-items: flex-start; }
.step-num {
  flex-shrink: 0;
  font-family: var(--font-title);
  font-weight: 700;
  font-size: 0.85rem;
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--claw-purple);
  display: flex; align-items: center; justify-content: center;
}
.steps li div { padding-top: 6px; font-size: 0.92rem; color: var(--muted); line-height: 1.75; }
.steps li div strong { font-family: var(--font-title); font-weight: 600; color: var(--text); }

/* ─── FAQ ────────────────────────────────────────────────────────────────── */
.faq { padding: 88px 24px; background: var(--bg-deep); }
.faq-list { max-width: 720px; margin: 0 auto; display: flex; flex-direction: column; gap: 10px; }
details {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color .2s;
}
details[open] { border-color: var(--claw-purple); }
summary {
  padding: 18px 24px;
  font-family: var(--font-title);
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: -0.01em;
  cursor: pointer; list-style: none;
  display: flex; justify-content: space-between; align-items: center;
}
summary::-webkit-details-marker { display: none; }
summary::after { content: "+"; color: var(--claw-purple); font-size: 1.3rem; line-height: 1; font-family: var(--font-title); }
details[open] summary::after { content: "−"; }
details p { padding: 0 24px 20px; font-size: 0.88rem; color: var(--muted); line-height: 1.8; }

/* ─── Footer ─────────────────────────────────────────────────────────────── */
footer {
  padding: 52px 24px;
  border-top: 1px solid var(--border);
  text-align: center;
  color: var(--muted);
}
footer .logo { display: block; margin-bottom: 14px; }
footer p { font-family: var(--font-body); font-size: 0.85rem; margin-bottom: 4px; }
.footer-small { font-size: 0.76rem; opacity: .55; margin-top: 14px; }

/* ─── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
  h1 { font-size: 2.2rem; }
  .hero-cta { flex-direction: column; }
  .btn-lg { justify-content: center; }
}
