/* ==========================================================
   SAMPAD — Bondage & Liberation
   Contemplative reader. Built on base.css tokens.
   ========================================================== */

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

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

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

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

.sp-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;
}
[data-theme="dark"] .sp-landing__crown { color: var(--color-gold); }

.sp-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-3);
}

.sp-landing__desc {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--color-text-muted);
  max-width: 32rem;
  margin: 0 auto var(--space-10);
  font-style: italic;
}

.sp-invocation {
  margin: var(--space-10) auto;
  padding: var(--space-6);
  max-width: 40rem;
  border-top: 1px solid var(--color-divider);
  border-bottom: 1px solid var(--color-divider);
  text-align: left;
}
.sp-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"] .sp-invocation__label { color: var(--color-gold); }
.sp-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;
}

/* TOC */
.sp-toc { list-style: none; padding: 0; margin: var(--space-10) auto 0; max-width: 40rem; }
.sp-toc__item {
  display: block;
  width: 100%;
  text-align: left;
  padding: var(--space-6) 0;
  border-bottom: 1px solid var(--color-divider);
  cursor: pointer;
  background: none;
  border-left: none;
  border-right: none;
  border-top: none;
  color: inherit;
  transition: background var(--transition-interactive);
}
.sp-toc__item:first-child { border-top: 1px solid var(--color-divider); }
.sp-toc__item:hover { background: rgba(139, 0, 0, 0.04); }
[data-theme="dark"] .sp-toc__item:hover { background: rgba(240, 215, 127, 0.05); }

.sp-toc__roman {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  letter-spacing: 0.2em;
  color: var(--color-ruby-deep);
  margin-bottom: var(--space-2);
  display: block;
}
[data-theme="dark"] .sp-toc__roman { color: var(--color-ruby-soft); }
.sp-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"] .sp-toc__sanskrit { color: var(--color-gold-bright); }
.sp-toc__english {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}
.sp-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);
}
.sp-toc__teaser {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.65;
  color: var(--color-text-muted);
}

/* ============================================================
   SECTION HEAD
   ============================================================ */
.sp-head {
  text-align: center;
  margin-bottom: var(--space-12);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-divider);
}
.sp-head__roman {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  letter-spacing: 0.3em;
  color: var(--color-ruby-deep);
  margin-bottom: var(--space-4);
}
[data-theme="dark"] .sp-head__roman { color: var(--color-ruby-soft); }
.sp-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"] .sp-head__sanskrit { color: var(--color-gold-bright); }
.sp-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;
}
.sp-head__anchor {
  font-family: var(--font-body);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-text-faint);
  letter-spacing: 0.05em;
}

/* ============================================================
   SHARED PROSE
   ============================================================ */
.sp-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-ruby-deep);
  padding-left: var(--space-5);
}
[data-theme="dark"] .sp-opening { border-left-color: var(--color-ruby-soft); }

.sp-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;
}

.sp-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;
}

.sp-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"] .sp-h2 { color: var(--color-gold-bright); }

.sp-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-8) 0 var(--space-3);
  font-weight: 400;
}
[data-theme="dark"] .sp-h3 { color: var(--color-purple-soft); }

.sp-list {
  list-style: none;
  padding: 0;
  margin: var(--space-4) 0 var(--space-6);
}
.sp-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;
  padding-left: var(--space-5);
  position: relative;
}
.sp-list li::before {
  content: '·';
  position: absolute;
  left: var(--space-2);
  color: var(--color-ruby-deep);
}
[data-theme="dark"] .sp-list li::before { color: var(--color-ruby-soft); }

/* ============================================================
   VERSE
   ============================================================ */
.sp-verse {
  margin: var(--space-8) 0;
  padding: var(--space-2) 0;
}
.sp-verse__ref {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  letter-spacing: 0.1em;
  color: var(--color-ruby-deep);
  margin-bottom: var(--space-3);
  text-transform: uppercase;
}
[data-theme="dark"] .sp-verse__ref { color: var(--color-ruby-soft); }
.sp-verse__deva {
  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;
}
.sp-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"] .sp-verse__iast { color: var(--color-ruby-soft); }
.sp-verse__trans {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--color-text);
  font-style: italic;
}

/* ============================================================
   CONTEMPLATION
   ============================================================ */
.sp-contemplation {
  margin: var(--space-12) auto var(--space-8);
  padding: var(--space-6);
  max-width: 34rem;
  text-align: center;
  background: var(--color-surface-2);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-divider);
}
.sp-contemplation::before {
  content: '✦';
  display: block;
  color: var(--color-ruby-deep);
  font-size: var(--text-base);
  margin-bottom: var(--space-4);
  opacity: 0.6;
}
[data-theme="dark"] .sp-contemplation::before { color: var(--color-gold); }
.sp-contemplation__text {
  font-family: var(--font-display);
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--color-text);
  font-style: italic;
}

/* ============================================================
   I. THREE GATES
   ============================================================ */
.sp-gates {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin: var(--space-10) 0;
}

.sp-gate {
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  background: var(--color-surface-2);
  border-left: 3px solid var(--color-ruby-deep);
}
[data-theme="dark"] .sp-gate { border-left-color: var(--color-ruby-soft); }

.sp-gate__head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}
.sp-gate__sanskrit {
  font-family: var(--font-sanskrit);
  font-size: var(--text-2xl);
  color: var(--color-ruby-deep);
  line-height: 1.3;
}
[data-theme="dark"] .sp-gate__sanskrit { color: var(--color-gold-bright); }
.sp-gate__iast {
  font-family: var(--font-iast);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--color-text-muted);
}
.sp-gate__english {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--color-text-faint);
  font-style: italic;
}
.sp-gate__gloss {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-text);
  font-style: italic;
  margin-bottom: var(--space-3);
}
.sp-gate__note {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--color-text-muted);
}

