*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f172a;color:#e2e8f0;overflow:hidden;height:100vh;display:flex;flex-direction:column}#app{display:flex;flex-direction:column;height:100vh}#header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1.5rem;background:#1e293b;border-bottom:1px solid #334155;flex-shrink:0}#header h1{font-size:1.25rem;font-weight:700;color:#f8fafc;letter-spacing:-.02em}#info-btn{width:28px;height:28px;border-radius:50%;border:1px solid #475569;background:transparent;color:#94a3b8;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}#info-btn:hover{background:#334155;color:#f8fafc}#map-container{flex:1;min-height:0;background:#0f172a;overflow:hidden}#map-container svg{display:block}.country{cursor:pointer;transition:fill .2s ease,stroke .2s ease}#bottom-panel{display:flex;flex-shrink:0;height:180px;background:#1e293b;border-top:1px solid #334155}#detail-panel,#source-panel{flex:1;padding:.75rem 1.25rem;overflow-y:auto}#detail-panel{border-right:1px solid #334155}#detail-panel h3,#source-panel h3{font-size:.95rem;color:#f8fafc;margin-bottom:.4rem}.placeholder{color:#64748b;font-size:.85rem;padding-top:.5rem}.base-score,.pair-score{font-size:.85rem;color:#cbd5e1;margin-bottom:.3rem}.summary{font-size:.82rem;color:#94a3b8;font-style:italic;margin:.3rem 0}.reviewed{font-size:.75rem;color:#64748b}.hint{font-size:.75rem;color:#475569;margin-top:.5rem}.unresearched{color:#64748b;font-style:italic}#source-panel ol{padding-left:1.2rem;font-size:.8rem;color:#cbd5e1}#source-panel li{margin-bottom:.35rem;line-height:1.4}#source-panel a{color:#60a5fa;text-decoration:none}#source-panel a:hover{text-decoration:underline}#source-panel blockquote{border-left:2px solid #475569;padding-left:.5rem;margin:.2rem 0;color:#94a3b8;font-size:.78rem;font-style:italic}#tooltip{position:fixed;background:#1e293b;color:#e2e8f0;border:1px solid #475569;border-radius:6px;padding:.5rem .75rem;font-size:.8rem;line-height:1.4;pointer-events:none;z-index:1000;max-width:280px;box-shadow:0 4px 12px #0006}#tooltip.hidden{display:none}#modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000}#modal-overlay.hidden{display:none}#modal{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:1.5rem 2rem;max-width:560px;width:90%;max-height:80vh;overflow-y:auto;position:relative}#modal h2{font-size:1.2rem;color:#f8fafc;margin-bottom:.75rem}#modal h3{font-size:.95rem;color:#e2e8f0;margin:.75rem 0 .35rem}#modal p{font-size:.85rem;color:#94a3b8;line-height:1.5;margin-bottom:.4rem}#modal ul{padding-left:1.2rem;font-size:.85rem;color:#cbd5e1;margin-bottom:.5rem}#modal li{margin-bottom:.25rem}#modal-close{position:absolute;top:.75rem;right:.75rem;background:transparent;border:none;color:#94a3b8;font-size:1.5rem;cursor:pointer;line-height:1}#modal-close:hover{color:#f8fafc}.error{color:#ef4444;text-align:center;padding:2rem}.sore-spots-heading{font-size:.82rem;color:#94a3b8;margin-top:.6rem;margin-bottom:.3rem;border-top:1px solid #334155;padding-top:.4rem}.sore-spots{display:flex;flex-direction:column;gap:.3rem}.sore-spot{font-size:.78rem;line-height:1.35;padding:.25rem .4rem;border-radius:4px}.sore-spot.direction-higher{background:#22c55e1a;border-left:2px solid #22c55e}.sore-spot.direction-lower{background:#ef44441a;border-left:2px solid #ef4444}.spot-arrow{font-weight:700;font-size:.85rem}.direction-higher .spot-arrow{color:#22c55e}.direction-lower .spot-arrow{color:#ef4444}
