/* claudepulse-viewer — warm cream/walnut palette mirroring the Python
   webui but distilled to one stylesheet, no JS. */

:root {
  --bg:        #fbfaf6;
  --bg-elev:   #f4f1ea;
  --bg-elev-2: #ece8df;
  --fg:        #2b2724;
  --fg-dim:    #6b6358;
  --fg-bright: #1a1815;
  --border:    #d8d2c5;
  --accent:    #a04020;
  --warn:      #b86800;
  --tag-decision: #5c4a8a;
  --tag-session:  #3a6a2a;
  --fresh-live:   #0072b2;
  --mono: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;
  --serif: "Source Serif 4", "Iowan Old Style", Georgia, serif;
  --sans: -apple-system, BlinkMacSystemFont, "Inter", sans-serif;
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg:        #1c1a17;
    --bg-elev:   #25221e;
    --bg-elev-2: #2d2924;
    --fg:        #e6e0d4;
    --fg-dim:    #8a8275;
    --fg-bright: #faf7ee;
    --border:    #3a352f;
    --accent:    #d4744a;
  }
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.5;
}

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

.mono { font-family: var(--mono); font-size: 12.5px; }
.dim  { color: var(--fg-dim); }
.warn { color: var(--warn); }
.num  { font-variant-numeric: tabular-nums; }

.app-header {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 12px 28px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-elev);
}
.brand {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 600;
  color: var(--fg-bright);
}
.brand:hover { text-decoration: none; }
.top-nav { display: flex; gap: 16px; margin-left: 12px; }
.top-nav a { color: var(--fg-dim); font-size: 13px; }
.top-nav a:hover { color: var(--accent); text-decoration: none; }

.page { max-width: 1100px; margin: 0 auto; padding: 24px 28px 80px; }
.app-footer {
  text-align: center;
  font-size: 11px;
  color: var(--fg-dim);
  padding: 18px;
  border-top: 1px solid var(--border);
  margin-top: 60px;
}

.page-title {
  font-family: var(--serif);
  font-size: 32px;
  font-weight: 600;
  color: var(--fg-bright);
  margin: 0 0 4px;
}
.subtitle { color: var(--fg-dim); font-size: 13.5px; margin: 0 0 22px; }
.section-h {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 600;
  color: var(--fg);
  margin: 28px 0 10px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 4px;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}
.see-all { font-size: 12px; color: var(--fg-dim); font-weight: normal; }
.see-all:hover { color: var(--accent); }

.crumbs {
  font-size: 12px;
  color: var(--fg-dim);
  margin-bottom: 6px;
}
.crumbs a { color: var(--fg-dim); }
.crumbs a:hover { color: var(--accent); }
.crumbs span { margin: 0 4px; }

/* Home tiles */
.tiles {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 14px;
  margin: 18px 0 30px;
}
.tile {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 16px 18px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 6px;
  text-decoration: none;
  color: inherit;
}
.tile:hover { background: var(--bg-elev-2); text-decoration: none; }
.tile .num { font-size: 28px; font-weight: 600; color: var(--fg-bright); }
.tile .lbl { font-size: 13px; }
.tile .sub { font-size: 11px; color: var(--fg-dim); }

/* Tables */
.proj-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.proj-table th {
  text-align: left;
  font-weight: 500;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-dim);
  padding: 6px 10px;
  border-bottom: 1px solid var(--border);
}
.proj-table td {
  padding: 6px 10px;
  border-bottom: 1px solid var(--border);
}
.proj-table td.num { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.proj-table tbody tr:hover { background: var(--bg-elev); }

/* Buckets */
.bucket { margin: 14px 0 22px; }
.bucket-h {
  display: flex; align-items: center; gap: 8px;
  font-size: 11px; letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-dim);
  padding-bottom: 5px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--border);
}
.bucket-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--fg-dim);
}
.bucket-label { font-weight: 600; color: var(--fg); }
.bucket-count { margin-left: auto; font-family: var(--mono); color: var(--fg-dim); }
.bucket-today    .bucket-dot { background: var(--fresh-live); box-shadow: 0 0 0 3px rgba(0, 114, 178, 0.15); }
.bucket-today    .bucket-label { color: var(--fresh-live); }
.bucket-yesterday .bucket-dot { background: var(--accent); }
.bucket-week     .bucket-dot { background: var(--warn); }
.bucket-month    .bucket-dot { background: var(--tag-decision); opacity: 0.85; }
.bucket-quarter  .bucket-dot { background: var(--tag-session); opacity: 0.7; }
.bucket-year     .bucket-dot { background: var(--fg-dim); opacity: 0.7; }
.bucket-older    .bucket-dot { background: var(--fg-dim); opacity: 0.4; }
.bucket-unknown  .bucket-dot { background: transparent; border: 1px dashed var(--fg-dim); }

