/* Reading Room — shared theme (matches personal_learnings/index.html) */
:root{
  --bg:#0c0e13; --bg-2:#11141c; --panel:#161a24; --panel-2:#1b212d;
  --ink:#e8e4d8; --ink-dim:#a39c8c; --ink-faint:#6f6a5e;
  --line:rgba(255,255,255,.09); --line-strong:rgba(255,255,255,.16);
  --heat:#ff7a45; --heat-soft:rgba(255,122,69,.14);
  --info:#54d2e3; --info-soft:rgba(84,210,227,.13);
  --serif:'Spectral',Georgia,serif; --mono:'IBM Plex Mono',ui-monospace,monospace;
  --maxw:920px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--serif);font-weight:300;font-size:19px;line-height:1.65;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
a{color:inherit}

.topbar{position:sticky;top:0;z-index:40;background:rgba(12,14,19,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar-inner{max-width:var(--maxw);margin:0 auto;padding:12px 24px;display:flex;align-items:center;gap:10px}
.brand{font-family:var(--mono);font-size:13px;letter-spacing:.05em;color:var(--ink);text-decoration:none}
.brand b{color:var(--info);font-weight:600}
.topbar .spacer{margin-left:auto}
.topbar .tag{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--ink-faint);text-transform:uppercase}
.crumb{font-family:var(--mono);font-size:12px;color:var(--ink-faint);text-decoration:none}
.crumb:hover{color:var(--info)}

header.hero{padding:80px 0 36px;border-bottom:1px solid var(--line)}
.kicker{font-family:var(--mono);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--info);margin:0 0 20px}
h1{font-weight:300;font-size:clamp(32px,6vw,52px);line-height:1.08;letter-spacing:-.015em;margin:0 0 20px}
h1 em{font-style:italic;color:var(--heat)}
.standfirst{font-size:20px;color:var(--ink-dim);max-width:680px;margin:0}
.standfirst b{color:var(--ink);font-weight:500}

.section-label{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin:48px 0 18px;display:flex;align-items:center;gap:12px}
.section-label::after{content:"";height:1px;flex:1;background:var(--line)}

/* index: source cards grouped by cluster */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.card{position:relative;display:block;text-decoration:none;padding:20px 22px 18px;border-radius:12px;background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--line);transition:transform .18s,border-color .18s,box-shadow .18s}
.card:hover{transform:translateY(-3px);border-color:var(--line-strong);box-shadow:0 14px 34px rgba(0,0,0,.4)}
.card .ck{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--info);margin:0 0 9px}
.card h2{font-weight:400;font-size:22px;line-height:1.2;letter-spacing:-.01em;margin:0 0 6px}
.card:hover h2{color:#fff}
.card .auth{font-size:14px;color:var(--ink-dim);margin:0 0 12px}
.card .foot{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11.5px;color:var(--ink-faint)}
.card .arrow{margin-left:auto;color:var(--ink-faint);transition:.18s}
.card:hover .arrow{color:var(--info);transform:translateX(3px)}

/* per-source guide page */
.room-head{padding-bottom:8px}
.stat{font-family:var(--mono);font-size:12.5px;color:var(--ink-faint);margin:6px 0 0}
.stat b{color:var(--info);font-weight:600}
.theme{margin:40px 0 0}
.theme > h2{font-weight:400;font-size:26px;letter-spacing:-.01em;margin:0 0 4px}
.theme .tcount{font-family:var(--mono);font-size:11.5px;color:var(--ink-faint);margin:0 0 8px}
.theme .tintro{font-size:16.5px;color:var(--ink-dim);margin:0 0 20px}
.entry{padding:16px 0;border-top:1px solid var(--line)}
.entry h3{font-weight:500;font-size:18px;line-height:1.3;margin:0 0 6px}
.entry .meta{font-family:var(--mono);font-size:11.5px;color:var(--ink-faint);margin:0 0 8px;display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center}
.tier{font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.04em;padding:2px 7px;border-radius:999px}
.tier.t5{color:var(--heat);background:var(--heat-soft);border:1px solid var(--heat-soft)}
.tier.t4{color:var(--info);background:var(--info-soft);border:1px solid var(--info-soft)}
.entry .sum{font-size:16px;color:var(--ink-dim);margin:0 0 8px}
.topics{display:flex;flex-wrap:wrap;gap:6px}
.topics span{font-family:var(--mono);font-size:10.5px;color:var(--ink-faint);border:1px solid var(--line);border-radius:999px;padding:2px 8px}
.readlink{font-family:var(--mono);font-size:12px;color:var(--info);text-decoration:none;border-bottom:1px solid var(--info-soft)}

/* library: filter + search */
.lib-controls{position:sticky;top:46px;z-index:30;background:var(--bg);padding:16px 0;border-bottom:1px solid var(--line);display:flex;flex-wrap:wrap;gap:10px}
.lib-controls input,.lib-controls select{font-family:var(--mono);font-size:13px;background:var(--panel);color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:8px 12px}
.lib-controls input{flex:1;min-width:200px}
.lib-row{padding:14px 0;border-top:1px solid var(--line)}
.lib-row h3{font-weight:500;font-size:17px;margin:0 0 5px}
.lib-row .meta{font-family:var(--mono);font-size:11px;color:var(--ink-faint);display:flex;flex-wrap:wrap;gap:6px 12px;margin:0 0 6px}
.lib-row .sum{font-size:15px;color:var(--ink-dim);margin:0}
.libcount{font-family:var(--mono);font-size:12px;color:var(--ink-faint);margin:14px 0 0}

footer{padding:44px 0 60px;margin-top:44px;border-top:1px solid var(--line);color:var(--ink-faint);font-family:var(--mono);font-size:12.5px;line-height:1.8}
@media(max-width:680px){body{font-size:18px}.grid{grid-template-columns:1fr}.topbar .tag{display:none}}

/* left TOC sidebar (per-source guide pages) */
html{scroll-padding-top:62px}
.toc{position:fixed;top:64px;left:max(14px,calc((100vw - var(--maxw))/2 - 232px));width:212px;max-height:78vh;overflow-y:auto;padding:6px 14px 24px 0;font-family:var(--mono)}
.toc-h{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 12px}
.toc a{display:block;color:var(--ink-dim);text-decoration:none;font-size:11.5px;line-height:1.32;padding:5px 0 5px 12px;border-left:2px solid var(--line);transition:.15s}
.toc a:hover{color:var(--info);border-left-color:var(--info)}
@media(max-width:1320px){.toc{display:none}}
