/* ============================================================
   Component primitives — Novakid-DS tokens
   Button · Chip · Badge · Card · Stat · Ring · Bento · Banner
   PersonaCard · TeacherCard · LessonCard · StaircaseStep
   ChannelPreview · VocabChip · TimelineBanner · BrandWordmark
   ============================================================ */

/* ---------- Brand wordmark ----------
   Official Novakid wordmark (logo_white.svg, 95×25, single path)
   rendered via CSS mask so `color` controls the fill. Use
   currentColor at the call site to tint it (deep purple in
   topbar, matches text on landing). */
.brand-wordmark {
  display: inline-block;
  width: 95px;
  height: 25px;
  background-color: currentColor;
  -webkit-mask: url('../assets/novakid-wordmark.svg') no-repeat center / contain;
          mask: url('../assets/novakid-wordmark.svg') no-repeat center / contain;
  flex-shrink: 0;
}
.brand-wordmark--lg {
  width: 140px;
  height: 37px;
}

/* ---------- Button ---------- */
.btn {
  --_bg: var(--sds-bg-brand-default);
  --_bg-h: var(--sds-bg-brand-hover);
  --_fg: var(--text-on-brand);
  --_bd: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-6);
  border-radius: var(--radius-pill);
  background: var(--_bg);
  color: var(--_fg);
  border: 1px solid var(--_bd);
  font-weight: var(--font-weight-bold);
  font-size: var(--text-sm);
  line-height: 1;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-standard),
              transform var(--duration-fast) var(--ease-standard),
              box-shadow var(--duration-fast) var(--ease-standard);
  white-space: nowrap;
}

.btn:hover {
  background: var(--_bg-h);
}
.btn:active {
  transform: translateY(1px);
}

.btn--lg {
  padding: var(--space-5) var(--space-7);
  font-size: var(--text-md);
}

.btn--ghost {
  --_bg: transparent;
  --_bg-h: var(--surface-muted);
  --_fg: var(--text-primary);
  --_bd: var(--border-default);
}

.btn--brand-deep {
  --_bg: var(--brand-purple-deep);
  --_bg-h: var(--brand-purple-darker);
  --_fg: var(--text-on-brand);
}

.btn--promo {
  --_bg: var(--brand-yellow);
  --_bg-h: var(--brand-yellow-hover);
  --_fg: var(--brand-purple-deep);
}

.btn--link {
  --_bg: transparent;
  --_bg-h: transparent;
  --_fg: var(--sds-text-brand-default);
  padding: 0;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.btn[aria-pressed="true"] {
  background: var(--brand-purple-deep);
  color: var(--text-on-brand);
}

/* ---------- Chip / Badge ---------- */
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  background: var(--sds-bg-default-secondary);
  color: var(--text-secondary);
  border-radius: var(--radius-pill);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
}

.chip--brand {
  background: var(--sds-bg-brand-tertiary);
  color: var(--sds-text-brand-default);
}
.chip--promo {
  background: var(--sds-bg-promo-tertiary);
  color: var(--sds-text-promo-default);
}
.chip--positive {
  background: var(--sds-bg-positive-tertiary);
  color: var(--sds-text-positive-default);
}
.chip--warning {
  background: var(--sds-bg-warning-tertiary);
  color: var(--sds-text-warning-default);
}
.chip--attention {
  background: var(--state-attention-bg);
  color: var(--state-attention-fg);
}
.chip--ghost {
  background: transparent;
  border: 1px solid var(--border-default);
  color: var(--text-secondary);
}

.badge-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
  box-shadow: 0 0 0 3px color-mix(in oklab, currentColor 18%, transparent);
}

/* ---------- Card ---------- */
.card {
  background: var(--surface-default);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-7);
  display: grid;
  gap: var(--space-5);
  position: relative;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--duration-fast) var(--ease-standard),
              transform var(--duration-fast) var(--ease-standard);
}

.card--raised {
  box-shadow: var(--shadow-md);
}

.card--muted {
  background: var(--surface-muted);
}

.card--brand {
  background: linear-gradient(135deg, var(--sds-bg-brand-tertiary), var(--sds-bg-highlight-tertiary));
  border-color: transparent;
}

.card__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--text-tertiary);
}

