/* ==========================================================================
   main.css — layout + component styles for root64 landing prototype
   All values reference tokens from tokens.css — no raw hex/#... or Npx
   DESIGN-SPEC.md §2 is authoritative for every component spec.
   ========================================================================== */

/* ── Dot-grid body motif (DESIGN-SPEC §3) ──────────────────────────────── */
body {
  background-color: var(--color-surface);
  background-image: radial-gradient(circle at 1px 1px, rgba(20,33,61,0.05) 1px, transparent 0);
  background-size: 32px 32px;
}

/* ── Layout helpers ─────────────────────────────────────────────────────── */
.wrap {
  max-width: var(--layout-max);
  margin-inline: auto;
  padding-inline: var(--layout-pad);
}
.section {
  padding-block: var(--layout-section-y);
}

/* ── Scroll reveal (DESIGN-SPEC §3) ─────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--motion-reveal) var(--ease-standard),
              transform var(--motion-reveal) var(--ease-standard);
}
.reveal.in {
  opacity: 1;
  transform: none;
}

/* ── §2.2 Eyebrow label ─────────────────────────────────────────────────── */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--type-label);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-5);
}
.eyebrow::before {
  content: "";
  display: block;
  width: 24px;
  height: 1px;
  background: var(--color-accent);
  flex-shrink: 0;
}

/* ── §2.7 Section header ────────────────────────────────────────────────── */
.sec-head {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--space-12);
  margin-bottom: var(--space-12);
}
.sec-head h2 {
  font-size: var(--type-title);
  font-weight: 500;
  line-height: 1.06;
  letter-spacing: -0.032em;
  color: var(--color-ink);
}
.sec-head h2 em {
  font-style: italic;
  color: var(--color-accent);
}
.sec-head .lead {
  font-size: var(--type-body);
  line-height: 1.5;
  color: var(--color-ink-soft);
  padding-top: var(--space-2);
}

/* ── §2.8 Nav shell ─────────────────────────────────────────────────────── */
.nav-shell {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--layout-nav-h);
  background: color-mix(in srgb, var(--color-surface) 88%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--color-border);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
}
.nav-wordmark {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  font-weight: 700;
  font-size: var(--type-body-lg);
  color: var(--color-ink);
  letter-spacing: -0.02em;
}
.nav-wordmark .mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
}
.nav-wordmark .mark svg {
  width: 32px;
  height: 32px;
}
.nav-links {
  display: flex;
  align-items: center;
  gap: var(--space-8);
}
.nav-links a {
  font-size: var(--type-body-sm);
  font-weight: 500;
  color: var(--color-ink-soft);
  text-decoration: none;
  transition: color var(--motion-base) var(--ease-standard);
}
.nav-links a:hover,
.nav-links a.active {
  color: var(--color-accent);
}
.nav-actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

/* ── §2.1 Button ─────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  height: 44px;
  padding-inline: 22px;
  background: var(--color-ink);
  color: var(--color-surface);
  border: 1px solid var(--color-ink);
  border-radius: var(--radius-sharp);
  font-family: var(--font-sans);
  font-size: var(--type-body-sm);
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--motion-base) var(--ease-standard),
              border-color var(--motion-base) var(--ease-standard),
              transform var(--motion-fast) var(--ease-standard);
  position: relative;
}
.btn::after {
  content: " →";
  font-family: var(--font-mono);
  display: inline-block;
  transition: transform var(--motion-base) var(--ease-standard);
}
.btn:hover {
  background: var(--color-accent);
  border-color: var(--color-accent);
}
.btn:hover::after {
  transform: translateX(3px);
}
.btn:active {
  transform: translateY(1px);
}
.btn.copper {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-surface);
}
.btn.copper:hover {
  background: var(--color-ink);
  border-color: var(--color-ink);
}
.btn.ghost {
  background: transparent;
  border-color: var(--color-border-strong);
  color: var(--color-ink);
}
.btn.ghost:hover {
  background: var(--color-ink);
  border-color: var(--color-ink);
  color: var(--color-surface);
}
.btn.sm {
  height: 34px;
  padding-inline: 14px;
  font-size: 12px;
}
.btn.lg {
  height: 52px;
  padding-inline: 28px;
  font-size: var(--type-body);
}

/* ── §2.3 Card / Panel ──────────────────────────────────────────────────── */
.card {
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sharp);
}
.card.shadow {
  box-shadow: var(--shadow-card);
}
.card:hover {
  border-color: var(--color-accent);
}

