/* =============================================================
   LINK WITH PRIDE — Subpages (Travel Guides + Blog Archive)
   ============================================================= */

/* ── PAGE HERO ── */
.page-hero {
  position: relative;
  padding: calc(var(--space-20) + var(--space-8)) var(--space-6) var(--space-12);
  overflow: hidden;
  border-bottom: 1px solid var(--color-border);
}
.page-hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse 60% 50% at 15% 20%, rgba(91,206,250,.14) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 90% 80%, rgba(245,169,184,.12) 0%, transparent 55%),
    var(--color-bg);
}
.page-hero-bg::after {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, color-mix(in oklab, var(--color-border) 60%, transparent) 1px, transparent 1px);
  background-size: 80px 100%;
  opacity: .35;
  mask-image: linear-gradient(to bottom, transparent, black 30%, black 70%, transparent);
  -webkit-mask-image: linear-gradient(to bottom, transparent, black 30%, black 70%, transparent);
}
.page-hero-inner { position: relative; z-index: 1; }

.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--color-text-faint);
  margin-bottom: var(--space-6);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: .04em;
}
.breadcrumb a { color: var(--color-text-muted); text-decoration: none; transition: color var(--t); }
.breadcrumb a:hover { color: var(--color-primary); }
.breadcrumb .current { color: var(--color-text); }

.page-hero-text { max-width: 720px; }
.page-title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 700;
  line-height: 1.05;
  margin-bottom: var(--space-4);
  background: linear-gradient(135deg, var(--color-text) 30%, var(--trans-blue) 70%, var(--trans-pink) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.page-lede {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  line-height: 1.6;
  max-width: 640px;
}

.page-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border);
}
.stat { display: flex; flex-direction: column; gap: 4px; }
.stat-num {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  line-height: 1;
  color: var(--color-text);
  font-feature-settings: "tnum";
}
.stat-label {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--color-text-muted);
}
@media (max-width: 700px) {
  .page-stats { grid-template-columns: repeat(2, 1fr); }
}

/* ── FILTER BAR ── */
.filter-bar {
  position: sticky;
  top: 60px;
  z-index: 50;
  background: color-mix(in oklab, var(--color-bg) 88%, transparent);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-3) var(--space-6);
}
.filter-inner {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.search-wrap {
  position: relative;
  flex: 1;
  min-width: 220px;
  max-width: 320px;
}
.search-wrap svg {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-faint);
  pointer-events: none;
}
.search-input {
  width: 100%;
  background: var(--color-surface-offset);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  padding: 9px 14px 9px 38px;
  font-size: var(--text-sm);
  color: var(--color-text);
  outline: none;
  transition: all var(--t);
}
.search-input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--color-primary) 15%, transparent);
}

.filter-chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.filter-chips.region { margin-left: auto; }
.fchip {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  padding: 7px 12px;
  border-radius: var(--radius-full);
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  transition: all var(--t);
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.fchip:hover { color: var(--color-text); border-color: var(--color-primary); }
.fchip.active {
  background: linear-gradient(135deg, var(--trans-blue), var(--trans-pink));
  color: #0f172a;
  border-color: transparent;
}
.fchip-count {
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--color-text) 10%, transparent);
  color: var(--color-text-muted);
}
.fchip.active .fchip-count {
  background: rgba(15, 23, 42, .15);
  color: #0f172a;
}

@media (max-width: 700px) {
  .filter-chips.region { margin-left: 0; width: 100%; overflow-x: auto; flex-wrap: nowrap; padding-bottom: 4px; }
}

/* ── TIGHTER SECTION ── */
.section-tight { padding-top: var(--space-12); padding-bottom: var(--space-12); }
.section-title-sm { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: var(--color-text); }

.guides-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}
.results-meta {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  display: flex;
  align-items: center;
  gap: 8px;
}
.results-meta strong, .results-meta #resultsCount {
  color: var(--color-text);
  font-weight: 700;
}
.sort-select {
  background: var(--color-surface-offset);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 5px 10px;
  font-size: var(--text-sm);
  color: var(--color-text);
  outline: none;
  font-family: var(--font-body);
}
.sort-select:focus { border-color: var(--color-primary); }