.card__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  line-height: var(--leading-snug);
  color: var(--text-primary);
  margin: 0;
  font-weight: var(--font-weight-bold);
}

.card__body {
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}

.card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
  padding-top: var(--space-3);
  border-top: 1px dashed var(--border-default);
}

.card-link {
  color: inherit;
  text-decoration: none;
}
.card-link:hover .card {
  box-shadow: var(--shadow-lg);
  transform: translateY(-1px);
  text-decoration: none;
}

/* ---------- Stat ---------- */
.stat {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-5) var(--space-6);
  border-radius: var(--radius-md);
  background: var(--surface-muted);
}

.stat--inline {
  padding: 0;
  background: transparent;
}

.stat__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

.stat__value {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  line-height: 1;
  color: var(--text-primary);
  font-weight: var(--font-weight-bold);
  font-variant-numeric: tabular-nums;
}

.stat__delta {
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  color: var(--state-positive-fg);
  font-variant-numeric: tabular-nums;
}
.stat__delta--down {
  color: var(--state-attention-fg);
}

/* ---------- Hero block ---------- */
.hero {
  display: grid;
  gap: var(--space-6);
  padding: var(--space-10);
  border-radius: var(--radius-2xl);
  background:
    radial-gradient(800px 400px at 10% 0%, var(--data-lavender-tint) 0%, transparent 60%),
    radial-gradient(600px 300px at 100% 100%, var(--brand-yellow-tint) 0%, transparent 60%),
    var(--surface-default);
  border: 1px solid var(--border-default);
  position: relative;
  overflow: hidden;
}

.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--sds-text-brand-default);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

.hero__narrative {
  font-family: var(--font-display);
  font-size: clamp(24px, 2.6vw, 34px);
  line-height: var(--leading-tight);
  color: var(--brand-purple-deep);
  margin: 0;
  max-width: 32ch;
  font-weight: var(--font-weight-bold);
  letter-spacing: var(--tracking-tight);
}

.hero__narrative em {
  font-style: normal;
  background: linear-gradient(180deg, transparent 62%, var(--brand-yellow) 62%, var(--brand-yellow) 92%, transparent 92%);
  padding: 0 2px;
}

.hero__body {
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
  max-width: 54ch;
  margin: 0;
}

.hero__meta {
  display: flex;
  gap: var(--space-7);
  flex-wrap: wrap;
  padding-top: var(--space-5);
  border-top: 1px dashed var(--border-default);
}

.hero__actions {
  display: inline-flex;
  gap: var(--space-4);
  align-items: center;
}

/* ---------- Bento ---------- */
.bento {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-5);
}

.bento > * {
  grid-column: span 2;
}
.bento > .bento--w3 { grid-column: span 3; }
.bento > .bento--w4 { grid-column: span 4; }
.bento > .bento--w6 { grid-column: span 6; }

@media (max-width: 900px) {
  .bento {
    grid-template-columns: 1fr 1fr;
  }
  .bento > *,
  .bento > .bento--w3,
  .bento > .bento--w4,
  .bento > .bento--w6 {
    grid-column: span 2;
  }
}
@media (max-width: 560px) {
  .bento { grid-template-columns: 1fr; }
  .bento > * { grid-column: span 1 !important; }
}

/* ---------- Ring (skill / progress) ---------- */
.ring {
  --_size: 140px;
  --_stroke: 14px;
  --_pct: 68;
  --_color: var(--brand-purple-cta);
  width: var(--_size);
  height: var(--_size);
  position: relative;
  flex-shrink: 0;
}
.ring svg {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}
.ring__track {
  fill: none;
  stroke: var(--surface-muted);
  stroke-width: var(--_stroke);
}
.ring__indicator {
  fill: none;
  stroke: var(--_color);
  stroke-width: var(--_stroke);
  stroke-linecap: round;
  transition: stroke-dasharray var(--duration-slow) var(--ease-emphasize);
}
.ring__label {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  text-align: center;
  line-height: 1.1;
}
.ring__label strong {
  display: block;
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.ring__label small {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

/* ---------- Banner (plateau, milestone) ---------- */
.banner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-7);
  padding: var(--space-6) var(--space-7);
  border-radius: var(--radius-lg);
  border: 1px solid;
  background: var(--surface-muted);
}

