/* ═══════════════════════════════════════════════════════════════
   BlueprintCoach — Design System
   Movement: LONGITUDINAL QUIET
   Aesthetic of patient observation. Discipline is subtraction.
   ═══════════════════════════════════════════════════════════════ */

/* ───────────────────────────────────────────────────────────────
   1. TOKENS
   ─────────────────────────────────────────────────────────────── */
:root {
  /* Surfaces */
  --bq-ink:        #06060f;        /* the matte field */
  --bq-ink-2:      #0b0b15;        /* subtle elevation */
  --bq-ink-3:      #11111c;        /* card */
  --bq-dark:       #1c1e26;        /* grid lines */
  --bq-darker:     #363a44;        /* hairline separators */

  /* Type */
  --bq-paper:      #d6d8dc;        /* primary text — warm paper */
  --bq-dim:        #60646c;        /* marginalia / labels */
  --bq-dim-2:      #44474f;        /* tertiary */

  /* Accent — slate (the only accent, rationed) */
  --bq-slate:      #6e8ea8;        /* primary accent */
  --bq-slate-dim:  #4a6478;        /* hover/secondary state */

  /* Semantic (very restrained — used only for compliance/danger states) */
  --bq-amber:      #b08c4a;        /* warn — patinated brass, not yellow */
  --bq-rust:       #a35b4f;        /* danger — oxidized iron, not red */

  /* Typography stacks */
  --bq-font-display: 'Jura', 'Inter', system-ui, -apple-system, sans-serif;
  --bq-font-sans:    'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
  --bq-font-mono:    'Geist Mono', 'JetBrains Mono', 'IBM Plex Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  /* Type scale — typography-first hierarchy lives here */
  --bq-fs-micro:   11px;     /* tiny marginalia */
  --bq-fs-meta:    12px;     /* meta labels */
  --bq-fs-tiny:    13px;     /* small */
  --bq-fs-body:    14px;     /* body */
  --bq-fs-md:      16px;     /* slightly emphasised */
  --bq-fs-lg:      20px;     /* section heads */
  --bq-fs-xl:      28px;     /* reading values */
  --bq-fs-2xl:     40px;     /* large reading */
  --bq-fs-3xl:     64px;     /* hero numeral */

  /* Weights */
  --bq-fw-light:   300;
  --bq-fw-regular: 400;
  --bq-fw-medium:  500;

  /* Spacing scale (4px base) */
  --bq-s-1:  4px;
  --bq-s-2:  8px;
  --bq-s-3:  12px;
  --bq-s-4:  16px;
  --bq-s-5:  24px;
  --bq-s-6:  32px;
  --bq-s-7:  48px;
  --bq-s-8:  64px;
  --bq-s-9:  96px;

  /* Layout */
  --bq-max-w:      1280px;
  --bq-radius:     2px;        /* nearly square — clinical */
  --bq-radius-lg:  4px;

  /* Hairlines */
  --bq-hair:       1px solid var(--bq-darker);
  --bq-hair-faint: 1px solid var(--bq-dark);
  --bq-hair-slate: 1px solid var(--bq-slate-dim);

  /* Motion — restrained */
  --bq-ease:       cubic-bezier(0.4, 0, 0.2, 1);
  --bq-dur-fast:   120ms;
  --bq-dur:        180ms;
}

/* ───────────────────────────────────────────────────────────────
   2. RESET
   ─────────────────────────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html, body {
  height: 100%;
}

body {
  background: var(--bq-ink);
  color: var(--bq-paper);
  font-family: var(--bq-font-sans);
  font-size: var(--bq-fs-body);
  font-weight: var(--bq-fw-regular);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'tnum' 1, 'cv11' 1;   /* tabular figures by default for body too */
}

a {
  color: var(--bq-paper);
  text-decoration: none;
  border-bottom: 1px solid var(--bq-dim-2);
  transition: color var(--bq-dur) var(--bq-ease), border-color var(--bq-dur) var(--bq-ease);
}
a:hover { color: var(--bq-slate); border-bottom-color: var(--bq-slate); }

button {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
  background: transparent;
  border: 0;
  cursor: pointer;
}

input, textarea, select {
  font-family: inherit;
  font-size: inherit;
  color: var(--bq-paper);
  background: transparent;
  border: 0;
  outline: none;
}

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bq-ink); }
::-webkit-scrollbar-thumb { background: var(--bq-dark); }
::-webkit-scrollbar-thumb:hover { background: var(--bq-darker); }

