/* ============================================================
   SEANFITZ DESIGN SYSTEM — v1.0
   ============================================================
   archival academia × technical reference
   auto theme: light = parchment/ink. dark = ink/parchment.
   ============================================================ */

/* ---------- font imports ---------- */
@import url('https://cdn.jsdelivr.net/npm/hack-font@3.3.0/build/web/hack.css');
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&display=swap');

/* ============================================================
   TOKENS
   ============================================================ */

:root {
  /* foundation — warm neutral ramp */
  --linen:     #F4EFE3;
  --parchment: #E8E2D3;
  --stone:     #B4B2A9;
  --lead:      #5F5E5A;
  --iron:      #2C2A26;
  --ink:       #1C1A17;

  /* accents — used sparingly, one per surface */
  --oxblood:   #7A2E1E;
  --brass:     #A87332;
  --verdigris: #1F4D44;
  --indigo:    #23395B;

  /* semantic — these flip in dark mode */
  --bg:           var(--linen);
  --bg-alt:       var(--parchment);
  --fg:           var(--ink);
  --fg-soft:      var(--iron);
  --fg-muted:     var(--lead);
  --fg-faint:     var(--stone);
  --rule:         var(--stone);
  --rule-strong:  var(--ink);
  --tick:         var(--oxblood);

  /* type stacks */
  --serif: 'EB Garamond', Georgia, 'Times New Roman', serif;
  --mono:  'Hack', ui-monospace, 'SF Mono', Menlo, Consolas, monospace;

  /* scale */
  --type-xs:   11px;
  --type-sm:   13px;
  --type-base: 17px;
  --type-md:   18px;
  --type-lg:   22px;
  --type-xl:   28px;
  --type-2xl:  36px;
  --type-3xl:  48px;
  --type-hero: 72px;

  /* spacing rhythm */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-8: 3rem;
  --space-10: 4rem;

  /* rule weights */
  --rule-thin:  0.5px;
  --rule-mid:   0.75px;
  --rule-thick: 1px;

  /* layout */
  --measure: 680px;
  --gutter:  1.5rem;
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg:          var(--ink);
    --bg-alt:      var(--iron);
    --fg:          var(--linen);
    --fg-soft:     var(--parchment);
    --fg-muted:    var(--stone);
    --fg-faint:    var(--lead);
    --rule:        var(--lead);
    --rule-strong: var(--linen);
    --tick:        var(--brass);
  }
}

/* ============================================================
   RESET & BASE
   ============================================================ */

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--serif);
  font-size: var(--type-base);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ============================================================
   PAGE FRAME
   ============================================================ */

