/* THE NICK.EXE CASE FILE — design system
   Three visual languages, one per epistemic status:
   - EVIDENCE  : pale, document-like, cyan-edged
   - LORE      : green phosphor terminal
   - INTAKE    : amber, machine-stamped, unreviewed
   Palette nods to nick.exe's CGA art: cyan / magenta / yellow on black. */

:root {
  --bg: #0a0d11;
  --bg-2: #0f141b;
  --panel: #121922;
  --line: #1f2a36;
  --txt: #c8d4de;
  --txt-dim: #74848f;
  --cyan: #34d6e8;
  --magenta: #e84fd0;
  --yellow: #ffe14d;
  --amber: #ffb000;
  --green: #3aff8e;
  --red: #ff5d5d;
  --evidence: #9adcff;
  --mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Consolas, Menlo, monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background:
    radial-gradient(1200px 500px at 70% -10%, rgba(52, 214, 232, 0.06), transparent 60%),
    radial-gradient(900px 500px at 0% 110%, rgba(232, 79, 208, 0.05), transparent 60%),
    var(--bg);
  color: var(--txt);
  font-family: var(--mono);
  font-size: 15px;
  line-height: 1.65;
}

.wrap { max-width: 960px; margin: 0 auto; padding: 0 20px 90px; }

a { color: var(--cyan); text-decoration: none; }
a:hover { color: var(--magenta); }
code, .mono { font-family: var(--mono); }
code {
  background: #0d1218;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 1px 6px;
  font-size: 0.86em;
  word-break: break-all;
  color: var(--yellow);
}
hr { border: 0; border-top: 1px dashed var(--line); margin: 38px 0; }

/* ---------- header / nav ---------- */
header.site {
  border-bottom: 1px solid var(--line);
  background: rgba(10, 13, 17, 0.92);
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(6px);
}
.site-inner {
  max-width: 960px;
  margin: 0 auto;
  padding: 14px 20px;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 10px 22px;
}
.logo {
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--txt);
  white-space: nowrap;
}
.logo b { color: var(--cyan); }
.logo .blink { color: var(--magenta); animation: blink 1.4s steps(2) infinite; }
@keyframes blink { 50% { opacity: 0; } }
nav.main { display: flex; flex-wrap: wrap; gap: 4px 16px; font-size: 12.5px; }
nav.main a {
  color: var(--txt-dim);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px 0;
}
nav.main a:hover { color: var(--cyan); }
nav.main a.active { color: var(--yellow); border-bottom: 1px solid var(--yellow); }

/* ---------- typography ---------- */
h1 {
  font-size: 28px;
  line-height: 1.25;
  letter-spacing: 0.02em;
  margin: 48px 0 8px;
  color: #eef6fb;
}
h1 .accent { color: var(--cyan); }
h2 {
  font-size: 17px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--cyan);
  margin: 46px 0 14px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 8px;
}
h3 { font-size: 15px; color: var(--yellow); margin: 26px 0 8px; letter-spacing: 0.04em; }
.kicker {
  color: var(--magenta);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 11.5px;
  margin-top: 42px;
}
.lead { color: #a9bac6; font-size: 16px; }
.dim { color: var(--txt-dim); }
.small { font-size: 12.5px; }

/* ---------- panels & cards ---------- */
.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px 20px;
  margin: 18px 0;
}
.panel.evidence { border-left: 3px solid var(--evidence); }
.panel.lore {
  background: #07120b;
  border: 1px solid #14402a;
  border-left: 3px solid var(--green);
  color: #9defbe;
}
.panel.lore h3, .panel.lore strong { color: var(--green); }
.panel.warn { border-left: 3px solid var(--yellow); }
.panel.danger { border-left: 3px solid var(--red); }

.grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 720px) { .grid { grid-template-columns: 1fr; } }

