*{margin:0;padding:0;box-sizing:border-box}body{font-family:system-ui,-apple-system,sans-serif;background:#0f172a;color:#e2e8f0}.container{display:flex;height:100vh;overflow:hidden}.sidebar{width:380px;min-width:380px;background:#1e293b;border-right:1px solid #334155;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:16px;border-bottom:1px solid #334155;background:#1e293b}.sidebar-header h1{font-size:18px;color:#f1f5f9;margin-bottom:12px}.sidebar-header h1 span{color:#38bdf8}.upload-area{border:2px dashed #475569;border-radius:8px;padding:12px;text-align:center;cursor:pointer;transition:all .2s;font-size:13px;color:#94a3b8}.upload-area:hover{border-color:#38bdf8;color:#38bdf8;background:#38bdf81a}.upload-area input{display:none}.sidebar-content{flex:1;overflow-y:auto;padding:12px 16px}.filter-bar{margin-bottom:12px}.filter-bar select{width:100%;padding:8px 10px;background:#0f172a;color:#e2e8f0;border:1px solid #475569;border-radius:6px;font-size:13px}.route-list{display:flex;flex-direction:column;gap:8px}.route-card{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:12px;cursor:pointer;transition:all .2s}.route-card:hover{border-color:#38bdf8}.route-card.active{border-color:#38bdf8;background:#38bdf81a}.route-card-header{display:flex;justify-content:space-between;align-items:start}.route-card h3{font-size:14px;color:#f1f5f9;margin-bottom:4px}.route-card .plate{font-size:12px;color:#38bdf8;font-weight:600}.route-card .date{font-size:12px;color:#94a3b8;margin-top:2px}.route-card .points-count{font-size:11px;color:#64748b;margin-top:4px}.route-card .actions{display:flex;gap:4px}.route-card button{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;color:#94a3b8;font-size:14px;transition:all .2s}.route-card button:hover{background:#334155;color:#f1f5f9}.route-card button.danger:hover{background:#ef444433;color:#ef4444}.route-card button.active{background:#38bdf826;color:#38bdf8}.route-card button.btn-points,.route-card button.btn-reorder{font-size:16px;line-height:1}.route-card button.btn-reorder:disabled{opacity:.5;cursor:not-allowed}.route-card button.btn-reorder:disabled:hover{background:none;color:#94a3b8}.map-container{flex:1;position:relative}#map{width:100%;height:100%}.map-header{position:absolute;top:10px;left:10px;z-index:1000;background:#0f172af2;padding:10px 16px;border-radius:8px;border:1px solid #334155;max-width:400px}.map-header h2{font-size:14px;color:#f1f5f9}.map-header p{font-size:12px;color:#94a3b8;margin-top:2px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#64748b;text-align:center;padding:20px}.empty-state h2{font-size:20px;margin-bottom:8px}.empty-state p{font-size:14px}.points-panel{border-top:1px solid #334155;margin-top:12px;padding-top:12px;max-height:50%;display:flex;flex-direction:column}.points-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.points-panel-header h3{font-size:13px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.points-actions{display:flex;gap:6px}.points-actions button{font-size:11px;padding:4px 10px;border-radius:4px;border:1px solid #475569;background:#0f172a;color:#94a3b8;cursor:pointer;transition:all .2s}.points-actions button:hover{border-color:#38bdf8;color:#38bdf8}.points-actions button.active{background:#38bdf826;border-color:#38bdf8;color:#38bdf8}.points-actions button:disabled{opacity:.5;cursor:not-allowed}.points-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:3px}.point-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:4px;background:#0f172a;border:1px solid #1e293b;font-size:12px;font-family:monospace}.point-seq{color:#38bdf8;font-weight:600;min-width:20px;text-align:center}.point-coords{flex:1;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.point-remove{background:none;border:none;color:#64748b;cursor:pointer;padding:2px 4px;border-radius:3px;font-size:11px;transition:all .2s}.point-remove:hover{background:#ef444433;color:#ef4444}.route-card .card-main{display:flex;align-items:flex-start;gap:10px}.route-card .card-checkbox{margin-top:2px;accent-color:#38bdf8;width:16px;height:16px;cursor:pointer;flex-shrink:0}.route-card .card-body{flex:1;cursor:pointer;min-width:0}.route-card.selected{border-color:#38bdf8;background:#38bdf814}.route-card.selected .card-checkbox{accent-color:#38bdf8}.map-legend{position:absolute;bottom:30px;right:10px;z-index:1000;background:#0f172aeb;padding:10px 14px;border-radius:8px;border:1px solid #334155;min-width:160px}.map-legend h4{font-size:11px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.map-legend-item{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-size:12px;color:#e2e8f0}.map-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.3)}.overlap-bar{display:flex;gap:8px;align-items:center;padding:10px 16px;border-bottom:1px solid #334155}.overlap-bar button{font-size:12px;padding:6px 14px;border-radius:6px;border:1px solid #ef4444;background:#ef444426;color:#ef4444;cursor:pointer;transition:all .2s;font-weight:600}.overlap-bar button:hover{background:#ef44444d}.overlap-bar button:disabled{opacity:.5;cursor:not-allowed}.overlap-bar .overlap-info{font-size:12px;color:#94a3b8;margin-left:auto}.overlap-panel{border-top:1px solid #334155;padding-top:10px;margin-top:8px}.overlap-panel h4{font-size:12px;color:#ef4444;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.overlap-zone-item{font-size:11px;color:#cbd5e1;padding:6px 8px;background:#0f172a;border-radius:4px;margin-bottom:4px;border-left:3px solid #ef4444;cursor:pointer;transition:all .2s}.overlap-zone-item:hover{background:#ef44441a}@media(max-width:768px){.container{flex-direction:column}.sidebar{width:100%;min-width:100%;max-height:50vh}}
