/* ───────────────────────────────────────────────
 * sparkmtg.org — site styles
 * Built on Spark Design System tokens (tokens.css)
 * Dark-first, matches the app.
 * ─────────────────────────────────────────────── */

html, body { margin: 0; padding: 0; }
body.spark { min-height: 100vh; background: var(--bg-0); }
.site a { -webkit-tap-highlight-color: transparent; }

::selection { background: var(--spark-soft); }

/* ── Topbar ─────────────────────────────────── */
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: 28px;
  height: 64px; padding: 0 clamp(20px, 4vw, 48px);
  background: oklch(0.13 0.005 60 / 0.82);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border-1);
}
.brand {
  display: flex; align-items: center; gap: 10px;
  color: var(--fg-0); text-decoration: none;
}
.wordmark {
  font: var(--w-heavy) 19px/1 var(--font-display);
  letter-spacing: -0.02em;
}
.topnav { margin-left: auto; display: flex; align-items: center; gap: 6px; }
.nav-link {
  padding: 9px 12px; border-radius: var(--r-sm);
  color: var(--fg-1); text-decoration: none;
  font: var(--w-medium) 14px/1 var(--font-text);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.nav-link:hover { background: var(--bg-2); color: var(--fg-0); }
.nav-link.active { color: var(--fg-0); }

.signin-pill {
  display: flex; align-items: center; gap: 8px;
  margin-left: 6px; padding: 7px 8px 7px 14px;
  border: 1px solid var(--border-2); border-radius: var(--r-pill);
  color: var(--fg-2); font: var(--w-medium) 13px/1 var(--font-text);
  cursor: default; user-select: none;
}
.soon-chip {
  font: var(--w-semibold) 10px/1 var(--font-text);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--spark); background: var(--spark-soft);
  padding: 5px 8px; border-radius: var(--r-pill);
}
body[data-signin="off"] .signin-pill { display: none; }

.lang-seg {
  display: flex; gap: 2px; margin-left: 10px; padding: 3px;
  background: var(--bg-1); border: 1px solid var(--border-1);
  border-radius: var(--r-pill);
}
.lang-btn {
  border: none; background: transparent; cursor: pointer;
  color: var(--fg-2); padding: 7px 10px; border-radius: var(--r-pill);
  font: var(--w-semibold) 11.5px/1 var(--font-text); letter-spacing: 0.04em;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.lang-btn:hover { color: var(--fg-0); }
.lang-btn.active { background: var(--bg-3); color: var(--fg-0); }

/* ── Hero ───────────────────────────────────── */
.hero { position: relative; overflow: hidden; padding: clamp(56px, 9vh, 110px) 0 72px; }
.hero::before {
  content: ""; position: absolute; left: -10%; right: -10%; top: -45%; height: 90%;
  background: radial-gradient(ellipse at 28% 10%, oklch(0.74 0.165 55 / 0.18), transparent 62%);
  opacity: var(--hero-glow, 0.6);
  pointer-events: none;
}
.hero-inner {
  position: relative; max-width: 1180px; margin: 0 auto;
  padding: 0 clamp(20px, 4vw, 48px);
}
.hero-flex {
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.08fr);
  gap: clamp(36px, 5vw, 64px); align-items: center;
}
.hero-copy { display: flex; flex-direction: column; align-items: flex-start; gap: 22px; }

.badge {
  display: inline-flex; align-items: center; gap: 8px;
  font: var(--w-semibold) 12px/1 var(--font-text);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--spark); background: var(--spark-soft);
  border: 1px solid var(--spark-line);
  padding: 8px 13px; border-radius: var(--r-pill);
}
.hero-h1 {
  margin: 0;
  font: var(--w-heavy) clamp(38px, 4.8vw, 62px)/1.04 var(--font-display);
  letter-spacing: -0.025em; color: var(--fg-0);
  text-wrap: balance;
}
.hero-h1 em { font-style: normal; color: var(--spark); }
body[data-copy="a"] .h1-b { display: none; }
body[data-copy="b"] .h1-a { display: none; }
.hero-sub {
  margin: 0; max-width: 50ch;
  font: var(--w-regular) 17.5px/1.55 var(--font-text);
  color: var(--fg-1); text-wrap: pretty;
}

