/* ============================================================
   Fly GACA — Document detail page (document.html)
   Load order: tokens.css -> base.css -> library.css -> document.css
   ============================================================ */

#main { padding-block: var(--space-6) var(--space-12); }

/* --- Breadcrumb --- */
.breadcrumb {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2);
  font-family: var(--font-mono); font-size: var(--fs-xs);
  color: var(--text-dim); margin-block-end: var(--space-6);
}
.breadcrumb a { color: var(--text-muted); }
.breadcrumb a:hover { color: var(--text); }
.breadcrumb .sep { color: var(--border-bright); }
.breadcrumb .current { color: var(--text-muted); }

/* --- Detail header --- */
.detail-header { margin-block-end: var(--space-6); }
.detail-badges {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-3);
  margin-block-end: var(--space-4);
}
.detail-header h1 {
  font-size: var(--fs-h1); letter-spacing: -0.02em;
  margin-block-end: var(--space-3);
}
.detail-meta {
  display: flex; flex-wrap: wrap; gap: var(--space-2) var(--space-4);
  color: var(--text-dim); font-family: var(--font-mono); font-size: var(--fs-xs);
}
.detail-meta span { display: inline-flex; align-items: center; gap: var(--space-2); }
.detail-meta .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--accent); }

/* --- Layout: main + aside --- */
.detail-grid {
  display: grid; grid-template-columns: minmax(0, 1.7fr) 1fr;
  gap: var(--space-6); align-items: start;
  margin-block-start: var(--space-6);
}

/* --- Main content --- */
.detail-section + .detail-section { margin-block-start: var(--space-8); }
.detail-section h2 {
  font-size: var(--fs-h3); margin-block-end: var(--space-4);
}
.detail-blurb { color: var(--text-muted); font-size: var(--fs-lg); line-height: var(--lh-body); }
.detail-blurb + .detail-blurb { margin-block-start: var(--space-4); }

/* Outline list (subparts) */
.outline-list { display: flex; flex-direction: column; gap: var(--space-2); }
.outline-item {
  display: flex; align-items: center; gap: var(--space-3);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
}
.outline-item .ol-key {
  font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-bold);
  color: var(--accent-bright);
  background: rgba(45,110,138,0.18);
  border: 1px solid rgba(74,156,184,0.30);
  border-radius: var(--radius-sm);
  padding: 0.22rem 0.5rem; white-space: nowrap; flex: none;
}
.outline-item .ol-name { font-size: var(--fs-sm); }
.outline-empty { color: var(--text-dim); font-size: var(--fs-sm); }

/* --- Aside: official-source panel --- */
.source-panel {
  background: var(--surface);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  position: sticky; top: calc(var(--nav-h) + var(--space-4));
}
.source-panel h2 {
  font-family: var(--font-mono); font-size: var(--fs-xs);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-dim); margin-block-end: var(--space-3);
}
.source-panel p { color: var(--text-muted); font-size: var(--fs-sm); margin-block-end: var(--space-4); }
.source-panel .btn { width: 100%; }
.source-panel .verify-note {
  margin-block-start: var(--space-4); padding-block-start: var(--space-4);
  border-block-start: 1px solid var(--border);
  color: var(--text-dim); font-size: var(--fs-xs); line-height: var(--lh-snug);
}

/* --- Back link --- */
.detail-back { margin-block-start: var(--space-10); }
.detail-back a { color: var(--link); font-weight: var(--fw-semibold); }

/* --- Error --- */
.detail-error { padding-block: var(--space-12); text-align: center; }
.detail-error h1 { font-size: var(--fs-h2); margin-block-end: var(--space-3); }
.detail-error p { color: var(--text-muted); margin-block-end: var(--space-5); }

/* --- In-app reader (regulations) --- */
.reader-notice {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  margin-block-end: var(--space-5);
  color: var(--text-muted); font-size: var(--fs-sm); line-height: var(--lh-snug);
}
.reader-notice strong { color: var(--text); }

.reader-aside { display: flex; flex-direction: column; gap: var(--space-5); }

.toc-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
}
.toc-panel h2 {
  font-family: var(--font-mono); font-size: var(--fs-xs);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-dim); margin-block-end: var(--space-3);
}
.toc-panel ul { display: flex; flex-direction: column; gap: var(--space-2); }
.toc-panel a { color: var(--text-muted); font-size: var(--fs-sm); }
.toc-panel a:hover { color: var(--accent-bright); }

.related-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
}
.related-panel h2 {
  font-family: var(--font-mono); font-size: var(--fs-xs);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-dim); margin-block-end: var(--space-3);
}
.related-panel ul { list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: var(--space-2); }
.related-panel a {
  display: block; text-decoration: none;
  padding: var(--space-2); border-radius: var(--radius-md);
}
.related-panel a:hover { background: rgba(255, 255, 255, 0.04); }
.rel-badge {
  display: block; font-size: var(--fs-xs); font-weight: var(--fw-bold);
  letter-spacing: 0.04em; color: var(--teal-bright); margin-block-end: 2px;
}
.rel-title { display: block; font-size: var(--fs-sm); color: var(--text-muted); }
.related-panel a:hover .rel-title { color: var(--text); }

