:root{color:#172033;background:#f5f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}.app{grid-template-columns:350px 1fr;min-height:100vh;display:grid}aside{color:#e5e7eb;background:#111827;max-height:100vh;padding:22px;overflow:auto}h1{color:#f9a8d4;margin:0;font-size:26px}h2{margin:22px 0 10px;font-size:16px}p{color:#475569}aside p{color:#cbd5e1}button,select{cursor:pointer;color:#111827;background:#e5e7eb;border:0;border-radius:10px;margin:4px;padding:9px 11px;font-weight:700}input::file-selector-button{cursor:pointer;color:#111827;background:#e5e7eb;border:0;border-radius:10px;margin:4px;padding:9px 11px;font-weight:700}button:disabled{opacity:.45;cursor:not-allowed}button:hover:not(:disabled){filter:brightness(.95)}button.primary{color:#fff;background:#f472b6;width:100%;padding:13px;font-size:16px}.error{color:#fff;background:#7f1d1d;border-radius:10px;margin-top:10px;padding:10px}.tools{grid-template-columns:1fr 1fr;gap:6px;display:grid}.tools button{align-items:center;gap:6px;margin:0;display:flex}.tools .active{outline:3px solid #f472b6}.swatch{vertical-align:middle;border:1px solid #111827;border-radius:4px;width:14px;height:14px;display:inline-block}.empty{background:#fff}.wall{background:#1f2937}.blocked{background:#020617}.risk{background:#f97316}.crowd{background:#38bdf8}.start{background:#22c55e}.exit{background:#ef4444}.presetBtns,.inline{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.inline input{border:0;border-radius:10px;width:70px;padding:9px 8px}label{color:#f3f4f6;margin:8px 0;display:block}.fileLabel input{margin-top:6px;display:block}input[type=range]{width:100%}main{padding:24px;overflow:auto}header{justify-content:space-between;align-items:flex-start;gap:20px;display:flex}header h2{color:#111827;margin:0;font-size:24px}.legend{background:#fff;border-radius:14px;flex-wrap:wrap;gap:12px;margin:12px 0;padding:10px 12px;display:flex;box-shadow:0 8px 24px #0f172a10}.legend span{color:#334155;align-items:center;gap:5px;font-size:13px;display:inline-flex}.gridWrap{background:#fff;border-radius:18px;padding:16px;overflow:auto;box-shadow:0 10px 30px #0f172a14}.grid{gap:2px;width:max-content;display:grid}.cell{background:#fff;border:1px solid #dbe3ee;border-radius:3px;width:24px;height:24px;margin:0;padding:0;position:relative}.cell.wall{background:#334155;border-color:#334155}.cell.blocked{background:#020617;border-color:#020617}.cell.risk.i1{background:#fed7aa}.cell.risk.i2{background:#fb923c}.cell.risk.i3{background:#ea580c}.cell.crowd.i1{background:#bae6fd}.cell.crowd.i2{background:#38bdf8}.cell.crowd.i3{background:#0284c7}.cell.start{background:#22c55e;border-color:#16a34a}.cell.exit{background:#ef4444;border-color:#dc2626}.cell.hasRoute{outline:3px solid var(--route-color);outline-offset:-3px;box-shadow:inset 0 0 0 2px #fff,0 0 0 1px var(--route-color);background-image:linear-gradient(135deg,color-mix(in srgb,var(--route-color) 28%,transparent),transparent 48%)}.cell.multiRoute{outline-color:var(--route-color-2);background-image:linear-gradient(135deg,color-mix(in srgb,var(--route-color) 34%,transparent) 0 49%,color-mix(in srgb,var(--route-color-2) 34%,transparent) 50% 100%)}.routeBadge{color:#fff;pointer-events:none;background:#0f172a;border-radius:999px;min-width:11px;height:11px;font-size:8px;font-weight:800;line-height:11px;position:absolute;bottom:1px;right:1px}.routeFilters{grid-template-columns:1fr 1fr;gap:6px;margin-bottom:6px;display:grid}.routeFilters button{justify-content:center;align-items:center;gap:6px;margin:0;display:flex}.routeFilters .active{background:#fce7f3;outline:3px solid #f472b6}.emptyPanel,.results{background:#fff;border-radius:18px;margin-top:18px;padding:18px;box-shadow:0 10px 30px #0f172a14}.recommend{color:#065f46;background:#ecfdf5;border-radius:12px;margin-bottom:12px;padding:12px;line-height:1.5}table{border-collapse:collapse;width:100%;font-size:14px}th,td{text-align:left;border-bottom:1px solid #e5e7eb;padding:10px}th{color:#475569;background:#f8fafc}.sortBtn{color:#475569;background:0 0;margin:0;padding:0}.win{background:#f0fdf4}.best{color:#166534;background:#dcfce7;font-weight:800}.routeKey{border-radius:999px;width:10px;height:10px;margin-right:8px;display:inline-block}.check{align-items:center;gap:8px;margin:7px 0;display:flex}.check input{width:auto}.weightsLine{color:#475569;background:#f8fafc;border-radius:10px;margin-bottom:10px;padding:10px}.hint{font-size:12px}@media (width<=1000px){.app{grid-template-columns:1fr}aside{max-height:none}.cell{width:24px;height:24px}}.num{text-align:right}.win{background:#f0fdf4;border-left:5px solid #16a34a}.win td:first-child{font-weight:800}.results td.num,.results th.num{text-align:right}.results tr:hover{background:#f8fafc}.cell:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible{outline-offset:2px;outline:3px solid #f472b6}
