/* ============================================================
   ROOTS GROW IN THE DARK - SHARED DESIGN SYSTEM
   Single source of truth for all page styles.
   Edit here, every page updates.
   ============================================================ */

/* ---------- DESIGN TOKENS ---------- */
:root {
  /* Colours */
  --bg: #0a0908;
  --bg-card: rgba(20, 18, 16, 0.4);
  --bg-card-hover: rgba(28, 24, 20, 0.6);
  --ink: #e8e4dc;
  --ink-soft: #c8c2b4;
  --ink-mute: #a8a397;
  --ink-faint: #8a8580;
  --ink-deep: #6a5a3c;
  --gold: #c9a961;
  --gold-soft: #8a7a5c;
  --oxblood: #5c1a1a;
  --oxblood-bright: #7a2424;
  --rule: rgba(232, 228, 220, 0.08);
  --rule-mid: rgba(232, 228, 220, 0.15);

  /* Fonts */
  --font-body: 'Cormorant Garamond', Georgia, serif;
  --font-caps: 'Cinzel', serif;
}

/* ---------- RESET ---------- */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 1.55;
  min-height: 100vh;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ---------- APP LAYOUT ---------- */
.app {
  display: grid;
  grid-template-columns: 140px 1fr;
  min-height: 100vh;
}

/* ---------- SIDEBAR ---------- */
.sidebar {
  background: var(--bg);
  border-right: 1px solid var(--rule);
  padding: 24px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: sticky;
  top: 0;
  height: 100vh;
}
.logo {
  width: 64px;
  height: 64px;
  margin-bottom: 36px;
  opacity: 0.9;
}
.nav {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding: 0 12px;
}
.nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  color: var(--ink-mute);
  font-family: var(--font-caps);
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  transition: color 0.2s;
  text-align: center;
}
.nav-item:hover, .nav-item.active { color: var(--ink); }
.nav-icon {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  stroke-width: 1.5;
  fill: none;
}
.nav-sub {
  font-size: 7px;
  letter-spacing: 1.5px;
  color: var(--ink-deep);
  margin-top: 2px;
}
.sidebar-quote {
  margin-top: auto;
  padding: 0 14px 24px;
  font-style: italic;
  font-size: 12px;
  color: var(--ink-faint);
  line-height: 1.5;
  position: relative;
}
.sidebar-quote::before {
  content: '"';
  font-family: var(--font-body);
  font-size: 36px;
  color: var(--ink-deep);
  position: absolute;
  top: -8px;
  left: 12px;
  font-style: normal;
}
.sidebar-quote p {
  padding-left: 8px;
  padding-top: 16px;
}

/* ---------- MAIN ---------- */
main {
  padding: 24px 60px 0;
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
}

/* ---------- TOP BAR ---------- */
.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 60px;
  flex-wrap: wrap;
  gap: 16px;
}
.mantra {
  font-family: var(--font-caps);
  font-size: 11px;
  letter-spacing: 4px;
  color: var(--ink-soft);
  text-transform: uppercase;
}

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 22px;
  border: 1px solid var(--gold-soft);
  background: transparent;
  color: var(--ink);
  font-family: var(--font-caps);
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
}
.btn:hover {
  background: rgba(122, 36, 36, 0.15);
  border-color: var(--oxblood-bright);
}
.btn-primary {
  background: var(--oxblood);
  border-color: var(--oxblood-bright);
}
.btn-primary:hover { background: var(--oxblood-bright); }
.btn svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  stroke-width: 1.5;
  fill: none;
}

/* ---------- HERO ---------- */
.hero {
  text-align: center;
  padding: 20px 0 60px;
}
.hero-image-wrap {
  width: 100%;
  max-width: 560px;
  margin: 0 auto 30px;
  position: relative;
}
.hero-image {
  width: 100%;
  height: auto;
  display: block;
}
.hero-placeholder {
  width: 100%;
  aspect-ratio: 1;
  border: 1px dashed rgba(200, 194, 180, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-deep);
  font-style: italic;
  font-size: 14px;
  padding: 40px;
  text-align: center;
}
h1.hero-title {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: clamp(36px, 6vw, 64px);
  letter-spacing: 8px;
  line-height: 1;
  margin: 30px 0 20px;
  color: var(--ink);
}
.ornament {
  margin: 20px auto;
  width: 40px;
  height: 16px;
  color: var(--gold-soft);
}
.ornament svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}
.hero-subhead {
  max-width: 620px;
  margin: 0 auto;
  font-size: 18px;
  color: var(--ink-soft);
  line-height: 1.6;
}

