:root{color:#20242a;background:#f4f1ea;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button{font:inherit}code{padding:2px 5px;background:#e7e1d5;font-size:.9em}.article-shell{width:min(1120px,calc(100% - 32px));margin:0 auto;padding:40px 0 56px}.article-intro{max-width:760px;margin-bottom:22px}.article-intro h1{max-width:720px;margin:0;color:#171a1e;font-size:clamp(2rem,4vw,3.25rem);line-height:1.03}.article-intro p:last-child{max-width:680px;margin:14px 0 0;color:#4f514e;font-size:1.02rem}.story-module{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(320px,.9fr);grid-template-rows:auto auto;border:1px solid rgba(32,36,42,.18);background:#fbfaf6;box-shadow:0 18px 45px #20242a1f}.map-panel{position:relative;background:#e9e4d8}#map{position:relative;width:100%;line-height:0}.legend{position:absolute;left:16px;bottom:16px;display:flex;flex-wrap:wrap;gap:10px;max-width:calc(100% - 32px);padding:8px 10px;border:1px solid rgba(32,36,42,.16);background:#ffffffeb;color:#20242a;font-size:.78rem;box-shadow:0 10px 24px #20242a24}.legend span{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}.legend i{width:10px;height:10px;border-radius:50%;display:inline-block}.legend .confirmed{background:#15745f}.legend .provisional{background:#4b5cae}.legend .reconstructed{background:#88568f}.legend .case-size{width:16px;height:16px;border:2px solid rgba(75,92,174,.72);background:#4b5cae24}.place-marker{position:relative;display:inline-flex;align-items:center;gap:6px;width:auto;padding:0;border:0;background:transparent;color:#20242a;cursor:pointer;transform:translate(-8px,-8px);pointer-events:auto}.case-bubble{position:absolute;left:calc(var(--bubble-size) / -2 + 7px);top:calc(var(--bubble-size) / -2 + 7px);width:var(--bubble-size);height:var(--bubble-size);display:inline-grid;place-items:center;border:2px solid rgba(75,92,174,.68);border-radius:50%;background:#4b5cae29;color:#1c2026;font-size:.68rem;font-weight:900;z-index:-1}.place-dot{width:14px;height:14px;display:inline-block;border:2px solid #ffffff;border-radius:50%;background:var(--marker-color);box-shadow:0 3px 10px #20242a42}.place-marker.is-reconstructed .place-dot{border-style:dashed}.place-marker.is-provisional .place-dot{box-shadow:0 0 0 5px #4b5cae29,0 3px 10px #20242a38}.place-marker.is-active .place-label{border-color:#15181c}.place-label{max-width:140px;padding:3px 6px;border:1px solid rgba(32,36,42,.18);background:#ffffffeb;color:#20242a;font-size:.72rem;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 4px 12px #20242a24}.phase-marker{display:inline-flex;align-items:center;gap:5px;padding:0;border:0;background:transparent;cursor:pointer;transform:translate(-5px,-5px);pointer-events:auto}.phase-dot{width:11px;height:11px;border:2px solid #ffffff;border-radius:50%;background:var(--phase-color, #8a96a3);box-shadow:0 2px 7px #20242a47}.phase-marker-label{padding:2px 5px;background:#ffffffdb;color:#33373d;font-size:.68rem;font-weight:700;white-space:nowrap}.maplibregl-popup-content{max-width:300px;padding:0;border-radius:0;box-shadow:0 12px 28px #20242a33;color:#20242a;font:.82rem/1.35 Inter,ui-sans-serif,system-ui,sans-serif}.event-tooltip{padding:12px 13px}.event-tooltip p,.event-tooltip h2{margin:0}.event-tooltip h2{margin-top:3px;color:#171a1e;font-size:1rem;line-height:1.15}.event-tooltip p:not(.tooltip-date):not(.tooltip-status){margin-top:9px}.event-tooltip footer{margin-top:10px;color:#6b6258;font-size:.74rem}.tooltip-date{color:#6a6258;font-size:.72rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.tooltip-status{display:inline-flex;margin-top:7px;padding:3px 7px;color:#fff;font-size:.72rem;font-weight:800}.tooltip-status.is-confirmed{background:#15745f}.tooltip-status.is-provisional{background:#4b5cae}.tooltip-status.is-reconstructed{background:#88568f}.tooltip-status.is-suspected{background:#c27a20}.tooltip-status.is-disputed{background:#a73b38}.story-panel{position:relative;min-height:0;border-left:1px solid rgba(32,36,42,.14);background:#fffdf8;overflow:hidden}#story{position:absolute;inset:0;overflow-y:auto;padding:24px 24px 20px}.eyebrow{margin:0 0 10px;color:#6a6258;font-size:.76rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.story-panel h1{margin:0;color:#171a1e;font-size:1.65rem;line-height:1.12}.kicker{margin:12px 0 0;color:#15745f;font-size:.92rem;font-weight:800}.story-description{margin:16px 0 0;color:#30343a;font-size:.98rem}blockquote{margin:16px 0 0;padding:0 0 0 14px;border-left:4px solid #c27a20;color:#3c3428;font-size:.94rem}.tally{margin-top:18px;padding-top:14px;border-top:1px solid rgba(32,36,42,.14)}.tally-label{margin:0;color:#6a6258;font-size:.72rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.tally .metric-strip{margin-top:8px}.evo-curve{width:100%;height:auto;display:block;margin-top:8px}.evo-line{fill:none}.evo-line.evo-confirmed{stroke:#15745f;stroke-width:2.2}.evo-line.evo-suspected{stroke:#c8913c;stroke-width:1.6}.evo-line.evo-deaths{stroke:#b5403a;stroke-width:1.6}.evo-dot{stroke:#fff;stroke-width:1}.evo-dot.evo-confirmed{fill:#15745f}.evo-dot.evo-suspected{fill:#c8913c}.evo-dot.evo-deaths{fill:#b5403a}.evo-axis{stroke:#20242a40}.evo-now{stroke:#20242a2e;stroke-dasharray:2 2}.evo-axis-label{fill:#8a8275;font-size:9px}.evo-legend{display:flex;flex-wrap:wrap;gap:4px 14px;margin-top:5px;color:#4f514e;font-size:.72rem}.evo-key{display:inline-flex;align-items:center;gap:5px}.evo-key:before{content:"";width:13px;height:3px;border-radius:2px}.evo-key.evo-confirmed:before{background:#15745f}.evo-key.evo-suspected:before{background:#c8913c}.evo-key.evo-deaths:before{background:#b5403a}.tally-figure{margin:9px 0 0;color:#30343a;font-size:.88rem}.tally-figure strong{font-variant-numeric:tabular-nums}.tally-zones{margin:12px 0 0;color:#30343a;font-size:.86rem;line-height:1.45}.tally-zones-label{font-weight:800;color:#6a6258}.tally-zones strong{font-variant-numeric:tabular-nums}.tally-note{margin:8px 0 0;color:#8a8275;font-size:.74rem;font-style:italic}.metric-strip{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}.metric-strip span{padding:7px 9px;border:1px solid rgba(32,36,42,.14);background:#fff;font-size:.82rem}.metric-strip strong{margin-right:4px}.uncertainty-note{display:grid;gap:5px;margin-top:18px;padding:11px 12px;border-left:4px solid #c27a20;background:#fff7e7;color:#3c3428;font-size:.86rem}.source-line{margin:20px 0 0;padding-top:12px;border-top:1px solid rgba(32,36,42,.12);color:#6a6258;font-size:.82rem}.uncertainty-note strong{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}.metadata{display:grid;gap:10px;margin:20px 0 0}.metadata div{padding-top:9px;border-top:1px solid rgba(32,36,42,.12)}.metadata dt{color:#6a6258;font-size:.72rem;font-weight:800;text-transform:uppercase}.metadata dd{margin:3px 0 0;color:#20242a;font-size:.9rem}.status-pill{display:inline-flex;align-items:center;min-height:23px;padding:3px 8px;color:#fff;font-size:.76rem;font-weight:800}.status-pill.is-confirmed,.step-index.is-confirmed{background:#15745f}.status-pill.is-provisional,.step-index.is-provisional{background:#4b5cae}.status-pill.is-reconstructed,.step-index.is-reconstructed{background:#88568f}.status-pill.is-suspected,.step-index.is-suspected{background:#c27a20}.status-pill.is-disputed,.step-index.is-disputed{background:#a73b38}.static-map{width:100%;height:auto;display:block;background:#e9e4d8}.map-base{fill:#e9e4d8}.map-relief{opacity:.5}.province-focus{fill:#c9843a52;stroke:#b9742e;stroke-width:1.2;opacity:.9}.map-roads{fill:none;stroke:#b6a587;stroke-width:1.1;opacity:.65}.map-rivers{fill:none;stroke:#9db6c6;stroke-width:1.1}.map-lakes{fill:#c2d3dc;stroke:#a7bfca;stroke-width:.8}.province-border{fill:none;stroke:#8c8470;stroke-width:1.2;stroke-dasharray:5 4;opacity:.8}.country-border{fill:none;stroke:#6f6857;stroke-width:1.4;opacity:.7}.country-label{fill:#5f5949;font-size:19px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;text-anchor:middle;paint-order:stroke;stroke:#f4f1ead9;stroke-width:3.5}.province-label{fill:#97702f;font-size:17px;font-style:italic;text-anchor:middle;paint-order:stroke;stroke:#f4f1eacc;stroke-width:3}.map-scale line{stroke:#3a3730;stroke-width:2}.map-scale text{fill:#3a3730;font-size:16px;font-weight:700;text-anchor:middle}.map-place{cursor:pointer}.place-pin{fill:#1b1f24;stroke:#fff;stroke-width:2}.place-name{fill:#1b1f24;font-size:18px;font-weight:700;paint-order:stroke;stroke:#f4f1ea;stroke-width:3.5}.map-place.is-active .place-pin{fill:#15745f}.map-place.is-active .place-name{font-size:20px}.map-place.is-dimmed{opacity:.28}.map-place[style*=--phase-color] .place-pin{fill:var(--phase-color)}.case-bubble{fill:#b0403a33;stroke:#b0403a8c;stroke-width:.8;pointer-events:none}.case-bubble.is-dimmed{opacity:.22}.case-legend-bg{fill:#fcfaf6db;stroke:#20242a2e;stroke-width:1}.case-legend-title{fill:#33373d;font-size:13px;font-weight:800}.case-legend-sub{fill:#6a6258;font-size:11px}.case-legend-num{fill:#33373d;font-size:11px;font-weight:700;text-anchor:middle;dominant-baseline:middle}.map-inset{position:absolute;left:14px;bottom:14px;width:138px;height:auto;background:#fbfaf6eb;border:1px solid rgba(32,36,42,.18);padding:4px}.inset-land{fill:#d8d2c4;stroke:#b3ab98;stroke-width:.4}.inset-frame{fill:none;stroke:#c0392b;stroke-width:1.2}.inset-dot{fill:#33373d}.inset-city{fill:#33373d;font-size:7px;font-weight:700}.inset-caption{fill:#33373d;font-size:8px;font-weight:800}.timeline-rail{grid-column:1 / -1;min-width:0;border-top:1px solid rgba(32,36,42,.14);background:#f7f4ed}.timeline-axis{padding:12px 20px 4px}.axis-track{position:relative;height:96px}.axis-track:after{content:"";position:absolute;left:0;right:0;top:76px;border-top:1px solid rgba(32,36,42,.22)}.axis-annot{position:absolute;top:0;width:0;height:76px}.axis-annot:after{content:"";position:absolute;left:0;top:28px;height:48px;border-left:1px solid var(--phase-color, #8a96a3);opacity:.55}.axis-annot.tier-1:after{top:56px;height:20px}.axis-annot-text{position:absolute;top:0;left:0;width:144px;transform:translate(-50%);text-align:center;color:#33373d;font-size:.69rem;font-weight:600;line-height:1.15;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.axis-annot.tier-1 .axis-annot-text{top:28px}.axis-annot.is-start .axis-annot-text{transform:translate(0);text-align:left}.axis-annot.is-end .axis-annot-text{transform:translate(-100%);text-align:right}.axis-annot-date{display:block;color:var(--phase-color, #8a96a3);font-size:.66rem;font-weight:800}.axis-tick{position:absolute;top:76px;height:6px;width:0;border-left:1px solid rgba(32,36,42,.2)}.axis-tick-label{position:absolute;top:10px;left:0;transform:translate(-50%);color:#8a8275;font-size:.66rem;font-weight:700;white-space:nowrap}.axis-dot{position:absolute;top:calc(76px - var(--row, 0) * 11px);width:9px;height:9px;padding:0;border:1.5px solid #ffffff;border-radius:50%;background:var(--phase-color, #6a6258);box-shadow:0 0 0 1px #20242a38;transform:translate(-50%,-50%);cursor:pointer}.axis-dot.is-primary{width:12px;height:12px}.axis-dot.is-secondary{opacity:.82}.axis-dot:hover{box-shadow:0 0 0 2px #20242a52}.axis-dot.is-active{box-shadow:0 0 0 4px #15745f47}.axis-dot.is-dimmed{opacity:.16}.axis-annot.is-dimmed{opacity:.28}.timeline-legend{display:flex;flex-wrap:wrap;gap:6px 8px;padding:4px 20px 14px}.legend-phase{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid rgba(32,36,42,.18);border-radius:999px;background:#fbfaf6;color:#4f514e;font-size:.72rem;font-weight:700;cursor:pointer}.legend-phase:hover{border-color:#20242a66}.legend-phase.is-on{border-color:var(--phase-color);background:var(--phase-color);color:#fff}.legend-swatch{width:10px;height:10px;border-radius:50%;background:var(--phase-color);box-shadow:0 0 0 1px #ffffffb3}.legend-phase.is-on .legend-swatch{background:#fff}@media(max-width:900px){.article-shell{width:min(100% - 20px,680px);padding-top:24px}.story-module{grid-template-columns:1fr;grid-template-rows:auto auto auto}.story-panel{min-height:auto;border-left:0;border-top:1px solid rgba(32,36,42,.14);overflow:visible}#story{position:static;padding:22px 20px}}
