/* ==========================================================
   TATTVAS — Contemplative Reader
   Built on base.css tokens. Parallel idiom to kshetrajna.css
   but with distinct .tattva-* classes.
   ========================================================== */

/* ---- view shell ---- */
.tattva-view {
  min-height: 100dvh;
  padding: var(--space-12) var(--space-6) var(--space-24);
  position: relative;
  z-index: 1;
}
@media (max-width: 480px) {
  .tattva-view { padding: var(--space-6) var(--space-4) var(--space-20); }
}

@media (min-width: 768px) {
  .tattva-view { padding: var(--space-20) var(--space-8) var(--space-32); }
}

.tattva-shell { max-width: 40rem; margin: 0 auto; }

/* ============================================================
   LANDING
   ============================================================ */
.tattva-landing { text-align: center; }

.tattva-landing__crown {
  font-family: var(--font-sanskrit);
  font-size: var(--text-3xl);
  color: var(--color-ruby-deep);
  margin-bottom: var(--space-3);
  line-height: 1.2;
  letter-spacing: 0.02em;
}
[data-theme="dark"] .tattva-landing__crown { color: var(--color-gold); }

.tattva-landing__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-style: italic;
  color: var(--color-text-muted);
  font-weight: 400;
  letter-spacing: 0.04em;
  margin-bottom: var(--space-12);
}

.tattva-invocation {
  margin: var(--space-12) auto var(--space-10);
  padding: var(--space-6);
  max-width: 40rem;
  border-top: 1px solid var(--color-divider);
  border-bottom: 1px solid var(--color-divider);
  text-align: left;
}
.tattva-invocation__label {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-gold-deep);
  text-align: center;
  margin-bottom: var(--space-6);
}
[data-theme="dark"] .tattva-invocation__label { color: var(--color-gold); }
.tattva-invocation__note {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--color-text-faint);
  margin-top: var(--space-4);
  text-align: center;
  font-style: italic;
}

.tattva-typology {
  margin: var(--space-10) auto;
  padding: var(--space-5) var(--space-6);
  background: var(--color-surface-2);
  border-left: 3px solid var(--color-gold-deep);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  max-width: 40rem;
}
[data-theme="dark"] .tattva-typology { border-left-color: var(--color-gold); }
.tattva-typology__title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-gold-deep);
  margin-bottom: var(--space-3);
  text-align: center;
}
[data-theme="dark"] .tattva-typology__title { color: var(--color-gold); }
.tattva-typology__body {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--color-text);
  margin-top: var(--space-3);
}

/* TOC */
.tattva-toc { list-style: none; padding: 0; margin: var(--space-10) auto 0; max-width: 40rem; }
.tattva-toc__item {
  display: block;
  width: 100%;
  text-align: left;
  padding: var(--space-6) 0;
  border-bottom: 1px solid var(--color-divider);
  cursor: pointer;
  transition: background var(--transition-interactive);
  background: none;
  border-left: none;
  border-right: none;
  border-top: none;
  color: inherit;
}
.tattva-toc__item:first-child { border-top: 1px solid var(--color-divider); }
.tattva-toc__item:hover { background: rgba(184, 134, 11, 0.06); }
[data-theme="dark"] .tattva-toc__item:hover { background: rgba(240, 215, 127, 0.05); }
.tattva-toc__roman {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  letter-spacing: 0.2em;
  color: var(--color-gold-deep);
  margin-bottom: var(--space-2);
  display: block;
}
[data-theme="dark"] .tattva-toc__roman { color: var(--color-gold); }
.tattva-toc__sanskrit {
  font-family: var(--font-sanskrit);
  font-size: var(--text-xl);
  color: var(--color-ruby-deep);
  line-height: 1.4;
  margin-bottom: var(--space-1);
}
[data-theme="dark"] .tattva-toc__sanskrit { color: var(--color-gold-bright); }
.tattva-toc__english {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}
.tattva-toc__anchor {
  font-family: var(--font-body);
  font-style: italic;
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  letter-spacing: 0.05em;
  margin-bottom: var(--space-3);
}
.tattva-toc__teaser {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.65;
  color: var(--color-text-muted);
}

