/* ============================================================
   research.crabcc.app — page styles
   Dark, terminal-leaning, terracotta accent. Built entirely on
   crabcc design tokens (see _ds/.../tokens/*.css).
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; scroll-padding-top: 60px; }

body {
  margin: 0;
  background: var(--surface-page);
  color: var(--text-body);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--lh-base);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection { background: color-mix(in oklch, var(--accent) 35%, transparent); }

.wrap {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

a { color: var(--text-accent); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 2px; }

code, .mono { font-family: var(--font-mono); }

/* ========== HERO ========================================== */
.hero {
  position: relative;
  overflow: hidden;
  border-bottom: var(--border-hair) solid var(--border-subtle);
  background:
    radial-gradient(120% 80% at 12% -10%, color-mix(in oklch, var(--crab-hot) 14%, transparent), transparent 60%),
    radial-gradient(90% 70% at 100% 0%, color-mix(in oklch, var(--crab-500) 10%, transparent), transparent 55%),
    var(--surface-page);
  padding-block: var(--space-16) var(--space-12);
}
.hero::after {
  /* faint scanline texture, very low contrast */
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image: repeating-linear-gradient(0deg, transparent 0 3px, rgba(255,255,255,0.012) 3px 4px);
  mix-blend-mode: screen;
}
.hero-grid {
  display: grid; grid-template-columns: 1.05fr 0.95fr;
  gap: var(--space-12); align-items: center; position: relative; z-index: 1;
}
.hero-main { min-width: 0; }

.kicker {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-muted);
  letter-spacing: var(--tracking-snug);
  margin-bottom: var(--space-5);
}
.kicker .prompt { color: var(--accent); font-weight: var(--fw-bold); }

