@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=Epilogue:ital,wght@0,400;0,500;0,600;1,400&family=Space+Mono:wght@400;700&display=swap');

/* Midnight Circuit tokens */
:root {
  --bm-base:    #06070D;
  --bm-surface: #0C0D1A;
  --bm-card:    #111225;
  --bm-border:  #1C1D35;
  --bm-text:    #F0F0F8;
  --bm-muted:   #6B7280;
  --bm-accent:  #6366f1;
  --bm-accent2: #818cf8;
  --bm-green:   #4AFF91;
  --bm-blue:    #4D9FFF;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bm-base);
  color: var(--bm-text);
  font-family: 'Epilogue', system-ui, sans-serif;
  line-height: 1.6;
  min-height: 100vh;
}

/* ── Shared layout ─────────────────────────────── */
.page-wrap {
  max-width: 760px;
  margin: 0 auto;
  padding: 48px 24px;
}

.type-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(99,102,241,0.12);
  color: var(--bm-accent2);
  font-size: 10px;
  font-weight: 700;
  font-family: 'Space Mono', monospace;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 4px;
  margin-bottom: 20px;
}

.entity-tag {
  display: inline-block;
  font-size: 11px;
  padding: 2px 8px;
  border: 1px solid var(--bm-border);
  border-radius: 100px;
  color: var(--bm-muted);
  margin: 3px 4px 3px 0;
}

/* ── Web Page template ────────────────────────── */
.tmpl-webpage .article-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 2.2rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.15;
  margin-bottom: 16px;
}
.tmpl-webpage .article-subtitle {
  font-size: 1.1rem;
  color: #9CA3AF;
  margin-bottom: 36px;
  line-height: 1.6;
}
.tmpl-webpage .article-body {
  font-size: 1rem;
  line-height: 1.8;
  color: #D1D5DB;
}
.tmpl-webpage .article-body p { margin-bottom: 20px; }
.tmpl-webpage .article-body h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.3rem;
  font-weight: 700;
  margin: 32px 0 12px;
  color: var(--bm-text);
}
.tmpl-webpage .article-body h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.1rem;
  font-weight: 600;
  margin: 24px 0 8px;
  color: var(--bm-text);
}
.tmpl-webpage .article-meta {
  display: flex;
  gap: 12px;
  align-items: center;
  font-size: 12px;
  color: var(--bm-muted);
  font-family: 'Space Mono', monospace;
  margin-bottom: 32px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--bm-border);
}

/* ── Newsletter template ──────────────────────── */
.tmpl-newsletter .email-wrap {
  background: #111;
  border: 1px solid var(--bm-border);
  border-radius: 8px;
  overflow: hidden;
}
.tmpl-newsletter .email-header-bar {
  background: var(--bm-surface);
  border-bottom: 1px solid var(--bm-border);
  padding: 12px 20px;
  font-size: 12px;
  color: var(--bm-muted);
  font-family: 'Space Mono', monospace;
}
.tmpl-newsletter .email-header-bar span { color: var(--bm-text); }
.tmpl-newsletter .email-body { padding: 32px 28px; }
.tmpl-newsletter .email-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: 16px;
}
.tmpl-newsletter .email-content { color: #C4C4CF; line-height: 1.8; font-size: 0.95rem; }
.tmpl-newsletter .email-content p { margin-bottom: 16px; }
.tmpl-newsletter .email-footer {
  border-top: 1px solid var(--bm-border);
  padding: 16px 28px;
  font-size: 11px;
  color: var(--bm-muted);
  font-family: 'Space Mono', monospace;
}

/* ── Blog template ────────────────────────────── */
.tmpl-blog .blog-category {
  font-size: 10px;
  font-weight: 700;
  font-family: 'Space Mono', monospace;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bm-accent2);
  margin-bottom: 16px;
}
.tmpl-blog .blog-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 2rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.2;
  margin-bottom: 12px;
}
.tmpl-blog .blog-meta {
  font-size: 12px;
  color: var(--bm-muted);
  font-family: 'Space Mono', monospace;
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--bm-border);
}
.tmpl-blog .blog-hook {
  font-size: 1.1rem;
  color: #9CA3AF;
  margin-bottom: 28px;
  font-style: italic;
  line-height: 1.7;
}
.tmpl-blog .blog-body { color: #D1D5DB; line-height: 1.85; font-size: 1rem; }
.tmpl-blog .blog-body p { margin-bottom: 20px; }
.tmpl-blog .blog-tags { margin-top: 36px; padding-top: 24px; border-top: 1px solid var(--bm-border); }

/* ── Social Post template ─────────────────────── */
.tmpl-social .social-card {
  background: var(--bm-card);
  border: 1px solid var(--bm-border);
  border-radius: 12px;
  overflow: hidden;
  max-width: 480px;
  margin: 0 auto;
}
.tmpl-social .social-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px;
  border-bottom: 1px solid var(--bm-border);
}
.tmpl-social .social-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--bm-accent), var(--bm-blue));
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 16px;
  color: white;
  font-family: 'Plus Jakarta Sans', sans-serif;
  flex-shrink: 0;
}
.tmpl-social .social-name {
  font-weight: 600;
  font-size: 14px;
}
.tmpl-social .social-handle {
  font-size: 12px;
  color: var(--bm-muted);
  font-family: 'Space Mono', monospace;
}
.tmpl-social .social-body {
  padding: 20px;
  font-size: 1rem;
  line-height: 1.7;
  color: #E5E7EB;
}
.tmpl-social .social-body p { margin-bottom: 14px; }
.tmpl-social .social-footer {
  display: flex;
  gap: 20px;
  padding: 12px 20px;
  border-top: 1px solid var(--bm-border);
  font-size: 13px;
  color: var(--bm-muted);
}