.faa-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-inline-start: 3px solid var(--teal-bright);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
}
.faa-panel h2 {
  font-family: var(--font-mono); font-size: var(--fs-xs);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-dim); margin-block-end: var(--space-3);
}
.faa-panel p { color: var(--text-muted); font-size: var(--fs-sm); margin-block-end: var(--space-4); }
.faa-panel .btn { width: 100%; }

/* The reading surface — dark, matching the rest of the app. */
.reader {
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: clamp(1.4rem, 1rem + 2.4vw, 3.1rem);
  font-size: 1.02rem;
  line-height: 1.75;
  overflow-wrap: break-word;
  min-width: 0;
}
/* Wide regulation tables scroll within the column, not the page. */
.reader .reg-scroll { overflow-x: auto; margin-block: 1.3rem; }
.reader .reg-scroll table { margin-block: 0; }
.reader > *:first-child { margin-block-start: 0 !important; }
.reader h2 {
  color: var(--teal-bright);
  font-size: 1.5rem; font-weight: var(--fw-black); letter-spacing: -0.01em;
  margin-block: 2.4rem 1rem;
  padding-block-start: 1.4rem;
  border-block-start: 1px solid var(--border);
}
.reader h3 {
  color: var(--text);
  font-size: 1.1rem; font-weight: var(--fw-bold);
  margin-block: 1.7rem 0.5rem;
}
.reader p { margin-block: 0 0.8rem; }
.reader strong { color: var(--text); font-weight: var(--fw-semibold); }
.reader a { color: var(--link); text-decoration: underline; }
.reader ul, .reader ol { margin: 0 0 0.8rem; padding-inline-start: 1.4em; }
.reader li { margin-block: 0.2rem; }
.reader li::marker { color: var(--teal-bright); }
.reader-loading { color: var(--text-dim); }
.reader h2, .reader h3 { scroll-margin-top: 88px; }
.reader .reader-target {
  background: rgba(74,156,184,0.20);
  border-radius: 6px;
  padding-inline: 8px; margin-inline: -8px;
}
.reader-fallback ul { padding-inline-start: 1.3em; margin-block: 0.6rem 0.9rem; }

/* Tables inside the reader */
.reader .reg-table { margin-block: 1.3rem; overflow-x: auto; }
.reader .reg-table table { border-collapse: collapse; width: 100%; font-size: 0.88rem; }
.reader .reg-table th, .reader .reg-table td {
  border: 1px solid var(--border); padding: 0.42rem 0.6rem;
  text-align: start; vertical-align: top;
}
.reader .reg-table th { background: var(--surface-raised); color: var(--text); font-weight: var(--fw-semibold); }
.reader figcaption { font-size: 0.85rem; color: var(--text-dim); margin-block-start: 0.4rem; }

/* --- Aerodrome dashboard --- */
.fact-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }
.fact-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  display: flex; flex-direction: column;
}
.fact-label {
  font-family: var(--font-mono); font-size: var(--fs-xs);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-dim); margin-block-end: var(--space-3);
}
.fact-value { font-size: 1.05rem; font-weight: var(--fw-semibold); color: var(--text); }
.fact-value.fact-big { font-size: 1.7rem; font-weight: var(--fw-black); letter-spacing: -0.02em; }
.fact-sub { font-size: var(--fs-sm); color: var(--text-muted); margin-block-start: var(--space-1); }
.fact-link { margin-block-start: var(--space-3); font-size: var(--fs-sm); font-weight: var(--fw-semibold); }

.rwy-list { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.rwy-pill {
  font-family: var(--font-mono); font-weight: var(--fw-bold); font-size: var(--fs-sm);
  color: var(--accent-bright);
  background: rgba(45,110,138,0.18);
  border: 1px solid rgba(74,156,184,0.30);
  border-radius: var(--radius-sm);
  padding: 0.3rem 0.62rem;
}
.freq-list { display: flex; flex-direction: column; gap: var(--space-2); }
.freq-row { display: flex; justify-content: space-between; gap: var(--space-3); }
.freq-svc {
  font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-bold);
  letter-spacing: 0.06em; color: var(--text-muted);
}
.freq-val { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--accent-bright); }

@media (max-width: 760px) {
  .detail-grid { grid-template-columns: minmax(0, 1fr); }
  .source-panel { position: static; }
  .reader-aside { order: 2; }
}
@media (max-width: 520px) {
  .fact-grid { grid-template-columns: 1fr; }
}