/* ---------- SEARCH ---------- */
.search-row {
  display: flex;
  gap: 14px;
  max-width: 760px;
  margin: 40px auto 0;
  flex-wrap: wrap;
}
.search-wrap {
  flex: 1;
  min-width: 280px;
  position: relative;
  display: flex;
  border: 1px solid var(--rule-mid);
  background: rgba(20, 18, 16, 0.4);
}
.search-icon {
  padding: 0 14px;
  display: flex;
  align-items: center;
  color: var(--ink-deep);
}
.search-icon svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 1.5;
  fill: none;
}
.search-input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: var(--ink);
  font-family: var(--font-body);
  font-style: italic;
  font-size: 16px;
  padding: 14px 0;
}
.search-input::placeholder { color: var(--ink-deep); }
.search-submit {
  background: transparent;
  border: none;
  border-left: 1px solid var(--rule-mid);
  color: var(--ink);
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  padding: 0 22px;
  cursor: pointer;
}
.search-submit:hover { background: rgba(122, 36, 36, 0.15); }

/* ---------- TOPIC CHIPS ---------- */
.topics-label {
  margin-top: 36px;
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--ink-deep);
  text-transform: uppercase;
  text-align: center;
}
.topics {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin: 14px 0 50px;
}
.chip {
  padding: 8px 16px;
  border: 1px solid var(--rule-mid);
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--ink-soft);
  cursor: pointer;
  transition: all 0.2s;
}
.chip:hover, .chip.active {
  border-color: var(--gold-soft);
  color: var(--ink);
}

/* ---------- SECTIONS / LABELS ---------- */
.section { margin-top: 30px; margin-bottom: 60px; }
.section-label {
  font-family: var(--font-caps);
  font-size: 11px;
  letter-spacing: 4px;
  color: var(--gold-soft);
  text-transform: uppercase;
  margin-bottom: 20px;
}
.section-h {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: clamp(28px, 4vw, 42px);
  letter-spacing: 2px;
  line-height: 1.2;
  margin-bottom: 20px;
  color: var(--ink);
}

/* ---------- CARDS ---------- */
.cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}
.card {
  background: var(--bg-card);
  border: 1px solid var(--rule);
  padding: 30px 28px;
  display: flex;
  flex-direction: column;
  min-height: 200px;
  transition: border-color 0.2s, background 0.2s;
}
.card:hover {
  border-color: rgba(138, 122, 92, 0.5);
  background: var(--bg-card-hover);
}
.card h3 {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 22px;
  margin-bottom: 10px;
  color: var(--ink);
}
.card p {
  color: var(--ink-mute);
  font-size: 15px;
  line-height: 1.6;
  flex: 1;
  margin-bottom: 18px;
}
.card-cta {
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--ink-soft);
  text-transform: uppercase;
}
.card-cta.disabled { color: var(--ink-deep); }

/* ---------- FIVE VERBS ---------- */
.verbs {
  margin-top: 60px;
  padding-top: 50px;
  border-top: 1px solid var(--rule);
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
}
@media (max-width: 880px) {
  .verbs { grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); }
}
.verb { text-align: center; padding: 20px 10px; }
.verb-icon {
  width: 48px;
  height: 48px;
  margin: 0 auto 14px;
  border: 1px solid var(--ink-deep);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold-soft);
}
.verb-icon svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  stroke-width: 1.5;
  fill: none;
}
.verb-title {
  font-family: var(--font-caps);
  font-size: 13px;
  letter-spacing: 4px;
  color: var(--ink);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.verb-desc {
  font-size: 14px;
  color: var(--ink-mute);
  line-height: 1.5;
  margin-bottom: 14px;
}
.verb-link {
  font-family: var(--font-caps);
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--ink-soft);
  text-transform: uppercase;
}
.verb-link:hover { color: var(--ink); }

/* ---------- FOOTER ---------- */
footer {
  margin-top: 60px;
  padding: 24px 0 30px;
  border-top: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: var(--ink-deep);
  flex-wrap: wrap;
  gap: 16px;
}
footer a:hover { color: var(--ink-soft); }
.footer-meta { display: flex; gap: 28px; align-items: center; flex-wrap: wrap; }
.footer-meta span { font-family: var(--font-caps); letter-spacing: 1.5px; }
.footer-icons { display: flex; gap: 18px; }
.footer-icons a {
  color: var(--ink-deep);
  width: 20px;
  height: 20px;
  display: inline-block;
}
.footer-icons a:hover { color: var(--ink-soft); }
.footer-icons svg {
  width: 100%;
  height: 100%;
  stroke: currentColor;
  stroke-width: 1.5;
  fill: none;
}