/* Pillar card (§2.3) */
.pillar-card {
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sharp);
  padding: var(--space-10);
  min-height: 460px;
  display: flex;
  flex-direction: column;
  transition: border-color var(--motion-base) var(--ease-standard);
}
.pillar-card:hover {
  border-color: var(--color-accent);
}
.pillar-card.copper {
  background: var(--color-ink);
  color: var(--color-surface);
}
.pillar-card.copper .pillar-body {
  color: var(--color-accent-soft);
}
.pillar-card h3 {
  font-size: var(--type-heading);
  font-weight: 500;
  line-height: 1.12;
  letter-spacing: -0.03em;
  margin-bottom: var(--space-6);
}
.pillar-card h3 em {
  font-style: italic;
  color: var(--color-accent);
}
.pillar-card.copper h3 em {
  color: var(--color-accent-bright);
}
.pillar-body {
  font-size: var(--type-body-sm);
  line-height: 1.6;
  color: var(--color-ink-soft);
  flex: 1;
}
.pillar-number {
  font-family: var(--font-mono);
  font-size: var(--type-label);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-6);
}

/* ── §2.5 Pill ──────────────────────────────────────────────────────────── */
.pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-pill);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
}
.pill.live {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-surface);
}
.pill.live::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: var(--radius-pill);
  background: var(--color-surface);
  animation: pulse-dot 1.8s ease-in-out infinite;
}
.pill.soon {
  color: var(--color-ink-soft);
}
.pill.stale {
  background: var(--color-accent-soft);
  border-color: var(--color-accent-soft);
  color: var(--color-ink);
}
@keyframes pulse-dot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(245,240,232,0.5); }
  50%       { box-shadow: 0 0 0 4px rgba(245,240,232,0); }
}