/* --- VFR chart viewer --- */
.chart-toolbar {
  display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center;
  gap: var(--space-3); margin-block-end: var(--space-3);
}
.chart-hint { color: var(--text-dim); font-size: var(--fs-sm); }
.chart-open { font-size: var(--fs-sm); font-weight: var(--fw-semibold); }
.chart-viewer {
  height: 74vh; min-height: 440px; width: 100%;
  background: var(--falcon-deep);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.chart-msg { padding: var(--space-8); text-align: center; color: var(--text-muted); }
.chart-foot {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-4);
  justify-content: space-between; margin-block-start: var(--space-5);
}
.chart-foot p { color: var(--text-dim); font-size: var(--fs-sm); max-width: 48ch; }
.leaflet-container { background: var(--falcon-deep); }

/* --- In-document find (Cmd / Ctrl + K) --- */
.doc-find {
  position: fixed; z-index: 150;
  inset-block-start: calc(var(--nav-h) + var(--space-3));
  inset-inline-end: var(--space-5);
  display: flex; align-items: center; gap: var(--space-2);
  background: var(--surface-raised);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-pill);
  padding: 0.4rem 0.5rem 0.4rem 0.9rem;
  box-shadow: var(--shadow-pop);
}
.doc-find-ic { color: var(--text-dim); flex: none; }
.doc-find-input {
  background: transparent; border: 0; outline: none;
  color: var(--text); font-size: var(--fs-sm);
  width: clamp(150px, 32vw, 240px);
}
.doc-find-input::placeholder { color: var(--text-dim); }
.doc-find-count {
  font-family: var(--font-mono); font-size: var(--fs-xs);
  color: var(--text-dim); white-space: nowrap;
  min-width: 3.6em; text-align: center;
}
.doc-find-btn {
  background: transparent; border: 1px solid transparent;
  color: var(--text-muted); cursor: pointer;
  width: 26px; height: 26px; border-radius: var(--radius-sm);
  display: grid; place-items: center; font-size: var(--fs-sm); line-height: 1;
}
.doc-find-btn:hover {
  background: var(--surface); color: var(--text);
  border-color: var(--border-bright);
}
mark.doc-find-hit {
  background: rgba(200, 160, 74, 0.42);
  color: inherit; border-radius: 2px;
}
mark.doc-find-current {
  background: var(--falcon-gold); color: var(--falcon-night);
}
@media (max-width: 520px) {
  .doc-find { inset-inline: var(--space-4); }
  .doc-find-input { width: 100%; flex: 1; min-width: 0; }
}

/* --- Currency stamp ("Last synced with GACA") + in-page-find hint --- */
.currency-stamp {
  display: flex; gap: var(--space-3); align-items: flex-start;
  margin-block-end: var(--space-5);
  padding: var(--space-3) var(--space-4);
  background: var(--surface);
  border: 1px solid var(--border-bright);
  border-inline-start: 3px solid var(--text-dim);
  border-radius: var(--radius-md);
  color: var(--text-muted); font-size: var(--fs-sm); line-height: var(--lh-snug);
}
.currency-stamp .cs-body { display: flex; flex-direction: column; gap: 3px; }
.currency-stamp strong { color: var(--text); font-weight: var(--fw-semibold); }
.cs-dot {
  width: 10px; height: 10px; border-radius: 50%;
  flex: none; margin-block-start: 4px; background: var(--text-dim);
}
.currency-stamp.cs-fresh { border-inline-start-color: var(--success); }
.currency-stamp.cs-fresh .cs-dot { background: var(--success); }
.currency-stamp.cs-aging { border-inline-start-color: var(--gold); }
.currency-stamp.cs-aging .cs-dot { background: var(--gold); }
.reader-kbd-hint { color: var(--text-dim); white-space: nowrap; }

/* --- In-document find trigger button --- */
.doc-find-trigger {
  position: fixed; z-index: 140;
  inset-block-start: calc(var(--nav-h) + var(--space-3));
  inset-inline-end: var(--space-5);
  display: inline-flex; align-items: center; gap: var(--space-2);
  background: var(--surface-raised);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-pill);
  color: var(--text-muted);
  padding: 0.42rem 0.9rem;
  font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  font-family: var(--font-sans);
  cursor: pointer; box-shadow: var(--shadow-card);
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.doc-find-trigger:hover { color: var(--text); border-color: var(--teal-bright); }
.doc-find-trigger[hidden] { display: none; }

/* --- Bookmark ("Save to My Library") button --- */
.bookmark-btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  margin-block-start: var(--space-4);
  background: transparent;
  border: 1px solid var(--border-bright);
  color: var(--text-muted);
  border-radius: var(--radius-pill);
  padding: 0.42rem 0.95rem;
  font-size: var(--fs-sm); font-weight: var(--fw-semibold);
  font-family: var(--font-sans); cursor: pointer;
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.bookmark-btn:hover { border-color: var(--teal-bright); color: var(--text); }
.bookmark-btn.on { border-color: var(--gold); color: var(--gold); }

/* --- Report-an-issue link --- */
.report-issue-wrap { margin-block-start: var(--space-3); }
.report-issue {
  display: inline-flex; align-items: center; gap: var(--space-2);
  color: var(--text-dim); font-size: var(--fs-sm);
}
.report-issue:hover { color: var(--text-muted); }
.report-issue svg { flex: none; }
