:root{--color-primary:#0ea5e9;--color-primary-dark:#0284c7;--color-primary-light:#38bdf8;--color-accent:#06b6d4;--color-success:#10b981;--color-warning:#f59e0b;--color-danger:#ef4444;--color-danger-light:#fef2f2;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-heading:"Space Grotesk", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--sidebar-width:260px;--sidebar-collapsed-width:70px;--header-height:60px;--transition:.2s cubic-bezier(.4, 0, .2, 1);--sidebar-transition:.3s cubic-bezier(.4, 0, .2, 1);--border-focus:#0ea5e9;--hue-primary:200;--card:var(--bg-card);--foreground:var(--text-primary);--muted-foreground:var(--text-secondary);--accent:var(--bg-hover)}:root,[data-theme=light]{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-card:#fff;--bg-input:#f1f5f9;--bg-hover:#e2e8f0;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border:#e2e8f0;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 32px #0000001f;--shadow-glow:0 0 20px #0ea5e914}[data-theme=dark]{--bg-primary:#0b1120;--bg-secondary:#111827;--bg-card:#1a2332;--bg-input:#1e293b;--bg-hover:#1e3a5f;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border:#1e293b;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #0ea5e926}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6}a{color:var(--color-primary);transition:color var(--transition);text-decoration:none}a:hover{color:var(--color-primary-light)}h1,h2,h3,h4,h5,h6,.heading{font-family:var(--font-heading);letter-spacing:-.02em;line-height:1.2}h1{letter-spacing:-.025em;font-size:32px;font-weight:700}h2{letter-spacing:-.02em;font-size:24px;font-weight:600}h3{letter-spacing:-.015em;font-size:20px;font-weight:600}h4{letter-spacing:-.01em;font-size:16px;font-weight:600}h5{font-size:14px;font-weight:600}h6{text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.login-container{background:radial-gradient(ellipse at 20% 50%, #0ea5e914 0%, transparent 50%), radial-gradient(ellipse at 80% 20%, #06b6d40f 0%, transparent 50%), var(--bg-primary);justify-content:center;align-items:center;gap:80px;min-height:100vh;padding:40px;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg), var(--shadow-glow);padding:40px}.register-card{max-width:480px}.login-header{text-align:center;margin-bottom:32px}.login-logo{justify-content:center;align-items:center;gap:12px;margin-bottom:8px;display:flex}.login-title{font-family:var(--font-heading);letter-spacing:-.03em;background:linear-gradient(135deg, var(--color-primary), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:14px}.login-form{flex-direction:column;gap:20px;display:flex}.login-error{border-radius:var(--radius-md);color:#fca5a5;background:#ef44441a;border:1px solid #ef444433;align-items:center;gap:8px;padding:12px 16px;font-size:13px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);font-size:13px;font-weight:500}.form-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-size:14px;font-family:var(--font-sans);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:10px 14px}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #0ea5e926}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.login-button{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff;border-radius:var(--radius-md);width:100%;font-size:14px;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);border:none;justify-content:center;align-items:center;min-height:44px;padding:12px;display:flex}.login-button:hover:not(:disabled){background:linear-gradient(135deg, var(--color-primary-light), var(--color-primary));transform:translateY(-1px);box-shadow:0 4px 16px #0ea5e94d}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;color:var(--text-secondary);margin-top:24px;font-size:13px}.login-link{color:var(--color-primary);font-weight:500}.register-trial-info{border-radius:var(--radius-md);color:var(--color-primary-light);background:#0ea5e914;border:1px solid #0ea5e926;align-items:center;gap:8px;padding:12px 16px;font-size:13px;display:flex}@keyframes cc-pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}@keyframes cc-spin-loader{to{transform:rotate(360deg)}}@keyframes cc-glow-pulse{0%,to{box-shadow:0 0 #00bcd400}50%{box-shadow:0 0 0 8px #00bcd414}}.cc-login-wrapper{background:#0b1120;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:flex}.cc-left-panel{background:linear-gradient(145deg,#0b1120 0%,#0d1b30 40%,#0a1528 100%);flex-direction:column;flex:50%;justify-content:space-between;min-height:100vh;padding:36px;display:flex;position:relative;overflow:hidden}.cc-right-panel{background:#0f1923;flex-direction:column;flex:50%;justify-content:center;align-items:center;min-height:100vh;padding:40px 24px;display:flex;position:relative}.cc-glass-card{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);z-index:1;background:#0d1b32d1;border:1px solid #00bcd424;border-radius:16px;width:100%;max-width:420px;padding:40px;animation:4s ease-in-out infinite cc-glow-pulse;position:relative;box-shadow:0 8px 40px #00000080}.cc-input:focus{outline:none;border-color:#00bcd4!important;box-shadow:0 0 0 3px #00bcd41f!important}.cc-btn-primary:hover:not(:disabled){filter:brightness(1.08)!important;transform:translateY(-1px)!important;box-shadow:0 0 28px #00bcd473!important}.cc-btn-secondary:hover{color:#e0e8f5!important;border-color:#00bcd4!important}.cc-eye-btn:hover{color:#00bcd4!important}.cc-forgot-link:hover{text-decoration:underline;color:#44d8f1!important}.cc-mobile-logo{align-items:center;gap:10px;margin-bottom:28px;display:none}.cc-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite cc-spin-loader;display:inline-block}.cc-fallback-spinner{border:2px solid #00bcd44d;border-top-color:#00bcd4;border-radius:50%;width:32px;height:32px;animation:.7s linear infinite cc-spin-loader}@media (min-width:768px) and (max-width:1023px){.cc-left-panel{flex:0 0 40%}.cc-right-panel{flex:60%;padding:32px 20px}.cc-glass-card{max-width:380px;padding:36px 32px}}@media (max-width:767px){.cc-login-wrapper{flex-direction:column}.cc-left-panel{display:none!important}.cc-right-panel{flex:100%;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:32px 16px}.cc-glass-card{border-radius:14px;max-width:100%;padding:28px 20px}.cc-mobile-logo{display:flex!important}}.login-features{flex-direction:column;gap:24px;max-width:320px;display:flex}.feature-item{align-items:flex-start;gap:16px;display:flex}.feature-icon{background:var(--bg-card);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.feature-item h3{color:var(--text-primary);margin-bottom:4px;font-size:15px;font-weight:600}.feature-item p{color:var(--text-secondary);font-size:13px;line-height:1.4}.dashboard-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-collapsed-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:50;transition:width var(--sidebar-transition), transform var(--transition);white-space:nowrap;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar:hover{width:var(--sidebar-width)}.sidebar-header{height:var(--header-height);border-bottom:1px solid var(--border);min-width:var(--sidebar-width);align-items:center;gap:12px;padding:0 20px;display:flex}.sidebar-logo{font-family:var(--font-heading);letter-spacing:-.03em;background:linear-gradient(135deg, var(--color-primary), var(--color-accent));-webkit-text-fill-color:transparent;opacity:0;transition:opacity var(--sidebar-transition);-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:700}.sidebar:hover .sidebar-logo{opacity:1}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px;display:flex;overflow:hidden auto}.nav-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;opacity:0;height:0;transition:opacity var(--sidebar-transition), height var(--sidebar-transition), padding var(--sidebar-transition);padding:0;font-size:11px;font-weight:600;overflow:hidden}.sidebar:hover .nav-section-title{opacity:1;height:auto;padding:16px 12px 8px}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition);cursor:pointer;min-width:var(--sidebar-width);box-sizing:border-box;padding:10px 12px;padding-left:calc((var(--sidebar-collapsed-width) - 24px - 20px) / 2);align-items:center;gap:12px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.sidebar:hover .nav-item{padding-left:12px}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{color:var(--color-primary);background:#0ea5e91f}.nav-item-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex;position:relative}.nav-item-label{opacity:0;transition:opacity var(--sidebar-transition)}.sidebar:hover .nav-item-label{opacity:1}.nav-item-badge-dot{background:var(--color-danger);width:8px;height:8px;transition:opacity var(--sidebar-transition);border-radius:50%;position:absolute;top:-2px;right:-4px}.sidebar:hover .nav-item-badge-dot{opacity:0}.nav-item-badge{color:var(--color-danger);opacity:0;transition:opacity var(--sidebar-transition);background:#ef444426;border-radius:999px;margin-left:auto;padding:2px 8px;font-size:11px;font-weight:600}.sidebar:hover .nav-item-badge{opacity:1}.sidebar-footer{border-top:1px solid var(--border);padding:12px}.sidebar-collapsible{opacity:0;max-height:0;transition:opacity var(--sidebar-transition), max-height var(--sidebar-transition);overflow:hidden}.sidebar:hover .sidebar-collapsible{opacity:1;max-height:200px}.sidebar-user{border-radius:var(--radius-md);transition:background var(--transition);cursor:pointer;min-width:var(--sidebar-width);box-sizing:border-box;padding:10px 12px;padding-left:calc((var(--sidebar-collapsed-width) - 24px - 36px) / 2);align-items:center;gap:12px;display:flex}.sidebar:hover .sidebar-user{padding-left:12px}.sidebar-user:hover{background:var(--bg-hover)}.sidebar-avatar{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.sidebar-user-info{opacity:0;min-width:0;transition:opacity var(--sidebar-transition);flex:1}.sidebar:hover .sidebar-user-info{opacity:1}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-muted);text-transform:capitalize;font-size:11px}.main-content{margin-left:var(--sidebar-collapsed-width);min-height:100vh;transition:margin-left var(--sidebar-transition);flex-direction:column;flex:1;display:flex}.main-header{height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:40;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.main-header-title{font-family:var(--font-heading);letter-spacing:-.01em;font-size:16px;font-weight:600}.main-header-actions{align-items:center;gap:12px;display:flex}.main-body{flex:1;padding:24px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);padding:24px}.stat-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.stat-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.stat-card-label{color:var(--text-secondary);font-size:13px;font-weight:500}.stat-card-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.stat-card-icon.blue{color:var(--color-primary);background:#0ea5e91f}.stat-card-icon.green{color:var(--color-success);background:#10b9811f}.stat-card-icon.yellow{color:var(--color-warning);background:#f59e0b1f}.stat-card-icon.red{color:var(--color-danger);background:#ef44441f}.stat-card-value{font-family:var(--font-heading);letter-spacing:-.03em;color:var(--text-primary);margin-bottom:4px;font-size:32px;font-weight:700;line-height:1}.stat-card-change{align-items:center;gap:4px;font-size:12px;display:flex}.stat-card-change.positive{color:var(--color-success)}.stat-card-change.negative{color:var(--color-danger)}.frota-section{border-top:1px solid var(--border);margin-top:8px;padding-top:24px}.frota-section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.frota-section-title{font-family:var(--font-heading);letter-spacing:-.01em;color:var(--text-primary);align-items:center;gap:8px;font-size:16px;font-weight:600;display:flex}.frota-tables-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.frota-tables-3col{grid-template-columns:repeat(3,1fr)}.compact-table-header{color:var(--text-primary);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:14px 16px;font-size:13px;font-weight:600;display:flex}.compact-table-empty{text-align:center;color:var(--text-muted);padding:24px;font-size:13px}.compact-table{border-collapse:collapse;width:100%;font-size:13px}.compact-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--border);padding:8px 12px;font-size:11px;font-weight:600}.compact-table td{border-bottom:1px solid var(--border);color:var(--text-primary);padding:8px 12px}.compact-table tr:last-child td{border-bottom:none}.compact-table tr:hover td{background:#0ea5e90a}.skeleton-line{background:linear-gradient(90deg, var(--bg-hover) 25%, var(--bg-input) 50%, var(--bg-hover) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite skeleton-pulse}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes icon-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-ghost{color:var(--text-muted);border-radius:var(--radius-md);background:0 0;border:none;padding:6px}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}@media (max-width:768px){.frota-tables-grid{grid-template-columns:1fr}}@media (min-width:769px) and (max-width:1200px){.frota-tables-3col{grid-template-columns:1fr 1fr}}.btn{border-radius:var(--radius-md);font-size:13px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);border:1px solid #0000;align-items:center;gap:8px;padding:8px 16px;line-height:1;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-light);box-shadow:0 2px 8px #0ea5e94d}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover{background:var(--bg-hover)}.btn-danger{color:var(--color-danger);background:#ef44441a;border-color:#ef444433}.btn-danger:hover{background:#ef444433}.select-trigger{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-size:14px;font-family:var(--font-sans);cursor:pointer;transition:border-color var(--transition), box-shadow var(--transition);outline:none;justify-content:space-between;align-items:center;gap:8px;min-height:42px;padding:10px 14px;line-height:1.4;display:inline-flex}.select-trigger:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #0ea5e926}.select-trigger:hover{border-color:var(--text-muted)}.select-trigger[data-disabled]{opacity:.5;cursor:not-allowed}.select-trigger[data-placeholder]>span:first-child{color:var(--text-muted)}.select-trigger-icon{color:var(--text-muted);flex-shrink:0}.select-content{z-index:100;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);min-width:8rem;max-height:320px;box-shadow:var(--shadow-lg);animation:.15s ease-out select-in;position:relative;overflow:hidden}@keyframes select-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.select-content-popper{width:var(--radix-select-trigger-width);max-height:var(--radix-select-content-available-height)}.select-viewport{padding:4px}.select-viewport-popper{height:var(--radix-select-content-available-height);width:100%}.select-scroll-button{cursor:default;height:28px;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.select-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:6px 8px 6px 32px;font-size:12px;font-weight:600}.select-item{border-radius:var(--radius-sm);width:100%;color:var(--text-primary);cursor:pointer;transition:background var(--transition);-webkit-user-select:none;user-select:none;outline:none;align-items:center;padding:8px 8px 8px 32px;font-size:14px;display:flex;position:relative}.select-item[data-disabled]{opacity:.5;pointer-events:none}.select-item[data-highlighted]{color:var(--color-primary);background:#0ea5e914}.select-item-indicator{width:16px;height:16px;color:var(--color-primary);justify-content:center;align-items:center;display:inline-flex;position:absolute;left:8px}.select-separator{background:var(--border);height:1px;margin:4px -4px}.searchable-select{width:100%;position:relative}.searchable-select .select-trigger-disabled{opacity:.5;cursor:not-allowed}.searchable-select-placeholder{color:var(--text-muted)}.searchable-select-chevron-open{transform:rotate(180deg)}.select-trigger-icon{transition:transform .15s}.searchable-select-dropdown{z-index:200;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-lg);animation:.15s ease-out select-in;position:absolute;top:calc(100% + 6px);left:0;overflow:hidden}.searchable-select-search-wrapper{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 12px;display:flex}.searchable-select-search-icon{color:var(--text-muted);flex-shrink:0}.searchable-select-search-input{color:var(--text-primary);font-size:13px;font-family:var(--font-sans);background:0 0;border:none;outline:none;flex:1}.searchable-select-search-input::placeholder{color:var(--text-muted)}.searchable-select-list{scroll-behavior:smooth;max-height:240px;padding:4px;overflow-y:auto}.searchable-select-list::-webkit-scrollbar{width:6px}.searchable-select-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.searchable-select-list::-webkit-scrollbar-track{background:0 0}.searchable-select-empty{text-align:center;color:var(--text-muted);padding:16px 12px;font-size:13px}.select-item-selected{font-weight:500}.select-item-highlighted{color:var(--color-primary);background:#0ea5e914!important}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding:12px 16px;font-size:12px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-primary);padding:12px 16px}.data-table tr:hover td{background:#0ea5e90a}.status-badge{border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.status-badge.online{color:var(--color-success);background:#10b9811f}.status-badge.offline{color:var(--text-muted);background:#64748b1f}.status-badge.moving{color:var(--color-primary);background:#0ea5e91f}.status-badge.warning{color:var(--color-warning);background:#f59e0b1f}.status-badge:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}@media (max-width:768px){.login-container{flex-direction:column;gap:40px;padding:20px}.login-features{display:none}.login-card{padding:24px}.form-row{grid-template-columns:1fr}.sidebar{width:var(--sidebar-width);transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar .sidebar-logo,.sidebar .nav-section-title,.sidebar .nav-item-label,.sidebar .nav-item-badge,.sidebar .sidebar-user-info,.sidebar .sidebar-collapsible{opacity:1}.sidebar .nav-section-title{height:auto;padding:16px 12px 8px;overflow:visible}.sidebar .sidebar-collapsible{max-height:200px}.sidebar .nav-item,.sidebar .sidebar-user{padding-left:12px}.sidebar .nav-item-badge-dot{display:none}.main-content{margin-left:0}.stats-grid{grid-template-columns:1fr}}.devices-count{color:var(--text-secondary);background:var(--bg-input);border-radius:999px;padding:4px 12px;font-size:13px}.devices-filters{gap:12px;margin-bottom:20px;display:flex}.devices-search{flex:1;max-width:400px}.devices-status-filter{cursor:pointer;width:200px}.devices-table-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.device-name-cell{flex-direction:column;gap:2px;display:flex}.device-model{color:var(--text-muted);font-size:12px}.device-imei{font-family:var(--font-mono);background:var(--bg-input);border-radius:var(--radius-sm);color:var(--text-secondary);padding:2px 8px;font-size:12px}.device-position-cell{flex-direction:column;gap:2px;display:flex}.device-address{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:200px;font-size:13px;overflow:hidden}.device-time{color:var(--text-muted);font-size:11px}.text-muted{color:var(--text-muted);font-size:13px}.device-actions{align-items:center;gap:6px;display:flex}.devices-pagination{justify-content:center;align-items:center;gap:16px;margin-top:20px;display:flex}.pagination-info{color:var(--text-secondary);font-size:13px}.devices-loading{color:var(--text-secondary);flex-direction:column;align-items:center;gap:12px;padding:80px 0;display:flex}.devices-empty{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:80px 0;display:flex}.devices-empty-icon{opacity:.6;font-size:48px}.devices-empty h3{color:var(--text-primary);font-size:18px}.devices-empty p{color:var(--text-secondary);max-width:300px;font-size:14px}.modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:520px;box-shadow:var(--shadow-lg), var(--shadow-glow);padding:32px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h2{font-size:20px;font-weight:600}.modal-close{width:32px;height:32px;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;font-size:18px;display:flex}.modal-form{flex-direction:column;gap:16px;display:flex}.modal-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.map-page{height:calc(100vh - var(--header-height));display:flex;position:relative;overflow:hidden}.map-page.map-fullscreen{z-index:100;height:100vh;position:fixed;inset:0}.dashboard-layout:has(.map-fullscreen) .sidebar{pointer-events:none;transform:translate(-100%)}.dashboard-layout:has(.map-fullscreen) .main-content{margin-left:0}.map-fullscreen-btn{z-index:15;-webkit-backdrop-filter:blur(8px);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:#0a0f1ecc;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;bottom:40px;right:12px;box-shadow:0 2px 8px #0000004d}.map-fullscreen-btn:hover{color:var(--color-primary);background:#0ea5e926;border-color:#0ea5e966;transform:scale(1.05)}.map-geofence-btn{z-index:15;-webkit-backdrop-filter:blur(8px);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:#0a0f1ecc;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;bottom:82px;right:12px;box-shadow:0 2px 8px #0000004d}.map-geofence-btn:hover{color:var(--color-primary);background:#0ea5e926;border-color:#0ea5e966;transform:scale(1.05)}.map-geofence-btn.active{color:var(--color-primary);background:#0ea5e933;border-color:#0ea5e980;box-shadow:0 0 12px #0ea5e940}.map-geofence-btn-spinner{border:2px solid #0000;border-top-color:var(--color-primary);border-radius:50%;width:10px;height:10px;animation:.8s linear infinite spin;position:absolute;top:-3px;right:-3px}.map-pin-search{z-index:15;align-items:center;gap:0;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;bottom:124px;right:12px}.map-pin-search-btn{-webkit-backdrop-filter:blur(8px);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;z-index:2;background:#0a0f1ecc;border:1px solid #ffffff1a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000004d}.map-pin-search-btn:hover{color:var(--color-primary);background:#0ea5e926;border-color:#0ea5e966;transform:scale(1.05)}.map-pin-search.expanded .map-pin-search-btn{color:var(--color-primary);background:#0ea5e933;border-color:#0ea5e980;border-radius:8px 0 0 8px;transform:none;box-shadow:0 0 12px #0ea5e940}.map-pin-search-field{opacity:0;-webkit-backdrop-filter:blur(12px);background:#0a0f1ee0;border:1px solid #ffffff1a;border-left:none;border-radius:0 8px 8px 0;align-items:center;width:0;padding:0;transition:width .3s cubic-bezier(.4,0,.2,1),opacity .2s 50ms,padding .3s;display:flex;overflow:hidden}.map-pin-search.expanded .map-pin-search-field{opacity:1;border-color:#0ea5e94d;width:220px;padding:0 8px 0 4px}.map-pin-search-input{width:100%;height:34px;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);background:0 0;border:none;outline:none;padding:0 4px}.map-pin-search-input::placeholder{color:var(--text-muted);font-size:12px}.map-pin-search-clear{width:22px;height:22px;color:var(--text-muted);cursor:pointer;background:#ffffff14;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.map-pin-search-clear:hover{color:#ef4444;background:#ef444433}.map-pin-search-count{color:#fff;background:var(--color-primary);white-space:nowrap;pointer-events:none;border-radius:999px;padding:1px 6px;font-size:10px;font-weight:700;animation:.2s fadeIn;position:absolute;top:-8px;right:-4px;box-shadow:0 2px 6px #0ea5e966}.geofence-map-label{pointer-events:none;align-items:center;gap:4px;display:flex}.geofence-map-label-text{-webkit-backdrop-filter:blur(6px);border:1px solid #ffffff14;border-left:3px solid var(--geofence-color,#3b82f6);color:#ffffffeb;white-space:nowrap;letter-spacing:.2px;text-shadow:0 1px 2px #00000080;background:#0a0f1ed1;border-radius:6px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block;box-shadow:0 2px 8px #0000004d}.map-area{flex:1;position:relative}.map-wrapper{width:100%;height:100%;position:relative}.map-canvas{width:100%;height:100%}.map-loading{background:var(--bg-primary);color:var(--text-secondary);z-index:10;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:absolute;inset:0}.map-controls-wrapper{z-index:20;flex-shrink:0;width:300px;transition:width .3s cubic-bezier(.4,0,.2,1),margin-left .3s cubic-bezier(.4,0,.2,1),opacity .25s;overflow:hidden}.map-controls-wrapper:not(.open){width:0;overflow:hidden}.map-controls-panel{background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;height:100%;display:flex}.map-controls-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;padding:16px 16px 16px 20px;display:flex}.map-controls-header h3{white-space:nowrap;font-size:16px;font-weight:600}.map-controls-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.map-controls-count{color:var(--color-success);white-space:nowrap;background:#10b9811a;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:500}.map-controls-collapse-btn{border:1px solid var(--border);border-radius:var(--radius-sm);width:30px;height:30px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.map-controls-collapse-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted)}.map-controls-expand-btn{z-index:25;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-md);width:40px;height:40px;color:var(--text-primary);cursor:pointer;transition:all var(--transition);background:#111827e0;justify-content:center;align-items:center;display:flex;position:absolute;top:12px;left:12px;box-shadow:0 2px 8px #0003}.map-controls-expand-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#111827f2;box-shadow:0 2px 12px #0ea5e933}.map-device-search{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 12px;display:flex}.map-device-search-icon{color:var(--text-muted);flex-shrink:0}.map-device-search-input{width:100%;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);background:0 0;border:none;outline:none}.map-device-search-input::placeholder{color:var(--text-muted)}.map-status-tabs{border-bottom:1px solid var(--border);gap:2px;padding:8px 12px;display:flex}.map-status-tab{color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);font-size:12px;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;flex:1;padding:6px 8px}.map-status-tab:hover{background:var(--bg-hover)}.map-status-tab.active{color:var(--color-primary);background:#0ea5e91f}.map-device-list{flex:1;padding:4px 8px;overflow-y:auto}.map-device-item{border-radius:var(--radius-md);cursor:pointer;width:100%;transition:all var(--transition);text-align:left;color:var(--text-primary);font-family:var(--font-sans);background:0 0;border:none;align-items:center;gap:12px;padding:10px 12px;display:flex}.map-device-item:hover{background:var(--bg-hover)}.map-device-item.selected{border-left:3px solid var(--color-primary);background:#0ea5e91a}.map-device-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.map-device-info{flex-direction:column;min-width:0;display:flex}.map-device-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.map-device-detail{color:var(--text-muted);font-size:11px}.map-device-empty{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:13px}.map-device-section{padding-bottom:4px}.map-device-section+.map-device-section{border-top:1px solid var(--border)}.map-device-section-header{z-index:2;background:var(--bg-primary);color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;align-items:center;gap:6px;padding:8px 14px 6px;font-size:11px;font-weight:600;display:flex;position:sticky;top:0}.map-device-section-header--checklist{color:#22c55e;background:linear-gradient(180deg, #22c55e14 0%, var(--bg-primary) 100%);border-bottom:1px solid #22c55e1f}.map-device-section-count{min-width:20px;height:18px;color:var(--text-muted);background:#ffffff0f;border-radius:999px;justify-content:center;align-items:center;margin-left:auto;padding:0 6px;font-size:10px;font-weight:700;display:inline-flex}.map-device-section-count--checklist{color:#22c55e;background:#22c55e26}.map-device-item--checklist{border-left:2px solid #22c55e59}.map-device-item--checklist.selected{border-left:3px solid #22c55e}.map-device-checklist-badge{color:#22c55e;background:#22c55e1f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-left:auto;display:flex}.map-controls-actions{border-top:1px solid var(--border);gap:8px;padding:12px;display:flex}.map-controls-footer{color:var(--text-muted);border-top:1px solid var(--border);text-align:center;padding:8px 16px;font-size:11px}.map-controls-toggle{display:none}.map-advanced-filters{border-bottom:1px solid var(--border)}.map-advanced-filters-toggle{width:100%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:12px;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;align-items:center;gap:8px;padding:10px 16px;display:flex}.map-advanced-filters-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.map-advanced-filters-toggle span{text-align:left;flex:1}.map-advanced-filters-badge{background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex}.map-advanced-filters-body{flex-direction:column;gap:14px;padding:8px 16px 16px;animation:.2s slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.map-filter-group{flex-direction:column;gap:6px;display:flex}.map-filter-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;align-items:center;gap:4px;font-size:11px;font-weight:600;display:flex}.map-filter-checkboxes{flex-wrap:wrap;gap:4px;display:flex}.map-filter-checkbox{color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:6px;padding:5px 10px;font-size:11px;font-weight:500;display:flex}.map-filter-checkbox input[type=checkbox]{display:none}.map-filter-checkbox-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.map-filter-checkbox.checked{color:var(--color-primary);background:#0ea5e91f;border-color:#0ea5e966}.map-filter-checkbox:hover{background:var(--bg-hover);border-color:var(--text-muted)}.map-filter-speed-range{align-items:center;gap:8px;display:flex}.map-filter-speed-input{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:12px;font-family:var(--font-sans);transition:border-color var(--transition);-moz-appearance:textfield;outline:none;flex:1;padding:6px 10px}.map-filter-speed-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.map-filter-speed-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.map-filter-speed-input:focus{border-color:var(--color-primary)}.map-filter-speed-input::placeholder{color:var(--text-muted)}.map-filter-speed-sep{color:var(--text-muted);font-size:12px}.map-filter-select{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:12px;font-family:var(--font-sans);cursor:pointer;transition:border-color var(--transition);outline:none;width:100%;padding:6px 10px}.map-filter-select:focus{border-color:var(--color-primary)}.map-filter-toggle-row{color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;padding:4px 0;font-size:12px;display:flex}.map-filter-toggle-row input[type=checkbox]{width:14px;height:14px;accent-color:var(--color-primary);cursor:pointer}.map-filter-checklist-count{color:#22c55e;background:#22c55e26;border-radius:999px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:auto;padding:0 5px;font-size:10px;font-weight:700;display:inline-flex}.map-filter-chips{z-index:16;-webkit-backdrop-filter:blur(12px);background:#0a0f1ee0;border:1px solid #ffffff14;border-radius:999px;align-items:center;gap:8px;max-width:calc(100% - 80px);padding:6px 12px;animation:.25s fadeSlideIn;display:flex;position:absolute;top:12px;left:50%;transform:translate(-50%)}@keyframes fadeSlideIn{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.map-filter-chips-list{scrollbar-width:none;align-items:center;gap:6px;display:flex;overflow-x:auto}.map-filter-chips-list::-webkit-scrollbar{display:none}.map-filter-chip{color:#ffffffe6;cursor:pointer;white-space:nowrap;font-size:11px;font-family:var(--font-sans);background:#0ea5e926;border:1px solid #0ea5e94d;border-radius:999px;align-items:center;gap:4px;padding:4px 10px;transition:all .15s;display:flex}.map-filter-chip:hover{background:#ef444433;border-color:#ef444480}.map-filter-chip-label{color:#0ea5e9e6;font-weight:600}.map-filter-chip-value{font-weight:400}.map-filter-clear-all{color:#ef4444e6;cursor:pointer;white-space:nowrap;font-size:11px;font-weight:500;font-family:var(--font-sans);background:#ef44441f;border:1px solid #ef44444d;border-radius:999px;padding:4px 10px;transition:all .15s}.map-filter-clear-all:hover{background:#ef444440;border-color:#ef444499}.map-stats-overlay{z-index:15;-webkit-backdrop-filter:blur(12px);background:#0a0f1ee0;border:1px solid #ffffff14;border-radius:12px;padding:8px 14px;animation:.3s fadeIn;position:absolute;top:12px;right:12px;box-shadow:0 2px 12px #0000004d}.map-stats-row{align-items:center;gap:10px;display:flex}.map-stat-item{color:var(--text-secondary);align-items:center;gap:4px;font-size:12px;display:flex}.map-stat-item.alert{color:#ef4444}.map-stat-item.orders{color:#f97316}.map-stat-value{color:#ffffffe6;font-size:13px;font-weight:600}.map-stat-item.alert .map-stat-value{color:#ef4444}.map-stat-item.orders .map-stat-value{color:#f97316}.map-stat-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.map-stat-divider{background:#ffffff1a;width:1px;height:16px}.marker-alert-badge{z-index:5;background:#ef4444;border:2px solid #0006;border-radius:50%;width:10px;height:10px;animation:1.5s infinite alertPulse;position:absolute;top:-2px;right:-2px}@keyframes alertPulse{0%,to{box-shadow:0 0 #ef444499}50%{box-shadow:0 0 0 6px #ef444400}}.device-map-marker.has-alert .marker-dot{box-shadow:0 0 8px #ef444466,0 2px 8px #0000004d}.marker-checklist-badge{z-index:6;background:#22c55e;border:2px solid #0000004d;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;animation:.3s cubic-bezier(.34,1.56,.64,1) checklistBadgeAppear;display:flex;position:absolute;top:-4px;left:-4px;box-shadow:0 1px 4px #22c55e80}@keyframes checklistBadgeAppear{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.device-map-marker.has-checklist .marker-dot{box-shadow:0 0 8px #22c55e4d,0 2px 8px #0000004d}.marker-checklist-tooltip{-webkit-backdrop-filter:blur(16px);z-index:20;pointer-events:none;opacity:0;min-width:200px;font-family:var(--font-sans);background:#0a0f1eeb;border:1px solid #22c55e40;border-radius:10px;padding:10px 12px;transition:opacity .2s,transform .2s;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%)translateY(4px);box-shadow:0 4px 20px #0006,0 0 12px #22c55e1a}.device-map-marker:hover .marker-checklist-tooltip{opacity:1;transform:translate(-50%)translateY(0)}.marker-checklist-tooltip:after{content:"";background:#0a0f1eeb;border-bottom:1px solid #22c55e40;border-right:1px solid #22c55e40;width:10px;height:10px;position:absolute;bottom:-5px;left:50%;transform:translate(-50%)rotate(45deg)}.marker-checklist-tooltip-header{color:#22c55e;letter-spacing:.02em;border-bottom:1px solid #ffffff14;align-items:center;gap:6px;margin-bottom:8px;padding-bottom:6px;font-size:11px;font-weight:600;display:flex}.marker-checklist-tooltip-row{justify-content:space-between;align-items:center;gap:12px;padding:2px 0;display:flex}.marker-checklist-tooltip-label{color:#ffffff80;font-size:11px}.marker-checklist-tooltip-value{color:#ffffffe6;font-size:12px;font-weight:500}.marker-checklist-tooltip-critical{color:#ef4444;border-top:1px solid #ef444433;align-items:center;gap:5px;margin-top:6px;padding-top:6px;font-size:11px;font-weight:500;display:flex}.map-status-bar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);color:var(--text-secondary);z-index:15;background:#111827e6;border-radius:999px;align-items:center;gap:12px;padding:8px 20px;font-size:13px;display:flex;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}.map-status-loading{color:var(--color-primary);animation:1.5s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.cluster-marker{animation:.25s cubic-bezier(.34,1.56,.64,1) clusterAppear}@keyframes clusterAppear{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.cluster-marker-inner{-webkit-backdrop-filter:blur(10px);background:#0a0f1ee0;border:2px solid #ffffff26;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 16px #0006,0 0 0 1px #ffffff0d}.cluster-marker:hover .cluster-marker-inner{border-color:#0ea5e966;transform:scale(1.1);box-shadow:0 6px 24px #00000080,0 0 20px #0ea5e933}.cluster-marker-count{color:#fff;font-size:14px;font-weight:700;line-height:1;font-family:var(--font-sans)}.cluster-marker-breakdown{gap:3px;margin-top:2px;display:flex}.cluster-status-dot{color:#fff;font-size:8px;font-weight:600;line-height:1.2;font-family:var(--font-sans);border-radius:999px;padding:1px 4px}.cluster-sm .cluster-marker-inner{width:40px;height:40px}.cluster-sm .cluster-marker-count{font-size:13px}.cluster-sm .cluster-status-dot{padding:0 3px;font-size:7px}.cluster-md .cluster-marker-inner{width:52px;height:52px}.cluster-md .cluster-marker-count{font-size:15px}.cluster-lg .cluster-marker-inner{width:64px;height:64px}.cluster-lg .cluster-marker-count{font-size:18px}.cluster-lg .cluster-marker-breakdown{gap:4px;margin-top:3px}.device-map-marker{cursor:pointer;justify-content:center;align-items:center;width:28px;height:28px;display:flex;position:relative}.marker-dot{z-index:2;border:2px solid #fffc;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:transform .2s;display:flex;box-shadow:0 2px 8px #0000004d}.device-map-marker:hover .marker-dot{transform:scale(1.15)}.device-map-marker.selected .marker-dot{box-shadow:0 0 12px var(--marker-color,#0ea5e9);border-color:#fff;transform:scale(1.25)}.marker-pulse{z-index:1;border-radius:50%;width:28px;height:28px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.device-map-marker.moving .marker-pulse{background:var(--marker-color,#22c55e);animation:2s infinite markerPulse}.device-map-marker.stopped .marker-pulse{background:var(--marker-color,#eab308);animation:3s infinite markerPulse}@keyframes markerPulse{0%{opacity:.6;width:28px;height:28px}to{opacity:0;width:56px;height:56px}}.marker-label{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-sm);color:#fff;white-space:nowrap;z-index:2;pointer-events:none;background:#111827d9;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:500;position:absolute;top:100%;left:50%;transform:translate(-50%)}.device-popup-container .maplibregl-popup-content{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);color:var(--text-primary);background:#1a2332f2;padding:0}.device-popup-container .maplibregl-popup-close-button{color:var(--text-muted);padding:8px 12px;font-size:18px}.device-popup-container .maplibregl-popup-close-button:hover{color:var(--text-primary);background:0 0}.device-popup-container .maplibregl-popup-tip{border-top-color:#1a2332f2}.device-popup{min-width:260px}.device-popup-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 16px 12px;display:flex}.device-popup-header h3{font-size:15px;font-weight:600}.device-popup-body{flex-direction:column;gap:8px;padding:12px 16px 16px;display:flex}.popup-row{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.popup-label{color:var(--text-muted);flex-shrink:0;font-size:12px}.popup-value{text-align:right;color:var(--text-primary);font-size:13px}.popup-address{text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.popup-coords{font-family:var(--font-mono);color:var(--text-secondary);font-size:11px}@media (max-width:768px){.map-controls-wrapper{z-index:30;width:280px;transition:transform .3s cubic-bezier(.4,0,.2,1);position:absolute;top:0;bottom:0;left:0;transform:translate(-100%)}.map-controls-wrapper:not(.open){width:280px;transform:translate(-100%)}.map-controls-wrapper.open{width:280px;transform:translate(0)}.map-controls-expand-btn{top:12px;left:64px}.devices-filters{flex-direction:column}.devices-search{max-width:100%}.devices-status-filter{width:100%}.modal-content{margin:16px;padding:24px}}.geofence-page{height:calc(100vh - var(--header-height));flex-direction:column;display:flex}.geofence-page-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.geofence-page-title{font-family:var(--font-heading);letter-spacing:-.02em;font-size:22px;font-weight:700}.geofence-page-subtitle{color:var(--text-secondary);margin-top:2px;font-size:13px}.geofence-layout{flex:1;min-height:0;display:flex}.geofence-sidebar{border-right:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;width:360px;overflow-y:auto}.geofence-map-area{flex:1;position:relative}.geofence-list{flex-direction:column;height:100%;display:flex}.geofence-list-search{border-bottom:1px solid var(--border);padding:12px}.geofence-search-input{font-size:13px}.geofence-list-loading{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.geofence-empty{text-align:center;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.geofence-empty-icon{opacity:.3;margin-bottom:12px;font-size:48px}.geofence-empty-hint{color:var(--text-muted);margin-top:4px;font-size:12px}.geofence-items{flex:1;padding:8px;overflow-y:auto}.geofence-item{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);border:1px solid #0000;margin-bottom:4px;padding:14px}.geofence-item:hover{background:var(--bg-hover)}.geofence-item.selected{background:#0ea5e914;border-color:#0ea5e94d}.geofence-item.inactive{opacity:.5}.geofence-item-header{align-items:center;gap:10px;margin-bottom:4px;display:flex}.geofence-color-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px;box-shadow:0 0 6px #0000004d}.geofence-item-name{color:var(--text-primary);flex:1;font-size:14px;font-weight:600}.geofence-inactive-badge{color:var(--text-muted);background:#64748b1f;border-radius:999px;padding:2px 6px;font-size:10px}.geofence-item-desc{color:var(--text-secondary);margin-bottom:8px;font-size:12px;line-height:1.4}.geofence-item-footer{justify-content:space-between;align-items:center;display:flex}.geofence-device-count{color:var(--text-muted);font-size:12px}.geofence-item-actions{opacity:0;transition:opacity var(--transition);gap:4px;display:flex}.geofence-item:hover .geofence-item-actions{opacity:1}.geofence-action-btn{border-radius:var(--radius-sm);cursor:pointer;width:28px;height:28px;transition:background var(--transition);background:0 0;border:none;justify-content:center;align-items:center;font-size:14px;display:flex}.geofence-action-btn:hover{background:var(--bg-input)}.geofence-action-btn.danger:hover{background:#ef444426}.geofence-form{flex-direction:column;gap:16px;padding:20px;display:flex}.geofence-form-title{color:var(--text-primary);border-bottom:1px solid var(--border);padding-bottom:12px;font-size:16px;font-weight:700}.geofence-color-picker{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.geofence-color-swatch{cursor:pointer;width:28px;height:28px;transition:all var(--transition);border:2px solid #0000;border-radius:50%;box-shadow:0 1px 3px #0000004d}.geofence-color-swatch:hover{transform:scale(1.15)}.geofence-color-swatch.active{box-shadow:0 0 0 2px var(--color-primary), 0 1px 3px #0000004d;border-color:#fff}.geofence-color-custom{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:50%;width:28px;height:28px;padding:0}.geofence-draw-buttons{gap:8px;display:flex}.geofence-draw-btn{flex:1;justify-content:center;font-size:12px}.geofence-area-indicator{color:var(--color-success);margin-top:4px;font-size:12px}.field-error{color:var(--color-danger);font-size:12px}.input-error{border-color:var(--color-danger)!important}.geofence-device-selector{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-input);max-height:200px;overflow-y:auto}.geofence-device-option{cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 12px;display:flex}.geofence-device-option:last-child{border-bottom:none}.geofence-device-option:hover{background:var(--bg-hover)}.geofence-device-option.selected{background:#0ea5e90f}.geofence-device-checkbox{accent-color:var(--color-primary)}.geofence-device-info{flex:1;min-width:0}.geofence-device-name{color:var(--text-primary);font-size:13px;font-weight:500;display:block}.geofence-device-plate{color:var(--text-muted);font-size:11px;display:block}.geofence-form-actions{border-top:1px solid var(--border);gap:8px;padding-top:12px;display:flex}.geofence-form-actions .btn{flex:1;justify-content:center}.geofence-map-wrapper{width:100%;height:100%;position:relative}.geofence-map-canvas{width:100%;height:100%}.geofence-draw-hint{background:var(--bg-card);border:1px solid var(--color-primary);border-radius:var(--radius-md);color:var(--color-primary-light);box-shadow:var(--shadow-md);z-index:10;white-space:nowrap;padding:8px 16px;font-size:13px;animation:.3s fadeInDown;position:absolute;top:12px;left:50%;transform:translate(-50%)}@keyframes fadeInDown{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.geofence-radius-badge{background:var(--bg-card);border:1px solid var(--color-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:10;align-items:center;gap:6px;padding:6px 16px;animation:.2s fadeInDown;display:flex;position:absolute;bottom:40px;left:50%;transform:translate(-50%)}.geofence-radius-value{color:var(--color-primary-light);font-variant-numeric:tabular-nums;letter-spacing:-.2px;font-size:15px;font-weight:700}.geofence-radius-editor{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);margin-top:10px;padding:12px}.geofence-radius-label{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:8px;font-size:12px;font-weight:600;display:flex}.geofence-radius-input-group{align-items:center;gap:8px;margin-bottom:8px;display:flex}.geofence-radius-input{font-variant-numeric:tabular-nums;text-align:center;width:100px;font-size:14px;font-weight:600}.geofence-radius-unit{color:var(--text-muted);font-size:12px;font-weight:500}.geofence-radius-slider{appearance:none;background:var(--border);cursor:pointer;border-radius:3px;outline:none;width:100%;height:6px;margin-bottom:4px}.geofence-radius-slider::-webkit-slider-thumb{appearance:none;background:var(--color-primary);cursor:pointer;border-radius:50%;width:18px;height:18px;transition:transform .15s;box-shadow:0 1px 4px #0000004d}.geofence-radius-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.geofence-radius-slider::-moz-range-thumb{background:var(--color-primary);cursor:pointer;border:none;border-radius:50%;width:18px;height:18px;box-shadow:0 1px 4px #0000004d}.geofence-radius-range-labels{color:var(--text-muted);justify-content:space-between;font-size:10px;display:flex}.geofence-error-close{color:currentColor;cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0 4px;font-size:14px}@media (max-width:768px){.geofence-layout{flex-direction:column}.geofence-sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;max-height:40vh}.geofence-map-area{min-height:50vh}.geofence-page-header{flex-direction:column;align-items:flex-start;gap:12px}}.alerts-tabs{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);gap:2px;width:fit-content;margin-bottom:20px;padding:4px;display:flex}.alerts-tab{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:14px;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;align-items:center;gap:8px;padding:10px 20px;display:flex}.alerts-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.alerts-tab.active{color:var(--color-primary);background:#0ea5e91f}.alerts-tab-badge{color:var(--color-danger);text-align:center;background:#ef444426;border-radius:999px;min-width:20px;padding:1px 7px;font-size:11px;font-weight:600}.alerts-filters{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.alerts-search{flex:1;min-width:200px;max-width:320px}.alerts-type-filter,.alerts-read-filter{cursor:pointer;width:180px}.alerts-list{flex-direction:column;gap:8px;display:flex}.alert-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);align-items:flex-start;gap:14px;padding:16px 20px;display:flex;position:relative}.alert-card:hover{border-color:#0ea5e94d}.alert-card.unread{border-left:3px solid var(--color-primary);background:#0ea5e90a}.alert-card.unread.critical{border-left-color:var(--color-danger);background:#ef44440a}.alert-card.unread.warning{border-left-color:var(--color-warning);background:#f59e0b0a}.alert-card-icon{background:var(--bg-input);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:22px;display:flex}.alert-card-body{flex:1;min-width:0}.alert-card-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:4px;display:flex}.alert-card-type{text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted);font-size:11px;font-weight:600}.alert-fence-name{text-transform:none;color:var(--color-primary-light);letter-spacing:0;font-weight:500}.alert-card-time{color:var(--text-muted);flex-shrink:0;font-size:12px}.alert-card-message{color:var(--text-primary);margin-bottom:4px;font-size:14px;line-height:1.5}.alert-card.unread .alert-card-message{font-weight:500}.alert-card-device{color:var(--text-secondary);font-size:12px}.alert-card-actions{opacity:0;transition:opacity var(--transition);flex-shrink:0;gap:4px;display:flex}.alert-card:hover .alert-card-actions{opacity:1}.alert-action-btn{border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;transition:background var(--transition);background:0 0;border:none;justify-content:center;align-items:center;font-size:16px;display:flex}.alert-action-btn:hover{background:var(--bg-input)}.alert-action-btn.danger:hover{background:#ef444426}.alerts-loading{color:var(--text-secondary);flex-direction:column;align-items:center;gap:12px;padding:80px 0;display:flex}.alerts-empty{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:80px 0;display:flex}.alerts-empty-icon{opacity:.4;font-size:48px}.alerts-empty h3{color:var(--text-primary);font-size:18px}.alerts-empty p{color:var(--text-secondary);max-width:400px;font-size:14px}.rules-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.rule-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);padding:20px}.rule-card:hover{box-shadow:var(--shadow-glow);border-color:#0ea5e94d}.rule-card.inactive{opacity:.5}.rule-card-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.rule-card-name{color:var(--text-primary);margin-bottom:4px;font-size:15px;font-weight:600}.rule-card-type{color:var(--text-secondary);font-size:13px}.rule-card-status{flex-shrink:0}.rule-toggle{background:var(--bg-input);border:1px solid var(--border);cursor:pointer;width:44px;height:24px;transition:all var(--transition);border-radius:12px;padding:0;position:relative}.rule-toggle.active{background:var(--color-primary);border-color:var(--color-primary)}.rule-toggle-knob{width:18px;height:18px;transition:transform var(--transition);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0000004d}.rule-toggle.active .rule-toggle-knob{transform:translate(20px)}.rule-card-channels{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.rule-channel{background:var(--bg-input);color:var(--text-secondary);border-radius:999px;padding:3px 10px;font-size:12px}.rule-card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:12px;display:flex}.rule-card-date{color:var(--text-muted);font-size:12px}.alerts-notify-options{flex-direction:column;gap:8px;display:flex}.alerts-notify-checkboxes{gap:20px;display:flex}.alerts-checkbox-label{color:var(--text-primary);cursor:pointer;align-items:center;gap:8px;font-size:14px;display:flex}.alerts-checkbox-label input[type=checkbox]{accent-color:var(--color-primary);width:16px;height:16px}@media (max-width:768px){.alerts-filters{flex-direction:column}.alerts-search,.alerts-type-filter,.alerts-read-filter{width:100%;max-width:100%}.alerts-tabs{width:100%}.alerts-tab{flex:1;justify-content:center}.rules-grid{grid-template-columns:1fr}.alert-card-actions{opacity:1}}.billing-page{flex-direction:column;gap:32px;display:flex}.billing-loading{min-height:400px;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.billing-section{flex-direction:column;gap:16px;display:flex}.billing-section-title{font-family:var(--font-heading);letter-spacing:-.015em;color:var(--text-primary);font-size:20px;font-weight:700}.billing-section-subtitle{color:var(--text-secondary);margin-top:-8px;font-size:14px}.billing-banner{border-radius:var(--radius-lg);align-items:center;gap:12px;padding:14px 20px;font-size:14px;font-weight:500;animation:.3s ease-out billing-banner-in;display:flex}@keyframes billing-banner-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.billing-banner--success{color:var(--color-success);background:#10b9811a;border:1px solid #10b98140}.billing-banner--canceled{color:var(--color-primary-light);background:#0ea5e914;border:1px solid #0ea5e926}.billing-banner-close{color:inherit;cursor:pointer;opacity:.6;transition:opacity var(--transition);background:0 0;border:none;margin-left:auto;padding:4px;font-size:14px}.billing-banner-close:hover{opacity:1}.plan-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:999px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.plan-badge--free{color:var(--text-secondary);background:#64748b26}.plan-badge--pro{color:var(--color-primary-light);background:#0ea5e926}.plan-badge--enterprise{color:var(--color-warning);background:#f59e0b26}.plan-badge-trial{color:var(--color-warning);background:#f59e0b33;border-radius:999px;padding:1px 6px;font-size:10px}.subscription-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);flex-direction:column;gap:20px;padding:28px;display:flex}.subscription-card:hover{box-shadow:var(--shadow-glow);border-color:#0ea5e933}.subscription-card-header{justify-content:space-between;align-items:center;display:flex}.subscription-card-title{align-items:center;gap:12px;display:flex}.subscription-card-title h3{font-size:18px;font-weight:600}.sub-status-badge{border-radius:999px;padding:4px 12px;font-size:12px;font-weight:500}.sub-status--active{color:var(--color-success);background:#10b9811f}.sub-status--trialing{color:var(--color-warning);background:#f59e0b1f}.sub-status--past-due{color:var(--color-danger);background:#ef44441f}.sub-status--canceled,.sub-status--unpaid,.sub-status--incomplete{color:var(--text-muted);background:#64748b1f}.subscription-trial-banner{border-radius:var(--radius-md);color:var(--color-warning);background:#f59e0b14;border:1px solid #f59e0b26;align-items:center;gap:10px;padding:12px 16px;font-size:13px;display:flex}.subscription-trial-icon{font-size:18px}.subscription-usage{flex-direction:column;gap:8px;display:flex}.subscription-usage-header{justify-content:space-between;align-items:center;display:flex}.subscription-usage-label{color:var(--text-secondary);font-size:13px;font-weight:500}.subscription-usage-count{color:var(--text-primary);font-size:14px;font-weight:600;font-family:var(--font-mono)}.subscription-usage-bar{background:var(--bg-input);border-radius:999px;height:8px;overflow:hidden}.subscription-usage-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-accent));border-radius:999px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.subscription-usage-fill--warning{background:linear-gradient(90deg, var(--color-warning), #f97316)}.subscription-usage-fill--danger{background:linear-gradient(90deg, var(--color-danger), #f87171)}.subscription-usage-limit{color:var(--color-danger);margin-top:2px;font-size:12px}.subscription-renewal{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:12px;display:flex}.subscription-renewal-label{color:var(--text-secondary);font-size:13px}.subscription-renewal-date{color:var(--text-primary);font-size:14px;font-weight:500}.subscription-card-actions{gap:12px;padding-top:4px;display:flex}.pricing-grid{grid-template-columns:repeat(3,1fr);align-items:start;gap:20px;display:grid}.pricing-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);flex-direction:column;gap:24px;padding:32px 28px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.pricing-card:hover{box-shadow:0 12px 40px #0000004d, var(--shadow-glow);border-color:#0ea5e94d;transform:translateY(-4px)}.pricing-card--popular{border-color:var(--color-primary);box-shadow:0 0 30px #0ea5e91f}.pricing-card--popular:hover{box-shadow:0 12px 40px #0000004d,0 0 40px #0ea5e933}.pricing-card--current{border-color:var(--color-success)}.pricing-popular-badge{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));color:#fff;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-radius:999px;padding:4px 16px;font-size:11px;font-weight:700;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.pricing-current-badge{background:var(--color-success);color:#fff;border-radius:999px;padding:4px 12px;font-size:11px;font-weight:600;position:absolute;top:-12px;right:20px}.pricing-card-header{text-align:center}.pricing-card-name{color:var(--text-primary);margin-bottom:12px;font-size:20px;font-weight:700}.pricing-card-price{justify-content:center;align-items:baseline;gap:4px;margin-bottom:8px;display:flex}.pricing-card-amount{letter-spacing:-1px;color:var(--text-primary);font-size:36px;font-weight:800}.pricing-card-period{color:var(--text-muted);font-size:14px}.pricing-card-devices{color:var(--text-secondary);font-size:13px}.pricing-card-features{flex-direction:column;flex:1;gap:12px;list-style:none;display:flex}.pricing-feature-item{color:var(--text-secondary);align-items:center;gap:10px;font-size:14px;display:flex}.pricing-feature-check{color:var(--color-success);flex-shrink:0;font-size:14px;font-weight:700}.pricing-card-footer{margin-top:auto}.pricing-card-footer .btn{justify-content:center;width:100%;padding:12px;font-size:14px;font-weight:600}.invoice-container{flex-direction:column;gap:16px;display:flex}.invoice-empty{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.invoice-empty-icon{opacity:.5;margin-bottom:12px;font-size:36px}.invoice-empty p{color:var(--text-secondary);font-size:15px;font-weight:500}.invoice-empty-sub{margin-top:4px;color:var(--text-muted)!important;font-size:13px!important}.invoice-period{color:var(--text-secondary);font-size:13px}.invoice-status-badge{border-radius:999px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.invoice-status--paid{color:var(--color-success);background:#10b9811f}.invoice-status--open{color:var(--color-warning);background:#f59e0b1f}.invoice-status--draft{color:var(--text-muted);background:#64748b1f}.invoice-status--void,.invoice-status--uncollectible{color:var(--color-danger);background:#ef444414}.invoice-actions{gap:8px;display:flex}.invoice-action-btn{padding:4px 10px!important;font-size:12px!important}.invoice-pagination{justify-content:center;align-items:center;gap:16px;display:flex}.invoice-pagination-info{color:var(--text-secondary);font-size:13px}@media (max-width:1024px){.pricing-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}}@media (max-width:768px){.subscription-card-header{flex-direction:column;align-items:flex-start;gap:8px}.invoice-actions{flex-direction:column}.invoice-pagination{flex-direction:column;gap:8px}}.theme-toggle{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-input);cursor:pointer;width:36px;height:36px;transition:all var(--transition);color:var(--text-secondary);justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--bg-hover);border-color:var(--color-primary);color:var(--color-primary)}.theme-toggle-icon{justify-content:center;align-items:center;line-height:1;display:flex}.sidebar-footer-actions{justify-content:flex-end;align-items:center;padding:0 12px 8px;display:flex}.settings-grid{grid-template-columns:2fr 1fr;align-items:start;gap:24px;display:grid}@media (max-width:768px){.settings-grid{grid-template-columns:1fr}}.settings-card-title{font-family:var(--font-heading);letter-spacing:-.01em;align-items:center;gap:8px;margin-bottom:20px;font-size:16px;font-weight:600;display:flex}.settings-toast{border-radius:var(--radius-md);align-items:center;gap:8px;margin-bottom:16px;padding:12px 16px;font-size:13px;animation:.3s ease-out toast-in;display:flex}.settings-toast[data-type=success]{color:var(--color-success);background:#10b9811a;border:1px solid #10b98133}.settings-toast[data-type=error]{color:var(--color-danger);background:#ef44441a;border:1px solid #ef444433}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.settings-tabs{background:var(--surface-secondary);border-radius:var(--radius-md);gap:4px;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.settings-tab{color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.settings-tab:hover{color:var(--text-primary);background:var(--surface-hover)}.settings-tab.active{background:var(--surface-primary);color:var(--text-primary);box-shadow:0 1px 3px #00000026}.backup-settings-layout{grid-template-columns:1fr 1fr;align-items:start;gap:24px;display:grid}@media (max-width:960px){.backup-settings-layout{grid-template-columns:1fr}}.backup-toggle{background:var(--surface-secondary);border:1px solid var(--border);cursor:pointer;border-radius:12px;width:44px;height:24px;transition:all .2s;position:relative}.backup-toggle.active{background:var(--color-success);border-color:var(--color-success)}.backup-toggle-thumb{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003}.backup-toggle.active .backup-toggle-thumb{transform:translate(20px)}.backup-eye-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;transition:color .15s;position:absolute;top:8px;right:8px}.backup-eye-btn:hover{color:var(--text-primary)}.backup-history-list{flex-direction:column;gap:2px;display:flex}.backup-history-item{border-radius:var(--radius-sm);align-items:center;gap:12px;padding:10px 12px;transition:background .15s;display:flex}.backup-history-item:hover{background:var(--surface-hover)}.backup-history-status{flex-shrink:0}.backup-history-info{flex:1;min-width:0}.backup-history-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.backup-badge-ok,.backup-badge-error,.backup-badge-running{text-transform:uppercase;letter-spacing:.3px;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.backup-badge-ok{color:var(--color-success);background:#10b9811f}.backup-badge-error{color:var(--color-danger);background:#ef44441f}.backup-badge-running{color:var(--color-warning);background:#f59e0b1f}.backup-drive-link{color:var(--color-primary);border-radius:var(--radius-sm);align-items:center;gap:4px;padding:2px 8px;font-size:11px;text-decoration:none;transition:background .15s;display:inline-flex}.backup-drive-link:hover{background:#3b82f61a}.backup-guide-header{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:0;display:flex}.backup-guide-content{border-top:1px solid var(--border);margin-top:16px;padding-top:16px}.backup-guide-intro{color:var(--text-secondary);margin-bottom:20px;font-size:13px;line-height:1.5}.backup-guide-steps{flex-direction:column;gap:16px;display:flex}.backup-guide-step{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.backup-guide-step-header{align-items:flex-start;gap:12px;padding:12px 16px;display:flex}.backup-guide-step-number{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-top:1px;font-size:12px;font-weight:700;display:flex}.backup-guide-code-block{border-top:1px solid var(--border)}.backup-guide-code-header{background:var(--surface-secondary);color:var(--text-muted);justify-content:space-between;align-items:center;padding:6px 12px;font-size:11px;display:flex}.backup-guide-copy-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:11px;transition:all .15s;display:inline-flex}.backup-guide-copy-btn:hover{color:var(--text-primary);background:var(--surface-hover)}.backup-guide-code{background:var(--surface-secondary);font-family:var(--font-mono);margin:0;padding:12px 16px;font-size:12px;line-height:1.6;overflow-x:auto}.backup-guide-comment{color:var(--text-muted);font-style:italic}.backup-guide-empty{height:8px}.backup-guide-cmd{color:var(--text-primary)}.theme-selector{grid-template-columns:1fr 1fr;gap:12px;display:grid}.theme-option{background:var(--bg-input);border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);font-family:var(--font-sans);text-align:left;flex-direction:column;gap:10px;padding:12px;display:flex;position:relative}.theme-option:hover{border-color:var(--text-muted);background:var(--bg-hover)}.theme-option.active{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary), var(--shadow-glow);background:#0ea5e90f}.theme-option-preview{aspect-ratio:16/10;border-radius:var(--radius-sm);border:1px solid var(--border);width:100%;position:relative;overflow:hidden}.theme-option-preview[data-preview=light]{background:#f8fafc}.theme-option-preview[data-preview=dark]{background:#0b1120}.theme-preview-header{border-bottom:1px solid;height:18%;position:absolute;top:0;left:0;right:0}.theme-option-preview[data-preview=light] .theme-preview-header{background:#fff;border-color:#e2e8f0}.theme-option-preview[data-preview=dark] .theme-preview-header{background:#111827;border-color:#1e293b}.theme-preview-sidebar{border-right:1px solid;width:28%;position:absolute;top:18%;bottom:0;left:0}.theme-option-preview[data-preview=light] .theme-preview-sidebar{background:#fff;border-color:#e2e8f0}.theme-option-preview[data-preview=dark] .theme-preview-sidebar{background:#111827;border-color:#1e293b}.theme-preview-content{flex-direction:column;gap:6px;display:flex;position:absolute;top:28%;left:35%;right:10%}.theme-preview-line{border-radius:2px;width:100%;height:4px}.theme-preview-line.short{width:60%}.theme-option-preview[data-preview=light] .theme-preview-line{background:#e2e8f0}.theme-option-preview[data-preview=dark] .theme-preview-line{background:#1e293b}.theme-option-info{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:flex}.theme-option.active .theme-option-info{color:var(--color-primary)}.theme-option-label{font-weight:600}.theme-option-check{background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;animation:.2s ease-out check-pop;display:flex;position:absolute;top:8px;right:8px}@keyframes check-pop{0%{opacity:0;transform:scale(0)}70%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}.sidebar-hamburger{z-index:55;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:36px;height:36px;padding:8px;display:none;position:fixed;top:14px;left:16px}.hamburger-line{background:var(--text-primary);width:18px;height:2px;transition:all var(--transition);border-radius:1px;display:block}.sidebar-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;margin-left:auto;padding:4px;font-size:18px;display:none}.sidebar-backdrop{z-index:45;background:#00000080;display:none;position:fixed;inset:0}@media (max-width:768px){.sidebar-hamburger{display:flex}.sidebar-close,.sidebar-backdrop{display:block}.sidebar{z-index:50}.main-header{padding-left:60px}.devices-table-container,.admin-tenant-section .devices-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.devices-table-container .data-table{min-width:600px}}@media (max-width:480px){.main-body{padding:16px}.main-header-title{font-size:14px}.stat-card{padding:16px}.stat-card-value{font-size:24px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.admin-filters{flex-direction:column}.admin-filter-select{width:100%}}.admin-layout{background:var(--bg-primary);min-height:100vh}.admin-header{height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:40;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.admin-header-left{align-items:center;gap:12px;display:flex}.admin-header-title{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:700}.admin-nav{align-items:center;gap:16px;display:flex}.admin-nav-link{color:var(--text-secondary);transition:color var(--transition);font-size:14px;font-weight:500}.admin-nav-link:hover{color:var(--color-primary)}.admin-main{max-width:1200px;margin:0 auto;padding:24px}.admin-page-header{margin-bottom:24px}.admin-page-title{font-family:var(--font-heading);letter-spacing:-.02em;margin-bottom:4px;font-size:24px;font-weight:700}.admin-page-subtitle{color:var(--text-secondary);font-size:14px}.admin-metrics-grid{grid-template-columns:repeat(3,1fr)}.monitor-section{margin-bottom:28px}.monitor-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.monitor-header-left{color:var(--text-primary);align-items:center;gap:10px;display:flex}.monitor-header-right{align-items:center;gap:10px;display:flex}.monitor-title{letter-spacing:-.3px;color:var(--text-primary);margin:0;font-size:18px;font-weight:600}.monitor-status-badge{letter-spacing:.02em;border-radius:999px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.monitor-status-badge.online{color:var(--color-success);background:#10b9811f}.monitor-status-badge.offline{color:var(--color-danger);background:#ef44441f}.monitor-status-dot{background:currentColor;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite monitor-pulse}@keyframes monitor-pulse{0%,to{opacity:1}50%{opacity:.4}}.monitor-refresh-btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);justify-content:center;align-items:center;display:flex}.monitor-refresh-btn:hover{color:var(--color-primary);border-color:var(--color-primary)}.monitor-refresh-btn.spinning svg{animation:.8s linear infinite monitor-spin}@keyframes monitor-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.monitor-grid{gap:12px;margin-bottom:12px;display:grid}.monitor-grid-4{grid-template-columns:repeat(4,1fr)}.monitor-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);padding:20px}.monitor-card:hover{border-color:#ffffff1a;box-shadow:0 4px 20px #00000026}.monitor-card-header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:8px;margin-bottom:16px;font-size:12px;font-weight:600;display:flex}.monitor-skeleton{min-height:140px;animation:1.5s ease-in-out infinite monitor-skeleton-pulse}@keyframes monitor-skeleton-pulse{0%,to{opacity:.5}50%{opacity:.3}}.monitor-gauge{flex-direction:column;align-items:center;gap:8px;display:flex}.monitor-gauge-svg{display:block}.monitor-gauge-arc{transition:stroke-dashoffset 1s ease-out}.monitor-gauge-value{letter-spacing:-.5px;font-size:20px;font-weight:700;font-family:var(--font-sans)}.monitor-gauge-sublabel{text-transform:uppercase;letter-spacing:.05em;font-size:9px;font-weight:500;font-family:var(--font-sans)}.monitor-gauge-label{color:var(--text-muted);text-align:center;font-size:11px;line-height:1.3}.monitor-progress-container{flex-direction:column;gap:12px;margin-top:8px;display:flex}.monitor-progress-info{justify-content:space-between;align-items:baseline;display:flex}.monitor-progress-value{letter-spacing:-.5px;color:var(--text-primary);font-size:28px;font-weight:700}.monitor-progress-detail{color:var(--text-muted);font-size:12px}.monitor-progress-bar{background:#ffffff0f;border-radius:999px;width:100%;height:6px;overflow:hidden}.monitor-progress-fill{background:linear-gradient(90deg,#0a6ebd,#00bcd4);border-radius:999px;height:100%;transition:width 1s ease-out;box-shadow:0 0 8px #00bcd44d}.monitor-progress-fill.warning{background:linear-gradient(90deg,#f59e0b,#ef4444);box-shadow:0 0 8px #f59e0b4d}.monitor-progress-fill.danger{background:linear-gradient(90deg,#ef4444,#dc2626);box-shadow:0 0 8px #ef44444d}.monitor-load-container{flex-direction:column;align-items:center;margin-top:8px;display:flex}.monitor-load-values{align-items:center;gap:16px;display:flex}.monitor-load-item{flex-direction:column;align-items:center;gap:4px;display:flex}.monitor-load-number{color:var(--text-primary);letter-spacing:-.5px;font-size:24px;font-weight:700}.monitor-load-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:600}.monitor-load-divider{background:var(--border);width:1px;height:32px}.monitor-stat-value{letter-spacing:-.5px;color:var(--text-primary);margin-bottom:4px;font-size:28px;font-weight:700;line-height:1}.monitor-stat-sub{color:var(--text-muted);margin-bottom:8px;font-size:12px}.monitor-sparkline{width:100%;margin-top:8px;display:block}.monitor-chart-card{margin-bottom:12px}.monitor-chart-card .monitor-card-header{justify-content:flex-start}.monitor-chart-legend{gap:16px;margin-left:auto;display:flex}.monitor-legend-item{color:var(--text-secondary);text-transform:none;letter-spacing:0;align-items:center;gap:6px;font-size:11px;font-weight:500;display:flex}.monitor-legend-dot{border-radius:50%;width:8px;height:8px}.monitor-activity-chart{width:100%;height:auto;display:block}.monitor-chart-empty{text-align:center;color:var(--text-muted);padding:32px;font-size:13px}.monitor-infra-label{align-items:center;gap:8px;margin-bottom:8px;padding-top:4px;display:flex}.monitor-infra-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.monitor-infra-hostname{color:var(--text-secondary);border:1px solid var(--border);background:#ffffff0a;border-radius:999px;padding:2px 8px;font-family:monospace;font-size:10px;font-weight:500}.monitor-footer{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.monitor-badge{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:500;display:inline-flex}.monitor-error{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-secondary);flex-direction:column;align-items:center;gap:12px;padding:40px;font-size:14px;display:flex}.monitor-retry-btn{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--color-primary);cursor:pointer;transition:all var(--transition);font-size:13px;font-weight:500;font-family:var(--font-sans);padding:6px 16px}.monitor-retry-btn:hover{border-color:var(--color-primary);background:#0ea5e914}@media (max-width:1024px){.monitor-grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.monitor-grid-4{grid-template-columns:1fr}.monitor-header{flex-direction:column;align-items:flex-start;gap:8px}.monitor-footer{flex-direction:column}.monitor-chart-legend{display:none}}.log-viewer-section{margin-top:8px}.log-viewer-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;display:flex}.log-viewer-header-left{color:var(--text-primary);align-items:center;gap:10px;display:flex}.log-viewer-header-right{align-items:center;gap:6px;display:flex}.log-viewer-title{letter-spacing:-.3px;color:var(--text-primary);margin:0;font-size:18px;font-weight:600}.log-viewer-badge{color:var(--text-muted);border:1px solid var(--border);background:#ffffff0a;border-radius:999px;padding:2px 8px;font-family:monospace;font-size:11px;font-weight:500}.log-viewer-select{height:28px;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font-sans);transition:all var(--transition);appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 4px center;background-repeat:no-repeat;background-size:16px;padding:0 24px 0 8px}.log-viewer-select:hover{border-color:var(--color-primary)}.log-viewer-select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #0ea5e926}.log-viewer-icon-btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);justify-content:center;align-items:center;display:flex}.log-viewer-icon-btn:hover{color:var(--color-primary);border-color:var(--color-primary)}.log-viewer-icon-btn:disabled{opacity:.4;cursor:not-allowed}.log-viewer-icon-btn.active{color:var(--color-primary);border-color:var(--color-primary);background:#0ea5e914}.log-viewer-icon-btn.spinning svg{animation:.8s linear infinite monitor-spin}.log-viewer-filter-bar{gap:8px;margin-bottom:12px;display:flex}.log-viewer-filter-input-wrapper{flex:1;align-items:center;display:flex;position:relative}.log-viewer-filter-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:10px}.log-viewer-filter-input{width:100%;height:34px;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;font-family:var(--font-sans);transition:all var(--transition);padding:0 32px 0 30px}.log-viewer-filter-input::placeholder{color:var(--text-muted)}.log-viewer-filter-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #0ea5e926}.log-viewer-filter-clear{width:18px;height:18px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:#ffffff14;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;right:8px}.log-viewer-filter-clear:hover{color:var(--text-primary);background:#ffffff26}.log-viewer-filter-btn{height:34px;color:var(--text-primary);border:1px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-sans);transition:all var(--transition);background:#0ea5e914;padding:0 16px}.log-viewer-filter-btn:hover{background:#0ea5e926}.log-viewer-terminal{border:1px solid var(--border);border-radius:var(--radius-lg);scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#ffffff14 transparent;background:#0a0e17;max-height:520px;padding:2px 0;font-family:JetBrains Mono,Fira Code,Cascadia Code,SF Mono,Consolas,monospace;font-size:12px;line-height:1.65;overflow:hidden auto}.log-viewer-terminal::-webkit-scrollbar{width:6px}.log-viewer-terminal::-webkit-scrollbar-track{background:0 0}.log-viewer-terminal::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}.log-viewer-terminal::-webkit-scrollbar-thumb:hover{background:#ffffff26}.log-viewer-line{border-left:2px solid #0000;align-items:flex-start;padding:1px 14px 1px 0;transition:background .15s;display:flex}.log-viewer-line:hover{background:#ffffff08}.log-viewer-line-number{text-align:right;color:#ffffff26;-webkit-user-select:none;user-select:none;flex-shrink:0;width:44px;padding-right:12px;font-size:11px}.log-viewer-line-content{word-break:break-all;white-space:pre-wrap;color:#ffffffbf;flex:1}.log-level-error{border-left-color:#ef4444}.log-level-error .log-viewer-line-content{color:#f87171}.log-level-error:hover{background:#ef44440f}.log-level-warn{border-left-color:#f59e0b}.log-level-warn .log-viewer-line-content{color:#fbbf24}.log-level-warn:hover{background:#f59e0b0f}.log-level-info .log-viewer-line-content{color:#ffffffbf}.log-level-debug .log-viewer-line-content{color:#fff6}.log-level-trace .log-viewer-line-content{color:#ffffff40}.log-viewer-empty{text-align:center;color:#ffffff4d;font-family:var(--font-sans);padding:48px 24px;font-size:13px}.log-viewer-error{border-radius:var(--radius-md);color:#f87171;background:#ef44440f;border:1px solid #ef444433;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:16px;font-size:13px;display:flex}.log-viewer-retry-btn{color:#f87171;border-radius:var(--radius-md);cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font-sans);transition:all var(--transition);white-space:nowrap;background:#ef44441a;border:1px solid #ef44444d;padding:4px 12px}.log-viewer-retry-btn:hover{background:#ef44442e}.log-viewer-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:10px;display:flex}.log-viewer-footer-badges{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.log-viewer-follow-btn{color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;font-size:11px;font-weight:500;font-family:var(--font-sans);transition:all var(--transition);align-items:center;gap:5px;padding:4px 10px;display:flex}.log-viewer-follow-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.log-viewer-follow-btn.active{color:var(--color-primary);border-color:var(--color-primary);background:#0ea5e914}.log-viewer-status-badge{color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:5px;padding:3px 8px;font-size:11px;font-weight:500;display:inline-flex}.log-viewer-status-badge.live{color:var(--color-success);background:#10b9810f;border-color:#10b9814d}.log-viewer-status-badge.filter{color:var(--color-primary);background:#0ea5e90f;border-color:#0ea5e94d}.log-viewer-live-dot{background:var(--color-success);border-radius:50%;width:5px;height:5px;animation:2s ease-in-out infinite monitor-pulse}.log-viewer-skeleton{flex-direction:column;gap:6px;min-height:300px;padding:20px 16px;display:flex}.log-viewer-skeleton-line{background:#ffffff0a;border-radius:4px;height:14px;animation:1.5s ease-in-out infinite monitor-skeleton-pulse}@media (max-width:768px){.log-viewer-header{flex-direction:column;align-items:flex-start}.log-viewer-header-right{justify-content:flex-end;width:100%}.log-viewer-filter-bar{flex-direction:column}.log-viewer-filter-btn{width:100%}.log-viewer-terminal{max-height:380px;font-size:11px}.log-viewer-line-number{width:32px;padding-right:8px;font-size:10px}.log-viewer-footer{flex-direction:column;align-items:flex-start}}.admin-tabs{border-bottom:1px solid var(--border);gap:4px;margin:24px 0 16px;display:flex}.admin-tab{color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-sans);transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 20px}.admin-tab:hover{color:var(--text-primary)}.admin-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.admin-filters{gap:12px;margin-bottom:16px;display:flex}.admin-search{flex:1;max-width:360px}.admin-filter-select{cursor:pointer;width:180px}.admin-pagination{justify-content:center;align-items:center;gap:16px;padding:16px 0;display:flex}.admin-page-info{color:var(--text-secondary);font-size:13px}.audit-action-badge{color:var(--color-primary);background:#0ea5e91f;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.admin-metric-skeleton{background:var(--bg-card);border-radius:var(--radius-lg);height:120px;animation:1.5s ease-in-out infinite pulse}.pricing-page{background:var(--bg-primary);min-height:100vh}.pricing-page-header{height:var(--header-height);justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 24px;display:flex}.pricing-page-logo{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;align-items:center;gap:10px;font-size:20px;font-weight:700;display:flex}.pricing-page-nav{align-items:center;gap:16px;display:flex}.pricing-page-content{text-align:center;max-width:1200px;margin:0 auto;padding:48px 24px}.pricing-page-title{font-family:var(--font-heading);letter-spacing:-.03em;background:linear-gradient(135deg, var(--text-primary), var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:36px;font-weight:800}.pricing-page-subtitle{color:var(--text-secondary);max-width:500px;margin-bottom:48px;margin-left:auto;margin-right:auto;font-size:16px}@media (max-width:1024px){.admin-metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.admin-main{padding:16px}.admin-metrics-grid{grid-template-columns:1fr}.admin-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.admin-filters{flex-direction:column}.admin-search{max-width:100%}.admin-filter-select{width:100%}.pricing-page-title{font-size:24px}.pricing-page-content{padding:24px 16px}}.reports-page{flex-direction:column;gap:24px;max-width:1440px;margin:0 auto;padding:24px;display:flex}.reports-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.reports-header-info{flex-direction:column;gap:4px;display:flex}.reports-title{color:var(--text-primary);letter-spacing:-.5px;font-size:24px;font-weight:700;line-height:1.2}.reports-subtitle{color:var(--text-secondary);font-size:14px}.reports-export-actions{flex-shrink:0;gap:8px;display:flex}.reports-export-btn{border-radius:var(--radius-md);font-size:13px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);border:1px solid #0000;align-items:center;gap:6px;padding:8px 14px;display:inline-flex}.reports-export-btn.excel{color:var(--color-success);background:#10b9811f;border-color:#10b98133}.reports-export-btn.excel:hover{background:#10b98133;box-shadow:0 0 12px #10b98126}.reports-export-btn.pdf{color:#fca5a5;background:#ef44441f;border-color:#ef444433}.reports-export-btn.pdf:hover{background:#ef444433;box-shadow:0 0 12px #ef444426}.reports-export-btn:disabled{opacity:.4;cursor:not-allowed}.reports-filter-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.reports-filter-grid{grid-template-columns:1fr 1fr 2fr auto;align-items:end;gap:16px;display:grid}.reports-filter-group{flex-direction:column;gap:6px;display:flex}.reports-filter-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.reports-filter-select,.reports-filter-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);transition:border-color var(--transition), box-shadow var(--transition);appearance:none;outline:none;min-height:38px;padding:9px 12px}.reports-filter-select{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='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:32px}.reports-filter-select:focus,.reports-filter-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0ea5e91f}.reports-filter-date-range{align-items:center;gap:8px;display:flex}.reports-filter-date-separator{color:var(--text-muted);flex-shrink:0;font-size:12px;font-weight:500}.reports-generate-btn{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff;border-radius:var(--radius-md);min-height:38px;font-size:13px;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:0 20px;display:inline-flex}.reports-generate-btn:hover:not(:disabled){background:linear-gradient(135deg, var(--color-primary-light), var(--color-primary));transform:translateY(-1px);box-shadow:0 4px 16px #0ea5e94d}.reports-generate-btn:disabled{opacity:.6;cursor:not-allowed}.reports-filter-error{border-radius:var(--radius-md);color:#fca5a5;background:#ef444414;border:1px solid #ef444426;align-items:center;gap:8px;margin-top:12px;padding:10px 14px;font-size:13px;display:flex}.reports-quick-periods{border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:16px;padding-top:12px;display:flex}.reports-quick-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-right:4px;font-size:11px;font-weight:600}.reports-quick-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);background:0 0;padding:5px 12px}.reports-quick-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#0ea5e914}.reports-quick-btn.active{border-color:var(--color-primary);color:var(--color-primary);background:#0ea5e91f}.reports-kpi-grid{grid-template-columns:repeat(6,1fr);gap:12px;display:grid}.reports-kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);padding:16px;position:relative;overflow:hidden}.reports-kpi-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;opacity:.6;height:2px;transition:opacity var(--transition);position:absolute;top:0;left:0;right:0}.reports-kpi-card:hover{border-color:#0ea5e94d;transform:translateY(-2px);box-shadow:0 0 20px #0ea5e914}.reports-kpi-card:hover:before{opacity:1}.reports-kpi-card.blue:before{background:var(--color-primary)}.reports-kpi-card.cyan:before{background:var(--color-accent)}.reports-kpi-card.green:before{background:var(--color-success)}.reports-kpi-card.yellow:before{background:var(--color-warning)}.reports-kpi-card.red:before{background:var(--color-danger)}.reports-kpi-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.reports-kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.reports-kpi-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.reports-kpi-icon.blue{color:var(--color-primary);background:#0ea5e91f}.reports-kpi-icon.cyan{color:var(--color-accent);background:#06b6d41f}.reports-kpi-icon.green{color:var(--color-success);background:#10b9811f}.reports-kpi-icon.yellow{color:var(--color-warning);background:#f59e0b1f}.reports-kpi-icon.red{color:var(--color-danger);background:#ef44441f}.reports-kpi-value{color:var(--text-primary);letter-spacing:-.5px;font-size:24px;font-weight:700;line-height:1}.reports-kpi-unit{color:var(--text-muted);margin-left:4px;font-size:13px;font-weight:400}.reports-kpi-badge{cursor:help;vertical-align:middle;width:20px;height:20px;transition:all var(--transition);border-radius:50%;justify-content:center;align-items:center;margin-left:6px;font-size:11px;font-weight:700;display:inline-flex;position:relative;top:-2px}.reports-kpi-badge.estimated{color:var(--color-warning);background:#f59e0b26;border:1px solid #f59e0b4d}.reports-kpi-badge.estimated:hover{background:#f59e0b40;box-shadow:0 0 8px #f59e0b33}.reports-kpi-badge.warning{color:var(--color-danger);background:#ef444426;border:1px solid #ef44444d}.reports-kpi-badge.warning:hover{background:#ef444440;box-shadow:0 0 8px #ef444433}.reports-table-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.reports-table-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.reports-table-title{color:var(--text-primary);font-size:15px;font-weight:600}.reports-table-count{color:var(--text-muted);font-size:12px;font-weight:500}.reports-table-scroll{overflow-x:auto}.reports-table{border-collapse:collapse;width:100%;font-size:13px}.reports-table thead{z-index:1;position:sticky;top:0}.reports-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-input);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 16px;font-size:11px;font-weight:700}.reports-table td{color:var(--text-primary);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 16px}.reports-table tbody tr{transition:background var(--transition)}.reports-table tbody tr:nth-child(2n){background:#ffffff04}.reports-table tbody tr:hover{background:#0ea5e90d}.reports-table tbody tr:last-child td{border-bottom:none}.reports-table-address{text-overflow:ellipsis;white-space:nowrap;max-width:200px;color:var(--text-secondary);overflow:hidden}.reports-table-mono{font-family:var(--font-mono);color:var(--text-secondary);font-size:12px}.reports-table-duration{color:var(--color-primary);background:#0ea5e914;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-flex}.reports-table-distance{color:var(--text-primary);font-weight:600}.reports-table-footer{border-top:1px solid var(--border);background:var(--bg-input);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.reports-table-footer-info{color:var(--text-muted);font-size:12px}.reports-empty-state{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 24px;display:flex}.reports-empty-icon{border-radius:var(--radius-lg);width:56px;height:56px;color:var(--color-primary);background:#0ea5e914;justify-content:center;align-items:center;margin-bottom:16px;display:flex}.reports-empty-title{color:var(--text-primary);margin-bottom:6px;font-size:15px;font-weight:600}.reports-empty-description{color:var(--text-muted);max-width:280px;font-size:13px}.reports-map-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);justify-content:center;align-items:center;height:500px;display:flex;position:relative;overflow:hidden}.reports-map-container:before{content:"";background:radial-gradient(at 30%,#0ea5e90d 0%,#0000 50%),radial-gradient(at 70% 30%,#06b6d40a 0%,#0000 50%);position:absolute;inset:0}.reports-map-placeholder{z-index:1;color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;display:flex}.reports-map-placeholder svg{opacity:.4}.reports-map-placeholder span{font-size:13px}.reports-event-badge{border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.reports-event-badge.enter{color:var(--color-success);background:#10b9811a}.reports-event-badge.exit{color:var(--color-danger);background:#ef44441a}.reports-event-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.reports-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}.column-picker-trigger{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:12px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);white-space:nowrap;align-items:center;gap:6px;padding:6px 14px;display:inline-flex}.column-picker-trigger:hover{border-color:var(--color-primary);color:var(--color-primary);background:#0ea5e90d}.column-picker-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:280px;box-shadow:var(--shadow-lg);z-index:60;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}.column-picker-actions{border-bottom:1px solid var(--border);background:var(--bg-input);gap:8px;padding:10px 12px;display:flex}.column-picker-action-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:11px;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);background:0 0;flex:1;padding:5px 10px}.column-picker-action-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#0ea5e914}.column-picker-list{max-height:360px;padding:4px 0;overflow-y:auto}.column-picker-category{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:8px 14px 4px;font-size:10px;font-weight:700}.column-picker-item{width:100%;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);cursor:pointer;transition:background var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:6px 14px;display:flex}.column-picker-item:hover{background:#0ea5e90f}.column-picker-checkbox{border:2px solid var(--border);width:16px;height:16px;transition:all var(--transition);border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.column-picker-checkbox.checked{background:var(--color-primary);border-color:var(--color-primary)}.column-picker-item-label{flex:1}.column-picker-item-unit{color:var(--text-muted);font-size:11px}.position-report-warning{color:var(--color-warning);background:#f59e0b14;border-bottom:1px solid #f59e0b26;padding:10px 20px;font-size:12px;font-weight:500}@media (max-width:1200px){.reports-kpi-grid{grid-template-columns:repeat(3,1fr)}.reports-filter-grid{grid-template-columns:1fr 1fr}}@media (max-width:768px){.reports-page{gap:16px;padding:16px}.reports-header{flex-direction:column}.reports-kpi-grid{grid-template-columns:repeat(2,1fr)}.reports-filter-grid{grid-template-columns:1fr}.reports-filter-date-range{flex-direction:column;align-items:stretch}.reports-filter-date-separator{display:none}.reports-quick-periods{flex-wrap:wrap}}.traccar-popup-container .maplibregl-popup-content{background:#1a2332;border:1px solid #2a3a4e;border-radius:12px;min-width:300px;max-width:340px;padding:0;overflow:hidden;box-shadow:0 12px 40px #0000008c,0 0 0 1px #0ea5e91a}.traccar-popup-container .maplibregl-popup-tip{border-top-color:#1a2332}.traccar-popup{color:#f1f5f9;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px}.traccar-popup-header{background:#0f1a2a;border-bottom:1px solid #2a3a4e;justify-content:space-between;align-items:center;padding:12px 14px 10px;display:flex}.traccar-popup-name{color:#0ea5e9;letter-spacing:-.01em;font-size:14px;font-weight:600}.traccar-popup-close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;font-size:16px;line-height:1;transition:all .15s}.traccar-popup-close-btn:hover{color:#f1f5f9;background:#ffffff14}.traccar-popup-body{background:#1a2332;padding:10px 14px 8px}.traccar-popup-row{border-bottom:1px solid #ffffff0a;justify-content:space-between;align-items:center;gap:16px;padding:5px 0;display:flex}.traccar-popup-row:last-of-type{border-bottom:none}.traccar-popup-label{color:#94a3b8;white-space:nowrap;font-size:12px;font-weight:500}.traccar-popup-value{text-align:right;word-break:break-word;color:#e2e8f0;font-size:12px;font-weight:500}.traccar-popup-link{color:#38bdf8;cursor:pointer}.traccar-popup-link:hover{color:#0ea5e9;text-decoration:underline}.traccar-popup-coords{color:#64748b;font-family:JetBrains Mono,Fira Code,monospace;font-size:11px}.traccar-popup-details-link{color:#38bdf8;cursor:pointer;-webkit-user-select:none;user-select:none;border-top:1px solid #ffffff0f;justify-content:center;align-items:center;gap:4px;margin-top:8px;padding-top:8px;font-size:12px;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.traccar-popup-details-link:hover{color:#0ea5e9}.traccar-popup-details{margin-top:6px}.traccar-popup-details-divider{background:#ffffff0f;height:1px;margin:6px 0 8px}.traccar-popup-actions{background:#0f1a2a;border-top:1px solid #2a3a4e;justify-content:space-around;align-items:center;gap:2px;padding:10px 8px;display:flex}.traccar-action-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:38px;height:38px;transition:all .15s;display:flex}.traccar-action-btn:hover{color:#f1f5f9;background:#0ea5e91f}.traccar-action-command:hover{color:#0ea5e9}.traccar-action-geofence:hover{color:#34d399}.traccar-action-replay:hover{color:#fbbf24}.traccar-action-edit:hover{color:#60a5fa}.traccar-action-fence:hover{color:#f59e0b}.traccar-action-delete:hover{color:#f87171}.quick-geofence-success{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:32px 16px;display:flex}.quick-geofence-success-icon{color:#10b981;background:#10b9811f;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;font-weight:700;display:flex}.quick-geofence-success p{color:var(--text-primary);margin:0;font-size:14px;font-weight:600}.quick-geofence-coords{color:var(--text-muted);text-align:center;font-size:12px;font-family:var(--font-mono);padding:8px 0 4px}.quick-geofence-error{color:#f87171;text-align:center;background:#ef444414;border:1px solid #ef444433;border-radius:8px;margin-top:8px;padding:8px 12px;font-size:12px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-container{background:var(--card);border:1px solid var(--border);border-radius:16px;max-height:85vh;animation:.25s slideUp;overflow-y:auto;box-shadow:0 16px 64px #0006}.modal-sm{width:380px;max-width:92vw}.modal-md{width:480px;max-width:92vw}.modal-lg{width:640px;max-width:92vw}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header-info{color:var(--color-primary);align-items:center;gap:10px;display:flex}.modal-title{font-family:var(--font-heading);letter-spacing:-.01em;color:var(--foreground);margin:0;font-size:15px;font-weight:600}.modal-subtitle{color:var(--muted-foreground);margin:0;font-size:12px}.modal-close{width:30px;height:30px;color:var(--muted-foreground);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.modal-close:hover{background:var(--accent);color:var(--foreground)}.modal-body{padding:16px 20px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:8px;padding:12px 20px;display:flex}.modal-loading{color:var(--muted-foreground);justify-content:center;align-items:center;gap:10px;padding:32px 0;font-size:13px;display:flex}.command-result{border-radius:8px;align-items:center;gap:8px;margin-bottom:12px;padding:10px 14px;font-size:13px;display:flex}.command-result.success{color:#67e4bb;background:#13392d;border:1px solid #1f7a5c}.command-result.error{color:#e46767;background:#391313;border:1px solid #732626}.command-empty{text-align:center;color:var(--muted-foreground);padding:32px 16px}.command-empty p{color:var(--foreground);margin:8px 0 4px;font-size:14px}.command-empty span{font-size:12px}.command-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.command-card{border:1px solid var(--border);background:var(--accent);cursor:pointer;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:14px 8px;transition:all .15s;display:flex}.command-card:hover{border-color:var(--color-primary);background:hsl(var(--hue-primary) 35% 15%)}.command-card.selected{border-color:var(--color-primary);background:hsl(var(--hue-primary) 40% 18%);box-shadow:0 0 0 1px var(--color-primary)}.command-card-icon{font-size:20px}.command-card-label{text-align:center;color:var(--foreground);font-size:11px;font-weight:500;line-height:1.3}.replay-panel{z-index:800;color:#f1f5f9;background:#1a2332;border:1px solid #2a3a4e;border-radius:14px;min-width:400px;max-width:540px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;animation:.3s slideUp;position:absolute;bottom:48px;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 12px 40px #0000008c,0 0 0 1px #0ea5e914}.replay-header{background:#0f1a2a;border-bottom:1px solid #2a3a4e;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.replay-header-info{color:#0ea5e9;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.replay-close{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:all .15s;display:flex}.replay-close:hover{color:#f1f5f9;background:#ffffff14}.replay-date-selector{background:#1a2332;padding:14px}.replay-date-row{gap:10px;margin-bottom:10px;display:flex}.replay-date-row .form-group{flex:1}.replay-date-row .form-label{color:#94a3b8;align-items:center;gap:4px;margin-bottom:4px;font-size:11px;font-weight:500;display:flex}.replay-date-row .form-input,.replay-date-row .form-input-sm{color:#f1f5f9;background:#111827;border:1px solid #2a3a4e;border-radius:8px;outline:none;width:100%;padding:8px 10px;font-size:12px;transition:border-color .15s}.replay-date-row .form-input:focus,.replay-date-row .form-input-sm:focus{border-color:#0ea5e9}.replay-load-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0ea5e9,#0284c7);border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;width:100%;padding:10px 16px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.replay-load-btn:hover{background:linear-gradient(135deg,#38bdf8,#0ea5e9)}.replay-load-btn:disabled{opacity:.6;cursor:not-allowed}.replay-playback{background:#1a2332;padding:12px 14px}.replay-progress{background:#2a3a4e;border-radius:2px;height:4px;margin-bottom:10px;position:relative}.replay-progress-fill{background:#0ea5e9;border-radius:2px;height:100%;transition:width .1s linear;position:absolute;top:0;left:0}.replay-slider{opacity:0;cursor:pointer;z-index:2;width:100%;height:16px;margin:0;position:absolute;top:-6px;left:0}.replay-controls-row{justify-content:space-between;align-items:center;display:flex}.replay-buttons{align-items:center;gap:4px;display:flex}.replay-btn{color:#94a3b8;cursor:pointer;background:#111827;border:none;border-radius:8px;justify-content:center;align-items:center;gap:3px;width:36px;height:36px;transition:all .15s;display:flex}.replay-btn:hover,.replay-btn.active{color:#0ea5e9;background:#0ea5e926}.replay-speed-label{font-size:10px;font-weight:600}.replay-info{color:#94a3b8;align-items:center;gap:12px;font-size:12px;display:flex}.replay-info-time{color:#f1f5f9;font-weight:500}.replay-info-speed{color:#0ea5e9}.replay-new-date{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-top:1px solid #2a3a4e;justify-content:center;align-items:center;gap:4px;width:100%;margin-top:8px;padding:8px;font-size:11px;transition:color .15s;display:flex}.replay-new-date:hover{color:#0ea5e9}.replay-empty{text-align:center;color:#94a3b8;background:#1a2332;padding:20px;font-size:13px}.replay-empty .btn{color:#e2e8f0;cursor:pointer;background:#111827;border:1px solid #2a3a4e;border-radius:8px;margin-top:8px;padding:6px 14px;font-size:12px}.replay-empty .btn:hover{background:#1e293b}.replay-marker{width:20px;height:20px;position:relative}.replay-marker-inner{background:#0ea5e9;border:2px solid #fff;border-radius:50%;width:12px;height:12px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 12px #0ea5e9,0 0 24px #0ea5e94d}.replay-popup .maplibregl-popup-content{box-shadow:none;background:0 0;border-radius:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.replay-popup .maplibregl-popup-tip{display:none}.external-marker-el{z-index:1;pointer-events:auto!important}.external-marker-inner{pointer-events:auto}.external-point-popup{z-index:100!important;pointer-events:auto!important}.external-point-popup .maplibregl-popup-content{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);pointer-events:auto;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#e2e8f0!important;background:#1a2332f5!important;border:1px solid #94a3b826!important;border-radius:12px!important;padding:14px!important;box-shadow:0 8px 32px #0006!important}.external-point-popup .maplibregl-popup-close-button{padding:6px 10px;font-size:18px;line-height:1;color:#94a3b8!important}.external-point-popup .maplibregl-popup-close-button:hover{color:#e2e8f0!important;background:0 0!important}.external-point-popup .maplibregl-popup-tip{border-top-color:#1a2332f5!important}.ext-popup{min-width:240px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.ext-popup-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.ext-popup-badge{color:#fff;letter-spacing:.02em;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600}.ext-popup-layer-label{color:#94a3b8;font-size:11px}.ext-popup-name{color:#f1f5f9;margin-bottom:6px;font-size:14px;display:block}.ext-popup-meta{border-collapse:collapse;width:100%;margin-bottom:10px}.ext-popup-meta td{padding:2px 0;font-size:12px}.ext-popup-meta-key{color:#94a3b8;white-space:nowrap;padding-right:8px!important}.ext-popup-meta-val{color:#e2e8f0}.ext-popup-coord-actions{border-top:1px solid #94a3b81f;flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;padding:8px 0;display:flex}.ext-popup-coord-btn{color:#94a3b8;cursor:pointer;background:#ffffff0a;border:1px solid #94a3b82e;border-radius:6px;align-items:center;gap:5px;padding:5px 10px;font-family:inherit;font-size:11px;font-weight:500;transition:all .15s;display:inline-flex}.ext-popup-coord-btn:hover{color:#38bdf8;background:#0ea5e91a;border-color:#0ea5e94d}.ext-popup-coord-btn:active{transform:scale(.97)}.ext-popup-coord-btn svg{flex-shrink:0}.ext-popup-coord-feedback{color:#10b981;font-size:11px;font-weight:500;animation:.2s extPopupFadeIn}.ext-popup-distances{border-top:1px solid #94a3b81f;margin-top:4px;padding-top:10px}.ext-popup-distances-header{color:#94a3b8;align-items:center;gap:6px;margin-bottom:8px;font-size:12px;font-weight:600;display:flex}.ext-popup-distances-header svg{color:#0ea5e9;flex-shrink:0}.ext-popup-distances-count{color:#0ea5e9;text-align:center;background:#0ea5e926;border-radius:10px;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.ext-popup-empty{text-align:center;color:#64748b;padding:12px 8px;font-size:12px}.ext-popup-device-list{max-height:220px;margin:0;padding:0;list-style:none;overflow-y:auto}.ext-popup-device-list::-webkit-scrollbar{width:4px}.ext-popup-device-list::-webkit-scrollbar-thumb{background:#94a3b833;border-radius:2px}.ext-popup-device-item{cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:7px 8px;transition:background .12s;animation:.25s both extPopupFadeIn;display:flex}.ext-popup-device-item:hover{background:#0ea5e914}.ext-popup-section{margin-bottom:4px}.ext-popup-section-header{text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);align-items:center;gap:6px;padding:5px 8px 3px;font-size:10px;font-weight:600;display:flex}.ext-popup-section-header--checklist{color:#22c55e}.ext-popup-section-count{color:#22c55e;background:#22c55e26;border-radius:8px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.ext-popup-device-item--checklist{background:#22c55e0f;border-left:2px solid #22c55e}@keyframes extPopupFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.ext-popup-device-info{align-items:center;gap:8px;min-width:0;display:flex}.ext-popup-device-status{border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 6px}.ext-popup-device-details{flex-direction:column;min-width:0;display:flex}.ext-popup-device-name{color:#f1f5f9;white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-size:12px;font-weight:500;overflow:hidden}.ext-popup-device-plate{color:#64748b;letter-spacing:.04em;font-family:JetBrains Mono,monospace;font-size:10px}.ext-popup-device-distance{color:#0ea5e9;white-space:nowrap;flex-shrink:0;font-size:12px;font-weight:600}.ext-popup-show-more{color:#64748b;cursor:pointer;text-align:center;background:0 0;border:none;width:100%;margin-top:4px;padding:6px;font-family:inherit;font-size:11px;transition:color .15s;display:block}.ext-popup-show-more:hover{color:#0ea5e9}.ext-popup-action-cell{position:relative}.ext-popup-action-trigger{color:#38bdf8;cursor:pointer;background:#0ea5e914;border:1px solid #0ea5e94d;border-radius:4px;align-items:center;gap:4px;padding:1px 6px;font-family:inherit;font-size:12px;transition:all .15s;display:inline-flex}.ext-popup-action-trigger:hover,.ext-popup-action-trigger.active{background:#0ea5e926;border-color:#0ea5e9}.ext-popup-action-trigger svg{transition:transform .15s}.ext-popup-action-trigger.active svg{transform:rotate(180deg)}.ext-popup-action-dropdown{z-index:50;background:#111827;border:1px solid #2a3a4e;border-radius:8px;min-width:180px;max-width:260px;margin-top:4px;animation:.15s extPopupFadeIn;position:absolute;top:100%;left:0;overflow:hidden;box-shadow:0 8px 24px #00000080}.ext-popup-action-loading{color:#64748b;text-align:center;padding:10px 12px;font-size:11px}.ext-popup-action-options{max-height:160px;margin:0;padding:4px 0;list-style:none;overflow-y:auto}.ext-popup-action-options::-webkit-scrollbar{width:4px}.ext-popup-action-options::-webkit-scrollbar-thumb{background:#94a3b833;border-radius:2px}.ext-popup-action-option{color:#e2e8f0;cursor:pointer;padding:6px 12px;font-size:12px;transition:background .1s}.ext-popup-action-option:hover{color:#38bdf8;background:#0ea5e91f}.ext-popup-action-confirm{color:#e2e8f0;padding:10px 12px;font-size:12px}.ext-popup-action-confirm span{margin-bottom:8px;line-height:1.4;display:block}.ext-popup-action-confirm strong{color:#38bdf8}.ext-popup-action-confirm-btns{gap:6px;display:flex}.ext-popup-action-btn-confirm{color:#10b981;cursor:pointer;background:#10b98133;border:none;border-radius:5px;flex:1;padding:5px 10px;font-family:inherit;font-size:11px;font-weight:600;transition:background .15s}.ext-popup-action-btn-confirm:hover{background:#10b9814d}.ext-popup-action-btn-confirm:disabled{opacity:.5;cursor:not-allowed}.ext-popup-action-btn-cancel{color:#ef4444;cursor:pointer;background:#ef444426;border:none;border-radius:5px;flex:1;padding:5px 10px;font-family:inherit;font-size:11px;font-weight:600;transition:background .15s}.ext-popup-action-btn-cancel:hover{background:#ef444440}.ext-popup-action-result{border-radius:4px;margin-top:4px;padding:3px 8px;font-size:11px;font-weight:500;animation:.2s extPopupFadeIn}.ext-popup-action-result.success{color:#10b981;background:#10b9811f}.ext-popup-action-result.error{color:#ef4444;background:#ef44441f}.ext-popup-action-text-input{flex-direction:column;gap:6px;padding:4px 0;display:flex}.ext-popup-action-textarea{color:#e2e8f0;resize:vertical;background:#0000004d;border:1px solid #ffffff1f;border-radius:5px;outline:none;width:100%;min-height:36px;padding:6px 8px;font-family:inherit;font-size:12px;transition:border-color .15s}.ext-popup-action-textarea:focus{border-color:#06b6d480}.ext-popup-action-textarea::placeholder{color:#ffffff59}.replay-speed-legend{color:#94a3b8;align-items:center;gap:6px;padding:6px 14px 2px;font-size:10px;display:flex}.replay-speed-legend-bar{background:linear-gradient(90deg,#3b82f6,#06b6d4,#10b981,#84cc16,#eab308,#f97316,#ef4444);border-radius:2px;flex:1;height:4px}.replay-speed-legend-label{white-space:nowrap;font-weight:500}.map-layer-selector{z-index:500;transition:left .3s cubic-bezier(.4,0,.2,1);position:absolute;top:10px;left:10px}.panel-collapsed .map-layer-selector{left:68px}@media (max-width:768px){.map-layer-selector{top:14px;left:64px}.panel-collapsed .map-layer-selector{left:118px}}.map-layer-toggle{color:#f1f5f9;cursor:pointer;background:#1a2332;border:1px solid #2a3a4e;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;transition:all .15s;display:flex;box-shadow:0 2px 8px #00000059}.map-layer-toggle:hover{background:#243348;border-color:#0ea5e9}.map-layer-dropdown{background:#1a2332;border:1px solid #2a3a4e;border-radius:12px;min-width:180px;animation:.2s slideUp;position:absolute;top:44px;left:0;overflow:hidden;box-shadow:0 8px 32px #0000008c}.map-layer-dropdown-header{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #2a3a4e;padding:10px 14px;font-size:11px;font-weight:600}.map-layer-option{color:#e2e8f0;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:10px 14px;font-size:13px;transition:background .1s;display:flex}.map-layer-option:hover{background:#0ea5e914}.map-layer-option.active{color:#0ea5e9;background:#0ea5e91f}.map-layer-check{color:#0ea5e9;margin-left:auto;font-weight:700}.share-description{color:var(--muted-foreground);margin-bottom:16px;font-size:13px;line-height:1.5}.share-expiry-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px;display:grid}.share-expiry-option{border:1px solid var(--border);background:var(--accent);color:var(--foreground);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:6px;padding:12px;font-size:13px;transition:all .15s;display:flex}.share-expiry-option:hover{border-color:var(--color-primary)}.share-expiry-option.selected{border-color:var(--color-primary);background:hsl(var(--hue-primary) 40% 18%);box-shadow:0 0 0 1px var(--color-primary);color:var(--color-primary)}.share-generate-btn{width:100%}.share-result{margin-top:8px}.share-url-box{gap:6px;margin-bottom:10px;display:flex}.share-url-box .form-input{font-size:12px;font-family:var(--font-mono);flex:1}.share-copy-btn{white-space:nowrap}.share-expires-info{color:var(--muted-foreground);align-items:center;gap:4px;font-size:12px;display:flex}.share-page{background:var(--bg-primary);height:100vh;color:var(--foreground);flex-direction:column;display:flex}.share-page.share-loading,.share-page.share-error{text-align:center;color:var(--muted-foreground);justify-content:center;align-items:center;gap:12px}.share-error h2{color:var(--foreground);margin:0;font-size:18px}.share-error p{margin:0;font-size:14px}.share-header{background:var(--card);border-bottom:1px solid var(--border);align-items:center;gap:16px;padding:12px 20px;display:flex}.share-header-logo{color:var(--color-primary);align-items:center;gap:6px;font-size:16px;font-weight:700;display:flex}.share-header-title{margin:0;font-size:15px;font-weight:500}.share-map{flex:1;min-height:0}.share-info-bar{background:var(--card);border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:20px;padding:12px 20px;display:flex}.share-info-item{color:var(--foreground);align-items:center;gap:6px;font-size:13px;display:flex}.share-info-item svg{color:var(--color-primary)}.share-map-marker{width:24px;height:24px;position:relative}.share-map-marker-dot{background:var(--color-primary);width:14px;height:14px;box-shadow:0 0 12px var(--color-primary);border:3px solid #fff;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.share-map-marker-pulse{background:#0ea5e933;border-radius:50%;width:40px;height:40px;animation:2s infinite pulse-ring;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes pulse-ring{0%{opacity:1;transform:translate(-50%,-50%)scale(.5)}to{opacity:0;transform:translate(-50%,-50%)scale(1.5)}}.form-row{gap:12px;display:flex}.form-row .form-group{flex:1}.form-input-sm{padding:6px 10px;font-size:12px}.btn-sm{padding:6px 12px;font-size:12px}.billing-range{appearance:none;cursor:pointer;border-radius:99px;outline:none;height:4px;transition:all .2s}.billing-range::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#44d8f1;border:2px solid #121317;border-radius:50%;width:18px;height:18px;transition:transform .15s,box-shadow .15s;box-shadow:0 0 10px #44d8f180}.billing-range::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 16px #44d8f1b3}.billing-range::-moz-range-thumb{cursor:pointer;background:#44d8f1;border:2px solid #121317;border-radius:50%;width:18px;height:18px;box-shadow:0 0 10px #44d8f180}.intg-tabs{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border);gap:4px;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.intg-tab{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:14px;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;align-items:center;gap:8px;padding:10px 20px;display:flex}.intg-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.intg-tab.active{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #0ea5e940}.intg-section{flex-direction:column;gap:16px;display:flex}.intg-section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:16px;display:flex}.intg-section-title{font-family:var(--font-heading);letter-spacing:-.01em;color:var(--text-primary);align-items:center;gap:10px;margin-bottom:4px;font-size:18px;font-weight:600;display:flex}.intg-section-desc{color:var(--text-secondary);font-size:13px}.intg-key-banner{border-radius:var(--radius-lg);background:#10b9810f;border:1px solid #10b98133;gap:16px;padding:20px;animation:.3s ease-out intg-slide-in;display:flex;position:relative}@keyframes intg-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.intg-key-banner-icon{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-success);background:#10b9811f;flex-shrink:0;justify-content:center;align-items:center;display:flex}.intg-key-banner-content{flex:1}.intg-key-banner-content strong{color:var(--color-success);margin-bottom:4px;font-size:14px;display:block}.intg-key-banner-content p{color:var(--text-secondary);margin-bottom:12px;font-size:13px}.intg-key-display{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:12px;padding:10px 16px;display:flex}.intg-key-display code{font-family:var(--font-mono,"JetBrains Mono", "Fira Code", monospace);color:var(--color-primary);word-break:break-all;flex:1;font-size:13px}.intg-key-banner-close{width:24px;height:24px;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;font-size:18px;display:flex;position:absolute;top:12px;right:12px}.intg-key-banner-close:hover{background:var(--bg-hover);color:var(--text-primary)}.intg-form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;animation:.3s ease-out intg-slide-in}.intg-form-title{color:var(--text-primary);margin-bottom:20px;font-size:16px;font-weight:600}.intg-form{flex-direction:column;gap:16px;display:flex}.intg-form-actions{justify-content:flex-end;gap:8px;padding-top:8px;display:flex}.intg-scopes-grid{flex-wrap:wrap;gap:8px;display:flex}.intg-scope-chip{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;display:flex}.intg-scope-chip:has(input:checked){border-color:var(--color-primary);color:var(--color-primary);background:#0ea5e91a}.intg-scope-chip input[type=checkbox]{width:14px;height:14px;accent-color:var(--color-primary)}.intg-list{flex-direction:column;gap:8px;display:flex}.intg-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);overflow:hidden}.intg-card:hover{border-color:#0ea5e94d}.intg-card.inactive{opacity:.6}.intg-card-main{justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}.intg-card-info{flex:1;min-width:0}.intg-card-name{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:6px;font-size:14px;font-weight:600;display:flex}.intg-card-meta{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.intg-meta-sep{color:var(--border)}.intg-key-prefix{font-family:var(--font-mono,monospace);background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-muted);padding:2px 6px;font-size:12px}.intg-webhook-url{font-family:var(--font-mono,monospace);text-overflow:ellipsis;white-space:nowrap;max-width:400px;font-size:13px;overflow:hidden}.intg-card-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.intg-card-timestamps{color:var(--text-muted);flex-direction:column;gap:2px;margin-right:8px;font-size:11px;display:flex}.intg-card-timestamps span{align-items:center;gap:4px;display:flex}.intg-card-timestamps .expired{color:var(--color-danger)}.intg-empty{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.intg-empty p{color:var(--text-secondary);margin-top:12px;font-size:15px;font-weight:500}.intg-empty span{margin-top:4px;font-size:13px}.intg-docs-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.intg-docs-card h4{color:var(--text-primary);margin-bottom:12px;font-size:14px;font-weight:600}.intg-code-block{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-mono,"JetBrains Mono", "Fira Code", monospace);color:var(--color-primary);white-space:pre;margin-bottom:8px;padding:16px;font-size:13px;line-height:1.5;overflow-x:auto}.intg-docs-hint{color:var(--text-muted);font-size:12px}.intg-docs-hint code{background:var(--bg-input);border-radius:var(--radius-sm);padding:2px 5px;font-size:11px}.intg-deliveries{border-top:1px solid var(--border);padding:16px 20px;animation:.2s ease-out intg-slide-in}.intg-deliveries-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.intg-deliveries-header h4{color:var(--text-secondary);font-size:13px;font-weight:600}.intg-spin{animation:1s linear infinite intg-spin-anim}@keyframes intg-spin-anim{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width:768px){.intg-card-main{flex-direction:column;align-items:flex-start}.intg-card-actions{flex-wrap:wrap;width:100%}.intg-section-header{flex-direction:column}.intg-section-header .btn{justify-content:center;width:100%}.intg-webhook-url{max-width:200px}.intg-tabs{width:100%}.intg-tab{flex:1;justify-content:center}}.docs-version-badge{color:var(--color-primary);font-size:13px;font-weight:600;font-family:var(--font-mono,monospace);background:#0ea5e91a;border:1px solid #0ea5e940;border-radius:999px;padding:6px 14px}.docs-quickstart{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.docs-block-title{color:var(--text-primary);align-items:center;gap:10px;margin-bottom:16px;font-size:16px;font-weight:600;display:flex}.docs-steps{flex-direction:column;gap:16px;margin-bottom:20px;display:flex}.docs-step{align-items:flex-start;gap:14px;display:flex}.docs-step-num{background:linear-gradient(135deg, var(--color-primary), #0ea5e999);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;min-width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.docs-step strong{color:var(--text-primary);margin-bottom:2px;font-size:14px;display:block}.docs-step p{color:var(--text-secondary);font-size:13px;line-height:1.5}.docs-quickstart-code{margin-top:4px}.docs-code-header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:12px;font-weight:600;display:flex}.docs-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.docs-block-content{flex-direction:column;gap:16px;display:flex}.docs-block-content p{color:var(--text-secondary);font-size:14px;line-height:1.6}.docs-block-content code{background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-mono,monospace);color:var(--color-primary);padding:2px 6px}.docs-info-box{border-radius:var(--radius-md);color:var(--text-secondary);background:#0ea5e90f;border:1px solid #0ea5e926;align-items:flex-start;gap:10px;padding:12px 16px;font-size:13px;line-height:1.5;display:flex}.docs-info-box svg{color:var(--color-primary);flex-shrink:0;margin-top:2px}.docs-info-box.warn{background:#f59e0b0f;border-color:#f59e0b33}.docs-info-box.warn svg{color:var(--color-warning)}.docs-endpoint-row{cursor:pointer;width:100%;font-family:var(--font-sans);transition:background var(--transition);background:0 0;border:none;justify-content:space-between;align-items:center;gap:16px;padding:14px 20px;display:flex}.docs-endpoint-row:hover{background:var(--bg-hover)}.docs-endpoint-info{flex-shrink:0;align-items:center;gap:10px;display:flex}.docs-method{color:var(--color-success);border-radius:var(--radius-sm);font-size:11px;font-weight:700;font-family:var(--font-mono,monospace);letter-spacing:.5px;background:#10b9811f;padding:3px 8px}.docs-path{font-family:var(--font-mono,monospace);color:var(--text-primary);font-size:13px;font-weight:500}.docs-scope-tag{color:var(--color-primary);font-size:11px;font-family:var(--font-mono,monospace);background:#0ea5e914;border:1px solid #0ea5e933;border-radius:999px;padding:2px 8px}.docs-event-tag{color:#a855f7;font-size:12px;font-weight:500;font-family:var(--font-mono,monospace);background:#a855f71a;border:1px solid #a855f733;border-radius:999px;padding:3px 10px}.docs-endpoint-right{align-items:center;gap:12px;min-width:0;display:flex}.docs-endpoint-desc{color:var(--text-secondary);text-align:right;white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.docs-endpoint-detail{border-top:1px solid var(--border);padding:16px 20px;animation:.2s ease-out intg-slide-in}@media (max-width:768px){.docs-endpoint-row{flex-direction:column;align-items:flex-start}.docs-endpoint-right{justify-content:space-between;width:100%}.docs-endpoint-desc{text-align:left;white-space:normal}.docs-steps{gap:12px}}.intg-admin-filter{border-radius:var(--radius-lg);color:var(--color-warning);background:#f59e0b0f;border:1px solid #f59e0b33;align-items:center;gap:10px;padding:12px 16px;display:flex}.intg-admin-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-warning);white-space:nowrap;font-size:12px;font-weight:700}.intg-admin-filter .form-input{background:var(--bg-secondary);border-color:#f59e0b4d;font-size:13px}.map-tenant-filter-wrapper{z-index:10;position:absolute;top:12px;left:12px}.map-tenant-filter-wrapper .intg-admin-filter{-webkit-backdrop-filter:blur(12px);background:#0a0f1ed9;border:1px solid #f59e0b40;box-shadow:0 4px 20px #0006}.offline-page{background:radial-gradient(ellipse at 20% 50%, #0ea5e914 0%, transparent 50%), radial-gradient(ellipse at 80% 20%, #06b6d40f 0%, transparent 50%), var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.offline-content{text-align:center;flex-direction:column;align-items:center;gap:16px;max-width:360px;display:flex}.offline-content h1{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:24px;font-weight:700}.offline-content p{color:var(--text-secondary);font-size:14px;line-height:1.5}.install-prompt-banner{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);margin:8px 12px;padding:12px}.install-prompt-text{color:var(--text-secondary);margin-bottom:8px;font-size:12px;line-height:1.4}.install-prompt-actions{gap:8px;display:flex}.install-prompt-btn{flex:1;justify-content:center;padding:6px 10px!important;font-size:12px!important}:root{--safe-area-top:env(safe-area-inset-top,0px);--safe-area-bottom:env(safe-area-inset-bottom,0px);--safe-area-left:env(safe-area-inset-left,0px);--safe-area-right:env(safe-area-inset-right,0px)}@media (display-mode:standalone){body{padding-top:var(--safe-area-top);padding-bottom:var(--safe-area-bottom);overscroll-behavior:none;-webkit-overflow-scrolling:touch;-webkit-user-select:none;user-select:none}input,textarea,[contenteditable]{-webkit-user-select:auto;user-select:auto}.sidebar{padding-top:calc(var(--safe-area-top) + 16px);padding-bottom:calc(var(--safe-area-bottom) + 16px)}.sidebar-footer{padding-bottom:calc(var(--safe-area-bottom) + 8px)}input,select,textarea{font-size:16px!important}.sidebar-hamburger{top:calc(var(--safe-area-top) + 12px)}}html{overscroll-behavior-y:contain}@media (pointer:coarse){.nav-item{min-height:44px}button,a,[role=button]{min-width:44px;min-height:44px}.nav-item:hover{background:0 0}.nav-item.active,.nav-item:active{background:var(--color-surface-hover)}}.map-external-section{border-top:1px solid var(--border);margin-top:4px;padding-top:8px}.map-external-header{width:100%;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition);background:0 0;border:none;align-items:center;gap:6px;padding:6px 8px;font-size:11px;font-weight:600;display:flex}.map-external-header span{text-align:left;flex:1}.map-external-header:hover{background:var(--bg-hover);color:var(--text-primary)}.map-external-layers{flex-direction:column;gap:8px;padding:4px 0;display:flex}.map-external-group{flex-direction:column;gap:2px;display:flex}.map-external-system-label{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);padding:4px 8px 2px;font-size:10px;font-weight:700}.map-external-layer-btn{border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:7px;padding:6px 8px;font-size:12px;display:flex}.map-external-layer-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.map-external-layer-btn.active{color:var(--text-primary);background:#0ea5e914;font-weight:500}.map-external-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.map-external-filters{border-radius:var(--radius-sm);background:#0ea5e90a;border:1px solid #0ea5e91a;flex-direction:column;gap:6px;margin-top:6px;padding:8px;display:flex}.map-external-filters-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:10px;font-weight:700}.map-external-filter-item{align-items:center;gap:8px;display:flex}.map-external-filter-label{color:var(--text-secondary);flex-shrink:0;min-width:60px;font-size:11px}.map-filter-select{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition);flex:1;padding:3px 6px;font-size:11px}.map-filter-select:hover{border-color:var(--color-primary)}.map-filter-select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #0ea5e926}.intg-ext-filter-card{border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color var(--transition);background:#0ea5e908;margin-bottom:10px;padding:12px}.intg-ext-filter-card:hover{border-color:#0ea5e94d}.intg-ext-filter-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.intg-ext-filter-index{color:var(--text-muted);background:var(--bg-hover);border-radius:var(--radius-sm);padding:2px 6px;font-size:11px;font-weight:700}.intg-ext-filter-enabled{color:var(--text-secondary);cursor:pointer;align-items:center;gap:4px;margin-left:auto;font-size:11px;display:flex}.intg-ext-filter-options-preview{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.intg-ext-filter-option-chip{color:var(--text-secondary);background:#0ea5e91a;border:1px solid #0ea5e926;border-radius:10px;padding:2px 8px;font-size:10px}.intg-ext-filter-option-chip.more{color:var(--text-muted);background:#64748b1a;border-color:#64748b26;font-style:italic}.intg-ext-modal-tab-badge{background:var(--color-primary);color:#fff;text-align:center;border-radius:8px;min-width:16px;padding:1px 5px;font-size:9px;font-weight:700}.intg-notice{border-radius:var(--radius-md);color:var(--color-warning);background:#f59e0b0f;border:1px solid #f59e0b33;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.intg-loading{text-align:center;color:var(--text-muted);padding:32px;font-size:13px}.intg-empty-icon{color:var(--text-muted);margin-bottom:4px}.intg-ext-list{flex-direction:column;gap:10px;display:flex}.intg-ext-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), box-shadow var(--transition);overflow:hidden}.intg-ext-card:hover{border-color:#0ea5e940;box-shadow:0 2px 12px #00000026}.intg-ext-card.disabled{opacity:.65}.intg-ext-card-header{justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.intg-ext-card-info{align-items:center;gap:12px;min-width:0;display:flex}.intg-ext-badge{color:#fff;letter-spacing:.5px;border-radius:999px;flex-shrink:0;padding:3px 10px;font-size:11px;font-weight:700}.intg-ext-name{color:var(--text-primary);font-size:14px;font-weight:600;display:block}.intg-ext-host{color:var(--text-muted);font-size:11px;font-family:var(--font-mono,monospace);align-items:center;gap:4px;margin-top:2px;display:flex}.intg-ext-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.intg-ext-action-btn{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);align-items:center;gap:4px;padding:5px 10px;font-size:12px;display:flex}.intg-ext-action-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:#0ea5e94d}.intg-ext-action-btn.danger:hover{color:var(--color-danger);background:#ef44441a;border-color:#ef44444d}.intg-ext-toggle{cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition);background:0 0;border:none;padding:4px}.intg-ext-toggle.on{color:var(--color-success)}.intg-ext-toggle.off{color:var(--text-muted)}.intg-ext-toggle:hover{opacity:.8}.intg-ext-test-result{border-top:1px solid var(--border);align-items:center;gap:6px;padding:8px 18px;font-size:12px;display:flex}.intg-ext-test-result.ok{color:var(--color-success);background:#10b9810f}.intg-ext-test-result.error{color:var(--color-danger);background:#ef44440f}.intg-ext-tested-at{color:var(--text-muted);font-size:11px}.intg-ext-queries{border-top:1px solid var(--border);flex-wrap:wrap;gap:6px;padding:8px 18px 12px;display:flex}.intg-ext-query-chip{border-radius:999px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:500;display:flex}.intg-ext-query-chip.configured{color:var(--color-success);background:#10b98114;border:1px solid #10b98133}.intg-ext-query-chip.missing{background:var(--bg-secondary);color:var(--text-muted);border:1px solid var(--border)}.intg-ext-modal{flex-direction:column;max-height:90vh;display:flex;overflow:hidden;max-width:720px!important}.intg-ext-modal-tabs{border-bottom:1px solid var(--border);flex-shrink:0;gap:0;padding:0 20px;display:flex}.intg-ext-modal-tab{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 16px;font-size:13px;display:flex}.intg-ext-modal-tab:hover{color:var(--text-primary)}.intg-ext-modal-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.intg-ext-modal-body{flex-direction:column;flex:1;gap:14px;padding:20px;display:flex;overflow-y:auto}.intg-ext-query-hint{color:var(--text-secondary);background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border);padding:10px 14px;font-size:12px;line-height:1.5}.intg-ext-query-hint code{background:var(--bg-input);font-family:var(--font-mono,monospace);border-radius:3px;padding:1px 5px;font-size:11px}.intg-ext-query-group{gap:6px}.intg-ext-query-label-row{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.form-textarea-code{font-family:var(--font-mono,"JetBrains Mono", "Fira Code", monospace);resize:vertical;min-height:70px;font-size:12px}.intg-ext-preview{border-radius:var(--radius-sm);color:var(--color-success);background:#10b9810f;border:1px solid #10b98133;flex-direction:column;gap:4px;padding:8px 10px;font-size:11px;display:flex}.intg-ext-preview.error{color:var(--color-danger);background:#ef44440f;border-color:#ef444433;flex-direction:row;align-items:center;gap:6px;display:flex}.intg-ext-preview-label{align-items:center;gap:5px;font-weight:600;display:flex}.intg-ext-preview-table-wrap{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);max-height:200px;overflow:auto}.intg-ext-preview-table{border-collapse:collapse;width:100%;font-family:var(--font-mono,monospace);color:var(--text-secondary);white-space:nowrap;font-size:11px}.intg-ext-preview-table th{background:var(--bg-secondary);color:var(--text-primary);text-align:left;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.3px;padding:6px 10px;font-size:10px;font-weight:600;position:sticky;top:0}.intg-ext-preview-table td{text-overflow:ellipsis;border-bottom:1px solid #ffffff0a;max-width:220px;padding:5px 10px;overflow:hidden}.intg-ext-preview-table tbody tr:hover{background:var(--bg-hover)}.intg-null{color:var(--text-muted);opacity:.6;font-style:italic}.intg-error-msg{color:var(--color-danger);background:#ef44440f;border-top:1px solid #ef444426;align-items:center;gap:6px;padding:10px 20px;font-size:12px;display:flex}.spin{animation:.8s linear infinite spin-anim}@keyframes spin-anim{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.push-toggle-card{flex-direction:column;gap:12px;display:flex}.push-toggle-header{color:var(--text-primary);align-items:center;gap:8px;display:flex}.push-toggle-title{font-size:14px;font-weight:600}.push-toggle-description{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}.push-toggle-actions{gap:8px;display:flex}.push-toggle-btn{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-input);color:var(--text-primary);cursor:pointer;transition:all var(--transition);font-size:13px;font-weight:500;font-family:var(--font-sans);align-items:center;gap:8px;padding:10px 20px;display:inline-flex}.push-toggle-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:#0ea5e914}.push-toggle-btn.active{color:var(--text-secondary);border-color:#ef44444d}.push-toggle-btn.active:hover:not(:disabled){border-color:var(--color-danger);color:var(--color-danger);background:#ef444414}.push-toggle-btn:disabled{opacity:.6;cursor:not-allowed}.push-toggle-spinner{animation:.8s linear infinite spin-anim}.push-toggle-status{color:var(--text-muted);background:var(--bg-input);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:8px 12px;font-size:12px;display:flex}.push-toggle-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.push-toggle-status[data-status=active] .push-toggle-dot{background:var(--color-success);animation:2s ease-in-out infinite push-pulse;box-shadow:0 0 6px #10b98180}.push-toggle-status[data-status=inactive] .push-toggle-dot{background:var(--text-muted)}.push-toggle-status[data-status=denied] .push-toggle-dot{background:var(--color-danger)}.push-toggle-status[data-status=active]{color:var(--color-success);background:#10b9810f}.push-toggle-status[data-status=denied]{color:var(--color-danger);background:#ef44440f}@keyframes push-pulse{0%,to{opacity:1}50%{opacity:.5}}.schedule-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;justify-content:center;align-items:center;padding:24px;animation:.2s ease-out fade-in;display:flex;position:fixed;inset:0}.schedule-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl,16px);flex-direction:column;width:100%;max-width:580px;max-height:90vh;animation:.25s ease-out modal-slide-up;display:flex;overflow:hidden;box-shadow:0 24px 80px #00000080}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.schedule-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;padding:24px 28px 16px;display:flex}.schedule-modal-title{font-family:var(--font-heading);letter-spacing:-.015em;color:var(--text-primary);margin:0;font-size:18px;font-weight:700}.schedule-modal-subtitle{color:var(--text-secondary);margin:4px 0 0;font-size:13px}.schedule-modal-close{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;padding:4px}.schedule-modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.schedule-modal-body{flex-direction:column;flex:1;gap:18px;padding:24px 28px;display:flex;overflow-y:auto}.schedule-modal-footer{border-top:1px solid var(--border);padding:16px 28px 24px}.schedule-modal-actions{justify-content:flex-end;gap:10px;display:flex}.schedule-field{flex-direction:column;gap:6px;display:flex}.schedule-field-row{gap:12px;display:flex}.schedule-label{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.schedule-input,.schedule-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-family:var(--font-sans);transition:border-color var(--transition);padding:10px 14px}.schedule-input:focus,.schedule-select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #0ea5e91a}.schedule-checkbox-label{color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.schedule-checkbox{accent-color:var(--color-primary);width:16px;height:16px}.schedule-plate{color:var(--text-muted);margin-left:2px;font-size:12px}.schedule-device-grid{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:6px;max-height:160px;padding:8px;display:grid;overflow-y:auto}.schedule-frequency-pills{gap:8px;display:flex}.schedule-pill{border:1px solid var(--border);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:13px;font-weight:500;font-family:var(--font-sans);border-radius:999px;padding:8px 20px}.schedule-pill:hover{border-color:var(--color-primary);color:var(--text-primary)}.schedule-pill.active{border-color:var(--color-primary);color:var(--color-primary);background:#0ea5e91f;font-weight:600}.schedule-recipient-input-row{gap:8px;display:flex}.schedule-add-btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-input);width:42px;height:42px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.schedule-add-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#0ea5e90f}.schedule-recipients-list{flex-wrap:wrap;gap:6px;display:flex}.schedule-recipient-tag{color:var(--color-primary);background:#0ea5e914;border:1px solid #0ea5e933;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:inline-flex}.schedule-recipient-remove{cursor:pointer;color:inherit;opacity:.6;background:0 0;border:none;padding:0;display:flex}.schedule-recipient-remove:hover{opacity:1;color:var(--color-danger)}.schedule-btn-primary{background:linear-gradient(135deg, var(--color-primary), #0096c7);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);font-size:14px;font-weight:600;font-family:var(--font-sans);border:none;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:10px 24px;display:inline-flex}.schedule-btn-primary:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 4px 16px #0ea5e94d}.schedule-btn-primary:disabled{opacity:.6;cursor:not-allowed}.schedule-btn-secondary{background:var(--bg-input);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);font-size:14px;font-weight:500;font-family:var(--font-sans);justify-content:center;align-items:center;min-height:42px;padding:10px 20px;display:inline-flex}.schedule-btn-secondary:hover{color:var(--text-primary);border-color:#0ea5e94d}.schedule-error{color:var(--color-danger);margin:0 0 8px;font-size:13px}.schedules-section{margin-top:24px}.schedules-section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.schedules-section-title{font-family:var(--font-heading);letter-spacing:-.01em;color:var(--text-primary);align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.schedules-empty{color:var(--text-muted);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:40px 20px;display:flex}.schedules-empty p{color:var(--text-secondary);margin:0;font-size:14px;font-weight:600}.schedules-empty span{color:var(--text-muted);font-size:13px}.schedules-list{flex-direction:column;gap:10px;display:flex}.schedule-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), box-shadow var(--transition);overflow:hidden}.schedule-card:hover{border-color:#0ea5e933;box-shadow:0 2px 12px #0000001f}.schedule-card.inactive{opacity:.65}.schedule-card.has-error{border-color:#ef444440}.schedule-card-header{justify-content:space-between;align-items:flex-start;gap:12px;padding:14px 18px;display:flex}.schedule-card-info{flex-direction:column;gap:4px;min-width:0;display:flex}.schedule-card-title-row{align-items:center;gap:10px;display:flex}.schedule-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:14px;font-weight:600;overflow:hidden}.schedule-status-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:999px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.schedule-status-badge.active{color:var(--color-success);background:#10b9811a;border:1px solid #10b98140}.schedule-status-badge.paused{color:var(--color-warning);background:#f59e0b1a;border:1px solid #f59e0b40}.schedule-card-meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.schedule-card-type{color:var(--text-secondary);font-weight:500}.schedule-card-separator{color:var(--border)}.schedule-card-actions{flex-shrink:0;gap:4px;display:flex}.schedule-action-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-secondary);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);justify-content:center;align-items:center;display:flex}.schedule-action-btn:hover{color:var(--text-primary);background:var(--bg-hover);border-color:#0ea5e94d}.schedule-action-btn.danger:hover{color:var(--color-danger);background:#ef444414;border-color:#ef44444d}.schedule-action-btn:disabled{opacity:.5;cursor:not-allowed}.schedule-card-footer{flex-direction:column;gap:8px;padding:0 18px 14px;display:flex}.schedule-card-timing{flex-wrap:wrap;gap:16px;display:flex}.schedule-timing-item{color:var(--text-muted);align-items:center;gap:5px;font-size:11px;display:flex}.schedule-error-banner{border-radius:var(--radius-sm);color:var(--color-danger);background:#ef44440f;border:1px solid #ef444426;align-items:flex-start;gap:6px;padding:8px 12px;font-size:12px;line-height:1.4;display:flex}.schedule-error-banner strong{margin-top:2px;display:block}.schedule-card-recipients{flex-wrap:wrap;gap:4px;display:flex}.schedule-recipient-badge{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-muted);border-radius:999px;padding:2px 8px;font-size:11px}.schedule-recipient-badge.admin{color:var(--color-primary);background:#0ea5e90f;border-color:#0ea5e926;font-weight:500}.schedule-trigger-btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:13px;font-weight:500;font-family:var(--font-sans);align-items:center;gap:6px;padding:8px 16px;display:inline-flex}.schedule-trigger-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#0ea5e90f}@media (max-width:768px){.schedule-modal{border-radius:var(--radius-lg);max-height:95vh;margin:8px}.schedule-field-row{flex-direction:column}.schedule-frequency-pills{flex-wrap:wrap}.schedule-card-header{flex-direction:column;gap:8px}.schedule-card-actions{align-self:flex-end}.schedule-card-timing{flex-direction:column;gap:4px}}.geofence-toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;width:calc(100% - 32px);max-width:400px;display:flex;position:fixed;top:16px;right:16px}.geofence-toast{-webkit-backdrop-filter:blur(16px);cursor:pointer;pointer-events:auto;opacity:0;background:#0f1923eb;border:1px solid #ffffff14;border-radius:14px;align-items:flex-start;gap:12px;padding:14px 16px;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .25s;display:flex;position:relative;overflow:hidden;transform:translate(120%);box-shadow:0 8px 32px #0006,inset 0 0 0 1px #ffffff0a}.geofence-toast.visible{opacity:1;transform:translate(0)}.geofence-toast.exiting{opacity:0;transition:transform .3s cubic-bezier(.4,0,1,1),opacity .2s;transform:translate(120%)}.geofence-toast.enter{border-left:3px solid #0ea5e9}.geofence-toast.enter .geofence-toast-icon{color:#0ea5e9;background:#0ea5e91f}.geofence-toast.enter .geofence-toast-progress{background:linear-gradient(90deg,#0ea5e9,#06b6d4)}.geofence-toast.exit{border-left:3px solid #f59e0b}.geofence-toast.exit .geofence-toast-icon{color:#f59e0b;background:#f59e0b1f}.geofence-toast.exit .geofence-toast-progress{background:linear-gradient(90deg,#f59e0b,#ef4444)}.geofence-toast:hover{border-color:#ffffff26;box-shadow:0 12px 40px #00000080,inset 0 0 0 1px #ffffff0f}.geofence-toast-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.geofence-toast-body{flex:1;min-width:0}.geofence-toast-title{text-transform:uppercase;letter-spacing:.5px;opacity:.7;color:var(--text-secondary,#8ba0c0);margin-bottom:4px;font-size:11px;font-weight:700}.geofence-toast-message{color:var(--text-primary,#e0e8f5);word-break:break-word;font-size:13px;line-height:1.4}.geofence-toast-message strong{color:#fff;font-weight:600}.geofence-toast-fence-name{color:#22d3ee;font-weight:700}.geofence-toast.exit .geofence-toast-fence-name{color:#fbbf24}.geofence-toast-time{color:var(--text-muted,#3a5a7a);margin-top:4px;font-size:11px}.geofence-toast-close{width:24px;height:24px;color:var(--text-muted,#3a5a7a);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-top:-2px;transition:all .15s;display:flex}.geofence-toast-close:hover{color:var(--text-primary,#e0e8f5);background:#ffffff1a}.geofence-toast-progress{transform-origin:0;width:100%;height:2px;animation:8s linear forwards geofence-toast-countdown;position:absolute;bottom:0;left:0}@keyframes geofence-toast-countdown{0%{transform:scaleX(1)}to{transform:scaleX(0)}}[data-theme=light] .geofence-toast{background:#fffffff2;border-color:#00000014;box-shadow:0 8px 32px #0000001f,inset 0 0 0 1px #0000000a}[data-theme=light] .geofence-toast:hover{border-color:#00000026;box-shadow:0 12px 40px #0000002e,inset 0 0 0 1px #0000000f}[data-theme=light] .geofence-toast-message strong{color:#0f172a}[data-theme=light] .geofence-toast-fence-name{color:#0284c7}[data-theme=light] .geofence-toast.exit .geofence-toast-fence-name{color:#d97706}@media (max-width:768px){.geofence-toast-container{width:auto;max-width:none;top:8px;left:8px;right:8px}.geofence-toast{border-radius:12px;padding:12px 14px}}
