.viu-modal[data-v-38920b27]{position:absolute;top:0;right:0;z-index:6;display:flex;flex-flow:column;align-items:center;justify-content:center;width:100vw;height:100vh;background:rgba(0,0,0,.4)}.viu-modal[data-v-38920b27]:not(.no-bg){opacity:0;animation:show-38920b27 .2s ease-in 0ms forwards}.viu-modal.lateral[data-v-38920b27],.viu-modal.no-bg[data-v-38920b27]{top:0;overflow:hidden;opacity:1;animation:show-38920b27 .2s ease-in 0ms forwards}.viu-modal.lateral>.viu-modal-popup.full-screen[data-v-38920b27],.viu-modal.no-bg>.viu-modal-popup.full-screen[data-v-38920b27]{top:100%;opacity:1;animation:showFromBottom-38920b27 .4s ease-out .2s forwards}.viu-modal.lateral>.viu-modal-popup.lateral[data-v-38920b27],.viu-modal.no-bg>.viu-modal-popup.lateral[data-v-38920b27]{position:absolute;top:0;right:-375px;width:375px;min-width:375px;max-width:375px;height:100%;min-height:100%;max-height:100%;border-radius:0;opacity:1;animation:showFromRight-38920b27 .25s ease-out .2s forwards}.viu-modal.lateral>.viu-modal-popup.lateral>.viu-modal-popup-header[data-v-38920b27],.viu-modal.no-bg>.viu-modal-popup.lateral>.viu-modal-popup-header[data-v-38920b27]{display:none}.viu-modal.lateral>.viu-modal-popup.lateral>.viu-modal-popup-content[data-v-38920b27],.viu-modal.no-bg>.viu-modal-popup.lateral>.viu-modal-popup-content[data-v-38920b27]{height:100%;padding:0}@keyframes showFromBottom-38920b27{0%{top:100%}to{top:0}}@keyframes showFromRight-38920b27{0%{right:-375px}to{right:0}}.viu-modal [data-v-38920b27]{box-sizing:border-box}@keyframes show-38920b27{0%{opacity:0}to{opacity:1}}.viu-modal>.viu-modal-popup[data-v-38920b27]{min-width:678px;max-width:80%;max-height:90%;overflow:hidden;background:#fff;border-radius:5px;box-shadow:0 4px 20px rgba(64,84,137,.25);opacity:0;animation:show-38920b27 .2s ease-in .2s forwards}.viu-modal>.viu-modal-popup>.viu-modal-popup-header[data-v-38920b27]{display:flex;flex-flow:row;align-items:center;justify-content:space-between;padding:8px 20px;color:#fff;background:#35425b}.viu-modal>.viu-modal-popup>.viu-modal-popup-header>span[data-v-38920b27]{width:calc(100% - 26px);margin:0;padding-top:2px;overflow:hidden;font-weight:700;font-size:14px;white-space:nowrap;text-overflow:ellipsis}.viu-modal>.viu-modal-popup>.viu-modal-popup-header>.close[data-v-38920b27]{color:#fff;font-size:14px;background:none;border:0;cursor:pointer}.viu-modal>.viu-modal-popup>.viu-modal-popup-header>.close[data-v-38920b27]:focus{outline:none}.viu-modal>.viu-modal-popup>.viu-modal-popup-content[data-v-38920b27]{height:calc(100% - 34px);padding:20px;overflow-y:auto;scroll-behavior:smooth}.viu-modal>.viu-modal-popup>.viu-modal-popup-content[data-v-38920b27]::-webkit-scrollbar{width:9px;overflow:hidden;background-color:#dfe6e9;border-radius:9px;cursor:pointer}.viu-modal>.viu-modal-popup>.viu-modal-popup-content[data-v-38920b27]::-webkit-scrollbar-thumb{background-color:#95a5a6;border-radius:9px}.viu-modal>.viu-modal-popup>.viu-modal-popup-content[data-v-38920b27]::-webkit-scrollbar-track{background-color:#dfe6e9;opacity:0}.viu-modal>.viu-modal-popup>.viu-modal-popup-content.no-title[data-v-38920b27]{height:100%}.viu-modal>.viu-modal-popup.full-screen[data-v-38920b27]{position:absolute;left:0;width:100%;min-width:100%;max-width:100%;height:100%;min-height:100%;max-height:100%;border-radius:0}.viu-modal>.viu-modal-popup.full-screen>.viu-modal-popup-header[data-v-38920b27]{position:absolute;top:0;left:0;z-index:1;display:flex;flex-flow:row;align-items:center;justify-content:flex-start;width:100%;height:50px;padding:8px 20px;color:#35425b;background:#fff;box-shadow:0 3px 4px rgba(53,66,91,.1)}.viu-modal>.viu-modal-popup.full-screen>.viu-modal-popup-header>span[data-v-38920b27]{order:2;width:auto;margin-top:-2px;margin-left:30px;padding-top:0;overflow:hidden;color:#35425b;font-weight:500;font-size:14px;white-space:nowrap;text-overflow:ellipsis}.viu-modal>.viu-modal-popup.full-screen>.viu-modal-popup-header>.close[data-v-38920b27]{order:1;color:#35425b;font-size:16px;background:none;border:0;cursor:pointer}.viu-modal>.viu-modal-popup.full-screen>.viu-modal-popup-header>.close[data-v-38920b27]:focus{outline:none}.viu-modal>.viu-modal-popup.full-screen>.viu-modal-popup-content[data-v-38920b27]{height:calc(100% - 50px);margin-top:50px;padding:30px;background:#f8f9fc}.modal-leave-active[data-v-38920b27]:not(.no-bg){opacity:1;animation:hide-38920b27 .2s ease-in .2s forwards}.modal-leave-active:not(.no-bg) .viu-modal-popup[data-v-38920b27]{opacity:1;animation:hide-38920b27 .2s ease-in 0ms forwards}.modal-leave-active.lateral[data-v-38920b27],.modal-leave-active.no-bg[data-v-38920b27]{opacity:1;animation:hide-38920b27 .2s ease-in .4s forwards}.modal-leave-active.lateral .viu-modal-popup.full-screen[data-v-38920b27],.modal-leave-active.no-bg .viu-modal-popup.full-screen[data-v-38920b27]{top:0;opacity:1;animation:hideFromTop-38920b27 .4s ease-out 0ms forwards}.modal-leave-active.lateral .viu-modal-popup.lateral[data-v-38920b27],.modal-leave-active.no-bg .viu-modal-popup.lateral[data-v-38920b27]{top:0;right:0;opacity:1;animation:hideFromRight-38920b27 .25s ease-out 0ms forwards}@keyframes hide-38920b27{0%{opacity:1}to{opacity:0}}@keyframes hideFromTop-38920b27{0%{top:0}to{top:100%}}@keyframes hideFromRight-38920b27{0%{right:0}to{right:-375px}}@media(max-width:700px){.viu-modal>.viu-modal-popup[data-v-38920b27]{min-width:90%;max-width:90%}}@media(max-width:500px){.viu-modal.lateral>.viu-modal-popup.lateral[data-v-38920b27]{right:-97%;width:97%;min-width:97%;max-width:97%}@keyframes showFromRight-38920b27{0%{right:-97%}to{right:0}}@keyframes hideFromRight-38920b27{0%{right:0}to{right:-97%}}}.ruta-popup-modern[data-v-3c13396c]{background:var(--bg-card);width:280px;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.15);overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}@media(max-width:768px){.ruta-popup-modern[data-v-3c13396c]{width:100%;border-radius:0;box-shadow:none}}.ruta-popup-modern .header[data-v-3c13396c]{background:var(--bg-card);padding:16px;position:relative;color:var(--text-primary);border-bottom:2px solid var(--border-primary)}.ruta-popup-modern .header.header-motor[data-v-3c13396c]{border-bottom-color:var(--danger)}.ruta-popup-modern .header .header-content[data-v-3c13396c]{display:flex;align-items:center;gap:10px}.ruta-popup-modern .header .header-content .header-icon[data-v-3c13396c]{font-size:20px;color:var(--accent)}.ruta-popup-modern .header .header-content .title[data-v-3c13396c]{font-size:16px;font-weight:600;letter-spacing:.3px}.ruta-popup-modern .header.header-motor .header-icon[data-v-3c13396c]{color:var(--danger)}.ruta-popup-modern .header .close-btn[data-v-3c13396c]{position:absolute;top:12px;right:12px;background:var(--bg-tertiary);border:none;width:28px;height:28px;border-radius:50%;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.ruta-popup-modern .header .close-btn[data-v-3c13396c]:hover{background:var(--border-primary);color:var(--text-primary)}.ruta-popup-modern .header .close-btn i[data-v-3c13396c]{font-size:14px}.ruta-popup-modern .body[data-v-3c13396c]{padding:16px}.ruta-popup-modern .body .duration-highlight[data-v-3c13396c]{background:var(--bg-tertiary);border-radius:10px;padding:14px;display:flex;align-items:center;gap:12px;margin-bottom:16px;border-left:4px solid var(--accent)}.ruta-popup-modern .body .duration-highlight .duration-icon[data-v-3c13396c]{font-size:24px;color:var(--accent)}.ruta-popup-modern .body .duration-highlight .duration-content[data-v-3c13396c]{display:flex;flex-direction:column;gap:2px}.ruta-popup-modern .body .duration-highlight .duration-content .duration-label[data-v-3c13396c]{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.ruta-popup-modern .body .duration-highlight .duration-content .duration-value[data-v-3c13396c]{font-size:20px;font-weight:700;color:var(--text-primary)}.ruta-popup-modern .body .time-section[data-v-3c13396c]{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.ruta-popup-modern .body .time-section .time-item[data-v-3c13396c]{display:flex;align-items:center;gap:12px;padding:10px;background:var(--bg-secondary);border-radius:8px;transition:all .2s ease}.ruta-popup-modern .body .time-section .time-item[data-v-3c13396c]:hover{background:var(--bg-tertiary)}.ruta-popup-modern .body .time-section .time-item .time-icon-wrapper[data-v-3c13396c]{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px}.ruta-popup-modern .body .time-section .time-item .time-icon-wrapper.start[data-v-3c13396c]{background:var(--accent-light);color:var(--success)}.ruta-popup-modern .body .time-section .time-item .time-icon-wrapper.end[data-v-3c13396c]{background:var(--badge-danger-bg);color:var(--danger)}.ruta-popup-modern .body .time-section .time-item .time-details[data-v-3c13396c]{display:flex;flex-direction:column;gap:2px;flex:1}.ruta-popup-modern .body .time-section .time-item .time-details .time-label[data-v-3c13396c]{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.ruta-popup-modern .body .time-section .time-item .time-details .time-value[data-v-3c13396c]{font-size:13px;font-weight:500;color:var(--text-primary)}.ruta-popup-modern .body .time-section .time-divider[data-v-3c13396c]{display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:12px;margin:-4px 0}.ruta-popup-modern .body .street-view-btn[data-v-3c13396c]{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease}.ruta-popup-modern .body .street-view-btn[data-v-3c13396c]:hover{background:var(--accent-hover)}.ruta-popup-modern .body .street-view-btn i[data-v-3c13396c]{font-size:16px}@keyframes markerActive{0%{top:0}to{top:-10px}}.route-info-panel{position:absolute;right:80px;top:75px;z-index:3;transition:all .3s cubic-bezier(.4,0,.2,1);background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;box-shadow:0 2px 12px rgba(0,0,0,.1);border:1px solid var(--border-primary);overflow:hidden;max-width:500px}.route-info-panel .panel-handle{display:none}.route-info-panel.hide{opacity:0;transform:translateY(-10px);pointer-events:none}.route-info-panel .panel-header{background:var(--accent-light);padding:14px 20px;border-bottom:1px solid var(--border-primary)}[data-theme=dark] .route-info-panel .panel-header{background:rgba(129,140,248,.18);border-bottom-color:rgba(140,160,220,.2)}.route-info-panel .panel-header .driver-info{display:flex;align-items:center;gap:12px}.route-info-panel .panel-header .driver-info .avatar{height:42px;width:42px;border:2px solid var(--border-primary);box-shadow:0 2px 8px rgba(0,0,0,.08);background:url(/images/avatar/default.png);background-repeat:no-repeat;background-position:50%;background-size:cover;border-radius:50%;transition:all .3s ease;flex-shrink:0}.route-info-panel .panel-header .driver-info .avatar:hover{transform:scale(1.08);border-color:var(--accent)}.route-info-panel .panel-header .driver-info .driver-details{display:flex;flex-direction:column;gap:2px;flex:1}.route-info-panel .panel-header .driver-info .driver-details .name{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:.3px;margin:0}.route-info-panel .panel-header .driver-info .driver-details .imei{font-size:12px;font-weight:500;color:var(--text-muted);letter-spacing:.2px;margin:0}.route-info-panel .panel-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bg-tertiary)}.route-info-panel .panel-kpis .kpi-item{background:var(--bg-card);padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:8px;transition:all .2s ease;position:relative}.route-info-panel .panel-kpis .kpi-item:hover{background:var(--bg-secondary);transform:translateY(-2px)}.route-info-panel .panel-kpis .kpi-item:hover .kpi-icon{transform:scale(1.15);color:var(--accent)}.route-info-panel .panel-kpis .kpi-item .kpi-icon{font-size:22px;color:var(--accent);transition:all .3s ease;margin-bottom:4px}.route-info-panel .panel-kpis .kpi-item .kpi-data{display:flex;flex-direction:column;align-items:center;gap:2px}.route-info-panel .panel-kpis .kpi-item .kpi-data .kpi-value{font-size:18px;font-weight:700;color:var(--text-primary);line-height:1.2}.route-info-panel .panel-kpis .kpi-item .kpi-data .kpi-label{font-size:11px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.leaflet-div-icon{background:transparent!important;border:none!important}.leaflet-popup-content.hide{display:none}.leaflet-popup-content.show{display:block}.hidden-marker{display:none}.speed-popup{border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.15),0 4px 8px rgba(0,0,0,.1);width:220px;padding:16px 20px;display:flex;justify-content:center;align-items:center;background:var(--bg-card);position:relative;border:1px solid var(--border-primary)}.speed-popup span{font-size:14px;font-weight:600;color:var(--text-primary);text-align:center}.speed-popup .icon-close{position:absolute;right:-12px;top:-12px;width:28px;height:28px;background:var(--danger);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 8px rgba(239,68,68,.3);transition:all .2s ease;border:2px solid #fff}.speed-popup .icon-close i{font-size:14px}.speed-popup .icon-close:hover{background:#dc2626;transform:scale(1.1);box-shadow:0 6px 12px rgba(239,68,68,.4)}.speed-popup .icon-close:active{transform:scale(.95)}.calendar-map{position:absolute!important;top:75px;left:50px;z-index:2;max-width:320px;width:320px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}@media(max-width:600px){.calendar-map{filter:none}}.enumeration-text{margin-top:-37px;text-align:center;font-size:9px;font-weight:700}.leaflet-marker-pane.marker-activated img.leaflet-marker-icon:not(.opened-marker){opacity:.2}.marker-activated-relative-motion{animation-name:markerActive;animation-duration:.3s;animation-iteration-count:infinite;animation-direction:alternate;position:relative;background:var(--success)}.modal-street-view .viu-modal-popup{min-width:900px!important}@media(max-width:600px){.modal-street-view .viu-modal-popup{min-width:unset!important;width:100%!important;height:100%!important;margin:0!important;border-radius:0!important}.modal-street-view .viu-modal-popup #street-view{height:100%!important}}.vue2leaflet-map{z-index:1}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:none;color:none;box-shadow:none}.leaflet-control-zoom{border:none!important}.change-map{position:absolute;bottom:190px;left:50px;z-index:1;height:90px;width:90px;background-size:cover;background-repeat:no-repeat;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:8px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px rgba(0,0,0,.25),0 2px 4px rgba(0,0,0,.15);border:3px solid hsla(0,0%,100%,.9);overflow:hidden}.change-map:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,transparent 0,rgba(0,0,0,.5));z-index:0}.change-map:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 20px rgba(0,0,0,.3),0 4px 8px rgba(0,0,0,.2)}.change-map:active{transform:translateY(-2px) scale(1)}.change-map.map{background-image:url(/images/leaflet-map/mapa.png)}.change-map.satellite{background-image:url(/images/leaflet-map/satelite.png)}.change-map .map-name{width:100%;font-weight:700;text-align:center;font-size:13px;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5);letter-spacing:.5px;position:relative;z-index:1}.map-types{position:absolute;bottom:75px;right:50px;z-index:1;gap:12px}.map-types,.map-types .duel,.map-types .standalone{display:flex;flex-direction:column;justify-content:center;align-items:center}.map-types .duel,.map-types .standalone{height:48px;width:48px;background:var(--bg-card);border-radius:12px;box-shadow:0 4px 8px rgba(0,0,0,.12),0 2px 4px rgba(0,0,0,.08);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--border-primary)}.map-types .duel.speed,.map-types .standalone.speed{background:linear-gradient(135deg,#667eea,#764ba2)}.map-types .duel.speed i,.map-types .standalone.speed i{color:#fff!important;opacity:1!important;transform:scale(1.1)}.map-types .duel .icon,.map-types .duel .icon-duel,.map-types .standalone .icon,.map-types .standalone .icon-duel{display:flex;justify-content:center;align-items:center;transition:all .2s ease;cursor:pointer;font-size:20px;font-weight:500;color:var(--text-secondary)}.map-types .duel .icon-duel.disabled,.map-types .duel .icon.disabled,.map-types .standalone .icon-duel.disabled,.map-types .standalone .icon.disabled{color:var(--text-muted)}.map-types .duel:hover:not(.disabled),.map-types .standalone:hover:not(.disabled){transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.15),0 3px 6px rgba(0,0,0,.1)}.map-types .duel:hover:not(.disabled) .icon,.map-types .duel:hover:not(.disabled) .icon-duel,.map-types .standalone:hover:not(.disabled) .icon,.map-types .standalone:hover:not(.disabled) .icon-duel{color:var(--text-primary);transform:scale(1.05)}.map-types .duel:active:not(.disabled),.map-types .standalone:active:not(.disabled){transform:translateY(0);box-shadow:0 2px 4px rgba(0,0,0,.1)}.map-types .duel.disabled,.map-types .standalone.disabled{cursor:not-allowed!important;opacity:.5}.map-types .duel.disabled i,.map-types .standalone.disabled i{color:var(--text-muted)!important;cursor:not-allowed!important}.map-types .duel{height:auto;padding:4px}.map-types .duel .icon-duel{height:44px;width:44px;border-radius:8px}.map-types .duel .icon-duel:first-of-type{border-bottom:1px solid var(--bg-tertiary);margin-bottom:4px}.map-types .duel .icon-duel:hover{background:var(--bg-secondary)}.mobile-route-bar{position:absolute;top:8px;left:8px;right:8px;z-index:3}.mobile-route-bar,.mobile-route-date{display:flex;align-items:center;gap:8px}.mobile-route-date{flex:1;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.1);cursor:pointer;font-size:14px;font-weight:600;color:var(--text-primary)}.mobile-route-date .far{color:var(--accent);font-size:15px}.mobile-route-date .fa-chevron-down{margin-left:auto;font-size:10px;color:var(--text-muted)}.mobile-route-avatar{width:42px;height:42px;border-radius:50%;overflow:hidden;border:2px solid var(--accent);box-shadow:0 2px 8px rgba(0,0,0,.1);cursor:pointer;flex-shrink:0}.mobile-route-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.mobile-streetview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1100;background:rgba(0,0,0,.3)}.mobile-streetview-sheet{position:fixed;bottom:0;left:0;right:0;top:56px;z-index:1101;background:var(--bg-card);border-radius:16px 16px 0 0;display:flex;flex-direction:column;overflow:hidden}.mobile-streetview-sheet .mobile-streetview-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-primary);flex-shrink:0}.mobile-streetview-sheet .mobile-streetview-header span{font-size:15px;font-weight:700;color:var(--text-primary)}.mobile-streetview-sheet .mobile-streetview-header button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:var(--bg-tertiary);color:var(--text-tertiary);font-size:14px;cursor:pointer}.mobile-streetview-sheet .mobile-streetview-header button:active{background:var(--border-primary)}.mobile-calendar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;background:rgba(0,0,0,.3)}.mobile-calendar-sheet{position:fixed;bottom:0;left:0;right:0;z-index:1001;background:var(--bg-card);border-radius:16px 16px 0 0;box-shadow:0 -4px 20px rgba(0,0,0,.15);max-height:85vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.mobile-calendar-sheet .mobile-calendar-handle{display:flex;justify-content:center;padding:10px 0 4px;cursor:pointer}.mobile-calendar-sheet .mobile-calendar-handle span{width:36px;height:4px;border-radius:2px;background:var(--border-hover)}.mobile-calendar-sheet .mobile-calendar-inline{position:relative!important;top:auto!important;left:auto!important;width:100%!important;max-width:100%!important;filter:none!important}.mobile-calendar-sheet .mobile-calendar-inline .modern-calendar-trigger{display:none}.mobile-calendar-sheet .mobile-calendar-inline .modern-calendar-dropdown{display:flex!important;flex-direction:column!important;position:relative!important;top:auto!important;left:auto!important;right:auto!important;bottom:auto!important;min-width:unset!important;width:100%!important;border:none!important;border-radius:0!important;box-shadow:none!important}.bottom-sheet-enter-active{transition:all .3s ease-out}.bottom-sheet-enter-active .device-sheet,.bottom-sheet-enter-active .mobile-calendar-sheet{transition:transform .3s ease-out}.bottom-sheet-leave-active{transition:all .2s ease-in}.bottom-sheet-leave-active .device-sheet,.bottom-sheet-leave-active .mobile-calendar-sheet{transition:transform .2s ease-in}.bottom-sheet-enter .device-sheet,.bottom-sheet-enter .mobile-calendar-sheet,.bottom-sheet-leave-to .device-sheet,.bottom-sheet-leave-to .mobile-calendar-sheet{transform:translateY(100%)}@media(max-width:768px){.route-info-panel{right:0;left:0;top:auto;bottom:0;max-width:unset;border-radius:14px 14px 0 0;box-shadow:0 -4px 20px rgba(0,0,0,.15);cursor:pointer}.route-info-panel .panel-handle{display:flex;justify-content:center;padding:8px 0 4px}.route-info-panel .panel-handle span{width:32px;height:4px;border-radius:2px;background:var(--border-hover)}.route-info-panel .panel-header{padding:8px 14px 6px}.route-info-panel .panel-header .avatar{width:32px;height:32px}.route-info-panel .panel-header .name{font-size:13px}.route-info-panel .panel-header .imei{font-size:10px}.route-info-panel .panel-kpis .kpi-item{padding:6px 8px}.route-info-panel .panel-kpis .kpi-value{font-size:15px}.route-info-panel .panel-kpis .kpi-label{font-size:10px}.route-info-panel.expanded{max-height:60vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.route-info-panel:not(.expanded) .panel-kpis{display:none}.calendar-map{top:8px;left:8px;max-width:calc(100vw - 80px);width:auto}}@media(max-width:600px){.change-map{bottom:30px;left:6px;height:60px;width:60px;border-radius:8px}.change-map .map-name{font-size:11px}.map-types{bottom:50px;right:4px;flex-direction:row;gap:4px}.map-types .duel,.map-types .standalone{margin-bottom:0;margin-right:0;display:flex;height:36px!important;width:36px!important;flex-direction:row;justify-content:center;align-items:center;border-radius:8px!important;font-size:13px;box-shadow:0 2px 4px rgba(0,0,0,.1)}.map-types .duel .icon-duel,.map-types .standalone .icon-duel{display:flex;width:36px;justify-content:center;align-items:center;flex-direction:row;font-size:13px}.map-types .duel{width:72px!important}}.route-marker{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;box-shadow:0 4px 8px rgba(0,0,0,.3);border:3px solid #fff;transition:transform .2s ease}.route-marker:hover{transform:scale(1.15)}.route-marker.start-marker{background:var(--accent);animation:pulse-start 2s infinite}.route-marker.end-marker{background:var(--danger);animation:pulse-end 2s infinite}.route-endpoint-popup-wrapper .leaflet-popup-content-wrapper{padding:0;border-radius:12px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.15)}.route-endpoint-popup-wrapper .leaflet-popup-content{margin:0;width:100%!important}.route-endpoint-popup{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-card);color:var(--text-primary)}.route-endpoint-popup .rep-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:3px solid}.route-endpoint-popup .rep-header>i{font-size:20px}.route-endpoint-popup .rep-header .rep-header-text{display:flex;flex-direction:column;gap:1px}.route-endpoint-popup .rep-header .rep-title{font-size:14px;font-weight:700}.route-endpoint-popup .rep-header .rep-subtitle{font-size:11px;color:var(--text-muted);font-weight:500}.route-endpoint-popup .rep-time-row{display:flex;align-items:baseline;gap:8px;padding:12px 16px 4px}.route-endpoint-popup .rep-time-row .rep-time{font-size:28px;font-weight:800;letter-spacing:-1px;color:var(--text-primary)}.route-endpoint-popup .rep-time-row .rep-date{font-size:12px;color:var(--text-muted);font-weight:500}.route-endpoint-popup .rep-address{display:flex;align-items:flex-start;gap:8px;padding:4px 16px 12px;font-size:12px;color:var(--text-secondary);line-height:1.3}.route-endpoint-popup .rep-address>i{color:var(--text-muted);margin-top:2px;flex-shrink:0}.route-endpoint-popup .rep-address>span{white-space:normal;word-break:break-word}.route-endpoint-popup .rep-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border-secondary);border-top:1px solid var(--border-secondary)}.route-endpoint-popup .rep-stats .rep-stat{background:var(--bg-card);padding:10px 12px;display:flex;flex-direction:column;align-items:center;gap:2px}.route-endpoint-popup .rep-stats .rep-stat .rep-stat-value{font-size:15px;font-weight:700;color:var(--text-primary)}.route-endpoint-popup .rep-stats .rep-stat .rep-stat-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;font-weight:600;letter-spacing:.3px}.route-endpoint-sheet .rep-header{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:3px solid}.route-endpoint-sheet .rep-header>i{font-size:22px}.route-endpoint-sheet .rep-header .rep-header-text{display:flex;flex-direction:column;gap:1px}.route-endpoint-sheet .rep-header .rep-title{font-size:16px;font-weight:700;color:var(--text-primary)}.route-endpoint-sheet .rep-header .rep-subtitle{font-size:12px;color:var(--text-muted);font-weight:500}.route-endpoint-sheet .rep-time-row{display:flex;align-items:baseline;gap:10px;padding:14px 20px 4px}.route-endpoint-sheet .rep-time-row .rep-time{font-size:34px;font-weight:800;letter-spacing:-1px;color:var(--text-primary)}.route-endpoint-sheet .rep-time-row .rep-date{font-size:13px;color:var(--text-muted);font-weight:500}.route-endpoint-sheet .rep-address{display:flex;align-items:flex-start;gap:8px;padding:6px 20px 14px;font-size:13px;color:var(--text-secondary);line-height:1.4}.route-endpoint-sheet .rep-address>i{color:var(--text-muted);margin-top:2px;flex-shrink:0}.route-endpoint-sheet .rep-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border-secondary);border-top:1px solid var(--border-secondary)}.route-endpoint-sheet .rep-stats .rep-stat{background:var(--bg-card);padding:14px 12px;display:flex;flex-direction:column;align-items:center;gap:3px}.route-endpoint-sheet .rep-stats .rep-stat .rep-stat-value{font-size:18px;font-weight:700;color:var(--text-primary)}.route-endpoint-sheet .rep-stats .rep-stat .rep-stat-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;font-weight:600;letter-spacing:.3px}.route-endpoint-sheet .rep-street-view-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:calc(100% - 32px);margin:16px auto;padding:14px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer}.route-endpoint-sheet .rep-street-view-btn i{font-size:18px}@keyframes pulse-start{0%,to{box-shadow:0 4px 8px rgba(102,126,234,.4),0 0 0 0 rgba(102,126,234,.7)}50%{box-shadow:0 4px 12px rgba(102,126,234,.6),0 0 0 10px rgba(102,126,234,0)}}@keyframes pulse-end{0%,to{box-shadow:0 4px 8px rgba(239,68,68,.4),0 0 0 0 rgba(239,68,68,.7)}50%{box-shadow:0 4px 12px rgba(239,68,68,.6),0 0 0 10px rgba(239,68,68,0)}}.no-route-overlay{position:absolute;top:0;left:0;right:0;bottom:0;z-index:2;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none}.no-route-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:40px 48px;max-width:420px;text-align:center;box-shadow:0 8px 32px rgba(0,0,0,.1),0 4px 8px rgba(0,0,0,.06);border:1px solid var(--border-primary);pointer-events:auto}.no-route-card .no-route-icon{width:72px;height:72px;border-radius:50%;background:var(--accent-light);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.no-route-card .no-route-icon i{font-size:30px;color:var(--accent)}.no-route-card .no-route-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 10px}.no-route-card .no-route-message{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0 0 16px}.no-route-card .no-route-message strong{color:var(--text-primary)}.no-route-card .no-route-hint{font-size:13px;color:var(--text-muted);margin:0;display:flex;align-items:center;justify-content:center;gap:6px}.no-route-card .no-route-hint i{color:var(--accent);font-size:14px}.fade-empty-enter-active,.fade-empty-leave-active{transition:opacity .3s ease}.fade-empty-enter,.fade-empty-leave-to{opacity:0}.speed-chart-panel{position:absolute;bottom:0;left:0;right:0;z-index:800;background:var(--bg-secondary);border-top:1px solid var(--border-primary);box-shadow:0 -4px 16px rgba(0,0,0,.1)}.speed-chart-panel .speed-chart-panel-handle{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px;cursor:pointer;color:var(--text-muted);font-size:11px;font-weight:500;transition:color .2s}.speed-chart-panel .speed-chart-panel-handle:hover{color:var(--text-primary)}.speed-chart-panel .speed-chart-panel-handle i{font-size:10px}.grouped-marker-wrapper{background:none!important;border:none!important}.grouped-marker-icon{width:44px;height:44px;background:linear-gradient(135deg,#f59e0b,#ef4444);font-size:18px;box-shadow:0 3px 10px rgba(239,68,68,.4);position:relative;cursor:pointer}.grouped-marker-icon,.grouped-marker-icon .grouped-marker-count{border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;border:2px solid #fff}.grouped-marker-icon .grouped-marker-count{position:absolute;top:-6px;right:-6px;background:#ef4444;font-size:11px;font-weight:700;width:20px;height:20px;line-height:1}.grouped-popup .grouped-popup-footer{padding:8px 12px 12px}.grouped-popup .grouped-popup-footer .street-view-btn{width:100%;padding:10px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s}.grouped-popup .grouped-popup-footer .street-view-btn:hover{background:var(--accent-hover)}.grouped-popup{font-family:Inter,-apple-system,sans-serif;background:var(--bg-card);min-width:260px}.grouped-popup .grouped-popup-header{display:flex;align-items:center;gap:8px;padding:14px 16px;border-bottom:2px solid #f59e0b;font-size:14px;font-weight:600;color:var(--text-primary)}.grouped-popup .grouped-popup-header>i{color:#f59e0b;font-size:16px}.grouped-popup .grouped-popup-header>span{flex:1}.grouped-popup .grouped-popup-list{padding:8px;max-height:300px;overflow-y:auto}.grouped-popup .grouped-popup-list .grouped-popup-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:8px;transition:background .2s}.grouped-popup .grouped-popup-list .grouped-popup-item:hover{background:var(--bg-tertiary)}.grouped-popup .grouped-popup-list .grouped-popup-item+.grouped-popup-item{border-top:1px solid var(--border-secondary)}.grouped-popup .grouped-popup-list .grouped-popup-item .grouped-item-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.grouped-popup .grouped-popup-list .grouped-popup-item.grouped-type-p .grouped-item-icon{background:var(--bg-tertiary);color:var(--danger)}.grouped-popup .grouped-popup-list .grouped-popup-item.grouped-type-m .grouped-item-icon{background:var(--bg-tertiary);color:#d97706}.grouped-popup .grouped-popup-list .grouped-popup-item.grouped-type-e .grouped-item-icon{background:var(--bg-tertiary);color:var(--accent)}.grouped-popup .grouped-popup-list .grouped-popup-item.grouped-type-s .grouped-item-icon{background:var(--bg-tertiary);color:#7c3aed}.grouped-popup .grouped-popup-list .grouped-popup-item.grouped-type-f .grouped-item-icon{background:var(--bg-tertiary);color:#dc2626}.grouped-popup .grouped-popup-list .grouped-popup-item .grouped-item-sv{width:32px;height:32px;border-radius:8px;border:none;background:var(--bg-tertiary);color:var(--accent);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.grouped-popup .grouped-popup-list .grouped-popup-item .grouped-item-sv:active,.grouped-popup .grouped-popup-list .grouped-popup-item .grouped-item-sv:hover{background:var(--accent);color:#fff}.grouped-popup .grouped-popup-list .grouped-popup-item .grouped-item-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.grouped-popup .grouped-popup-list .grouped-popup-item .grouped-item-info .grouped-item-title{font-size:13px;font-weight:600;color:var(--text-primary)}.grouped-popup .grouped-popup-list .grouped-popup-item .grouped-item-info .grouped-item-time{display:flex;flex-direction:column;gap:2px;font-size:11px;color:var(--text-secondary)}.grouped-popup .grouped-popup-list .grouped-popup-item .grouped-item-info .grouped-item-time .time-icon-start{color:var(--success);margin-right:4px;font-size:10px}.grouped-popup .grouped-popup-list .grouped-popup-item .grouped-item-info .grouped-item-time .time-icon-end{color:var(--danger);margin-right:4px;font-size:10px}.fan-front,.telemetry-event-icon{background:none!important;border:none!important}.fan-front{z-index:1000!important}.fan-back{z-index:900!important;background:none!important;border:none!important}.event-popup-wrapper .leaflet-popup-content{margin:0!important;min-width:220px}.event-popup-wrapper .leaflet-popup-content-wrapper{padding:0!important;border-radius:12px!important;overflow:hidden!important}.event-popup-content{font-family:Inter,-apple-system,sans-serif;background:var(--bg-card)}.event-popup-content .event-popup-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:2px solid #667eea}.event-popup-content .event-popup-header .event-popup-icon{font-size:20px}.event-popup-content .event-popup-header .event-popup-title{font-size:15px;font-weight:600;color:var(--text-primary);flex:1}.event-popup-content .event-popup-header .event-close-btn{background:var(--bg-tertiary);border:none;width:28px;height:28px;border-radius:50%;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.event-popup-content .event-popup-header .event-close-btn:hover{background:var(--border-primary);color:var(--text-primary)}.event-popup-content .event-popup-header .event-close-btn i{font-size:14px}.event-popup-content .event-popup-body{padding:14px 16px}.event-popup-content .event-popup-body .event-popup-time{display:flex;align-items:center;gap:12px;padding:10px;background:var(--bg-secondary);border-radius:8px}.event-popup-content .event-popup-body .event-popup-time .event-time-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;background:var(--accent-light);color:var(--accent)}.event-popup-content .event-popup-body .event-popup-time .event-time-details{display:flex;flex-direction:column;gap:2px}.event-popup-content .event-popup-body .event-popup-time .event-time-details .event-time-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.event-popup-content .event-popup-body .event-popup-time .event-time-details .event-time-value{font-size:13px;font-weight:500;color:var(--text-primary)}.chart-hover-marker-wrapper{background:none!important;border:none!important}.chart-hover-marker{background:rgba(102,126,234,.95);color:#fff;padding:5px 12px;border-radius:16px;font-size:12px;font-weight:600;text-align:center;white-space:nowrap;box-shadow:0 2px 8px rgba(0,0,0,.25);font-family:Inter,sans-serif;position:relative}.chart-hover-marker .chart-hover-arrow{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid rgba(102,126,234,.95)}.mobile-chart-sheet{position:fixed;bottom:0;left:0;right:0;z-index:900;background:var(--bg-card);border-radius:16px 16px 0 0;max-height:45vh;overflow-y:auto;box-shadow:0 -4px 20px rgba(0,0,0,.15);padding-bottom:env(safe-area-inset-bottom,0)}.mobile-chart-sheet .mobile-chart-header{display:flex;align-items:center;justify-content:center;position:relative;padding:8px 16px 0}.mobile-chart-sheet .mobile-chart-header .mobile-calendar-handle{flex:1}.mobile-chart-sheet .mobile-chart-header .mobile-chart-close{position:absolute;right:12px;top:8px;width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-tertiary);color:var(--text-muted);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer}.mobile-chart-sheet .mobile-chart-header .mobile-chart-close:active{background:var(--border-primary);color:var(--text-primary)}.slide-up-chart-enter-active,.slide-up-chart-leave-active{transition:transform .3s ease,opacity .3s ease}.slide-up-chart-enter,.slide-up-chart-leave-to{transform:translateY(100%);opacity:0}.tramos-btn{position:relative}.tramos-control-badge{position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid #fff;line-height:1}.mobile-tramos-sheet{position:fixed;bottom:0;left:0;right:0;z-index:900;background:var(--bg-card);border-radius:16px 16px 0 0;max-height:60vh;display:flex;flex-direction:column;box-shadow:0 -4px 20px rgba(0,0,0,.15);padding-bottom:env(safe-area-inset-bottom,0)}.mobile-tramos-sheet .tramos-sheet-header .tramos-sheet-handle{display:flex;justify-content:center;padding:10px;cursor:pointer}.mobile-tramos-sheet .tramos-sheet-header .tramos-sheet-handle span{width:36px;height:4px;border-radius:2px;background:var(--border-primary)}.mobile-tramos-sheet .tramos-sheet-header .tramos-sheet-title{display:flex;align-items:center;gap:8px;padding:0 16px 12px;font-size:16px;font-weight:600;color:var(--text-primary)}.mobile-tramos-sheet .tramos-sheet-header .tramos-sheet-title i{color:var(--accent)}.mobile-tramos-sheet .tramos-sheet-header .tramos-sheet-title .tramos-sheet-km{margin-left:auto;font-size:12px;color:var(--text-muted);font-weight:500}.mobile-tramos-sheet .tramos-sheet-list{flex:1;overflow-y:auto;padding:0 16px 16px}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item{display:flex;gap:0;cursor:pointer;transition:background .15s}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item:active .tramo-sheet-content{background:var(--bg-tertiary)}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item.active .tramo-sheet-number{background:var(--accent);color:#fff;border-color:var(--accent)}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item.active .tramo-sheet-line{background:var(--accent)}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item.active .tramo-sheet-content{border-color:var(--accent);background:rgba(102,126,234,.04)}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-timeline{display:flex;flex-direction:column;align-items:center;width:36px;flex-shrink:0}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-timeline .tramo-sheet-number{width:32px;height:32px;border-radius:50%;border:2px solid var(--accent);background:var(--bg-card);color:var(--accent);font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-timeline .tramo-sheet-line{width:2px;flex:1;background:var(--border-primary);margin:2px 0}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content{flex:1;min-width:0;margin-left:12px;margin-bottom:8px;padding:12px;background:var(--bg-card);border-radius:10px;border:1px solid var(--border-primary)}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-header-row .tramo-sheet-time-end,.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-header-row .tramo-sheet-time-start{font-size:14px;font-weight:600;color:var(--text-primary)}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-header-row .tramo-sheet-stats-row{display:flex;flex-direction:column;align-items:center;gap:2px}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-header-row .tramo-sheet-stats-row .tramo-sheet-km-value{font-size:14px;font-weight:700;color:var(--text-primary)}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-header-row .tramo-sheet-stats-row .tramo-sheet-duration{font-size:11px;color:var(--accent);background:var(--accent-light);padding:1px 8px;border-radius:10px;font-weight:600}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-addresses{display:flex;flex-direction:column;gap:6px}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-addresses .tramo-sheet-addr{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text-secondary);line-height:1.4}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-addresses .tramo-sheet-addr i{margin-top:2px;flex-shrink:0;font-size:12px}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-addresses .tramo-sheet-addr .addr-start{color:#22c55e}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-addresses .tramo-sheet-addr .addr-end{color:#ef4444}.mobile-tramos-sheet .tramos-sheet-list .tramo-sheet-item .tramo-sheet-content .tramo-sheet-addresses .tramo-sheet-addr span{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.device-sheet-overlay{top:0;z-index:1000;background:rgba(0,0,0,.3)}.device-sheet,.device-sheet-overlay{position:fixed;left:0;right:0;bottom:0}.device-sheet{z-index:1001;background:var(--bg-card);border-radius:16px 16px 0 0;box-shadow:0 -4px 20px rgba(0,0,0,.15);height:70vh;display:flex;flex-direction:column;overflow:hidden}.device-sheet-handle{display:flex;justify-content:center;padding:10px 0 4px;cursor:pointer}.device-sheet-handle span{width:36px;height:4px;border-radius:2px;background:var(--border-hover)}.device-sheet-header{padding:0 16px 12px;border-bottom:1px solid var(--border-primary);flex-shrink:0}.device-sheet-header h3{font-size:16px;font-weight:700;color:var(--text-primary);margin:0 0 10px}.device-sheet-search{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-primary)}.device-sheet-search i{color:var(--text-muted);font-size:13px}.device-sheet-search input{flex:1;border:none;background:transparent;font-size:14px;color:var(--text-primary);outline:none}.device-sheet-search input::-moz-placeholder{color:var(--text-muted)}.device-sheet-search input::placeholder{color:var(--text-muted)}.device-sheet-body{flex:1;overflow-y:auto;padding:8px 0;-webkit-overflow-scrolling:touch}.device-sheet-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .15s ease}.device-sheet-item:active{background:var(--bg-hover)}.device-sheet-item.active{background:var(--accent-light);border-left:3px solid var(--accent)}.device-sheet-item-icon{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--border-primary)}.device-sheet-item-icon img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.device-sheet-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.device-sheet-item-info .device-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-sheet-item-info .device-imei{font-size:11px;color:var(--text-muted)}.device-sheet-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 16px;color:var(--text-muted);font-size:14px}.device-sheet-empty i{font-size:24px;opacity:.5}