.banner--attention {
  background: var(--state-attention-bg);
  border-color: color-mix(in oklab, var(--state-attention-fg) 30%, transparent);
  color: var(--state-attention-fg);
}

.banner--positive {
  background: var(--state-positive-bg);
  border-color: color-mix(in oklab, var(--state-positive-fg) 25%, transparent);
  color: var(--state-positive-fg);
}

.banner--promo {
  background: linear-gradient(135deg, var(--brand-yellow-tint), var(--brand-yellow-soft));
  border-color: color-mix(in oklab, var(--brand-yellow) 40%, transparent);
  color: var(--brand-purple-deep);
}

.banner__icon {
  font-size: 28px;
}

.banner__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  margin: 0;
  font-weight: var(--font-weight-bold);
}

.banner__body {
  font-size: var(--text-sm);
  margin: var(--space-2) 0 0;
  opacity: 0.85;
}

/* ---------- Persona card ---------- */
.persona-card {
  display: grid;
  gap: var(--space-5);
  padding: var(--space-7);
  background: var(--surface-default);
  border: 2px solid var(--border-default);
  border-radius: var(--radius-xl);
  text-align: left;
  cursor: pointer;
  transition: border-color var(--duration-fast) var(--ease-standard),
              transform var(--duration-fast) var(--ease-standard),
              box-shadow var(--duration-medium) var(--ease-standard);
  position: relative;
  overflow: hidden;
}

.persona-card::before {
  content: "";
  position: absolute;
  top: -40%;
  right: -20%;
  width: 200px; height: 200px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--_accent, var(--data-lavender-soft)), transparent 70%);
  opacity: 0.5;
  pointer-events: none;
  transition: opacity var(--duration-medium) var(--ease-standard);
}

.persona-card:hover {
  transform: translateY(-2px);
  border-color: var(--brand-purple-cta);
  box-shadow: var(--shadow-lg);
}
.persona-card:hover::before {
  opacity: 0.9;
}

.persona-card[data-persona="reassurance"] { --_accent: var(--brand-yellow-soft); }
.persona-card[data-persona="auditor"]     { --_accent: var(--data-lavender-soft); }
.persona-card[data-persona="investor"]    { --_accent: var(--data-sage); }

.persona-card__id {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

.persona-card__name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  margin: 0;
  color: var(--brand-purple-deep);
  font-weight: var(--font-weight-bold);
}

.persona-card__quote {
  font-style: italic;
  color: var(--text-primary);
  border-left: 2px solid var(--brand-purple-cta);
  padding-left: var(--space-4);
  line-height: var(--leading-relaxed);
}

.persona-card__meta {
  display: inline-flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}

.persona-card__cta {
  margin-top: var(--space-3);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: var(--font-weight-bold);
  color: var(--sds-text-brand-default);
}
.persona-card__cta::after {
  content: "→";
  transition: transform var(--duration-fast) var(--ease-standard);
}
.persona-card:hover .persona-card__cta::after {
  transform: translateX(4px);
}

/* ---------- Market card (landing) ---------- */
.market-card {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-7);
  background: var(--surface-default);
  border: 2px solid var(--border-default);
  border-radius: var(--radius-xl);
  text-align: left;
  cursor: pointer;
  transition: border-color var(--duration-fast) var(--ease-standard),
              transform var(--duration-fast) var(--ease-standard),
              box-shadow var(--duration-medium) var(--ease-standard);
  position: relative;
  overflow: hidden;
}
.market-card::before {
  content: "";
  position: absolute;
  top: -40%;
  right: -20%;
  width: 220px; height: 220px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--_accent, var(--data-lavender-soft)), transparent 70%);
  opacity: 0.55;
  pointer-events: none;
  transition: opacity var(--duration-medium) var(--ease-standard);
}
.market-card[data-market="ru"] { --_accent: #dfe9f0; }
.market-card[data-market="tr"] { --_accent: var(--brand-yellow-soft); }
.market-card[data-market="it"] { --_accent: var(--data-mint); }
.market-card[data-market="pl"] { --_accent: var(--data-lavender-soft); }
.market-card[data-market="es"] { --_accent: var(--data-coral); }

.market-card:hover {
  transform: translateY(-2px);
  border-color: var(--brand-purple-cta);
  box-shadow: var(--shadow-lg);
}
.market-card:hover::before { opacity: 0.95; }

.market-card__flag {
  font-size: 44px;
  line-height: 1;
  position: relative;
}

.market-card__meta { display: grid; gap: 2px; position: relative; }

.market-card__id {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

.market-card__name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  margin: 0;
  color: var(--brand-purple-deep);
  font-weight: var(--font-weight-bold);
}

.market-card__align {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin: 2px 0 0;
}

.market-card__hints {
  display: inline-flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  position: relative;
}

.market-card__sample {
  font-style: italic;
  color: var(--text-primary);
  border-left: 2px solid var(--brand-purple-cta);
  padding-left: var(--space-4);
  line-height: var(--leading-relaxed);
  font-size: var(--text-sm);
  margin: 0;
  position: relative;
}

.market-card__cta {
  margin-top: var(--space-2);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: var(--font-weight-bold);
  color: var(--sds-text-brand-default);
  position: relative;
}
.market-card__cta::after {
  content: "→";
  transition: transform var(--duration-fast) var(--ease-standard);
}
.market-card:hover .market-card__cta::after { transform: translateX(4px); }

/* ---------- Teacher card ---------- */
.teacher {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-5);
  align-items: start;
}