/* ============================================================
   II. ṢAḌRIPU — ENEMIES
   ============================================================ */
.sp-enemies {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  margin: var(--space-10) 0;
}

.sp-enemy {
  display: grid;
  grid-template-columns: 2.5rem 1fr;
  gap: var(--space-5);
  padding: var(--space-5) var(--space-5) var(--space-5) 0;
  border-top: 1px solid var(--color-divider);
}
.sp-enemy:first-child { border-top: none; }

.sp-enemy__number {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-3xl);
  color: var(--color-ruby-deep);
  line-height: 1;
  text-align: right;
  padding-top: var(--space-2);
  opacity: 0.35;
}
[data-theme="dark"] .sp-enemy__number { color: var(--color-gold); opacity: 0.4; }

.sp-enemy__head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}
.sp-enemy__sanskrit {
  font-family: var(--font-sanskrit);
  font-size: var(--text-2xl);
  color: var(--color-ruby-deep);
}
[data-theme="dark"] .sp-enemy__sanskrit { color: var(--color-gold-bright); }
.sp-enemy__iast {
  font-family: var(--font-iast);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--color-text-muted);
}
.sp-enemy__english {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--color-text-faint);
  font-style: italic;
}

.sp-enemy__gloss {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-text);
  font-style: italic;
  margin-bottom: var(--space-4);
}

.sp-enemy__meta {
  background: var(--color-surface-2);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin: var(--space-4) 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.sp-enemy__meta-row {
  display: grid;
  grid-template-columns: 5.5rem 1fr;
  gap: var(--space-3);
  align-items: baseline;
}
.sp-enemy__meta-label {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-faint);
  flex-shrink: 0;
}
.sp-enemy__meta-val {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--color-text);
}
.sp-enemy__meta-row--antidote .sp-enemy__meta-label { color: var(--color-gold-deep); }
[data-theme="dark"] .sp-enemy__meta-row--antidote .sp-enemy__meta-label { color: var(--color-gold); }
.sp-enemy__meta-row--antidote .sp-enemy__meta-val { color: var(--color-text); font-weight: 500; }

/* ============================================================
   III & IV. QUALITIES
   ============================================================ */
.sp-qualities {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin: var(--space-8) 0;
}

.sp-quality {
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-divider);
  background: var(--color-surface-2);
}
.sp-quality--asuri { border-left: 3px solid var(--color-ruby-deep); }
[data-theme="dark"] .sp-quality--asuri { border-left-color: var(--color-ruby-soft); }
.sp-quality--daivi { border-left: 3px solid var(--color-gold-deep); }
[data-theme="dark"] .sp-quality--daivi { border-left-color: var(--color-gold); }

.sp-quality__head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}
.sp-quality__sanskrit {
  font-family: var(--font-sanskrit);
  font-size: var(--text-xl);
  color: var(--color-ruby-deep);
}
[data-theme="dark"] .sp-quality__sanskrit { color: var(--color-gold-bright); }
.sp-quality__iast {
  font-family: var(--font-iast);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--color-text-muted);
}
.sp-quality__english {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--color-text-faint);
  font-style: italic;
}
.sp-quality__gloss {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.65;
  color: var(--color-text);
  font-style: italic;
  margin-bottom: var(--space-2);
}
.sp-quality__insight {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--color-text-muted);
}
.sp-quality__practice {
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-divider);
  margin-top: var(--space-2);
  color: var(--color-purple);
}
[data-theme="dark"] .sp-quality__practice { color: var(--color-purple-soft); }

/* ============================================================
   IV. CLUSTERS
   ============================================================ */
.sp-cluster {
  margin: var(--space-10) 0;
}
.sp-cluster__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-style: italic;
  color: var(--color-gold-deep);
  margin-bottom: var(--space-1);
  font-weight: 400;
}
[data-theme="dark"] .sp-cluster__title { color: var(--color-gold); }
.sp-cluster__label {
  font-family: var(--font-body);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-text-faint);
  margin-bottom: var(--space-5);
  letter-spacing: 0.03em;
}
.sp-cluster__qualities {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.sp-extended {
  margin: var(--space-10) 0;
  padding: var(--space-6);
  background: var(--color-surface-2);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-divider);
}

/* ============================================================
   NAVIGATION
   ============================================================ */
.sp-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);
}
.sp-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;
}
.sp-nav__btn:hover {
  color: var(--color-ruby-deep);
  border-color: var(--color-ruby-deep);
  background: var(--color-surface);
}
[data-theme="dark"] .sp-nav__btn:hover {
  color: var(--color-gold-bright);
  border-color: var(--color-gold);
}
.sp-nav__btn--centre {
  border: none;
  color: var(--color-ruby-deep);
}
[data-theme="dark"] .sp-nav__btn--centre { color: var(--color-ruby-soft); }

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

/* ============================================================
   HERO IMAGE
   ============================================================ */
.sp-hero {
  margin: var(--space-10) calc(-1 * var(--space-6));
  position: relative;
}
@media (min-width: 768px) {
  .sp-hero { margin-left: calc(-1 * var(--space-8)); margin-right: calc(-1 * var(--space-8)); }
}
.sp-hero__img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
}
.sp-hero__caption {
  font-family: var(--font-sanskrit);
  font-size: var(--text-sm);
  color: var(--color-text-faint);
  text-align: center;
  margin-top: var(--space-3);
  letter-spacing: 0.03em;
  padding: 0 var(--space-6);
}
