
:root {
  --bg: #0e0e10; --fg: #e8e8e8; --dim: #888;
  --accent: #ffb84d; --hl: #4caf50;
  --neg: #ef5350; --pos: #4caf50;
  --card: #1c1c20; --card-hover: #25252a;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--fg);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: 16px; line-height: 1.5; min-height: 100vh; }

.topnav { display: flex; align-items: center; gap: 1.5em; padding: 0.8em 1.2em;
  background: #16161a; border-bottom: 1px solid #25252a; position: sticky; top: 0; z-index: 10; }
.topnav .brand { color: var(--accent); font-weight: 700; text-decoration: none; font-size: 1.1em; }
.topnav nav { display: flex; gap: 1em; flex-wrap: wrap; }
.topnav a { color: var(--fg); text-decoration: none; font-size: 0.92em; }
.topnav a:hover { color: var(--accent); }

main { max-width: 1100px; margin: 0 auto; padding: 1.5em 1.2em 4em; }

.hero h1 { font-size: 2.0em; margin-bottom: 0.3em; }
.hero .lead { color: var(--dim); font-size: 1.1em; max-width: 720px; }

.two-msg, .cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1em; margin-top: 1.5em; }
.card { background: var(--card); padding: 1.2em; border-radius: 10px;
  text-decoration: none; color: var(--fg); transition: background 0.15s; }
.card:hover { background: var(--card-hover); }
.card.msg { border-left: 4px solid var(--hl); }
.card h3 { margin: 0 0 0.4em 0; color: var(--accent); }
.card p  { margin: 0 0 0.6em 0; color: var(--fg); }
.card .cta { color: var(--hl); font-size: 0.85em; }

footer { text-align: center; color: var(--dim); padding: 1em; font-size: 0.85em;
  border-top: 1px solid #25252a; }
footer a { color: var(--dim); }

.caption { color: var(--dim); font-size: 0.92em; margin-bottom: 1em; }
.placeholder { background: var(--card); padding: 0.8em 1.2em; border-left: 3px solid var(--accent);
  border-radius: 6px; }

/* Cohorts page */
.controls { display: flex; gap: 1.5em; align-items: center; flex-wrap: wrap;
  background: var(--card); padding: 0.8em 1.2em; border-radius: 8px; margin-bottom: 1em; }
.controls label { display: flex; align-items: center; gap: 0.4em; font-size: 0.9em; }
.controls .tog { padding: 0.2em 0.5em; border-radius: 4px; background: var(--card-hover); }
.controls input[type=number] { width: 60px; }
#plot { background: var(--bg); border-radius: 8px; }

/* Slider page */
.slider-controls { display: flex; flex-direction: column; gap: 0.8em;
  background: var(--card); padding: 1em 1.2em; border-radius: 8px; margin-bottom: 1.5em; }
#mol-search { padding: 0.5em; font-size: 1em; background: #2a2a30; color: var(--fg);
  border: 1px solid #444; border-radius: 4px; min-width: 280px; }
#mol-suggestions { list-style: none; padding: 0; margin: 0.3em 0; max-height: 240px; overflow: auto; }
#mol-suggestions li { padding: 0.4em 0.6em; cursor: pointer; border-radius: 4px; }
#mol-suggestions li:hover { background: var(--card-hover); }
.badge { background: #444; padding: 0.1em 0.5em; border-radius: 4px; font-size: 0.85em; color: var(--accent); }
#mol-info { font-size: 1.05em; }
#frac { width: 240px; }

#prop-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 0.7em; }
.prop-card { background: var(--card); padding: 0.8em; border-radius: 6px; }
.prop-name { color: var(--accent); font-size: 0.9em; }
.prop-val  { font-size: 1.4em; font-weight: 700; margin: 0.2em 0; }
.prop-val .units { color: var(--dim); font-size: 0.65em; font-weight: 400; }
.prop-delta.pos { color: var(--pos); }
.prop-delta.neg { color: var(--neg); }
.prop-baseline, .prop-ci { color: var(--dim); font-size: 0.8em; }

/* Parity page */
.parity-frame { width: 100%; height: 700px; border: 0; background: var(--card); border-radius: 8px; }
table.parity-summary, table.prior-demo { width: 100%; border-collapse: collapse; margin: 1em 0; font-size: 0.92em; }
table.parity-summary th, table.parity-summary td,
table.prior-demo th, table.prior-demo td {
  padding: 0.5em 0.7em; border-bottom: 1px solid #25252a; text-align: left;
}
table.parity-summary th, table.prior-demo th { color: var(--accent); }
.ok      { color: var(--pos); }
.caution { color: var(--accent); }
.bad     { color: var(--neg); }

@media (max-width: 700px) {
  .topnav nav { gap: 0.6em; }
  .topnav a { font-size: 0.85em; }
  main { padding: 1em 0.7em 3em; }
  .hero h1 { font-size: 1.5em; }
  #prop-grid { grid-template-columns: 1fr 1fr; }
  .parity-frame { height: 500px; }
}