h1, .hero h1 {
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  letter-spacing: var(--tracking-tight);
  font-size: clamp(38px, 5.4vw, var(--text-4xl));
  line-height: var(--lh-4xl);
  margin: 0 0 var(--space-5);
  color: var(--text-strong);
  text-wrap: balance;
}
.hero h1 {
  background: linear-gradient(96deg, var(--crab-glow) 0%, var(--crab-hot) 42%, var(--crab-500) 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.sub {
  font-size: var(--text-md);
  line-height: var(--lh-md);
  color: var(--text-muted);
  max-width: 56ch;
  margin: 0 0 var(--space-7);
}

/* badges */
.badges { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.badge {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  line-height: 1;
  padding: 7px 10px;
  border-radius: var(--radius-sm);
  border: var(--border-hair) solid var(--border-subtle);
  background: var(--surface-card);
  color: var(--text-muted);
  white-space: nowrap;
}
.badge.ok   { color: var(--ok);   border-color: color-mix(in oklch, var(--ok) 40%, transparent);   background: var(--ok-wash); }
.badge.open { color: var(--accent); border-color: color-mix(in oklch, var(--accent) 40%, transparent); background: var(--accent-wash); }

/* hero CTA buttons */
.hero-cta { display: flex; flex-wrap: wrap; gap: var(--space-2_5); margin-top: var(--space-5); }
.btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-family: var(--font-mono); font-size: var(--text-sm); font-weight: var(--fw-medium);
  height: var(--control-h-md); padding: 0 var(--space-4);
  border-radius: var(--radius-md); border: var(--border-hair) solid transparent;
  cursor: pointer; transition: var(--transition-control); white-space: nowrap;
}
.btn:hover { text-decoration: none; }
.btn-primary { background: var(--accent); color: var(--text-on-accent); border-color: var(--accent); }
.btn-primary:hover { background: var(--accent-hover); border-color: var(--accent-hover); }
.btn-primary:active { background: var(--accent-press); }
.btn-ghost { background: transparent; color: var(--text-muted); border-color: var(--border-strong); }
.btn-ghost:hover { color: var(--accent); border-color: var(--border-accent); background: var(--accent-wash); }
.btn .gh { flex: none; }

/* github link in the sticky TOC */
.toc-gh {
  display: inline-flex; align-items: center; gap: var(--space-1_5);
  margin-left: auto; flex: none;
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-muted);
  padding: 6px 10px; border-radius: var(--radius-sm); transition: var(--transition-control);
}
.toc-gh:hover { color: var(--accent); background: var(--surface-hover); text-decoration: none; }

/* hero terminal block */
.hero-side { min-width: 0; }
.term {
  border: var(--border-hair) solid var(--border-subtle);
  border-radius: var(--radius-lg);
  background: var(--surface-inverse);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.term-bar {
  display: flex; align-items: center; gap: 7px;
  padding: var(--space-2_5) var(--space-3);
  background: #141416;
  border-bottom: var(--border-hair) solid #242427;
}
.tdot { width: 10px; height: 10px; border-radius: 50%; background: #3a3a3c; }
.tdot:nth-child(1){ background:#e05a4d; } .tdot:nth-child(2){ background:#e0a23a; } .tdot:nth-child(3){ background:#43b04a; }
.term-title { margin-left: auto; font-family: var(--font-mono); font-size: var(--text-2xs); color: var(--text-faint); }
.term-body {
  margin: 0; padding: var(--space-4) var(--space-4) var(--space-5);
  font-family: var(--font-mono); font-size: var(--text-sm); line-height: 1.7;
  color: #cdd3da; white-space: pre-wrap; word-break: break-word;
}
.c-prompt { color: var(--accent); } .c-cmd { color: var(--crab-glow); }
.c-dim { color: #6b7280; } .c-acc { color: var(--accent); } .c-ok { color: var(--green-400); }
.c-good { color: var(--green-400); font-weight: var(--fw-bold); } .c-crab { filter: saturate(1.1); }
.cursor { color: var(--accent); animation: blink 1.1s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }

/* ========== TOC ========================================== */
.toc {
  position: sticky; top: 0; z-index: 20;
  background: color-mix(in oklch, var(--surface-page) 86%, transparent);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border-bottom: var(--border-hair) solid var(--border-subtle);
}
.toc-row { display: flex; gap: var(--space-1); overflow-x: auto; padding-block: var(--space-2); scrollbar-width: none; }
.toc-row::-webkit-scrollbar { display: none; }
.toc-row a {
  font-family: var(--font-mono); font-size: var(--text-xs);
  color: var(--text-muted); padding: 6px 10px; border-radius: var(--radius-sm);
  white-space: nowrap; transition: var(--transition-control);
}
.toc-row a:hover { color: var(--text-strong); background: var(--surface-hover); text-decoration: none; }
.toc-row a.active { color: var(--accent); background: var(--accent-wash); }

/* ========== SECTION RHYTHM =============================== */
main { padding-block: var(--space-12) var(--space-16); }
section { padding-block: var(--space-12); border-top: var(--border-hair) solid var(--border-subtle); }
section:first-child { border-top: 0; }
.eyebrow {
  font-family: var(--font-mono); text-transform: uppercase;
  font-size: var(--text-2xs); letter-spacing: var(--tracking-caps);
  color: var(--accent); margin-bottom: var(--space-3);
}
section h2 {
  font-family: var(--font-display); font-weight: var(--fw-bold);
  font-size: clamp(26px, 3.2vw, var(--text-2xl)); line-height: var(--lh-2xl);
  letter-spacing: var(--tracking-snug); color: var(--text-strong);
  margin: 0 0 var(--space-4); text-wrap: balance;
}
.lead { font-size: var(--text-md); line-height: var(--lh-md); color: var(--text-muted); max-width: 72ch; margin: 0 0 var(--space-6); }
.lead strong { color: var(--text-body); font-weight: var(--fw-semibold); }

/* ========== STATS ======================================== */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: var(--space-3); margin-bottom: var(--space-6); }
.stat {
  border: var(--border-hair) solid var(--border-subtle); border-radius: var(--radius-lg);
  background: var(--surface-card); padding: var(--space-4) var(--space-4) var(--space-4);
  position: relative; overflow: hidden;
}
.stat::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; background: var(--border-subtle); }
.stat.acc::before  { background: var(--accent); }
.stat.good::before { background: var(--ok); }
.stat.vio::before  { background: var(--slate-500); }
.stat .v {
  font-family: var(--font-display); font-weight: var(--fw-bold);
  font-size: var(--text-2xl); line-height: 1; color: var(--text-strong);
  letter-spacing: var(--tracking-tight);
}
.stat.acc .v { color: var(--accent); }
.stat.good .v { color: var(--ok); }
.stat .l { margin-top: var(--space-2); font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-muted); line-height: 1.4; }

/* ========== CHARTS ======================================= */
.chart {
  position: relative;
  border: var(--border-hair) solid var(--border-subtle); border-radius: var(--radius-lg);
  background: var(--surface-card); height: 340px; padding: var(--space-4);
}
.chart.tall { height: 420px; }
.chart-cap {
  font-family: var(--font-mono); text-transform: uppercase; font-size: var(--text-2xs);
  letter-spacing: var(--tracking-wide); color: var(--text-faint);
  position: absolute; top: var(--space-3); left: var(--space-4); z-index: 2;
}
.chart-host { position: absolute; inset: 0; top: var(--space-6); }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }

/* ========== CALLOUT ====================================== */
.callout {
  border: var(--border-hair) solid var(--border-subtle);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-md);
  background: linear-gradient(90deg, var(--accent-wash), var(--surface-card) 40%);
  padding: var(--space-5) var(--space-5);
  margin-block: var(--space-2);
}
.callout .h { font-family: var(--font-display); font-weight: var(--fw-semibold); font-size: var(--text-md); color: var(--text-strong); margin: 0 0 var(--space-2); letter-spacing: var(--tracking-snug); }
.callout .b { font-size: var(--text-base); color: var(--text-muted); margin: 0; max-width: 78ch; }