/* Project page */
.proj-header {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 4px;
}
.git-meta {
  font-size: 12px;
  color: var(--fg-dim);
  margin: 6px 0 16px;
  padding: 8px 12px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 4px;
}
.git-meta .meta-k { font-size: 10px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--fg-dim); }
.warn-pill {
  display: inline-block;
  margin-left: 10px;
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 8px;
  background: var(--bg);
  border: 1px solid var(--warn);
  color: var(--warn);
}
.counts-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 12px 0 18px;
}
.count-chip {
  display: flex;
  align-items: baseline;
  gap: 6px;
  padding: 4px 12px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--fg);
}
.count-chip:hover { background: var(--bg-elev-2); text-decoration: none; }
.count-chip .num { font-size: 16px; font-weight: 600; color: var(--fg-bright); }
.count-chip .lbl { font-size: 12px; color: var(--fg-dim); }

/* Entity rows */
.entity-list { list-style: none; padding: 0; margin: 0 0 22px; }
.entity-row {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 4px 6px;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.entity-row:hover { background: var(--bg-elev); }
.entity-row.is-dismissed { opacity: 0.45; }
.entity-row .slug { color: var(--accent); min-width: 180px; }
.entity-row .title { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.entity-row .when { font-family: var(--mono); font-size: 11px; }
.entity-row .proj-tag {
  font-family: var(--mono); font-size: 11px;
  color: var(--fg-dim);
  padding: 1px 6px;
  background: var(--bg-elev);
  border-radius: 8px;
}

.kind-chip {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: lowercase;
  padding: 1px 6px;
  border-radius: 8px;
  background: var(--bg-elev-2);
  color: var(--fg-dim);
  min-width: 70px;
  text-align: center;
}
.kind-episode  { color: var(--fresh-live); }
.kind-history  { color: var(--tag-decision); }
.kind-decision { color: var(--accent); }
.kind-gotcha   { color: var(--warn); }
.kind-tension  { color: #8a2a2a; }
.kind-session  { color: var(--tag-session); }
.kind-briefing { color: var(--tag-session); }
.kind-memory   { color: var(--fg-dim); }

/* Entity page */
.entity-title { font-family: var(--serif); font-size: 18px; margin: 4px 0 18px; color: var(--fg); }
.frontmatter {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 10px 14px;
  margin: 0 0 22px;
  font-size: 12.5px;
}
.frontmatter dl { margin: 0; display: grid; grid-template-columns: max-content 1fr; column-gap: 16px; row-gap: 4px; }
.frontmatter dt { color: var(--fg-dim); }
.frontmatter dd { margin: 0; word-break: break-all; }

.markdown { font-family: var(--serif); font-size: 16px; line-height: 1.65; max-width: 70ch; }
.markdown h1 { font-size: 22px; margin: 22px 0 8px; }
.markdown h2 { font-size: 18px; margin: 18px 0 6px; }
.markdown h3 { font-size: 16px; margin: 14px 0 4px; }
.markdown pre, .markdown code {
  font-family: var(--mono);
  font-size: 13px;
  background: var(--bg-elev);
  border-radius: 3px;
}
.markdown code { padding: 1px 5px; }
.markdown pre { padding: 12px 14px; overflow-x: auto; line-height: 1.45; }
.markdown blockquote {
  border-left: 3px solid var(--accent);
  padding-left: 12px;
  margin-left: 0;
  color: var(--fg-dim);
}
.markdown a { color: var(--accent); }

/* Epistemology */
.epis-tier-head {
  display: flex; align-items: baseline; gap: 12px;
  margin: 26px 0 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.epis-tier-label {
  font-size: 13px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
}
.epis-tier-sub { font-size: 12px; color: var(--fg-dim); font-style: italic; }
.epis-list { display: flex; flex-direction: column; gap: 12px; max-width: 920px; }
.epis-card {
  display: grid;
  grid-template-columns: 32px 12px 1fr;
  padding: 12px 14px 12px 8px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 6px;
}
.epis-card:hover { background: var(--bg-elev-2); }
.epis-rank { font-family: var(--mono); color: var(--fg-dim); text-align: center; padding-top: 2px; }
.epis-spine { border-left: 2px solid var(--accent); margin-right: 12px; }
.epis-card.epis-tier-application .epis-spine { border-left-color: var(--tag-decision); }
.epis-card.epis-tier-application .epis-role { color: var(--tag-decision); }
.epis-body { display: flex; flex-direction: column; gap: 4px; }
.epis-h {
  display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap;
}
.epis-name { font-size: 16px; font-weight: 600; color: var(--fg-bright); }
.epis-role { font-size: 13px; color: var(--accent); font-style: italic; }
.epis-note { font-size: 13.5px; line-height: 1.5; margin: 4px 0 6px; max-width: 60ch; }
.epis-stats { font-family: var(--mono); font-size: 11px; }
.epis-goto { font-size: 12px; color: var(--accent); }
.epis-missing { color: #8a2a2a; font-style: italic; font-size: 11px; }

/* ─ Login page ─────────────────────────────────────────────── */
body.login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
}
.login-card {
  width: 100%;
  max-width: 360px;
  padding: 32px 28px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
}
.login-title {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 600;
  color: var(--fg-bright);
  margin: 0 0 4px;
  text-align: center;
}
.login-sub {
  text-align: center;
  color: var(--fg-dim);
  font-size: 12px;
  margin: 0 0 22px;
}
.login-error {
  background: #fff0ec;
  border: 1px solid #d28070;
  color: #8a2a2a;
  padding: 8px 12px;
  border-radius: 4px;
  font-size: 13px;
  margin-bottom: 14px;
}
.login-card form { display: flex; flex-direction: column; gap: 12px; }
.login-card label {
  font-size: 11px;
  color: var(--fg-dim);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.login-card input[type="text"],
.login-card input[type="password"] {
  padding: 8px 10px;
  font-size: 14px;
  font-family: var(--sans);
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--bg);
  color: var(--fg);
}
.login-card input:focus {
  outline: 2px solid var(--accent);
  outline-offset: -1px;
  border-color: var(--accent);
}
.login-card button {
  margin-top: 6px;
  padding: 10px 16px;
  font-size: 14px;
  font-weight: 500;
  background: var(--accent);
  color: white;
  border: none;
  border-radius: 4px;
  cursor: pointer;
}
.login-card button:hover { opacity: 0.9; }

/* ─ Mobile (≤ 700px) ──────────────────────────────────────────
   Goal: zero horizontal scroll on a phone. Tables get a scroll
   container; entity rows wrap; long words break instead of pushing
   the viewport wider. */
@media (max-width: 700px) {
  body { font-size: 14.5px; }

  .app-header {
    padding: 10px 14px;
    gap: 10px;
    flex-wrap: wrap;
  }
  .top-nav { gap: 12px; margin-left: 0; }

  .page { padding: 16px 14px 60px; }

  .page-title { font-size: 24px; }
  .section-h { font-size: 16px; flex-wrap: wrap; gap: 6px; }

  /* Tables: let them scroll inside their own box, not the page. */
  .proj-table { display: block; overflow-x: auto; white-space: nowrap; }
  .proj-table thead, .proj-table tbody { display: table; width: 100%; }

  /* Entity rows: wrap instead of pushing the viewport. */
  .entity-row {
    flex-wrap: wrap;
    gap: 6px 10px;
    padding: 6px 4px;
  }
  .entity-row .slug { min-width: 0; }
  .entity-row .title { white-space: normal; overflow: visible; word-break: break-word; flex-basis: 100%; }
  .entity-row .when { font-size: 10.5px; }

  /* Counts row & tiles: tighter on small screens. */
  .tiles { grid-template-columns: 1fr; gap: 10px; }
  .tile { padding: 12px 14px; }
  .tile .num { font-size: 22px; }

  .counts-row { gap: 6px; }
  .count-chip { padding: 3px 8px; }
  .count-chip .num { font-size: 14px; }

  /* Frontmatter: one-column key/value stack. */
  .frontmatter dl { grid-template-columns: 1fr; row-gap: 2px; }
  .frontmatter dt { margin-top: 4px; }

  /* Project header: stack instead of side-by-side. */
  .proj-header { flex-direction: column; gap: 4px; }

  /* Markdown: cap width to viewport, break long URLs/words. */
  .markdown { font-size: 15px; max-width: 100%; word-wrap: break-word; overflow-wrap: anywhere; }
  .markdown pre { font-size: 12px; }

  /* Epistemology cards: thinner spine, give content the room. */
  .epis-card { grid-template-columns: 22px 6px 1fr; padding: 10px 10px 10px 6px; }
  .epis-spine { margin-right: 8px; }
  .epis-note { font-size: 13px; max-width: 100%; }

  /* Login card: full-width on phone. */
  .login-card { max-width: 100%; padding: 24px 18px; border-radius: 0; border-left: 0; border-right: 0; }
}

/* Belt-and-braces: anywhere a stray long token (URL, hash, slug)
   sneaks past the rules above, never let it shove the viewport. */
html, body { overflow-x: hidden; max-width: 100%; }
