body{margin:0;padding:0;overflow:hidden}.switch{position:relative;display:inline-block;width:40px;height:20px}.switch input{opacity:0;width:0;height:0}.slider-round{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.4s;border-radius:20px}.slider-round:before{position:absolute;content:"";height:14px;width:14px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider-round{background-color:#3b82f6}input:checked+.slider-round:before{transform:translate(20px)}.app-container{display:flex;height:100vh;width:100vw;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:hidden;position:relative}.sidebar{width:320px;height:100%;background-color:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;z-index:20;transition:transform .3s ease-in-out}.sidebar-header{padding:16px;background-color:#3b82f6;color:#fff;display:flex;justify-content:space-between;align-items:center}.sidebar-title{font-size:20px;font-weight:600;margin:0}.close-sidebar-btn{background:none;border:none;color:#fff;cursor:pointer;display:none}.sidebar-content{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:16px}.section{display:flex;flex-direction:column;gap:12px;padding-bottom:16px;border-bottom:1px solid #f1f5f9}.input-group{display:flex;align-items:center;gap:8px;background-color:#f8fafc;padding:8px 12px;border-radius:6px;border:1px solid #e2e8f0}.text-input{border:none;background-color:transparent;font-size:13px;outline:none;width:100%;color:#0c0;font-weight:700}.locate-type-tags{display:flex;gap:4px}.tag-active{background-color:#3b82f6;color:#fff;font-size:11px;padding:4px 8px;border-radius:4px;cursor:pointer}.tag{background-color:#f1f5f9;color:#64748b;font-size:11px;padding:4px 8px;border-radius:4px;cursor:pointer}.date-label{text-align:center;font-size:14px;font-weight:700;color:#1e293b;padding:4px 0}.calendar-mini{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;font-size:11px;text-align:center}.cal-day{color:#0c0;font-weight:700}.cal-date{padding:2px}.date-time-field{display:flex;flex-direction:column;gap:4px}.field-label{font-size:11px;color:#ef4444}.date-time-input{font-size:12px;padding:4px;border-radius:4px;border:1px solid #e2e8f0}.control-row{display:flex;align-items:center;gap:8px;font-size:12px}.label{min-width:80px;color:#64748b}.speed-slider-container{flex:1;display:flex;align-items:center;gap:4px}.speed-text{font-size:10px;color:#94a3b8}.slider{flex:1}.select-input{flex:1;padding:4px 8px;border-radius:4px;border:1px solid #cbd5e1;font-size:14px;color:#334155;outline:none;cursor:pointer}.legend-wrapper{display:flex;flex-direction:column;gap:8px;margin-top:8px}.threshold-badges{display:flex;gap:4px}.input-badge-wrapper{display:flex;align-items:center;gap:2px;background-color:#f1f5f9;padding-right:4px;border-radius:4px;overflow:hidden}.speed-input{width:40px;font-size:10px;color:#fff;padding:2px 4px;border:none;font-weight:700;outline:none;text-align:center}.unit{font-size:8px;color:#64748b;font-weight:700}.legend-container{display:flex;flex-wrap:wrap;gap:8px}.legend-item{display:flex;align-items:center;gap:4px}.dot{width:24px;height:10px;border-radius:2px}.legend-text{font-size:10px;color:#64748b}.quick-dates{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}.quick-btn{font-size:10px;padding:4px 2px;background-color:#fff;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer}.start-btn{width:100%;padding:10px;color:#fff;border:none;border-radius:6px;font-weight:700;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}.tabs{display:flex;border-bottom:1px solid #e2e8f0}.tab-active{flex:1;padding:8px;text-align:center;font-size:12px;color:#3b82f6;border-bottom:2px solid #3b82f6;font-weight:700}.tab{flex:1;padding:8px;text-align:center;font-size:12px;color:#64748b}.event-list{flex:1;display:flex;flex-direction:column;gap:8px;margin-top:12px}.event-item{display:flex;gap:8px;padding:8px;background-color:#f9fafb;border-radius:6px;border-left:4px solid transparent}.event-pin{background-color:#3b82f6;color:#fff;font-size:10px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;font-weight:700}.event-detail{flex:1}.event-addr{font-size:11px;margin:0;color:#334155}.event-time{font-size:10px;margin:2px 0 0;color:#94a3b8}.map-area{flex:1;position:relative;height:100%}.map-header{position:absolute;top:12px;left:12px;right:12px;display:flex;justify-content:space-between;z-index:10;pointer-events:none}.map-header>*{pointer-events:auto}.map-actions{display:flex;background-color:#fff;padding:4px;border-radius:6px;box-shadow:0 2px 10px #0000001a}.map-btn-active{padding:4px 12px;font-size:13px;border:none;background-color:#fff;color:#334155;cursor:pointer;font-weight:700}.map-btn{padding:4px 12px;font-size:13px;border:none;background-color:#fff;color:#94a3b8;cursor:pointer}.map-right-actions{display:flex;gap:8px}.top-btn{padding:4px 12px;font-size:12px;background-color:#fff;border:1px solid #e2e8f0;border-radius:4px;box-shadow:0 2px 10px #0000001a;cursor:pointer}.top-btn-active{padding:4px 12px;font-size:12px;background-color:#3b82f6;color:#fff;border:none;border-radius:4px;box-shadow:0 2px 10px #0000001a;cursor:pointer}.bottom-stats{position:absolute;bottom:24px;left:50%;transform:translate(-50%);width:500px;background-color:#fffffff2;border-radius:12px;box-shadow:0 10px 30px #0003;padding:16px;z-index:15}.progress-track{width:100%;height:6px;background-color:#e2e8f0;border-radius:3px;margin-bottom:12px;overflow:hidden}.progress-fill{height:100%;background-color:#3b82f6;transition:width .1s linear}.stats-bar{display:flex;justify-content:space-between;font-size:13px;color:#334155;font-weight:500;align-items:center}.reset-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;background-color:#f1f5f9;border:none;border-radius:4px;font-size:11px;cursor:pointer}.tooltip-custom{padding:8px;font-size:12px;line-height:1.6;min-width:220px}.tooltip-play{padding:12px;font-size:12px;min-width:200px;background-color:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;border:1px solid rgba(255,255,255,.2);animation:fadeInUp .3s ease-out}.tooltip-line{margin:4px 0}.menu-toggle{display:none;background:#fff;border:none;padding:8px;border-radius:4px;box-shadow:0 2px 5px #0000001a;cursor:pointer;z-index:21;position:absolute;top:12px;left:12px}.loader-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;width:100vw;gap:16px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.app-container{flex-direction:column}.sidebar{position:absolute;top:0;left:0;height:100%;width:280px;transform:translate(-100%);box-shadow:2px 0 10px #0000001a}.sidebar.open{transform:translate(0)}.close-sidebar-btn,.menu-toggle{display:block}.map-header{top:60px;flex-direction:column;gap:8px;align-items:flex-end;width:auto;left:auto;right:12px}.map-actions{display:none}.map-right-actions{flex-direction:column}.bottom-stats{width:90%;bottom:16px;padding:12px}.stats-bar{flex-wrap:wrap;gap:8px}}.map-loader-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#ffffffb3;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);color:#3b82f6;font-weight:600}