.page {
  max-width: var(--measure);
  margin: 0 auto;
  padding: var(--space-10) var(--gutter);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.page--wide {
  max-width: 960px;
}

/* ============================================================
   THE MARKS
   ============================================================ */

/* shared mark base */
.mark {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  font-family: var(--mono);
  font-size: var(--type-base);
  font-weight: 400;
  color: var(--fg);
  line-height: 1;
  letter-spacing: -0.3px;
  text-decoration: none;
}

.mark--lg  { font-size: 28px; gap: 10px; letter-spacing: -1px; }
.mark--xl  { font-size: 48px; gap: 16px; letter-spacing: -2px; }
.mark--hero { font-size: 72px; gap: 24px; letter-spacing: -3px; }

/* ACTIVE MARK — wordmark + blinking cursor */
.mark--active .cursor {
  display: inline-block;
  width: 8px;
  height: 2px;
  background: var(--tick);
  animation: cursor-blink 1.1s steps(1) infinite;
}

.mark--active.mark--lg  .cursor { width: 13px; height: 3px; }
.mark--active.mark--xl  .cursor { width: 22px; height: 5px; }
.mark--active.mark--hero .cursor { width: 32px; height: 7px; }

@keyframes cursor-blink {
  0%, 49%   { opacity: 1; }
  50%, 100% { opacity: 0; }
}

/* honor reduced motion: no blink, but tick stays visible */
@media (prefers-reduced-motion: reduce) {
  .mark--active .cursor { animation: none; }
}

/* STATIC MARK — wordmark + square wave + tick */
/* the SVG is inline and inherits currentColor for the wave;
   the tick is the only colored element. */
.mark--static .wave {
  display: inline-block;
  height: 1em;
  vertical-align: baseline;
}

.mark--static .wave .stroke {
  fill: none;
  stroke: currentColor;
  stroke-width: 0.75;
}

.mark--static.mark--lg  .wave .stroke { stroke-width: 1; }
.mark--static.mark--xl  .wave .stroke { stroke-width: 1.5; }
.mark--static.mark--hero .wave .stroke { stroke-width: 2; }

.mark--static .wave .tick {
  fill: var(--tick);
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */

.kicker {
  font-family: var(--mono);
  font-size: var(--type-xs);
  color: var(--fg-muted);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin: 0 0 var(--space-3) 0;
}

.title {
  font-family: var(--serif);
  font-size: var(--type-2xl);
  font-weight: 500;
  line-height: 1.1;
  color: var(--fg);
  margin: 0 0 var(--space-2) 0;
  letter-spacing: -0.5px;
}

.title--lg { font-size: var(--type-3xl); line-height: 1.05; }
.title--hero { font-size: var(--type-hero); line-height: 1; letter-spacing: -2px; }

.subtitle {
  font-family: var(--serif);
  font-size: var(--type-md);
  font-style: italic;
  font-weight: 400;
  line-height: 1.4;
  color: var(--fg-soft);
  margin: 0 0 var(--space-6) 0;
}

.title-rule {
  width: 48px;
  height: 1px;
  background: var(--tick);
  margin: 0 0 var(--space-6) 0;
  border: none;
}

/* prose body */
.prose p {
  margin: 0 0 var(--space-4) 0;
  font-family: var(--serif);
}

.prose h2 {
  font-family: var(--serif);
  font-size: var(--type-lg);
  font-weight: 500;
  margin: var(--space-6) 0 var(--space-3) 0;
  letter-spacing: -0.2px;
}

.prose h3 {
  font-family: var(--mono);
  font-size: var(--type-sm);
  font-weight: 400;
  color: var(--fg-muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin: var(--space-5) 0 var(--space-2) 0;
}

.prose a {
  color: var(--fg);
  text-decoration: underline;
  text-decoration-color: var(--tick);
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.prose a:hover { text-decoration-thickness: 2px; }

.prose em { font-style: italic; }
.prose strong { font-weight: 500; }

.prose blockquote {
  margin: var(--space-5) 0;
  padding-left: var(--space-4);
  border-left: var(--rule-thin) solid var(--rule-strong);
  font-style: italic;
  color: var(--fg-soft);
}

/* dropcap — opt-in, applied to any p */
.dropcap::first-letter {
  font-size: 1.2em;
  font-weight: 500;
}

/* ============================================================
   CODE
   ============================================================ */

.prose code,
code.inline {
  font-family: var(--mono);
  font-size: 0.88em;
  background: var(--bg-alt);
  padding: 1px 5px;
  border-radius: 2px;
}

.prose pre,
pre.block {
  font-family: var(--mono);
  font-size: var(--type-sm);
  background: var(--bg-alt);
  border-left: 2px solid var(--tick);
  padding: var(--space-4) var(--space-5);
  overflow-x: auto;
  margin: var(--space-5) 0;
  line-height: 1.6;
}

.prose pre code,
pre.block code {
  background: transparent;
  padding: 0;
  font-size: inherit;
}

/* ============================================================
   HEADER & FOOTER (title-block pattern)
   ============================================================ */

.header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding-bottom: var(--space-3);
  border-bottom: var(--rule-thin) solid var(--rule-strong);
  margin-bottom: var(--space-6);
}

.header-meta {
  font-family: var(--mono);
  font-size: var(--type-xs);
  color: var(--fg-muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
}

.footer {
  margin-top: var(--space-8);
  padding-top: var(--space-3);
  border-top: var(--rule-thin) solid var(--rule-strong);
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: var(--type-xs);
  color: var(--fg-muted);
  letter-spacing: 1px;
}

/* ============================================================
   META ROW — drafted/by/status etc.
   ============================================================ */

.meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
  font-family: var(--mono);
  font-size: var(--type-sm);
  color: var(--fg-muted);
  margin-bottom: var(--space-5);
}

.meta-row .label {
  color: var(--fg-muted);
  margin-right: var(--space-2);
}

.meta-row .value {
  color: var(--fg);
}

/* ============================================================
   CALLOUT
   ============================================================ */

.callout {
  background: var(--bg-alt);
  border-left: 3px solid var(--tick);
  padding: var(--space-3) var(--space-4);
  margin: var(--space-5) 0;
  font-family: var(--mono);
  font-size: var(--type-sm);
  color: var(--fg-soft);
  line-height: 1.6;
}

.callout-label {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--fg-muted);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: var(--space-1);
  display: block;
}

.callout--note { border-left-color: var(--lead); }
.callout--note .callout-label { color: var(--lead); }

.callout--warn { border-left-color: var(--brass); }
.callout--warn .callout-label { color: var(--brass); }

/* ============================================================
   CARD
   ============================================================ */

.card {
  background: var(--bg-alt);
  border: var(--rule-thin) solid var(--rule);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-4) 0;
}

.card-title {
  font-family: var(--serif);
  font-size: var(--type-md);
  font-weight: 500;
  margin: 0 0 var(--space-2) 0;
}

.card-meta {
  font-family: var(--mono);
  font-size: var(--type-xs);
  color: var(--fg-muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}

/* ============================================================
   TABLE — engineer's drawing register
   ============================================================ */

.table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--mono);
  font-size: var(--type-sm);
  margin: var(--space-5) 0;
}