/* ============================================================
   SECTION HEAD
   ============================================================ */
.tattva-section-head {
  text-align: center;
  margin-bottom: var(--space-12);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-divider);
}
.tattva-section-head__roman {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  letter-spacing: 0.3em;
  color: var(--color-gold-deep);
  margin-bottom: var(--space-4);
}
[data-theme="dark"] .tattva-section-head__roman { color: var(--color-gold); }
.tattva-section-head__sanskrit {
  font-family: var(--font-sanskrit);
  font-size: var(--text-3xl);
  color: var(--color-ruby-deep);
  line-height: 1.2;
  margin-bottom: var(--space-3);
}
[data-theme="dark"] .tattva-section-head__sanskrit { color: var(--color-gold-bright); }
.tattva-section-head__english {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-style: italic;
  color: var(--color-text);
  margin-bottom: var(--space-3);
  font-weight: 400;
}
.tattva-section-head__anchor {
  font-family: var(--font-body);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-text-faint);
  letter-spacing: 0.05em;
}

.tattva-opening {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: 1.75;
  color: var(--color-text);
  margin-bottom: var(--space-10);
  font-style: italic;
  border-left: 2px solid var(--color-gold-deep);
  padding-left: var(--space-5);
}
[data-theme="dark"] .tattva-opening { border-left-color: var(--color-gold); }

.tattva-bridge {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--color-text-muted);
  margin: var(--space-8) 0;
  font-style: italic;
}

.tattva-closing {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  line-height: 1.7;
  color: var(--color-text);
  margin: var(--space-12) auto var(--space-6);
  text-align: center;
  font-style: italic;
  max-width: 32rem;
}

.tattva-h2 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-style: italic;
  color: var(--color-ruby-deep);
  text-align: center;
  margin: var(--space-12) 0 var(--space-6);
  font-weight: 400;
}
[data-theme="dark"] .tattva-h2 { color: var(--color-gold-bright); }
.tattva-h3 {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-style: italic;
  letter-spacing: 0.05em;
  color: var(--color-purple);
  margin: var(--space-6) 0 var(--space-3);
  font-weight: 400;
}
[data-theme="dark"] .tattva-h3 { color: var(--color-purple-soft); }

/* ============================================================
   VERSE
   ============================================================ */
.tattva-verse {
  margin: var(--space-8) 0;
  padding: var(--space-2) 0;
}
.tattva-verse__ref {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  letter-spacing: 0.1em;
  color: var(--color-gold-deep);
  margin-bottom: var(--space-3);
  text-transform: uppercase;
}
[data-theme="dark"] .tattva-verse__ref { color: var(--color-gold); }
.tattva-verse__devanagari {
  font-family: var(--font-sanskrit);
  font-size: var(--text-sanskrit-large);
  line-height: 1.85;
  color: var(--color-text);
  margin-bottom: var(--space-4);
  white-space: pre-line;
  letter-spacing: 0.01em;
}
.tattva-verse__iast {
  font-family: var(--font-iast);
  font-style: italic;
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--color-ruby-deep);
  margin-bottom: var(--space-4);
  white-space: pre-line;
}
[data-theme="dark"] .tattva-verse__iast { color: var(--color-ruby-soft); }
.tattva-verse__trans {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--color-text);
  font-style: italic;
}

/* ============================================================
   CONTEMPLATION
   ============================================================ */
.tattva-contemplation {
  margin: var(--space-16) auto var(--space-8);
  padding: var(--space-6) var(--space-6);
  max-width: 32rem;
  text-align: center;
}
.tattva-contemplation::before,
.tattva-contemplation::after {
  content: '✦';
  display: block;
  color: var(--color-gold-deep);
  font-size: var(--text-lg);
  margin: var(--space-3) 0;
}
[data-theme="dark"] .tattva-contemplation::before,
[data-theme="dark"] .tattva-contemplation::after { color: var(--color-gold); }
.tattva-contemplation__text {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  line-height: 1.7;
  color: var(--color-text);
  font-style: italic;
}