/* ── FEATURED CALLOUT ── */
.featured-callout {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border);
  min-height: 360px;
  display: flex;
  align-items: stretch;
}
.featured-bg { position: absolute; inset: 0; }
.featured-bg-vegas {
  background:
    radial-gradient(circle at 30% 30%, color-mix(in oklab, var(--trans-blue) 50%, transparent), transparent 60%),
    radial-gradient(circle at 75% 70%, color-mix(in oklab, var(--trans-pink) 45%, transparent), transparent 55%),
    linear-gradient(135deg, #0a0f1f 0%, #1a0f2e 100%);
}
.featured-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(120deg,
    rgba(8,12,20,.85) 0%,
    rgba(8,12,20,.55) 50%,
    rgba(8,12,20,.25) 100%);
}
.featured-content {
  position: relative; z-index: 1;
  padding: clamp(2rem, 5vw, 3.5rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 640px;
}
.featured-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  align-self: flex-start;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--trans-blue);
  background: color-mix(in oklab, var(--trans-blue) 16%, transparent);
  border: 1px solid color-mix(in oklab, var(--trans-blue) 30%, transparent);
  padding: 6px 12px;
  border-radius: var(--radius-full);
}
.featured-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.05;
}
.featured-desc {
  font-size: var(--text-base);
  color: rgba(255,255,255,.78);
  line-height: 1.6;
  max-width: 56ch;
}
.featured-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin: var(--space-2) 0 var(--space-4);
}
.featured-meta span {
  font-size: var(--text-xs);
  color: rgba(255,255,255,.7);
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  padding: 6px 12px;
  border-radius: var(--radius-full);
  font-family: 'JetBrains Mono', monospace;
}
.featured-meta strong { color: #fff; margin-right: 4px; }
.featured-content .btn { align-self: flex-start; }

/* ── TRAVEL GRID ── */
.travel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--space-5);
}
.tcard {
  position: relative;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  text-decoration: none;
  transition: all var(--t);
  display: flex;
  flex-direction: column;
  min-height: 380px;
}
.tcard:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: color-mix(in oklab, var(--color-primary) 40%, transparent);
}
.tcard-img {
  height: 160px;
  position: relative;
  overflow: hidden;
}
.tcard-img::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent, rgba(0,0,0,.35));
}
.tcard-status {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 1;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  backdrop-filter: blur(8px);
  background: rgba(255,255,255,.15);
  color: #fff;
  border: 1px solid rgba(255,255,255,.2);
}
.tcard-status.live { background: color-mix(in oklab, #34d399 28%, transparent); border-color: color-mix(in oklab, #34d399 50%, transparent); }
.tcard-status.in-progress { background: color-mix(in oklab, #fb923c 28%, transparent); border-color: color-mix(in oklab, #fb923c 50%, transparent); }
.tcard-status.planned { background: color-mix(in oklab, #94a3b8 28%, transparent); border-color: color-mix(in oklab, #94a3b8 50%, transparent); }

.tcard-region {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 1;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,.85);
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.18);
  padding: 4px 10px;
  border-radius: var(--radius-full);
  backdrop-filter: blur(8px);
}

.tcard-body {
  padding: var(--space-5) var(--space-6) var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.tcard-loc {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--color-primary);
  display: flex;
  align-items: center;
  gap: 6px;
}
.tcard-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.2;
}
.tcard-desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
  flex: 1;
}
.tcard-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-divider);
}
.tcard-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.tcard-tag {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 3px 8px;
  border-radius: var(--radius-full);
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
}
.tcard-cta {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-primary);
  white-space: nowrap;
}
.tcard:hover .tcard-cta { color: var(--color-accent); }

