*{box-sizing:border-box}html,body,#root{min-height:100%}:root{color:#e9f2f4;background:radial-gradient(circle at 10% 20%,#19313b,#0c151b 60%);font-family:IBM Plex Sans,Segoe UI,sans-serif}body{margin:0}.layout{grid-template-columns:minmax(680px,1fr) 380px;align-items:start;gap:1rem;min-height:100vh;padding:.5rem;display:grid}.map-panel{justify-content:center;align-items:center;display:flex}.map-shell{border:2px solid #2d4a59;border-radius:12px;width:min(100%,88.4114vh - .884114rem);height:calc(100vh - 1rem);position:relative;overflow:hidden}.map-svg{cursor:crosshair;width:100%;height:100%;display:block}.route-label,.poi-label{fill:#fff;paint-order:stroke;stroke:#000;stroke-width:2px;font-size:11px}.sidebar{background:#132732;border:1px solid #284655;border-radius:12px;padding:1rem}.route-list{gap:.35rem;margin:1rem 0;display:grid}.route-item{align-items:center;gap:.5rem;font-size:.95rem;display:flex}.solve-button{color:#021016;background:linear-gradient(90deg,#39d3ff,#7affc2);border:none;border-radius:8px;width:100%;padding:.75rem;font-weight:700}.error{color:#ff8e8e}.result{margin-top:1rem}.hint{color:#b8dce9;font-size:.85rem}pre{white-space:pre-wrap;background:#091319;border:1px solid #243e4c;border-radius:8px;padding:.75rem;font-size:.8rem}@media (width<=1100px){.layout{grid-template-columns:1fr}.map-shell{width:min(100%,88.4114vh - .884114rem)}}