/* ============================================================
   I. TWO ROOTS — paired layout
   ============================================================ */
.tattva-roots-pair {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin: var(--space-8) 0;
}
@media (min-width: 720px) {
  .tattva-roots-pair { grid-template-columns: 1fr 1fr; }
}
.tattva-root {
  padding: var(--space-6);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  background: var(--color-surface-2);
}
.tattva-root__head { text-align: center; margin-bottom: var(--space-4); }
.tattva-root__sanskrit {
  font-family: var(--font-sanskrit);
  font-size: var(--text-2xl);
  color: var(--color-ruby-deep);
  line-height: 1.3;
}
[data-theme="dark"] .tattva-root__sanskrit { color: var(--color-gold-bright); }
.tattva-root__label {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-style: italic;
  color: var(--color-text);
  margin-top: var(--space-1);
}
.tattva-root__iast {
  font-family: var(--font-iast);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-text-faint);
}
.tattva-root__gloss {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-text);
  text-align: center;
  margin: var(--space-3) 0;
  font-style: italic;
}
.tattva-root__qualities {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-align: center;
  padding: var(--space-2) 0;
  border-top: 1px dashed var(--color-divider);
  border-bottom: 1px dashed var(--color-divider);
  margin-bottom: var(--space-4);
}
.tattva-root__parallel-label {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xs);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-purple);
  margin-top: var(--space-4);
  text-align: center;
}
[data-theme="dark"] .tattva-root__parallel-label { color: var(--color-purple-soft); }
.tattva-root__note {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--color-text-muted);
  font-style: italic;
  margin: var(--space-4) 0;
}
.tattva-root__pointer {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--color-purple);
  text-align: center;
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px dashed var(--color-divider);
}
[data-theme="dark"] .tattva-root__pointer { color: var(--color-purple-soft); }

/* ============================================================
   II. FIRST UNFOLDING — evolutes
   ============================================================ */
.tattva-evolute {
  margin: var(--space-10) 0;
  padding: var(--space-6) 0;
  border-top: 1px solid var(--color-divider);
}
.tattva-evolute__head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-2);
}
.tattva-evolute__sanskrit {
  font-family: var(--font-sanskrit);
  font-size: var(--text-2xl);
  color: var(--color-ruby-deep);
  line-height: 1.3;
}
[data-theme="dark"] .tattva-evolute__sanskrit { color: var(--color-gold-bright); }
.tattva-evolute__label {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--color-text);
}
.tattva-evolute__iast {
  font-family: var(--font-iast);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-text-faint);
}
.tattva-evolute__gloss {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-text-muted);
  font-style: italic;
  margin: var(--space-2) 0;
}
.tattva-evolute__lineage {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: var(--space-3) 0;
  padding: var(--space-2) var(--space-4);
  background: var(--color-surface-2);
  border-radius: var(--radius-md);
}
.tattva-evolute__from,
.tattva-evolute__to {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-gold-deep);
}
[data-theme="dark"] .tattva-evolute__from,
[data-theme="dark"] .tattva-evolute__to { color: var(--color-gold); }
.tattva-evolute__pointer {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--color-purple);
  padding: var(--space-3) var(--space-4);
  border-top: 1px dashed var(--color-divider);
  border-bottom: 1px dashed var(--color-divider);
  margin-top: var(--space-5);
  text-align: center;
}
[data-theme="dark"] .tattva-evolute__pointer { color: var(--color-purple-soft); }

.tattva-streams {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  margin: var(--space-5) 0;
}
@media (min-width: 640px) {
  .tattva-streams { grid-template-columns: repeat(3, 1fr); }
}
.tattva-stream {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  background: var(--color-surface-2);
  border: 1px solid var(--color-divider);
  text-align: center;
}
.tattva-stream--sāttvika { border-color: var(--color-gold-deep); }
.tattva-stream--rājasa   { border-color: var(--color-ruby-deep); }
.tattva-stream--tāmasa   { border-color: var(--color-purple); }
[data-theme="dark"] .tattva-stream--sāttvika { border-color: var(--color-gold); }
[data-theme="dark"] .tattva-stream--rājasa   { border-color: var(--color-ruby-soft); }
[data-theme="dark"] .tattva-stream--tāmasa   { border-color: var(--color-purple-soft); }
.tattva-stream__name {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--color-text);
  margin-bottom: var(--space-1);
}
.tattva-stream__mode {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-gold-deep);
  margin-bottom: var(--space-2);
}
[data-theme="dark"] .tattva-stream__mode { color: var(--color-gold); }
.tattva-stream__produces {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--color-text-muted);
}

