:root{--primary-color: #8264FA;--primary-dark: #6B4FD8;--primary-light: #A78BFA;--secondary-color: #1E293B;--success-color: #22C55E;--warning-color: #F59E0B;--danger-color: #EF4444;--info-color: #3B82F6;--bg-primary: #F8FAFC;--bg-secondary: #FFFFFF;--bg-tertiary: #F1F5F9;--text-primary: #1E293B;--text-secondary: #64748B;--text-muted: #94A3B8;--border-color: #E2E8F0;--border-radius: 12px;--border-radius-sm: 8px;--border-radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden;width:100%;max-width:100vw}#app{width:100%;max-width:100vw;overflow-x:hidden}.loading-screen{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-secondary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;z-index:9999}.loading-screen.hidden{display:none}.loader{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}#app{min-height:100vh}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%)}.login-card{background:var(--bg-secondary);padding:3rem;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:64px;height:64px;margin-bottom:1rem}.login-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.login-subtitle{color:var(--text-secondary);font-size:.95rem}.form-row{display:flex;gap:1rem;align-items:flex-start}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-weight:500;font-size:.875rem;color:var(--text-primary);margin-bottom:.5rem}.form-input{width:100%;padding:.75rem 1rem;font-size:1rem;font-family:inherit;border:2px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-secondary);color:var(--text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8264fa26}.form-input::placeholder{color:var(--text-muted)}.form-input.error{border-color:var(--danger-color)}.form-select{width:100%;padding:.75rem 2.5rem .75rem 1rem;font-size:1rem;font-family:inherit;border:2px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.25rem}.form-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8264fa26}.form-error{color:var(--danger-color);font-size:.8rem;margin-top:.25rem}.form-hint{color:var(--text-muted);font-size:.8rem;margin-top:.25rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;font-family:inherit;border:none;border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--border-color)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-success{background:var(--success-color);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.btn-danger{background:var(--danger-color);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-warning{background:var(--warning-color);color:#fff}.btn-warning:hover:not(:disabled){background:#d97706}.btn-outline{background:transparent;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-outline:hover:not(:disabled){background:var(--primary-color);color:#fff}.btn-block{width:100%}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.btn-lg{padding:1rem 2rem;font-size:1.1rem}.btn-icon{padding:.5rem;width:40px;height:40px}.main-layout{display:flex;min-height:100vh}.mobile-menu-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:200;width:44px;height:44px;border:none;border-radius:var(--border-radius-sm);background:var(--primary-color);color:#fff;cursor:pointer;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:all var(--transition-fast)}.mobile-menu-toggle:hover{background:var(--primary-dark);transform:scale(1.05)}.mobile-menu-toggle svg{width:24px;height:24px}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:95;opacity:0;pointer-events:none;transition:opacity var(--transition-normal)}.sidebar-overlay.active{opacity:1;pointer-events:auto}.sidebar{width:280px;background:var(--secondary-color);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform var(--transition-normal)}.sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{display:flex;align-items:center;gap:.75rem}.sidebar-logo img{width:40px;height:40px}.sidebar-logo-text{font-weight:700;font-size:1.1rem}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-section{margin-bottom:1.5rem}.nav-section-title{padding:.5rem 1.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff6}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:#ffffffb3;text-decoration:none;font-weight:500;transition:all var(--transition-fast);cursor:pointer;border:none;background:none;width:100%;text-align:left;font-size:.95rem}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:var(--primary-color);color:#fff}.nav-item svg{width:20px;height:20px;flex-shrink:0}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;gap:.75rem}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem}.user-details{flex:1;min-width:0}.user-name{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:#ffffff80}.main-content{flex:1;margin-left:280px;min-height:100vh}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center;gap:1rem}.page-title{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.breadcrumb-separator{color:var(--text-muted)}.header-right{display:flex;align-items:center;gap:1rem}.content{padding:2rem;overflow-x:hidden;max-width:100%}.card{background:var(--bg-secondary);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);overflow:hidden;max-width:100%}.card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.card-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);word-break:break-word}.card-subtitle{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.card-body{padding:1.5rem}.card-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color);background:var(--bg-tertiary);border-radius:0 0 var(--border-radius) var(--border-radius)}.user-selection-panel{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);border-radius:var(--border-radius);padding:1.5rem;margin-bottom:2rem;color:#fff}.user-selection-title{font-size:1.25rem;font-weight:600;margin-bottom:1rem}.user-id-input-group{display:flex;gap:.75rem;flex-wrap:wrap}.user-id-input-group .form-input{flex:1;min-width:250px;background:#fffffff2;border:none}.user-id-input-group .form-input:focus{box-shadow:0 0 0 3px #ffffff4d}.multi-user-hint{margin-top:.75rem;font-size:.85rem;opacity:.9}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.setting-item{padding:1rem;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-tertiary)}.setting-item:hover{border-color:var(--primary-light)}.setting-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem}.setting-label{font-weight:600;color:var(--text-primary);font-size:.95rem}.setting-value{font-weight:600;color:var(--primary-color);font-size:.9rem}.setting-description{font-size:.8rem;color:var(--text-secondary);margin-bottom:.75rem}.setting-input{width:100%}.toggle-switch{position:relative;width:52px;height:28px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border-color);transition:var(--transition-fast);border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;transition:var(--transition-fast);border-radius:50%;box-shadow:var(--shadow-sm)}.toggle-switch input:checked+.toggle-slider{background-color:var(--success-color)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;border-radius:9999px}.badge-success{background:#22c55e1a;color:var(--success-color)}.badge-warning{background:#f59e0b1a;color:var(--warning-color)}.badge-danger{background:#ef44441a;color:var(--danger-color)}.badge-info{background:#3b82f61a;color:var(--info-color)}.badge-primary{background:#8264fa1a;color:var(--primary-color)}.mode-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.mode-card{background:var(--bg-secondary);border-radius:var(--border-radius);border:2px solid var(--border-color);padding:1.5rem;transition:all var(--transition-fast)}.mode-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-md)}.mode-card.active{border-color:var(--success-color);background:#22c55e0d}.mode-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.mode-card-title{display:flex;align-items:center;gap:.75rem}.mode-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.mode-icon.normal{background:#3b82f61a;color:var(--info-color)}.mode-icon.force{background:#f59e0b1a;color:var(--warning-color)}.mode-icon.realtime{background:#8264fa1a;color:var(--primary-color)}.mode-icon.emergency{background:#ef44441a;color:var(--danger-color)}.mode-card-name{font-weight:600;font-size:1.1rem}.mode-card-body{margin-bottom:1rem}.mode-detail{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-color);font-size:.9rem}.mode-detail:last-child{border-bottom:none}.mode-detail-label{color:var(--text-secondary)}.mode-detail-value{font-weight:600;color:var(--text-primary)}.mode-card-actions{display:flex;gap:.5rem}.mode-toggle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:1.5rem}.mode-toggle-card{background:var(--bg-secondary);border-radius:var(--border-radius);border:2px solid var(--border-color);padding:1.25rem;transition:all var(--transition-fast)}.mode-toggle-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-md)}.mode-toggle-card.active{border-color:var(--success-color);background:linear-gradient(135deg,#22c55e0d,#22c55e05)}.mode-toggle-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.mode-toggle-info{display:flex;align-items:center;gap:.75rem}.mode-toggle-text{display:flex;flex-direction:column}.mode-toggle-name{font-weight:600;font-size:1rem;color:var(--text-primary)}.mode-toggle-desc{font-size:.8rem;color:var(--text-muted)}.mode-toggle-details{background:var(--bg-tertiary);border-radius:var(--border-radius-sm);padding:.75rem}.mode-detail-row{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.85rem}.mode-detail-row:not(:last-child){border-bottom:1px solid var(--border-color);padding-bottom:.5rem;margin-bottom:.25rem}.toggle-switch-large{position:relative;display:inline-block;width:56px;height:28px;flex-shrink:0}.toggle-switch-large input{opacity:0;width:0;height:0}.toggle-slider-large{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e1;transition:all var(--transition-fast);border-radius:28px}.toggle-slider-large:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;transition:all var(--transition-fast);border-radius:50%;box-shadow:0 2px 4px #0003}.toggle-switch-large input:checked+.toggle-slider-large{background-color:var(--success-color)}.toggle-switch-large input:checked+.toggle-slider-large:before{transform:translate(28px)}.toggle-switch-large input:focus+.toggle-slider-large{box-shadow:0 0 0 3px #22c55e33}.interval-popup-content{max-width:420px;text-align:center}.modal-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.modal-subtitle{font-size:.9rem;color:var(--text-secondary);margin-bottom:1.5rem}.interval-options{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem}.interval-option{padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-secondary);cursor:pointer;font-size:.95rem;font-weight:500;transition:all var(--transition-fast);color:var(--text-primary)}.interval-option:hover{border-color:var(--primary-color);background:#8264fa0d}.interval-option.selected{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.custom-interval-row{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);margin-bottom:1.5rem}.custom-interval-row label{font-weight:500;color:var(--text-secondary)}.custom-interval-row input{width:100px;text-align:center}.custom-interval-row span{color:var(--text-muted);font-size:.9rem}.modal-actions{display:flex;gap:.75rem;justify-content:center}.modal-actions .btn{min-width:120px}.settings-grid.single-setting{max-width:400px}.user-panel{background:var(--bg-secondary);border-radius:var(--border-radius);border:1px solid var(--border-color);margin-bottom:1.5rem;overflow:hidden}.user-panel-header{background:var(--bg-tertiary);padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color)}.user-panel-id{font-family:Courier New,monospace;font-weight:600;color:var(--primary-color);font-size:.95rem}.user-panel-status{display:flex;align-items:center;gap:1rem}.user-panel-body{padding:1.5rem}.user-panel-actions{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color);background:var(--bg-tertiary)}.tabs{display:flex;gap:.25rem;background:var(--bg-tertiary);padding:.25rem;border-radius:var(--border-radius-sm);margin-bottom:1.5rem}.tab{flex:1;padding:.75rem 1rem;text-align:center;font-weight:500;color:var(--text-secondary);background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--bg-secondary);color:var(--primary-color);box-shadow:var(--shadow-sm)}.alert{padding:1rem 1.25rem;border-radius:var(--border-radius-sm);margin-bottom:1rem;display:flex;align-items:flex-start;gap:.75rem}.alert-success{background:#22c55e1a;border:1px solid rgba(34,197,94,.2);color:#166534}.alert-warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);color:#92400e}.alert-danger{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#991b1b}.alert-info{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);color:#1e40af}.data-freshness-warning{font-weight:500;animation:pulseWarning 2s ease-in-out infinite;border-left:4px solid currentColor}.data-freshness-warning.alert-danger{animation:pulseCritical 1.5s ease-in-out infinite}@keyframes pulseWarning{0%,to{opacity:1;transform:scale(1)}50%{opacity:.95;transform:scale(1.01)}}@keyframes pulseCritical{0%,to{opacity:1;box-shadow:0 0 #ef444466}50%{opacity:1;box-shadow:0 0 0 8px #ef444400}}.data-freshness-warning .btn{margin-top:.5rem}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem}.toast{padding:1rem 1.5rem;border-radius:var(--border-radius-sm);background:var(--bg-secondary);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.75rem;animation:slideIn .3s ease;max-width:400px}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left:4px solid var(--success-color)}.toast-warning{border-left:4px solid var(--warning-color)}.toast-danger{border-left:4px solid var(--danger-color)}.toast-info{border-left:4px solid var(--info-color)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-overlay.hidden{display:none}.modal,.modal-content{background:var(--bg-secondary);border-radius:var(--border-radius);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;padding:1.5rem}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:.25rem;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--bg-secondary);border-radius:var(--border-radius);padding:1.5rem;border:1px solid var(--border-color)}.stat-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.stat-change{font-size:.8rem;margin-top:.5rem}.stat-change.positive{color:var(--success-color)}.stat-change.negative{color:var(--danger-color)}.history-table{width:100%;border-collapse:collapse}.history-table th,.history-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-color)}.history-table th{font-weight:600;font-size:.85rem;color:var(--text-secondary);background:var(--bg-tertiary)}.history-table tbody tr:hover{background:var(--bg-tertiary)}.empty-state{text-align:center;padding:3rem;color:var(--text-secondary)}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.map-page{display:grid;grid-template-columns:380px 1fr;gap:1.5rem;min-height:calc(100vh - 140px);overflow-x:hidden;max-width:100%}.map-controls-panel{display:flex;flex-direction:column;overflow:visible}.map-controls-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff;border-radius:var(--border-radius) var(--border-radius) 0 0}.map-controls-header h3{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600}.map-controls-body{padding:1.25rem;border-bottom:1px solid var(--border-color);overflow:visible}.map-controls-body .form-group{margin-bottom:1rem}.map-controls-body .form-group:last-child{margin-bottom:1.5rem}.input-group{display:flex;gap:.5rem}.input-group .form-input{flex:1}.date-range-inputs{display:flex;align-items:center;gap:.5rem}.date-range-inputs .form-input{flex:1;font-size:.85rem;padding:.5rem}.date-range-separator{color:var(--text-muted);font-size:.85rem}.scroll-datetime-picker{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:.75rem}.scroll-picker-row{display:flex;gap:.5rem;align-items:flex-end}.scroll-picker-col{flex:1;min-width:0;display:flex;flex-direction:column}.scroll-picker-col .picker-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem;font-weight:600}.scroll-select{width:100%;padding:.5rem 1.25rem .5rem .25rem;font-size:.85rem;font-weight:500;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;text-align:center;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .35rem center;transition:border-color .2s,box-shadow .2s}.scroll-select:hover{border-color:var(--primary-color)}.scroll-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8264fa26}.scroll-select option{padding:.5rem;background:var(--bg-primary);color:var(--text-primary)}.scroll-picker-col:first-child{flex:1.2}.scroll-picker-col:nth-child(4),.scroll-picker-col:nth-child(5){flex:.8}.locations-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.playback-checkbox-label{display:flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:500;color:var(--primary-color);cursor:pointer;-webkit-user-select:none;user-select:none;padding:.25rem .5rem;background:#8264fa1a;border-radius:4px;transition:background-color var(--transition-fast)}.playback-checkbox-label:hover{background:#8264fa33}.playback-checkbox-label input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary-color)}.playback-hint{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:6px;padding:.5rem .75rem;margin-bottom:.5rem}.playback-hint small{color:var(--success-color);font-weight:500;font-size:.75rem}.playback-range-info{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#8264fa14;border-radius:var(--border-radius-sm);margin-bottom:1rem;flex-wrap:wrap}.range-badge{background:var(--primary-color);color:#fff;padding:.25rem .6rem;border-radius:4px;font-size:.75rem;font-weight:600;font-family:SF Mono,Monaco,Menlo,monospace}.playback-range-info small{color:var(--text-secondary);font-size:.75rem}.playback-range-info .btn{margin-left:auto}.locations-dropdown-container{position:relative;margin-bottom:2rem}.locations-dropdown{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius)}.dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;cursor:pointer;transition:background-color var(--transition-fast);-webkit-user-select:none;user-select:none}.dropdown-header:hover{background:var(--bg-tertiary)}.dropdown-text{font-size:.9rem;color:var(--text-primary);font-weight:500}.dropdown-arrow{color:var(--text-muted);transition:transform var(--transition-fast);font-size:.8rem}.dropdown-content{border-top:1px solid var(--border-color);display:flex;flex-direction:column}.dropdown-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.5rem;color:var(--text-secondary)}.spinner-small{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.dropdown-list{display:flex;flex-direction:column;max-height:300px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--primary-color) var(--bg-tertiary)}.dropdown-list::-webkit-scrollbar{width:8px}.dropdown-list::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.dropdown-list::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:4px}.dropdown-list::-webkit-scrollbar-thumb:hover{background:var(--primary-hover)}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background-color var(--transition-fast)}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background:var(--bg-tertiary)}.dropdown-item.selected{background:#8264fa1a;border-left:3px solid var(--primary-color)}.dropdown-item.playback-selected{background:#22c55e26;border-left:3px solid var(--success-color);position:relative}.dropdown-item.playback-start:before{content:"START";position:absolute;right:8px;top:50%;transform:translateY(-50%);background:var(--success-color);color:#fff;font-size:.6rem;font-weight:700;padding:.15rem .4rem;border-radius:4px}.dropdown-item.playback-end:before{content:"END";position:absolute;right:8px;top:50%;transform:translateY(-50%);background:var(--info-color);color:#fff;font-size:.6rem;font-weight:700;padding:.15rem .4rem;border-radius:4px}.dropdown-item-time{font-weight:600;font-size:.85rem;color:var(--primary-color);min-width:80px}.dropdown-item-coords{font-size:.8rem;color:var(--text-secondary);font-family:SF Mono,Monaco,Menlo,monospace;flex:1}.dropdown-item-accuracy{font-size:.75rem;color:var(--text-muted);background:var(--bg-tertiary);padding:.15rem .5rem;border-radius:4px}.dropdown-empty{padding:1.5rem;text-align:center;color:var(--text-muted);font-size:.9rem}.dropdown-empty.dropdown-error{color:var(--danger-color)}.dropdown-load-more{width:100%;border-radius:0 0 var(--border-radius) var(--border-radius);margin:0;padding:.75rem;font-size:.85rem}.location-count-badge{position:absolute;top:-8px;right:-8px;background:var(--primary-color);color:#fff;font-size:.7rem;font-weight:600;padding:.25rem .5rem;border-radius:12px;display:flex;align-items:center;gap:.15rem}.quick-date-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.quick-date-buttons .btn{flex:1;min-width:40px}.quick-date-buttons .btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.map-action-buttons{display:flex;gap:.5rem}.map-action-buttons .btn{flex:1;font-size:.8rem;padding:.5rem .75rem}.map-playback-section{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.map-playback-section h4{font-size:.9rem;font-weight:600;margin-bottom:.75rem;color:var(--text-secondary)}.map-live-section{background:linear-gradient(135deg,#fefefe,#f8fafc);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;margin-bottom:1rem}.live-mode-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.live-mode-header h4{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:var(--text-primary);margin:0}.live-indicator{display:flex;align-items:center;gap:.4rem;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;background:var(--bg-tertiary);color:var(--text-muted);transition:all var(--transition-normal)}.live-indicator.active{background:var(--danger-color);color:#fff;animation:live-pulse 2s infinite}.live-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.live-indicator.active .live-dot{animation:dot-pulse 1s infinite}@keyframes live-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}@keyframes dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}.live-controls{display:flex;gap:.5rem;margin-top:.75rem}.live-location-info{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:var(--border-radius-sm);padding:.75rem;margin-top:.75rem}.live-info-item{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0}.live-info-item:not(:last-child){border-bottom:1px solid rgba(34,197,94,.2)}.live-info-label{font-size:.8rem;color:var(--text-secondary)}.live-info-value{font-size:.85rem;font-weight:500;color:var(--text-primary);font-family:Monaco,Menlo,monospace}.return-to-live-banner{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #F59E0B;border-radius:var(--border-radius-sm);margin-top:.75rem}.return-to-live-info{display:flex;align-items:center;gap:.5rem;color:#92400e;font-size:.9rem;font-weight:500}.return-icon{display:flex;align-items:center;justify-content:center}.return-to-live-banner .btn-warning{width:100%;justify-content:center;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;font-weight:600;transition:all var(--transition-fast)}.return-to-live-banner .btn-warning:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-1px);box-shadow:var(--shadow-md)}.location-item.live{background:linear-gradient(135deg,#ef44441a,#ef44440d);border-color:var(--danger-color);position:relative}.location-item.live:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--danger-color);border-radius:4px 0 0 4px}.location-item.live .location-item-icon{color:var(--danger-color)}.live-mode-toggle{margin-left:auto}.live-mode-toggle .btn{display:flex;align-items:center;gap:.5rem;font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.live-mode-toggle .btn.live-active{background:var(--danger-color);border-color:var(--danger-color);animation:liveGlow 1.5s ease-in-out infinite}@keyframes liveGlow{0%,to{box-shadow:0 0 5px #ef444480}50%{box-shadow:0 0 20px #ef4444cc}}.live-indicator{width:8px;height:8px;background:currentColor;border-radius:50%;display:inline-block}.live-indicator.pulsing{animation:livePulse 1s ease-in-out infinite}@keyframes livePulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.live-mode-info{margin-bottom:1rem}.live-mode-card{display:flex;align-items:center;gap:.75rem;padding:1rem;background:linear-gradient(135deg,#ef44441a,#ef44440d);border:1px solid rgba(239,68,68,.3);border-radius:var(--border-radius-sm);margin-bottom:1rem}.live-icon-wrapper{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--danger-color);border-radius:50%;flex-shrink:0}.live-dot{width:12px;height:12px;background:#fff;border-radius:50%;animation:livePulse 1s ease-in-out infinite}.live-text strong{display:block;color:var(--danger-color);font-size:.9rem;margin-bottom:.25rem}.live-text p{font-size:.8rem;color:var(--text-muted);margin:0}.latest-location-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);padding:1rem}.latest-header{font-weight:600;font-size:.85rem;color:var(--success-color);margin-bottom:.5rem}.latest-coords{font-family:Monaco,Consolas,monospace;font-size:.95rem;color:var(--text-primary);margin-bottom:.25rem}.latest-time{font-size:.8rem;color:var(--text-muted);margin-bottom:.75rem}.latest-actions{display:flex;gap:.5rem}.live-badge-floating{position:absolute;top:1rem;left:1rem;z-index:1000;display:flex;align-items:center;gap:.5rem;background:var(--danger-color);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;box-shadow:var(--shadow-lg);animation:floatingBadge 2s ease-in-out infinite}@keyframes floatingBadge{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.live-dot-small{width:8px;height:8px;background:#fff;border-radius:50%;animation:livePulse 1s ease-in-out infinite}.history-section{margin-bottom:1rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.section-header h4{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:var(--text-secondary);margin:0}.date-input-wrapper{flex:1;display:flex;flex-direction:column;gap:.25rem}.date-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.current-user-badge{margin-top:.5rem}.location-list-header{display:flex;justify-content:space-between;align-items:center}.location-count{font-size:.75rem;color:var(--text-muted);font-weight:500}.location-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border-bottom:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast)}.location-item:hover{background:#8264fa0d}.location-item.active{background:#8264fa26;border-left:3px solid var(--primary-color)}.location-item.latest{background:#22c55e1a}.location-item-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:50%;font-size:.75rem;font-weight:600;flex-shrink:0}.location-item.active .location-item-number{background:var(--primary-color);color:#fff}.location-item.latest .location-item-number{background:var(--success-color);color:#fff}.location-item-content{flex:1;min-width:0}.location-item-main{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.location-item-coords{font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.location-item-meta{display:flex;align-items:center;gap:.75rem;font-size:.75rem;color:var(--text-muted)}.location-item-time{display:flex;align-items:center;gap:.25rem}.location-item-accuracy{color:var(--warning-color);font-weight:500}.location-item-actions{flex-shrink:0}.btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;font-size:1rem;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-tertiary);border-color:var(--primary-color)}.location-list-more{padding:1rem;text-align:center}.stat-card-mini{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--border-radius-sm)}.stat-card-mini .stat-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--primary-light);color:#fff;border-radius:50%;flex-shrink:0}.stat-card-mini .stat-icon svg{width:16px;height:16px}.stat-card-mini .stat-content{flex:1;min-width:0}.stat-card-mini .stat-value{display:block;font-size:1rem;font-weight:700;color:var(--text-primary);line-height:1.2}.stat-card-mini .stat-label{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em}.feature-badges{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap;justify-content:center}.feature-badge{padding:.35rem .75rem;background:#8264fa1a;color:var(--primary-color);border-radius:20px;font-size:.8rem;font-weight:500}.playback-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;padding:0;font-size:1rem}.playback-btn.playback-main{width:48px;height:48px;font-size:1.25rem;border-radius:50%}.playback-position{display:flex;align-items:center;justify-content:center;gap:.25rem;margin-top:.5rem;font-size:.85rem;color:var(--text-secondary)}.playback-position span:first-child{font-weight:600;color:var(--primary-color)}.map-controls-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff;border-radius:var(--border-radius) var(--border-radius) 0 0}.btn-block{width:100%;display:block}.empty-state-mini{padding:2rem 1rem;text-align:center}.empty-state-mini .empty-icon{display:flex;align-items:center;justify-content:center;width:60px;height:60px;margin:0 auto 1rem;background:var(--bg-tertiary);color:var(--text-muted);border-radius:50%}.empty-state-mini .empty-icon svg{width:28px;height:28px}.empty-state-mini p{margin:.25rem 0;color:var(--text-muted);font-size:.9rem}.empty-state-mini .text-muted{font-size:.8rem;opacity:.7}.empty-state-mini h4{color:var(--text-primary);font-size:1rem;margin-bottom:.5rem}.empty-tips{margin-top:1rem;text-align:left;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);padding:1rem}.empty-tips p{margin-bottom:.5rem;color:var(--text-primary)}.empty-tips ul{margin:0;padding-left:1.25rem}.empty-tips li{margin:.25rem 0;font-size:.85rem;color:var(--text-secondary)}.location-list-actions{display:flex;gap:.5rem;padding:.5rem 0;margin-bottom:.5rem;border-bottom:1px solid var(--border-color)}.location-item.first .location-item-number{background:var(--info-color);color:#fff}.location-badges{display:flex;gap:.25rem;flex-wrap:wrap}.location-item-provider{font-size:.7rem;color:var(--text-muted);background:var(--bg-tertiary);padding:.1rem .4rem;border-radius:4px;text-transform:uppercase}.location-item-actions{display:flex;gap:.25rem;flex-shrink:0}.location-item-actions .btn-icon{width:28px;height:28px;font-size:.85rem}@media (max-width: 400px){.location-item-actions{flex-direction:column}}.map-container-wrapper{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg-secondary);border-radius:var(--border-radius);box-shadow:var(--shadow-md);overflow:visible;position:relative;max-width:100%}.map-view-controls{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;gap:6px;background:var(--bg-secondary);border:1px solid var(--border-color);border-bottom:none;border-radius:var(--border-radius) var(--border-radius) 0 0;padding:8px 12px;pointer-events:auto;width:100%;box-sizing:border-box;flex-shrink:0}.map-view-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .85rem;font-size:.82rem;font-weight:500;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap;width:auto;justify-content:center}.map-view-btn:hover{background:var(--bg-primary);border-color:var(--primary-light);color:var(--primary-color)}.map-view-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.map-range-section{padding:1rem;background:var(--bg-secondary);border-radius:var(--border-radius);margin-bottom:1rem;border:1px solid var(--border-color)}.map-range-section h4{margin:0 0 .25rem;font-size:.95rem;color:var(--text-primary)}.map-range-section .text-muted{margin-bottom:.75rem}.range-selection-controls{display:flex;flex-direction:column;gap:.75rem;margin-bottom:.75rem}.range-point-selector{display:flex;flex-direction:column;gap:.25rem}.range-point-selector label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.range-point-selector select{padding:.5rem;font-size:.85rem;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-primary);color:var(--text-primary)}.range-action-buttons{display:flex;gap:.5rem;margin-bottom:.5rem}.map-fitall-more-btn{margin-top:.35rem;width:100%;font-weight:600}.map-fitall-more-btn:disabled{opacity:.75;cursor:not-allowed}.range-action-buttons .btn{flex:1;padding:.5rem .75rem;font-size:.85rem}.range-info{padding:.5rem;background:var(--primary-light);border-radius:var(--border-radius-sm);text-align:center;color:var(--primary);font-weight:500}@media (max-width: 480px){.map-view-controls{gap:.35rem;padding:.5rem}.map-view-btn{padding:.4rem .65rem;font-size:.75rem}.range-action-buttons{flex-direction:column}}.location-map{flex:1;min-height:700px;height:700px;width:100%;position:relative;background:var(--bg-tertiary);border-radius:0 0 var(--border-radius) var(--border-radius);overflow:hidden}.google-map-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:700px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:var(--border-radius);text-align:center;padding:2rem}.google-map-empty-state{max-width:400px}.google-map-empty-state svg{width:80px;height:80px;color:var(--primary-light);margin-bottom:1.5rem;opacity:.6}.google-map-empty-state h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.google-map-empty-state p{font-size:1rem;color:var(--text-secondary);margin-bottom:.5rem;line-height:1.5}.google-map-empty-state .text-muted{font-size:.85rem;color:var(--text-muted)}.google-map-iframe{width:100%;height:700px;min-height:700px;border:none;border-radius:var(--border-radius)}.leaflet-fitall-map{width:100%;height:700px;min-height:700px;border-radius:var(--border-radius)}.fitall-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a59;z-index:1200;display:flex;align-items:center;justify-content:center;gap:.6rem;color:#fff;font-weight:600;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.fitall-marker-wrapper{background:transparent;border:none}.fitall-marker-pin{position:relative;width:26px;height:38px}.fitall-marker-pin svg{width:26px;height:38px;display:block;filter:drop-shadow(0 2px 3px rgba(0,0,0,.35))}.fitall-marker-pin path{fill:#ef4444;stroke:#b91c1c;stroke-width:1}.fitall-marker-pin circle{fill:#fff}.fitall-marker-badge{position:absolute;top:-6px;right:-10px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#111827;color:#fff;font-size:.68rem;line-height:18px;font-weight:700;text-align:center;border:1px solid #ffffff}.fitall-popup-content{font-size:.82rem;line-height:1.35}.fitall-popup-title{font-weight:700;margin-bottom:.35rem;color:var(--text-primary)}.fitall-popup-list{max-height:220px;overflow-y:auto;padding-right:.2rem}.fitall-popup-row{display:grid;grid-template-columns:2.3rem 1fr;gap:.12rem .45rem;margin-bottom:.35rem;padding-bottom:.3rem;border-bottom:1px solid rgba(148,163,184,.25)}.fitall-popup-visit-index{grid-column:1;grid-row:1 / span 2;align-self:start;font-weight:700;color:var(--text-primary)}.fitall-popup-visit-time{grid-column:2;font-weight:600;color:var(--text-primary)}.fitall-popup-visit-coords{grid-column:2;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.74rem;color:var(--text-secondary)}.fitall-popup-more{margin-top:.2rem;font-weight:600;color:var(--primary-color)}.map-info-panel{position:absolute;bottom:1rem;right:1rem;top:auto;z-index:1000;background:var(--bg-secondary);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);min-width:320px;max-width:400px;overflow:hidden;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.map-info-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff}.map-info-header h4{font-size:1rem;font-weight:600;margin:0;display:flex;align-items:center;gap:.5rem}.map-info-header .btn-secondary{background:#fff3;border:none;color:#fff;width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all var(--transition-fast)}.map-info-header .btn-secondary:hover{background:#ffffff4d}#map-info-details{padding:1rem}.info-grid{display:grid;gap:.75rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.info-item span{font-size:.9rem;color:var(--text-primary);font-family:Monaco,Consolas,monospace}.info-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.map-stats-section{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.map-stats-section h4{font-size:.9rem;font-weight:600;margin-bottom:.75rem;color:var(--text-secondary)}.stats-grid-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.stat-item-mini{display:flex;flex-direction:column;align-items:center;text-align:center;padding:.5rem;background:var(--bg-tertiary);border-radius:var(--border-radius-sm)}.stat-item-mini .stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;margin-bottom:.25rem}.stat-item-mini .stat-value{font-size:1rem;font-weight:700;color:var(--text-primary)}.location-list-section{flex:1;display:flex;flex-direction:column;min-height:0;overflow:visible;padding-bottom:1rem}.location-list-section h4{font-size:.9rem;font-weight:600;color:var(--text-secondary);padding:1rem 1.25rem .5rem}.location-list{flex:1;overflow-y:auto;padding:0 .5rem .5rem}.playback-controls{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.75rem}.playback-slider-container{padding:0 .5rem;margin-bottom:.75rem}.playback-slider{width:100%;height:6px;background:var(--border-color);border-radius:3px;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer}.playback-slider::-webkit-slider-thumb{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:16px;height:16px;background:var(--primary-color);border-radius:50%;cursor:pointer;box-shadow:var(--shadow-md);transition:transform var(--transition-fast)}.playback-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.playback-slider::-moz-range-thumb{width:16px;height:16px;background:var(--primary-color);border-radius:50%;border:none;cursor:pointer;box-shadow:var(--shadow-md)}.playback-speed{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.playback-speed label{font-weight:500}.form-select-sm{padding:.25rem .5rem;font-size:.85rem;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-secondary);cursor:pointer}@media (max-width: 1200px){.map-page{grid-template-columns:340px 1fr;gap:1rem}}@media (max-width: 992px){.mobile-menu-toggle{display:flex!important;z-index:200}.sidebar-overlay{display:block!important}.sidebar{transform:translate(-100%)!important;box-shadow:none}.sidebar.open{transform:translate(0)!important;box-shadow:4px 0 24px #0000004d}.main-content{margin-left:0!important;width:100%!important}.header{padding-left:4rem}.form-row{flex-direction:column}.form-row .form-group{width:100%}.map-page{grid-template-columns:1fr;grid-template-rows:auto 1fr;height:auto;min-height:auto;overflow-x:hidden;max-width:100%}.map-controls-panel{max-height:none;overflow:visible;max-width:100%}.location-list-section{max-height:none;overflow:visible}.location-map{min-height:500px;height:500px;max-width:100%}.google-map-iframe{min-height:500px;height:500px}.map-info-panel{position:relative;top:auto;bottom:auto;right:auto;min-width:auto;max-width:none;margin-top:1rem}.settings-grid{grid-template-columns:1fr}.device-visual-modern{transform:scale(.85);transform-origin:top center;margin:-10px 0}}@media (max-width: 768px){.header{flex-direction:column;align-items:flex-start;gap:.75rem;padding-left:4rem}.header-right{width:100%;justify-content:flex-start;flex-wrap:wrap}.page-title{font-size:1.1rem}.card-header,.card-body{padding:1rem}.stats-grid{grid-template-columns:1fr}.stat-card{padding:1rem}.user-settings-grid{grid-template-columns:1fr}.mode-card{padding:1rem}.mode-card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.table-container{overflow-x:auto}table{min-width:600px}.input-group{flex-direction:column}.input-group .btn{width:100%}.scroll-picker-row{flex-direction:column;gap:.5rem}.scroll-picker-col{width:100%}.quick-date-buttons{flex-wrap:wrap}.quick-date-buttons .btn{flex:1;min-width:calc(50% - .5rem)}.dropdown-list{max-height:200px}.map-controls-body{padding:1rem}.device-status-container{flex-direction:column;align-items:center;gap:1rem}.device-visual-modern{transform:scale(.75);transform-origin:top center;margin:-20px 0 -40px;max-width:100%}.device-details-modern{width:100%}.device-name-row{flex-wrap:wrap}.device-identity-modern{text-align:center}.device-name-row{justify-content:center}.device-meta-badges{flex-wrap:wrap;gap:6px;justify-content:center}.meta-badge{font-size:.75rem}.device-stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.device-stat-item{padding:8px 10px}.device-stat-item .stat-label{font-size:.65rem}.device-stat-item .stat-value{font-size:.85rem}.backend-monitor-grid{grid-template-columns:repeat(2,1fr);gap:8px}.backend-monitor-item{padding:8px 10px}.bm-label{font-size:.65rem}.bm-value{font-size:.85rem}.backend-monitor-card .card-header{flex-direction:column;align-items:flex-start;gap:8px}.grace-header{flex-direction:column;gap:4px;align-items:flex-start}.timeline-step{width:18px;height:18px;font-size:.6rem}.timeline-header{flex-direction:column;gap:4px;align-items:flex-start}.permission-item{font-size:.85rem}.alert{font-size:.85rem;padding:.75rem}}@media (max-width: 480px){.mobile-menu-toggle{top:.75rem;left:.75rem;width:40px;height:40px}.header{padding:.75rem .75rem .75rem 3.5rem}.page-title{font-size:1rem}.content,.card-header,.card-body{padding:.75rem}.btn{padding:.625rem 1rem;font-size:.875rem}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.form-input,.form-select{padding:.625rem .875rem;font-size:.875rem}.stat-value{font-size:1.5rem}.stat-label{font-size:.75rem}.sidebar{width:260px}.sidebar-header{padding:1rem}.nav-item{padding:.625rem 1rem;font-size:.875rem}.location-map,.google-map-iframe,.google-map-placeholder{min-height:280px}.map-info-panel{padding:.75rem}.map-info-panel h4{font-size:.9rem}.location-item{padding:.625rem .75rem}.time-text{font-size:.8rem}.time-coords{font-size:.7rem}.toggle-switch{width:44px;height:24px}.toggle-slider:before{width:18px;height:18px}.mode-status{font-size:.7rem;padding:.25rem .5rem}.modal-content{margin:.5rem;max-height:calc(100vh - 1rem)}.modal-header,.modal-body,.modal-footer{padding:1rem}.user-avatar-large{width:60px;height:60px;font-size:1.25rem}.date-list-scroll,.time-list-scroll{max-height:120px}.login-card{padding:1.5rem}.login-title{font-size:1.5rem}.device-visual-modern{transform:scale(.6);transform-origin:top center;margin:-25px 0 -70px}.device-stats-grid,.backend-monitor-grid{grid-template-columns:1fr}.backend-phase-badge{font-size:.7rem;padding:3px 8px}.timeline-steps{gap:2px}.timeline-step{width:16px;height:16px;font-size:.55rem}.backend-last-action{font-size:.8rem;padding:6px 10px}.fcm-controls .btn{width:100%}.log-card{padding:.75rem}.log-device-state{flex-direction:column;align-items:flex-start;gap:.25rem;font-size:.75rem}}@media (max-width: 360px){.header{padding-left:3rem}.mobile-menu-toggle{width:36px;height:36px}.mobile-menu-toggle svg{width:20px;height:20px}.sidebar{width:240px}.page-title{font-size:.9rem}.btn{padding:.5rem .75rem;font-size:.8rem}.card-title{font-size:.95rem}.quick-date-buttons .btn{min-width:100%}}@media (max-height: 500px) and (orientation: landscape){.sidebar{overflow-y:auto}.sidebar-nav{padding:.5rem 0}.nav-item,.sidebar-footer{padding:.5rem 1rem}}@media print{.sidebar,.mobile-menu-toggle,.sidebar-overlay,.header-right{display:none!important}.main-content{margin-left:0!important}.content{padding:0!important}}.email-page{max-width:900px}.user-info-card{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-primary) 100%);border-radius:var(--border-radius);padding:1.25rem;margin-top:1rem;border:1px solid var(--border-color)}.user-info-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.user-info-row:last-child{border-bottom:none}.user-info-label{font-weight:500;color:var(--text-secondary);font-size:.875rem}.user-info-value{font-weight:600;color:var(--text-primary);font-size:.9375rem}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.template-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--border-radius);padding:1.25rem;cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.template-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.template-card.active{border-color:var(--primary-color);background:linear-gradient(135deg,#8264fa0d,#8264fa1a);box-shadow:0 0 0 3px #8264fa33}.template-name{font-weight:600;color:var(--text-primary);font-size:.9375rem;margin-bottom:.5rem}.template-sender{font-size:.8125rem;color:var(--text-secondary);word-break:break-all}.form-textarea{width:100%;padding:.875rem 1rem;font-size:.9375rem;line-height:1.6;color:var(--text-primary);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);resize:vertical;min-height:200px;font-family:var(--font-family);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8264fa26}.email-preview{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.preview-header{background:var(--bg-tertiary);padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);font-size:.9375rem}.preview-body{padding:1.5rem;font-size:.9375rem;color:var(--text-primary);line-height:1.7}.preview-body p{margin-bottom:1rem}.gap-2{gap:.5rem}.d-flex{display:flex}.flex-wrap{flex-wrap:wrap}@media (max-width: 768px){.template-grid{grid-template-columns:1fr}.email-page .d-flex{flex-direction:column}.email-page .d-flex .btn{width:100%}}.fcm-page{max-width:1200px;margin:0 auto}.fcm-page .card{overflow:visible}.device-status-container{display:flex;gap:2rem;align-items:flex-start;width:100%;overflow:visible}@media (max-width: 768px){.device-status-container{flex-direction:column;align-items:center;gap:1rem}}.device-visual{position:relative;flex-shrink:0}.device-frame{width:180px;height:360px;background:linear-gradient(145deg,#2d3748,#1a202c);border-radius:36px;padding:12px;position:relative;box-shadow:0 25px 50px -20px #00000080,0 30px 60px -30px #0009,inset 0 1px #ffffff1a,inset 0 -1px #0006}.device-screen{width:100%;height:100%;background:linear-gradient(180deg,#1a1d23,#0d0f12);border-radius:28px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;position:relative;overflow:hidden}.device-screen:before{content:"";position:absolute;top:0;left:0;right:0;height:60px;background:linear-gradient(180deg,rgba(255,255,255,.03) 0%,transparent 100%)}.device-notch{position:absolute;top:18px;left:50%;transform:translate(-50%);width:80px;height:24px;background:#0f172a;border-radius:12px;z-index:10}.device-notch:after{content:"";position:absolute;top:50%;right:12px;transform:translateY(-50%);width:8px;height:8px;background:#1e293b;border-radius:50%;box-shadow:inset 0 0 0 1px #ffffff1a}.device-button{position:absolute;right:-3px;top:100px;width:4px;height:40px;background:linear-gradient(180deg,#3d4a5c,#2a2f38 30%,#3a3f4b);border-radius:0 2px 2px 0}.device-status-indicator{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;border-radius:16px;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08)}.device-status-indicator .status-icon{font-size:2rem}.device-status-indicator .status-icon svg{width:32px;height:32px}.device-status-indicator .status-text{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.device-app-icon{width:56px;height:56px;background:linear-gradient(145deg,var(--primary-color) 0%,var(--primary-dark) 100%);border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px #8264fa66}.device-app-icon img{width:32px;height:32px;filter:brightness(10)}.device-visual.device-status-active .device-status-indicator{background:#22c55e26;color:#22c55e}.device-visual.device-status-active .device-screen{box-shadow:inset 0 0 60px #22c55e1a}.device-visual.device-status-warning .device-status-indicator{background:#f59e0b26;color:#f59e0b}.device-visual.device-status-warning .device-screen{box-shadow:inset 0 0 60px #f59e0b1a}.device-visual.device-status-offline .device-status-indicator{background:#ef444426;color:#ef4444}.device-visual.device-status-offline .device-screen{box-shadow:inset 0 0 60px #ef44441a}.device-visual.device-status-unreachable .device-status-indicator{background:#64748b26;color:#64748b}.device-visual.device-status-unreachable .device-screen{box-shadow:inset 0 0 60px #64748b1a}.device-visual.device-status-unknown .device-status-indicator{background:#94a3b826;color:#94a3b8}.device-pulse-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:220px;height:420px;border-radius:50px;pointer-events:none;opacity:0;border:2px solid rgba(34,197,94,.5)}.device-pulse-ring.active{animation:pulseRing 2.5s ease-out infinite}.device-pulse-ring.delay.active{animation-delay:1.25s}@keyframes pulseRing{0%{transform:translate(-50%,-50%) scale(.95);opacity:1}50%{opacity:.95;transform:scale(1.01)}to{transform:translate(-50%,-50%) scale(1.15);opacity:0}}.device-identity{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.device-name-large{display:flex;align-items:center;gap:10px;font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.device-name-large .device-icon{font-size:1.5rem}.device-meta{display:flex;flex-wrap:wrap;gap:12px}.device-meta .meta-item{font-size:.875rem;color:var(--text-secondary);background:var(--bg-tertiary);padding:4px 10px;border-radius:6px}.device-visual-modern{position:relative;flex-shrink:0;display:flex;align-items:center;justify-content:center;perspective:1000px}.device-outer-frame{position:relative;width:220px;height:440px;background:linear-gradient(145deg,#3a3f4b,#2d3240 40%,#1f232d);border-radius:44px;padding:4px;box-shadow:0 30px 60px -15px #00000080,0 0 0 1px #ffffff14,inset 0 1px #ffffff1a,inset 0 -1px #0000004d;transition:transform .4s ease,box-shadow .4s ease}.device-visual-modern:hover .device-outer-frame{transform:translateY(-4px) rotateX(2deg);box-shadow:0 40px 80px -15px #0009,0 0 0 1px #ffffff1a,inset 0 1px #ffffff26,inset 0 -1px #0000004d}.device-antenna-top{position:absolute;top:80px;left:-1px;right:-1px;height:1px;background:#ffffff0d}.device-antenna-bottom{position:absolute;bottom:80px;left:-1px;right:-1px;height:1px;background:#ffffff0d}.device-inner-frame{position:relative;width:100%;height:100%;background:#000;border-radius:40px;overflow:hidden}.device-screen-modern{width:100%;height:100%;background:linear-gradient(180deg,#0f1117,#0a0c10);display:flex;flex-direction:column;position:relative;overflow:hidden}.device-dynamic-island{position:absolute;top:12px;left:50%;transform:translate(-50%);width:90px;height:28px;background:#000;border-radius:20px;z-index:10;box-shadow:0 0 0 2px #00000080}.device-dynamic-island:before{content:"";position:absolute;top:50%;right:18px;transform:translateY(-50%);width:8px;height:8px;background:radial-gradient(circle,#1a1d23 30%,#0d1015);border-radius:50%;box-shadow:inset 0 0 2px #323c5099}.device-statusbar{display:flex;justify-content:space-between;align-items:center;padding:14px 24px 0;height:48px;z-index:5}.statusbar-time{font-size:14px;font-weight:600;color:#ffffffe6;letter-spacing:.5px}.statusbar-icons{display:flex;align-items:center;gap:6px}.signal-bars{display:flex;align-items:flex-end;gap:1.5px;height:12px}.signal-bar{width:3px;background:#ffffffd9;border-radius:1px}.signal-bar:nth-child(1){height:4px}.signal-bar:nth-child(2){height:6px}.signal-bar:nth-child(3){height:8px}.signal-bar:nth-child(4){height:11px}.battery-icon{display:flex;align-items:center;gap:1px}.battery-body{width:22px;height:10px;border:1.5px solid rgba(255,255,255,.8);border-radius:2.5px;padding:1px;display:flex;align-items:stretch}.battery-level{border-radius:1px;transition:width .3s ease}.battery-cap{width:2px;height:4px;background:#fff9;border-radius:0 1px 1px 0;align-self:center}.device-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:0 20px}.device-status-badge{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 20px;border-radius:16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.status-icon-modern{font-size:28px;line-height:1}.status-text-modern{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#fffc}.device-app-icon-modern{width:56px;height:56px;background:linear-gradient(145deg,var(--primary-color) 0%,var(--primary-dark) 100%);border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #8264fa66}.device-app-icon-modern img{width:30px;height:30px;filter:brightness(10)}.device-app-name{font-size:11px;font-weight:600;color:#ffffff80;letter-spacing:.5px;text-transform:uppercase}.device-navbar{padding:8px 0 6px;display:flex;justify-content:center}.navbar-indicator{width:120px;height:4px;background:#ffffff40;border-radius:4px}.device-mute{position:absolute;left:-2px;top:100px;width:3px;height:24px;background:linear-gradient(180deg,#4a4f5c,#3a3f4b);border-radius:2px 0 0 2px}.device-volume-up{position:absolute;left:-2px;top:140px;width:3px;height:40px;background:linear-gradient(180deg,#4a4f5c,#3a3f4b);border-radius:2px 0 0 2px}.device-volume-down{position:absolute;left:-2px;top:190px;width:3px;height:40px;background:linear-gradient(180deg,#4a4f5c,#3a3f4b);border-radius:2px 0 0 2px}.device-power{position:absolute;right:-2px;top:155px;width:3px;height:55px;background:linear-gradient(180deg,#4a4f5c,#3a3f4b);border-radius:0 2px 2px 0}.device-pulse-ring-modern{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:260px;height:480px;border-radius:56px;pointer-events:none;opacity:0;border:2px solid rgba(34,197,94,.4)}.device-pulse-ring-modern.active{animation:pulseRingModern 3s ease-out infinite}.device-pulse-ring-modern.delay.active{animation-delay:1s}.device-pulse-ring-modern.delay-2.active{animation-delay:2s}@keyframes pulseRingModern{0%{transform:translate(-50%,-50%) scale(.92);opacity:.8}to{transform:translate(-50%,-50%) scale(1.12);opacity:0}}.device-visual-modern.device-status-active .device-status-badge{background:#22c55e26;border-color:#22c55e40}.device-visual-modern.device-status-active .status-icon-modern,.device-visual-modern.device-status-active .status-text-modern{color:#22c55e}.device-visual-modern.device-status-active .device-screen-modern{box-shadow:inset 0 0 80px #22c55e14}.device-visual-modern.device-status-active .device-outer-frame{box-shadow:0 30px 60px -15px #00000080,0 0 0 1px #22c55e33,0 0 30px #22c55e1a}.device-visual-modern.device-status-warning .device-status-badge{background:#f59e0b26;border-color:#f59e0b40}.device-visual-modern.device-status-warning .status-icon-modern,.device-visual-modern.device-status-warning .status-text-modern{color:#f59e0b}.device-visual-modern.device-status-warning .device-screen-modern{box-shadow:inset 0 0 80px #f59e0b14}.device-visual-modern.device-status-warning .device-outer-frame{box-shadow:0 30px 60px -15px #00000080,0 0 0 1px #f59e0b33,0 0 30px #f59e0b1a}.device-visual-modern.device-status-offline .device-status-badge{background:#ef444426;border-color:#ef444440}.device-visual-modern.device-status-offline .status-icon-modern,.device-visual-modern.device-status-offline .status-text-modern{color:#ef4444}.device-visual-modern.device-status-offline .device-screen-modern{box-shadow:inset 0 0 80px #ef444414}.device-visual-modern.device-status-offline .device-outer-frame{box-shadow:0 30px 60px -15px #00000080,0 0 0 1px #ef444433,0 0 30px #ef44441a}.device-visual-modern.device-status-unreachable .device-status-badge{background:#64748b26;border-color:#64748b33}.device-visual-modern.device-status-unreachable .status-icon-modern,.device-visual-modern.device-status-unreachable .status-text-modern{color:#64748b}.device-visual-modern.device-status-unreachable .device-screen-modern{box-shadow:inset 0 0 80px #64748b14}.device-visual-modern.device-status-recovering .device-status-badge{background:#ef44441f;border-color:#ef444433}.device-visual-modern.device-status-recovering .status-icon-modern{color:#ef4444;animation:recoveryPulse 1.5s ease-in-out infinite}.device-visual-modern.device-status-recovering .status-text-modern{color:#ef4444}.device-visual-modern.device-status-recovering .device-screen-modern{box-shadow:inset 0 0 80px #ef44440f}.device-visual-modern.device-status-recovering .device-pulse-ring-modern{border-color:#ef44444d}@keyframes recoveryPulse{0%,to{opacity:1}50%{opacity:.5}}.device-details-modern{flex:1;min-width:0;display:flex;flex-direction:column;gap:1rem}.device-identity-modern{padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.device-name-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}.device-icon-large{width:48px;height:48px;background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-primary) 100%);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;border:1px solid var(--border-color)}.device-name-text{flex:1}.device-name-text h4{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 2px}.device-name-text .device-model{font-size:.875rem;color:var(--text-secondary)}.device-meta-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1rem}.meta-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:.8rem;font-weight:500;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary)}.meta-badge .badge-icon{font-size:.85rem}.meta-badge.badge-success{background:#22c55e1a;border-color:#22c55e33;color:var(--success-color)}.meta-badge.badge-warning{background:#f59e0b1a;border-color:#f59e0b33;color:var(--warning-color)}.meta-badge.badge-danger{background:#ef44441a;border-color:#ef444433;color:var(--danger-color)}.device-status-reason{font-size:.85rem;color:var(--text-secondary);padding:.5rem .75rem;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);border-left:3px solid var(--warning-color)}.device-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.device-stat-item{display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--bg-tertiary);border-radius:var(--border-radius);border:1px solid var(--border-color)}.device-stat-item .stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600}.device-stat-item .stat-value{font-size:.95rem;font-weight:600;color:var(--text-primary)}.device-stat-item .stat-value.text-success{color:var(--success-color)}.device-stat-item .stat-value.text-danger{color:var(--danger-color)}.device-stat-item .stat-value.text-warning{color:var(--warning-color)}.text-success{color:var(--success-color)!important}.text-danger{color:var(--danger-color)!important}.text-warning{color:var(--warning-color)!important}.text-muted{color:var(--text-muted)!important}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.backend-monitor-card{overflow:hidden}.backend-monitor-card .card-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.backend-phase-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;font-size:.8rem;font-weight:600;border-radius:20px;white-space:nowrap}.backend-phase-description{margin-bottom:16px;padding-left:12px}.backend-phase-description p{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.backend-monitor-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.backend-monitor-item{display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);border:1px solid var(--border-color)}.bm-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600}.bm-value{font-size:.95rem;font-weight:600;color:var(--text-primary)}.backend-grace-period{margin-top:16px;padding:16px;background:var(--bg-tertiary);border-radius:var(--border-radius);border:1px solid var(--border-color)}.grace-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;font-size:.9rem;font-weight:600;color:var(--text-primary)}.grace-countdown{font-weight:600;white-space:nowrap}.grace-bar-track{width:100%;height:8px;background:var(--border-color);border-radius:4px;overflow:hidden;margin-bottom:6px}.grace-bar-fill{height:100%;border-radius:4px;transition:width 1s linear,background .3s ease}.grace-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-muted);font-weight:500}.backend-monitor-timeline{margin-top:16px;padding:16px;background:var(--bg-tertiary);border-radius:var(--border-radius);border:1px solid var(--border-color)}.timeline-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.timeline-title{font-size:.9rem;font-weight:600;color:var(--text-primary)}.timeline-progress{font-size:.8rem;font-weight:600;color:var(--text-secondary);background:var(--bg-secondary);padding:2px 10px;border-radius:12px;border:1px solid var(--border-color);white-space:nowrap}.timeline-steps{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.timeline-step{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;font-size:.7rem;border-radius:50%;font-weight:600;transition:all .2s ease}.timeline-step-pending{color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border-color)}.timeline-step-done{color:#fff;background:var(--success-color);border:1px solid var(--success-color)}.timeline-step-active{color:#fff;background:var(--warning-color);border:1px solid var(--warning-color);animation:stepPulse 1.5s ease-in-out infinite}@keyframes stepPulse{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 4px #f59e0b00}}.backend-last-action{margin-top:12px;padding:8px 12px;border-radius:6px;font-size:.85rem;line-height:1.5}.mb-4{margin-bottom:1.5rem}.empty-state.small{padding:2rem}.empty-state.small p{font-size:.9rem}.realtime-indicator{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#22c55e1a;border-radius:20px;border:1px solid rgba(34,197,94,.2)}.realtime-dot{width:8px;height:8px;background:var(--success-color);border-radius:50%;animation:realtimePulse 2s ease-in-out infinite}.realtime-text{font-size:12px;font-weight:600;color:var(--success-color)}@keyframes realtimePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.fcm-mode-section{margin-bottom:1.5rem}.fcm-mode-toggle{display:flex;gap:1rem;padding:.5rem;background:var(--bg-tertiary);border-radius:var(--border-radius)}.mode-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1rem;border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast);background:transparent;border:2px solid transparent}.mode-option:hover{background:var(--bg-secondary)}.mode-option.active{background:var(--bg-secondary);border-color:var(--primary-color);box-shadow:var(--shadow-md)}.mode-option .mode-icon{font-size:2rem}.mode-option .mode-label{font-weight:600;font-size:1rem;color:var(--text-primary)}.mode-option .mode-desc{font-size:.8rem;color:var(--text-muted);text-align:center}.mode-option.active .mode-label{color:var(--primary-color)}.fcm-send-section{text-align:center;padding:1.5rem;background:linear-gradient(135deg,#8264fa0d,#8264fa1a);border-radius:var(--border-radius);margin-bottom:1.5rem}.fcm-send-btn{min-width:250px;padding:1rem 2rem;font-size:1.1rem}.fcm-send-hint{margin-top:1rem;font-size:.85rem;color:var(--text-secondary)}.wake-cycle-active-alert{margin-top:1.5rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#f59e0b1a,#f59e0b33);border:2px solid var(--warning-color);border-radius:var(--border-radius);animation:pulse-warning 2s ease-in-out infinite}@keyframes pulse-warning{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 8px #f59e0b00}}.wake-cycle-content{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:space-between}.wake-cycle-icon{font-size:1.75rem;animation:spin-slow 3s linear infinite}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.wake-cycle-info{flex:1;min-width:200px}.wake-cycle-info strong{display:block;font-size:1rem;color:var(--text-primary);margin-bottom:.25rem}.wake-cycle-details{font-size:.85rem;color:var(--text-secondary)}.wake-cancel-btn{padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:var(--border-radius-sm);background:var(--danger-color);color:#fff;border:none;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:.4rem;box-shadow:0 2px 4px #ef44444d}.wake-cancel-btn:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 8px #ef444466}.fcm-stats-section{margin-top:1.5rem}.stats-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.fcm-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.fcm-stat-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1rem;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);transition:all var(--transition-fast)}.fcm-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.fcm-stat-card .stat-number{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.fcm-stat-card .stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}@media (max-width: 768px){.fcm-mode-toggle{flex-direction:column}.fcm-stats-grid{grid-template-columns:1fr}.fcm-send-btn{width:100%;min-width:unset}}.log-list{display:flex;flex-direction:column;gap:1.25rem;max-height:800px;overflow-y:auto;padding:1.5rem;background:var(--bg-tertiary);border-radius:16px;border:1px solid var(--border-color)}.log-list::-webkit-scrollbar{width:10px}.log-list::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:10px}.log-list::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:10px;transition:background var(--transition-fast)}.log-list::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}.log-item{display:flex;gap:1rem;padding:1.25rem;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px #1018280a;transition:all .2s ease;position:relative;overflow:visible;align-items:flex-start;width:100%;box-sizing:border-box;margin-bottom:0}.log-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--primary-color);border-radius:4px 0 0 4px;transition:background .2s ease,width .2s ease}.log-item:hover{box-shadow:0 4px 16px #10182814;transform:translateY(-1px);border-color:var(--primary-color)}.log-item:hover:before{width:5px}.log-item.log-success:before{background:var(--success-color)}.log-item.log-error:before{background:var(--danger-color)}.log-item.log-warning:before{background:var(--warning-color)}.log-item.log-pending:before{background:var(--info-color)}.log-item.log-success{background:linear-gradient(to right,rgba(34,197,94,.03),var(--bg-secondary) 30%)}.log-item.log-error{background:linear-gradient(to right,rgba(239,68,68,.03),var(--bg-secondary) 30%)}.log-item.log-warning{background:linear-gradient(to right,rgba(245,158,11,.03),var(--bg-secondary) 30%)}.log-item.log-pending{background:linear-gradient(to right,rgba(59,130,246,.03),var(--bg-secondary) 30%)}.log-icon{display:flex;align-items:center;justify-content:center;min-width:48px;width:48px;height:48px;background:var(--bg-tertiary);border-radius:12px;font-size:1.4rem;flex-shrink:0;transition:all var(--transition-fast)}.log-item:hover .log-icon{transform:scale(1.05)}.log-success .log-icon{background:#22c55e1f;color:var(--success-color)}.log-error .log-icon{background:#ef44441f;color:var(--danger-color)}.log-warning .log-icon{background:#f59e0b1f;color:var(--warning-color)}.log-pending .log-icon{background:#3b82f61f;color:var(--info-color)}.log-content{flex:1;display:flex;flex-direction:column;gap:.75rem;min-width:0}.log-header{display:flex;align-items:flex-start;gap:.75rem;flex-wrap:wrap;width:100%}.log-type{font-weight:600;font-size:.95rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem;flex:1;min-width:200px;line-height:1.4}.log-status{display:inline-flex;align-items:center;padding:.35rem .9rem;font-size:.7rem;font-weight:700;border-radius:16px;text-transform:uppercase;letter-spacing:.05em;border:none;background:var(--bg-tertiary);flex-shrink:0;transition:all .2s ease}.log-success .log-status{background:#22c55e26;color:#15803d;border:1px solid rgba(34,197,94,.3)}.log-error .log-status{background:#ef444426;color:#b91c1c;border:1px solid rgba(239,68,68,.3)}.log-warning .log-status{background:#f59e0b26;color:#c2410c;border:1px solid rgba(245,158,11,.3)}.log-pending .log-status{background:#3b82f626;color:#1e40af;border:1px solid rgba(59,130,246,.3)}.log-time{font-size:.8rem;color:var(--text-muted);font-weight:500;white-space:nowrap;flex-shrink:0;padding:.25rem .75rem;background:var(--bg-tertiary);border-radius:12px;border:1px solid var(--border-color)}.log-reason{font-size:.85rem;color:var(--text-secondary);padding:.625rem .875rem;background:var(--bg-tertiary);border-radius:6px;border-left:3px solid var(--primary-color);line-height:1.5;margin-top:0}.log-message{font-size:.85rem;color:var(--text-secondary);line-height:1.5;padding:0}.log-error-msg{display:flex;align-items:flex-start;gap:.5rem;padding:.625rem .875rem;background:#ef444414;border-left:3px solid var(--danger-color);border-radius:6px;font-size:.85rem;color:#b91c1c;font-weight:500;line-height:1.5}.log-device-state{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--bg-tertiary);border-radius:8px;font-size:.8rem;font-weight:500;color:var(--text-secondary);border:1px solid var(--border-color);margin-top:.5rem}.log-device-state span{white-space:nowrap}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}
