/* Grimwood — local site theme. Dark fairy-tale: ink, ash, parchment, ember. */
:root {
  --ink:        #0c0f0d;
  --ink-2:      #141a17;
  --panel:      #1a211d;
  --panel-2:    #212a25;
  --line:       #2c3a32;
  --parch:      #e8dcc0;
  --parch-dim:  #b6ad97;
  --muted:      #7d8a80;
  --ember:      #ffa046;
  --ember-dim:  #c97c34;
  --moss:       #7c9b3c;
  --hex:        #c264ff;
  --frost:      #79c0e8;
  --blood:      #c43b3b;
  --gold:       #e6d98a;
  --shadow:     0 8px 30px rgba(0,0,0,.55);
  --serif: "Iowan Old Style", "Palatino Linotype", Palatino, "Book Antiqua", Georgia, serif;
  --mono: "SF Mono", "JetBrains Mono", "Fira Mono", Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--serif);
  color: var(--parch);
  background:
    radial-gradient(1200px 600px at 50% -10%, #1c2620 0%, transparent 60%),
    radial-gradient(900px 500px at 90% 110%, #161e1a 0%, transparent 55%),
    var(--ink);
  background-attachment: fixed;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--ember); text-decoration: none; }
a:hover { color: var(--gold); }

/* ── Top nav ─────────────────────────────────────────────── */
.nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; flex-wrap: wrap; gap: 4px;
  padding: 10px 22px;
  background: rgba(10,13,11,.86);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.nav .brand {
  font-weight: 700; letter-spacing: .32em; text-transform: uppercase;
  color: var(--parch); margin-right: 18px; font-size: 15px;
}
.nav .brand b { color: var(--ember); }
.nav a.link {
  color: var(--parch-dim); padding: 6px 11px; border-radius: 5px;
  font-size: 13px; letter-spacing: .12em; text-transform: uppercase;
  white-space: nowrap;
}
.nav a.link:hover { color: var(--parch); background: var(--panel); }
.nav a.link.active { color: var(--ember); background: var(--panel-2); }

/* ── Layout ──────────────────────────────────────────────── */
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 22px 90px; }
.page-head { padding: 46px 0 26px; border-bottom: 1px solid var(--line); margin-bottom: 36px; }
.page-head .eyebrow {
  color: var(--ember-dim); letter-spacing: .35em; text-transform: uppercase;
  font-size: 12px; font-family: var(--mono);
}
.page-head h1 {
  font-size: clamp(34px, 5vw, 54px); margin: 8px 0 10px; font-weight: 700;
  letter-spacing: .02em; line-height: 1.05;
}
.page-head p { color: var(--parch-dim); max-width: 70ch; margin: 0; font-size: 17px; }

section.block { margin: 52px 0; }
section.block > h2 {
  font-size: 26px; letter-spacing: .04em; margin: 0 0 6px;
  display: flex; align-items: baseline; gap: 12px;
}
section.block > h2::after { content: ""; flex: 1; height: 1px; background: var(--line); }
section.block > .sub { color: var(--muted); margin: 0 0 22px; font-size: 14px; }

/* ── Cards ───────────────────────────────────────────────── */
.grid { display: grid; gap: 18px; }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 880px) { .cols-2,.cols-3,.cols-4 { grid-template-columns: 1fr; } }

.card {
  background: linear-gradient(180deg, var(--panel) 0%, var(--ink-2) 100%);
  border: 1px solid var(--line); border-radius: 10px; padding: 22px;
  box-shadow: var(--shadow); position: relative; overflow: hidden;
}
.card::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--accent, var(--ember));
}
.card h3 { margin: 0 0 4px; font-size: 21px; letter-spacing: .02em; }
.card .kicker {
  font-family: var(--mono); font-size: 11px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--accent, var(--ember));
}
.card p { color: var(--parch-dim); font-size: 15px; }

/* ── Stat tables ─────────────────────────────────────────── */
table.stats { width: 100%; border-collapse: collapse; font-size: 14px; margin-top: 8px; }
table.stats th, table.stats td {
  text-align: left; padding: 8px 12px; border-bottom: 1px solid var(--line);
}
table.stats th {
  color: var(--ember-dim); font-family: var(--mono); font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; font-size: 11px;
}
table.stats td { color: var(--parch); }
table.stats td.num, table.stats td.k { font-family: var(--mono); color: var(--parch-dim); }
table.stats tr:last-child td { border-bottom: none; }
table.stats tbody tr:hover { background: rgba(255,160,70,.04); }