/* Notify form */
.notify-form { display: flex; flex-direction: column; gap: 12px; width: 100%; max-width: 460px; }
.notify-row { display: flex; gap: 10px; }
.notify-row input {
  flex: 1; min-width: 0; height: 52px; padding: 0 18px;
  border-radius: var(--r-md); border: 1px solid var(--border-2);
  background: var(--bg-1); color: var(--fg-0);
  font: var(--w-regular) 15px/1 var(--font-text);
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.notify-row input:focus { border-color: var(--spark-line); box-shadow: 0 0 0 3px var(--spark-soft); }
.notify-row button {
  height: 52px; padding: 0 22px; border: none; cursor: pointer;
  border-radius: var(--r-md); background: var(--spark); color: var(--bg-0);
  font: var(--w-semibold) 13px/1 var(--font-text);
  letter-spacing: 0.05em; text-transform: uppercase; white-space: nowrap;
  transition: background var(--dur-fast) var(--ease-out), transform var(--dur-instant) var(--ease-out);
}
.notify-row button:hover { background: var(--spark-hover); }
.notify-row button:active { background: var(--spark-press); transform: scale(0.98); }
.notify-note { margin: 0; font: var(--w-regular) 13px/1.5 var(--font-text); color: var(--fg-2); }
.notify-success {
  display: none; align-items: center; gap: 10px; height: 52px; padding: 0 18px;
  border-radius: var(--r-md);
  background: oklch(0.72 0.17 145 / 0.12); border: 1px solid oklch(0.72 0.17 145 / 0.35);
  color: var(--ok); font: var(--w-medium) 15px/1.3 var(--font-text);
}
.notify-form.done .notify-row,
.notify-form.done .notify-note { display: none; }
.notify-form.done .notify-success { display: flex; }

/* Variant: App shot */
.shot-frame {
  border-radius: var(--r-xl); overflow: hidden; background: #000;
  border: 1px solid var(--border-2);
  box-shadow:
    0 30px 80px oklch(0 0 0 / 0.5),
    0 0 130px oklch(0.74 0.165 55 / calc(var(--hero-glow, 0.6) * 0.22));
}
.shot-frame img { display: block; width: 100%; height: auto; }

/* Variant: Typographic */
.life-row { display: none; gap: 14px; justify-content: center; margin-top: 26px; flex-wrap: wrap; }
.life-chip {
  width: 96px; height: 74px; border-radius: var(--r-lg);
  display: grid; place-items: center;
  font: var(--w-heavy) 34px/1 var(--font-display); letter-spacing: -0.02em;
  border: 1.5px solid;
  font-variant-numeric: tabular-nums;
}
body[data-hero="type"] .hero-flex { display: flex; flex-direction: column; align-items: center; text-align: center; }
body[data-hero="type"] .hero-copy { align-items: center; }
body[data-hero="type"] .hero-sub { max-width: 56ch; }
body[data-hero="type"] .hero-h1 { max-width: 17ch; font-size: clamp(42px, 5.6vw, 76px); }
body[data-hero="type"] .shot-frame { display: none; }
body[data-hero="type"] .life-row { display: flex; }
body[data-hero="type"] .hero::before {
  left: 0; right: 0;
  background: radial-gradient(ellipse at 50% 0%, oklch(0.74 0.165 55 / 0.18), transparent 62%);
}

/* Variant: Table photo */
.table-wrap {
  display: none; position: relative;
  border-radius: var(--r-xl); overflow: hidden;
  border: 1px solid var(--border-1);
}
.table-wrap image-slot {
  display: block; width: 100%; height: clamp(480px, 64vh, 640px);
  color: var(--fg-2);
  font: 12.5px/1.5 var(--font-mono);
  background:
    repeating-linear-gradient(45deg, oklch(1 0 0 / 0.022) 0 14px, transparent 14px 28px),
    var(--bg-1);
}
.table-scrim {
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(to top, oklch(0.13 0.005 60 / 0.94) 6%, oklch(0.13 0.005 60 / 0.4) 48%, oklch(0.13 0.005 60 / 0.05) 80%);
}
body[data-hero="table"] .table-wrap { display: block; }
body[data-hero="table"] .shot-frame { display: none; }
body[data-hero="table"] .hero-flex {
  display: block;
  position: absolute; z-index: 2;
  left: clamp(24px, 5vw, 64px); right: clamp(24px, 5vw, 64px); bottom: clamp(28px, 5vh, 52px);
}
body[data-hero="table"] .hero-copy { max-width: 620px; gap: 18px; }
body[data-hero="table"] .hero-h1 { font-size: clamp(34px, 3.8vw, 52px); }
body[data-hero="table"] .hero::before { display: none; }

/* ── While you wait ─────────────────────────── */
.wait { max-width: 1180px; margin: 0 auto; padding: 16px clamp(20px, 4vw, 48px) 96px; }
.cards-grid {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px; margin-top: 18px;
}
.wait-card {
  display: flex; flex-direction: column; gap: 8px;
  padding: 22px; border-radius: var(--r-lg);
  background: var(--bg-1); border: 1px solid var(--border-1);
  text-decoration: none;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out);
}
.wait-card:hover { background: var(--bg-2); border-color: var(--border-2); transform: translateY(-2px); }
.wait-card .t {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  font: var(--w-semibold) 16px/1.25 var(--font-display); letter-spacing: -0.01em;
  color: var(--fg-0);
}
.wait-card .t .arr { color: var(--fg-3); font: var(--w-regular) 15px/1 var(--font-text); transition: color var(--dur-fast) var(--ease-out); }
.wait-card:hover .t .arr { color: var(--spark); }
.wait-card .d { font: var(--w-regular) 13.5px/1.5 var(--font-text); color: var(--fg-2); }

