.not-found[data-v-ea511d48]{display:grid;gap:1rem;justify-items:start}.not-found h1[data-v-ea511d48]{font-size:clamp(3rem,5vw,4rem);margin:0}.not-found a[data-v-ea511d48]{color:#60a5fa;text-decoration:none}.connection-status[data-v-44956ddc]{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:999px;font-size:.8rem;font-weight:600;background:var(--input-bg, rgba(255, 255, 255, .08));color:inherit;transition:background .2s ease,transform .1s ease;cursor:pointer;border:1px solid transparent}.connection-status[data-v-44956ddc]:hover{background:var(--input-bg-hover, rgba(255, 255, 255, .12));transform:scale(1.02)}.connection-status[data-v-44956ddc]:active{transform:scale(.98)}.connection-status--connecting[data-v-44956ddc]{cursor:default;opacity:.7}.connection-status--connecting[data-v-44956ddc]:hover{background:var(--input-bg, rgba(255, 255, 255, .08));transform:none}.connection-status__indicator[data-v-44956ddc]{width:10px;height:10px;border-radius:50%;background:var(--status-offline, #ff5d5d);box-shadow:0 0 6px currentColor;transition:background .2s ease}.connection-status--connected .connection-status__indicator[data-v-44956ddc]{background:var(--status-online, #4ade80)}.connection-status--connecting .connection-status__indicator[data-v-44956ddc],.connection-status--reconnecting .connection-status__indicator[data-v-44956ddc]{background:var(--status-connecting, #facc15)}.connection-status--paused .connection-status__indicator[data-v-44956ddc]{background:var(--status-paused, #94a3b8)}.connection-status__indicator--pulse[data-v-44956ddc]{animation:pulse-44956ddc 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse-44956ddc{0%,to{opacity:1}50%{opacity:.5}}.password-input-wrapper[data-v-6e92c578]{position:relative;width:100%;display:flex;align-items:center}.password-input-wrapper input[data-v-6e92c578]{width:100%;padding:.75rem 3rem .75rem .75rem;background:var(--input-bg, #2a2a2a);border:1px solid var(--border-color, #444);border-radius:4px;color:var(--text-primary, #fff);font-size:1rem;transition:all .2s}.password-input-wrapper input[data-v-6e92c578]:focus{outline:none;border-color:var(--primary-color, #007bff);box-shadow:0 0 0 2px #007bff1a}.password-input-wrapper input[data-v-6e92c578]:disabled{opacity:.5;cursor:not-allowed}.password-toggle[data-v-6e92c578]{position:absolute;right:.75rem;background:none;border:none;color:var(--text-secondary, #999);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color .2s;outline:none;z-index:1}.password-toggle[data-v-6e92c578]:hover{color:var(--text-primary, #fff)}.password-toggle[data-v-6e92c578]:focus-visible{color:var(--text-primary, #fff);outline:2px solid var(--primary-color, #007bff);outline-offset:2px;border-radius:4px}.password-toggle svg[data-v-6e92c578]{display:block}.modal-backdrop[data-v-48b5803f]{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.modal-container[data-v-48b5803f]{position:relative;background:linear-gradient(135deg,#121522fa,#121522f2);border:1px solid rgba(99,102,241,.2);border-radius:16px;box-shadow:0 20px 60px #00000080,0 0 0 1px #ffffff0d;max-width:440px;width:100%;overflow:hidden}.modal-close[data-v-48b5803f]{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#ffffffb3;font-size:1.25rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;z-index:1}.modal-close[data-v-48b5803f]:hover{background:#ffffff1a;border-color:#fff3;color:#fff;transform:rotate(90deg)}.modal-content[data-v-48b5803f]{padding:2rem}.modal-header[data-v-48b5803f]{text-align:center;margin-bottom:2rem}.modal-header h2[data-v-48b5803f]{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,#6366f1,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.modal-header p[data-v-48b5803f]{font-size:.9rem;color:#fff9}.login-form[data-v-48b5803f]{display:flex;flex-direction:column;gap:1.25rem}.form-group[data-v-48b5803f]{display:flex;flex-direction:column;gap:.5rem}.form-group label[data-v-48b5803f]{font-size:.875rem;font-weight:600;color:#ffffffe6}.form-group input[data-v-48b5803f]{padding:.75rem 1rem;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#fff;font-size:.95rem;transition:all .2s ease}.form-group input[data-v-48b5803f]:focus{outline:none;border-color:#6366f180;background:#ffffff14;box-shadow:0 0 0 3px #6366f11a}.form-group input[data-v-48b5803f]:disabled{opacity:.5;cursor:not-allowed}.form-group input[data-v-48b5803f]::-moz-placeholder{color:#ffffff4d}.form-group input[data-v-48b5803f]::placeholder{color:#ffffff4d}.btn-primary[data-v-48b5803f]{padding:.875rem 1.5rem;border-radius:10px;border:none;background:linear-gradient(135deg,#6366f1,#3b82f6);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.btn-primary[data-v-48b5803f]:hover:not(:disabled){background:linear-gradient(135deg,#5558e3,#2c73e8);transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.btn-primary[data-v-48b5803f]:active:not(:disabled){transform:translateY(0)}.btn-primary[data-v-48b5803f]:disabled{opacity:.7;cursor:not-allowed}.error-message[data-v-48b5803f]{color:#ef4444;font-size:.875rem;text-align:center;padding:.75rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:8px;margin:0}.modal-enter-active[data-v-48b5803f],.modal-leave-active[data-v-48b5803f]{transition:opacity .25s ease}.modal-enter-active .modal-container[data-v-48b5803f],.modal-leave-active .modal-container[data-v-48b5803f]{transition:transform .25s ease,opacity .25s ease}.modal-enter-from[data-v-48b5803f],.modal-leave-to[data-v-48b5803f]{opacity:0}.modal-enter-from .modal-container[data-v-48b5803f],.modal-leave-to .modal-container[data-v-48b5803f]{opacity:0;transform:scale(.95) translateY(-20px)}.app-header[data-v-85d09543]{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;background:var(--surface-panel, linear-gradient(135deg, rgba(18, 21, 34, .96), rgba(18, 21, 34, .72)));box-shadow:inset 0 -1px 0 var(--border-color, rgba(255, 255, 255, .06));transition:background .3s ease,box-shadow .3s ease}.app-header__toggle[data-v-85d09543]{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;border:1px solid var(--border-color, rgba(255, 255, 255, .08));background:var(--input-bg, rgba(255, 255, 255, .08));color:inherit;cursor:pointer;transition:background .2s ease,border-color .2s ease}.app-header__toggle[data-v-85d09543]:hover{background:#6366f11f;border-color:#6366f14d}.app-header__toggle-icon[data-v-85d09543]{width:22px;height:2px;background:currentColor;position:relative}.app-header__toggle-icon[data-v-85d09543]:before,.app-header__toggle-icon[data-v-85d09543]:after{content:"";position:absolute;left:0;width:100%;height:100%;background:currentColor}.app-header__toggle-icon[data-v-85d09543]:before{transform:translateY(-7px)}.app-header__toggle-icon[data-v-85d09543]:after{transform:translateY(7px)}.app-header__brand[data-v-85d09543]{display:grid;gap:.125rem;font-size:1.125rem}.app-header__env[data-v-85d09543]{font-size:.75rem;color:var(--text-secondary, rgba(255, 255, 255, .68))}.app-header__actions[data-v-85d09543]{display:flex;align-items:center;gap:.5rem;margin-left:auto}.app-header__action[data-v-85d09543]{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:999px;border:1px solid var(--border-color, rgba(255, 255, 255, .08));background:var(--input-bg, rgba(255, 255, 255, .06));color:inherit;cursor:pointer;transition:background .12s ease-in-out,border .12s ease-in-out;text-decoration:none}.app-header__badge[data-v-85d09543]{min-width:20px;padding:0 .45rem;border-radius:999px;background:#ef4444;color:#fff;font-size:.75rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center}.app-header__action[data-v-85d09543]:hover{background:#ffffff1f;border-color:#ffffff29}.app-header__action-icon[data-v-85d09543]{width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#6d5dfc,#3ba6ff);position:relative}.app-header__action-icon[data-theme=light][data-v-85d09543]{background:linear-gradient(135deg,#ffb347,#fc3)}.app-header__action-label[data-v-85d09543]{font-size:.85rem;font-weight:600}.app-header__login[data-v-85d09543]{background:linear-gradient(135deg,#6366f1,#3b82f6);border-color:transparent;color:#fff}.app-header__login[data-v-85d09543]:hover{background:linear-gradient(135deg,#5558e3,#2c73e8);border-color:transparent}.app-header__profile[data-v-85d09543]{position:relative}.app-header__profile-button[data-v-85d09543]{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .75rem .35rem .35rem;border-radius:999px;border:1px solid var(--border-color, rgba(255, 255, 255, .08));background:var(--input-bg, rgba(255, 255, 255, .06));color:inherit;cursor:pointer;transition:background .12s ease-in-out,border .12s ease-in-out}.app-header__profile-button[data-v-85d09543]:hover{background:#ffffff1f;border-color:#ffffff29}.app-header__profile-avatar[data-v-85d09543]{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#3b82f6);color:#fff;font-size:.75rem;font-weight:700}.app-header__profile-name[data-v-85d09543]{font-size:.85rem;font-weight:600}.app-header__profile-arrow[data-v-85d09543]{font-size:.6rem;transition:transform .2s ease;color:var(--text-secondary, rgba(255, 255, 255, .6))}.app-header__profile-arrow--open[data-v-85d09543]{transform:rotate(180deg)}.app-header__profile-dropdown[data-v-85d09543]{position:absolute;top:calc(100% + .5rem);right:0;min-width:200px;background:var(--surface-panel, rgba(18, 21, 34, .98));border:1px solid var(--border-color, rgba(255, 255, 255, .12));border-radius:12px;box-shadow:0 8px 24px #0006;padding:.5rem;z-index:1000;animation:slideDown-85d09543 .2s ease}@keyframes slideDown-85d09543{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.app-header__profile-info[data-v-85d09543]{display:flex;flex-direction:column;gap:.25rem;padding:.75rem}.app-header__profile-info strong[data-v-85d09543]{font-size:.9rem}.app-header__profile-badge[data-v-85d09543]{display:inline-block;padding:.125rem .5rem;border-radius:999px;font-size:.7rem;font-weight:700;text-transform:uppercase;background:linear-gradient(135deg,#6366f1,#3b82f6);color:#fff;width:-moz-fit-content;width:fit-content}.app-header__profile-badge--user[data-v-85d09543]{background:linear-gradient(135deg,#64748b,#475569)}.app-header__profile-divider[data-v-85d09543]{border:none;border-top:1px solid var(--border-color, rgba(255, 255, 255, .08));margin:.25rem 0}.app-header__profile-menu-item[data-v-85d09543]{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;border-radius:8px;border:none;background:transparent;color:inherit;cursor:pointer;font-size:.875rem;text-align:left;transition:background .12s ease}.app-header__profile-menu-item[data-v-85d09543]:hover{background:#ffffff14}.app-header__profile-menu-item span[data-v-85d09543]:first-child{font-size:1.1rem}.sidebar[data-v-f186cf71]{display:grid;gap:1.5rem;padding:2rem 1.25rem;color:var(--text-secondary, rgba(255, 255, 255, .78));font-size:.92rem}.sidebar__section[data-v-f186cf71]{list-style:none;display:grid;gap:.25rem;padding:0;margin:0}.sidebar__section-header[data-v-f186cf71]{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary, rgba(255, 255, 255, .58))}.sidebar__link[data-v-f186cf71]{display:flex;align-items:center;gap:.8rem;padding:.65rem .9rem;border-radius:10px;color:inherit;text-decoration:none;transition:background-color .12s ease,color .12s ease}.sidebar__link[data-v-f186cf71]:hover{background:var(--input-bg, rgba(255, 255, 255, .08));color:var(--text-primary, #fff)}.sidebar__link--active[data-v-f186cf71]{background:#6366f129;color:var(--text-primary, #fff);box-shadow:inset 0 0 0 1px #6366f140}.sidebar__icon[data-v-f186cf71]{width:18px;height:18px;border-radius:4px;background:var(--border-color, rgba(255, 255, 255, .14));position:relative}.sidebar__label[data-v-f186cf71]{font-weight:600}.event-log[data-v-a080483d]{position:absolute;right:1.5rem;bottom:1.5rem;width:min(420px,90vw);max-height:min(65vh,720px);background:var(--surface-panel, rgba(10, 12, 18, .92));-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:16px;border:1px solid var(--border-color, rgba(255, 255, 255, .08));box-shadow:0 18px 40px #00000052;display:grid;grid-template-rows:auto 1fr;transform:translateY(110%);transition:transform .2s ease,opacity .2s ease;pointer-events:none;opacity:0}.event-log--open[data-v-a080483d]{transform:translateY(0);pointer-events:auto;opacity:1}.event-log__header[data-v-a080483d]{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border-color, rgba(255, 255, 255, .08))}.event-log__header h2[data-v-a080483d]{font-size:.85rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-secondary, rgba(255, 255, 255, .74));margin:0}.event-log__close[data-v-a080483d]{border:none;background:transparent;color:inherit;font-size:1.5rem;cursor:pointer}.event-log__content[data-v-a080483d]{padding:.75rem 1rem;overflow-y:auto}.event-log__list[data-v-a080483d]{margin:0;padding:0;list-style:none;display:grid;gap:.75rem}.event-log__item[data-v-a080483d]{display:grid;gap:.35rem;padding:.75rem;border-radius:12px;background:var(--surface-elevated, rgba(255, 255, 255, .05));border:1px solid var(--border-color, rgba(255, 255, 255, .08))}.event-log__item[data-severity=emergency][data-v-a080483d]{border-color:#ef444499;background:linear-gradient(145deg,#ef444429,#18161666)}.event-log__item[data-severity=warning][data-v-a080483d]{border-color:#fdba7473;background:linear-gradient(145deg,#fdba741f,#18161266)}.event-log__item-header[data-v-a080483d]{display:flex;align-items:center;gap:.75rem}.event-log__badge[data-v-a080483d]{width:10px;height:10px;border-radius:50%;background:var(--accent-color, #8b5cf6);flex-shrink:0}.event-log__item[data-severity=emergency] .event-log__badge[data-v-a080483d]{background:#ef4444}.event-log__item[data-severity=warning] .event-log__badge[data-v-a080483d]{background:#f97316}.event-log__item-meta[data-v-a080483d]{display:flex;flex-direction:column;gap:.125rem}.event-log__item-title[data-v-a080483d]{font-size:.95rem}.event-log__item-time[data-v-a080483d]{font-size:.75rem;color:var(--text-secondary, rgba(255, 255, 255, .6))}.event-log__item-message[data-v-a080483d]{margin:0;font-size:.85rem;color:var(--text-primary, rgba(255, 255, 255, .92))}.event-log__empty[data-v-a080483d]{margin:0;font-size:.85rem;color:var(--text-secondary, rgba(255, 255, 255, .68))}.app-shell[data-v-f560dafe]{display:grid;grid-template-rows:auto 1fr;min-height:100vh;background-color:var(--surface-base, #0f111a);color:var(--text-primary, #ffffff);transition:background-color .3s ease,color .3s ease}.app-shell__body[data-v-f560dafe]{display:grid;grid-template-columns:280px minmax(0,1fr);position:relative}.app-shell__sidebar[data-v-f560dafe]{background:var(--surface-panel, rgba(24, 27, 41, .95));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:width .2s ease-in-out,background .3s ease;overflow:hidden;border-right:1px solid var(--border-color, rgba(255, 255, 255, .06))}.app-shell__sidebar--collapsed[data-v-f560dafe]{width:0}.app-shell__content[data-v-f560dafe]{position:relative;padding:1.5rem;overflow:hidden auto}.app-shell__header[data-v-f560dafe]{position:sticky;top:0;z-index:10}@media (max-width: 1024px){.app-shell__body[data-v-f560dafe]{grid-template-columns:minmax(0,1fr)}.app-shell__sidebar[data-v-f560dafe]{position:absolute;inset:0 auto 0 0;width:min(320px,80vw);box-shadow:var(--shadow-lg, 0 14px 28px rgba(0, 0, 0, .25));z-index:20}.app-shell__sidebar--collapsed[data-v-f560dafe]{transform:translate(-100%)}}.toast-container[data-v-b932de09]{position:fixed;top:1rem;right:1rem;z-index:10000;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast[data-v-b932de09]{min-width:320px;max-width:500px;padding:1rem 1.25rem;background:#171a28f2;border:1px solid rgba(255,255,255,.1);border-radius:8px;box-shadow:0 10px 25px #00000080;display:flex;align-items:center;justify-content:space-between;gap:1rem;pointer-events:auto;cursor:pointer;transition:transform .2s ease,opacity .2s ease}.toast[data-v-b932de09]:hover{transform:translate(-4px)}.toast--info[data-v-b932de09]{border-left:4px solid #3b82f6}.toast--success[data-v-b932de09]{border-left:4px solid #10b981}.toast--warning[data-v-b932de09]{border-left:4px solid var(--status-button-alert-color);box-shadow:0 10px 25px var(--status-button-alert-glow)}.toast--error[data-v-b932de09]{border-left:4px solid #ef4444}.toast__message[data-v-b932de09]{flex:1;font-size:.9rem;line-height:1.5}.toast__close[data-v-b932de09]{background:none;border:none;color:#fff9;font-size:1.2rem;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s ease}.toast__close[data-v-b932de09]:hover{color:#fff}.toast-enter-active[data-v-b932de09],.toast-leave-active[data-v-b932de09]{transition:all .3s ease}.toast-enter-from[data-v-b932de09],.toast-leave-to[data-v-b932de09]{opacity:0;transform:translate(100%)}:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--surface-base: #f8fafc;--surface-panel: rgba(255, 255, 255, .95);--text-primary: #697287;--text-secondary: #64748b;--text-tertiary: #475569;--text-accent: #3b82f6;--border-color: rgba(15, 23, 42, .12);--shadow-color: rgba(0, 0, 0, .1);--input-bg: #ffffff;--input-border: #cbd5e1;--link-color: #667eea;--status-connected-bg: rgba(34, 197, 94, .1);--status-connected-color: #15803d;--status-disconnected-bg: rgba(239, 68, 68, .1);--status-disconnected-color: #dc2626;--device-card-bg: #ffffff;--device-card-border: rgba(15, 23, 42, .12);--device-card-shadow: 0 1px 3px rgba(15, 23, 42, .08), 0 1px 2px rgba(15, 23, 42, .06);--device-card-hover-shadow: 0 10px 25px rgba(15, 23, 42, .12), 0 4px 8px rgba(15, 23, 42, .08);--status-absent-bg: rgba(156, 163, 175, .15);--status-absent-color: #4b5563;--status-moving-bg: rgba(59, 130, 246, .1);--status-moving-color: #1d4ed8;--status-new-color: #059669;--status-departed-color: #dc2626;--status-button-alert-bg: rgba(245, 158, 11, .12);--status-button-alert-glow: rgba(245, 158, 11, .25);--status-button-alert-color: #b45309}[data-theme=dark]{--bg-primary: #0f111a;--bg-secondary: rgba(24, 27, 41, .95);--bg-tertiary: rgba(23, 26, 40, .9);--surface-base: #0f111a;--surface-panel: rgba(24, 27, 41, .95);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .6);--text-tertiary: rgba(255, 255, 255, .7);--text-accent: #818cf8;--border-color: rgba(255, 255, 255, .08);--shadow-color: rgba(0, 0, 0, .4);--input-bg: rgba(23, 26, 40, .9);--input-border: rgba(255, 255, 255, .1);--link-color: #818cf8;--status-connected-bg: rgba(34, 197, 94, .2);--status-connected-color: #4ade80;--status-disconnected-bg: rgba(239, 68, 68, .2);--status-disconnected-color: #f87171;--device-card-bg: rgba(23, 26, 40, .9);--device-card-border: rgba(255, 255, 255, .06);--device-card-shadow: 0 4px 6px rgba(0, 0, 0, .3);--device-card-hover-shadow: 0 10px 25px rgba(0, 0, 0, .4);--status-absent-bg: rgba(156, 163, 175, .2);--status-absent-color: #d1d5db;--status-moving-bg: rgba(59, 130, 246, .2);--status-moving-color: #60a5fa;--status-new-color: #10b981;--status-departed-color: #ef4444;--status-button-alert-bg: rgba(251, 191, 36, .18);--status-button-alert-glow: rgba(251, 191, 36, .35);--status-button-alert-color: #facc15}[data-theme=dark] .search-highlight{background-color:#451a03;color:#fbbf24}[data-theme=dark] .chart-container{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px}.flex{display:flex}.flex-column{display:flex;flex-direction:column}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-start{display:flex;justify-content:flex-start;align-items:center}.align-center{align-items:center}.align-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.rounded-sm{border-radius:4px}.rounded{border-radius:6px}.rounded-md{border-radius:8px}.rounded-lg{border-radius:12px}.rounded-xl{border-radius:16px}.rounded-full{border-radius:50%}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.px-2{padding-left:1rem;padding-right:1rem}.py-2{padding-top:1rem;padding-bottom:1rem}.m-1{margin:.5rem}.m-2{margin:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mt-2{margin-top:1rem}.shadow-sm{box-shadow:0 1px 3px var(--shadow-color)}.shadow{box-shadow:0 2px 6px var(--shadow-color)}.shadow-md{box-shadow:0 4px 12px var(--shadow-color)}.shadow-device{box-shadow:var(--device-card-shadow)}.text-center{text-align:center}.text-small{font-size:.875rem}.text-xs{font-size:.75rem}.font-bold{font-weight:700}.relative{position:relative}.absolute{position:absolute}.z-1{z-index:1}.z-2{z-index:2}.fixed{position:fixed}.w-full{width:100%}.max-w-full{max-width:100%}.h-full{height:100%}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.transition{transition:all .3s ease}.transition-colors{transition:background-color .3s ease,border-color .3s ease,color .3s ease}.transition-shadow{transition:box-shadow .3s ease}.cursor-grab{cursor:grab}.flex-wrap{flex-wrap:wrap}.gap-2{gap:8px}.mt-1{margin-top:.5rem}.inset-0{top:0;right:0;bottom:0;left:0}.pe-none{pointer-events:none}.border-dark{border:1px solid #2d2d32}.bg-black{background:#000}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;color:var(--text-primary);background-color:var(--bg-primary);transition:background-color .3s ease,color .3s ease}.dashboard{display:grid;grid-template-columns:300px 1fr;grid-template-rows:60px 1fr;grid-template-areas:"sidebar header" "sidebar main";height:100vh}.header{grid-area:header;background:var(--bg-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;border-bottom:1px solid var(--border-color);box-shadow:0 2px 10px var(--shadow-color);transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease;z-index:1000;position:relative}.header h1{font-size:1.5rem;font-weight:600;color:var(--text-tertiary)}.header-controls{display:flex;align-items:center;gap:1rem;position:relative}.sidebar{grid-area:sidebar;background:var(--bg-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-right:1px solid var(--border-color);padding:1.5rem;overflow-y:auto;transition:background-color .3s ease,border-color .3s ease}.main-content{grid-area:main;padding:2rem;overflow:scroll;display:flex;flex-direction:column;position:relative;background-color:var(--bg-primary);transition:background-color .3s ease}.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;color:var(--text-primary)}.shadow-safe-wrapper{position:relative;overflow:visible}.view-toggle{display:flex;background:var(--bg-secondary);border-radius:8px;overflow:hidden;box-shadow:0 2px 8px var(--shadow-color)}.view-toggle button{padding:.5rem 1rem;border:none;background:transparent;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;color:var(--text-primary)}.view-toggle button.active{background:#667eea;color:#fff}.stats-section{margin-top:2rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;transition:background-color .3s ease}.stats-section h3{font-size:.875rem;font-weight:600;margin-bottom:.75rem;color:var(--text-accent)}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0;font-size:.75rem;color:var(--text-secondary)}.stat-value{font-weight:600;color:var(--text-accent)}.connection-status{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease}.connection-status.connected{background:var(--status-connected-bg);color:var(--status-connected-color)}.connection-status.disconnected{background:var(--status-disconnected-bg);color:var(--status-disconnected-color)}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-indicator{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.status-indicator.present,.status-indicator.connected{background:var(--status-connected-bg);color:var(--status-connected-color)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-accent);cursor:pointer;transition:all .3s ease;font-size:1.2rem;-webkit-user-select:none;-moz-user-select:none;user-select:none}.theme-toggle:hover{background:var(--text-accent);color:var(--bg-primary);transform:scale(1.05);box-shadow:0 4px 12px #6366f14d}.theme-toggle:active{transform:scale(.95)}.theme-toggle:focus{outline:none;box-shadow:0 0 0 3px #6366f14d}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}.device-card *,.search-highlight,.status-dot{transition:none}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-secondary)}.loading-spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top:3px solid var(--text-accent);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{background:var(--status-disconnected-bg);color:var(--status-disconnected-color);padding:1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid #ef4444}@media (max-width: 768px){.dashboard{grid-template-columns:1fr;grid-template-rows:60px auto 1fr;grid-template-areas:"header" "sidebar" "main"}.sidebar{overflow-y:auto}.header-controls{gap:.5rem}}[data-theme=dark] ::-webkit-scrollbar{width:8px}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--bg-primary)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.pause-button{width:100%;padding:8px 12px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s ease;margin-top:5px}.pause-button:hover{background:#0056b3}.pause-button.paused{background:#28a745}.pause-button.paused:hover{background:#1e7e34}.device-grid{display:none;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;flex:1;overflow-y:auto;padding:1rem;margin:-.5rem;contain:layout style paint;position:relative;z-index:1}.device-grid.active{display:grid}.device-list{display:none;flex-direction:column;gap:.5rem;flex:1;overflow-y:auto;padding:1rem;margin:-.5rem;contain:layout style paint;position:relative;z-index:1}.device-list.active{display:flex}.device-map{display:none;flex:1;height:100%;border-radius:12px;overflow:hidden;border:1px solid rgba(0,0,0,.1);box-shadow:0 4px 20px #0000001a}.device-map.active{display:block}#filtersSection{display:none}#filtersSection.active{display:block}#searchFilterSection{display:none}#searchFilterSection.active{display:block}.content-header{display:none}.content-header.active{display:flex}#deviceDetailView{display:none}#deviceDetailView.active{display:block}#gatewayDetailView{display:none}#gatewayDetailView.active{display:block}#gatewayView{display:none}#gatewayView.active{display:flex}#adminView{display:none}#adminView.active{display:flex}#liveTrackingSection{display:none}#liveTrackingSection.active{display:block}.device-card{background:var(--device-card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;border:1px solid var(--device-card-border);padding:1.5rem;box-shadow:var(--device-card-shadow);transition:all .3s ease;height:-moz-fit-content;height:fit-content;transform:translateZ(0);will-change:transform,box-shadow;position:relative;z-index:2}.device-card:hover{transform:translateY(-2px) translateZ(0);box-shadow:var(--device-card-hover-shadow);z-index:3}.device-card.new-device{animation:deviceAppear .6s ease-out;border-left:4px solid var(--status-new-color)}.device-card.button-press-alert{border-left:4px solid var(--status-button-alert-color);box-shadow:0 12px 30px var(--status-button-alert-glow);animation:buttonPressPulse 1.2s ease-out}.device-list-item.button-press-alert{border-left:4px solid var(--status-button-alert-color);background:linear-gradient(90deg,var(--status-button-alert-bg),transparent 65%);box-shadow:0 0 0 2px var(--status-button-alert-glow);animation:buttonPressPulse 1.2s ease-out}.custom-marker.marker-highlight{z-index:10000!important}.custom-marker.marker-highlight>.map-marker-dot{animation:mapMarkerPulse 1.4s ease-out 0s 3;box-shadow:0 0 0 0 var(--status-button-alert-glow, rgba(245, 158, 11, .35));transform-origin:center}.device-card.departed{opacity:.6;border-left:4px solid var(--status-departed-color)}.device-card.inactive{opacity:.4}@keyframes deviceAppear{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes mapMarkerPulse{0%{transform:scale(1);box-shadow:0 0 0 0 var(--status-button-alert-glow, rgba(245, 158, 11, .45))}60%{transform:scale(1.6);box-shadow:0 0 0 16px #f59e0b00}to{transform:scale(1);box-shadow:0 0 #f59e0b00}}.device-header{margin-bottom:1rem}.device-name{font-size:1.125rem;font-weight:600;color:var(--text-tertiary);margin-bottom:.25rem}.device-type{font-size:.875rem;color:var(--text-secondary)}.device-status{gap:.5rem;font-size:.75rem;font-weight:500;padding:.25rem .75rem;border-radius:12px}.device-status.present{background:var(--status-connected-bg);color:var(--status-connected-color)}.device-status.absent{background:var(--status-absent-bg);color:var(--status-absent-color)}.device-status.moving{background:var(--status-moving-bg);color:var(--status-moving-color)}.device-details{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}.device-details .detail-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.device-details .detail-item:last-child{border-bottom:none}.device-details .detail-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.device-details .detail-value{font-size:.875rem;color:var(--text-primary);font-weight:600}.device-list .device-card{display:flex;align-items:center;padding:1rem;min-height:auto}.device-list .device-header{flex:1;margin-bottom:0}.device-list .device-details{display:flex;gap:2rem;margin-top:0;align-items:center}.device-list .manufacturer-specific{margin-top:0;margin-left:1rem}.ble-enhanced{display:inline-block;font-size:.75rem;color:#10b981;margin-left:.25rem;cursor:help;animation:pulse-subtle 2s infinite}@keyframes pulse-subtle{0%,to{opacity:.8}50%{opacity:1}}.detail-group{display:flex;flex-direction:column;gap:.5rem}.detail-item{display:flex;justify-content:space-between;align-items:center;font-size:.75rem}.detail-label{color:#6b7280;font-weight:500}.detail-value{color:#374151;font-weight:600}.rssi-bar{width:60px;height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden}.rssi-fill{height:100%;border-radius:2px;transition:all .3s ease}.rssi-display{display:flex;align-items:center;gap:6px}.rssi-display .rssi-bar{width:40px;height:4px;background:var(--input-border);border-radius:2px;overflow:hidden}.rssi-display .rssi-text{font-size:.75rem;font-weight:600;color:var(--text-tertiary)}.battery-indicator{display:flex;align-items:center;gap:.5rem}.battery-bar{width:30px;height:12px;border:1px solid #d1d5db;border-radius:2px;overflow:hidden;position:relative}.battery-fill{height:100%;transition:all .3s ease;border-radius:1px}.battery-text{font-size:.75rem;font-weight:600}.manufacturer-specific{margin-top:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.manufacturer-specific h4{font-size:.875rem;font-weight:600;margin-bottom:.75rem;color:var(--text-accent)}.bxp-sensors{margin-top:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.bxp-sensors h4{font-size:.875rem;font-weight:600;margin-bottom:.75rem;color:var(--text-accent)}.filter-section{margin-bottom:2rem}.filter-section h3{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text-secondary)}.filter-group{margin-bottom:1rem}.filter-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--text-tertiary)}.filter-group select,.filter-group input{width:100%;padding:.5rem;border:1px solid var(--input-border);border-radius:6px;font-size:.875rem;background:var(--input-bg);color:var(--text-primary);transition:border-color .3s ease,background-color .3s ease}.filter-group select:focus,.filter-group input:focus{outline:none;border-color:var(--text-accent);box-shadow:0 0 0 2px #6366f133}.filter-group input[type=checkbox]{width:auto;margin-right:.5rem}.filter-group a{color:var(--link-color)!important;text-decoration:none!important;font-weight:500;transition:color .3s ease}.filter-group a:hover{color:var(--text-accent)!important}.form-control{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.form-control input[type=checkbox]{width:auto;margin:0;accent-color:var(--text-accent)}.form-control label{color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer}.btn-primary{background:var(--text-accent);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .3s ease}.btn-primary:hover{background:#5b5fc7}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--text-accent)}.search-filter-section{margin-bottom:1.5rem;background:var(--bg-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;border:1px solid var(--border-color);padding:1.5rem;box-shadow:0 4px 20px var(--shadow-color);transform:translateZ(0);will-change:transform,box-shadow;transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease}.search-container{display:flex;flex-direction:column;gap:1rem}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:.875rem 3rem .875rem 1rem;border:2px solid var(--input-border);border-radius:8px;font-size:1rem;background:var(--input-bg);color:var(--text-primary);transition:all .2s ease;box-shadow:0 2px 4px var(--shadow-color)}.search-input:focus{outline:none;border-color:var(--link-color);box-shadow:0 0 0 3px #667eea1a}.search-input::-moz-placeholder{color:var(--text-secondary)}.search-input::placeholder{color:var(--text-secondary)}.clear-search-btn{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:var(--bg-tertiary);border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.75rem;color:var(--text-secondary);transition:all .2s ease}.clear-search-btn:hover{background:var(--text-secondary);color:var(--bg-primary)}.search-stats{display:flex;align-items:center;justify-content:space-between;font-size:.875rem;color:var(--text-secondary)}.search-results-highlight{color:var(--link-color);font-weight:500}.search-highlight{background-color:var(--bg-tertiary);color:var(--text-accent);padding:.125rem .25rem;border-radius:.25rem;font-weight:600}@media (max-width: 768px){.device-grid{grid-template-columns:1fr;gap:.75rem;padding:.75rem}.search-filter-section{padding:1rem;margin-bottom:1rem}.search-input{font-size:16px;padding:.75rem}.search-stats{font-size:.75rem}}@media (min-width: 1200px){.device-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}[data-theme=dark] .search-input{color:var(--text-primary)}[data-theme=dark] .search-input::-moz-placeholder{color:var(--text-secondary)}[data-theme=dark] .search-input::placeholder{color:var(--text-secondary)}[data-theme=dark] .clear-search-btn{background:var(--bg-tertiary);color:var(--text-secondary)}[data-theme=dark] .clear-search-btn:hover{background:var(--text-secondary);color:var(--bg-primary)}.user-management-admin-wrapper{display:flex;flex-direction:column;gap:1rem}.user-management-root{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;min-height:320px}.user-management-main-view{margin-top:1rem}.um-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.um-controls{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.um-controls input,.um-controls select{min-width:160px;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary)}.um-btn{border:1px solid transparent;border-radius:6px;padding:.35rem .75rem;font-size:.9rem;cursor:pointer;transition:all .2s ease}.um-btn.primary{background:var(--primary-color);color:#fff}.um-btn.primary:hover{filter:brightness(1.05)}.um-btn.ghost{background:transparent;border-color:var(--border-color);color:var(--text-primary)}.um-btn.ghost:hover{border-color:var(--primary-color);color:var(--primary-color)}.um-btn.danger{background:transparent;border-color:#ef4444;color:#ef4444}.um-btn.danger:hover{background:#ef44441a}.um-btn:disabled{opacity:.5;cursor:not-allowed}.um-table-wrapper{position:relative}.um-table{width:100%;border-collapse:collapse}.um-table thead th{text-align:left;padding:.75rem;border-bottom:1px solid var(--border-color);font-weight:600;font-size:.85rem;text-transform:uppercase;color:var(--text-secondary)}.um-table tbody td{padding:.75rem;border-bottom:1px solid var(--border-color);font-size:.9rem}.um-table tbody tr:hover{background:#3b82f60d}.um-actions{display:flex;gap:.5rem;flex-wrap:wrap}.um-role{display:inline-flex;align-items:center;padding:.1rem .5rem;border-radius:999px;font-size:.75rem;text-transform:capitalize;background:#3b82f626;color:var(--primary-color)}.um-role-admin{background:#22c55e26;color:#22c55e}.um-role-operator{background:#3b82f626;color:var(--primary-color)}.um-role-viewer{background:#6b728033;color:var(--text-secondary)}.um-status{font-weight:600}.um-status.active{color:#22c55e}.um-status.inactive{color:#ef4444}.um-pagination{margin-top:1rem;display:flex;align-items:center;gap:1rem;justify-content:flex-end}.um-page-info{font-size:.85rem;color:var(--text-secondary)}.um-empty{padding:2rem;text-align:center;color:var(--text-secondary)}.um-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:.5rem;background:#0000000d}.um-loading .spinner{width:16px;height:16px;border:2px solid rgba(59,130,246,.4);border-top-color:var(--primary-color);border-radius:50%;animation:um-spin .9s linear infinite}@keyframes um-spin{to{transform:rotate(360deg)}}.um-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:2000}.um-modal{width:min(480px,100%);background:var(--bg-primary);border-radius:10px;border:1px solid var(--border-color);box-shadow:0 18px 40px #00000059;display:flex;flex-direction:column;overflow:hidden}.um-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.um-modal-body{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.85rem}.um-modal-footer{padding:.85rem 1.25rem 1.25rem;display:flex;justify-content:flex-end;gap:.5rem}.um-field{display:flex;flex-direction:column;gap:.35rem}.um-field label{font-size:.85rem;color:var(--text-secondary)}.um-field input,.um-field select{padding:.55rem .75rem;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary)}.um-field small{font-size:.75rem;color:var(--text-secondary)}.um-field.toggle{flex-direction:row;align-items:center;gap:.5rem}.um-modal-error{margin-top:.5rem;padding:.55rem .75rem;border-radius:6px;background:#ef44441f;color:#ef4444;font-size:.85rem}@media (max-width: 768px){.um-header{flex-direction:column;align-items:flex-start}.um-controls,.um-actions{flex-direction:column;align-items:stretch}.um-pagination{flex-direction:column;align-items:flex-start}}.device-info-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;box-shadow:var(--device-card-shadow);transition:all .3s ease}.device-info-card h3{color:var(--text-accent);font-size:1rem;font-weight:600;margin-bottom:1rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.device-info-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.device-info-item:last-child{border-bottom:none}.device-info-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.device-info-value{font-size:.875rem;color:var(--text-primary);font-weight:600}.chart-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--device-card-shadow)}.chart-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--device-card-shadow);height:400px;overflow:hidden;position:relative}.chart-container h3,.chart-section h3{color:var(--text-accent);font-size:1.125rem;font-weight:600;margin-bottom:1rem}.chart-canvas{height:300px!important;max-height:300px!important;width:100%!important}.chart-container canvas{max-height:300px!important;height:300px!important}.map-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--device-card-shadow)}.map-section h3{color:var(--text-accent);font-size:1.125rem;font-weight:600;margin-bottom:1rem}.breadcrumb-section{margin-bottom:1.5rem}.breadcrumb-section .breadcrumb{background:var(--bg-tertiary);padding:.75rem 1rem;border-radius:8px;border:1px solid var(--border-color)}.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.breadcrumb a{color:var(--link-color);text-decoration:none;font-weight:500}.breadcrumb a:hover{text-decoration:underline}.breadcrumb-separator{color:var(--input-border)}.device-detail-view{display:none;flex-direction:column;height:100%}.device-detail-view.active{display:flex}.device-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;box-shadow:var(--device-card-shadow)}.device-detail-title{display:flex;align-items:center;gap:1rem}.device-detail-title h1,.device-detail-title h2{color:var(--text-primary);font-size:1.75rem;font-weight:600;margin-bottom:.5rem}.device-detail-subtitle{color:var(--text-secondary);font-size:1rem;font-weight:500}.device-detail-controls{display:flex;gap:1rem;align-items:center}.time-range-selector{display:flex;background:var(--bg-secondary);border-radius:8px;overflow:hidden;box-shadow:0 2px 8px var(--shadow-color)}.time-range-selector button{padding:.5rem 1rem;border:none;background:transparent;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;color:var(--text-primary)}.time-range-selector button.active{background:var(--link-color);color:#fff}.aggregation-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border-radius:8px;box-shadow:0 2px 8px var(--shadow-color)}.aggregation-toggle label{font-size:.875rem;font-weight:500;color:var(--text-tertiary);cursor:pointer}.device-detail-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem;flex:1}.device-charts-section{display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto}.device-info-section{display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;padding:1rem 0}.gateway-view{display:none;flex-direction:column;height:100%}.gateway-view.active{display:flex}.admin-view{display:none}.admin-view.active{display:flex;flex-direction:column;height:100%}.admin-content{flex:1;overflow-y:auto;padding:1rem 0}.admin-navigation .admin-toggle{display:flex;align-items:center;padding:.5rem 0;font-weight:600;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:var(--text-primary)}.admin-navigation .admin-toggle:hover{color:var(--text-accent)!important}#adminToggleIcon{display:inline-block;margin-right:.5rem;transition:transform .3s ease;font-size:.8rem}.admin-navigation.expanded #adminToggleIcon{transform:rotate(90deg)}.admin-submenu{border-left:2px solid var(--border-color);transition:all .3s ease}.admin-submenu-item{margin-bottom:.3rem}.admin-submenu-item a{display:block;padding:.4rem .8rem;font-size:.875rem;border-radius:4px;transition:background-color .3s ease,color .3s ease;color:var(--text-secondary);text-decoration:none}.admin-submenu-item a:hover{background:var(--bg-tertiary);color:var(--text-accent)!important}.admin-submenu-item a.active{background:var(--text-accent);color:#fff!important;font-weight:600}.sensor-data-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--device-card-shadow)}.sensor-data-section h3{color:var(--text-accent);font-size:1.125rem;font-weight:600;margin-bottom:1rem}.sensor-data-placeholder{color:var(--text-secondary);font-style:italic;text-align:center;padding:2rem;background:var(--bg-tertiary);border-radius:8px;border:2px dashed var(--border-color)}.raw-data-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--device-card-shadow)}.raw-data-section h3{color:var(--text-accent);font-size:1.125rem;font-weight:600;margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between}.raw-data-content{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;font-family:Monaco,Menlo,Consolas,monospace;font-size:.875rem;color:var(--text-primary);white-space:pre-wrap;word-wrap:break-word;max-height:400px;overflow-y:auto;line-height:1.4}.raw-data-content.collapsed{display:none}.json-key{color:var(--text-accent);font-weight:600}.json-string{color:#10b981}.json-number{color:#f59e0b}.json-boolean{color:#8b5cf6}.json-null{color:#6b7280}.device-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.device-meta-item{display:flex;flex-direction:column;gap:.25rem}.device-meta-label{font-size:.75rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.device-meta-value{font-size:.875rem;font-weight:600;color:var(--text-primary)}.device-location-map{height:200px;border-radius:8px;overflow:hidden;margin-top:1rem;cursor:pointer;transition:all .2s;background:var(--bg-primary);border:1px solid var(--border-color)}.device-location-map:hover{box-shadow:var(--device-card-hover-shadow)}.no-location-message{text-align:center;padding:2rem;color:var(--text-secondary);font-style:italic}.user-info{color:var(--text-secondary);font-size:.875rem;font-weight:500}.event-log{position:fixed;top:55px;right:20px;width:300px;max-height:400px;background:#000000e6;color:#fff;border-radius:8px;overflow:hidden;z-index:1000;display:none}.event-log.visible{display:block}.event-log-header{padding:.75rem 1rem;background:#ffffff1a;font-size:.875rem;font-weight:600}.event-log-content{max-height:350px;overflow-y:auto;padding:.5rem}.log-entry{padding:.5rem;margin-bottom:.25rem;border-radius:4px;font-size:.75rem;font-family:monospace;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.log-entry.discovered{background:var(--status-connected-bg);color:var(--status-connected-color)}.log-entry.departed{background:var(--status-disconnected-bg);color:var(--status-disconnected-color)}.log-entry.movement{background:var(--status-moving-bg);color:var(--status-moving-color)}.toggle-log{position:fixed;bottom:20px;right:20px;padding:.5rem 1rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:.875rem;z-index:1001;transition:all .3s ease}.toggle-log:hover{background:var(--text-accent);color:var(--bg-primary)}@media (max-width: 1200px){.device-detail-content,.device-meta-grid{grid-template-columns:1fr}}@media (max-width: 768px){.device-detail-controls{flex-direction:column;align-items:stretch;gap:.5rem}.time-range-selector{overflow-x:auto}.event-log{width:calc(100% - 40px);max-width:300px}}[data-theme=dark] canvas{filter:invert(.9) hue-rotate(180deg)}.admin-toggle{background:#ff6b35!important;color:#fff!important;border:none;padding:4px 8px;border-radius:4px;font-size:11px;cursor:pointer;transition:all .2s ease}.admin-toggle:hover{background:#e55a2e!important;transform:translateY(-1px)}.admin-toggle.active{background:#10b981!important;box-shadow:0 0 8px #10b9814d}.admin-btn-sm{background:#3b82f6;color:#fff;border:none;padding:4px 8px;border-radius:4px;font-size:10px;cursor:pointer;transition:all .2s ease}.admin-btn-sm:hover{background:#2563eb;transform:translateY(-1px)}.admin-btn-sm:disabled{background:#666;cursor:not-allowed;opacity:.6}.admin-panel{border-color:#ff6b35!important;background:#ff6b351a!important}.admin-section{margin:8px 0;padding:8px;background:#0000004d;border-radius:4px}.admin-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}#adminGatewayList .gateway-item{display:flex;justify-content:space-between;align-items:center;padding:4px 6px;margin:2px 0;background:#ffffff0d;border-radius:3px;font-size:10px}#adminGatewayList .gateway-item:hover{background:#ffffff1a}#adminGatewayList .gateway-actions{display:flex;gap:4px}#adminGatewayList .gateway-actions button{background:none;border:none;color:#888;cursor:pointer;padding:2px;border-radius:2px;font-size:10px}#adminGatewayList .gateway-actions button:hover{background:#ffffff1a;color:#fff}#liveTrackingSection{--bg: #0e0e10;--panel: #1b1b1f;--border: #2d2d32;--muted: #888;--accent: #3d7bff;--danger: #ff5f56;--warn: #ffb347}#liveTrackingSection .panel{margin-bottom:1.5rem;background:var(--bg-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;border:1px solid var(--border-color);padding:1.5rem;box-shadow:0 4px 20px var(--shadow-color);transform:translateZ(0);will-change:transform,box-shadow;transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease}#liveTrackingSection .toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;position:relative;z-index:2}#liveTrackingSection .toolbar fieldset{border:1px solid var(--border);border-radius:6px;padding:4px 8px 6px;display:flex;gap:8px;align-items:center}#liveTrackingSection .toolbar fieldset legend{font-size:10px;padding:0 4px;letter-spacing:.5px;text-transform:uppercase;color:#888}#liveTrackingSection select,#liveTrackingSection button{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text);font:inherit;padding:4px 8px;border-radius:4px}#liveTrackingSection button{cursor:pointer}#liveTrackingSection .status{font-size:11px;color:var(--muted)}#liveTrackingSection .pill{display:inline-block;padding:2px 6px;font-size:10px;border-radius:12px;background:var(--bg-secondary);margin-left:4px;border:1px solid var(--border)}#liveTrackingSection .fade-in{animation:fade .4s ease}@keyframes fade{0%{opacity:0;transform:translate(-50%,-40%)}to{opacity:1;transform:translate(-50%,-50%)}}#liveTrackingSection .mini{font-size:10px;opacity:.7}#liveTrackingSection .grid{display:grid;gap:6px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}#liveTrackingSection .deviceCard{background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;padding:6px 8px;font-size:11px;line-height:1.3}#liveTrackingSection .deviceCard .id{font-weight:600}#liveTrackingSection .device-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}#liveTrackingSection .device-actions{display:flex;gap:4px}#liveTrackingSection .focus-btn{background:var(--accent);border:none;color:#fff;padding:2px 6px;border-radius:3px;cursor:pointer;font-size:10px;opacity:.8;transition:opacity .2s}#liveTrackingSection .focus-btn:hover{opacity:1}#liveTrackingSection .coordinates{font-family:monospace;font-size:10px;color:var(--accent)}#liveTrackingSection .quality-metrics,#liveTrackingSection .proximity-metrics{display:flex;gap:8px;margin:2px 0}#liveTrackingSection .metric{background:var(--bg-secondary);border:1px solid var(--border);padding:1px 4px;border-radius:2px;font-size:9px;color:var(--muted)}#liveTrackingSection .movement-indicator{color:var(--accent);font-size:10px;margin-top:2px}#liveTrackingSection .path-indicator{color:var(--warn);font-size:9px;margin-top:1px}#liveTrackingSection .fallback-info{color:var(--warn);font-size:10px}#liveTrackingSection .warn{color:var(--warn)}#liveTrackingSection .error{color:var(--danger)}#liveTrackingSection .ghost{opacity:.35}#liveTrackingSection #mapWrapper{position:relative;max-width:100%;border:1px solid var(--border);background:var(--bg-secondary);overflow:hidden;margin-top:10px;cursor:grab}#liveTrackingSection #mapWrapper img{max-width:100%;height:auto;display:block;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}#liveTrackingSection #deviceLayer,#liveTrackingSection #gatewayLayer,#liveTrackingSection #zoneLayer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}#liveTrackingSection #pathLayer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1}#liveTrackingSection .marker{position:absolute;transform:translate(-50%,-50%);font-size:11px;line-height:1.2;padding:3px 5px 4px;border-radius:5px;background:#3d7bffd9;color:#fff;font-weight:500;box-shadow:0 0 4px #0009;pointer-events:auto;cursor:pointer;white-space:nowrap;z-index:3;transition:left .3s ease,top .3s ease,transform .18s ease,box-shadow .18s ease,filter .18s ease}#liveTrackingSection .marker.fallback{background:var(--warn)}#liveTrackingSection .marker.gateway{background:#787878b3;font-weight:400;font-size:10px;padding:2px 4px}#liveTrackingSection .marker.method-rssi_ls{background:#3d7bffd9}#liveTrackingSection .marker.method-fingerprint_knn{background:#8657ffd9}#liveTrackingSection .marker.method-hybrid_mix{background:linear-gradient(135deg,#3d7bffe6,#8657ffe6)}#liveTrackingSection .marker:hover,#liveTrackingSection .marker:focus-visible{transform:translate(-50%,-50%) scale(1.06);box-shadow:0 8px 16px #00000073;filter:brightness(1.1);outline:none;z-index:12}#liveTrackingSection .marker:focus-visible{box-shadow:0 0 0 2px #6366f1b3,0 8px 16px #00000073}#liveTrackingSection .marker.attention{transform:translate(-50%,-50%) scale(1.12);box-shadow:0 0 0 2px #6366f159,0 0 18px #6366f18c,0 0 32px #3b82f659;filter:brightness(1.12);z-index:16}#liveTrackingSection .marker.attention:before{content:"";position:absolute;left:50%;top:50%;width:220%;height:220%;transform:translate(-50%,-50%);border-radius:14px;border:2px solid rgba(99,102,241,.25);animation:liveTrackingMarkerPulse 1.4s ease-out infinite;pointer-events:none;z-index:-1}@keyframes liveTrackingMarkerPulse{0%{opacity:.45;transform:translate(-50%,-50%) scale(.7)}65%{opacity:0;transform:translate(-50%,-50%) scale(1.35)}to{opacity:0;transform:translate(-50%,-50%) scale(1.55)}}#liveTrackingSection .marker:after{content:"";position:absolute;left:50%;top:100%;width:0;height:0;border:5px solid transparent;border-top-color:currentColor;opacity:.7;transform:translate(-50%)}#liveTrackingSection .legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px;position:relative;z-index:2}#liveTrackingSection .legend-item{display:flex;align-items:center;gap:6px;font-size:11px;background:var(--bg-secondary);padding:4px 6px;border:1px solid var(--border);border-radius:5px}#liveTrackingSection .dot{width:14px;height:14px;border-radius:50%;box-shadow:0 0 2px #000000b3}#liveTrackingSection .filters-adv{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}#liveTrackingSection .group{min-width:120px;background:var(--bg-secondary);padding:6px 8px 8px;border:1px solid var(--border);border-radius:6px;display:flex;flex-direction:column;gap:4px}#liveTrackingSection .group .title{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#888}#liveTrackingSection .group input[type=text],#liveTrackingSection .group input[type=number],#liveTrackingSection .group select{background:var(--bg-secondary);border:1px solid var(--border);padding:4px 6px;border-radius:4px;font-size:11px}#liveTrackingSection #zoomHud{position:absolute;top:6px;right:6px;background:#ffffff80;padding:4px 8px;font-size:11px;border:1px solid var(--border);border-radius:5px;z-index:4}#mapWrapper img#mapImage{max-width:100%;height:auto;display:block;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.device-marker{background:transparent;border:none}.device-marker-pin{width:30px;height:30px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:2px solid var(--bg-primary)}.device-marker-icon{transform:rotate(45deg);font-size:12px}.leaflet-control-fit-bounds,.leaflet-control-device-count{background:var(--bg-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;border:1px solid var(--border-color);box-shadow:var(--device-card-shadow)}.map-control-btn{background:var(--bg-secondary);border:1px solid var(--border-color);padding:8px;cursor:pointer;font-size:16px;border-radius:6px;transition:all .2s ease;color:var(--text-tertiary)}.map-control-btn:hover{background:var(--text-accent);color:var(--bg-primary)}.leaflet-control-device-count{padding:8px 12px;font-size:.875rem;font-weight:500;color:var(--text-tertiary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px}.device-popup{min-width:250px}.popup-header{margin-bottom:12px}.popup-title{font-size:1rem;font-weight:600;color:var(--text-tertiary);margin-bottom:4px}.popup-subtitle{font-size:.875rem;color:var(--text-secondary);margin-bottom:8px}.popup-content{gap:8px}.popup-item{font-size:.75rem}.popup-label{color:var(--text-secondary);font-weight:500}.popup-value{color:var(--text-tertiary);font-weight:600}.popup-footer{margin-top:12px;text-align:center}.popup-detail-btn{background:var(--link-color);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%}.popup-detail-btn:hover{background:var(--text-accent)}[data-theme=dark] .leaflet-container{background:var(--bg-primary)}[data-theme=dark] .leaflet-control,[data-theme=dark] .leaflet-control-zoom a{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}[data-theme=dark] .leaflet-control-zoom a:hover{background:var(--text-accent);color:var(--bg-primary)}[data-theme=dark] .leaflet-popup-content-wrapper{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}[data-theme=dark] .leaflet-popup-tip{background:var(--bg-secondary);border:1px solid var(--border-color)}[data-theme=dark] .leaflet-control-attribution{background:var(--bg-secondary);color:var(--text-secondary)}.leaflet-container{font-family:inherit}.leaflet-popup-content{margin:8px 12px;line-height:1.4}.leaflet-popup-content h4{margin:0 0 8px;color:var(--text-primary)}.leaflet-popup-content p{margin:4px 0;color:var(--text-secondary)}.marker-cluster-small{background-color:#6366f199}.marker-cluster-small div{background-color:#6366f1cc}.marker-cluster-medium{background-color:#3b82f699}.marker-cluster-medium div{background-color:#3b82f6cc}.marker-cluster-large{background-color:#2563eb99}.marker-cluster-large div{background-color:#2563ebcc}.marker-cluster{background-clip:padding-box;border-radius:20px}.marker-cluster div{width:30px;height:30px;margin-left:5px;margin-top:5px;text-align:center;border-radius:15px;font:12px Helvetica Neue,Arial,Helvetica,sans-serif;color:#fff;line-height:30px}.device-marker.present{color:var(--status-connected-color)}.device-marker.absent{color:var(--status-absent-color);opacity:.6}.device-marker.moving{color:var(--status-moving-color);animation:markerPulse 2s infinite}@keyframes markerPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.gateway-marker{background:var(--text-secondary);color:#fff;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:500}.location-accuracy-circle{stroke:var(--text-accent);stroke-opacity:.8;stroke-width:2;fill:var(--text-accent);fill-opacity:.1}.map-loading{display:flex;align-items:center;justify-content:center;height:200px;background:var(--bg-tertiary);border-radius:8px;color:var(--text-secondary)}.map-error{display:flex;align-items:center;justify-content:center;height:200px;background:var(--status-disconnected-bg);border-radius:8px;color:var(--status-disconnected-color);text-align:center;padding:1rem}@media (max-width: 768px){.device-popup{min-width:200px}.popup-title{font-size:.875rem}.popup-subtitle{font-size:.75rem}.popup-item{font-size:.625rem}.popup-detail-btn{font-size:.625rem;padding:6px 12px}.leaflet-control-device-count{font-size:.75rem;padding:6px 10px}}.admin-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease}.admin-modal.show{display:flex!important;align-items:center;justify-content:center}.admin-modal-content{background:var(--bg-primary);border-radius:12px;box-shadow:0 20px 40px #0000004d;padding:2rem;width:90%;max-width:400px;border:1px solid var(--border-color);animation:slideUp .3s ease}.admin-modal-header{text-align:center;margin-bottom:1.5rem}.admin-modal-header h2{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:600}.admin-form{display:flex;flex-direction:column;gap:1rem}.admin-form-group{display:flex;flex-direction:column;gap:.5rem}.admin-form-group label{color:var(--text-secondary);font-weight:500;font-size:.875rem}.admin-form-group input{padding:.75rem;border:1px solid var(--input-border);border-radius:8px;background:var(--input-bg);color:var(--text-primary);font-size:1rem;transition:border-color .3s ease,box-shadow .3s ease}.admin-form-group input:focus{outline:none;border-color:var(--text-accent);box-shadow:0 0 0 3px #6366f11a}.admin-form-group small{color:var(--text-secondary);font-size:.75rem}.admin-form-actions{display:flex;gap:1rem;margin-top:.5rem}.admin-btn{flex:1;padding:.75rem;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease;font-size:1rem}.admin-btn.primary{background:var(--text-accent);color:#fff}.admin-btn.primary:hover{background:#3b82f6;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.admin-btn.secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.admin-btn.secondary:hover{background:var(--border-color)}.admin-error{color:#ef4444;font-size:.875rem;text-align:center;margin-top:.5rem;padding:.5rem;background:#ef44441a;border-radius:6px;display:none}.admin-error.show{display:block}.expanded-map-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;z-index:2000;display:none;justify-content:center;align-items:center}.expanded-map-overlay.active{display:flex}.expanded-map-container{width:90%;height:90%;background:var(--bg-secondary);border-radius:12px;overflow:hidden;position:relative;border:1px solid var(--border-color)}.expanded-map-header{padding:1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.expanded-map-header h3{color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:600}.expanded-map-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);transition:color .2s ease;padding:.5rem;border-radius:4px}.expanded-map-close:hover{color:var(--text-accent);background:var(--bg-primary)}.expanded-map{height:calc(100% - 60px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.admin-account-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:20px;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-accent);cursor:pointer;transition:all .3s ease;font-size:.875rem;font-weight:500;text-decoration:none}.admin-account-btn:hover{background:var(--text-accent);color:var(--bg-primary);transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.admin-account-btn.authenticated{background:var(--status-connected-bg);color:var(--status-connected-color);border-color:var(--status-connected-color)}.admin-account-btn.authenticated:hover{background:var(--status-connected-color);color:var(--bg-primary)}.admin-dropdown{position:absolute;top:100%;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:10002;min-width:180px;margin-top:.5rem}.admin-dropdown-content{padding:.5rem 0}.admin-dropdown-content a{display:block;padding:.75rem 1rem;color:var(--text-primary);text-decoration:none;font-size:.875rem;transition:background-color .2s ease}.admin-dropdown-content a:hover{background:var(--bg-tertiary);color:var(--text-accent)}.edit-device-name-btn{background:none;border:1px solid var(--border-color);border-radius:6px;padding:.375rem .5rem;font-size:1rem;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;margin-left:.5rem}.edit-device-name-btn:hover{background-color:var(--bg-tertiary);border-color:var(--text-accent);color:var(--text-accent)}.raw-data-toggle{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .3s ease}.raw-data-toggle:hover{background:var(--text-accent);color:var(--bg-primary)}@media (max-width: 768px){.admin-modal-content{width:95%;max-width:none;padding:1.5rem}.admin-form-actions{flex-direction:column;gap:.75rem}.admin-btn{flex:none}.expanded-map-container{width:95%;height:85%}.expanded-map-header{padding:.75rem}.expanded-map-header h3{font-size:1.125rem}.expanded-map{height:calc(100% - 50px)}}:root{color-scheme:light dark;--status-button-alert-color: #f59e0b;--status-button-alert-bg: rgba(245, 158, 11, .12);--status-button-alert-glow: rgba(245, 158, 11, .35)}html,body{margin:0;padding:0;font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--surface-base, #07090f);color:var(--text-primary, #ffffff);transition:background-color .3s ease,color .3s ease}#app{min-height:100vh}*{box-sizing:border-box}button{font:inherit}.app-shell .admin-view{display:block}.device-card.button-press-alert{border-left:4px solid var(--status-button-alert-color)!important;box-shadow:0 12px 30px var(--status-button-alert-glow)!important;animation:buttonPressPulse 1.2s ease-out}.device-list-item.button-press-alert{border-left:4px solid var(--status-button-alert-color)!important;background:linear-gradient(90deg,var(--status-button-alert-bg),transparent 65%)!important;box-shadow:0 0 0 2px var(--status-button-alert-glow)!important;animation:buttonPressPulse 1.2s ease-out}@keyframes buttonPressPulse{0%{box-shadow:0 0 0 0 var(--status-button-alert-glow)}70%{box-shadow:0 0 0 10px #0000}to{box-shadow:0 0 #0000}}