/* ============================================================
   III. & IV. ELEMENTS — tanmātras and mahābhūtas
   ============================================================ */
.tattva-elements {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  margin: var(--space-8) 0;
}
.tattva-element {
  display: grid;
  grid-template-columns: 3rem 1fr;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--color-surface-2);
  border-radius: var(--radius-lg);
  border-left: 3px solid var(--color-gold-deep);
}
[data-theme="dark"] .tattva-element { border-left-color: var(--color-gold); }
.tattva-element--gross { border-left-color: var(--color-ruby-deep); }
[data-theme="dark"] .tattva-element--gross {
  border-left-color: var(--color-ruby);
  background: var(--color-surface);
}
[data-theme="dark"] .tattva-element {
  background: var(--color-surface);
}
[data-theme="dark"] .tattva-element--gross { border-left-color: var(--color-ruby-soft); }
.tattva-element__index {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-2xl);
  color: var(--color-gold-deep);
  line-height: 1;
  text-align: center;
}
[data-theme="dark"] .tattva-element__index { color: var(--color-gold); }
.tattva-element__body {}
.tattva-element__head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-2);
}
.tattva-element__sanskrit {
  font-family: var(--font-sanskrit);
  font-size: var(--text-xl);
  color: var(--color-ruby-deep);
}
[data-theme="dark"] .tattva-element__sanskrit { color: var(--color-gold-bright); }
.tattva-element__iast {
  font-family: var(--font-iast);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--color-text-muted);
}
.tattva-element__english {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--color-text);
}
.tattva-element__quality,
.tattva-element__source,
.tattva-element__qualities-list,
.tattva-element__body-correlate {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--color-text);
  margin: var(--space-2) 0;
}
.tattva-element__arrow {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-purple);
  margin: var(--space-2) 0;
}
[data-theme="dark"] .tattva-element__arrow { color: var(--color-purple-soft); }
.tattva-element__anchor {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  color: var(--color-gold-deep);
  margin-top: var(--space-2);
}
[data-theme="dark"] .tattva-element__anchor { color: var(--color-gold); }
.tattva-element__pointer {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--color-purple);
  margin-top: var(--space-3);
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-divider);
}
[data-theme="dark"] .tattva-element__pointer { color: var(--color-purple-soft); }

/* ============================================================
   V. FACULTIES — manas + senses
   ============================================================ */
.tattva-manas {
  margin: var(--space-10) 0;
  padding: var(--space-6);
  background: var(--color-surface-2);
  border-radius: var(--radius-lg);
  border-top: 2px solid var(--color-gold-deep);
}
[data-theme="dark"] .tattva-manas { border-top-color: var(--color-gold); }
.tattva-manas__head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}
.tattva-manas__sanskrit {
  font-family: var(--font-sanskrit);
  font-size: var(--text-2xl);
  color: var(--color-ruby-deep);
}
[data-theme="dark"] .tattva-manas__sanskrit { color: var(--color-gold-bright); }
.tattva-manas__label {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--color-text);
}
.tattva-manas__iast {
  font-family: var(--font-iast);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-text-faint);
}
.tattva-manas__gloss {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-style: italic;
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}
.tattva-manas__pointer {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--color-purple);
  padding: var(--space-3);
  text-align: center;
  border-top: 1px dashed var(--color-divider);
  margin-top: var(--space-4);
}
[data-theme="dark"] .tattva-manas__pointer { color: var(--color-purple-soft); }