/* ── Footer ─────────────────────────────────── */
.site-footer { border-top: 1px solid var(--border-1); }
.foot-inner {
  max-width: 1180px; margin: 0 auto;
  padding: 36px clamp(20px, 4vw, 48px) 56px;
  display: flex; flex-direction: column; gap: 22px;
}
.foot-row { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; justify-content: space-between; }
.foot-links { display: flex; gap: 4px; flex-wrap: wrap; }
.foot-q { font: var(--w-regular) 14px/1.4 var(--font-text); color: var(--fg-2); }
.foot-q a { color: var(--fg-1); text-decoration: none; border-bottom: 1px solid var(--border-2); }
.foot-q a:hover { color: var(--spark); border-bottom-color: var(--spark-line); }
.disclaimer { font: var(--w-regular) 12.5px/1.6 var(--font-text); color: var(--fg-3); max-width: 78ch; margin: 0; }

/* ── Inner pages (prose) ────────────────────── */
.page { max-width: 760px; margin: 0 auto; padding: 56px clamp(20px, 4vw, 48px) 96px; }
.page-wide { max-width: 980px; }
.kicker {
  font: var(--w-semibold) 12px/1 var(--font-text);
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--spark);
  margin: 0 0 14px;
}
.page h1 {
  margin: 0 0 10px;
  font: var(--w-heavy) clamp(32px, 4.4vw, 46px)/1.08 var(--font-display);
  letter-spacing: -0.022em; color: var(--fg-0);
}
.page .lede { margin: 0; font: var(--w-regular) 17px/1.55 var(--font-text); color: var(--fg-1); max-width: 56ch; text-wrap: pretty; }
.updated { font: var(--w-medium) 13px/1 var(--font-text); color: var(--fg-2); margin: 18px 0 0; }

.note-en {
  display: none; align-items: center; gap: 10px;
  margin-top: 22px; padding: 12px 16px;
  border-radius: var(--r-md); background: var(--bg-1); border: 1px solid var(--border-1);
  font: var(--w-regular) 13.5px/1.4 var(--font-text); color: var(--fg-2);
}
html:not([lang="en"]) .note-en { display: flex; }