/* ── §2.4 Snapshot / stat card ──────────────────────────────────────────── */
.snap-card {
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sharp);
  box-shadow: var(--shadow-card);
}
.snap-head {
  padding: var(--space-6) var(--space-6) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.snap-head-label {
  font-family: var(--font-mono);
  font-size: var(--type-label);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
}
.snap-row {
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--color-border);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
}
.snap-row.featured {
  padding-block: var(--space-6);
}
.snap-label {
  font-family: var(--font-mono);
  font-size: var(--type-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
}
.snap-value {
  font-family: var(--font-mono);
  font-weight: 500;
  font-feature-settings: "tnum" 1, "zero" 1;
  color: var(--color-ink);
}
.snap-value.xl { font-size: var(--type-data-xl); letter-spacing: -0.03em; }
.snap-value.lg { font-size: var(--type-data-lg); letter-spacing: -0.02em; }
.snap-value.md { font-size: var(--type-data-md); letter-spacing: -0.01em; }
.snap-foot {
  padding: var(--space-4) var(--space-6);
  background: color-mix(in srgb, var(--color-accent) 6%, var(--color-surface-raised));
  font-family: var(--font-mono);
  font-size: var(--type-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* ── §2.6 Data table ────────────────────────────────────────────────────── */
.assets-tbl {
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sharp);
  overflow: hidden;
}
.assets-tbl table {
  width: 100%;
  border-collapse: collapse;
}
.assets-tbl thead {
  background: var(--color-surface-sunken);
}
.assets-tbl thead th {
  padding: var(--space-4) var(--space-6);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}
.assets-tbl tbody td {
  padding: var(--space-5) var(--space-6);
  font-size: var(--type-body-sm);
  color: var(--color-ink);
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
}
.assets-tbl tbody tr:last-child td {
  border-bottom: none;
}
.assets-tbl tbody tr:hover td {
  background: color-mix(in srgb, var(--color-accent) 4%, var(--color-surface-raised));
}
.tbl-mono {
  font-family: var(--font-mono);
  font-feature-settings: "tnum" 1, "zero" 1;
}

/* Pool status badges — PENDING Q12 (color tokens undefined in DESIGN-SPEC) */
/* → Q12: 풀 상태 배지·리스크 지표 색상 — DESIGN-SPEC §1.2 미정의 pending 토큰 */
.badge {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-pill);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
/* Using DESIGN-SPEC accent tokens as closest available approximations until Q12 resolved */
.badge.active  { background: color-mix(in srgb, var(--color-accent) 15%, var(--color-surface-raised)); color: var(--color-accent); border: 1px solid var(--color-accent); }
.badge.closed  { background: color-mix(in srgb, var(--color-ink-soft) 10%, var(--color-surface-raised)); color: var(--color-ink-soft); border: 1px solid var(--color-border-strong); }
.badge.pending { background: color-mix(in srgb, var(--color-accent-soft) 40%, var(--color-surface-raised)); color: var(--color-ink); border: 1px solid var(--color-accent-soft); }

/* Risk indicators — PENDING Q12 */
.risk-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: var(--radius-pill);
}
.risk-dot.low    { background: var(--color-accent); }        /* PENDING Q12 */
.risk-dot.medium { background: var(--color-accent-bright); } /* PENDING Q12 */
.risk-dot.high   { background: var(--color-ink-soft); }      /* PENDING Q12 */

/* ── Skeleton loading (state=loading) ───────────────────────────────────── */
.skeleton {
  background: linear-gradient(90deg,
    var(--color-surface-sunken) 25%,
    var(--color-surface-raised) 50%,
    var(--color-surface-sunken) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s ease-in-out infinite;
  border-radius: var(--radius-sharp);
  min-height: 1em;
}
@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ── Hero section ───────────────────────────────────────────────────────── */
.hero {
  padding-block: var(--space-30) var(--space-24);
  position: relative;
  overflow: hidden;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
}
.hero-eyebrow { margin-bottom: var(--space-6); }
.hero h1 {
  font-size: var(--type-display);
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: -0.035em;
  color: var(--color-ink);
  margin-bottom: var(--space-8);
}
.hero h1 em {
  font-style: italic;
  color: var(--color-accent);
}
.hero-sub {
  font-size: var(--type-body-lg);
  line-height: 1.55;
  color: var(--color-ink-soft);
  margin-bottom: var(--space-10);
  max-width: 480px;
}
.hero-ctas {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}
/* Hero roots motif (§3 brand) */
.hero-motif {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 40%;
  height: 2px;
  background: var(--color-accent);
  opacity: 0.25;
}

/* ── Intro / What is root64 section ─────────────────────────────────────── */
.pillars-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-bottom: var(--space-10);
}
.brand-panel {
  background: var(--color-ink);
  color: var(--color-surface);
  padding: var(--space-10);
  border-radius: var(--radius-sharp);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
  align-items: center;
}
.brand-panel-text h3 {
  font-size: var(--type-heading);
  font-weight: 500;
  letter-spacing: -0.03em;
  margin-bottom: var(--space-4);
  color: var(--color-surface);
}
.brand-panel-text h3 em {
  font-style: italic;
  color: var(--color-accent-bright);
}
.brand-panel-text p {
  font-size: var(--type-body-sm);
  line-height: 1.6;
  color: var(--color-accent-soft);
}
.brand-panel-visual {
  display: flex;
  align-items: center;
  justify-content: center;
}
.brand-math {
  font-family: var(--font-mono);
  font-size: var(--type-data-xl);
  font-weight: 500;
  letter-spacing: -0.03em;
  color: var(--color-accent-bright);
}

/* ── How it works / Fund flow section ───────────────────────────────────── */
.flow-diagram {
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sharp);
  padding: var(--space-10);
  margin-bottom: var(--space-10);
  overflow-x: auto;
}
.flow-entities {
  display: flex;
  align-items: flex-start;
  gap: 0;
  position: relative;
}
.flow-entity {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
}
.flow-entity-box {
  width: 100%;
  max-width: 140px;
  background: var(--color-surface-sunken);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-sharp);
  padding: var(--space-4) var(--space-3);
  margin-bottom: var(--space-4);
}
.flow-entity-label {
  font-size: var(--type-body-sm);
  font-weight: 500;
  color: var(--color-ink);
  margin-bottom: var(--space-2);
}
.flow-entity-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
}
.flow-arrow {
  position: absolute;
  top: 28px;
  right: -12px;
  z-index: 2;
  font-family: var(--font-mono);
  color: var(--color-accent);
  font-size: 18px;
  line-height: 1;
}
.flow-connector {
  flex: none;
  width: 48px;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 28px;
  color: var(--color-accent);
  font-size: 16px;
}
.flow-connector-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
  writing-mode: horizontal-tb;
  margin-top: var(--space-2);
  text-align: center;
}
.verification-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}
.verif-card {
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sharp);
  padding: var(--space-6);
}
.verif-card h4 {
  font-size: var(--type-body-sm);
  font-weight: 500;
  color: var(--color-ink);
  margin-bottom: var(--space-3);
}
.verif-card p {
  font-size: var(--type-body-sm);
  line-height: 1.5;
  color: var(--color-ink-soft);
}
.verif-icon {
  font-family: var(--font-mono);
  font-size: var(--type-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-4);
}