/* ---------- PROSE (long-form content pages) ---------- */
.prose {
  max-width: 720px;
  margin: 0 auto;
  font-size: 18px;
  line-height: 1.75;
  color: var(--ink-soft);
}
.prose h1 {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: clamp(36px, 5vw, 56px);
  letter-spacing: 4px;
  line-height: 1.1;
  margin-bottom: 24px;
  color: var(--ink);
  text-align: center;
}
.prose h2 {
  font-family: var(--font-caps);
  font-size: 14px;
  letter-spacing: 5px;
  text-transform: uppercase;
  margin: 50px 0 16px;
  color: var(--gold-soft);
}
.prose h3 {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 22px;
  margin: 36px 0 12px;
  color: var(--ink);
  letter-spacing: 1px;
}
.prose p { margin-bottom: 18px; }
.prose ul, .prose ol { margin: 16px 0 18px 24px; }
.prose li { margin-bottom: 8px; }
.prose strong { color: var(--ink); font-weight: 500; }
.prose em { color: var(--ink-soft); }
.prose blockquote {
  border-left: 2px solid var(--gold-soft);
  padding-left: 20px;
  margin: 24px 0;
  font-style: italic;
  color: var(--ink-soft);
}
.prose a {
  color: var(--gold);
  border-bottom: 1px solid var(--gold-soft);
  transition: color 0.2s;
}
.prose a:hover { color: var(--ink); }
.prose hr {
  border: 0;
  border-top: 1px solid var(--rule);
  margin: 40px 0;
}
.prose table {
  width: 100%;
  margin: 20px 0;
  border-collapse: collapse;
  font-size: 16px;
}
.prose th, .prose td {
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
}
.prose th {
  font-family: var(--font-caps);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold-soft);
  font-weight: 400;
}
.prose code {
  font-family: 'Courier New', monospace;
  font-size: 14px;
  background: rgba(232, 228, 220, 0.06);
  padding: 2px 6px;
  color: var(--gold);
}

/* ---------- LIBRARY (doc grid by cluster) ---------- */
.cluster-block {
  margin-bottom: 50px;
}
.cluster-head {
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--rule);
}
.cluster-name {
  font-family: var(--font-caps);
  font-size: 16px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--ink);
}
.cluster-count {
  font-family: var(--font-caps);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--ink-deep);
}
.doc-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 14px;
}
.doc-item {
  padding: 18px 20px;
  border: 1px solid var(--rule);
  background: rgba(20, 18, 16, 0.3);
  transition: all 0.2s;
}
.doc-item:hover {
  border-color: var(--gold-soft);
  background: var(--bg-card-hover);
}
.doc-title {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 18px;
  color: var(--ink);
  margin-bottom: 6px;
}
.doc-desc {
  font-size: 14px;
  color: var(--ink-mute);
  line-height: 1.5;
}
.doc-meta {
  margin-top: 10px;
  font-family: var(--font-caps);
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--ink-deep);
  text-transform: uppercase;
}

/* ---------- DOC PAGE (single document view) ---------- */
.doc-header {
  text-align: center;
  margin-bottom: 50px;
  padding-bottom: 30px;
  border-bottom: 1px solid var(--rule);
}
.doc-cluster-tag {
  font-family: var(--font-caps);
  font-size: 11px;
  letter-spacing: 4px;
  color: var(--gold-soft);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.doc-verified {
  margin-top: 16px;
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--ink-deep);
}