::selection { background: var(--bq-slate-dim); color: var(--bq-ink); }

/* ───────────────────────────────────────────────────────────────
   3. TYPOGRAPHY UTILITIES
   ─────────────────────────────────────────────────────────────── */
.bq-mono     { font-family: var(--bq-font-mono); font-feature-settings: 'tnum' 1, 'zero' 1; }
.bq-display  { font-family: var(--bq-font-display); font-weight: var(--bq-fw-light); letter-spacing: 0.02em; }

.bq-micro    { font-size: var(--bq-fs-micro);  letter-spacing: 0.05em; }
.bq-meta     { font-size: var(--bq-fs-meta);   letter-spacing: 0.04em; }
.bq-tiny     { font-size: var(--bq-fs-tiny); }
.bq-body     { font-size: var(--bq-fs-body); }
.bq-md       { font-size: var(--bq-fs-md); }
.bq-lg       { font-size: var(--bq-fs-lg); }
.bq-xl       { font-size: var(--bq-fs-xl); }
.bq-2xl      { font-size: var(--bq-fs-2xl); }
.bq-3xl      { font-size: var(--bq-fs-3xl); }

.bq-light    { font-weight: var(--bq-fw-light); }
.bq-regular  { font-weight: var(--bq-fw-regular); }
.bq-medium   { font-weight: var(--bq-fw-medium); }

.bq-paper    { color: var(--bq-paper); }
.bq-dim      { color: var(--bq-dim); }
.bq-dim-2    { color: var(--bq-dim-2); }
.bq-slate    { color: var(--bq-slate); }

.bq-uppercase { text-transform: uppercase; letter-spacing: 0.08em; }

/* ───────────────────────────────────────────────────────────────
   4. LAYOUT PRIMITIVES
   ─────────────────────────────────────────────────────────────── */
.bq-shell {
  max-width: var(--bq-max-w);
  margin: 0 auto;
  padding: 0 var(--bq-s-6);
}

.bq-section {
  padding: var(--bq-s-7) 0;
}

.bq-rule {
  border: 0;
  border-top: var(--bq-hair);
  margin: 0;
}

.bq-rule-faint { border-top: var(--bq-hair-faint); }
.bq-rule-slate { border-top: var(--bq-hair-slate); }

/* corner brackets — the only frame we use */
.bq-brackets {
  position: relative;
}
.bq-brackets::before,
.bq-brackets::after {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  border: 0 solid var(--bq-darker);
}
.bq-brackets::before {
  top: 0; left: 0;
  border-top-width: 1px;
  border-left-width: 1px;
}
.bq-brackets::after {
  bottom: 0; right: 0;
  border-bottom-width: 1px;
  border-right-width: 1px;
}
.bq-brackets-full > *::before,
.bq-brackets-full > *::after { /* placeholder for future 4-corner variant */ }

/* ───────────────────────────────────────────────────────────────
   5. NAV / HEADER
   ─────────────────────────────────────────────────────────────── */
.bq-header {
  border-bottom: var(--bq-hair);
  background: var(--bq-ink);
  position: sticky;
  top: 0;
  z-index: 10;
}
.bq-header-inner {
  max-width: var(--bq-max-w);
  margin: 0 auto;
  padding: var(--bq-s-4) var(--bq-s-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--bq-s-5);
}
.bq-brand {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-meta);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bq-paper);
}
.bq-brand-sub {
  color: var(--bq-dim);
  margin-left: var(--bq-s-3);
}

.bq-nav {
  display: flex;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: thin;
}
.bq-nav-item {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-meta);
  letter-spacing: 0.06em;
  text-transform: lowercase;
  color: var(--bq-dim);
  padding: var(--bq-s-3) var(--bq-s-4);
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  cursor: pointer;
  transition: color var(--bq-dur) var(--bq-ease), border-color var(--bq-dur) var(--bq-ease);
}
.bq-nav-item:hover { color: var(--bq-paper); }
.bq-nav-item.is-active {
  color: var(--bq-paper);
  border-bottom-color: var(--bq-slate);
}

/* ───────────────────────────────────────────────────────────────
   6. READING CARD — the "lastra" idiom
   ─────────────────────────────────────────────────────────────── */