/* ========== TAGS / PILLS ================================= */
.pill-row { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-5); align-items: center; }
.pill-row .pill-lbl { font-family: var(--font-mono); font-size: var(--text-2xs); color: var(--text-faint); text-transform: uppercase; letter-spacing: var(--tracking-wide); margin-right: var(--space-1); }
.tag {
  font-family: var(--font-mono); font-size: var(--text-xs);
  padding: 4px 9px; border-radius: var(--radius-sm);
  border: var(--border-hair) solid var(--border-subtle); background: var(--surface-sunken);
  color: var(--text-body); white-space: nowrap;
}
.tag.sn  { color: var(--ok);     border-color: color-mix(in oklch, var(--ok) 45%, transparent);     background: var(--ok-wash); }
.tag.nsn { color: var(--danger); border-color: color-mix(in oklch, var(--danger) 45%, transparent); background: var(--danger-wash); }

/* ========== TABLE ======================================== */
.table-wrap { margin-top: var(--space-5); border: var(--border-hair) solid var(--border-subtle); border-radius: var(--radius-lg); overflow: hidden; }
table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: var(--text-sm); }
thead th {
  text-align: left; text-transform: uppercase; letter-spacing: var(--tracking-wide);
  font-size: var(--text-2xs); color: var(--text-faint); font-weight: var(--fw-medium);
  padding: var(--space-3) var(--space-4); background: var(--surface-sunken);
  border-bottom: var(--border-hair) solid var(--border-subtle);
}
tbody td { padding: var(--space-3) var(--space-4); border-bottom: var(--border-hair) solid var(--border-subtle); color: var(--text-body); }
tbody tr:last-child td { border-bottom: 0; }
tbody tr:hover td { background: var(--surface-hover); }
td.num { text-align: right; color: var(--text-strong); }
td .sym { color: var(--accent); }
td .path { color: var(--text-faint); font-size: var(--text-xs); }

/* ========== ZOO ========================================== */
.zoo { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--space-3); margin-bottom: var(--space-5); }
.cell {
  border: var(--border-hair) solid var(--border-subtle); border-radius: var(--radius-lg);
  background: var(--surface-card); overflow: hidden; display: flex; flex-direction: column;
  transition: var(--transition-control);
}
.cell:hover { border-color: var(--border-strong); }
.cell.nsn { box-shadow: inset 3px 0 0 var(--danger); }
.cell.sn  { box-shadow: inset 3px 0 0 var(--ok); }
.cell .cap {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-2);
  padding: var(--space-3) var(--space-3); border-bottom: var(--border-hair) solid var(--border-subtle);
}
.cell .cap .term-name { font-family: var(--font-mono); font-size: var(--text-sm); color: var(--text-strong); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cell .cy { height: 150px; background: var(--surface-sunken); }

/* ========== RESEARCH CARDS =============================== */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--space-3); }
.card {
  border: var(--border-hair) solid var(--border-subtle); border-radius: var(--radius-lg);
  background: var(--surface-card); padding: var(--space-5); transition: var(--transition-control);
}
.card:hover { border-color: var(--border-strong); box-shadow: var(--shadow-md); }
.card h3 { font-family: var(--font-display); font-weight: var(--fw-semibold); font-size: var(--text-md); color: var(--text-strong); margin: 0 0 var(--space-2); letter-spacing: var(--tracking-snug); }
.card p { font-size: var(--text-base); color: var(--text-muted); margin: 0 0 var(--space-3); }
.cites { display: flex; flex-wrap: wrap; gap: var(--space-1_5); }
.cites .cite { font-family: var(--font-mono); font-size: var(--text-2xs); padding: 3px 7px; border-radius: var(--radius-sm); border: var(--border-hair) solid var(--border-subtle); color: var(--text-faint); }

/* ========== MISC ========================================= */
.note { font-family: var(--font-mono); font-size: var(--text-xs); line-height: 1.65; color: var(--text-muted); margin-top: var(--space-4); max-width: 84ch; }
.note code { color: var(--accent); }
.muted { color: var(--text-faint); }
.err { color: var(--danger); }
.kat { font-style: normal; }
.methods-body p { margin: 0 0 var(--space-4); color: var(--text-muted); font-size: var(--text-base); max-width: 80ch; }
.methods-body strong { color: var(--text-body); }

/* ========== FOOTER ====================================== */
footer { border-top: var(--border-hair) solid var(--border-subtle); padding-block: var(--space-8); }
footer .wrap { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-faint); line-height: 1.7; }
.foot-row { color: var(--text-muted); margin-bottom: var(--space-2); }
.foot-row a { color: var(--text-accent); }
.foot-row a:hover { color: var(--accent-hover); }
.foot-meta { color: var(--text-faint); }

/* ========== RESPONSIVE ================================== */
@media (max-width: 920px) {
  .hero-grid { grid-template-columns: 1fr; gap: var(--space-8); }
  .hero-side { order: -1; }
  .grid2 { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .wrap { padding-inline: var(--space-4); }
  .hero { padding-block: var(--space-10) var(--space-8); }
}