/* ---------- SYSTEM MAP (used on homepage and system-maps page) ---------- */
.system-map-container {
  position: relative;
  max-width: 1400px;
  margin: 0 auto;
  line-height: 0;
}
.system-map-image {
  width: 100%;
  height: auto;
  display: block;
  border: 1px solid var(--rule);
}
.map-pin {
  position: absolute;
  width: 7%;
  height: 9%;
  transform: translate(-50%, -50%);
  border-radius: 4px;
  transition: all 0.2s;
  display: block;
  text-decoration: none;
  cursor: pointer;
}
.map-pin:hover {
  background: rgba(201, 169, 97, 0.08);
  box-shadow: 0 0 24px 4px rgba(201, 169, 97, 0.25);
}
.map-pin::after {
  content: attr(data-label);
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0,0,0,0.95);
  color: var(--gold);
  padding: 6px 12px;
  border: 1px solid var(--gold-soft);
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
  line-height: 1;
  z-index: 10;
}
.map-pin:hover::after {
  opacity: 1;
}
.map-pin.no-doc {
  cursor: help;
}
.map-pin.no-doc:hover {
  background: rgba(106, 90, 60, 0.08);
  box-shadow: 0 0 24px 4px rgba(106, 90, 60, 0.2);
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 700px) {
  .app { grid-template-columns: 1fr; }
  .sidebar {
    flex-direction: row;
    height: auto;
    position: relative;
    padding: 16px 24px;
    gap: 20px;
    overflow-x: auto;
  }
  .nav { flex-direction: row; gap: 18px; padding: 0; }
  .logo { margin-bottom: 0; width: 40px; height: 40px; flex-shrink: 0; }
  .sidebar-quote { display: none; }
  main { padding: 20px 24px 0; }
  h1.hero-title { letter-spacing: 4px; }
}

/* ---------- ACTION-FIRST: situation-based entry for people who need help right now ---------- */

.action-first {
  margin: 0 auto 48px;
  max-width: 1100px;
  padding: 32px 28px 36px;
  border: 1px solid var(--rule-mid);
  background: rgba(15, 13, 11, 0.6);
}

.action-first-eyebrow {
  font-family: var(--font-caps);
  font-size: 11px;
  letter-spacing: 5px;
  color: var(--gold);
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 14px;
}

.action-first-title {
  font-family: var(--font-body);
  font-size: clamp(24px, 3.2vw, 32px);
  color: var(--ink);
  text-align: center;
  font-weight: 400;
  letter-spacing: 0.5px;
  margin-bottom: 8px;
}

.action-first-subhead {
  text-align: center;
  color: var(--ink-mute);
  font-size: 16px;
  font-style: italic;
  margin-bottom: 28px;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

.urgent-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 14px;
  margin-bottom: 24px;
}

.situations-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 14px;
}

.situation-card {
  display: block;
  padding: 18px 20px;
  background: var(--bg-card);
  border: 1px solid var(--rule-mid);
  text-decoration: none;
  color: var(--ink);
  transition: all 0.18s ease;
  position: relative;
}

.situation-card:hover {
  border-color: var(--gold-soft);
  background: var(--bg-card-hover);
  transform: translateY(-1px);
}

.situation-card.urgent {
  border-color: var(--oxblood-bright);
  background: rgba(92, 26, 26, 0.10);
}

.situation-card.urgent:hover {
  border-color: var(--oxblood-bright);
  background: rgba(122, 36, 36, 0.18);
}

.situation-card .card-tag,
.situation-card .card-num {
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 8px;
  display: block;
}

.situation-card.urgent .card-tag {
  color: #c97a7a;
}

.situation-card h3 {
  font-family: var(--font-body);
  font-size: 19px;
  color: var(--ink);
  font-weight: 500;
  line-height: 1.25;
  margin-bottom: 6px;
  letter-spacing: 0;
}

.situation-card.urgent h3 {
  color: #f0d6d6;
}

.situation-card p {
  font-size: 14px;
  color: var(--ink-mute);
  line-height: 1.4;
  margin: 0;
}

.action-first-foot {
  text-align: center;
  color: var(--ink-faint);
  font-size: 13px;
  font-style: italic;
  margin-top: 22px;
}

.action-first-foot a {
  color: var(--gold);
  border-bottom: 1px dotted var(--gold-soft);
  text-decoration: none;
}

/* ---------- ACTION PAGE: dedicated situation page (action.html) ---------- */

.action-page {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 20px;
}

.action-eyebrow {
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 4px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 10px;
}

.action-title {
  font-family: var(--font-body);
  font-size: clamp(28px, 3.6vw, 38px);
  color: var(--ink);
  font-weight: 400;
  line-height: 1.2;
  margin-bottom: 12px;
  letter-spacing: 0.5px;
}

.action-intro {
  font-size: 17px;
  color: var(--ink-soft);
  line-height: 1.55;
  margin-bottom: 28px;
}

.action-block {
  margin-bottom: 26px;
  border: 1px solid var(--rule-mid);
  background: rgba(15, 13, 11, 0.5);
  padding: 20px 22px;
}

.action-block.urgent {
  border-color: var(--oxblood-bright);
  background: rgba(92, 26, 26, 0.12);
}

.action-block-label {
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 4px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 12px;
}