/* Per-destination art (CSS-only) */
.tcard-art-vegas    { background: radial-gradient(circle at 30% 40%, #f5a9b8 0%, transparent 50%), linear-gradient(135deg, #5b21b6, #1e3a8a); }
.tcard-art-honolulu { background: radial-gradient(circle at 70% 60%, #fbbf24 0%, transparent 55%), linear-gradient(135deg, #0f4c3a, #155e75); }
.tcard-art-la       { background: radial-gradient(circle at 40% 30%, #fb923c 0%, transparent 50%), linear-gradient(135deg, #be185d, #7c2d12); }
.tcard-art-nyc      { background: radial-gradient(circle at 60% 50%, #5BCEFA 0%, transparent 50%), linear-gradient(135deg, #1e293b, #0f172a); }
.tcard-art-atl      { background: radial-gradient(circle at 50% 50%, #f472b6 0%, transparent 50%), linear-gradient(135deg, #4c1d95, #1e1b4b); }
.tcard-art-chi      { background: radial-gradient(circle at 30% 60%, #38bdf8 0%, transparent 50%), linear-gradient(135deg, #0c4a6e, #082f49); }
.tcard-art-sf       { background: radial-gradient(circle at 50% 40%, #fb923c 0%, transparent 60%), linear-gradient(135deg, #831843, #500724); }
.tcard-art-ptx      { background: radial-gradient(circle at 70% 30%, #fcd34d 0%, transparent 55%), linear-gradient(135deg, #064e3b, #052e16); }
.tcard-art-mtl      { background: radial-gradient(circle at 30% 30%, #c084fc 0%, transparent 55%), linear-gradient(135deg, #1e1b4b, #312e81); }
.tcard-art-mxc      { background: radial-gradient(circle at 60% 60%, #f97316 0%, transparent 55%), linear-gradient(135deg, #14532d, #052e16); }

/* ── EMPTY STATE ── */
.empty-state {
  text-align: center;
  padding: var(--space-16) var(--space-6);
  background: var(--color-surface-2);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-xl);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}
.empty-icon {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--color-surface-offset);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-faint);
  margin-bottom: var(--space-2);
}
.empty-state h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--color-text);
}
.empty-state p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* ── SUGGEST ── */
.suggest-section {
  padding: var(--space-16) var(--space-6) var(--space-20);
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
}
.suggest-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: start;
  max-width: var(--content-wide);
  margin: 0 auto;
}
.suggest-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--space-3);
}
.suggest-desc {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: 1.7;
  max-width: 50ch;
}
.suggest-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
}
.suggest-textarea {
  background: var(--color-surface-offset);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-5);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  color: var(--color-text);
  resize: vertical;
  outline: none;
  transition: all var(--t);
}
.suggest-textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--color-primary) 15%, transparent);
}
@media (max-width: 768px) {
  .suggest-card { grid-template-columns: 1fr; gap: var(--space-6); }
}

/* ═══════════════════════
   BLOG ARCHIVE
═══════════════════════ */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--space-5);
}
.bcard {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  text-decoration: none;
  transition: all var(--t);
  display: flex;
  flex-direction: column;
}
.bcard:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: color-mix(in oklab, var(--color-primary) 40%, transparent);
}
.bcard-img {
  height: 180px;
  position: relative;
  overflow: hidden;
}
.bcard-cat {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 1;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 5px 10px;
  border-radius: var(--radius-full);
  background: rgba(0,0,0,.5);
  color: #fff;
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.18);
}
.bcard-cat.news     { background: color-mix(in oklab, #f43f5e 35%, rgba(0,0,0,.5)); border-color: color-mix(in oklab, #f43f5e 50%, transparent); }
.bcard-cat.travel   { background: color-mix(in oklab, #5BCEFA 35%, rgba(0,0,0,.5)); border-color: color-mix(in oklab, #5BCEFA 50%, transparent); }
.bcard-cat.relationships { background: color-mix(in oklab, #f472b6 35%, rgba(0,0,0,.5)); border-color: color-mix(in oklab, #f472b6 50%, transparent); }
.bcard-cat.health   { background: color-mix(in oklab, #34d399 35%, rgba(0,0,0,.5)); border-color: color-mix(in oklab, #34d399 50%, transparent); }
.bcard-cat.community { background: color-mix(in oklab, #a78bfa 35%, rgba(0,0,0,.5)); border-color: color-mix(in oklab, #a78bfa 50%, transparent); }
.bcard-cat.essay    { background: color-mix(in oklab, #fb923c 35%, rgba(0,0,0,.5)); border-color: color-mix(in oklab, #fb923c 50%, transparent); }

.bcard-body {
  padding: var(--space-5) var(--space-6) var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.bcard-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.25;
}
.bcard-excerpt {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
  flex: 1;
}
.bcard-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: var(--space-2);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-divider);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  font-family: 'JetBrains Mono', monospace;
}
.bcard-author {
  display: flex;
  align-items: center;
  gap: 8px;
}
.bcard-avatar {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--trans-blue), var(--trans-pink));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 10px;
  font-weight: 700;
  color: #0f172a;
}

/* Blog featured row */
.blog-featured {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--space-5);
  margin-bottom: var(--space-12);
}
.bfeatured {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border);
  text-decoration: none;
  min-height: 420px;
  display: block;
}
.bfeatured-bg {
  position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 30%, #5BCEFA 0%, transparent 50%),
              radial-gradient(circle at 70% 70%, #F5A9B8 0%, transparent 50%),
              linear-gradient(135deg, #1e1b4b, #0a0a1f);
  transition: transform .6s ease;
}
.bfeatured:hover .bfeatured-bg { transform: scale(1.04); }
.bfeatured-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(8,12,20,.95) 0%, rgba(8,12,20,.5) 50%, rgba(8,12,20,.1) 100%);
}
.bfeatured-content {
  position: relative;
  z-index: 1;
  padding: clamp(1.75rem, 4vw, 3rem);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
  gap: var(--space-3);
}
.bfeatured-cat {
  align-self: flex-start;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--trans-blue);
  background: color-mix(in oklab, var(--trans-blue) 18%, transparent);
  border: 1px solid color-mix(in oklab, var(--trans-blue) 30%, transparent);
  padding: 6px 12px;
  border-radius: var(--radius-full);
}
.bfeatured-title {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3.2vw, 2.4rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.1;
}
.bfeatured-excerpt {
  font-size: var(--text-base);
  color: rgba(255,255,255,.8);
  line-height: 1.6;
  max-width: 56ch;
}
.bfeatured-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  color: rgba(255,255,255,.6);
  font-family: 'JetBrains Mono', monospace;
  margin-top: var(--space-2);
}

.blog-side {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.bside-header {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}
.bside-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.bside-item {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-lg);
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  text-decoration: none;
  transition: all var(--t);
}
.bside-item:hover {
  border-color: color-mix(in oklab, var(--color-primary) 40%, transparent);
  transform: translateX(2px);
}
.bside-num {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-text-faint);
  width: 32px;
  flex-shrink: 0;
  line-height: 1;
}
.bside-text { display: flex; flex-direction: column; gap: 4px; }
.bside-title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.3;
}
.bside-meta {
  font-size: 10px;
  color: var(--color-text-faint);
  font-family: 'JetBrains Mono', monospace;
  text-transform: uppercase;
  letter-spacing: .06em;
}

@media (max-width: 900px) {
  .blog-featured { grid-template-columns: 1fr; }
  .bfeatured { min-height: 320px; }
}

/* Pagination */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  margin-top: var(--space-12);
  flex-wrap: wrap;
}
.pagination button,
.pagination .page-num {
  width: 38px; height: 38px;
  border-radius: var(--radius-md);
  background: var(--color-surface-offset);
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all var(--t);
  cursor: pointer;
  text-decoration: none;
}
.pagination button:hover:not(:disabled),
.pagination .page-num:hover {
  color: var(--color-text);
  border-color: var(--color-primary);
}
.pagination .page-num.active {
  background: linear-gradient(135deg, var(--trans-blue), var(--trans-pink));
  color: #0f172a;
  border-color: transparent;
}
.pagination button:disabled { opacity: .4; cursor: not-allowed; }

/* Archive year nav (sidebar style) */
.archive-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--space-10);
}
.archive-aside {
  position: sticky;
  top: 140px;
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}
.archive-section h4 {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--color-text-faint);
  margin-bottom: var(--space-3);
}
.archive-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.archive-list button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-muted);
  background: transparent;
  border: 1px solid transparent;
  transition: all var(--t);
  text-align: left;
}
.archive-list button:hover {
  background: var(--color-surface-offset);
  color: var(--color-text);
}
.archive-list button.active {
  background: color-mix(in oklab, var(--color-primary) 12%, transparent);
  color: var(--color-primary);
  border-color: color-mix(in oklab, var(--color-primary) 30%, transparent);
}
.archive-list .count {
  font-size: 10px;
  font-weight: 700;
  color: var(--color-text-faint);
  font-family: 'JetBrains Mono', monospace;
}
.archive-list button.active .count { color: var(--color-primary); }