/* compact two-col definition list inside cards */
.kv { display: grid; grid-template-columns: max-content 1fr; gap: 4px 16px; margin: 12px 0 0; font-size: 14px; }
.kv dt { color: var(--muted); font-family: var(--mono); font-size: 12px; letter-spacing: .08em; }
.kv dd { margin: 0; color: var(--parch); font-family: var(--mono); }

/* tier ladder */
.tiers { list-style: none; margin: 14px 0 0; padding: 0; }
.tiers li { display: flex; gap: 12px; padding: 8px 0; border-top: 1px solid var(--line); font-size: 14px; }
.tiers li:first-child { border-top: none; }
.tiers .t { font-family: var(--mono); color: var(--accent, var(--ember)); font-size: 12px; min-width: 26px; padding-top: 1px; }
.tiers .tn { color: var(--parch); font-weight: 600; min-width: 118px; }
.tiers .td { color: var(--parch-dim); }
@media (max-width: 600px) { .tiers li { flex-wrap: wrap; } .tiers .tn { min-width: 0; } }

/* badges / pills */
.pill {
  display: inline-block; font-family: var(--mono); font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase; padding: 3px 9px; border-radius: 999px;
  border: 1px solid var(--line); color: var(--parch-dim); background: var(--ink);
}
.pill.accent { color: var(--ink); background: var(--accent, var(--ember)); border-color: transparent; font-weight: 700; }

.swatch { display: inline-block; width: 11px; height: 11px; border-radius: 2px; transform: rotate(45deg); vertical-align: middle; margin-right: 7px; }

.lore { color: var(--parch-dim); font-size: 16px; max-width: 72ch; }
.lore p { margin: 0 0 14px; }
.lore p:first-letter { }

.muted { color: var(--muted); }
.note { font-size: 13px; color: var(--muted); font-style: italic; }

hr.rule { border: none; border-top: 1px solid var(--line); margin: 40px 0; }

/* ── Hero (home) ─────────────────────────────────────────── */
.hero {
  text-align: center; padding: 92px 22px 70px;
  border-bottom: 1px solid var(--line);
  background:
    radial-gradient(700px 320px at 50% 0%, rgba(255,160,70,.10), transparent 70%);
}
.hero .mark { font-family: var(--mono); letter-spacing: .5em; color: var(--ember-dim); font-size: 13px; text-transform: uppercase; }
.hero h1 { font-size: clamp(52px, 9vw, 104px); margin: 14px 0 6px; letter-spacing: .04em; line-height: .95; }
.hero .tagline { color: var(--parch-dim); font-size: 20px; font-style: italic; max-width: 52ch; margin: 8px auto 0; }
.hero .cta {
  display: inline-block; margin-top: 30px;
  font-family: var(--mono); font-size: 16px; letter-spacing: .04em;
  color: var(--ink); background: var(--gold);
  padding: 14px 30px; border-radius: 8px;
  border: 1px solid transparent;
  transition: transform .15s, box-shadow .15s, background .15s;
  box-shadow: 0 10px 30px rgba(230,217,138,.16);
}
.hero .cta:hover {
  color: var(--ink); background: #f0e6a4;
  transform: translateY(-2px); box-shadow: 0 14px 36px rgba(230,217,138,.26);
}
.hero .quote { color: var(--muted); margin-top: 26px; font-size: 15px; }

.tiles { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 40px; }
@media (max-width: 820px) { .tiles { grid-template-columns: 1fr; } }
.tile {
  display: block; background: var(--panel); border: 1px solid var(--line);
  border-radius: 10px; padding: 22px; transition: border-color .15s, transform .15s;
}
.tile:hover { border-color: var(--ember-dim); transform: translateY(-2px); }
.tile h3 { margin: 0 0 6px; color: var(--parch); font-size: 19px; }
.tile p { margin: 0; color: var(--parch-dim); font-size: 14px; }
.tile .arrow { color: var(--ember); font-family: var(--mono); }

footer.foot {
  border-top: 1px solid var(--line); color: var(--muted);
  text-align: center; padding: 30px; font-size: 13px; font-family: var(--mono);
}