.bq-reading {
  position: relative;
  padding: var(--bq-s-5);
}
.bq-reading-eyebrow {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-micro);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bq-dim);
  margin-bottom: var(--bq-s-3);
  padding-bottom: var(--bq-s-2);
  border-bottom: var(--bq-hair-slate);
  display: inline-block;
}
.bq-reading-value {
  font-family: var(--bq-font-display);
  font-weight: var(--bq-fw-light);
  font-size: var(--bq-fs-3xl);
  line-height: 1;
  color: var(--bq-paper);
  letter-spacing: 0.01em;
  display: inline-flex;
  align-items: baseline;
  gap: var(--bq-s-2);
}
.bq-reading-value-sm {
  font-size: var(--bq-fs-2xl);
}
.bq-reading-unit {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-tiny);
  color: var(--bq-dim);
  font-weight: var(--bq-fw-regular);
}
.bq-reading-sub {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-micro);
  letter-spacing: 0.04em;
  color: var(--bq-dim);
  margin-top: var(--bq-s-3);
}

/* a small tick mark under a numeral cluster */
.bq-reading-tick {
  width: 24px;
  height: 1px;
  background: var(--bq-darker);
  margin-top: var(--bq-s-4);
}

/* ───────────────────────────────────────────────────────────────
   7. GRID & ROWS
   ─────────────────────────────────────────────────────────────── */
.bq-grid {
  display: grid;
  gap: var(--bq-s-5);
}
.bq-grid-2 { grid-template-columns: repeat(2, 1fr); }
.bq-grid-3 { grid-template-columns: repeat(3, 1fr); }
.bq-grid-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 920px) {
  .bq-grid-3, .bq-grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .bq-grid-2, .bq-grid-3, .bq-grid-4 { grid-template-columns: 1fr; }
}

/* tabular row — for biomarker/value lists */
.bq-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: var(--bq-s-3) 0;
  border-bottom: var(--bq-hair-faint);
}
.bq-row:last-child { border-bottom: 0; }
.bq-row-label {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-tiny);
  color: var(--bq-dim);
  letter-spacing: 0.04em;
}
.bq-row-value {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-body);
  color: var(--bq-paper);
  font-feature-settings: 'tnum' 1;
}
.bq-row-unit {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-micro);
  color: var(--bq-dim);
  margin-left: var(--bq-s-2);
}

/* ───────────────────────────────────────────────────────────────
   8. PANELS — bracketed containers
   ─────────────────────────────────────────────────────────────── */
.bq-panel {
  position: relative;
  padding: var(--bq-s-5) var(--bq-s-5);
  background: transparent;
}
.bq-panel-title {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-micro);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bq-dim);
  margin-bottom: var(--bq-s-4);
  padding-bottom: var(--bq-s-2);
  border-bottom: var(--bq-hair-faint);
}

/* ───────────────────────────────────────────────────────────────
   9. INPUTS — minimal, hairline underlines
   ─────────────────────────────────────────────────────────────── */
.bq-field {
  display: flex;
  flex-direction: column;
  gap: var(--bq-s-2);
}
.bq-label {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-micro);
  letter-spacing: 0.08em;
  text-transform: lowercase;
  color: var(--bq-dim);
}
.bq-input,
.bq-textarea,
.bq-select {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-body);
  color: var(--bq-paper);
  background: transparent;
  padding: var(--bq-s-2) 0;
  border: 0;
  border-bottom: var(--bq-hair);
  width: 100%;
  font-feature-settings: 'tnum' 1;
  transition: border-color var(--bq-dur) var(--bq-ease);
}
.bq-input:focus,
.bq-textarea:focus,
.bq-select:focus {
  outline: none;
  border-bottom-color: var(--bq-slate);
}
.bq-textarea { min-height: 100px; resize: vertical; line-height: 1.5; }
.bq-input::placeholder,
.bq-textarea::placeholder { color: var(--bq-dim-2); }

/* ───────────────────────────────────────────────────────────────
   10. BUTTONS
   ─────────────────────────────────────────────────────────────── */
