:root{
  --ink:#12243b;          /* deep authority navy */
  --ink-soft:#33465f;
  --paper:#f7f4ec;        /* document off-white */
  --paper-2:#efeadd;
  --line:#d8d0bd;
  --amber:#b9742a;        /* measured caution, not alarm */
  --amber-soft:#f0dcc2;
  --red:#9b2f2f;          /* reserved for score 5 */
  --red-soft:#eccaca;
  --green:#3a6b4f;        /* defensible */
  --green-soft:#cfe0d3;
  --shadow:0 1px 0 var(--line), 0 10px 30px -22px rgba(18,36,59,.5);
  --serif:"IBM Plex Serif",Georgia,serif;
  --sans:"IBM Plex Sans",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-size:16px;line-height:1.5;
}
.wrap{max-width:1140px;margin:0 auto;padding:0 22px}
a{color:var(--ink)}
.skip{position:absolute;left:-999px}
.skip:focus{left:12px;top:12px;background:var(--ink);color:var(--paper);padding:8px 12px;z-index:50}

/* masthead */
.masthead{border-bottom:2px solid var(--ink);background:var(--paper)}
.masthead-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 22px}
.brand{display:flex;align-items:center;gap:14px}
.seal{font-family:var(--serif);font-size:38px;line-height:1;color:var(--amber);
  border:2px solid var(--ink);border-radius:50%;width:52px;height:52px;display:grid;place-items:center;flex:none}
.masthead h1{font-family:var(--serif);font-weight:600;font-size:25px;margin:0;letter-spacing:-.01em}
.tagline{margin:2px 0 0;font-size:12.5px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em}
.topnav{display:flex;gap:20px;font-size:14px}
.topnav a{text-decoration:none;color:var(--ink-soft);border-bottom:1px solid transparent;padding-bottom:2px}
.topnav a:hover{color:var(--ink);border-color:var(--amber)}