/* ── Platform stats section (§4.4) ─────────────────────────────────────── */
.stats-featured {
  margin-bottom: var(--space-8);
}
.stats-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}
.dist-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}
.dist-bar-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.dist-bar-label {
  font-family: var(--font-mono);
  font-size: var(--type-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
}
.dist-bar {
  height: 6px;
  background: var(--color-border);
  border-radius: var(--radius-sharp);
  overflow: hidden;
}
.dist-bar-fill {
  height: 100%;
  background: var(--color-accent);
  transition: width 0.6s var(--ease-standard);
}
.dist-value {
  font-family: var(--font-mono);
  font-size: var(--type-body-sm);
  font-weight: 500;
  color: var(--color-ink);
  font-feature-settings: "tnum" 1;
}

/* State variants for §4.4 platform stats */
/* default: visible; loading: skeleton; empty/error: message panels */
.state-panel {
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sharp);
  padding: var(--space-12);
  text-align: center;
  display: none;
}
.state-panel h3 {
  font-size: var(--type-subheading);
  font-weight: 500;
  color: var(--color-ink);
  margin-bottom: var(--space-4);
}
.state-panel p {
  font-size: var(--type-body-sm);
  color: var(--color-ink-soft);
  line-height: 1.6;
  margin-bottom: var(--space-6);
}

/* ── Pool table section (§4.5) ──────────────────────────────────────────── */
.pool-table-wrap {
  margin-top: var(--space-8);
}
.pool-filter-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}
.filter-pill {
  padding: var(--space-2) var(--space-5);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-pill);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
  background: transparent;
  cursor: pointer;
  transition: all var(--motion-base) var(--ease-standard);
}
.filter-pill:hover,
.filter-pill.active {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-surface);
}

/* ── Why root64 section (§4.6) ───────────────────────────────────────────── */
.why-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}
.why-card {
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sharp);
  padding: var(--space-8);
  transition: border-color var(--motion-base) var(--ease-standard);
}
.why-card:hover {
  border-color: var(--color-accent);
}
.why-card-num {
  font-family: var(--font-mono);
  font-size: var(--type-label);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-5);
}
.why-card h3 {
  font-size: var(--type-subheading);
  font-weight: 500;
  letter-spacing: -0.025em;
  color: var(--color-ink);
  margin-bottom: var(--space-4);
}
.why-card p {
  font-size: var(--type-body-sm);
  line-height: 1.6;
  color: var(--color-ink-soft);
}