.action-block.urgent .action-block-label { color: #d99090; }

.phone-line {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px 0;
  border-bottom: 1px solid var(--rule);
}

.phone-line:last-child { border-bottom: none; }

.phone-line .phone-label {
  font-size: 15px;
  color: var(--ink-soft);
  flex: 1 1 200px;
}

.phone-line .phone-num {
  font-family: var(--font-caps);
  font-size: 22px;
  color: var(--gold);
  letter-spacing: 1.5px;
  text-decoration: none;
  flex: 0 0 auto;
}

.phone-line .phone-num:hover { color: var(--ink); }

.action-block.urgent .phone-num { color: #f0d6d6; }
.action-block.urgent .phone-num:hover { color: #ffffff; }

.form-line {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--rule);
}

.form-line:last-child { border-bottom: none; }

.form-line .form-link {
  color: var(--gold);
  font-size: 16px;
  text-decoration: none;
  border-bottom: 1px dotted var(--gold-soft);
  padding-bottom: 1px;
  flex: 1;
}

.form-line .form-link:hover {
  color: var(--ink);
  border-color: var(--ink);
}

.form-line .form-meta {
  font-size: 12px;
  color: var(--ink-faint);
  font-family: var(--font-caps);
  letter-spacing: 2px;
}

.form-line .official-badge {
  display: inline-block;
  font-family: var(--font-caps);
  font-size: 9px;
  letter-spacing: 2px;
  color: #82b482;
  border: 1px solid rgba(130, 180, 130, 0.5);
  padding: 3px 8px;
  border-radius: 2px;
  text-transform: uppercase;
}

.steps-list {
  list-style: none;
  counter-reset: stepcount;
  padding: 0;
}

.steps-list li {
  counter-increment: stepcount;
  position: relative;
  padding: 10px 0 10px 50px;
  border-bottom: 1px solid var(--rule);
  font-size: 16px;
  line-height: 1.5;
  color: var(--ink-soft);
}

.steps-list li:last-child { border-bottom: none; }

.steps-list li::before {
  content: counter(stepcount, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 12px;
  font-family: var(--font-caps);
  font-size: 16px;
  color: var(--gold);
  letter-spacing: 1px;
}

.deeper-list {
  list-style: none;
  padding: 0;
}

.deeper-list li {
  padding: 8px 0;
  border-bottom: 1px solid var(--rule);
}

.deeper-list li:last-child { border-bottom: none; }

.deeper-list a {
  color: var(--ink);
  text-decoration: none;
  font-size: 15px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.deeper-list a:hover { color: var(--gold); }

.deeper-list .doc-arrow {
  color: var(--gold-soft);
  font-size: 14px;
}

.safety-callout {
  margin-top: 28px;
  padding: 16px 18px;
  border-left: 3px solid var(--oxblood-bright);
  background: rgba(92, 26, 26, 0.08);
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.5;
}

.back-to-home {
  display: inline-block;
  margin-top: 36px;
  margin-bottom: 12px;
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 4px;
  color: var(--gold);
  text-decoration: none;
  border-bottom: 1px dotted var(--gold-soft);
}

.back-to-home:hover { color: var(--ink); }

/* Tighter on small screens */
@media (max-width: 720px) {
  .phone-line .phone-num { font-size: 19px; }
  .situation-card h3 { font-size: 17px; }
  .urgent-row, .situations-grid { gap: 10px; }
  .action-first { padding: 22px 18px 24px; }
}


/* ---------- QUICK ACTIONS CARD: TL;DR action box at the top of a doc ---------- */

.quick-actions-card {
  margin: 0 0 36px;
  padding: 22px 24px 20px;
  border: 1.5px solid var(--gold);
  background: rgba(15, 13, 11, 0.7);
  position: relative;
}

.quick-actions-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(to right, transparent, var(--gold), transparent);
}

.quick-actions-label {
  font-family: var(--font-caps);
  font-size: 11px;
  letter-spacing: 5px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 16px;
  text-align: center;
}

.quick-actions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
  margin-bottom: 18px;
}

.qa-block {
  display: block;
}

.qa-block-label {
  font-family: var(--font-caps);
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 10px;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 6px;
}

.qa-phone {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 6px;
  padding: 6px 0;
}

.qa-phone-label {
  font-size: 13px;
  color: var(--ink-mute);
  flex: 1 1 160px;
  line-height: 1.3;
}

.qa-phone-num {
  font-family: var(--font-caps);
  font-size: 18px;
  color: var(--gold);
  letter-spacing: 1px;
  text-decoration: none;
  flex: 0 0 auto;
}

.qa-phone-num:hover { color: var(--ink); }

.qa-form {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 0;
}

.qa-form-link {
  color: var(--gold);
  font-size: 14px;
  text-decoration: none;
  border-bottom: 1px dotted var(--gold-soft);
  padding-bottom: 1px;
  flex: 1;
  line-height: 1.3;
}

.qa-form-link:hover {
  color: var(--ink);
  border-color: var(--ink);
}

.qa-badge {
  display: inline-block;
  font-family: var(--font-caps);
  font-size: 8px;
  letter-spacing: 2px;
  color: #82b482;
  border: 1px solid rgba(130, 180, 130, 0.5);
  padding: 2px 6px;
  border-radius: 2px;
  text-transform: uppercase;
  flex: 0 0 auto;
}

.qa-first-step {
  padding: 14px 16px;
  background: rgba(92, 26, 26, 0.08);
  border-left: 3px solid var(--oxblood-bright);
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.5;
  margin-bottom: 14px;
}

.qa-first-step strong {
  color: #f0d6d6;
  font-weight: 600;
}

.qa-fullguide {
  display: inline-block;
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--gold);
  text-decoration: none;
  border-bottom: 1px dotted var(--gold-soft);
  padding-bottom: 1px;
}

.qa-fullguide:hover { color: var(--ink); border-color: var(--ink); }

@media (max-width: 720px) {
  .quick-actions-card { padding: 18px 16px 16px; }
  .qa-phone-num { font-size: 16px; }
  .quick-actions-grid { gap: 14px; }
}

/* ---------- PRINT-FRIENDLY VIEW ---------- */
@media print {
  /* Reset to high-contrast, paper-friendly */
  * {
    background: transparent !important;
    color: #000 !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }
  body {
    background: #fff !important;
    color: #000 !important;
    font-family: Georgia, 'Times New Roman', serif !important;
    font-size: 12pt !important;
    line-height: 1.5;
  }
  /* Hide navigation, sidebar, topbar, buttons */
  .sidebar, .topbar, .nav, .nav-item, .btn,
  .footer-icons, .map-pin, .view-toggle,
  .system-map-container, .map-hint,
  .companion-tree, .ornament,
  .action-first, .quick-actions-card,
  .forms-toc, .back-to-home,
  .topics, .topics-label, .chip,
  .search-row, .search-wrap, .search-submit {
    display: none !important;
  }
  /* Main area uses full width */
  .app { display: block !important; }
  main {
    padding: 0 !important;
    max-width: 100% !important;
    margin: 0 !important;
  }
  /* Show URLs after links so the printed page is self-contained */
  a[href^="http"]::after {
    content: " [" attr(href) "]";
    font-size: 10pt;
    color: #555 !important;
    word-break: break-all;
  }
  /* Don't show URL for internal anchors or relative links */
  a[href^="#"]::after,
  a[href^="doc.html"]::after,
  a[href^="action.html"]::after,
  a[href^="forms.html"]::after,
  a[href^="library.html"]::after,
  a[href^="index.html"]::after,
  a[href^="mailto:"]::after,
  a[href^="tel:"]::after {
    content: "" !important;
  }
  /* Headings paginate nicely */
  h1, h2, h3, h4, h5, h6 {
    page-break-after: avoid;
    color: #000 !important;
    font-weight: bold !important;
  }
  h1 { font-size: 22pt !important; }
  h2 { font-size: 18pt !important; }
  h3 { font-size: 14pt !important; }
  h4 { font-size: 12pt !important; }
  /* Tables print with visible borders */
  table {
    border-collapse: collapse !important;
    page-break-inside: avoid;
  }
  table, th, td {
    border: 1px solid #aaa !important;
  }
  th, td {
    padding: 4px 8px !important;
  }
  /* Lists don't break mid-page */
  ul, ol, li { page-break-inside: avoid; }
  /* Phone numbers stay readable */
  .qa-phone-num, .phone-num {
    font-weight: bold !important;
    font-size: 12pt !important;
  }
  /* Quick action callouts visible on print */
  .qa-first-step, .safety-callout {
    border: 1px solid #000 !important;
    padding: 10px !important;
    margin: 10px 0 !important;
  }
  /* Page-break helpers */
  .page-break-before { page-break-before: always; }
  .page-break-after { page-break-after: always; }
}

/* ---------- ACCESSIBILITY: larger-text toggle ---------- */
/* Default body bumped from 17 to 18px elsewhere in this file. */
/* Adding ".text-large" to body increases body size for older readers. */
body.text-large {
  font-size: 21px !important;
}
body.text-large .form-row-title,
body.text-large .doc-item .doc-desc,
body.text-large .doc-row-desc {
  font-size: 17px !important;
}
body.text-large .qa-phone-num { font-size: 22px !important; }
body.text-large .phone-num { font-size: 26px !important; }
body.text-large p { font-size: 19px !important; }
body.text-large h1 { font-size: clamp(40px, 6vw, 56px) !important; }
body.text-large h2 { font-size: 26px !important; }
body.text-large h3 { font-size: 20px !important; }

.text-toggle {
  position: fixed;
  bottom: 18px;
  right: 18px;
  z-index: 1000;
  background: rgba(15, 13, 11, 0.95);
  border: 1px solid var(--gold-soft);
  padding: 8px 14px;
  font-family: var(--font-caps);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--gold);
  cursor: pointer;
  text-transform: uppercase;
  transition: all 0.2s;
}
.text-toggle:hover {
  background: rgba(122, 36, 36, 0.3);
  border-color: var(--oxblood-bright);
  color: var(--ink);
}
.text-toggle.active {
  background: rgba(122, 36, 36, 0.4);
  border-color: var(--oxblood-bright);
  color: var(--ink);
}
@media print {
  .text-toggle { display: none !important; }
}


/* ---------- FLAG WIDGET (floating, every page) ---------- */
.flag-btn {
  position: fixed;
  bottom: 18px;
  left: 18px;
  z-index: 999;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  background: rgba(15, 13, 11, 0.95);
  border: 1px solid var(--gold-soft);
  color: var(--gold);
  font-family: var(--font-caps);
  font-size: 9px;
  letter-spacing: 2px;
  cursor: pointer;
  text-transform: uppercase;
  transition: all 0.2s;
}
.flag-btn:hover {
  border-color: var(--oxblood-bright);
  background: rgba(122, 36, 36, 0.3);
  color: var(--ink);
}
.flag-btn svg { stroke: currentColor; }
@media print { .flag-btn { display: none !important; } }

/* ---------- FLAG MODAL ---------- */
.flag-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(0, 0, 0, 0.75);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: flag-fade 0.18s ease;
}
@keyframes flag-fade { from { opacity: 0; } to { opacity: 1; } }
.flag-modal {
  position: relative;
  max-width: 560px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  background: var(--bg);
  border: 1px solid var(--gold);
  padding: 32px 30px 26px;
}
.flag-modal-close {
  position: absolute;
  top: 10px;
  right: 14px;
  background: transparent;
  border: none;
  color: var(--ink-mute);
  font-size: 26px;
  cursor: pointer;
  line-height: 1;
  padding: 4px 8px;
}
.flag-modal-close:hover { color: var(--ink); }
.flag-modal-label {
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 4px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.flag-modal h2 {
  font-family: var(--font-body);
  font-size: 22px;
  color: var(--ink);
  font-weight: 500;
  margin-bottom: 6px;
}
.flag-modal-sub {
  color: var(--ink-mute);
  font-size: 14px;
  font-style: italic;
  margin-bottom: 18px;
}
.flag-field {
  display: block;
  margin-bottom: 14px;
}
.flag-field span {
  display: block;
  font-family: var(--font-caps);
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-bottom: 5px;
}
.flag-field input,
.flag-field select,
.flag-field textarea {
  width: 100%;
  padding: 10px 12px;
  background: rgba(20, 18, 16, 0.5);
  border: 1px solid var(--rule-mid);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 15px;
  outline: none;
}
.flag-field input:focus,
.flag-field select:focus,
.flag-field textarea:focus {
  border-color: var(--gold-soft);
}
.flag-field textarea { resize: vertical; min-height: 80px; }
.flag-submit-row {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 18px;
}
.flag-submit {
  padding: 10px 22px;
  background: transparent;
  border: 1px solid var(--gold);
  color: var(--gold);
  font-family: var(--font-caps);
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
}
.flag-submit:hover { background: rgba(201, 169, 97, 0.15); color: var(--ink); }
.flag-status {
  font-size: 13px;
  color: var(--ink-mute);
  font-style: italic;
}

/* ---------- SIGNUP PAGE ---------- */
.signup-hero {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
  padding: 30px 0 40px;
}
.signup-hero h1 {
  font-family: var(--font-body);
  font-size: clamp(32px, 5vw, 46px);
  letter-spacing: 4px;
  color: var(--ink);
  margin-bottom: 16px;
}
.signup-hero p {
  color: var(--ink-soft);
  font-size: 17px;
  line-height: 1.6;
  font-style: italic;
}
.signup-form-wrap {
  max-width: 540px;
  margin: 0 auto 50px;
  padding: 32px 30px;
  border: 1px solid var(--rule-mid);
  background: rgba(15, 13, 11, 0.5);
}
.signup-form-wrap form { display: block; }
.signup-form-wrap label {
  display: block;
  margin-bottom: 16px;
}
.signup-form-wrap label > span {
  display: block;
  font-family: var(--font-caps);
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.signup-form-wrap input,
.signup-form-wrap select,
.signup-form-wrap textarea {
  width: 100%;
  padding: 12px 14px;
  background: rgba(20, 18, 16, 0.5);
  border: 1px solid var(--rule-mid);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  outline: none;
}
.signup-form-wrap input:focus,
.signup-form-wrap select:focus,
.signup-form-wrap textarea:focus { border-color: var(--gold-soft); }
.signup-form-wrap textarea { resize: vertical; min-height: 70px; }
.signup-submit-row {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 12px;
}
.signup-submit {
  padding: 13px 28px;
  background: transparent;
  border: 1px solid var(--gold);
  color: var(--gold);
  font-family: var(--font-caps);
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
}
.signup-submit:hover { background: rgba(201, 169, 97, 0.15); color: var(--ink); }
.signup-privacy {
  margin-top: 26px;
  padding: 14px 16px;
  border-left: 2px solid var(--gold-soft);
  font-size: 13px;
  color: var(--ink-mute);
  line-height: 1.5;
}
.signup-status {
  font-size: 14px;
  font-style: italic;
}

/* ============================================================
   SEARCH - global Ctrl+K overlay + library page filtering
   ============================================================ */
.search-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(4px);
  z-index: 9000;
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: 80px 20px 20px;
  overflow-y: auto;
}
.search-overlay.is-open { display: flex; }

.search-modal {
  background: #16140f;
  border: 1px solid var(--rule-mid);
  width: 100%;
  max-width: 680px;
  border-radius: 4px;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.6);
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 100px);
}