.teacher__avatar {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand-purple-cta), var(--data-lavender));
  display: inline-grid;
  place-items: center;
  color: var(--text-on-brand);
  font-family: var(--font-display);
  font-weight: var(--font-weight-bold);
  font-size: var(--text-lg);
  flex-shrink: 0;
}

.teacher__name {
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  font-size: var(--text-md);
  margin: 0;
}

.teacher__meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  letter-spacing: var(--tracking-wide);
  margin-top: 2px;
}

.teacher__note {
  margin-top: var(--space-4);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
  font-style: italic;
}

.teacher__quote-open {
  font-family: var(--font-display);
  color: var(--brand-purple-cta);
  font-size: var(--text-xl);
  line-height: 0;
  vertical-align: -12px;
  margin-right: var(--space-2);
}

/* ---------- Lesson card ---------- */
.lesson-card {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--space-5);
  align-items: center;
  padding: var(--space-5) var(--space-6);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  background: var(--surface-default);
}
.lesson-card + .lesson-card { margin-top: var(--space-3); }

.lesson-card__num {
  width: 44px; height: 44px;
  display: inline-grid;
  place-items: center;
  background: var(--sds-bg-brand-tertiary);
  color: var(--sds-text-brand-default);
  border-radius: 50%;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-bold);
  font-variant-numeric: tabular-nums;
}

.lesson-card__title {
  font-size: var(--text-sm);
  margin: 0;
  color: var(--text-primary);
  font-weight: var(--font-weight-bold);
}
.lesson-card__meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin-top: 2px;
}

/* ---------- Vocabulary chips ---------- */
.vocab {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.vocab__chip {
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-pill);
  background: var(--sds-bg-brand-tertiary);
  color: var(--sds-text-brand-default);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
}
.vocab__chip--new {
  background: var(--sds-bg-promo-tertiary);
  color: var(--sds-text-promo-default);
  border: 1px solid var(--sds-border-promo-default);
}

/* ---------- Staircase ---------- */
.staircase {
  display: grid;
  gap: 0;
}

.staircase__step {
  display: grid;
  grid-template-columns: 72px 1fr auto;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-6);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  background: var(--surface-default);
  position: relative;
  transition: transform var(--duration-fast) var(--ease-standard);
}

.staircase__step + .staircase__step {
  margin-top: var(--space-5);
}

.staircase__step[data-state="done"] {
  background: var(--sds-bg-positive-tertiary);
  border-color: var(--sds-border-positive-default);
}
.staircase__step[data-state="current"] {
  background: linear-gradient(90deg, var(--brand-yellow-tint), var(--sds-bg-brand-tertiary));
  border-color: var(--brand-purple-cta);
  box-shadow: var(--shadow-md);
}
.staircase__step[data-state="current"]::before {
  content: "YOU ARE HERE";
  position: absolute;
  top: -12px; left: var(--space-5);
  background: var(--brand-purple-deep);
  color: var(--text-on-brand);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: var(--tracking-wide);
  padding: 4px 8px;
  border-radius: var(--radius-xs);
}

.staircase__step[data-state="upcoming"] {
  opacity: 0.7;
}