/* ── Roadmap section (§4.7) ──────────────────────────────────────────────── */
.roadmap-track {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
  margin-top: var(--space-12);
}
.roadmap-track::before {
  content: "";
  position: absolute;
  top: 20px;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--color-border-strong);
  z-index: 0;
}
.roadmap-step {
  position: relative;
  padding-top: var(--space-12);
  padding-right: var(--space-8);
}
.roadmap-step-dot {
  position: absolute;
  top: 14px;
  left: 0;
  width: 14px;
  height: 14px;
  border-radius: var(--radius-pill);
  background: var(--color-surface);
  border: 2px solid var(--color-border-strong);
  z-index: 1;
}
.roadmap-step.active .roadmap-step-dot {
  background: var(--color-accent);
  border-color: var(--color-accent);
}
.roadmap-step.done .roadmap-step-dot {
  background: var(--color-ink);
  border-color: var(--color-ink);
}
.roadmap-step-tag {
  font-family: var(--font-mono);
  font-size: var(--type-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
  margin-bottom: var(--space-3);
}
.roadmap-step.active .roadmap-step-tag {
  color: var(--color-accent);
}
.roadmap-step h4 {
  font-size: var(--type-body);
  font-weight: 500;
  color: var(--color-ink);
  margin-bottom: var(--space-3);
}
.roadmap-step p {
  font-size: var(--type-body-sm);
  line-height: 1.6;
  color: var(--color-ink-soft);
}
.roadmap-step .soon-tag {
  display: inline-block;
  margin-top: var(--space-3);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-pill);
}

/* ── Contact band (§4.8) ────────────────────────────────────────────────── */
.contact-band {
  background: var(--color-ink);
  color: var(--color-surface);
  padding-block: var(--space-24);
  position: relative;
  overflow: hidden;
}
.contact-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(245,240,232,0.05) 1px, transparent 0);
  background-size: 32px 32px;
}
.contact-band .wrap {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
}
.contact-band h2 {
  font-size: var(--type-title-lg);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.032em;
  color: var(--color-surface);
  margin-bottom: var(--space-4);
}
.contact-band h2 em {
  font-style: italic;
  color: var(--color-accent-bright);
}
.contact-band .sub {
  font-size: var(--type-body);
  color: var(--color-accent-soft);
  line-height: 1.5;
  margin-bottom: var(--space-8);
}

/* Contact form — STUB (Q20: PII handling undecided) */
/* → Q20: 문의 형태(입력 폼 vs mailto vs 없음)·PII 처리 표면 — 백엔드 미연결 스텁 */
.contact-form-stub {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.form-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.form-field label {
  font-family: var(--font-mono);
  font-size: var(--type-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-accent-soft);
}
.form-field input,
.form-field textarea {
  background: rgba(245,240,232,0.06);
  border: 1px solid rgba(245,240,232,0.15);
  border-radius: var(--radius-sharp);
  padding: var(--space-4) var(--space-5);
  color: var(--color-surface);
  font-size: var(--type-body-sm);
  font-family: var(--font-sans);
  width: 100%;
  transition: border-color var(--motion-base) var(--ease-standard);
}
.form-field input::placeholder,
.form-field textarea::placeholder {
  color: rgba(245,240,232,0.3);
}
.form-field input:focus,
.form-field textarea:focus {
  border-color: var(--color-accent-bright);
  outline: none;
}
.form-field textarea { resize: vertical; min-height: 100px; }
.form-note {
  font-size: 12px;
  color: rgba(245,240,232,0.4);
  line-height: 1.5;
}

/* ── Footer ─────────────────────────────────────────────────────────────── */
.footer {
  background: var(--color-ink-deep);
  color: var(--color-accent-soft);
  padding-block: var(--space-12);
  border-top: 1px solid rgba(245,240,232,0.06);
}
.footer-inner {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-10);
  margin-bottom: var(--space-10);
}
.footer-brand {
  font-size: var(--type-body-sm);
  color: var(--color-accent-soft);
  line-height: 1.6;
}
.footer-brand strong {
  display: block;
  font-size: var(--type-body);
  color: var(--color-surface);
  margin-bottom: var(--space-3);
}
.footer-links h5 {
  font-family: var(--font-mono);
  font-size: var(--type-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
  margin-bottom: var(--space-4);
}
.footer-links ul {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.footer-links a {
  font-size: var(--type-body-sm);
  color: var(--color-accent-soft);
  text-decoration: none;
  transition: color var(--motion-base) var(--ease-standard);
}
.footer-links a:hover { color: var(--color-surface); }
.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-8);
  border-top: 1px solid rgba(245,240,232,0.06);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
}
/* → Q21: 규제 면책·관할권 제한 고지 수준 (법무 검토 필요) */
.footer-disclaimer {
  font-size: 11px;
  color: var(--color-ink-soft);
  line-height: 1.6;
  padding-top: var(--space-6);
  border-top: 1px solid rgba(245,240,232,0.06);
  margin-top: var(--space-6);
}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .roadmap-track { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 880px) {
  .pillars-grid { grid-template-columns: 1fr; }
  .why-grid { grid-template-columns: 1fr; }
  .sec-head { grid-template-columns: 1fr; gap: var(--space-6); }
  .brand-panel { grid-template-columns: 1fr; }
  .verification-grid { grid-template-columns: 1fr 1fr; }
  .contact-band .wrap { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .wrap { padding-inline: var(--layout-pad-mobile); }
  .section { padding-block: var(--layout-section-y-mobile); }
  .hero { padding-block: var(--space-16) var(--space-12); }
  .nav-links { display: none; }
  .stats-grid { grid-template-columns: 1fr; }
  .roadmap-track { grid-template-columns: 1fr; }
  .verification-grid { grid-template-columns: 1fr; }
  .dist-grid { grid-template-columns: 1fr; }
}

/* ── Stale data banner ───────────────────────────────────────────────────── */
.stale-banner {
  display: none;
  background: color-mix(in srgb, var(--color-accent-soft) 30%, var(--color-surface-raised));
  border: 1px solid var(--color-accent-soft);
  border-radius: var(--radius-sharp);
  padding: var(--space-3) var(--space-6);
  font-family: var(--font-mono);
  font-size: var(--type-label);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-ink);
  margin-bottom: var(--space-6);
  align-items: center;
  gap: var(--space-3);
}