.search-modal-input-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--rule);
}
.search-modal-icon { color: var(--ink-deep); flex-shrink: 0; }
#search-modal-input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px;
  padding: 6px 0;
}
#search-modal-input::placeholder { color: var(--ink-deep); }
.search-modal-esc {
  font-family: var(--font-caps);
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--ink-deep);
  border: 1px solid var(--rule-mid);
  padding: 4px 8px;
  border-radius: 2px;
}

.search-modal-results {
  overflow-y: auto;
  padding: 8px 0;
  flex: 1;
  min-height: 60px;
}

.search-modal-empty {
  padding: 28px 18px;
  color: var(--ink-mute);
  font-style: italic;
  font-size: 14px;
  text-align: center;
}
.search-modal-empty em { color: var(--gold); font-style: normal; }

.search-result {
  display: block;
  padding: 12px 18px;
  border-left: 2px solid transparent;
  color: var(--ink-soft);
  text-decoration: none;
  transition: background 0.12s, border-color 0.12s;
  cursor: pointer;
}
.search-result:hover, .search-result.is-active {
  background: rgba(201, 169, 97, 0.06);
  border-left-color: var(--gold);
}
.search-result-cluster {
  font-family: var(--font-caps);
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.search-result-title {
  color: var(--ink);
  font-size: 16px;
  line-height: 1.3;
  margin-bottom: 4px;
}
.search-result-snippet {
  font-size: 12px;
  color: var(--ink-mute);
  line-height: 1.45;
}
.search-result-snippet mark {
  background: rgba(201, 169, 97, 0.25);
  color: var(--gold);
  padding: 0 2px;
}

.search-modal-footer {
  display: flex;
  justify-content: center;
  gap: 22px;
  padding: 10px 18px;
  border-top: 1px solid var(--rule);
  color: var(--ink-deep);
  font-size: 11px;
}
.search-modal-footer kbd {
  font-family: var(--font-caps);
  font-size: 9px;
  letter-spacing: 1px;
  border: 1px solid var(--rule-mid);
  padding: 2px 6px;
  border-radius: 2px;
  margin-right: 4px;
  color: var(--ink-soft);
}

/* Library page filter results - hides non-matching doc cards */
.doc-item.is-hidden-by-search,
.cluster-block.is-hidden-by-search { display: none !important; }