.tattva-senses {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  margin: var(--space-6) 0;
}
@media (min-width: 720px) {
  .tattva-senses { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .tattva-senses { grid-template-columns: repeat(5, 1fr); }
}
.tattva-sense {
  padding: var(--space-4);
  background: var(--color-surface-2);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-divider);
  text-align: center;
}
.tattva-sense--action { border-color: var(--color-orange); }
[data-theme="dark"] .tattva-sense--action { border-color: var(--color-orange-soft); }
.tattva-sense__sanskrit {
  font-family: var(--font-sanskrit);
  font-size: var(--text-lg);
  color: var(--color-ruby-deep);
  margin-bottom: var(--space-1);
}
[data-theme="dark"] .tattva-sense__sanskrit { color: var(--color-gold-bright); }
.tattva-sense__name {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--color-text);
  margin-bottom: var(--space-1);
}
.tattva-sense__english {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}
.tattva-sense__detail {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  line-height: 1.5;
  color: var(--color-text-faint);
}

/* ============================================================
   VI. COMPLETE MAP — cascade SVG + summary
   ============================================================ */
.tattva-cascade {
  margin: var(--space-10) auto;
  max-width: 100%;
  overflow-x: auto;
}
.tattva-cascade svg {
  display: block;
  margin: 0 auto;
  max-width: 100%;
  height: auto;
  min-width: 560px;
}
.tattva-cas__line {
  stroke: var(--color-gold-deep);
  stroke-width: 1.2;
  fill: none;
  opacity: 0.6;
}
[data-theme="dark"] .tattva-cas__line { stroke: var(--color-gold); }
.tattva-cas__line--fork { stroke-width: 1; opacity: 0.5; }
.tattva-cas__line--dotted { stroke-dasharray: 4 6; opacity: 0.25; }

.tattva-cas__node rect {
  fill: var(--color-surface);
  stroke: var(--color-ruby-deep);
  stroke-width: 1.5;
}
[data-theme="dark"] .tattva-cas__node rect { fill: var(--color-surface-2); stroke: var(--color-gold); }
.tattva-cas__node--witness rect { stroke: var(--color-gold-deep); stroke-width: 2.5; fill: rgba(184, 134, 11, 0.08); }
[data-theme="dark"] .tattva-cas__node--witness rect { stroke: var(--color-gold-bright); fill: rgba(240, 215, 127, 0.08); }
.tattva-cas__node--matrix rect { stroke: var(--color-purple); }
[data-theme="dark"] .tattva-cas__node--matrix rect { stroke: var(--color-purple-soft); }
.tattva-cas__node--cosmic rect { stroke: var(--color-ruby-deep); }
.tattva-cas__node--subtle rect { stroke: var(--color-orange); }
[data-theme="dark"] .tattva-cas__node--subtle rect { stroke: var(--color-orange-soft); }
.tattva-cas__node--gross rect { stroke: var(--color-orange-deep); fill: rgba(194, 84, 30, 0.05); }
[data-theme="dark"] .tattva-cas__node--gross rect { stroke: var(--color-orange); fill: rgba(232, 140, 82, 0.06); }
.tattva-cas__node--instrument rect { stroke: var(--color-gold-deep); }
[data-theme="dark"] .tattva-cas__node--instrument rect { stroke: var(--color-gold); }
.tattva-cas__node--rajas rect { stroke-dasharray: 3 3; opacity: 0.65; }
.tattva-cas__deva {
  font-family: var(--font-sanskrit);
  font-size: 14px;
  fill: var(--color-text);
}
.tattva-cas__label {
  font-family: var(--font-iast);
  font-style: italic;
  font-size: 11px;
  fill: var(--color-text-muted);
}
.tattva-cas__count {
  font-family: var(--font-display);
  font-style: italic;
  fill: var(--color-gold-deep);
}
[data-theme="dark"] .tattva-cas__count { fill: var(--color-gold); }