@media (max-width: 900px) {
  .archive-layout { grid-template-columns: 1fr; }
  .archive-aside { position: static; flex-direction: row; gap: var(--space-4); overflow-x: auto; padding-bottom: 8px; }
  .archive-section { min-width: 220px; flex-shrink: 0; }
}

/* fade-pending hooks for fade-in */
.tcard, .bcard { transition: opacity var(--t), transform var(--t); }
.tcard.is-hidden, .bcard.is-hidden { display: none; }

/* ============================================================
   RESOURCE HUB
   ============================================================ */
.hub-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); margin-top: var(--space-8); padding-top: var(--space-6); border-top: 1px solid var(--color-divider); }
.hub-stat { display: flex; flex-direction: column; gap: 4px; }
.hub-stat-num { font-family: var(--font-display); font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 700; background: linear-gradient(135deg, var(--trans-blue), var(--trans-pink)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; line-height: 1; }
.hub-stat-label { font-size: 11px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--color-text-faint); }
@media (max-width:700px){ .hub-stats { grid-template-columns: repeat(2,1fr); } }

.crisis-banner { background: linear-gradient(90deg, color-mix(in oklab, var(--trans-pink) 14%, transparent), color-mix(in oklab, var(--trans-blue) 14%, transparent)); border-bottom: 1px solid var(--color-border); }
.crisis-banner-inner { display: flex; align-items: center; gap: var(--space-4); padding: var(--space-4) 0; flex-wrap: wrap; }
.crisis-icon { width: 38px; height: 38px; border-radius: 50%; display: flex; align-items: center; justify-content: center; background: var(--color-bg); border: 1px solid var(--color-border); color: var(--trans-pink); flex-shrink: 0; }
.crisis-text { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 240px; }
.crisis-text strong { font-weight: 700; color: var(--color-text); }
.crisis-text span, .crisis-text a { color: var(--color-text-muted); font-size: var(--text-sm); }
.crisis-text a { color: var(--color-primary); font-weight: 600; }
.crisis-cta { font-size: var(--text-sm); font-weight: 600; color: var(--color-primary); white-space: nowrap; }
.crisis-cta:hover { color: var(--color-primary-hover); }

