/* ============================================================
   Sant Sahitya — site.css
   Two modes: light "Illuminated Paper" | dark "Indigo Night"
   NO build toolchain — hand-written CSS
   ============================================================ */

/* --- Design Tokens --- */
:root {
  --bg: #FAF6EE;
  --bg-deep: #F2EAD8;
  --paper: #FFFCF5;
  --ink: #1F1A14;
  --ink-soft: #3A3128;
  --muted: #7A6E5D;
  --saffron: #C8702A;
  --saffron-dk: #8F4E18;
  --vithal: #1F3A5F;
  --vithal-dk: #142640;
  --gold: #A8842C;
  --line: #D7CBB3;
  --glow: transparent;
  --shadow-tint: rgba(200,112,42,.12);
}

[data-theme="dark"] {
  --bg: #0E1424;
  --bg-deep: #131B30;
  --paper: rgba(255,255,255,.04);
  --ink: #EDE6D6;
  --ink-soft: #B9B2A0;
  --muted: #8E8775;
  --saffron: #D9A441;
  --saffron-dk: #D9A441;
  --vithal: #F5EFDF;
  --vithal-dk: #F5EFDF;
  --gold: #D9A441;
  --line: rgba(217,164,65,.25);
  --glow: rgba(217,164,65,.25);
  --shadow-tint: rgba(217,164,65,.15);
}
/* Cool Slate — a calm cool off-white (overrides backgrounds only; ink/accents inherit) */
[data-theme="slate"] {
  --bg: #F2F4F6;
  --bg-deep: #E5E9EE;
  --paper: #FCFDFE;
  --line: #D6DCE3;
  --glow: transparent;
  --shadow-tint: rgba(31,58,95,.10);
}
/* Soft Sage — a warm-neutral green-grey limestone */
[data-theme="sage"] {
  --bg: #F1F3EF;
  --bg-deep: #E4E8E1;
  --paper: #FBFCFA;
  --line: #D4DBCE;
  --glow: transparent;
  --shadow-tint: rgba(90,110,80,.10);
}

/* --- Self-hosted fonts --- */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/cormorant-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/cormorant-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/cormorant-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Tiro Devanagari Marathi';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/tiro-devanagari-marathi.woff2') format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CFF, U+A8E0-A8FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/inter-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/inter-600.woff2') format('woff2');
}

/* --- Reset & Box model --- */
*, *::before, *::after {
  box-sizing: border-box;
}

/* --- Body / base --- */
body {
  font-family: 'Cormorant Garamond', Georgia, serif;
  background: var(--bg);
  color: var(--ink);
  font-size: 19px;
  line-height: 1.65;
  margin: 0;
  padding: 0;
  transition: background .25s, color .25s;
}

main {
  max-width: 760px;
  margin: 0 auto;
  padding: 32px 20px 64px;
}

a {
  color: var(--saffron-dk);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
  color: var(--saffron);
}

::selection {
  background: var(--saffron);
  color: var(--paper);
}

/* --- Top navigation --- */
.topnav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--bg-deep);
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  height: 52px;
}

.brand {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 19px;
  color: var(--vithal);
  font-weight: 600;
  text-decoration: none;
  letter-spacing: .02em;
}

.brand:hover {
  color: var(--saffron);
  text-decoration: none;
}

.navlinks {
  display: flex;
  gap: 20px;
  align-items: center;
}

.navlinks a {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--muted);
  text-decoration: none;
}

.navlinks a:hover {
  color: var(--saffron);
  text-decoration: none;
}

#theme-toggle {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--gold);
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: border-color .2s;
}

#theme-toggle:hover {
  border-color: var(--gold);
}

/* --- Breadcrumb --- */
.crumb {
  font-family: 'Inter', sans-serif;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--saffron-dk);
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
  margin-bottom: 22px;
}

.crumb a {
  color: var(--saffron-dk);
  text-decoration: none;
}

.crumb a:hover {
  text-decoration: underline;
}

/* --- Verse article container --- */
.verse {
  /* simple wrapper — no special box, just a semantic anchor */
}

/* --- Verse / page headings --- */
.verse-title {
  font-size: 30px;
  color: var(--vithal-dk);
  margin: 0 0 10px;
  font-weight: 600;
  line-height: 1.25;
}

.teaching {
  font-size: 26px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--ink);
  margin: 0 0 20px;
}

/* --- Verse block (situation) --- */
.sit {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 5px;
  padding: 20px 24px;
  font-size: 16.5px;
  color: var(--ink-soft);
  margin-bottom: 24px;
}

/* --- UI label headings --- */
h2.ui {
  font-family: 'Inter', sans-serif;
  color: var(--gold);
  text-transform: uppercase;
  font-size: 10.5px;
  letter-spacing: .15em;
  font-weight: 600;
  margin: 26px 0 8px;
}

/* --- Devanagari / Marathi text --- */
.deva {
  font-family: 'Tiro Devanagari Marathi', serif;
}