.tattva-summary {
  margin: var(--space-10) auto;
  padding: var(--space-6);
  max-width: 28rem;
  background: var(--color-surface-2);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
}
.tattva-summary__title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-gold-deep);
  text-align: center;
  margin-bottom: var(--space-4);
}
[data-theme="dark"] .tattva-summary__title { color: var(--color-gold); }
.tattva-summary__list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.tattva-summary__list li {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--color-text);
  padding: var(--space-1) 0;
  font-variant-numeric: tabular-nums;
}
.tattva-summary__list li:nth-last-child(2) {
  color: var(--color-text-faint);
  letter-spacing: 0.05em;
}
.tattva-summary__list li:last-child {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-ruby-deep);
  font-size: var(--text-base);
  padding-top: var(--space-2);
}
[data-theme="dark"] .tattva-summary__list li:last-child { color: var(--color-gold-bright); }

/* ============================================================
   NAVIGATION
   ============================================================ */
.tattva-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  margin: var(--space-12) 0 var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-divider);
}
.tattva-nav__btn {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  background: none;
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-5);
  cursor: pointer;
  transition: all var(--transition-interactive);
  letter-spacing: 0.03em;
}
.tattva-nav__btn:hover {
  color: var(--color-ruby-deep);
  border-color: var(--color-ruby-deep);
  background: var(--color-surface);
}
[data-theme="dark"] .tattva-nav__btn:hover {
  color: var(--color-gold-bright);
  border-color: var(--color-gold);
}
.tattva-nav__btn--centre {
  border: none;
  color: var(--color-gold-deep);
}
[data-theme="dark"] .tattva-nav__btn--centre { color: var(--color-gold); }

.tattva-breadcrumb {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-gold-deep);
  background: none;
  border: none;
  cursor: pointer;
  margin-bottom: var(--space-8);
  letter-spacing: 0.05em;
  padding: var(--space-2) 0;
}
[data-theme="dark"] .tattva-breadcrumb { color: var(--color-gold); }
.tattva-breadcrumb:hover { color: var(--color-ruby-deep); }
[data-theme="dark"] .tattva-breadcrumb:hover { color: var(--color-gold-bright); }

/* ============================================================
   VI. HTML CASCADE — replaces broken SVG text renderer
   Devanāgarī is rendered by HTML so ligature shaping works
   correctly on iOS WebKit and all other browsers.
   ============================================================ */

.tcv {
  margin: var(--space-10) auto;
  max-width: 680px;
}

.tcv__intro {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-text-faint);
  text-align: center;
  letter-spacing: 0.03em;
  margin-bottom: var(--space-8);
  border-left: 2px solid var(--color-divider);
  padding-left: var(--space-4);
  text-align: left;
}

/* ---- Spine (single column, top 4 nodes) ---- */
.tcv__spine {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* ---- Vertical gap (connecting line) ---- */
.tcv__vgap {
  width: 1.5px;
  min-height: 22px;
  background: var(--color-gold-deep);
  opacity: 0.55;
  margin: 0 auto;
}
[data-theme="dark"] .tcv__vgap { background: var(--color-gold); }

/* Vertical line from spine base to fork bar */
.tcv__spine-to-fork {
  width: 1.5px;
  height: 20px;
  background: var(--color-gold-deep);
  opacity: 0.55;
  margin: 0 auto;
}
[data-theme="dark"] .tcv__spine-to-fork { background: var(--color-gold); }

/* ---- Node box ---- */
.tcv__node {
  border: 1.5px solid var(--color-ruby-deep);
  border-radius: 4px;
  padding: 5px 14px 4px;
  text-align: center;
  background: var(--color-surface);
  width: 100%;
  max-width: 260px;
  box-sizing: border-box;
}
[data-theme="dark"] .tcv__node { background: var(--color-surface-2); }

.tcv__node--witness {
  border-color: var(--color-gold-deep);
  border-width: 2px;
  background: rgba(184, 134, 11, 0.06);
}
[data-theme="dark"] .tcv__node--witness {
  border-color: var(--color-gold-bright);
  background: rgba(240, 215, 127, 0.07);
}
.tcv__node--matrix  { border-color: var(--color-purple); }
[data-theme="dark"] .tcv__node--matrix  { border-color: var(--color-purple-soft); }
.tcv__node--cosmic  { border-color: var(--color-ruby-deep); }
.tcv__node--subtle  { border-color: var(--color-orange); }
[data-theme="dark"] .tcv__node--subtle  { border-color: var(--color-orange-soft); }
.tcv__node--gross   { border-color: var(--color-orange-deep); background: rgba(194,84,30,0.04); }
[data-theme="dark"] .tcv__node--gross   { border-color: var(--color-orange); background: rgba(232,140,82,0.05); }
.tcv__node--instrument { border-color: var(--color-gold-deep); }
[data-theme="dark"] .tcv__node--instrument { border-color: var(--color-gold); }
.tcv__node--rajas   { border-style: dashed; opacity: 0.72; }

.tcv__deva {
  font-family: var(--font-sanskrit);
  font-size: 15px;
  line-height: 1.4;
  color: var(--color-text);
}

.tcv__tag {
  font-family: var(--font-iast);
  font-style: italic;
  font-size: 10.5px;
  color: var(--color-text-muted);
  line-height: 1.4;
  margin-top: 2px;
}

.tcv__count {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-gold-deep);
}
[data-theme="dark"] .tcv__count { color: var(--color-gold); }