.prose { margin-top: 36px; }
.prose h2 {
  margin: 44px 0 12px;
  font: var(--w-bold) 22px/1.25 var(--font-display); letter-spacing: -0.012em; color: var(--fg-0);
}
.prose h3 { margin: 28px 0 8px; font: var(--w-semibold) 17px/1.35 var(--font-text); color: var(--fg-0); }
.prose p, .prose li { font: var(--w-regular) 15.5px/1.68 var(--font-text); color: var(--fg-1); text-wrap: pretty; }
.prose p { margin: 0 0 14px; }
.prose ul { margin: 0 0 14px; padding-left: 22px; }
.prose li { margin-bottom: 6px; }
.prose strong { color: var(--fg-0); font-weight: var(--w-semibold); }
.prose a { color: var(--spark); text-decoration: none; border-bottom: 1px solid var(--spark-line); }
.prose a:hover { color: var(--spark-hover); }
.prose .divider { margin: 36px 0; }

/* FAQ accordion */
details.faq {
  margin-top: 10px; padding: 0 18px;
  border: 1px solid var(--border-1); border-radius: var(--r-md);
  background: var(--bg-1);
  transition: border-color var(--dur-fast) var(--ease-out);
}
details.faq[open] { border-color: var(--border-2); }
details.faq summary {
  display: flex; align-items: baseline; justify-content: space-between; gap: 16px;
  padding: 16px 0; cursor: pointer; list-style: none;
  font: var(--w-semibold) 15.5px/1.4 var(--font-text); color: var(--fg-0);
}
details.faq summary::-webkit-details-marker { display: none; }
details.faq summary::after {
  content: "+"; flex: none;
  font: var(--w-regular) 20px/1 var(--font-display); color: var(--fg-3);
  transition: transform var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
details.faq[open] summary::after { transform: rotate(45deg); color: var(--spark); }
details.faq p { margin: 0 0 18px; font: var(--w-regular) 14.5px/1.65 var(--font-text); color: var(--fg-1); }

/* Guides hub */
.guide-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin-top: 36px; }
.guide-card {
  display: flex; flex-direction: column; gap: 10px;
  padding: 28px; border-radius: var(--r-xl);
  background: var(--bg-1); border: 1px solid var(--border-1);
}
.guide-card .gt { font: var(--w-bold) 22px/1.2 var(--font-display); letter-spacing: -0.015em; color: var(--fg-0); margin: 0; }
.guide-card .gd { font: var(--w-regular) 14.5px/1.55 var(--font-text); color: var(--fg-1); margin: 0; }
.guide-meta { font: var(--w-semibold) 11.5px/1 var(--font-text); letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-2); }
.doc-langs { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.doc-lang {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 10px 15px; border-radius: var(--r-pill);
  border: 1px solid var(--border-2); color: var(--fg-0);
  font: var(--w-semibold) 13px/1 var(--font-text); text-decoration: none;
  transition: border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.doc-lang:hover { border-color: var(--spark-line); background: var(--spark-soft); }
.doc-lang .draft { font: var(--w-semibold) 9.5px/1 var(--font-text); letter-spacing: 0.07em; color: var(--warn); }

/* Contact block */
.contact-card {
  display: flex; flex-direction: column; gap: 6px;
  margin-top: 24px; padding: 22px;
  border-radius: var(--r-lg); background: var(--bg-1); border: 1px solid var(--border-1);
}
.contact-card .cl { font: var(--w-semibold) 11.5px/1 var(--font-text); letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-2); }
.contact-card .cv { font: var(--w-semibold) 18px/1.3 var(--font-display); }
.contact-card .cv a { color: var(--fg-0); text-decoration: none; border-bottom: 1px solid var(--border-2); }
.contact-card .cv a:hover { color: var(--spark); border-bottom-color: var(--spark-line); }
.contact-card .cd { font: var(--w-regular) 13.5px/1.5 var(--font-text); color: var(--fg-2); }

/* ── Responsive ─────────────────────────────── */
@media (max-width: 980px) {
  .hero-flex { grid-template-columns: 1fr; }
  .cards-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .guide-grid { grid-template-columns: 1fr; }
  .signin-pill { display: none; }
}
@media (max-width: 620px) {
  .topnav .nav-link { display: none; }
  .cards-grid { grid-template-columns: 1fr; }
  .notify-row { flex-direction: column; }
  .notify-row button { width: 100%; }
  body[data-hero="table"] .hero-flex { position: static; margin-top: 24px; }
  body[data-hero="table"] .table-wrap image-slot { height: 320px; }
}