.marathi {
  font-family: 'Tiro Devanagari Marathi', serif;
  font-size: 21px;
  line-height: 2.0;
  color: var(--vithal-dk);
  border-left: 3px solid var(--saffron);
  padding-left: 16px;
  margin: 8px 0;
  text-shadow: 0 0 24px var(--glow);
}

/* --- Literal translation --- */
.literal {
  font-style: italic;
  color: var(--ink-soft);
  margin: 6px 0;
}

/* --- Word-by-word gloss --- */
details.gloss {
  border-bottom: 1px dashed var(--line);
  padding: 6px 0;
  margin: 4px 0;
}

details.gloss summary {
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: var(--muted);
}

details.gloss table {
  width: 100%;
  font-size: 14px;
  border-collapse: collapse;
  margin-top: 8px;
}

details.gloss td {
  padding: 4px 8px;
  border-bottom: 1px solid var(--line);
}

/* --- Content tables (word-by-word gloss, comparison tables, etc.) --- */
main table {
  width: 100%;
  border-collapse: collapse;
  margin: 20px 0;
  font-size: 15px;
  line-height: 1.5;
  border: 1px solid var(--line);
}

main thead th {
  background: var(--bg-deep);
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
}

main th,
main td {
  border: 1px solid var(--line);
  padding: 9px 14px;
  text-align: left;
  vertical-align: top;
}

main tbody tr:nth-child(even) {
  background: var(--shadow-tint, rgba(0, 0, 0, .02));
}

/* First column of a gloss table is the Marathi/Devanagari source — give it room. */
main td:first-child {
  font-weight: 500;
  white-space: nowrap;
}

@media (max-width: 640px) {
  main table { font-size: 13.5px; }
  main th, main td { padding: 7px 9px; }
  main td:first-child { white-space: normal; }
}

/* --- Work-in-progress / AI disclaimer banner --- */
.wip-banner {
  background: var(--bg-deep);
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  line-height: 1.45;
  text-align: center;
  padding: 8px 16px;
}
.wip-banner b { color: var(--saffron-dk, #A8842C); font-weight: 600; }

/* --- Theme tags --- */
.tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 12px 0;
}

.tag {
  background: var(--bg-deep);
  color: var(--saffron-dk);
  border-radius: 20px;
  padding: 3px 10px;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-decoration: none;
  border: 1px solid transparent;
}

.tag:hover {
  border-color: var(--saffron);
  text-decoration: none;
}

/* --- Related verses --- */
ul.related {
  list-style: none;
  padding: 0;
  margin: 8px 0;
}

ul.related li {
  padding: 4px 0;
  border-bottom: 1px solid var(--line);
}

ul.related a {
  font-size: 16px;
  color: var(--vithal);
}

/* --- Prev/Next navigation --- */
.pn {
  display: flex;
  justify-content: space-between;
  padding-top: 16px;
  border-top: 1px solid var(--line);
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  margin-top: 32px;
}

/* --- Chapter / theme page headings --- */
.chapter h1,
.theme-page h1 {
  font-size: 30px;
  color: var(--vithal-dk);
  line-height: 1.25;
  margin: 0 0 8px;
}

.subtitle {
  color: var(--muted);
  font-style: italic;
  margin: 0 0 24px;
}

/* --- Ovi (Dasbodh verse unit) --- */
.ovi {
  border-bottom: 1px solid var(--line);
  padding: 14px 0;
  margin: 0;
}

.ovi .deva {
  font-family: 'Tiro Devanagari Marathi', serif;
  font-size: 18px;
  line-height: 2.0;
  white-space: pre-line;
  border-left: 3px solid var(--saffron);
  padding-left: 16px;
  text-shadow: 0 0 24px var(--glow);
}

.ovi .translit {
  font-size: 14px;
  color: var(--muted);
  font-style: italic;
  margin: 4px 0;
}

.ovi .literal {
  margin-top: 6px;
  font-style: italic;
  color: var(--ink-soft);
  font-size: 15px;
}

.ovi .decoded {
  background: var(--paper);
  border-left: 3px solid var(--gold);
  padding: 6px 10px;
  margin-top: 6px;
  font-size: 15px;
}

/* --- Empty state --- */
.empty-notice {
  color: var(--muted);
  font-style: italic;
  text-align: center;
  padding: 24px;
  font-size: 16px;
}

/* --- Chapter body blockquotes --- */
.chapter .body blockquote {
  border-left: 3px solid var(--saffron);
  background: var(--paper);
  color: var(--vithal-dk);
  margin: 16px 0;
  padding: 12px 16px;
  border-radius: 0 4px 4px 0;
}

/* --- Chapter body pre / code (e.g. Devanagari śloka blocks in Jñāneśvarī) --- */
.chapter .body code {
  font-family: 'Tiro Devanagari Marathi', serif;
  white-space: pre-wrap;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 2px 6px;
  display: inline-block;
}

.chapter .body pre {
  font-family: 'Tiro Devanagari Marathi', serif;
  white-space: pre-wrap;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 12px 16px;
}

/* --- Hero (landing page) --- */
.hero {
  text-align: center;
  padding: 64px 20px 48px;
  background: radial-gradient(ellipse at 50% 0%, rgba(200,112,42,.12) 0%, transparent 60%);
}

.hero .om {
  font-family: 'Tiro Devanagari Marathi', serif;
  font-size: 24px;
  color: var(--saffron);
  opacity: .6;
  display: block;
  margin-bottom: 12px;
}

.hero .title-deva {
  font-family: 'Tiro Devanagari Marathi', serif;
  font-size: 52px;
  color: var(--vithal-dk);
  line-height: 1.2;
  text-shadow: 0 0 32px var(--glow);
  display: block;
  margin-bottom: 8px;
}

.hero .title-en {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  letter-spacing: .3em;
  color: var(--saffron-dk);
  text-transform: uppercase;
  display: block;
  margin-bottom: 16px;
}

.hero .tagline {
  font-style: italic;
  text-align: center;
  max-width: 460px;
  margin: 0 auto 32px;
  color: var(--ink-soft);
  font-size: 18px;
}

/* --- Search box --- */
input.searchbox {
  display: block;
  width: min(440px, 90%);
  margin: 22px auto 8px;
  padding: 13px 22px;
  border-radius: 30px;
  border: 1.5px solid var(--saffron);
  background: var(--paper);
  color: var(--ink);
  font-family: Inter, sans-serif;
  font-size: 15px;
  box-shadow: 0 4px 18px var(--shadow-tint);
  outline: none;
}

/* --- Filter chips --- */
.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-bottom: 32px;
}

