
:root{--teal:#1F4E5F;--teal2:#2E6E7E;--ink:#1b2227;--muted:#5b6770;--bg:#f6f9fa;--card:#fff;--line:#e2e8ea;
--causal:#2e7d32;--robust:#5a9e4f;--moderate:#c08a1e;--emerging:#cc7a33;--contested:#bb3b3b;
--risk:#b8442e;--protective:#2e7d32;--marker:#6b7780;--maxw:1100px}
*{box-sizing:border-box}html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.62;font-size:17px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.skip{position:absolute;left:-999px}.skip:focus{left:8px;top:8px;background:#fff;padding:8px;z-index:50}
a{color:var(--teal2)}h1,h2,h3{line-height:1.25;color:var(--teal)}
h1{font-size:2.05rem;margin:.2em 0 .3em}h2{font-size:1.5rem;margin:1.6em 0 .5em}h3{font-size:1.18rem;margin:1.3em 0 .4em;color:var(--ink)}
p{margin:.6em 0}
header.site{background:var(--teal);position:sticky;top:0;z-index:40;box-shadow:0 1px 0 rgba(0,0,0,.15)}
.nav{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:10px 20px}
.brand{display:flex;align-items:center;gap:9px;color:#fff;text-decoration:none;font-size:1.1rem}
.brand strong{color:#bfe3ec}
.brand .mark{width:22px;height:22px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#bfe3ec 0 18%,transparent 19%),radial-gradient(circle at 70% 40%,#bfe3ec 0 14%,transparent 15%),radial-gradient(circle at 50% 72%,#bfe3ec 0 14%,transparent 15%),#2E6E7E;box-shadow:inset 0 0 0 2px #4f93a3}
header nav{display:flex;gap:3px;flex-wrap:wrap}
header nav a{color:#dfeef2;text-decoration:none;padding:5px 8px;border-radius:6px;font-size:.9rem}
header nav a:hover{background:rgba(255,255,255,.12);color:#fff}
header nav a.active{background:#fff;color:var(--teal);font-weight:600}
.hero{background:linear-gradient(160deg,#1F4E5F,#2E6E7E);color:#eaf4f6;padding:34px 0 8px}
.hero .wrap{max-width:880px}.hero h1{color:#fff;font-size:2.2rem}.hero p.lead{font-size:1.12rem;color:#d6ebef}
section{padding:14px 0}.section-pad{padding:30px 0}.lede{font-size:1.12rem;color:#33424a;max-width:780px}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin:22px 0}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px}
.stat .n{font-size:1.7rem;font-weight:700;color:var(--teal)}.stat .l{font-size:.92rem;color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin:18px 0}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px}.card h3{margin-top:0}
.callout{background:#eaf1f3;border-left:5px solid var(--teal);border-radius:8px;padding:14px 16px;margin:18px 0}
.note{background:#fff7ed;border-left:5px solid var(--emerging);border-radius:8px;padding:12px 15px;margin:14px 0}
.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.78rem;font-weight:700;color:#fff;white-space:nowrap}
.b-causal{background:var(--causal)}.b-robust{background:var(--robust)}.b-moderate{background:var(--moderate)}.b-emerging{background:var(--emerging)}.b-contested{background:var(--contested)}
.dir{font-weight:700}.d-risk{color:var(--risk)}.d-protective{color:var(--protective)}.d-marker{color:var(--marker)}
.controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:16px 0;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px}
.controls select,.controls input{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:.95rem;background:#fff}.controls input{flex:1;min-width:160px}
table.matrix{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
table.matrix th{background:var(--teal);color:#fff;text-align:left;padding:10px 12px;font-size:.86rem}
table.matrix td{padding:10px 12px;border-top:1px solid var(--line);font-size:.93rem;vertical-align:top}
tr.frow{cursor:pointer}tr.frow:hover{background:#f0f6f7}tr.detail td{background:#f8fbfc;color:#33424a;font-size:.92rem}
.hide{display:none}.count{color:var(--muted);font-size:.9rem;margin:6px 2px}
ul.tight li{margin:.28em 0}
.src{margin:.45em 0}.src .ty{display:inline-block;font-size:.72rem;background:#e8eef0;color:#3a4a51;border-radius:5px;padding:1px 7px;margin-left:6px}
.dl{display:flex;gap:12px;flex-wrap:wrap;margin:14px 0}.dl a{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 16px;text-decoration:none;color:var(--ink)}.dl a strong{color:var(--teal)}
footer.site{background:#10333d;color:#cfe1e6;margin-top:40px;padding:26px 0;font-size:.9rem}
footer.site a{color:#bfe3ec}footer .disc{color:#eaf4f6}footer .meta{color:#9fbcc4;font-size:.84rem}
/* MAP */
.maphero{padding-bottom:18px}
.mapband{background:linear-gradient(180deg,#2E6E7E,#23586a);padding:6px 0 18px}
.mapgrid{max-width:1240px;margin:0 auto;padding:0 16px;display:grid;grid-template-columns:1fr 320px;gap:14px;align-items:start}
#map{background:#23586a;border-radius:12px;position:relative;min-height:300px}
#map svg{width:100%;height:auto;display:block}
.country{stroke:#1b4250;stroke-width:.4px;cursor:pointer;transition:opacity .1s}
.country:hover{stroke:#fff;stroke-width:1px}
.nodata{fill:#3c6573}
#cpanel{background:#fff;border-radius:12px;padding:16px;min-height:300px;color:var(--ink)}
#cpanel h3{margin:.1em 0 .2em;color:var(--teal)}
#cpanel .big{font-size:2rem;font-weight:700;color:var(--teal);line-height:1}
#cpanel .sub{color:var(--muted);font-size:.85rem;margin-bottom:8px}
#cpanel .pnote{font-size:.93rem}
.legend{display:flex;gap:0;flex-wrap:wrap;align-items:center;margin:10px 0 2px;color:#eaf4f6;font-size:.82rem}
.legend .sw{display:inline-block;width:30px;height:12px}
.maptip{position:fixed;pointer-events:none;background:#10333d;color:#fff;padding:5px 9px;border-radius:6px;font-size:.82rem;opacity:0;transition:opacity .08s;z-index:60}
.mapnote{color:#cfe6ec;font-size:.8rem;margin-top:8px}
.mapsel{margin:8px 0}
.mapsel select{padding:7px 9px;border-radius:8px;border:1px solid #2b6275;background:#1b4250;color:#fff}
@media(max-width:820px){.mapgrid{grid-template-columns:1fr}#cpanel{min-height:0}}
@media(max-width:640px){.hero h1{font-size:1.7rem}h1{font-size:1.6rem}}

/* tools */
header nav a.tool{background:#bfe3ec;color:#10333d;font-weight:700}
header nav a.tool.active{background:#fff;color:var(--teal)}
header nav a.tool:hover{background:#fff}
.note.privacy{background:#eaf5ef;border-left-color:#2e7d32}
.tm{font-weight:400;font-size:.8rem;color:var(--muted)}
form#dx .drh{margin:1.1em 0 .2em;color:var(--teal)}
.qrow{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin:10px 0}
.qrow .qt{font-weight:600;margin-bottom:8px}
.opts{display:flex;gap:6px;flex-wrap:wrap}
.opts label{font-size:.85rem;border:1px solid var(--line);border-radius:20px;padding:5px 11px;cursor:pointer;background:#fff;user-select:none}
.opts input{margin-right:5px}
.opts label:hover{background:#eef5f6}
.qrow input[type=range]{width:100%}
.btn2{background:var(--teal);color:#fff;border:none;border-radius:8px;padding:12px 22px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:16px}
.btn2:hover{background:#163c49}
.crisis{background:#fbeceb;border:1px solid #bb3b3b;border-left:5px solid #bb3b3b;border-radius:8px;padding:14px 16px;margin:16px 0}
.crisis b{color:#bb3b3b}
.sev{font-size:1.35rem;font-weight:700;color:var(--teal)}
.resultcard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px;margin:14px 0}
table.wheel{width:100%;border-collapse:collapse;margin:8px 0}
table.wheel td{padding:6px 8px;border-top:1px solid var(--line);font-size:.92rem;vertical-align:middle}
table.wheel td.sc{width:54px;text-align:right;font-weight:600}
.bar{height:10px;border-radius:6px;background:#e2e8ea;overflow:hidden}
.bar span{display:block;height:100%;background:var(--teal2)}
.big3 li{margin:.4em 0}
.copybtn{background:#fff;border:1px solid var(--teal2);color:var(--teal);border-radius:8px;padding:8px 14px;cursor:pointer;font-weight:600}
textarea.copyout{width:100%;min-height:170px;border:1px solid var(--line);border-radius:8px;padding:12px;font-family:ui-monospace,monospace;font-size:.85rem}
.proto{background:var(--card);border:1px solid var(--line);border-left:5px solid var(--teal2);border-radius:10px;padding:14px 16px;margin:12px 0}
.proto h3{margin:.1em 0 .3em;color:var(--ink)}
.hint{color:var(--muted);font-size:.95rem}