/* ---------- chips / tags ---------- */
.chip {
  display: inline-block;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border: 1px solid;
  border-radius: 3px;
  padding: 1px 7px;
  margin-right: 6px;
  vertical-align: middle;
}
.chip.evidence { color: var(--evidence); border-color: var(--evidence); }
.chip.lore { color: var(--green); border-color: var(--green); }
.chip.context { color: var(--txt-dim); border-color: var(--txt-dim); }
.chip.off_topic { color: #5b6770; border-color: #5b6770; }
.chip.unlabeled { color: var(--amber); border-color: var(--amber); border-style: dashed; }
.chip.known { color: var(--magenta); border-color: var(--magenta); }
.chip.conf { color: var(--txt-dim); border-color: var(--line); }

/* ---------- timeline ---------- */
.t-filters { display: flex; gap: 8px; flex-wrap: wrap; margin: 18px 0 6px; }
.t-filters button {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--txt-dim);
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 4px;
  cursor: pointer;
}
.t-filters button.on { color: var(--yellow); border-color: var(--yellow); }
.t-item {
  border-left: 2px solid var(--line);
  padding: 2px 0 18px 18px;
  margin-left: 6px;
  position: relative;
}
.t-item::before {
  content: "";
  position: absolute;
  left: -5px;
  top: 8px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cyan);
}
.t-item.lore::before { background: var(--green); }
.t-item.context::before { background: var(--txt-dim); }
.t-date { color: var(--yellow); font-size: 12px; letter-spacing: 0.08em; }
.t-title { color: #eaf3f9; font-weight: 700; margin: 2px 0; }
.t-desc { color: #9fb0bc; font-size: 13.5px; }
.t-caveat { color: var(--txt-dim); font-size: 12px; font-style: italic; }
.t-link { font-size: 12px; }

/* ---------- intake ---------- */
.intake-card {
  background: #16120a;
  border: 1px solid #3d2f12;
  border-left: 3px solid var(--amber);
  border-radius: 8px;
  padding: 14px 16px;
  margin: 12px 0;
}
.intake-card .url { word-break: break-all; font-size: 13px; }
.intake-card .summary { color: #d9c79a; font-size: 13.5px; margin: 8px 0 4px; }
.intake-card .meta { color: #8a7a55; font-size: 11.5px; }
.stamp {
  color: var(--amber);
  border: 1px dashed var(--amber);
  font-size: 10px;
  letter-spacing: 0.18em;
  padding: 1px 6px;
  border-radius: 3px;
  text-transform: uppercase;
}

form.submit { display: grid; gap: 10px; }
form.submit input[type="url"], form.submit input[type="text"] {
  width: 100%;
  background: #0d1218;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--txt);
  font-family: var(--mono);
  font-size: 14px;
  padding: 10px 12px;
}
form.submit input:focus { outline: 1px solid var(--amber); border-color: var(--amber); }
form.submit button {
  justify-self: start;
  background: var(--amber);
  color: #14100a;
  border: 0;
  border-radius: 6px;
  font-family: var(--mono);
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 10px 22px;
  cursor: pointer;
}
form.submit button:disabled { opacity: 0.5; cursor: wait; }
.form-msg { font-size: 13px; min-height: 20px; }
.form-msg.err { color: var(--red); }
.form-msg.ok { color: var(--green); }
.hp { position: absolute; left: -5000px; }

/* ---------- misc ---------- */
pre.diagram {
  background: #07120b;
  border: 1px solid #14402a;
  color: var(--green);
  border-radius: 8px;
  padding: 18px;
  overflow-x: auto;
  font-size: 12.5px;
  line-height: 1.5;
}
table { width: 100%; border-collapse: collapse; font-size: 13px; }
th, td { border: 1px solid var(--line); padding: 7px 10px; text-align: left; vertical-align: top; }
th { color: var(--cyan); text-transform: uppercase; font-size: 11px; letter-spacing: 0.1em; }
td code { font-size: 0.95em; }

.btnrow { display: flex; gap: 12px; flex-wrap: wrap; margin: 26px 0; }
.btn {
  border: 1px solid var(--cyan);
  color: var(--cyan);
  padding: 9px 18px;
  border-radius: 5px;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.btn:hover { background: var(--cyan); color: #07242a; }
.btn.amber { border-color: var(--amber); color: var(--amber); }
.btn.amber:hover { background: var(--amber); color: #241a06; }

footer.site {
  border-top: 1px solid var(--line);
  margin-top: 70px;
  padding: 26px 0 10px;
  color: var(--txt-dim);
  font-size: 12px;
}
.loop-box {
  border: 1px solid var(--magenta);
  border-radius: 8px;
  padding: 16px 18px;
  margin: 20px 0;
}
.loop-box b { color: var(--magenta); }
ul { padding-left: 22px; }
li { margin: 5px 0; }
li::marker { color: var(--cyan); }