/* --- Saints grid (landing) --- */
.saints {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 16px;
  max-width: 900px;
  margin: 0 auto 40px;
}

.saint-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 20px 16px;
  text-align: center;
  text-decoration: none;
  transition: border-color .2s, box-shadow .2s;
  display: block;
}

.saint-card:hover {
  border-color: var(--saffron);
  box-shadow: 0 4px 16px var(--shadow-tint);
  text-decoration: none;
}

.saint-card .sd {
  font-family: 'Tiro Devanagari Marathi', serif;
  font-size: 22px;
  color: var(--vithal-dk);
  display: block;
  margin-bottom: 6px;
}

.saint-card .sn {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  letter-spacing: .12em;
  color: var(--saffron-dk);
  text-transform: uppercase;
  display: block;
}

.saint-card .sc {
  font-family: 'Inter', sans-serif;
  font-size: 11.5px;
  color: var(--muted);
  display: block;
  margin-top: 4px;
}

/* --- Findings (landing highlights) --- */
.findings {
  max-width: 900px;
  margin: 0 auto;
}

.findings h6 {
  font-family: 'Inter', sans-serif;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: var(--gold);
  text-align: center;
  margin: 0 0 16px;
  font-weight: 600;
}

.frow {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}

.fcard {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 14px 16px;
}

.fcard b {
  display: block;
  color: var(--vithal);
  font-size: 16px;
  margin-bottom: 4px;
}

.fcard span {
  font-size: 14px;
  color: var(--ink-soft);
}

/* --- Search controls --- */
.controls {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.controls select,
.controls input {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 5px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: var(--ink);
  padding: 6px 10px;
  outline: none;
}

.controls select:focus,
.controls input:focus {
  border-color: var(--saffron);
}

/* --- Search results --- */
.result {
  border-bottom: 1px solid var(--line);
  padding: 10px 0;
}

.result a {
  font-size: 17px;
  color: var(--vithal);
  display: block;
  margin-bottom: 3px;
}

.result a:hover {
  color: var(--saffron);
  text-decoration: none;
}

.rs {
  font-size: 13px;
  color: var(--muted);
}

/* --- Theme member list --- */
ul.theme-members {
  list-style: none;
  padding: 0;
  margin: 0;
}

ul.theme-members li {
  padding: 5px 0;
  border-bottom: 1px solid var(--line);
}

ul.theme-members a {
  font-size: 16px;
  color: var(--vithal);
}

/* --- "More" link in theme sections --- */
.more {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: var(--muted);
  margin-top: 6px;
}

/* --- Footer --- */
footer {
  background: var(--bg-deep);
  border-top: 1px solid var(--line);
  text-align: center;
  padding: 20px;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: var(--muted);
  margin-top: 64px;
}

/* --- Responsive: mobile --- */
@media (max-width: 640px) {
  .teaching {
    font-size: 21px;
  }

  .hero .title-deva {
    font-size: 38px;
  }

  .navlinks a {
    font-size: 10px;
    letter-spacing: .08em;
  }

  main {
    padding: 20px 14px 48px;
  }

  .saints {
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  }
}

/* --- Print --- */
@media print {
  .topnav,
  footer,
  #theme-toggle {
    display: none;
  }

  body {
    font-size: 12pt;
    color: #000;
  }

  a {
    color: #000;
    text-decoration: underline;
  }
}