/* ── State variant display logic ─────────────────────────────────────────── */
/* Default: show live data, hide skeleton/empty/error/stale overrides */
.stats-live    { display: block; }
.stats-loading { display: none; }
.stats-empty   { display: none; }
.stats-error   { display: none; }
.stats-stale   { display: none; }

body[data-state="loading"] .stats-live    { display: none; }
body[data-state="loading"] .stats-loading { display: block; }
body[data-state="empty"]   .stats-live    { display: none; }
body[data-state="empty"]   .stats-empty   { display: block; }
body[data-state="error"]   .stats-live    { display: none; }
body[data-state="error"]   .stats-error   { display: block; }
body[data-state="stale"]   .stale-banner  { display: flex; }

/* Pool table state variants */
.pool-live    { display: block; }
.pool-loading { display: none; }
.pool-empty   { display: none; }
.pool-error   { display: none; }
.pool-partial { display: none; }

body[data-state="loading"] .pool-live    { display: none; }
body[data-state="loading"] .pool-loading { display: block; }
body[data-state="empty"]   .pool-live    { display: none; }
body[data-state="empty"]   .pool-empty   { display: block; }
body[data-state="error"]   .pool-live    { display: none; }
body[data-state="error"]   .pool-error   { display: block; }
body[data-state="partial"] .pool-live    { display: none; }
body[data-state="partial"] .pool-partial { display: block; }

/* ── State switcher (dev/preview only) ──────────────────────────────────── */
.state-switcher {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  z-index: 999;
  background: var(--color-ink);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-sharp);
  padding: var(--space-4) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  box-shadow: var(--shadow-card);
}
.state-switcher-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-accent-soft);
  margin-bottom: var(--space-1);
}
.state-switcher-btns {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.state-btn {
  padding: var(--space-1) var(--space-3);
  border: 1px solid rgba(245,240,232,0.2);
  border-radius: var(--radius-pill);
  background: transparent;
  color: var(--color-accent-soft);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--motion-base) var(--ease-standard);
}
.state-btn:hover,
.state-btn.active {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-surface);
}
