*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#e0e0e0}#app{display:flex;height:100%}#sidebar{width:360px;min-width:360px;background:#16213e;border-right:1px solid #0f3460;overflow-y:auto;display:flex;flex-direction:column;z-index:1000}#sidebar.collapsed{width:0;min-width:0;overflow:hidden}.sidebar-header{padding:16px;background:#0f3460;border-bottom:1px solid #533483}.sidebar-header h1{font-size:1.2rem;color:#e94560;margin-bottom:4px}.sidebar-header .subtitle{font-size:.8rem;color:#888}.sidebar-content{flex:1;padding:16px}.panel{display:none}.panel.active{display:block}#map{flex:1;background:#0a0a1a}.city-marker{background:none;border:none}.city-dot{width:10px;height:10px;background:#e94560;border:2px solid #fff;border-radius:50%;cursor:pointer;transition:transform .15s}.city-dot:hover{transform:scale(1.4)}.city-dot.metropolis{width:14px;height:14px;background:gold}.city-dot.port{background:#4fc3f7}.leaflet-popup-content-wrapper{background:#16213e;color:#e0e0e0;border:1px solid #533483;border-radius:8px}.leaflet-popup-tip{background:#16213e}.leaflet-popup-content{margin:12px}.city-popup h3{color:#e94560;margin-bottom:6px;font-size:1rem}.city-popup .zone-badge{display:inline-block;background:#533483;color:#e0e0e0;padding:2px 8px;border-radius:4px;font-size:.75rem;margin-bottom:6px}.city-popup .city-type{font-size:.8rem;color:#888}.search-box{width:100%;padding:8px 12px;background:#1a1a2e;border:1px solid #0f3460;border-radius:6px;color:#e0e0e0;font-size:.9rem;outline:none}.search-box:focus{border-color:#e94560}.search-box::placeholder{color:#555}.price-table{width:100%;border-collapse:collapse;font-size:.85rem}.price-table th,.price-table td{padding:6px 8px;text-align:left;border-bottom:1px solid #0f3460}.price-table th{color:#e94560;font-weight:600}.route-summary{background:#1a1a2e;border:1px solid #0f3460;border-radius:8px;padding:12px;margin-top:12px}.cost-bar{display:flex;height:24px;border-radius:4px;overflow:hidden;margin:8px 0}.cost-bar .segment{display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#fff;min-width:20px}.cost-bar .seg-base{background:#4caf50}.cost-bar .seg-toll{background:#ff9800}.cost-bar .seg-transport{background:#2196f3}.cost-bar .seg-guard{background:#9c27b0}.cost-bar .seg-spoilage{background:#f44336}.btn{display:inline-block;padding:8px 16px;background:#e94560;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem}.btn:hover{background:#c23152}.btn-secondary{background:#0f3460}.btn-secondary:hover{background:#1a4a8a}.fan-disclaimer{padding:12px 16px;background:#0a0a1a;border-top:1px solid #0f3460;font-size:.7rem;color:#666;text-align:center}.fan-disclaimer img{height:30px;margin-bottom:6px}@media(max-width:768px){#sidebar{position:absolute;top:0;left:0;width:100%;height:50%;min-width:unset;border-right:none;border-bottom:1px solid #0f3460}#sidebar.collapsed{height:0}}
