@import"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,900;1,700&family=Source+Code+Pro:wght@400;600&display=swap";*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;background:#ede6cc;font-family:Playfair Display,Georgia,serif;overflow:hidden}#app{display:flex;flex-direction:column;height:100vh;height:100dvh}#tabs{display:flex;background:#c4aa5c;border-bottom:2px solid #9a8030;flex-shrink:0}.tab{padding:9px 22px;font-size:10px;letter-spacing:2.5px;font-family:Source Code Pro,Courier New,monospace;color:#5a3e08;cursor:pointer;border-right:1px solid #9a8030;user-select:none;text-transform:uppercase}.tab.active{background:#ede6cc;color:#1a1008;font-weight:600}.tab:hover:not(.active){background:#d4b96a}#view-map{flex:1;display:flex;flex-direction:column;min-height:0}#map-wrap{flex:1;position:relative;min-height:0;overflow:hidden}#map-wrap canvas{position:absolute;top:0;left:0;width:100%;height:100%}#left-panel{position:absolute;top:20px;left:22px;pointer-events:none;display:flex;flex-direction:column;gap:12px;max-width:240px}#title-block{line-height:1.05}#t1{font-size:clamp(32px,4.05vw,52px);font-weight:700;color:#1a1008;letter-spacing:-.5px}#t2{font-size:clamp(40px,5.2vw,70px);font-style:italic;color:#b54a1a;font-weight:700;letter-spacing:-.5px}#sub-text{font-size:11px;color:#2e2010;line-height:1.65;font-family:Source Code Pro,Courier New,monospace;font-weight:400}#leg{font-family:Source Code Pro,Courier New,monospace;font-size:11px;color:#2e2010}.legr{display:flex;align-items:center;gap:7px;margin-bottom:5px}.legd{width:9px;height:9px;border-radius:50%;flex-shrink:0}#yr-display{position:absolute;top:16px;right:22px;text-align:right;pointer-events:none}#yr-label{font-size:10px;letter-spacing:3px;color:#7a5820;font-family:Source Code Pro,Courier New,monospace;text-transform:uppercase;margin-bottom:2px}#yr-num{font-size:clamp(72px,10vw,130px);font-weight:900;color:#1a1008;line-height:.9;font-family:Playfair Display,Georgia,serif;letter-spacing:-2px}#daily-wrap{margin-top:6px}#daily-num{font-size:clamp(18px,2.4vw,28px);font-weight:700;color:#1a4fa0;font-family:Playfair Display,Georgia,serif}#daily-lbl{font-size:9px;letter-spacing:2px;color:#7a5820;font-family:Source Code Pro,Courier New,monospace;text-transform:uppercase}#origins-box{position:absolute;bottom:14px;right:22px;font-family:Source Code Pro,Courier New,monospace;pointer-events:none}#orig-title{font-size:9px;letter-spacing:2.5px;color:#7a5820;margin-bottom:6px;text-transform:uppercase}.orow{display:flex;gap:8px;font-size:12px;color:#1a1008;margin-bottom:3px}.orank{color:#9a7030;width:18px;font-size:10px}.oname{width:110px}.oname.hi{color:#b54a1a;font-weight:600}.oval{min-width:60px;text-align:right;font-size:11px;color:#3a2810}#bottom-bar{background:#c8b060;border-top:2px solid #9a8030;padding:8px 22px 10px;flex-shrink:0}#stats-row{display:flex;justify-content:space-around;margin-bottom:7px}.sb{display:flex;flex-direction:column;align-items:center}.sn{font-size:clamp(16px,2.2vw,26px);font-weight:700;color:#1a1008;line-height:1;font-family:Playfair Display,Georgia,serif}.sn.blue{color:#1a3a80}.sn.red{color:#b54a1a}.sl{font-size:8px;letter-spacing:1.5px;color:#5a3e08;font-family:Source Code Pro,Courier New,monospace;text-align:center;margin-top:2px;text-transform:uppercase}#progress-row{display:flex;align-items:center;gap:12px}#play-btn{background:#1a3a80;border:none;color:#fff;font-size:11px;padding:6px 16px;border-radius:2px;font-family:Source Code Pro,Courier New,monospace;cursor:pointer;white-space:nowrap;flex-shrink:0;letter-spacing:1.5px;text-transform:uppercase}#play-btn:hover{background:#0d2a60}#pw{flex:1;position:relative;height:18px;cursor:pointer}#pt{width:100%;height:4px;background:#a89040;border-radius:2px;margin-top:7px}#pf{height:4px;background:#1a3a80;border-radius:2px;width:0%;pointer-events:none}#ph{position:absolute;top:2px;left:0;width:14px;height:14px;background:#1a3a80;border-radius:50%;transform:translate(-7px)}#yr-ticks{display:flex;justify-content:space-between;margin-top:2px}.yt{font-size:8px;font-family:Source Code Pro,Courier New,monospace;color:#7a5820}#view-income,#view-remit{display:none;flex:1;overflow-y:auto;padding:18px 22px;background:#ede6cc}.panel-title{font-size:11px;letter-spacing:3px;color:#7a5820;font-family:Source Code Pro,Courier New,monospace;margin-bottom:14px;text-transform:uppercase;border-bottom:1px solid #b8a050;padding-bottom:8px}.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.kpi{background:#d8c870;border-radius:2px;padding:11px 13px;border:1px solid #b8a050}.kpi-num{font-size:clamp(18px,2.5vw,28px);font-weight:700;color:#1a1008;font-family:Playfair Display,Georgia,serif}.kpi-num.blue{color:#1a3a80}.kpi-lbl{font-size:8px;letter-spacing:1px;color:#5a3e08;font-family:Source Code Pro,Courier New,monospace;margin-top:4px;text-transform:uppercase}.sec{font-size:9px;letter-spacing:2.5px;color:#7a5820;font-family:Source Code Pro,Courier New,monospace;margin:14px 0 7px;border-top:1px solid #b8a050;padding-top:9px;text-transform:uppercase}.br{display:flex;align-items:center;gap:8px;margin-bottom:5px}.bl{font-size:10px;font-family:Source Code Pro,Courier New,monospace;color:#2e2010;width:135px;flex-shrink:0}.bt{flex:1;height:13px;background:#b8a050;border-radius:1px;overflow:hidden}.bf{height:100%;border-radius:1px}.bv{font-size:10px;font-family:Source Code Pro,Courier New,monospace;color:#2e2010;width:72px;text-align:right;flex-shrink:0}.note{font-size:9px;font-family:Source Code Pro,Courier New,monospace;color:#7a5820;margin-top:12px;line-height:1.6}#toggles{position:absolute;top:14px;left:50%;transform:translate(-50%);display:flex;gap:6px;pointer-events:all}.tgl{background:#e8debed9;border:1.5px solid #9a8030;color:#5a3e08;font-size:9px;letter-spacing:1.5px;font-family:Source Code Pro,Courier New,monospace;padding:5px 12px;cursor:pointer;border-radius:2px;text-transform:uppercase;transition:all .15s;backdrop-filter:blur(2px)}.tgl.active{background:#1a3a80;color:#fff;border-color:#1a3a80}.tgl:hover:not(.active){background:#c8b060e6}#tooltip{position:absolute;pointer-events:none;background:#1a1008eb;color:#f0e8cc;font-family:Source Code Pro,Courier New,monospace;font-size:11px;padding:10px 14px;border-radius:3px;border:1px solid #c8a840;line-height:1.7;min-width:180px;z-index:100}#tooltip .tt-state{font-size:13px;font-weight:600;color:#f0d060;margin-bottom:4px;font-family:Playfair Display,Georgia,serif}#tooltip .tt-row{display:flex;justify-content:space-between;gap:16px}#tooltip .tt-key{color:#c8b880}#tooltip .tt-val{color:#fff;font-weight:600}#housing-legend{position:absolute;bottom:14px;left:22px;font-family:Source Code Pro,Courier New,monospace;pointer-events:none}#hl-title{font-size:8px;letter-spacing:2px;color:#7a5820;margin-bottom:5px;text-transform:uppercase}#hl-scale{display:flex;gap:2px}.hl-sw{width:22px;height:14px;border:.5px solid rgba(0,0,0,.2)}#hl-labels{display:flex;justify-content:space-between;font-size:7.5px;color:#5a3e08;margin-top:2px}@media(max-width:900px){.bl{width:110px}.bv{width:60px}}@media(max-width:640px){.tab{padding:7px 12px;font-size:8.5px;letter-spacing:1.5px}#left-panel{top:10px;left:10px;gap:5px;max-width:160px}#t1{font-size:clamp(20px,5.5vw,30px)}#t2{font-size:clamp(26px,7.5vw,40px)}#sub-text{display:none}#leg{font-size:9px}.legr{margin-bottom:2px}.legd{width:7px;height:7px}#yr-display{top:8px;right:10px}#yr-label{display:none}#yr-num{font-size:clamp(46px,13vw,72px)}#daily-num{font-size:clamp(13px,3.6vw,19px)}#daily-lbl{font-size:7px;letter-spacing:1.5px}#origins-box{display:none}#toggles{top:auto;bottom:10px;left:10px;transform:none;flex-direction:column;align-items:flex-start;gap:4px}.tgl{font-size:8px;padding:5px 12px;letter-spacing:1px}#housing-legend{left:auto;right:10px;bottom:10px}#hl-title{display:none}#bottom-bar{padding:5px 12px 8px}#stats-row{margin-bottom:4px}.sn{font-size:clamp(13px,3.6vw,20px)}.sl{font-size:6.5px;letter-spacing:1px}#play-btn{font-size:9px;padding:5px 12px;letter-spacing:1px}#pw{height:24px}#pt{margin-top:10px}#ph{top:5px}.yt{font-size:7px}#view-income,#view-remit{padding:14px}.panel-title{font-size:9px;letter-spacing:2px}.kpi-grid{grid-template-columns:1fr}.kpi{padding:9px 11px}.kpi-num{font-size:clamp(16px,5vw,22px)}.sec{font-size:8px}.bl{width:85px;font-size:9px}.bv{width:50px;font-size:9px}.bt{height:11px}.br{gap:6px;margin-bottom:4px}}@media(max-width:420px){#leg{display:none}#left-panel{max-width:130px}#t1{font-size:18px}#t2{font-size:24px}#yr-num{font-size:40px}.tgl{font-size:7.5px;padding:4px 10px}.sn{font-size:13px}.sl{font-size:6px}}