/* ---- Fork area ---- */
.tcv__fork-wrap {
  position: relative;
}

.tcv__branches {
  display: flex;
  gap: 6px;
  align-items: flex-start;
  position: relative;
  padding-top: 20px; /* room for drop lines from horizontal bar */
}

/* Horizontal bar spanning center of outer branches */
.tcv__branches::before {
  content: '';
  position: absolute;
  top: 0;
  left: calc(100% / 6);
  right: calc(100% / 6);
  height: 1.5px;
  background: var(--color-gold-deep);
  opacity: 0.5;
}
[data-theme="dark"] .tcv__branches::before { background: var(--color-gold); }

.tcv__branch {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  min-width: 0;
}

/* Vertical drop from horizontal bar into each branch */
.tcv__branch::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 1.5px;
  height: 20px;
  background: var(--color-gold-deep);
  opacity: 0.5;
}
[data-theme="dark"] .tcv__branch::before { background: var(--color-gold); }

.tcv__branch .tcv__node {
  max-width: none;
  width: 100%;
}

/* On narrow screens, stack the three branches vertically */
@media (max-width: 540px) {
  .tcv__branches {
    flex-direction: column;
    padding-top: 0;
    gap: 0;
  }
  .tcv__branches::before { display: none; }
  .tcv__branch {
    width: 100%;
    padding-top: 0;
  }
  .tcv__branch::before { display: none; }
  .tcv__branch + .tcv__branch {
    margin-top: 0;
  }
  /* Re-add vertical connectors between stacked branches */
  .tcv__branch + .tcv__branch::before {
    display: block;
    position: static;
    transform: none;
    width: 1.5px;
    height: 18px;
    margin: 0 auto;
  }
  .tcv__branch .tcv__node {
    max-width: 260px;
  }
}


/* ============================================================
   ALTAR MAP PANELS — sacred cosmology plates
   Integrated per dual-altar integration brief
   ============================================================ */

.tattva-altar-panel,
.tattva-complete-altar-map {
  margin: var(--space-12) auto;
  padding: var(--space-4);
  background: color-mix(in oklab, var(--color-surface) 92%, transparent);
  border: 1px solid color-mix(in oklab, var(--color-gold) 16%, var(--color-border));
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

.tattva-altar-panel img,
.tattva-altar-panel svg,
.tattva-complete-altar-map img,
.tattva-complete-altar-map svg {
  display: block;
  width: 100%;
  height: auto;
}

/* Complete map needs horizontal scroll at narrow viewports */
.tattva-complete-altar-map {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.tattva-complete-altar-map img,
.tattva-complete-altar-map svg {
  min-width: 980px;
}

/* Responsive: remove padding on very small screens */
@media (max-width: 480px) {
  .tattva-altar-panel,
  .tattva-complete-altar-map {
    padding: var(--space-2);
    margin: var(--space-8) auto;
    border-radius: var(--radius-md);
  }
}

@media (prefers-color-scheme: dark) {
  .tattva-element { background: var(--color-surface); }
  .tattva-element--gross { border-left-color: var(--color-ruby); background: var(--color-surface); }
}