/* ── Podcast template ─────────────────────────── */
.tmpl-podcast .pod-header {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  margin-bottom: 32px;
}
.tmpl-podcast .pod-art {
  width: 100px;
  height: 100px;
  flex-shrink: 0;
  background: linear-gradient(135deg, #1e1b4b, #312e81);
  border-radius: 12px;
  border: 1px solid var(--bm-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
}
.tmpl-podcast .pod-ep-label {
  font-size: 10px;
  font-family: 'Space Mono', monospace;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bm-accent2);
  margin-bottom: 8px;
}
.tmpl-podcast .pod-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.25;
  margin-bottom: 8px;
}
.tmpl-podcast .pod-meta {
  font-size: 12px;
  color: var(--bm-muted);
  font-family: 'Space Mono', monospace;
}
.tmpl-podcast .pod-play {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--bm-card);
  border: 1px solid var(--bm-border);
  border-radius: 8px;
  padding: 14px 18px;
  margin-bottom: 28px;
}
.tmpl-podcast .pod-play-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--bm-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.tmpl-podcast .pod-play-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--bm-text);
}
.tmpl-podcast .pod-play-sub {
  font-size: 11px;
  color: var(--bm-muted);
  font-family: 'Space Mono', monospace;
}
.tmpl-podcast .pod-shownotes { color: #C4C4CF; line-height: 1.8; }
.tmpl-podcast .pod-shownotes p { margin-bottom: 16px; }
.tmpl-podcast .pod-shownotes h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  margin: 24px 0 8px;
  color: var(--bm-text);
}

/* ── Index list ───────────────────────────────── */
.index-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 24px;
}
.index-card {
  background: var(--bm-card);
  border: 1px solid var(--bm-border);
  border-radius: 10px;
  padding: 20px;
  text-decoration: none;
  color: var(--bm-text);
  display: block;
  transition: border-color 0.15s;
}
.index-card:hover { border-color: var(--bm-accent); }
.index-card .ic-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}
.index-card .ic-hook { font-size: 0.875rem; color: var(--bm-muted); line-height: 1.5; }

/* ── Error / Loading ──────────────────────────── */
.loading, .error-msg {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  font-family: 'Space Mono', monospace;
  font-size: 13px;
  color: var(--bm-muted);
  flex-direction: column;
  gap: 12px;
}
.spinner {
  width: 24px;
  height: 24px;
  border: 2px solid var(--bm-border);
  border-top-color: var(--bm-accent);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