/* hero */
.hero{background:linear-gradient(180deg,var(--paper),var(--paper-2));border-bottom:1px solid var(--line);padding:34px 0 26px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--amber);text-transform:uppercase;margin:0 0 14px}
.thesis{font-family:var(--serif);font-size:21px;line-height:1.5;max-width:60ch;margin:0 0 26px}
.thesis em{font-style:italic;color:var(--amber)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.stat{background:var(--paper);padding:16px 18px}
.stat .num{display:block;font-family:var(--mono);font-weight:600;font-size:26px;color:var(--ink)}
.stat .lab{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin-top:4px}
.distribution{display:flex;height:12px;margin-top:18px;border:1px solid var(--ink);overflow:hidden}
.distribution span{display:block;height:100%}
.distribution .s1{background:var(--green-soft)}
.distribution .s2{background:#e7dcc4}
.distribution .s3{background:var(--amber-soft)}
.distribution .s4{background:var(--amber)}
.distribution .s5{background:var(--red)}

/* controls */
.controls{padding:24px 22px 6px}
.searchrow{display:flex;gap:10px;margin-bottom:14px}
#q{flex:1;font-family:var(--sans);font-size:16px;padding:12px 14px;border:1px solid var(--ink);background:var(--paper);border-radius:0}
#q:focus{outline:2px solid var(--amber);outline-offset:1px}
.ghost{background:none;border:1px solid var(--line);padding:0 16px;cursor:pointer;font-family:var(--sans);color:var(--ink-soft)}
.ghost:hover{border-color:var(--ink);color:var(--ink)}
.filters{display:flex;flex-wrap:wrap;gap:14px 20px}
.filters label{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);display:flex;flex-direction:column;gap:5px}
.filters select{font-family:var(--sans);font-size:14px;text-transform:none;letter-spacing:0;color:var(--ink);padding:8px 10px;border:1px solid var(--line);background:var(--paper)}
.filters select:focus{outline:2px solid var(--amber)}
.resultcount{font-family:var(--mono);font-size:13px;color:var(--ink-soft);margin:16px 0 0}

/* results */
#results{padding-top:8px;min-height:40vh}
.loading{font-family:var(--mono);color:var(--ink-soft);padding:30px 0}
.entry{display:grid;grid-template-columns:64px 1fr auto;gap:18px;align-items:start;
  border-bottom:1px solid var(--line);padding:18px 4px;cursor:pointer}
.entry:hover{background:var(--paper-2)}
.entry:focus-visible{outline:2px solid var(--amber);outline-offset:-2px}
.score{font-family:var(--mono);font-weight:600;width:54px;height:54px;display:grid;place-content:center;text-align:center;border:2px solid var(--ink);line-height:1}
.score b{font-size:20px}
.score small{font-size:8.5px;text-transform:uppercase;letter-spacing:.04em;display:block;margin-top:2px}
.score.sc5{background:var(--red);color:#fff;border-color:var(--red)}
.score.sc4{background:var(--amber);color:#fff;border-color:var(--amber)}
.score.sc3{background:var(--amber-soft)}
.score.sc2{background:#e7dcc4}
.score.sc1{background:var(--green-soft);border-color:var(--green)}
.entry-main h3{font-family:var(--sans);font-weight:600;font-size:16px;margin:0 0 3px;line-height:1.35}
.entry-main .ent{font-size:13.5px;color:var(--ink-soft);margin:0 0 8px}
.entry-main .reason{font-family:var(--serif);font-size:14.5px;color:var(--ink);margin:0;
  border-left:3px solid var(--line);padding-left:12px;max-width:74ch}
.flagchips{margin-top:9px;display:flex;flex-wrap:wrap;gap:6px}
.chip{font-family:var(--mono);font-size:11px;padding:3px 8px;background:var(--paper);border:1px solid var(--amber);color:var(--amber);text-transform:uppercase;letter-spacing:.03em}
.entry-meta{text-align:right;white-space:nowrap}
.entry-meta .val{font-family:var(--mono);font-weight:600;font-size:16px}
.entry-meta .typ{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin-top:4px}
.more{display:block;margin:26px auto 60px;font-family:var(--sans);font-size:15px;background:var(--ink);color:var(--paper);border:none;padding:13px 30px;cursor:pointer}
.more:hover{background:var(--amber)}
.empty{font-family:var(--serif);font-size:18px;color:var(--ink-soft);padding:40px 0 60px}

/* footer */
.sitefoot{background:var(--ink);color:#dfe5ee;margin-top:30px;padding:34px 0 46px}
.sitefoot a{color:#fff}
.disclaimer{font-size:13.5px;line-height:1.6;max-width:90ch;color:#cdd5e0}
.disclaimer strong{color:#fff}
.footnav{display:flex;flex-wrap:wrap;gap:18px;margin:20px 0 16px;font-size:14px}
.copyline{font-size:12px;color:#9fabbd;line-height:1.6}
.copyline a{color:#cdd5e0}

/* modal */
.modal{position:fixed;inset:0;background:rgba(10,18,30,.62);display:grid;place-items:start center;
  padding:40px 16px;overflow:auto;z-index:40}
.modal-card{background:var(--paper);max-width:760px;width:100%;border-top:6px solid var(--amber);
  box-shadow:var(--shadow);padding:30px 34px 38px;position:relative}
.modal-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:30px;line-height:1;cursor:pointer;color:var(--ink-soft)}
.modal-close:hover{color:var(--ink)}
.m-head{display:flex;gap:18px;align-items:flex-start;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:6px}
.m-head h2{font-family:var(--serif);font-weight:600;font-size:21px;margin:0 0 4px;line-height:1.3}
.m-head .sub{font-size:13.5px;color:var(--ink-soft)}
.m-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px 24px;margin:18px 0;font-size:14px}
.m-grid div{padding:7px 0;border-bottom:1px dotted var(--line)}
.m-grid .k{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
.m-grid .v{font-family:var(--mono);font-size:14px}
.m-section-title{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--amber);margin:22px 0 10px}
.m-reason{font-family:var(--serif);font-size:16px;border-left:3px solid var(--amber);padding:6px 0 6px 14px;margin:0 0 4px}
.flag-card{border:1px solid var(--line);padding:14px 16px;margin-bottom:12px;background:var(--paper)}
.flag-card h4{margin:0 0 8px;font-size:14.5px}
.flag-card .part{font-size:13.5px;margin:6px 0;line-height:1.55}
.flag-card .part b{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);display:block;margin-bottom:1px}
.m-note{font-size:12.5px;color:var(--ink-soft);background:var(--paper-2);padding:12px 14px;border-left:3px solid var(--line);margin-top:18px;line-height:1.55}
.m-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:20px}
.m-actions a{font-family:var(--sans);font-size:14px;text-decoration:none;padding:10px 18px;border:1px solid var(--ink)}
.m-actions a.primary{background:var(--ink);color:var(--paper)}
.m-actions a:hover{border-color:var(--amber)}

/* static content pages */
.doc{max-width:760px;margin:0 auto;padding:40px 22px 70px}
.doc h1{font-family:var(--serif);font-size:30px;margin:0 0 6px}
.doc h2{font-family:var(--serif);font-size:21px;margin:32px 0 8px}
.doc h3{font-size:16px;margin:22px 0 6px}
.doc p,.doc li{font-size:15px;line-height:1.65;color:var(--ink-soft)}
.doc strong{color:var(--ink)}
.doc .updated{font-family:var(--mono);font-size:12px;color:var(--ink-soft)}
.doc a{color:var(--amber)}
.backlink{font-family:var(--mono);font-size:13px;display:inline-block;margin-bottom:18px}

@media (max-width:820px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .thesis{font-size:18px}
  .entry{grid-template-columns:54px 1fr;gap:14px}
  .entry-meta{grid-column:2;text-align:left;margin-top:6px}
  .m-grid{grid-template-columns:1fr}
  .topnav{display:none}
}
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important}}

/* --- feature additions: flags, exports, smart-search link --- */
.flag{display:inline-block;width:20px;height:15px;margin-right:6px;vertical-align:-2px;
  border:1px solid rgba(18,36,59,.15);object-fit:cover}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:16px}
.toolbar .resultcount{margin:0}
.exports{display:flex;gap:10px}
.exports .ghost{font-size:13px;padding:8px 14px;cursor:pointer;background:var(--paper);border:1px solid var(--ink);color:var(--ink)}
.exports .ghost:hover{border-color:var(--amber);color:var(--amber)}
.linkbtn{background:none;border:none;padding:0;margin:0;font:inherit;color:var(--amber);
  text-decoration:underline;cursor:pointer}
.linkbtn:hover{color:var(--ink)}
.m-head .sub .flag{vertical-align:-2px}
@media (max-width:820px){
  .toolbar{flex-direction:column;align-items:flex-start}
}

/* --- insights: pie + heat map --- */
.insights{padding:28px 22px 6px}
.insights-head h2{font-family:var(--serif);font-size:22px;margin:0 0 4px}
.insights-head #insights-summary{font-size:14px;color:var(--ink-soft);margin:0 0 18px;max-width:80ch}
.insights-grid{display:grid;grid-template-columns:300px 1fr;gap:26px;align-items:start}
.insights figure{margin:0}
.insights figcaption{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--amber);margin-bottom:10px}
.map-hint{color:var(--ink-soft);text-transform:none;letter-spacing:0}
.pie-wrap{display:flex;flex-direction:column;align-items:center}
#pie{display:flex;justify-content:center}
.pieslice{cursor:pointer;transition:opacity .12s}
.pieslice:hover{opacity:.8}
.pie-center-n{font-family:var(--mono);font-weight:600;font-size:20px;fill:var(--ink)}
.pie-center-l{font-family:var(--sans);font-size:9px;fill:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em}
.pie-legend{display:grid;grid-template-columns:1fr 1fr;gap:2px 10px;margin-top:14px;width:100%}
.leg{display:flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;font:inherit;
  font-size:12px;color:var(--ink);padding:3px 2px;text-align:left}
.leg.nolink{cursor:default}
.leg:not(.nolink):hover{color:var(--amber)}
.leg .dot{width:10px;height:10px;flex:none;border:1px solid rgba(0,0,0,.1)}
.leg b{margin-left:auto;font-family:var(--mono);font-weight:600;color:var(--ink-soft)}
.map-wrap{position:relative}
#map{border:1px solid var(--line);background:#fbfaf6;min-height:200px;display:flex;align-items:center;justify-content:center}
#map svg{width:100%;height:auto;display:block}
.cpath{transition:fill .1s}
.cpath.has{cursor:pointer}
.cpath.has:hover{fill:var(--ink)!important}
.map-tip{position:absolute;background:var(--ink);color:#fff;font-size:12px;padding:5px 9px;
  pointer-events:none;z-index:5;white-space:nowrap;box-shadow:0 4px 14px -6px rgba(0,0,0,.5)}
.muted{color:var(--ink-soft);font-size:14px}
@media (max-width:820px){
  .insights-grid{grid-template-columns:1fr;gap:30px}
  .pie-wrap{max-width:320px;margin:0 auto}
}

/* --- relocated insights: compact panel beside the filters --- */
.controls-body{display:flex;gap:24px;align-items:flex-start;margin-top:2px}
.controls-body .filters{flex:1 1 320px;align-content:flex-start}
.insights-mini{flex:0 0 460px;max-width:460px;border:1px solid var(--line);background:var(--paper-2);padding:14px 16px}
.insights-mini h2{font-family:var(--serif);font-size:16px;margin:0 0 4px}
.insights-mini #insights-summary{font-size:11.5px;color:var(--ink-soft);margin:0 0 12px;line-height:1.5}
.insights-mini-grid{display:grid;grid-template-columns:148px 1fr;gap:14px;align-items:start}
.insights-mini #pie svg{width:140px;height:140px}
.insights-mini .pie-legend{grid-template-columns:1fr;gap:1px;margin-top:8px;font-size:11px}
.insights-mini .map-wrap{position:relative}
.insights-mini #map{min-height:110px;border:1px solid var(--line)}
@media (max-width:980px){
  .controls-body{flex-direction:column}
  .insights-mini{flex:1 1 auto;max-width:none;width:100%}
  .insights-mini-grid{grid-template-columns:170px 1fr}
}
@media (max-width:560px){
  .insights-mini-grid{grid-template-columns:1fr;justify-items:center}
}

/* --- logo as home link --- */
a.brand{text-decoration:none;color:inherit}
a.brand:hover h1{color:var(--amber)}
a.seal{text-decoration:none}
.seal{transition:background .12s,color .12s}
a.seal:hover{background:var(--amber);color:#fff}