.hub-filter-bar { position: sticky; top: 64px; z-index: 20; background: color-mix(in oklab, var(--color-bg) 92%, transparent); backdrop-filter: blur(12px); border-bottom: 1px solid var(--color-border); }
.hub-filter-inner { display: grid; grid-template-columns: minmax(260px, 360px) 1fr auto; gap: var(--space-4); align-items: center; padding: var(--space-4) 0; }
.hub-search { display: flex; align-items: center; gap: 8px; background: var(--color-surface-offset); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 9px 14px; color: var(--color-text-faint); transition: all var(--t); }
.hub-search:focus-within { border-color: var(--color-primary); box-shadow: 0 0 0 3px color-mix(in oklab, var(--color-primary) 20%, transparent); }
.hub-search input { background: transparent; border: 0; outline: 0; width: 100%; color: var(--color-text); font-size: var(--text-sm); font-family: var(--font-body); }
.hub-cat-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.hub-cat-chips .chip { padding: 7px 12px; border-radius: 999px; font-size: 12px; font-weight: 600; background: var(--color-surface-offset); border: 1px solid var(--color-border); color: var(--color-text-muted); transition: all var(--t); white-space: nowrap; }
.hub-cat-chips .chip:hover { color: var(--color-text); border-color: var(--color-primary); }
.hub-cat-chips .chip.active { background: linear-gradient(135deg, var(--trans-blue), var(--trans-pink)); color: #0f172a; border-color: transparent; }
.hub-meta { display: flex; align-items: center; gap: var(--space-3); font-size: 12px; color: var(--color-text-faint); font-family: 'JetBrains Mono', monospace; white-space: nowrap; }
.link-reset { font-size: 12px; font-weight: 600; color: var(--color-primary); background: transparent; border: 0; cursor: pointer; font-family: 'JetBrains Mono', monospace; }
.link-reset:hover { color: var(--color-primary-hover); }
@media (max-width:1000px){ .hub-filter-inner { grid-template-columns: 1fr; gap: var(--space-3); } }

.hub-main { padding: var(--space-10) 0 var(--space-12); }
.hub-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-4); }
.hub-card { display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-5); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); transition: all var(--t); position: relative; overflow: hidden; }
.hub-card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: linear-gradient(180deg, var(--trans-blue), var(--trans-pink)); opacity: 0; transition: opacity var(--t); }
.hub-card:hover { border-color: color-mix(in oklab, var(--trans-blue) 50%, var(--color-border)); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.hub-card:hover::before { opacity: 1; }
.hub-card.is-featured { background: linear-gradient(180deg, color-mix(in oklab, var(--trans-blue) 5%, var(--color-surface)), var(--color-surface)); border-color: color-mix(in oklab, var(--trans-blue) 30%, var(--color-border)); }
.hub-card-top { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.hub-card-cat { font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--color-text-faint); font-family: 'JetBrains Mono', monospace; }
.hub-card-cat[data-cat="crisis"] { color: var(--trans-pink); }
.hub-card-cat[data-cat="legal"] { color: #a78bfa; }
.hub-card-cat[data-cat="health"] { color: #34d399; }
.hub-card-cat[data-cat="mental"] { color: #fbbf24; }
.hub-card-cat[data-cat="housing"] { color: #fb923c; }
.hub-card-cat[data-cat="docs"] { color: #60a5fa; }
.hub-card-cat[data-cat="employment"] { color: #f472b6; }
.hub-card-cat[data-cat="community"] { color: var(--trans-blue); }
.hub-card-badge { font-size: 10px; font-weight: 700; padding: 3px 8px; border-radius: 999px; background: color-mix(in oklab, var(--trans-blue) 18%, transparent); color: var(--trans-blue); letter-spacing: .04em; }
.hub-card-name { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; line-height: 1.2; color: var(--color-text); }
.hub-card-focus { font-size: var(--text-sm); line-height: 1.5; color: var(--color-text-muted); }
.hub-card-meta { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--color-text-faint); }
.hub-card-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-top: auto; }
.tag-pill { font-size: 10px; font-weight: 600; padding: 3px 8px; border-radius: 999px; background: var(--color-surface-offset); color: var(--color-text-faint); letter-spacing: .02em; }
.hub-card-go { margin-top: var(--space-2); font-size: var(--text-sm); font-weight: 600; color: var(--color-primary); padding-top: var(--space-3); border-top: 1px dashed var(--color-divider); }
.hub-empty { text-align: center; padding: var(--space-12) var(--space-4); color: var(--color-text-muted); }
.hub-empty h3 { font-family: var(--font-display); font-size: var(--text-xl); margin-bottom: 8px; color: var(--color-text); }

.vetting-section { background: var(--color-surface-offset); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.vetting-grid { display: grid; grid-template-columns: minmax(260px, 380px) 1fr; gap: var(--space-10); align-items: start; }
.vetting-text .section-title { margin-top: var(--space-2); }
.vetting-criteria { display: flex; flex-direction: column; gap: var(--space-4); }
.vetting-item { display: grid; grid-template-columns: auto 1fr; gap: var(--space-4); padding: var(--space-5); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); align-items: start; }
.vetting-num { font-family: 'JetBrains Mono', monospace; font-size: 28px; font-weight: 700; background: linear-gradient(135deg, var(--trans-blue), var(--trans-pink)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; line-height: 1; }
.vetting-item h4 { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 600; margin-bottom: 4px; }
.vetting-item p { color: var(--color-text-muted); font-size: var(--text-sm); line-height: 1.5; }
@media (max-width:900px){ .vetting-grid { grid-template-columns: 1fr; gap: var(--space-6); } }

.suggest-section, .promise-section { padding: var(--space-12) 0; }
.suggest-card, .promise-card { text-align: center; max-width: 720px; margin: 0 auto; padding: var(--space-10) var(--space-8); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); position: relative; overflow: hidden; }
.suggest-flag, .promise-flag { display: flex; width: 80px; height: 6px; margin: 0 auto var(--space-5); border-radius: 999px; overflow: hidden; }
.suggest-flag span, .promise-flag span { flex: 1; }
.suggest-card h2, .promise-card h2 { font-family: var(--font-display); font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 700; margin-bottom: var(--space-3); }
.suggest-card p, .promise-card p { color: var(--color-text-muted); margin-bottom: var(--space-6); line-height: 1.6; }
.promise-ctas { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; }

/* ============================================================
   ABOUT US
   ============================================================ */
.about-hero-text .page-title em { font-family: 'DM Serif Display', serif; font-style: italic; background: linear-gradient(135deg, var(--trans-blue), var(--trans-pink)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.about-manifesto { padding: var(--space-12) 0 var(--space-8); }
.manifesto-grid { display: grid; grid-template-columns: 220px 1fr; gap: var(--space-10); align-items: start; }
.manifesto-tag { font-family: 'JetBrains Mono', monospace; font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--color-text-faint); padding-top: 18px; border-top: 2px solid var(--color-text); display: inline-block; }
.lede-quote { font-family: var(--font-display); font-size: clamp(1.4rem, 2.6vw, 1.85rem); line-height: 1.4; font-weight: 400; color: var(--color-text); margin-bottom: var(--space-6); }
.lede-quote em { font-family: 'DM Serif Display', serif; font-style: italic; color: var(--color-primary); }
.manifesto-body p { color: var(--color-text-muted); line-height: 1.7; margin-bottom: var(--space-4); font-size: var(--text-base); }
.manifesto-body strong { color: var(--color-text); font-weight: 600; }
@media (max-width:800px){ .manifesto-grid { grid-template-columns: 1fr; gap: var(--space-5); } }

.values-section { background: var(--color-surface-offset); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.value-card { padding: var(--space-6); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); position: relative; }
.value-num { font-family: 'JetBrains Mono', monospace; font-size: 14px; font-weight: 700; color: var(--color-text-faint); letter-spacing: .1em; margin-bottom: var(--space-4); }
.value-card h3 { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 600; margin-bottom: var(--space-2); }
.value-card p { color: var(--color-text-muted); line-height: 1.6; font-size: var(--text-sm); }
@media (max-width:900px){ .values-grid { grid-template-columns: 1fr; } }

.timeline-section { padding-bottom: var(--space-10); }
.timeline { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0; position: relative; max-width: 760px; }
.tl-item { display: grid; grid-template-columns: 110px 1fr; gap: var(--space-6); padding: var(--space-5) 0; border-bottom: 1px solid var(--color-divider); position: relative; }
.tl-item:last-child { border-bottom: 0; }
.tl-year { font-family: 'JetBrains Mono', monospace; font-size: 14px; font-weight: 700; color: var(--color-text-faint); letter-spacing: .06em; align-self: start; padding-top: 4px; }
.tl-item.is-now .tl-year { color: var(--trans-pink); position: relative; }
.tl-item.is-now .tl-year::after { content: "● NOW"; display: block; font-size: 9px; letter-spacing: .14em; margin-top: 4px; color: var(--trans-pink); }
.tl-body h4 { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 600; margin-bottom: 6px; }
.tl-body p { color: var(--color-text-muted); line-height: 1.6; font-size: var(--text-sm); }

.team-section { background: var(--color-surface-offset); border-top: 1px solid var(--color-border); }
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.team-card { padding: var(--space-6); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.team-portrait { width: 80px; height: 80px; border-radius: 50%; background: repeating-linear-gradient(45deg, color-mix(in oklab, var(--trans-blue) 22%, transparent) 0 8px, color-mix(in oklab, var(--trans-pink) 22%, transparent) 8px 16px); border: 1px solid var(--color-border); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 20px; font-weight: 700; color: var(--color-text); margin-bottom: var(--space-4); }
.team-portrait::before { content: attr(data-portrait); background: var(--color-surface); width: 60px; height: 60px; display: flex; align-items: center; justify-content: center; border-radius: 50%; }
.team-card h3 { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 600; }
.team-role { display: block; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--color-text-faint); margin: 4px 0 var(--space-3); }
.team-card p { color: var(--color-text-muted); line-height: 1.6; font-size: var(--text-sm); margin-bottom: var(--space-3); }
.team-card p a { color: var(--color-primary); }
.team-socials { display: flex; gap: var(--space-3); }
.team-socials a { font-size: 12px; font-weight: 600; color: var(--color-text); }
.team-socials a:hover { color: var(--color-primary); }
@media (max-width:900px){ .team-grid { grid-template-columns: 1fr; } }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-section { padding: var(--space-12) 0; }
.contact-grid { display: grid; grid-template-columns: 1.55fr 1fr; gap: var(--space-8); align-items: start; }
.contact-form-card { padding: var(--space-8); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); }
.contact-form-head { margin-bottom: var(--space-6); padding-bottom: var(--space-5); border-bottom: 1px solid var(--color-divider); }
.contact-form-head h2 { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 700; margin-bottom: 6px; }
.contact-form-head p { color: var(--color-text-muted); font-size: var(--text-sm); line-height: 1.5; }
.contact-form-head a { color: var(--color-primary); }
.contact-form { display: flex; flex-direction: column; gap: var(--space-5); }
.form-row { display: flex; flex-direction: column; gap: 8px; }
.form-row > label { font-size: 12px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--color-text-muted); font-family: 'JetBrains Mono', monospace; }
.form-optional { color: var(--color-text-faint); text-transform: none; font-weight: 400; letter-spacing: 0; }
.form-row input[type="text"], .form-row input[type="email"], .form-row textarea { width: 100%; background: var(--color-surface-offset); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 12px 14px; font-family: var(--font-body); font-size: var(--text-base); color: var(--color-text); outline: 0; transition: all var(--t); resize: vertical; }
.form-row input:focus, .form-row textarea:focus { border-color: var(--color-primary); box-shadow: 0 0 0 3px color-mix(in oklab, var(--color-primary) 22%, transparent); }
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.form-help { font-size: 11px; color: var(--color-text-faint); font-family: 'JetBrains Mono', monospace; text-align: right; }
.form-topic-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.topic-pill { cursor: pointer; }
.topic-pill input { display: none; }
.topic-pill span { display: block; text-align: center; padding: 10px 8px; font-size: var(--text-sm); font-weight: 600; background: var(--color-surface-offset); border: 1px solid var(--color-border); border-radius: var(--radius-md); color: var(--color-text-muted); transition: all var(--t); }
.topic-pill input:checked + span { background: linear-gradient(135deg, color-mix(in oklab, var(--trans-blue) 18%, var(--color-surface)), color-mix(in oklab, var(--trans-pink) 18%, var(--color-surface))); border-color: var(--color-primary); color: var(--color-text); }
.form-check { flex-direction: row; align-items: flex-start; gap: 10px; }
.form-check label { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.5; text-transform: none; letter-spacing: 0; font-family: var(--font-body); font-weight: 400; }
.form-check label a { color: var(--color-primary); }
.form-check input[type="checkbox"] { margin-top: 4px; accent-color: var(--color-primary); width: 16px; height: 16px; }
.form-actions { display: flex; align-items: center; gap: var(--space-4); flex-wrap: wrap; padding-top: var(--space-2); }
.form-status { font-size: var(--text-sm); color: var(--color-text-muted); font-family: 'JetBrains Mono', monospace; }
.form-status.ok { color: #34d399; }
.form-status.err { color: var(--trans-pink); }
@media (max-width:600px){ .form-grid-2 { grid-template-columns: 1fr; } .form-topic-grid { grid-template-columns: 1fr 1fr; } }

.contact-side { display: flex; flex-direction: column; gap: var(--space-4); }
.contact-card { padding: var(--space-6); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.contact-eyebrow { display: inline-block; font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--color-text-faint); margin-bottom: 8px; }
.contact-card h3 { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 600; margin-bottom: var(--space-3); }
.contact-email { display: block; font-family: 'JetBrains Mono', monospace; font-size: var(--text-base); font-weight: 600; color: var(--color-primary); word-break: break-all; margin-bottom: var(--space-2); }
.contact-email:hover { color: var(--color-primary-hover); }
.contact-card-note { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.5; }
.contact-social-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.contact-social-list a { display: flex; justify-content: space-between; align-items: center; padding: 10px 12px; border-radius: var(--radius-md); font-size: var(--text-sm); font-weight: 600; color: var(--color-text); transition: all var(--t); }
.contact-social-list a:hover { background: var(--color-surface-offset); color: var(--color-primary); }
.contact-social-list .social-handle { color: var(--color-text-faint); font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 500; }
.contact-card-flag { position: relative; padding-top: var(--space-7); }
.contact-flag-strip { position: absolute; top: 0; left: 0; right: 0; display: flex; height: 4px; border-top-left-radius: var(--radius-lg); border-top-right-radius: var(--radius-lg); overflow: hidden; }
.contact-flag-strip span { flex: 1; }
.contact-card a { color: var(--color-primary); }
@media (max-width:900px){ .contact-grid { grid-template-columns: 1fr; gap: var(--space-6); } }

.contact-faq-section { background: var(--color-surface-offset); border-top: 1px solid var(--color-border); }
.contact-faq { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; gap: var(--space-2); }
.faq-item { padding: var(--space-5); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.faq-item summary { list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between; font-family: var(--font-display); font-size: var(--text-base); font-weight: 600; color: var(--color-text); gap: var(--space-3); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; font-family: 'JetBrains Mono', monospace; font-weight: 400; font-size: 22px; color: var(--color-text-faint); transition: transform var(--t); }
.faq-item[open] summary::after { content: "−"; }
.faq-item p { margin-top: var(--space-3); color: var(--color-text-muted); font-size: var(--text-sm); line-height: 1.6; }

/* ============================================================
   PRIVACY POLICY
   ============================================================ */
.legal-section { padding: var(--space-10) 0 var(--space-12); }
.legal-grid { display: grid; grid-template-columns: 220px 1fr; gap: var(--space-10); align-items: start; }
.legal-toc { position: sticky; top: 88px; }
.legal-toc-inner { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-5); }
.legal-toc-label { display: block; font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--color-text-faint); margin-bottom: var(--space-3); }
.legal-toc ol { list-style: none; padding: 0; margin: 0; counter-reset: toc; display: flex; flex-direction: column; gap: 2px; }
.legal-toc li { counter-increment: toc; }
.legal-toc a { display: block; padding: 6px 8px; border-radius: var(--radius-sm); font-size: var(--text-sm); color: var(--color-text-muted); transition: all var(--t); }
.legal-toc a:hover { background: var(--color-surface-offset); color: var(--color-primary); }
.legal-toc a::before { content: counter(toc, decimal-leading-zero) " "; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--color-text-faint); margin-right: 6px; }
.legal-body { max-width: 720px; }
.legal-body h2 { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; margin: var(--space-8) 0 var(--space-3); color: var(--color-text); scroll-margin-top: 80px; }
.legal-body h2:first-of-type { margin-top: var(--space-6); }
.legal-body p, .legal-body li { color: var(--color-text-muted); font-size: var(--text-base); line-height: 1.7; }
.legal-body p { margin-bottom: var(--space-3); }
.legal-body strong { color: var(--color-text); font-weight: 600; }
.legal-body ul { margin: var(--space-3) 0 var(--space-4); padding-left: var(--space-5); display: flex; flex-direction: column; gap: 8px; }
.legal-body a { color: var(--color-primary); }
.legal-body a:hover { color: var(--color-primary-hover); }
.legal-tldr { padding: var(--space-6); border-radius: var(--radius-lg); background: linear-gradient(135deg, color-mix(in oklab, var(--trans-blue) 10%, var(--color-surface)), color-mix(in oklab, var(--trans-pink) 10%, var(--color-surface))); border: 1px solid color-mix(in oklab, var(--trans-blue) 30%, var(--color-border)); margin-bottom: var(--space-6); scroll-margin-top: 80px; }
.legal-tldr-label { display: inline-block; font-family: 'JetBrains Mono', monospace; font-size: 11px; font-weight: 700; letter-spacing: .14em; color: var(--trans-pink); margin-bottom: var(--space-3); }
.legal-tldr ul { margin: 0; padding-left: var(--space-5); }
.legal-tldr li { color: var(--color-text); }
.legal-sig { margin-top: var(--space-6); padding-top: var(--space-4); border-top: 1px solid var(--color-divider); font-family: 'JetBrains Mono', monospace; font-size: var(--text-sm); color: var(--color-text-faint); }
@media (max-width:900px){ .legal-grid { grid-template-columns: 1fr; gap: var(--space-5); } .legal-toc { position: static; } }