.table thead th {
  text-align: left;
  font-weight: 400;
  color: var(--fg-muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-size: var(--type-xs);
  padding: var(--space-2) var(--space-3) var(--space-2) 0;
  border-bottom: var(--rule-thin) solid var(--rule-strong);
}

.table tbody td {
  padding: var(--space-2) var(--space-3) var(--space-2) 0;
  border-bottom: var(--rule-thin) solid var(--rule);
  color: var(--fg);
  vertical-align: top;
}

.table tbody tr:last-child td {
  border-bottom: var(--rule-thin) solid var(--rule-strong);
}

.table .num {
  font-variant-numeric: tabular-nums;
  text-align: right;
}

/* prose context */
.prose .table { font-size: var(--type-sm); }

/* ============================================================
   STAT
   ============================================================ */

.stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-4);
  margin: var(--space-5) 0;
}

.stat {
  border-top: var(--rule-thin) solid var(--rule-strong);
  padding-top: var(--space-3);
}

.stat-label {
  font-family: var(--mono);
  font-size: var(--type-xs);
  color: var(--fg-muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: var(--space-1);
}

.stat-value {
  font-family: var(--serif);
  font-size: var(--type-xl);
  font-weight: 500;
  color: var(--fg);
  line-height: 1.1;
  letter-spacing: -0.5px;
}

.stat-detail {
  font-family: var(--mono);
  font-size: var(--type-xs);
  color: var(--fg-muted);
  margin-top: var(--space-1);
}

/* ============================================================
   STATUS PILL — for state indicators
   ============================================================ */

.status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--mono);
  font-size: var(--type-xs);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--fg-muted);
}

.status::before {
  content: '';
  display: inline-block;
  width: 7px;
  height: 7px;
  background: var(--fg-muted);
  border-radius: 50%;
}

.status--live::before    { background: var(--verdigris); animation: cursor-blink 1.6s steps(1) infinite; }
.status--review::before  { background: var(--brass); }
.status--draft::before   { background: var(--lead); }
.status--archive::before { background: var(--stone); }
.status--alert::before   { background: var(--oxblood); }

@media (prefers-color-scheme: dark) {
  .status--live::before { background: #5DCAA5; }
  .status--alert::before { background: #D85A30; }
}

/* ============================================================
   FIGURE
   ============================================================ */

.figure {
  margin: var(--space-6) 0;
}

.figure-frame {
  background: var(--bg-alt);
  border: var(--rule-thin) solid var(--rule);
  padding: var(--space-5);
}

.figure-caption {
  font-family: var(--mono);
  font-size: var(--type-xs);
  color: var(--fg-muted);
  letter-spacing: 1px;
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: var(--rule-thin) solid var(--rule);
}

.figure-caption .label {
  color: var(--fg);
  font-weight: 400;
  margin-right: var(--space-2);
}

/* ============================================================
   SECTION DIVIDER (in spec doc)
   ============================================================ */

.section-divider {
  border: none;
  border-top: var(--rule-thin) solid var(--rule);
  margin: var(--space-10) 0 var(--space-6) 0;
}

/* ============================================================
   NAV (for spec doc)
   ============================================================ */

.nav {
  font-family: var(--mono);
  font-size: var(--type-sm);
  border-top: var(--rule-thin) solid var(--rule-strong);
  border-bottom: var(--rule-thin) solid var(--rule-strong);
  padding: var(--space-3) 0;
  margin: var(--space-6) 0 var(--space-8) 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
}

.nav a {
  color: var(--fg-muted);
  text-decoration: none;
}

.nav a:hover { color: var(--fg); }

.nav .num {
  color: var(--tick);
  margin-right: var(--space-2);
}

/* ============================================================
   PALETTE SWATCHES (for spec doc)
   ============================================================ */

.swatches {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--space-1);
  margin: var(--space-5) 0;
}

.swatch {
  padding: var(--space-3);
  font-family: var(--mono);
  font-size: var(--type-xs);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 100px;
}

.swatch-name { letter-spacing: 0.5px; }
.swatch-hex { opacity: 0.7; margin-top: var(--space-2); }

/* ============================================================
   TYPE SPECIMEN (for spec doc)
   ============================================================ */

.specimen {
  margin: var(--space-5) 0;
  padding-bottom: var(--space-5);
  border-bottom: var(--rule-thin) solid var(--rule);
}

.specimen:last-child { border-bottom: none; }

.specimen-meta {
  font-family: var(--mono);
  font-size: var(--type-xs);
  color: var(--fg-muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}

/* ============================================================
   SOURCE BLOCK (for spec doc — shows component code)
   ============================================================ */

.source {
  background: var(--bg-alt);
  border-left: 2px solid var(--lead);
  padding: var(--space-3) var(--space-4);
  font-family: var(--mono);
  font-size: 12px;
  line-height: 1.6;
  overflow-x: auto;
  margin: var(--space-3) 0 var(--space-5) 0;
  color: var(--fg-soft);
}

.source-label {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--fg-muted);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin: var(--space-3) 0 var(--space-2) 0;
}

/* ============================================================
   UTILITIES
   ============================================================ */

.hidden { display: none; }
.center { text-align: center; }
.spacer-sm { height: var(--space-4); }
.spacer-md { height: var(--space-6); }
.spacer-lg { height: var(--space-10); }

/* ============================================================
   PRINT
   ============================================================ */

@media print {
  .mark--active .cursor { animation: none; opacity: 1; }
  .nav { display: none; }
  .page { padding: var(--space-5); }
}