.staircase__level {
  display: inline-grid;
  place-items: center;
  width: 56px; height: 56px;
  border-radius: var(--radius-md);
  font-family: var(--font-display);
  font-weight: var(--font-weight-bold);
  font-size: var(--text-md);
  background: var(--sds-bg-brand-secondary);
  color: var(--brand-purple-deep);
}
.staircase__step[data-state="done"] .staircase__level {
  background: var(--sds-bg-positive-secondary);
  color: var(--state-positive-strong);
}

.staircase__label {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  margin: 0;
}
.staircase__detail {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: var(--space-2) 0 0;
  line-height: var(--leading-relaxed);
}
.staircase__can-do {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-4);
}

/* ---------- Channel preview (Weekly Digest) ---------- */
.channels {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-7);
  align-items: start;
}

@media (max-width: 1040px) {
  .channels { grid-template-columns: 1fr; }
}

.channel {
  background: var(--surface-default);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  display: grid;
  grid-template-rows: auto 1fr;
  position: relative;
}

.channel__frame {
  padding: var(--space-4) var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  border-bottom: 1px solid var(--border-default);
  display: flex;
  justify-content: space-between;
  align-items: center;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

.channel__frame strong {
  color: var(--text-primary);
  text-transform: none;
  letter-spacing: 0;
  font-family: var(--font-body);
  font-size: var(--text-sm);
}

.channel__body { padding: var(--space-6); }

/* WhatsApp-ish */
.channel--whatsapp .channel__body {
  background: #ece5dd;
}
.channel--whatsapp .channel__bubble {
  background: #fff;
  border-radius: 14px 14px 14px 4px;
  padding: var(--space-5);
  box-shadow: 0 1px 0.5px rgba(0,0,0,0.13);
  max-width: 90%;
}
.channel--whatsapp .channel__unfurl {
  background: #f6f6f6;
  border-left: 3px solid #25D366;
  border-radius: 6px;
  padding: var(--space-4);
  margin-top: var(--space-4);
  font-size: var(--text-sm);
}

/* Email */
.channel--email .channel__body {
  background: #fafafa;
  padding: var(--space-7);
}
.channel--email .channel__subject {
  font-family: var(--font-display);
  font-weight: var(--font-weight-bold);
  font-size: var(--text-lg);
  margin: 0 0 var(--space-2);
  color: var(--text-primary);
}
.channel--email .channel__from {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin-bottom: var(--space-5);
}

/* Telegram */
.channel--telegram .channel__body {
  background: #dfe9f0;
}
.channel--telegram .channel__bubble {
  background: #eff7fd;
  border-radius: 14px 14px 4px 14px;
  padding: var(--space-5);
  margin-left: auto;
  max-width: 94%;
}

/* ---------- Timeline banner (story header) ---------- */
.story-header {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--border-default);
}

.story-header h1 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  line-height: var(--leading-tight);
  color: var(--brand-purple-deep);
  margin: 0;
  font-weight: var(--font-weight-bold);
  letter-spacing: var(--tracking-tight);
}

.story-header p {
  margin: 0;
  font-size: var(--text-lg);
  color: var(--text-secondary);
  max-width: 64ch;
  line-height: var(--leading-relaxed);
}

/* ---------- Explorations panel (alt concepts) ---------- */
.explorations {
  margin-top: var(--space-12);
  padding: var(--space-7);
  background: var(--surface-default);
  border: 1px dashed var(--border-default);
  border-radius: var(--radius-lg);
}

.explorations__title {
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin: 0 0 var(--space-5);
}

.explorations__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-5);
}

.exploration {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-5);
  background: var(--surface-muted);
  border-radius: var(--radius-md);
}
.exploration__name {
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  font-size: var(--text-sm);
}
.exploration__line {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}

/* ---------- Dense list ---------- */
.dense-list { margin: 0; padding: 0; list-style: none; display: grid; gap: var(--space-2); }
.dense-list li {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--space-4);
  align-items: baseline;
  padding: var(--space-3) 0;
  border-bottom: 1px dashed var(--border-default);
}
.dense-list li:last-child { border-bottom: none; }
.dense-list__tag {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}
.dense-list__value { color: var(--text-primary); }
.dense-list__meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  font-variant-numeric: tabular-nums;
}