.bq-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--bq-s-2);
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-tiny);
  letter-spacing: 0.06em;
  text-transform: lowercase;
  color: var(--bq-paper);
  padding: var(--bq-s-2) var(--bq-s-4);
  border: var(--bq-hair);
  background: transparent;
  cursor: pointer;
  transition: border-color var(--bq-dur) var(--bq-ease), color var(--bq-dur) var(--bq-ease);
}
.bq-btn:hover { border-color: var(--bq-slate); color: var(--bq-slate); }
.bq-btn:disabled { color: var(--bq-dim-2); border-color: var(--bq-dark); cursor: not-allowed; }

.bq-btn-primary {
  border-color: var(--bq-slate-dim);
  color: var(--bq-slate);
}
.bq-btn-primary:hover { border-color: var(--bq-slate); color: var(--bq-paper); background: rgba(110, 142, 168, 0.04); }

.bq-btn-ghost { border-color: transparent; padding-left: 0; padding-right: 0; }
.bq-btn-ghost:hover { border-color: transparent; }

/* ───────────────────────────────────────────────────────────────
   11. STATES — kept very small
   ─────────────────────────────────────────────────────────────── */
.bq-state-loading {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-meta);
  color: var(--bq-dim);
  letter-spacing: 0.08em;
}
.bq-state-loading::after {
  content: "—";
  display: inline-block;
  margin-left: var(--bq-s-2);
  animation: bq-pulse 1.6s ease-in-out infinite;
}
@keyframes bq-pulse {
  0%, 100% { opacity: 0.3; }
  50%      { opacity: 1;   }
}
.bq-state-error {
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-tiny);
  color: var(--bq-rust);
}

/* ───────────────────────────────────────────────────────────────
   12. TOAST
   ─────────────────────────────────────────────────────────────── */
.bq-toast {
  position: fixed;
  bottom: var(--bq-s-6);
  right: var(--bq-s-6);
  padding: var(--bq-s-3) var(--bq-s-4);
  background: var(--bq-ink-3);
  border: var(--bq-hair);
  border-left: 2px solid var(--bq-slate);
  color: var(--bq-paper);
  font-family: var(--bq-font-mono);
  font-size: var(--bq-fs-tiny);
  z-index: 100;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity var(--bq-dur) var(--bq-ease), transform var(--bq-dur) var(--bq-ease);
  pointer-events: none;
  max-width: 360px;
}
.bq-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.bq-toast.is-error { border-left-color: var(--bq-rust); }
.bq-toast.is-warn  { border-left-color: var(--bq-amber); }

/* ───────────────────────────────────────────────────────────────
   13. CHART CANVAS — common wrapper
   ─────────────────────────────────────────────────────────────── */
.bq-chart {
  position: relative;
  width: 100%;
  height: 180px;
}
.bq-chart canvas { display: block; width: 100% !important; height: 100% !important; }

/* ───────────────────────────────────────────────────────────────
   14. UTILITIES
   ─────────────────────────────────────────────────────────────── */
.bq-flex { display: flex; }
.bq-flex-col { display: flex; flex-direction: column; }
.bq-items-center { align-items: center; }
.bq-items-baseline { align-items: baseline; }
.bq-justify-between { justify-content: space-between; }
.bq-gap-1 { gap: var(--bq-s-1); }
.bq-gap-2 { gap: var(--bq-s-2); }
.bq-gap-3 { gap: var(--bq-s-3); }
.bq-gap-4 { gap: var(--bq-s-4); }
.bq-gap-5 { gap: var(--bq-s-5); }
.bq-gap-6 { gap: var(--bq-s-6); }

.bq-mt-1 { margin-top: var(--bq-s-1); }
.bq-mt-2 { margin-top: var(--bq-s-2); }
.bq-mt-3 { margin-top: var(--bq-s-3); }
.bq-mt-4 { margin-top: var(--bq-s-4); }
.bq-mt-5 { margin-top: var(--bq-s-5); }
.bq-mt-6 { margin-top: var(--bq-s-6); }

.bq-mb-1 { margin-bottom: var(--bq-s-1); }
.bq-mb-2 { margin-bottom: var(--bq-s-2); }
.bq-mb-3 { margin-bottom: var(--bq-s-3); }
.bq-mb-4 { margin-bottom: var(--bq-s-4); }
.bq-mb-5 { margin-bottom: var(--bq-s-5); }
.bq-mb-6 { margin-bottom: var(--bq-s-6); }

.bq-hidden { display: none !important; }
.bq-tnum { font-feature-settings: 'tnum' 1; }
