.vx-topbar{height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:var(--card, #ffffff);border-bottom:1px solid var(--border, #e5e7eb);gap:16px;flex-shrink:0;z-index:20}.vx-top-left{display:flex;align-items:center;gap:12px;flex-shrink:0}.vx-hamburger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border, #e5e7eb);border-radius:8px;background:transparent;font-size:18px;cursor:pointer;color:var(--text, #333);transition:background .15s ease,color .15s ease;flex-shrink:0}.vx-hamburger:hover{background:color-mix(in srgb,var(--text, #333) 6%,transparent)}.vx-search{display:flex;align-items:center}.vx-search input{height:36px;padding:0 14px;border-radius:8px;border:1px solid var(--border, #e5e7eb);background:var(--bg, #f7f9fb);color:var(--text, #333);font-size:14px;width:220px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.vx-search input::placeholder{color:var(--muted, #9aa4b2)}.vx-search input:focus{border-color:var(--accent, #2563eb);box-shadow:0 0 0 3px #2563eb1a}.vx-top-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.vx-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;background:transparent;font-size:18px;cursor:pointer;transition:background .15s ease}.vx-icon-btn:hover{background:color-mix(in srgb,var(--text, #333) 7%,transparent)}.vx-avatar{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent, #2563eb),var(--accent-2, #6a35ff));color:#fff;font-size:14px;font-weight:700;flex-shrink:0}.vx-avatar-letter{line-height:1}.vx-profile-menu{position:relative}.vx-profile-trigger{display:flex;align-items:center;gap:10px;border:1px solid var(--border, #e5e7eb);background:var(--card, #ffffff);color:var(--text, #111827);padding:6px 10px 6px 6px;border-radius:999px;cursor:pointer;font-size:13px;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.vx-profile-trigger:hover{background:var(--bg, #f7f9fb);border-color:var(--border-color, #cbd5e1)}.vx-profile-trigger:focus-visible{outline:none;box-shadow:0 0 0 3px #2563eb1f}.vx-profile-meta{display:flex;flex-direction:column;align-items:flex-start;min-width:0}.vx-profile-name,.vx-profile-role{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vx-profile-name{font-size:13px;font-weight:700}.vx-profile-role{font-size:11px;color:var(--muted, #6b7280)}.vx-profile-caret{color:var(--muted, #6b7280);transition:transform .2s ease}.vx-profile-menu.open .vx-profile-caret{transform:rotate(180deg)}.vx-profile-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:220px;padding:8px;border-radius:14px;border:1px solid var(--border, #e5e7eb);background:var(--card, #ffffff);box-shadow:0 18px 40px #0f172a29;z-index:50}.vx-profile-theme-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px 12px}.vx-profile-theme-copy{display:flex;flex-direction:column;gap:3px;min-width:0}.vx-profile-theme-label{font-size:13px;font-weight:700;color:var(--text-primary, #0f172a)}.vx-profile-theme-value{font-size:12px;color:var(--text-secondary, #64748b)}.vx-profile-divider{height:1px;margin:0 4px 6px;background:var(--border, #e5e7eb)}.vx-profile-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;background:transparent;border-radius:10px;color:var(--text, #111827);font-size:13px;font-weight:600;text-align:left;cursor:pointer;transition:background .15s ease,color .15s ease}.vx-profile-item:hover{background:color-mix(in srgb,var(--text, #111827) 5%,transparent)}.vx-profile-item.danger{color:var(--danger, #dc2626)}.vx-profile-item.danger:hover{background:color-mix(in srgb,var(--danger, #dc2626) 10%,transparent)}.vx-profile-item-icon{display:flex;align-items:center;justify-content:center}.vx-simple-page{padding:24px;display:flex;flex-direction:column;gap:20px}.vx-simple-page__hero{border:1px solid var(--border, #e5e7eb);border-radius:18px;padding:24px;background:radial-gradient(circle at top right,rgba(37,99,235,.12),transparent 30%),linear-gradient(135deg,color-mix(in srgb,var(--card, #ffffff) 92%,white 8%),color-mix(in srgb,var(--bg, #f8fafc) 96%,white 4%))}.vx-simple-page__hero h1{margin:8px 0 10px;font-size:28px;line-height:1.15;color:var(--text-primary, #0f172a)}.vx-simple-page__hero p{margin:0;max-width:700px;color:var(--text-secondary, #475569)}.vx-simple-page__eyebrow{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent, #2563eb)}.vx-simple-page__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.vx-simple-page__stack{display:grid;gap:14px}.vx-simple-page__card{padding:18px 20px;border:1px solid var(--border, #e5e7eb);border-radius:16px;background:var(--card, #ffffff);box-shadow:0 12px 30px #0f172a0a}.vx-simple-page__card h2,.vx-simple-page__card strong{color:var(--text-primary, #0f172a)}.vx-simple-page__card h2{margin:0 0 8px;font-size:17px}.vx-simple-page__card p{margin:0;color:var(--text-secondary, #64748b);line-height:1.5}.vx-simple-page__label{display:block;margin-bottom:6px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary, #64748b)}.vx-theme-switch{display:inline-flex;align-items:center;justify-content:center;padding:0;border:none;background:transparent;cursor:pointer}.vx-theme-switch:focus-visible{outline:none;border-radius:999px;box-shadow:0 0 0 3px #2563eb2e}.vx-theme-switch-track{position:relative;display:inline-flex;align-items:center;justify-content:space-between;width:58px;height:32px;padding:0 8px;border-radius:999px;background:color-mix(in srgb,var(--accent, #2563eb) 22%,var(--card, #ffffff));border:1px solid color-mix(in srgb,var(--accent, #2563eb) 25%,var(--border, #e5e7eb));box-shadow:inset 0 1px 2px #0f172a1f}.vx-theme-switch-icon{z-index:1;display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;color:var(--text-secondary, #64748b);transition:color .25s ease,opacity .25s ease,transform .25s ease}.vx-theme-switch-thumb{position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;box-shadow:0 4px 12px #0f172a33;transition:transform .25s ease,background-color .25s ease}.vx-theme-switch.is-dark .vx-theme-switch-thumb{transform:translate(26px);background:#e2e8f0}.vx-theme-switch.is-dark .vx-theme-switch-icon.moon,.vx-theme-switch:not(.is-dark) .vx-theme-switch-icon.sun{color:var(--accent, #2563eb)}.vx-theme-icon{width:14px;height:14px}@media(max-width:640px){.vx-topbar{padding:0 12px;gap:8px}.vx-search input{width:140px}.vx-profile-meta{display:none}.vx-profile-trigger{padding-right:6px}.vx-profile-dropdown{width:200px}.vx-simple-page{padding:16px}.vx-simple-page__hero{padding:18px}}@media(max-width:400px){.vx-search{display:none}}.vx-notification-icon-wrapper{position:relative;display:flex;align-items:center}.vx-notification-icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;background:transparent;cursor:pointer;transition:all .2s ease;color:var(--text, #333)}.vx-notification-icon-btn:hover{background:color-mix(in srgb,var(--text, #333) 7%,transparent)}.vx-notification-icon-btn.active{background:color-mix(in srgb,var(--accent, #2563eb) 12%,transparent)}.vx-notification-bell{font-size:20px;color:var(--text, #333);transition:transform .3s ease}.vx-notification-icon-btn:hover .vx-notification-bell{transform:scale(1.1)}.vx-notification-icon-btn.active .vx-notification-bell{color:var(--accent, #2563eb)}.vx-notification-badge{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;padding:0 5px;border-radius:10px;background:linear-gradient(135deg,var(--accent, #2563eb),var(--accent-2, #6a35ff));color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--card, #ffffff);box-shadow:0 2px 8px #2563eb4d;animation:vx-badge-pulse 2s ease-in-out infinite}@keyframes vx-badge-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}:root.dark .vx-notification-badge{border-color:var(--bg, #1f2937)}.vx-notification-backdrop{position:fixed;inset:0;background:#0006;z-index:100000;animation:vx-fade-in .15s ease}@keyframes vx-fade-in{0%{opacity:0}to{opacity:1}}.vx-notification-shade{position:fixed;top:60px;right:20px;width:420px;max-height:calc(100vh - 100px);border-radius:14px;background:var(--card, #ffffff);border:1px solid var(--border, #e5e7eb);box-shadow:0 20px 25px -5px #00000026,0 10px 10px -5px #00000014;z-index:100001;display:flex;flex-direction:column;animation:vx-slide-down .25s cubic-bezier(.16,1,.3,1)}@keyframes vx-slide-down{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.vx-notification-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border, #e5e7eb);flex-shrink:0}.vx-notification-title-section{display:flex;align-items:center;gap:10px}.vx-notification-title{margin:0;font-size:18px;font-weight:700;color:var(--text, #111827)}.vx-notification-count{min-width:24px;height:24px;padding:0 8px;border-radius:12px;background:color-mix(in srgb,var(--accent, #2563eb) 15%,transparent);color:var(--accent, #2563eb);font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center}.vx-notification-header-actions{display:flex;gap:8px;align-items:center}.vx-notification-action-btn,.vx-notification-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:transparent;color:var(--muted, #6b7280);cursor:pointer;transition:all .2s ease}.vx-notification-action-btn:hover,.vx-notification-close-btn:hover{background:color-mix(in srgb,var(--text, #333) 6%,transparent);color:var(--text, #333)}.vx-notification-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:0}.vx-notification-content::-webkit-scrollbar{width:6px}.vx-notification-content::-webkit-scrollbar-track{background:transparent}.vx-notification-content::-webkit-scrollbar-thumb{background:var(--border, #e5e7eb);border-radius:3px}.vx-notification-content::-webkit-scrollbar-thumb:hover{background:var(--muted, #9aa4b2)}.vx-notification-loading,.vx-notification-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--muted, #6b7280);text-align:center}.vx-notification-loading p,.vx-notification-empty p{margin:16px 0 0;font-size:14px;color:var(--text, #111827)}.vx-notification-empty-text{font-size:12px;color:var(--muted, #9aa4b2);margin-top:8px;display:block}.vx-notification-empty-icon{font-size:48px;opacity:.5}.vx-notification-spinner{width:32px;height:32px;border:3px solid var(--border, #e5e7eb);border-top-color:var(--accent, #2563eb);border-radius:50%;animation:vx-spin .8s linear infinite}.vx-notification-list{list-style:none;margin:0;padding:0}.vx-notification-item{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border, #e5e7eb);background:var(--card, #ffffff);transition:background .2s ease}.vx-notification-item:last-child{border-bottom:none}.vx-notification-item:hover{background:color-mix(in srgb,var(--text, #333) 2%,transparent)}.vx-notification-item.unread{background:color-mix(in srgb,var(--accent, #2563eb) 3%,transparent)}.vx-notification-item.unread:hover{background:color-mix(in srgb,var(--accent, #2563eb) 5%,transparent)}.vx-notification-item-icon{font-size:24px;flex-shrink:0}.vx-notification-item-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.vx-notification-item-thumb{width:64px;height:64px;object-fit:cover;border-radius:8px;border:1px solid var(--border, #e5e7eb);margin-top:4px;background:color-mix(in srgb,var(--text, #333) 4%,transparent)}.vx-notification-item-header{display:flex;align-items:baseline;gap:8px;justify-content:space-between}.vx-notification-item-title{margin:0;font-size:13px;font-weight:600;color:var(--text, #111827);flex:1}.vx-notification-item-time{font-size:11px;color:var(--muted, #9aa4b2);flex-shrink:0;white-space:nowrap}.vx-notification-item-message{margin:0;font-size:12px;color:var(--muted, #6b7280);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.vx-notification-item-actions{display:flex;gap:4px;flex-shrink:0}.vx-notification-item-action{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:4px;background:transparent;color:var(--muted, #9aa4b2);cursor:pointer;transition:all .2s ease}.vx-notification-item-action:hover{background:color-mix(in srgb,var(--text, #333) 8%,transparent);color:var(--text, #333)}.vx-notification-item-action.delete:hover{background:color-mix(in srgb,#ef4444 20%,transparent);color:#ef4444}.vx-notification-loading-more{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;color:var(--muted, #6b7280);font-size:13px}.vx-notification-spinner-small{width:20px;height:20px;border:2px solid var(--border, #e5e7eb);border-top-color:var(--accent, #2563eb);border-radius:50%;animation:vx-spin .8s linear infinite}.vx-notification-end{display:flex;align-items:center;justify-content:center;padding:20px;color:var(--muted, #9aa4b2);font-size:12px;border-top:1px solid var(--border, #e5e7eb)}.vx-notification-end p{margin:0}@media(max-width:768px){.vx-notification-shade{position:fixed;top:60px;right:0;left:0;width:auto;max-height:calc(100vh - 100px);border-radius:8px 8px 0 0;margin:0 10px;max-width:unset;animation:vx-slide-up .25s cubic-bezier(.16,1,.3,1)}@keyframes vx-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.vx-notification-item{padding:10px 12px}.vx-notification-item-title{font-size:12px}.vx-notification-item-message{font-size:11px}}:root.dark .vx-notification-item.unread{background:color-mix(in srgb,var(--accent, #2563eb) 8%,transparent)}html,body{margin:0;padding:0;height:100%}.loginPage{position:relative;min-height:100vh;width:100vw;display:flex;justify-content:center;align-items:center;padding:20px;background-image:url(/assets/Background.png);background-size:cover;background-position:center;background-repeat:no-repeat;overflow-x:hidden}.loginPage:before{content:"";position:absolute;inset:0;background:#00000040}.loginFormLeft{width:100%;display:flex;justify-content:left;align-items:left;z-index:2}.loginBox{width:100%;max-width:420px;padding:35px 28px;align-items:left;background:#fffffff5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:18px;box-shadow:0 10px 40px #00000040;margin:0 auto;box-sizing:border-box}.visionxLogoContainer{display:flex;justify-content:center;margin-bottom:28px}.visionxLogoText{font-size:34px;font-weight:700;color:#0576ca}.loginForm{display:flex;flex-direction:column;align-items:center;width:100%}.loginError{color:red;margin-bottom:10px}.forgotPasswordContainer{width:100%;text-align:center;margin:10px 0}.forgotPasswordLink{background:none;border:none;color:#0576ca;font-size:14px;font-weight:500;cursor:pointer}.register-company-container{width:100%;display:flex;justify-content:center}.registerCompanyLink{margin-top:22px;padding:10px 16px;background:transparent;border:none;color:#0576ca;font-size:14px;font-weight:500;cursor:pointer;border-radius:8px;transition:background .2s ease}.registerCompanyLink:hover{background:#6a35ff1a}.forgot-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.forgot-modal{background:#fff;padding:30px;border-radius:16px;width:min(420px,90%);box-shadow:0 10px 25px #00000040;text-align:center}@media(min-width:1024px){.loginPage{display:flex;justify-content:flex-start;align-items:center;background:#0b1b35;position:relative}.loginPage:before{display:none}.loginPage:after{content:"";position:absolute;top:0;right:0;width:65%;height:100vh;background-image:url(/assets/Background.png);background-size:cover;background-position:center right;clip-path:polygon(12% 0,100% 0,100% 100%,0% 100%);z-index:0}.loginFormLeft{width:35%;display:flex;justify-content:center;align-items:center;padding-right:56%;z-index:2}.loginBox{width:100%;max-width:360px;background:#0a1937d9;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);color:#fff;box-shadow:0 20px 60px #00000073;margin:0}.loginBox input{background:#ffffffe6}.forgotPasswordLink,.registerCompanyLink{color:#2da4ff}}@media(max-width:620px){.loginPage{padding:32px}.loginBox{padding:25px 18px}.visionxLogoText{font-size:24px}}.company-modal-root{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.company-modal-overlay{position:absolute;inset:0;background:#00000073;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.company-modal{position:relative;width:700px;height:600px;background:#fff;border-radius:20px;padding:32px 36px;box-shadow:0 30px 80px #00000059;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between}.wizard-step,.welcome-step,.success-step{flex:1;display:flex;flex-direction:column;justify-content:center}.welcome-step,.success-step{text-align:center}.wizard-step h2,.welcome-step h2,.success-step h2{font-size:20px;font-weight:600;color:#111827;margin-bottom:18px}.welcome-step p,.success-step p{font-size:14px;color:#6b7280}.success-step svg{color:#22c55e;margin:0 auto 16px}.step-fields{display:flex;flex-direction:column;gap:14px}.form-field{display:flex;flex-direction:column}.form-field input{height:46px;padding:0 14px;border-radius:10px;border:1px solid #d1d5db;background:#f9fafb;color:#111827;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.form-field input:focus{outline:none;background:#fff;border-color:#6a35ff;box-shadow:0 0 0 3px #6a35ff26}.wizard-footer{margin-top:24px;display:flex;justify-content:space-between;align-items:center}.wizard-footer button{background:none;border:none;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;transition:color .2s ease}.wizard-footer button:hover:not(:disabled){color:#111827}.wizard-footer button:disabled{opacity:.35;cursor:not-allowed}.wizard-footer .primary{background:#000;color:#fff;height:40px;padding:0 18px;border-radius:999px;display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;transition:background .2s ease,transform .12s ease,box-shadow .12s ease}.wizard-footer .primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 14px #0003}.wizard-footer .primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.visionx-modal-logo{position:absolute;top:28px;left:42%;transform:translate(-80%);font-size:36px;font-weight:700;letter-spacing:.6px;color:#0066b5;pointer-events:none;-webkit-user-select:none;user-select:none}.form-field input,.form-field select{height:46px;padding:0 14px;font-size:14px;color:#111827;background:#f9fafb;border:1px solid #d1d5db;outline:none;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.email-split{display:flex;align-items:center;background:#f9fafb;border:1px solid #d1d5db;border-radius:10px;overflow:hidden}.email-split input{border:none;background:transparent;flex:1;height:46px}.email-split span{padding:0 6px;font-size:14px;color:#6b7280;-webkit-user-select:none;user-select:none}.phone-input{display:flex;align-items:center;background:#f9fafb;border:1px solid #d1d5db;border-radius:10px;overflow:hidden}.phone-input select{border:none;background:transparent;padding:0 12px;height:46px;font-size:14px;color:#111827;cursor:pointer}.phone-input input{border:none;background:transparent;flex:1;height:46px}.email-split:focus-within,.phone-input:focus-within,.form-field input:focus{background:#fff;border-color:#6ec1ff;box-shadow:0 0 0 3px #6ec1ff2e}.form-field input::placeholder{color:#9ca3af}.form-field label{font-size:12px;font-weight:500;color:#6b7280;margin-bottom:6px}.dashboard-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--card-radius);padding:18px}.section-header-wrap{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.section-header{font-size:18px;font-weight:700;margin:0;color:var(--text-primary)}.section-subtitle{font-size:12px;color:var(--text-secondary);margin-top:2px}.primary-btn{background:var(--accent, #2563eb);color:#fff;border:none;padding:8px 14px;border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease}.primary-btn:hover{opacity:.9}.danger-btn{background:#ef4444;color:#fff;border:none;padding:6px 10px;border-radius:var(--radius);cursor:pointer}.data-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border-color);border-radius:var(--card-radius);overflow:hidden;font-size:14px}.data-table thead{background:#94a3b814}.data-table th{text-align:left;padding:12px;font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase}.data-table td{padding:14px 12px;border-top:1px solid var(--border-color);color:var(--text-primary)}.data-table tr:hover{background:#2563eb0a}.vx-dropdown{position:absolute;right:0;top:28px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);min-width:140px;box-shadow:0 10px 30px #00000014;z-index:1000;overflow:hidden}.vx-dropdown-item{padding:10px 12px;font-size:13px;cursor:pointer;transition:background .15s ease}.vx-dropdown-item:hover{background:#2563eb14}.vx-dropdown-item.danger{color:#ef4444}.vx-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:2000}.vx-modal{background:var(--bg-card);border-radius:var(--card-radius);padding:20px;width:420px;max-width:90%;border:1px solid var(--border-color)}input{width:100%;padding:8px;border-radius:var(--radius);border:1px solid var(--border-color);margin-top:4px;margin-bottom:12px;font-size:13px}label{font-size:12px;font-weight:600;color:var(--text-secondary)}.toast-container{position:fixed;top:20px;right:20px;z-index:9999}.toast{background:#111;color:#fff;padding:10px 14px;border-radius:var(--radius);margin-bottom:8px;font-size:13px}.vx-toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;align-items:flex-end;pointer-events:none}.vx-toast{position:relative;min-width:280px;max-width:min(380px,calc(100vw - 40px));padding:12px 34px 14px 12px;border-radius:var(--radius);color:#fff;background:#111;box-shadow:0 10px 24px #0003;overflow:hidden;pointer-events:auto;will-change:transform,opacity}.vx-toast-success{background:#16a34a}.vx-toast-error{background:#dc2626}.vx-toast-default{background:#111}.vx-toast-message{font-size:13px;line-height:1.4;padding-right:2px}.vx-toast-close{position:absolute;top:6px;right:8px;border:none;background:transparent;color:#fff;font-size:18px;line-height:1;padding:0;cursor:pointer;opacity:.85}.vx-toast-close:hover{opacity:1}.vx-toast-progress{position:absolute;left:0;bottom:0;height:3px;width:100%;background:#ffffff8c;transform-origin:left center;animation:vx-toast-progress 4s linear forwards}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}@keyframes vx-toast-progress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.system-status-bar{display:flex;flex-direction:column;gap:10px;padding:10px 16px;border-radius:10px;font-size:13px;border:1px solid var(--border-color);background:#10b9810f;overflow:hidden;transition:max-height .35s ease,padding .25s ease}.system-status-bar.closed{max-height:48px}.system-status-bar.open{max-height:200px}@media(min-width:1025px){.system-status-bar{flex-direction:row;align-items:center;justify-content:space-between}}.system-status-bar.yellow{background:#facc1514}.system-status-bar.red{background:#ef444414}.status-left{display:flex;align-items:center;justify-content:space-between;width:100%}.status-main{display:flex;align-items:center;gap:10px}.sys-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sys-dot.green{background:#10b981;box-shadow:0 0 8px #10b98180;animation:pulse-dot 2s ease-in-out infinite}.sys-dot.yellow{background:#facc15;box-shadow:0 0 8px #facc1580}.sys-dot.red{background:#ef4444;box-shadow:0 0 8px #ef444480;animation:pulse-dot 1s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.status-text{color:var(--text-primary);font-weight:600}.status-tags{display:flex;gap:16px;flex-wrap:wrap;transition:opacity .25s ease,transform .25s ease}.system-status-bar.closed .status-tags{opacity:0;transform:translateY(-6px);pointer-events:none}.system-status-bar.open .status-tags{opacity:1;transform:translateY(0)}.status-tag{color:var(--text-secondary);font-size:12px;font-weight:500}@media(max-width:1024px){.status-tags{justify-content:space-between}}.status-dropdown{display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary)}.status-dropdown svg{transition:transform .3s ease}.status-dropdown svg.rotated{transform:rotate(180deg)}.dashboard-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.toolbar-left{display:flex;align-items:center;gap:12px}.toolbar-title{font-size:22px;font-weight:700;color:var(--text-primary);margin:0}.toolbar-live-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;background:#10b9811a;color:#10b981;font-size:11px;font-weight:700;letter-spacing:.5px}.live-dot{width:7px;height:7px;border-radius:50%;background:#10b981;animation:pulse-dot 1.5s ease-in-out infinite}.toolbar-right{display:flex;align-items:center;gap:10px}.time-selector{display:flex;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.time-btn{padding:8px 14px;border:none;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:inherit}.time-btn:hover{background:#2563eb0d}.time-btn.active{background:var(--accent, #2563eb);color:#fff}.refresh-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border-color);background:transparent;font-size:18px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .15s ease}.refresh-btn:hover{background:#0000000d;transform:rotate(90deg)}.desktop-only{display:flex}.mobile-only{display:none}@media(max-width:640px){.dashboard-toolbar{flex-direction:row;align-items:center;justify-content:space-between;gap:8px}.desktop-only{display:none}.mobile-only{display:flex;align-items:center;gap:6px}.toolbar-right{gap:6px}.time-select{height:28px;padding:0 8px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-size:11px;font-weight:600;outline:none}.refresh-btn{width:28px;height:28px;font-size:14px}}.live-kpi-bar{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.kpi-item{display:flex;flex-direction:column;gap:6px;padding:16px;background:var(--bg-card);border:1px solid var(--border-color);border-left:3px solid var(--accent);border-radius:10px;transition:transform .16s ease,box-shadow .18s ease;cursor:pointer}.kpi-item:hover{transform:translateY(-3px);box-shadow:0 8px 24px #00000014}.kpi-header{display:flex;align-items:center;justify-content:space-between}.kpi-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;background:#2563eb14}.kpi-trend{font-size:12px;font-weight:700;padding:2px 8px;border-radius:12px;white-space:nowrap}.kpi-trend.trend-up{color:#10b981;background:#10b9811a}.kpi-trend.trend-down{color:#ef4444;background:#ef44441a}.kpi-trend.trend-flat{color:var(--text-secondary);background:#94a3b81a}.kpi-value{font-size:28px;font-weight:800;color:var(--text-primary);line-height:1}.kpi-label{font-size:12px;color:var(--text-secondary);font-weight:500}@media(max-width:1400px){.live-kpi-bar{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:1100px){.live-kpi-bar{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:768px){.live-kpi-bar{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:480px){.live-kpi-bar{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.kpi-item{padding:10px;border-radius:8px;gap:4px}.kpi-icon{width:24px;height:24px;font-size:12px}.kpi-value{font-size:16px}.kpi-label{font-size:10px}.kpi-trend{font-size:9px;padding:1px 6px}}.dashboard-card{background:var(--bg-card);border-radius:10px;border:1px solid var(--border-color);padding:18px}.section-header-wrap{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:12px}.section-header{font-size:16px;font-weight:600;margin:0;color:var(--text-primary)}.section-subtitle{margin:0;font-size:12px;color:var(--text-secondary)}.status-indicator{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-secondary)}.status-indicator.online .status-dot,.status-indicator.good .status-dot{background:var(--success)}.status-indicator.warning .status-dot{background:var(--warning)}.status-indicator.offline .status-dot,.status-indicator.danger .status-dot{background:var(--danger)}.camera-fleet-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:12px;color:var(--text-secondary);font-size:12px}.camera-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.camera-status-card{border:1px solid var(--border-color);border-radius:8px;padding:8px}.camera-card-name{font-size:12px;margin-bottom:6px;color:var(--text-primary)}.telemetry-list{display:flex;flex-direction:column;gap:8px}.telemetry-row{border:1px solid var(--border-color);border-radius:8px;padding:10px;display:grid;grid-template-columns:minmax(120px,1.2fr) minmax(0,3fr);align-items:center;gap:12px;min-height:60px}.telemetry-title{color:var(--text-primary);font-weight:600;margin-bottom:0;min-width:0}.telemetry-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;color:var(--text-secondary);font-size:12px}.telemetry-metrics--graphs{gap:10px;align-items:center}.telemetry-metric{display:grid;gap:3px;min-width:0}.telemetry-metric__header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.telemetry-metric__label{color:var(--text-secondary);font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.telemetry-metric__value{color:var(--text-primary);font-size:11px;font-weight:700;white-space:nowrap}.telemetry-metric__graph{height:20px;border-radius:6px;overflow:hidden;background:color-mix(in srgb,var(--bg-card) 35%,transparent)}.telemetry-sparkline{width:100%;height:100%;display:block;overflow:visible}.telemetry-sparkline__area{fill:#3b82f624}.telemetry-sparkline__line{stroke:var(--accent);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.telemetry-sparkline--offline .telemetry-sparkline__area{fill:#d645451f}.telemetry-sparkline--offline .telemetry-sparkline__line{stroke:#d64545}.telemetry-status{display:flex;align-items:center;justify-content:flex-end}.telemetry-status__badge{display:inline-flex;align-items:center;justify-content:center;min-width:70px;padding:6px 10px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent}.telemetry-status__badge--healthy{color:var(--success);background:color-mix(in srgb,var(--success) 14%,transparent);border-color:color-mix(in srgb,var(--success) 24%,var(--border-color))}.telemetry-status__badge--waiting{color:var(--text-secondary);background:color-mix(in srgb,var(--border-color) 24%,transparent);border-color:color-mix(in srgb,var(--border-color) 48%,transparent)}.telemetry-status__badge--degraded{color:var(--warning);background:color-mix(in srgb,var(--warning) 14%,transparent);border-color:color-mix(in srgb,var(--warning) 24%,var(--border-color))}.telemetry-status__badge--offline{color:#d64545;background:color-mix(in srgb,#d64545 12%,transparent);border-color:color-mix(in srgb,#d64545 24%,var(--border-color))}.empty-text{margin:0;color:var(--text-secondary);font-size:12px}@media(max-width:1200px){.camera-grid{grid-template-columns:repeat(4,1fr)}.telemetry-row{grid-template-columns:1fr}.telemetry-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.camera-grid,.camera-fleet-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.telemetry-row{grid-template-columns:1fr;padding:8px;gap:8px}.telemetry-title{display:flex;justify-content:space-between;align-items:center;font-size:13px}.telemetry-status{position:static}.telemetry-metrics{grid-template-columns:repeat(3,1fr);gap:clamp(6px,2vw,12px)}.telemetry-metric{gap:clamp(22px,.16vw,16px)}.telemetry-metric__graph{height:14px;width:clamp(70%,78vw / 3,90%);margin:0 auto}.telemetry-metric__value{font-size:clamp(9px,2.5vw,11px)}.telemetry-metric__label{font-size:clamp(8px,2vw,10px)}}.device-health-list{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:10px}.device-health-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px}.device-health-tile{border:1px solid var(--border-color);border-radius:12px;padding:12px;background:var(--panel-subtle-bg);min-height:276px;display:flex;flex-direction:column}.device-health-tile.healthy{border-color:#1f9a673d}.device-health-tile.degraded{border-color:#b5851d47}.device-health-tile.offline{border-color:#d645453d}.device-health-tile-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.device-health-tile-header strong{color:var(--text-primary);font-size:13px}.device-health-tile-header span{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.device-health-metric-grid{display:grid;gap:10px;flex:1}.device-health-metric{display:grid;gap:4px}.device-health-metric__label-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.device-health-metric__label{color:var(--text-secondary);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.device-health-metric__value{color:var(--text-primary);font-size:12px;font-weight:700}.device-health-metric__graph{position:relative;height:34px;overflow:hidden;border-radius:8px;background:linear-gradient(to top,color-mix(in srgb,var(--border-color) 45%,transparent) 1px,transparent 1px) center / 100% 100%,color-mix(in srgb,var(--bg-card) 35%,transparent)}.device-health-sparkline{width:100%;height:100%;display:block;overflow:visible}.device-health-sparkline__area{fill:#3b82f629;opacity:1}.device-health-sparkline__line{stroke:var(--accent);stroke-width:2.25;stroke-linecap:round;stroke-linejoin:round}.device-health-sparkline--offline .device-health-sparkline__area{fill:#d6454524}.device-health-sparkline--offline .device-health-sparkline__line{stroke:#d64545}.device-health-uptime{margin-top:12px;display:flex;align-items:baseline;justify-content:flex-end;gap:8px}.device-health-uptime__label{color:var(--text-secondary);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.device-health-uptime__value{color:var(--text-primary);font-size:13px;font-weight:800}.device-health-card{padding:10px;border:1px solid var(--border-color);border-radius:8px;background:var(--panel-subtle-bg)}.device-health-card h4{margin:0 0 8px;font-size:13px;color:var(--text-primary)}.device-health-metrics{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:4px 8px;font-size:64px;color:var(--text-secondary)}@media(max-width:768px){.device-health-list,.device-health-grid{grid-template-columns:1fr}}.zone-occupancy-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.zone-occupancy-item{display:flex;justify-content:space-between;align-items:center;padding:10px;border-radius:8px;border:1px solid var(--border-color);color:var(--text-secondary)}.zone-occupancy-item strong{color:var(--text-primary)}.alerts-panel{display:flex;flex-direction:column}.alerts-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:4px}.ack-all-btn{padding:6px 12px;border-radius:6px;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s ease;font-family:inherit}.ack-all-btn:hover{background:color-mix(in srgb,var(--success) 14%,transparent);color:var(--success);border-color:var(--success)}.alerts-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.alerts-empty{color:var(--text-secondary);font-size:13px;text-align:center;padding:20px 0}.alert-item{display:flex;align-items:center;gap:10px;padding:12px;border-radius:8px;border:1px solid var(--border-color);transition:background .15s ease;min-height:84px}.alert-item.critical{background:color-mix(in srgb,var(--danger) 10%,transparent);border-color:color-mix(in srgb,var(--danger) 24%,var(--border-color))}.alert-item.warning{background:color-mix(in srgb,var(--warning) 10%,transparent);border-color:color-mix(in srgb,var(--warning) 24%,var(--border-color))}.alert-item.info{background:color-mix(in srgb,var(--accent) 10%,transparent);border-color:color-mix(in srgb,var(--accent) 24%,var(--border-color))}.alert-card-media{width:64px;height:64px;border-radius:10px;object-fit:cover;flex-shrink:0;border:1px solid var(--border-color);background:var(--panel-subtle-bg)}.alert-card-media--fallback,.alert-card-media--skeleton{display:inline-flex;align-items:center;justify-content:center;color:var(--text-primary);font-size:20px;font-weight:700}.alert-card-media--fallback{background:color-mix(in srgb,var(--accent) 14%,var(--panel-subtle-bg))}.alert-body{flex:1;display:flex;flex-direction:column;gap:2px}.alert-body strong{font-size:13px;color:var(--text-primary)}.alert-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.alert-pill{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;background:var(--panel-subtle-bg);border:1px solid var(--border-color);font-size:10px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.alert-desc{font-size:12px;color:var(--text-secondary);line-height:1.4}.alert-meta{font-size:11px;color:var(--text-secondary);opacity:.7;margin-top:2px}.ack-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease}.ack-btn:hover{background:color-mix(in srgb,var(--danger) 90%,transparent);color:#fff;border-color:var(--danger)}.suspicious-feed{display:flex;flex-direction:column;gap:10px;max-height:360px;overflow-y:auto}.suspicious-item{border:1px solid var(--border-color);border-radius:8px;padding:12px;background:var(--panel-subtle-bg)}.suspicious-item-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}.suspicious-item-head strong{font-size:12px;color:var(--warning);text-transform:uppercase;letter-spacing:.04em}.suspicious-item-head time,.suspicious-item-meta{font-size:11px;color:var(--text-secondary)}.suspicious-item-title{font-size:13px;color:var(--text-primary);font-weight:600;margin-bottom:4px}.suspicious-item-meta{display:flex;flex-direction:column;gap:2px}.face-stream-scroll{max-height:340px;overflow-y:auto}.face-card{display:flex;gap:12px;padding:10px;border-bottom:1px solid var(--border-color);align-items:center}.face-card.unknown{background:#ef444426}.face-thumb-wrap{flex-shrink:0}.face-thumb{width:42px;height:42px;border-radius:8px;object-fit:cover;background:#d9e5f8}.face-thumb.fallback{display:grid;place-items:center;font-size:11px;color:var(--text-secondary)}.face-meta{display:flex;flex-direction:column;flex:1;color:var(--text-secondary);font-size:12px}.face-meta strong{color:var(--text-primary)}.face-card time{font-size:11px;color:var(--text-secondary)}.event-timeline{max-height:340px;overflow-y:auto}.event-row{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-color)}.event-content{display:flex;flex-direction:column;font-size:12px;color:var(--text-secondary)}.event-content strong{color:var(--text-primary)}.analytics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.chart-container{position:relative;height:220px;background:transparent;border:none;border-radius:8px;padding:4px 0 0;box-shadow:none}.chart-container :where(.recharts-surface,.recharts-wrapper){background:transparent!important}.chart-container :where(.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line){stroke:var(--chart-grid)!important}.chart-container :where(.recharts-cartesian-axis-line,.recharts-cartesian-axis-tick-line){stroke:transparent!important}.chart-container :where(.recharts-polar-grid-angle line,.recharts-polar-grid-concentric path){stroke:transparent!important}.chart-empty-state{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:16px;text-align:center;z-index:1;pointer-events:none}.chart-empty-state strong{font-size:13px;color:var(--text-primary)}.chart-empty-state span{max-width:220px;font-size:12px;color:var(--text-secondary)}.chart-container-lg,.chart-container-gauge{height:240px}.recognition-grid{align-items:stretch}.gauge-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.gauge-center-copy,.donut-center-copy{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;z-index:1;text-align:center}.gauge-center-copy strong,.donut-center-copy strong{font-size:28px;line-height:1;color:var(--text-primary)}.gauge-center-copy span,.donut-center-copy span{font-size:12px;color:var(--text-secondary)}.gauge-center-copy.warning strong{color:var(--warning)}.gauge-center-copy.danger strong{color:var(--danger)}@media(max-width:1200px){.analytics-grid{grid-template-columns:1fr}.gauge-grid{grid-template-columns:1fr 1fr}}@media(max-width:768px){.gauge-grid{grid-template-columns:1fr}}.presence-card{height:700px;display:flex;flex-direction:column;overflow:hidden}.presence-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:4px;flex-shrink:0}.presence-title-area{display:flex;flex-direction:column;gap:2px}.presence-title-area .section-header{margin:0}.presence-subtitle{font-size:12px;color:var(--text-secondary)}.presence-body{display:flex;flex-direction:column;gap:12px;padding-top:12px;flex:1;min-height:0;overflow:hidden}.presence-date-nav{display:flex;align-items:center;justify-content:center;gap:12px;flex-shrink:0}.date-arrow{width:34px;height:34px;border-radius:8px;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.date-arrow:hover{background:#2563eb14;color:var(--accent, #2563eb);border-color:var(--accent, #2563eb)}.date-display-wrapper{position:relative}.date-display{padding:8px 24px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-size:14px;font-weight:700;cursor:pointer;transition:all .15s ease;font-family:inherit;min-width:170px;text-align:center}.date-display:hover{border-color:var(--accent, #2563eb);box-shadow:0 0 0 3px #2563eb1a}.hidden-date-input{position:absolute;top:100%;left:50%;transform:translate(-50%);opacity:0;width:1px;height:1px;pointer-events:auto}.presence-summary{display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0}.summary-chip{flex:1;min-width:70px;padding:10px;border-radius:10px;border:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;transition:all .15s ease}.summary-chip:hover{transform:translateY(-2px);box-shadow:0 4px 14px #0000000f}.summary-chip.active{border-width:2px}.summary-chip.blue{background:#2563eb0d}.summary-chip.blue.active{border-color:#2563eb;background:#2563eb1f}.summary-chip.green{background:#10b9810d}.summary-chip.green.active{border-color:#10b981;background:#10b9811f}.summary-chip.purple{background:#8b5cf60d}.summary-chip.purple.active{border-color:#8b5cf6;background:#8b5cf61f}.summary-chip.teal{background:#06b6d40d}.summary-chip.teal.active{border-color:#06b6d4;background:#06b6d41f}.summary-chip.red{background:#ef44440d}.summary-chip.red.active{border-color:#ef4444;background:#ef44441f}.summary-chip.yellow{background:#facc150d}.summary-chip.yellow.active{border-color:#f59e0b;background:#facc151f}.chip-value{font-size:20px;font-weight:800;color:var(--text-primary);line-height:1}.chip-label{font-size:10px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.3px}.presence-tabs{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex-shrink:0}.presence-tab{border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:inherit}.presence-tab:hover{border-color:var(--accent, #2563eb);color:var(--accent, #2563eb)}.presence-tab.active{background:#2563eb1a;border-color:var(--accent, #2563eb);color:var(--accent, #2563eb)}.presence-search-bar{position:relative;display:flex;align-items:center;flex-shrink:0}.presence-search-input{width:100%;height:36px;padding:0 36px 0 14px;border-radius:8px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);font-size:13px;font-family:inherit;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.presence-search-input::placeholder{color:var(--text-secondary)}.presence-search-input:focus{border-color:var(--accent, #2563eb);box-shadow:0 0 0 3px #2563eb1a}.search-clear{position:absolute;right:8px;width:24px;height:24px;border-radius:50%;border:none;background:var(--border-color);color:var(--text-secondary);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.search-clear:hover{background:var(--text-secondary);color:#fff}.presence-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:40px 0;color:var(--text-secondary);font-size:13px;flex:1}.presence-spinner{width:24px;height:24px;border-radius:50%;border:3px solid var(--border-color);border-top-color:var(--accent, #2563eb);animation:presence-spin .8s linear infinite}@keyframes presence-spin{to{transform:rotate(360deg)}}.presence-error{display:flex;align-items:center;justify-content:center;gap:12px;padding:30px 0;color:#ef4444;font-size:13px;flex:1}.retry-btn{padding:6px 14px;border-radius:6px;border:1px solid #ef4444;background:#ef444414;color:#ef4444;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s ease}.retry-btn:hover{background:#ef4444;color:#fff}.presence-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 0;color:var(--text-secondary);font-size:13px;flex:1}.empty-icon{font-size:32px}.presence-table-wrap{flex:1;min-height:0;overflow-x:auto;overflow-y:auto;border:1px solid var(--border-color);border-radius:10px}.presence-table{width:100%;border-collapse:collapse;font-size:13px}.presence-table thead{position:sticky;top:0;z-index:2}.presence-table th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-secondary);background:var(--bg-card);border-bottom:2px solid var(--border-color);white-space:nowrap}.presence-table td{padding:10px 14px;color:var(--text-secondary);border-bottom:1px solid var(--border-color);vertical-align:middle}.presence-table tbody tr:last-child td{border-bottom:none}.person-main-row{cursor:pointer;transition:background .12s ease}.person-main-row:hover{background:#2563eb0a}.expand-cell{width:40px;text-align:center}.row-expand-btn{width:24px;height:24px;border-radius:4px;border:none;background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease}.row-expand-btn:hover{background:#2563eb1a;color:var(--accent, #2563eb)}.name-cell{display:flex;align-items:center;gap:10px;color:var(--text-primary);font-weight:600}.person-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent, #2563eb),#6a35ff);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.person-avatar-img{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--border-color)}.person-name-wrap{display:flex;flex-direction:column;gap:2px}.person-name-text{font-size:13px;font-weight:600;color:var(--text-primary)}.record-count-badge{font-size:10px;font-weight:600;color:var(--accent, #2563eb);background:#2563eb14;padding:1px 6px;border-radius:10px;width:fit-content}.presence-badge{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.3px}.badge-status{background:#10b9811a;color:#10b981}.badge-unknown{background:#f59e0b24;color:#b45309}.zone-tags{display:flex;flex-wrap:wrap;gap:4px}.zone-tag{font-size:11px;padding:2px 8px;border-radius:6px;background:#8b5cf614;color:#8b5cf6;font-weight:600;white-space:nowrap}.time-cell{white-space:nowrap;font-variant-numeric:tabular-nums}.seen-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:24px;padding:0 8px;border-radius:6px;background:#06b6d41a;color:#06b6d4;font-weight:700;font-size:12px}.person-detail-row{background:#2563eb05}.person-detail-row td{padding:0 14px;border-bottom:1px solid rgba(37,99,235,.06)}.detail-row-inner{display:flex;flex-wrap:wrap;gap:16px;border-left:3px solid var(--accent, #2563eb);padding:12px 0 12px 16px;margin-left:8px}.detail-section{display:flex;flex-direction:column;gap:2px;min-width:80px}.detail-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-secondary);opacity:.7}.detail-value{font-size:13px;color:var(--text-primary);font-weight:500}.detail-images{display:flex;gap:12px;margin-top:8px;width:100%}.detail-img-wrap{display:flex;flex-direction:column;gap:4px}.detail-capture-img{width:80px;height:80px;object-fit:cover;border-radius:8px;border:2px solid var(--border-color);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.detail-capture-img:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.presence-footer{font-size:12px;color:var(--text-secondary);text-align:center;padding:8px 0 0;border-top:1px solid var(--border-color);flex-shrink:0}@media(max-width:1024px){.presence-summary{display:grid;grid-template-columns:repeat(2,1fr)}.detail-row-inner{gap:12px}}@media(max-width:768px){.presence-card{height:500px}.presence-date-nav{gap:8px}.date-display{min-width:130px;font-size:13px;padding:6px 14px}.date-arrow{width:30px;height:30px}.presence-table{font-size:12px}.presence-table th,.presence-table td{padding:8px 10px}.person-avatar,.person-avatar-img{width:28px;height:28px;font-size:11px}.name-cell{gap:8px}.detail-row-inner{flex-direction:column;gap:10px}.detail-capture-img{width:60px;height:60px}}@media(max-width:640px){.presence-summary{grid-template-columns:repeat(2,1fr);gap:8px}.summary-chip{padding:10px}.chip-value{font-size:18px}.presence-table th:nth-child(3),.presence-table td:nth-child(3){display:none}.presence-table th:nth-child(7),.presence-table td:nth-child(7){display:none}}@media(max-width:480px){.presence-card{height:450px}.presence-table th:nth-child(6),.presence-table td:nth-child(6){display:none}}.live-attendance-panel-shell{position:fixed;right:20px;bottom:20px;z-index:1200;width:min(420px,calc(100vw - 24px));transition:width var(--transition-mid) ease,transform var(--transition-mid) ease}.live-attendance-panel-shell.is-collapsed{width:92px}.live-attendance-panel{padding:0;overflow:hidden;box-shadow:var(--shadow);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur))}.live-attendance-panel-shell.is-collapsed .live-attendance-panel{width:92px;height:50px;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-card)}.live-attendance-panel__collapsed{position:relative;width:57px;height:12px;padding:0 12px;display:flex;align-items:center;justify-content:center;gap:10px;background:var(--bg-card)}.live-attendance-panel__collapsed-count{display:inline-flex;align-items:center;justify-content:center}.live-attendance-panel__count-badge{min-width:34px;height:34px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-size:13px;font-weight:800;color:var(--accent);background:color-mix(in srgb,var(--accent) 18%,var(--bg-card));border:none}.live-attendance-panel__header{display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border-color);background:var(--panel-subtle-bg)}.live-attendance-panel__title-wrap{display:flex;flex-direction:column;gap:2px;min-width:0}.live-attendance-panel__title{margin:0;color:var(--text-primary);font-size:15px;font-weight:700}.live-attendance-panel__subtitle{color:var(--text-secondary);font-size:12px}.live-attendance-panel__toggle,.live-attendance-panel__new{border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font:inherit;cursor:pointer;transition:border-color var(--transition-fast) ease,background var(--transition-fast) ease,color var(--transition-fast) ease,transform var(--transition-fast) ease,box-shadow var(--transition-fast) ease}.live-attendance-panel__toggle{width:36px;height:36px;border-radius:12px;padding:0;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.live-attendance-panel-shell.is-collapsed .live-attendance-panel__toggle{width:26px;height:44px;border-radius:14px;border:none;background:transparent}.live-attendance-panel__toggle-arrow{display:inline-flex;align-items:center;justify-content:center;font-size:18px;line-height:1}.live-attendance-panel__toggle:hover,.live-attendance-panel__new:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 8px 18px color-mix(in srgb,var(--accent) 14%,transparent)}.live-attendance-panel__toggle:hover{transform:translateY(-1px)}.live-attendance-panel-shell.is-collapsed .live-attendance-panel__toggle:hover{transform:translateY(-1px);color:var(--text-primary);background:transparent;box-shadow:none}.live-attendance-panel__content{display:grid;grid-template-rows:1fr auto;max-height:60vh;transition:max-height var(--transition-mid) ease,opacity var(--transition-mid) ease,transform var(--transition-mid) ease;opacity:1;transform:translateY(0)}.live-attendance-panel__scroll{overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px;min-height:0;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}.live-attendance-panel__scroll::-webkit-scrollbar{width:8px}.live-attendance-panel__scroll::-webkit-scrollbar-track{background:var(--scrollbar-track)}.live-attendance-panel__scroll::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:999px}.live-attendance-panel__separator{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.live-attendance-panel__separator span{padding:0 10px;background:var(--bg-card)}.live-attendance-panel__separator:before,.live-attendance-panel__separator:after{content:"";height:1px;flex:1;background:var(--border-color)}.live-attendance-panel__empty{padding:24px 16px;text-align:center;color:var(--text-secondary);font-size:13px}.live-attendance-panel__new{justify-self:center;margin:0 14px 14px;padding:9px 14px;font-size:12px;font-weight:700;border-radius:999px;background:color-mix(in srgb,var(--accent) 12%,var(--bg-card))}.live-attendance-card{display:grid;grid-template-columns:48px 1fr;gap:12px;padding:12px;border:1px solid var(--border-color);border-radius:14px;background:var(--panel-muted);animation:live-attendance-card-enter .22s ease}.live-attendance-card__avatar-wrap{width:48px;height:48px}.live-attendance-card__avatar,.live-attendance-card__avatar-fallback{width:48px;height:48px;border-radius:50%}.live-attendance-card__avatar{display:block;object-fit:cover;border:1px solid var(--border-color);background:var(--panel-subtle-bg)}.live-attendance-card__avatar-fallback{display:grid;place-items:center;color:var(--text-primary);font-weight:700;background:color-mix(in srgb,var(--accent) 16%,var(--panel-subtle-bg));border:1px solid color-mix(in srgb,var(--accent) 22%,var(--border-color))}.live-attendance-card__body{display:flex;flex-direction:column;gap:8px;min-width:0}.live-attendance-card__topline{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.live-attendance-card__name{margin:0;color:var(--text-primary);font-size:14px;font-weight:700;line-height:1.2}.live-attendance-card__time{color:var(--text-secondary);font-size:11px;line-height:1.2;text-align:right;flex-shrink:0}.live-attendance-card__badges{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.live-attendance-card__badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;font-size:11px;font-weight:700;border:1px solid transparent}.live-attendance-card__badge--status{color:var(--text-primary);background:var(--panel-subtle-bg);border-color:var(--border-color)}.live-attendance-card__event--entry{color:var(--success);background:color-mix(in srgb,var(--success) 14%,transparent);border-color:color-mix(in srgb,var(--success) 26%,var(--border-color))}.live-attendance-card__event--exit{color:var(--warning);background:color-mix(in srgb,var(--warning) 14%,transparent);border-color:color-mix(in srgb,var(--warning) 26%,var(--border-color))}.live-attendance-card__meta{color:var(--text-secondary);font-size:12px}.live-attendance-card__camera{display:inline-flex;align-items:center;gap:6px}.live-attendance-card__preview-wrap{width:64px;height:64px;border-radius:12px;overflow:hidden;border:1px solid var(--border-color);background:var(--panel-subtle-bg)}.live-attendance-card__preview{display:block;width:100%;height:100%;object-fit:cover}@keyframes live-attendance-card-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.live-attendance-panel-shell{right:12px;bottom:12px;width:min(420px,calc(100vw - 24px))}.live-attendance-panel-shell.is-collapsed{width:92px}.live-attendance-panel__header{padding:14px}.live-attendance-panel__scroll{padding:12px}}.dashboard-container{display:flex;flex-direction:column;gap:20px;padding:20px}.dashboard-row{display:grid;gap:20px}.dashboard-container.cached-data-mode .dashboard-card,.dashboard-container.cached-data-mode .kpi-item,.dashboard-container.cached-data-mode .system-status-bar{position:relative;overflow:hidden}.dashboard-container.cached-data-mode .dashboard-card:after,.dashboard-container.cached-data-mode .kpi-item:after,.dashboard-container.cached-data-mode .system-status-bar:after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.18) 35%,rgba(255,255,255,.4) 50%,rgba(255,255,255,.18) 65%,transparent 100%);transform:translate(-120%);animation:dashboard-cache-shimmer 1.5s linear infinite;pointer-events:none}@keyframes dashboard-cache-shimmer{0%{transform:translate(-120%)}to{transform:translate(120%)}}.dashboard-row.three-up{grid-template-columns:2fr 1fr 1fr}.dashboard-row.two-up{grid-template-columns:1fr 1fr}.dashboard-row.two-up-8-4{grid-template-columns:2fr 1fr}@media(max-width:1200px){.dashboard-row.three-up{grid-template-columns:1fr 1fr}.dashboard-row.two-up,.dashboard-row.two-up-8-4{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-container{gap:14px;padding:14px}.dashboard-row{grid-template-columns:1fr!important}}.dashboard-container{display:grid;gap:var(--content-gap);padding:var(--content-gap)}.dashboard-theme{background:linear-gradient(180deg,var(--dashboard-bg),var(--dashboard-bg-secondary));border-radius:var(--card-radius);min-height:calc(100vh - 140px)}.dashboard-card{background:var(--bg-card);border-radius:var(--card-radius);border:1px solid var(--border-color);padding:18px}.section-header{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--text-primary)}@media(max-width:1200px){.dashboard-container{gap:calc(var(--content-gap) * .8);padding:calc(var(--content-gap) * .8)}}@media(max-width:768px){.dashboard-container{gap:calc(var(--content-gap) * .6);padding:calc(var(--content-gap) * .6)}}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;width:100%;height:100%}body{background:var(--bg);color:var(--text);overflow:hidden;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial}html,*{scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track);scrollbar-width:thin}*::-webkit-scrollbar{width:var(--scrollbar-size);height:var(--scrollbar-size)}*::-webkit-scrollbar-track{background:var(--scrollbar-track);border-radius:999px}*::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:999px;border:0;min-height:32px}*::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}*::-webkit-scrollbar-thumb:active{background:var(--scrollbar-thumb-active)}*::-webkit-scrollbar-corner{background:transparent}*::-webkit-scrollbar-button{width:0;height:0;display:none}img{max-width:100%;display:block}button{font-family:inherit}a{color:inherit;text-decoration:none}.vx-app{display:flex;width:100vw;height:100vh;overflow:hidden}.vx-main{flex:1;display:flex;flex-direction:column;min-width:0}.vx-content{flex:1;padding:var(--content-gap);overflow:auto;-webkit-overflow-scrolling:touch}.vx-side{width:260px;min-width:260px;background:var(--side);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:40;transition:width .26s cubic-bezier(.25,.8,.25,1)}.vx-side.collapsed{width:64px}.vx-side.mobile{position:fixed;inset:0 auto 0 0;transform:translate(-100%);box-shadow:0 8px 30px #030c1c1f}.vx-side-inner{flex:1;display:flex;flex-direction:column;padding:16px 12px;gap:8px;overflow-y:auto;scrollbar-width:none}.vx-side-inner::-webkit-scrollbar{width:0;height:0;display:none}.vx-nav{display:flex;flex-direction:column;gap:10px}.vx-nav-section{display:flex;flex-direction:column;gap:6px}.vx-nav-title{font-size:12px;font-weight:700;color:var(--muted);padding:6px 8px}.vx-nav-link{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius);font-size:14px;transition:background .14s ease,color .14s ease}.vx-nav-link.active{background:linear-gradient(90deg,#2563eb0f,#2563eb08);border-left:3px solid var(--accent);padding-left:10px}.vx-side.collapsed .vx-nav-link span{display:none}.vx-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border)}.vx-search input{padding:8px 12px;border-radius:var(--radius);border:1px solid var(--border);background:transparent;color:var(--text)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--card-radius);padding:18px;box-shadow:var(--shadow);transition:transform .16s ease,box-shadow .18s ease}.vx-hero{display:flex;justify-content:space-between;gap:16px;margin-bottom:14px}.hero-title{font-size:22px;font-weight:700}.hero-sub{font-size:14px;color:var(--muted)}.kpi-row{display:flex;gap:12px;flex-wrap:wrap}.kpi.card{flex:1;min-width:160px;padding:12px 14px}.kpi-value{font-size:18px;font-weight:700}.lm-content{display:flex;gap:18px}.lm-sidebar-panel{width:300px;min-width:220px}.lm-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;flex:1}.lm-card{display:flex;flex-direction:column;border-radius:var(--card-radius);overflow:hidden;border:1px solid var(--border);background:var(--card)}.lm-card-img{height:140px;object-fit:cover}.lm-card-footer{display:flex;justify-content:space-between;padding:10px 12px;font-size:14px}.fullscreen-modal,.cam-modal-overlay,.edit-overlay{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;z-index:80}.fullscreen-inner{width:min(90vw,1200px);background:var(--card);border-radius:var(--card-radius);display:flex;overflow:hidden}.fullscreen-video{flex:2;background:#000}.fullscreen-info{flex:1;padding:16px;overflow:auto}.edit-page-wrapper{position:fixed;inset:0 0 0 auto;width:460px;max-width:100%;transform:translate(100%);transition:transform .32s cubic-bezier(.2,.9,.3,1);z-index:90}.edit-page-wrapper.open{transform:translate(0)}.edit-page-container{height:100%;background:var(--card);padding:18px;overflow:auto}.loginPage{display:flex;min-height:100vh}.loginFormLeft{flex:1;display:flex;align-items:center;justify-content:center}.loginBox{width:420px;padding:18px;border-radius:var(--card-radius);background:var(--card);box-shadow:var(--shadow)}.loader-wrap{display:flex;align-items:center;justify-content:center;padding:24px}.loader{width:48px;height:48px;border-radius:50%;background:linear-gradient(90deg,var(--accent),var(--accent-2));animation:spin 1.2s linear infinite;-webkit-mask:radial-gradient(circle,transparent 40%,black 41%);mask:radial-gradient(circle,transparent 40%,black 41%)}.flex{display:flex}.center{display:flex;align-items:center;justify-content:center}.hidden{display:none}.text-muted{color:var(--muted)}.clickable{cursor:pointer}@media(max-width:1000px){.vx-side.desktop{display:none}.vx-side.mobile{display:flex}.vx-content{padding:calc(var(--content-gap) * .6)}}@media(max-width:640px){.vx-topbar{padding:10px}.lm-content{flex-direction:column}.lm-sidebar-panel{width:100%}}.vx-side-brand{display:flex;align-items:center;gap:10px;padding:12px 14px;margin-bottom:6px;border-bottom:1px solid var(--border)}.vx-brand-text{font-size:16px;font-weight:700;color:var(--accent);letter-spacing:.2px;white-space:nowrap}.vx-side.collapsed .vx-brand-text{font-size:15px}.vx-side-inner{display:flex;flex-direction:column;height:100%;overflow-y:auto;padding:12px 8px}.vx-nav{display:flex;flex-direction:column;gap:14px}.vx-nav-section{display:flex;flex-direction:column;gap:4px}.vx-nav-title{display:flex;align-items:center;gap:8px;padding:6px 12px;font-size:12px;font-weight:700;color:var(--muted);-webkit-user-select:none;user-select:none}.vx-nav-title.collapsible{cursor:pointer}.vx-nav-title .vx-icon{width:16px;height:16px;color:var(--muted)}.collapsible-caret{margin-left:auto;font-size:12px;color:var(--muted);transition:transform .18s ease}.collapsible-wrapper{overflow:hidden;transition:height .26s cubic-bezier(.2,.9,.3,1)}.collapsible-inner{display:flex;flex-direction:column;gap:2px;padding-left:6px}.vx-nav-link{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;font-size:14px;color:var(--text);transition:background .15s ease,color .15s ease}.vx-nav-link:hover{background:#0000000a}.vx-nav-link .vx-icon{width:16px;height:16px;flex-shrink:0;color:var(--muted)}.vx-nav-link.active{background:linear-gradient(90deg,#2563eb14,#2563eb0a);color:var(--accent)}.vx-nav-link.active .vx-icon{color:var(--accent)}.vx-nav-link.small{font-size:13px;padding-left:34px;color:var(--muted)}.vx-nav-link.small.active{color:var(--accent)}.vx-side.collapsed .vx-nav-title span,.vx-side.collapsed .vx-nav-link span,.vx-side.collapsed .collapsible-caret{display:none}.vx-side.collapsed .vx-nav-link{justify-content:center;padding-left:0;padding-right:0}.vx-side.collapsed .vx-nav-link .vx-icon{margin:0 auto}.vx-toggle-area{margin-top:10px;padding:6px 12px}.vx-backdrop{position:fixed;inset:0;background:#02061773;z-index:30}.vx-side{width:260px;min-width:260px;background:var(--side);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:40;transition:width .26s cubic-bezier(.25,.8,.25,1),min-width .26s cubic-bezier(.25,.8,.25,1);overflow:hidden}.vx-side.collapsed{width:64px;min-width:64px}.vx-side.collapsed .vx-nav-title{justify-content:center;padding:6px 0}.vx-side.collapsed .vx-nav-title .vx-nav-label,.vx-side.collapsed .collapsible-caret{display:none}.vx-side.collapsed .vx-nav-link{justify-content:center;padding:8px 0}.vx-side.collapsed .vx-nav-link .vx-icon{margin:0}.vx-side.collapsed .collapsible-wrapper{height:0!important;overflow:hidden}.vx-side.collapsed .vx-nav-link span,.vx-side.collapsed .vx-nav-title span:not(.collapsible-caret){display:none}.vx-side.collapsed .vx-side-brand{justify-content:center;padding:12px 0}.vx-side.collapsed .vx-nav-title{font-size:0}.vx-side.collapsed .vx-nav-title .vx-icon{font-size:initial}.vx-side.mobile{position:fixed;inset:0 auto 0 0;width:260px;min-width:260px;transform:translate(-100%);transition:transform .3s cubic-bezier(.25,.8,.25,1);box-shadow:0 8px 30px #030c1c1f}.vx-side.mobile.open{transform:translate(0)}.vx-side.desktop{position:relative;transform:none}@media(max-width:1000px){.vx-side.desktop{display:none}.vx-side.mobile{display:flex}}@media(min-width:1001px){.vx-side.mobile{display:none}.vx-side.desktop{display:flex}}.lm-page{display:flex;flex-direction:column;gap:16px;height:100%;width:100%;padding:20px;box-sizing:border-box;color:var(--text, #1f2937)}.lm-page-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.lm-page-header h1{margin:0;font-size:1.6rem;line-height:1.2}.lm-page-header p{margin:6px 0 0;color:#6b7280;font-size:.9rem}.lm-page-actions{display:flex;gap:10px;flex-wrap:wrap}.lm-header-button{border:1px solid #d4d7dd;background:#fff;border-radius:8px;padding:8px 12px;font-size:.85rem;color:#1f2937;display:inline-flex;align-items:center;gap:8px;cursor:pointer}.lm-header-button:hover{background:#f3f4f6}.lm-page-layout{position:relative;display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px;flex:1;min-height:0}.lm-grid-area{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:14px;min-height:0;overflow:auto}.lm-error-banner{margin-bottom:12px;border-radius:8px;border:1px solid #fecaca;background:#fef2f2;color:#b91c1c;padding:10px 12px;font-size:.85rem}.lm-sidebar{background:#fff;border:1px solid #e5e7eb;border-radius:12px;min-height:0;overflow:hidden}.lm-sidebar-scroll{height:100%;overflow-y:auto;padding:14px;box-sizing:border-box}.lm-sidebar-section{border-bottom:1px solid #f1f5f9;padding-bottom:14px;margin-bottom:14px}.lm-sidebar-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.lm-sidebar-section--header{display:flex;justify-content:space-between;align-items:center}.lm-sidebar-section h2,.lm-sidebar-section h3{margin:0 0 10px;font-size:.95rem}.lm-icon-button{border:none;background:#f3f4f6;width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.lm-camera-checklist{display:flex;flex-direction:column;gap:8px;max-height:260px;overflow-y:auto;padding-right:4px}.lm-camera-check-item{display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:10px;font-size:.85rem;min-height:44px;padding:8px 10px;border-radius:8px;border:1px solid #eef2f7}.lm-camera-check-item:hover{border-color:#cbd5e1;background:#f8fafc}.lm-camera-check-item input{width:16px;height:16px;margin:0;accent-color:#2563eb}.lm-camera-check-item span{display:flex;flex-direction:column;min-width:0;gap:2px}.lm-camera-check-item strong{font-size:.85rem;font-weight:600;line-height:1.2}.lm-camera-check-item small{color:#6b7280;font-size:.74rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lm-checklist-skeleton{height:42px;border-radius:8px;background:linear-gradient(110deg,#f3f4f6 8%,#e5e7eb 18%,#f3f4f6 33%);background-size:200% 100%;animation:lm-shimmer 1.2s linear infinite}.lm-sidebar-button-group,.lm-preset-list{display:grid;gap:8px}.lm-sidebar-button-group button,.lm-preset-list button{border:1px solid #d4d7dd;border-radius:8px;background:#fff;color:#1f2937;padding:9px 10px;display:flex;align-items:center;justify-content:flex-start;gap:8px;cursor:pointer;font-size:.84rem}.lm-sidebar-button-group button:hover,.lm-preset-list button:hover{background:#f8fafc}.lm-preset-list button.is-active{border-color:#2563eb;background:#eff6ff;color:#1d4ed8}.lm-hidden-input{display:none}.lm-empty-inline,.lm-grid-empty-inline{margin:0;font-size:.82rem;color:#6b7280}.lm-grid{display:grid;gap:12px}.lm-grid--grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.lm-grid--quad{grid-template-columns:repeat(2,minmax(0,1fr))}.lm-grid--stack{grid-template-columns:1fr}.lm-grid-footnote{margin:10px 2px 0;font-size:.8rem;color:#6b7280}.lm-grid-wide{display:grid;gap:12px;grid-template-columns:minmax(0,2fr) minmax(0,1fr)}.lm-grid-wide-main .lm-camera-card{min-height:380px}.lm-grid-wide-side{display:flex;flex-direction:column;gap:12px;min-height:0;overflow:auto}.lm-grid-empty{border:1px dashed #d4d7dd;border-radius:10px;padding:24px;text-align:center;color:#6b7280}.lm-grid-empty h3{margin:0 0 8px;color:#1f2937}.lm-grid-empty p{margin:0}.lm-camera-card{border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#fff;display:flex;flex-direction:column;min-height:260px}.lm-camera-card--compact{min-height:190px}.lm-camera-card--skeleton{pointer-events:none}.lm-camera-media{position:relative;flex:1;min-height:160px;background:#030712;overflow:hidden}.lm-camera-video{width:100%;height:100%;display:block;object-fit:cover;background:#000}.lm-status-badge{position:absolute;top:10px;left:10px;z-index:3;border-radius:20px;padding:4px 10px;font-size:.72rem;font-weight:600;border:1px solid transparent}.lm-status-badge--online{color:#166534;background:#dcfce7;border-color:#86efac}.lm-status-badge--checking{color:#9a3412;background:#ffedd5;border-color:#fdba74}.lm-status-badge--offline{color:#991b1b;background:#fee2e2;border-color:#fca5a5}.lm-status-badge--paused,.lm-status-badge--idle{color:#334155;background:#e2e8f0;border-color:#cbd5e1}.lm-overlay-actions{position:absolute;top:10px;right:10px;display:inline-flex;gap:8px;z-index:3}.lm-overlay-button{width:30px;height:30px;border:1px solid rgba(255,255,255,.25);border-radius:50%;background:#0f172ab3;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.lm-overlay-button:hover{background:#0f172af2}.lm-overlay-button:disabled{opacity:.65;cursor:not-allowed}.lm-overlay-button--power.is-start{background:#16a34ae0}.lm-overlay-button--power.is-start:hover{background:#16a34afa}.lm-overlay-button--power.is-stop{background:#dc2626e0}.lm-overlay-button--power.is-stop:hover{background:#dc2626fa}.lm-play-overlay{position:absolute;inset:auto auto 12px 12px;border:1px solid rgba(255,255,255,.3);border-radius:20px;background:#0f172ac7;color:#fff;display:inline-flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;z-index:3}.lm-camera-skeleton{position:absolute;inset:0;background:#020617cc;color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:12px;z-index:2}.lm-skeleton-shimmer{width:100%;height:100%;background:linear-gradient(110deg,#111827 8%,#1f2937 18%,#111827 33%);background-size:200% 100%;animation:lm-shimmer 1.2s linear infinite}.lm-camera-skeleton .lm-skeleton-shimmer{position:absolute;inset:0;opacity:.55}.lm-camera-skeleton p{position:relative;margin:0;font-size:.84rem;z-index:1}.lm-reconnect-indicator{position:absolute;bottom:10px;right:10px;z-index:3;border-radius:20px;padding:4px 10px;font-size:.72rem;color:#fff;background:#1e293bd1;display:inline-flex;align-items:center;gap:6px}.lm-line-skeleton{width:70%;height:11px;border-radius:8px;background:#e5e7eb}.lm-line-skeleton--small{width:50%;margin-top:6px}.lm-camera-meta{padding:10px 12px;border-top:1px solid #f3f4f6}.lm-camera-meta h4{margin:0;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lm-camera-meta p{margin:4px 0 0;font-size:.78rem;color:#6b7280}.lm-fullscreen-modal{position:fixed;inset:0;z-index:4000;background:#000;display:flex;flex-direction:column;width:100vw;height:100vh;height:100dvh;overflow:hidden}.lm-modal-stage{flex:1;position:relative;display:flex;align-items:center;justify-content:center;padding:56px 64px 24px;min-width:0;min-height:0;overflow:hidden}.lm-modal-video{flex:1 1 auto;width:100%;height:100%;min-width:0;min-height:0;max-width:100%;max-height:100%;object-fit:contain;background:#000}.lm-modal-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;color:#f3f4f6;background:#00000073}.lm-modal-loading p{margin:0;font-size:.95rem}.lm-modal-action{border:1px solid #475569;border-radius:22px;background:#1e293b;color:#f8fafc;padding:8px 14px;display:inline-flex;align-items:center;gap:8px;cursor:pointer}.lm-modal-close,.lm-modal-nav{position:absolute;z-index:5;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:#0f172aa6;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.lm-modal-close{top:12px;right:12px}.lm-modal-nav--left{top:50%;left:12px;transform:translateY(-50%)}.lm-modal-nav--right{top:50%;right:12px;transform:translateY(-50%)}.lm-modal-footer{flex:0 0 auto;border-top:1px solid rgba(148,163,184,.35);background:#020617d9;color:#e2e8f0;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:12px 18px}.lm-modal-footer-main{min-width:180px}.lm-modal-footer h3{margin:0;font-size:1rem}.lm-modal-footer p{margin:4px 0 0;font-size:.82rem;color:#94a3b8}.lm-modal-telemetry{display:grid;grid-template-columns:repeat(5,minmax(0,auto));gap:10px;align-items:center;min-width:0}.lm-modal-telemetry-item{display:flex;flex-direction:column;gap:3px;min-width:72px}.lm-modal-telemetry-item span{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8}.lm-modal-telemetry-item strong{font-size:.82rem;color:#f8fafc;font-weight:600}.lm-modal-status-block{display:flex;flex-direction:column;align-items:flex-end;gap:6px;margin-left:auto}.lm-modal-status-block small{color:#fca5a5;font-size:.72rem;max-width:280px;text-align:right}.lm-modal-retrying{font-size:.75rem;display:inline-flex;align-items:center;gap:6px;color:#cbd5e1}.lm-drawer-backdrop{border:none;background:#02061773;position:fixed;inset:0;z-index:2500}@keyframes lm-shimmer{to{background-position-x:-200%}}.lm-spin{animation:lm-spin .9s linear infinite}@keyframes lm-spin{to{transform:rotate(360deg)}}@media(max-width:1200px){.lm-grid--grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:1024px){.lm-page{padding:14px}.lm-page-header{flex-wrap:wrap;align-items:center}.lm-page-actions{width:100%;justify-content:flex-start}.lm-page-actions .lm-header-button:first-child{margin-right:auto}.lm-page-layout{grid-template-columns:1fr}.lm-sidebar--drawer{position:fixed;left:0;top:0;bottom:0;width:min(88vw,340px);border-radius:0;z-index:2600;transform:translate(-100%);transition:transform .25s ease}.lm-sidebar--drawer.is-open{transform:translate(0)}.lm-grid-wide{grid-template-columns:1fr}.lm-grid-wide-main .lm-camera-card{min-height:280px}.lm-fullscreen-modal{top:var(--topbar-height);height:calc(100dvh - var(--topbar-height))}.lm-modal-stage{padding:60px 20px 14px}}@media(max-width:768px){.lm-grid--grid,.lm-grid--quad,.lm-grid--stack{grid-template-columns:1fr}.lm-camera-card{min-height:220px}.lm-modal-close,.lm-modal-nav{width:46px;height:46px}.lm-modal-footer{padding:10px 12px;flex-direction:column;align-items:flex-start}.lm-modal-telemetry{grid-template-columns:repeat(2,minmax(0,1fr));width:100%}.lm-modal-status-block{align-items:flex-start;margin-left:0}.lm-modal-status-block small{text-align:left;max-width:none}}.dark .lm-page{background:radial-gradient(circle at top left,rgba(96,165,250,.1),transparent 22%),radial-gradient(circle at bottom right,rgba(59,130,246,.1),transparent 22%),transparent}.dark .lm-page-header h1,.dark .lm-sidebar-section h2,.dark .lm-sidebar-section h3,.dark .lm-camera-check-item strong,.dark .lm-grid-empty h3,.dark .lm-camera-meta h4{color:var(--text-primary)}.dark .lm-page-header p,.dark .lm-camera-check-item small,.dark .lm-empty-inline,.dark .lm-grid-empty-inline,.dark .lm-grid-footnote,.dark .lm-camera-meta p{color:var(--text-secondary)}.dark .lm-header-button,.dark .lm-grid-area,.dark .lm-sidebar,.dark .lm-sidebar-button-group button,.dark .lm-preset-list button,.dark .lm-camera-card{background:var(--card, var(--bg-elevated));border-color:var(--border-color);color:var(--text-primary);box-shadow:var(--shadow)}.dark .lm-header-button:hover,.dark .lm-icon-button,.dark .lm-sidebar-button-group button:hover,.dark .lm-preset-list button:hover{background:var(--button-hover)}.dark .lm-sidebar-section,.dark .lm-camera-meta{border-color:var(--border-color)}.dark .lm-camera-check-item{border-color:var(--border-color);background:color-mix(in srgb,var(--card, var(--bg-elevated)) 88%,var(--page-bg) 12%)}.dark .lm-camera-check-item:hover{border-color:#60a5fa66;background:#1e293bf5}.dark .lm-preset-list button.is-active{background:#3b82f62e;color:#93c5fd;border-color:#60a5fa66}.dark .lm-grid-empty{background:#0f172a8c;border-color:var(--border-color);color:var(--text-secondary)}.dark .lm-line-skeleton{background:#4755698c}.dark .lm-status-badge--online{background:#10b9812e;color:#86efac;border-color:#10b98157}.dark .lm-status-badge--checking{background:#f59e0b2e;color:#fcd34d;border-color:#f59e0b57}.dark .lm-status-badge--offline{background:#ef44442e;color:#fca5a5;border-color:#ef444457}.dark .lm-status-badge--paused,.dark .lm-status-badge--idle{background:#47556966;color:#cbd5e1;border-color:#94a3b842}@media(max-width:640px){.records-table{overflow-x:auto}.table-row{grid-template-columns:100px 140px 140px 100px 160px 160px 80px;min-width:880px}.camera-cell{min-height:auto}}.attendance-page{width:100%;min-height:100vh;background:#eaf0f9;padding:24px 28px 32px}.attendance-shell{width:100%;max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.attendance-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px}.attendance-title{margin:0;font-size:32px;font-weight:700;color:#0b1220}.attendance-meta{margin:6px 0 0;display:inline-flex;gap:12px;font-size:13px;color:#53607a}.snapshot-chip{background:#e7f8f2;color:#0f6e32;border-radius:20px;padding:8px 16px;font-size:13px;font-weight:600;align-self:flex-start}.attendance-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.date-controls{margin-top:8px;display:inline-flex;gap:10px;flex-wrap:wrap;align-items:center;padding:6px 10px;border-radius:999px}.snapshot-value{display:inline-block}.mobile-date-snapshot-row,.mobile-snapshot-under-meta{display:none}.date-controls button{border-radius:999px;border:1px solid rgba(15,23,42,.1);background:#fff;padding:8px 16px;font-size:12px;font-weight:600;cursor:pointer;color:#0b1220;box-shadow:0 4px 12px -8px #0f172acc;transition:transform .15s ease,box-shadow .15s ease}.date-controls button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 18px -10px #0f172acc}.date-controls button:disabled{opacity:.5;cursor:not-allowed}.today-btn{background:linear-gradient(120deg,#2563eb,#3b82f6);color:#fff;border:none;box-shadow:0 6px 16px -10px #2563ebcc}.date-picker-inline{display:inline-flex;flex-direction:column;gap:10px;font-size:28px}.date-picker-label{font-size:16px;color:#64748b}.date-picker-inline input[type=date]{border-radius:12px;border:1px solid rgba(15,23,42,.2);padding:4px 8px;font-size:16px;background:#fff;outline:none;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;box-shadow:0 4px 12px -8px #0f172acc}.date-picker-inline input[type=date]:hover{transform:translateY(-1px);box-shadow:0 8px 16px -10px #0f172acc;border-color:#2563eb80}.date-picker-inline input[type=date]:focus{border-color:#2563eb;box-shadow:0 10px 20px -12px #2563ebcc}.summary-card{background:#fff;border-radius:18px;border:1px solid rgba(15,23,42,.08);padding:18px 20px;display:flex;flex-direction:column;gap:4px;box-shadow:0 12px 40px #0f172a14}.mobile-only-card{display:none}.summary-label{margin:0;font-size:13px;color:#6b7280}.summary-label-mobile{display:none;margin:0;font-size:10px;color:#6b7280}.summary-value{margin:0;font-size:28px;font-weight:700;color:#0b1220}.attendance-detail-grid{display:grid;grid-template-columns:minmax(320px,1fr) 1.4fr;gap:24px}.card{background:#fff;padding:20px;border-radius:24px;border:1px solid rgba(15,23,42,.08);box-shadow:0 18px 40px #0f172a14}.section-heading h2{margin:0;font-size:20px;font-weight:600;color:#0b1220}.section-description{margin:4px 0 0;font-size:12px;color:#64748b}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.tab-row{margin:22px 0 12px;display:flex;gap:10px}.people-search-row{margin-top:18px;display:flex;align-items:center;gap:10px}.people-search-field{flex:1}.people-search-field input{width:100%;border-radius:14px;border:1px solid rgba(15,23,42,.12);background:#fff;padding:11px 14px;font-size:14px;color:#0b1220}.people-search-field input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.people-search-clear{border-radius:12px;border:1px solid rgba(15,23,42,.1);padding:10px 14px;background:#fff;color:#0b1220;font-weight:600;cursor:pointer}.people-search-summary{margin:10px 0 0;font-size:12px;color:#64748b}.tab-pill{border-radius:999px;border:1px solid rgba(15,23,42,.1);padding:6px 16px;background:#f3f5fb;font-size:13px;color:#0b1220;cursor:pointer}.tab-pill.active{background:linear-gradient(120deg,#2563eb,#3b82f6);color:#fff;border-color:transparent}.people-list{display:flex;flex-direction:column;gap:14px}.people-pagination{margin-top:12px;display:flex;align-items:center;justify-content:flex-end;gap:10px;font-size:13px;color:#4b5563}.people-pagination button{border-radius:10px;border:1px solid rgba(15,23,42,.1);padding:6px 14px;background:#fff;color:#0b1220;font-weight:600;cursor:pointer;transition:background .15s ease}.people-pagination button:disabled{opacity:.5;cursor:not-allowed}.person-card{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;border-radius:18px;border:1px solid rgba(15,23,42,.05);padding:14px 16px;background:#fefefe;cursor:pointer}.person-card.focused{border-color:#2563eb;box-shadow:0 15px 30px #2563eb2e}.presence-section{margin-top:20px;padding-top:16px;border-top:1px solid rgba(15,23,42,.08)}.presence-section__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.presence-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.presence-record{display:flex;justify-content:space-between;font-size:13px;color:#0b1220}.presence-badge{border-radius:999px;padding:4px 10px;font-size:12px;background:#dbeafe;color:#1d4ed8;font-weight:600}.presence-badge.error{background:#fee2e2;color:#b91c1c}.presence-placeholder{margin:0;font-size:13px;color:#64748b}.person-avatar,.selected-avatar{width:48px;height:48px;border-radius:50%;background:#e8eefc;color:#1e1f2a;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:16px;overflow:hidden}.person-avatar img,.selected-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.person-content{display:flex;flex-direction:column;gap:2px}.person-header{display:flex;align-items:center;gap:8px}.person-name{font-weight:600;color:#0b1220}.person-status{font-size:11px;padding:4px 10px;border-radius:999px;background:#d1fae5;color:#047857;font-weight:600}.person-sub,.person-meta{margin:0;font-size:12px;color:#94a3b8}.person-metrics{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#475569;text-align:right}.metric-label{color:#94a3b8;margin-right:4px}.details-section{display:flex;flex-direction:column;gap:18px}.selected-person{display:flex;align-items:flex-start;gap:16px}.selected-person-copy{flex:1;min-width:0}.selected-name-row{display:flex;align-items:center;gap:12px}.selected-name{margin:0;font-size:22px;font-weight:700}.selected-inline-captures{display:flex;align-items:center;gap:10px;flex-shrink:0}.selected-inline-capture{margin:0;display:flex;flex-direction:column;align-items:center;gap:4px}.selected-inline-capture img{width:54px;height:54px;object-fit:cover;border-radius:12px;display:block;background:#e5e7eb;border:1px solid rgba(15,23,42,.08)}.selected-inline-capture figcaption{font-size:10px;font-weight:600;color:#64748b}.selected-subtext{margin:4px 0 0;font-size:13px;color:#64748b}.selected-status.inside{color:#047857}.selected-status.exited{color:#b91c1c}.selected-status.neutral{color:#475569}.selected-meta{margin:4px 0 0;font-size:12px;color:#94a3b8}.selected-time-capture-list{margin-top:8px;display:flex;flex-direction:column;gap:8px}.selected-time-capture-row{display:flex;align-items:center;gap:10px;min-height:42px;width:100%}.selected-time-label{min-width:76px;font-size:11px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.selected-time-value{font-size:13px;font-weight:600;color:#0b1220;min-width:52px;white-space:nowrap}.selected-time-capture-img{width:42px;height:42px;object-fit:cover;border-radius:10px;background:#e5e7eb;border:1px solid rgba(15,23,42,.08);flex-shrink:0;margin-left:auto}.selected-time-image-missing{font-size:11px;color:#94a3b8}.selected-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.info-chip{background:#f3f4f6;padding:10px 14px;border-radius:16px;border:1px solid rgba(15,23,42,.08)}.info-chip span{display:block;font-size:11px;color:#94a3b8}.info-chip strong{display:block;font-size:16px;font-weight:600;color:#0b1220}.selected-capture-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.selected-capture-card{display:flex;flex-direction:column;gap:10px;padding:14px;background:#f8fafc;border:1px solid rgba(15,23,42,.08);border-radius:18px}.selected-capture-label{font-size:12px;font-weight:600;color:#475569}.selected-capture-card img{width:100%;max-height:220px;object-fit:cover;border-radius:12px;display:block;background:#e5e7eb}.records-wrapper{display:flex;flex-direction:column;gap:14px}.records-header h3{margin:0;font-size:18px}.records-header p{margin:4px 0 0;font-size:12px;color:#94a3b8}.records-table{display:flex;flex-direction:column;gap:8px}.table-row{display:grid;grid-template-columns:minmax(88px,.9fr) minmax(128px,1fr) minmax(128px,1fr) minmax(88px,.8fr) minmax(132px,1.1fr) minmax(132px,1.1fr) minmax(56px,.5fr);align-items:center;gap:8px;padding:10px 12px;border-radius:14px;background:#f9fafc;border:1px solid rgba(15,23,42,.04);font-size:13px;color:#0b1220}.table-row.header{background:#fff;font-weight:700;border-color:#0f172a1a}.table-row.clickable{cursor:default;transition:background .2s ease}.table-row.clickable:hover{background:#2563eb0f}.table-row.focused{border-color:#2563eb;background:#2563eb0a}.table-row.placeholder span{grid-column:span 7;text-align:center;color:#64748b}.record-row{display:flex;flex-direction:column;gap:4px}.status-pill{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}.status-pill.inside{background:#d1fae5;color:#047857}.status-pill.exited{background:#fee2e2;color:#b91c1c}.camera-cell{display:flex;align-items:center;min-height:28px}.camera-label{font-weight:500;font-size:11px;color:#0b1220;text-align:left;word-break:break-word}.record-capture-inline{border:0px solid rgba(99,102,241,.2);border-radius:10px;background:#f8fafc;padding:4px;display:flex;flex-direction:column;align-items:center;width:74px;margin:0}.record-capture-inline img{width:58px;height:72px;object-fit:cover;border-radius:6px;display:block}.record-capture-inline figcaption{padding:0;margin:0;font-size:9px;color:#475569}.camera-placeholder{font-size:9px;color:#475569;background:#f3f4f6;padding:4px 8px;border-radius:8px;border:1px dashed rgba(99,102,241,.4);width:74px}.record-time-value{font-variant-numeric:tabular-nums;font-weight:600;min-width:42px;white-space:nowrap}.record-time-cell{display:flex;align-items:center;gap:8px;min-height:36px;white-space:nowrap}.record-status-cell{display:inline-flex;align-items:center;min-height:28px}.mobile-camera-label{display:none}.record-time-avatar{display:block;width:42px;height:42px;border-radius:10px;object-fit:cover;flex-shrink:0;margin-left:0;border:1px solid rgba(15,23,42,.1);background:#e5e7eb}.interaction-flow{background:#eef2ff;padding:12px 16px;border-radius:16px;border:1px solid rgba(59,130,246,.2)}.interaction-flow p{margin:0 0 4px;font-size:13px;font-weight:600;color:#1d4ed8}.interaction-flow ol{margin:0;padding-left:18px;font-size:13px;color:#475569}@media(max-width:1024px){.attendance-detail-grid{grid-template-columns:1fr}.attendance-summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media(max-width:640px){.attendance-header{flex-direction:column;gap:10px}.attendance-title{font-size:24px}.attendance-meta{margin-top:4px;gap:8px;font-size:11px}.mobile-hide{display:none!important}.desktop-snapshot-chip{display:none}.mobile-date-snapshot-row{margin-top:8px;display:flex;align-items:center;gap:8px;min-width:0}.mobile-snapshot-under-meta{margin-top:6px;display:inline-flex;max-width:fit-content}.mobile-date-controls{display:inline-flex;align-items:center;gap:0;min-width:0;flex:1;border:1px solid rgba(15,23,42,.2);border-radius:10px;background:#fff;overflow:hidden}.mobile-date-controls button{border:none;border-right:1px solid rgba(15,23,42,.14);background:transparent;width:22px;height:14px;padding:0;font-size:11px;font-weight:600;line-height:1;color:#0b1220;cursor:pointer;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.mobile-date-controls button:last-of-type{border-right:none;border-left:1px solid rgba(15,23,42,.14)}.mobile-date-controls button:disabled{opacity:.5;cursor:not-allowed}.mobile-date-controls input[type=date]{min-width:0;width:100%;border:none;padding:1px 4px;font-size:10px;line-height:1;background:transparent;text-align:center}.mobile-date-controls input[type=date]:focus{outline:none}.mobile-date-controls:focus-within{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb24}.mobile-snapshot-chip{margin:0;padding:0 8px;border-radius:10px;font-size:10px;line-height:1;white-space:nowrap;flex-shrink:0;max-width:46%;overflow:hidden;text-overflow:ellipsis;height:16px;display:inline-flex;align-items:center}.mobile-snapshot-chip strong{display:inline;font-size:10px;line-height:1}.attendance-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.mobile-only-card{display:flex}.mobile-hide-card{display:none}.summary-card{border-radius:12px;padding:8px 6px;gap:2px;min-width:0;box-shadow:0 8px 18px #0f172a0f}.summary-label{display:none}.summary-label-mobile{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.summary-value{font-size:22px;line-height:1.05}.tab-row{flex-wrap:wrap}.people-search-row{flex-direction:column;align-items:stretch}.person-card{grid-template-columns:auto 1fr}.person-metrics{display:none}.selected-capture-grid{grid-template-columns:1fr}.selected-name-row{align-items:flex-start;flex-direction:column}.selected-inline-captures{flex-wrap:wrap}.record-time-cell{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:36px;white-space:nowrap}.record-time-avatar{display:block;width:64px;height:64px;border-radius:20%;object-fit:cover;flex-shrink:0;margin-left:auto;border:1px solid rgba(15,23,42,.1);background:#e5e7eb}}.dark .attendance-page{background:radial-gradient(circle at top left,rgba(96,165,250,.12),transparent 28%),radial-gradient(circle at bottom right,rgba(59,130,246,.12),transparent 26%),var(--page-bg)}.dark .attendance-title,.dark .summary-value,.dark .section-heading h2,.dark .presence-record,.dark .person-name,.dark .selected-name,.dark .info-chip strong,.dark .table-row,.dark .camera-label{color:var(--text-primary)}.dark .attendance-meta,.dark .date-picker-label,.dark .summary-label,.dark .section-description,.dark .presence-placeholder,.dark .person-sub,.dark .person-meta,.dark .person-metrics,.dark .metric-label,.dark .selected-subtext,.dark .selected-meta,.dark .selected-inline-capture figcaption,.dark .info-chip span,.dark .records-header p,.dark .record-capture-inline figcaption,.dark .camera-placeholder,.dark .interaction-flow ol{color:var(--text-secondary)}.dark .selected-time-label,.dark .selected-time-value{color:var(--text-primary)}.dark .selected-time-image-missing{color:var(--text-secondary)}.dark .selected-time-capture-img{background:color-mix(in srgb,var(--card, var(--bg-elevated)) 82%,var(--page-bg) 18%);border-color:var(--border-color)}.dark .snapshot-chip{background:#10b98129;color:#86efac;border:1px solid rgba(16,185,129,.28)}.dark .mobile-date-controls{background:var(--card, var(--bg-elevated));border-color:var(--border-color)}.dark .mobile-date-controls button,.dark .mobile-date-controls input[type=date]{color:var(--text-primary)}.dark .date-controls button,.dark .date-picker-inline input[type=date],.dark .summary-card,.dark .card,.dark .people-pagination button,.dark .person-card,.dark .info-chip,.dark .table-row.header,.dark .record-capture-inline,.dark .camera-placeholder,.dark .interaction-flow{background:var(--card, var(--bg-elevated));border-color:var(--border-color);color:var(--text-primary);box-shadow:var(--shadow)}.dark .date-controls button:hover:not(:disabled),.dark .date-picker-inline input[type=date]:hover,.dark .people-pagination button:hover:not(:disabled){background:var(--button-hover)}.dark .date-picker-inline input[type=date]:focus{border-color:var(--accent);box-shadow:0 0 0 3px #60a5fa29}.dark .tab-pill{background:#1e293be6;border-color:var(--border-color);color:var(--text-primary)}.dark .tab-pill.active,.dark .today-btn{background:linear-gradient(120deg,#2563eb,#3b82f6);color:#fff;border-color:transparent}.dark .person-card{background:color-mix(in srgb,var(--card, var(--bg-elevated)) 86%,var(--page-bg) 14%)}.dark .person-card.focused,.dark .table-row.focused{border-color:var(--accent);background:#3b82f61f;box-shadow:0 16px 32px #02061766}.dark .presence-section{border-top-color:var(--border-color)}.dark .presence-badge{background:#3b82f62e;color:#93c5fd}.dark .presence-badge.error{background:#ef444429;color:#fca5a5}.dark .person-avatar,.dark .selected-avatar{background:#3b82f624;color:#dbeafe}.dark .person-status,.dark .status-pill.inside{background:#10b9812e;color:#86efac}.dark .status-pill.exited{background:#ef44442e;color:#fca5a5}.dark .table-row{background:color-mix(in srgb,var(--card, var(--bg-elevated)) 90%,var(--page-bg) 10%);border-color:var(--border-color)}.dark .table-row.clickable:hover{background:#3b82f61a}.dark .table-row.placeholder span{color:var(--text-secondary)}.dark .record-capture-inline{background:#0f172ae0}.dark .camera-placeholder{background:#1e293beb;border-color:#60a5fa66}.dark .record-time-avatar{background:color-mix(in srgb,var(--card, var(--bg-elevated)) 82%,var(--page-bg) 18%);border-color:var(--border-color)}.dark .interaction-flow{background:#1e293bb8;border-color:#60a5fa38}.dark .interaction-flow p{color:#93c5fd}.breadcrumb{font-size:12px;color:#6b7280;margin-bottom:8px}.breadcrumb-item{font-weight:500}.breadcrumb-item.active{color:#111827;font-weight:600}.breadcrumb-link{text-decoration:none;color:#6b7280}.breadcrumb-link:hover{color:#2563eb}.breadcrumb-separator{margin:0 6px}.table-wrapper{border:1px solid var(--border-color);border-radius:var(--card-radius);background:color-mix(in srgb,var(--card, var(--bg-card)) 88%,var(--bg-primary) 12%);overflow:hidden;transform:none}.table-search-container{width:100%;position:static;transform:none;display:flex;justify-content:flex-end;align-items:center;margin-bottom:12px}.table-search-inline{width:auto;margin-bottom:0}.data-table{width:100%;border-collapse:collapse;background:var(--card, var(--bg-card));border-radius:var(--card-radius);color:var(--text-primary)}.data-table thead{background:color-mix(in srgb,var(--accent) 10%,var(--card, var(--bg-card)) 90%);border-radius:var(--card-radius)}.data-table th{padding:12px 16px;font-weight:600;text-align:left;border-bottom:1px solid var(--border-color);color:var(--text-secondary);font-size:12px}.data-table th:last-child,.data-table td:last-child{text-align:right}.data-table td{padding:12px 16px;border-top:1px solid var(--border-color);position:relative;overflow:visible!important;color:var(--text-primary)}.data-table tbody tr:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);cursor:pointer}.status-online{color:#3bd16f;font-weight:600}.status-offline{color:#ff4d4d;font-weight:600}.action-menu-container{position:relative;display:inline-block}.action-btn{background:none;border:none;cursor:pointer;padding:8px;border-radius:var(--radius)}.dropdown-menu{position:absolute;right:0;top:32px;background:var(--card, var(--bg-card));border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius);box-shadow:0 2px 8px #00000026;z-index:999999;padding:6px 0}.data-table td{position:relative;overflow:visible!important}.action-menu-container{position:relative;display:inline-block;overflow:visible;z-index:10}.dropdown-menu{position:absolute;right:0;top:32px;background:var(--card, var(--bg-card));border-radius:var(--radius);border:1px solid var(--border-color);color:var(--text-primary);box-shadow:0 2px 12px #00000026;z-index:999999}.dropdown-item{padding:10px 12px;width:100%;text-align:left;border:none;background:transparent;cursor:pointer}.dropdown-menu-portal{width:140px;background:var(--card, var(--bg-card));color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:0 4px 15px #0003;padding:6px 0}.dropdown-item{padding:10px 14px;background:transparent;border:none;width:100%;text-align:left;cursor:pointer}.dropdown-item:hover{background:color-mix(in srgb,var(--accent) 10%,transparent)}.dropdown-item.delete{color:#d9534f}.vx-pulse-loader{display:flex;gap:8px;justify-content:center;padding:20px 0}.panel-overlay{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:999}.panel-overlay.open{opacity:1;pointer-events:auto}.panel{position:fixed;top:0;right:0;width:500px;max-width:100%;height:100%;background:var(--card, var(--bg-card));color:var(--text-primary);border-left:1px solid var(--border-color);box-shadow:-10px 0 32px #00000029;transform:translate(100%);transition:transform .3s ease;padding:var(--content-gap);z-index:1000;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}.panel::-webkit-scrollbar{width:0;height:0;display:none}.panel-wrapper.right{right:0;transform:translate(100%)}.panel-wrapper.right.open{transform:translate(0)}.panel.open.right.rule{width:750px}.panel-wrapper.left{right:420px;transform:translate(100%);z-index:1001}.panel-wrapper.left.open,.panel.open{transform:translate(0)}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.panel-header h2{margin:0;font-size:22px;font-weight:700;color:var(--text-primary)}.panel-close{background:none;border:none;font-size:26px;cursor:pointer;color:var(--text-secondary)}.panel div{position:relative;width:100%;margin-top:20px}.panel div>input{appearance:none;-webkit-appearance:none;width:98%;padding:10px 6px 6px;border:none;border-bottom:1px solid var(--border-color);background:transparent;font-size:14px;color:var(--text-primary);outline:none;margin-top:0;margin-bottom:20px;transform:translateY(0)}.panel div>input{background-image:linear-gradient(var(--accent),var(--accent));background-repeat:no-repeat;background-size:0% 2px;background-position:left bottom;transition:background-size .2s ease,transform .3s ease,margin-top .3s ease,margin-bottom .3s ease}.panel div>input:focus,.panel div>input:not(:placeholder-shown){background-size:100% 2px;transform:translateY(70%);margin-bottom:30px;margin-top:10px}.panel div>label{position:absolute;left:2px;top:30%;transform:translateY(-50%);transform-origin:right center;pointer-events:none;white-space:nowrap;font-size:14px;color:var(--text-secondary);transition:transform .2s ease,font-size .4s ease,color .4s ease,margin-bottom .3s ease;margin-bottom:10px}.panel div>input:focus+label,.panel div>input:not(:placeholder-shown)+label{transform:translateY(-100%);font-size:15px;color:var(--accent);margin-bottom:20px}.panel button.submit-btn{width:100%;padding:11px;border:none;border-radius:var(--radius);background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:16px;cursor:pointer;margin-top:20px}.panel button.submit-btn:hover{filter:brightness(1.05)}.camera-table{width:100%;border-collapse:collapse;background:var(--card, var(--bg-card));border-radius:var(--card-radius);overflow:hidden;box-shadow:0 4px 14px #0000000f}.camera-table th{background:#f5f5f7;padding:14px;text-align:left;font-weight:600;font-size:15px;color:#555}.camera-table td{padding:14px;border-top:1px solid #e6e6e6;font-size:15px}.menu-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:4px 8px;color:#666}.menu-btn:hover{color:#000}.row-menu{position:absolute;right:0;background:var(--card, var(--bg-card));border:1px solid #ddd;border-radius:var(--radius);width:120px;padding:6px 0;box-shadow:0 4px 12px #0000001f;z-index:50}.row-menu button{width:100%;padding:10px 14px;background:none;border:none;text-align:left;font-size:14px;cursor:pointer;color:#333}.row-menu button:hover{background:#f3f3f3}.cameras-wrapper{width:100%;height:100%;box-sizing:border-box;flex:1;min-width:0;overflow-x:hidden}.custom-select{position:relative;font-size:16px;margin-bottom:50px;outline:none}.select-trigger{width:98%;padding:10px 6px 6px;background-size:0;background:transparent;border:none;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-size .2s ease;border-bottom:1px solid var(--border-color);outline:none}.custom-select[data-open=true] .select-trigger,.custom-select[data-has-value=true] .select-trigger,.custom-select[data-has-value=false] .select-trigger{border-bottom:2px solid var(--accent);background-size:100% 2px;margin-top:30px;outline:none}.custom-select label{position:absolute;left:6px;top:50%;transform:translateY(-500%);pointer-events:none;color:var(--text-secondary);transition:transform .3s ease,color .3s ease;font-size:16px;outline:none}.custom-select span{font-size:16px;outline:none}.custom-select[data-open=true] label,.custom-select[data-has-value=true] label,.custom-select[data-has-value=false] label{transform:translateY(-140%);color:var(--accent);outline:none}.select-menu{position:absolute;top:100%;left:0;right:0;background:var(--card, var(--bg-card));border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius);margin-top:6px;padding:6px 0;box-shadow:0 8px 24px #0000001f;list-style:none;display:none;z-index:2000;outline:none}.custom-select[data-open=true] .select-menu{display:block;outline:none}.select-menu li{padding:10px 14px;cursor:pointer}.select-menu li:hover{background:color-mix(in srgb,var(--accent) 10%,transparent)}.custom-select[data-disabled=true] .select-trigger{border-bottom:1px solid var(--border-color)!important;background:color-mix(in srgb,var(--card, var(--bg-card)) 92%,var(--bg-primary) 8%);color:var(--muted-2, var(--text-secondary));cursor:not-allowed;pointer-events:none}.custom-select[data-disabled=true] label,.custom-select[data-disabled=true] .select-value,.custom-select[data-disabled=true] .chevron{color:var(--muted-2, var(--text-secondary))!important}.camera-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:nowrap;margin-bottom:18px}.add-camera-btn{background:linear-gradient(135deg,#007bff,#0062d6);color:#fff;padding:10px 18px;border:none;border-radius:8px;font-size:15px;cursor:pointer;transition:.2s ease;box-shadow:0 3px 10px #0000001f}.bulk-upload-btn{background:linear-gradient(135deg,#b5b5b5,#b5b5b5);color:#3e3e3e;padding:10px 18px;border:none;border-radius:8px;font-size:15px;cursor:pointer;transition:.2s ease;box-shadow:0 3px 10px #0000001f;margin-left:20px}.bulk-upload-btn:hover{background:linear-gradient(135deg,#aaa9a9,#a6a6a6);transform:translateY(-2px)}.add-camera-btn:hover{background:linear-gradient(135deg,#0066d6,#004cb5);transform:translateY(-2px)}.empty-state{text-align:center;padding:60px 20px;color:#555}.empty-state h3{font-size:20px;margin-top:16px;font-weight:600}.empty-state p{color:#777;margin-top:6px;font-size:14px}.empty-icon{display:block;margin:0 auto;width:120px;opacity:.8}.persons-breadcrumb-pagination{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.persons-pagination{display:inline-flex;align-items:center;gap:8px;padding:4px 8px;border:1px solid #d5dde8;border-radius:999px;background:#f8fbff}.persons-pagination-row{margin-top:10px;display:flex;justify-content:center}.persons-pagination-arrow{width:28px;height:28px;border:1px solid #c8d5e8;border-radius:50%;background:#fff;color:#2e4f78;font-size:18px;line-height:1;cursor:pointer;transition:.2s ease}.persons-pagination-arrow:hover:not(:disabled){border-color:#88a8ce;background:#eef5ff}.persons-pagination-arrow:disabled{opacity:.45;cursor:not-allowed}.persons-pagination-indicator{display:inline-flex;align-items:center;gap:8px;min-width:92px;justify-content:center}.persons-pagination-number{min-width:22px;text-align:center;font-size:13px;font-weight:600;color:#5f7290}.persons-pagination-number.is-faded{opacity:.35}.persons-pagination-number.is-active{padding:2px 8px;border-radius:999px;color:#fff;background:linear-gradient(135deg,#1f78ff,#1257c4);box-shadow:0 4px 10px #1459c440}.persons-page-size-control{display:inline-flex;align-items:center;gap:6px;margin-left:4px;height:34px;padding:0 10px;border:1px solid #c8d5e8;border-radius:999px;background:#fff;align-self:center}.persons-page-size-label{display:inline-flex;align-items:center;font-size:12px;color:#60748f;font-weight:600;line-height:1}.persons-page-size-input{width:68px;min-width:68px;height:28px;padding:4px 10px;border:1px solid #c8d5e8;border-radius:999px;font-size:13px;background:#fff;color:#2d4e75;margin:0;align-self:center}.persons-page-size-input:focus{outline:none;border-color:#4d91ef;box-shadow:0 0 0 2px #4d91ef33}.persons-thumb-cell{width:44px;height:44px;border-radius:10px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;border:1px solid #d7e1ef;background:linear-gradient(145deg,#f3f8ff,#eaf2ff);position:relative}.persons-thumb-image{width:100%;height:100%;object-fit:cover;display:block}.persons-thumb-fallback{width:100%;height:100%;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#356193;text-transform:uppercase}.persons-thumb-fallback.is-hidden{display:none}@media(max-width:960px){.persons-breadcrumb-pagination{width:100%}.persons-pagination-row{justify-content:center}.persons-pagination{width:100%;justify-content:flex-start;border-radius:14px;padding:8px 10px;flex-wrap:wrap;row-gap:10px}}.camera-panel-header-actions{display:flex;align-items:center;gap:10px}.camera-advance-toggle{display:inline-flex;align-items:center;gap:8px;height:34px;padding:0 12px;border:1px solid #9dc0f2;border-radius:999px;background:#eef5ff;color:#1d57a5;cursor:pointer;font-size:13px;font-weight:600}.camera-advance-toggle svg{width:14px;height:14px}.camera-advance-toggle.active{background:#1d57a5;border-color:#1d57a5;color:#fff}.camera-advance-form{margin-top:18px;padding:14px;border:1px solid var(--border-color);border-radius:12px;background:color-mix(in srgb,var(--card, var(--bg-card)) 90%,#edf4ff 10%)}.camera-advance-heading h3{margin:0;font-size:16px}.camera-advance-heading p{margin:6px 0 0;font-size:12px;color:var(--text-secondary)}.camera-advance-grid{margin-top:12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.camera-advance-grid label{display:block;margin-bottom:6px;font-size:12px;color:var(--text-secondary)}.camera-advance-grid input{width:100%;margin:0;padding:8px 10px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-card);color:var(--text-primary)}.panel .camera-advance-grid>div>label,.panel .camera-advance-grid>div>input:focus+label,.panel .camera-advance-grid>div>input:not(:placeholder-shown)+label{position:static;left:auto;top:auto;transform:none;transform-origin:initial;pointer-events:auto;white-space:normal;margin:0 0 6px;transition:none;font-size:12px}.panel .camera-advance-grid>div>input,.panel .camera-advance-grid>div>input:focus,.panel .camera-advance-grid>div>input:not(:placeholder-shown){background-image:none;background-size:0 0;transform:none;margin-top:0;margin-bottom:0}.camera-advance-full-row{grid-column:1 / -1}.onvif-preview-block{border:1px solid var(--border-color);border-radius:10px;padding:10px;background:color-mix(in srgb,var(--bg-card) 92%,#f4f8ff 8%)}.onvif-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.onvif-preview-header h4{margin:0;font-size:13px}.onvif-ptz-icons{display:flex;gap:8px}.onvif-ptz-icons span{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-color);border-radius:50%;color:var(--text-secondary);background:var(--bg-card)}.onvif-preview-frame{width:100%;height:210px;position:relative;border-radius:10px;overflow:hidden;border:1px solid color-mix(in srgb,var(--border-color) 86%,#9ab9ee 14%);background:#000}.panel .onvif-preview-frame div{margin-top:0}.panel .onvif-stream-controls{position:absolute;inset:0;margin-top:0;width:auto}.panel .onvif-stream-slider-panel{position:absolute;margin-top:0;width:auto}.onvif-preview-empty{height:100%;display:flex;align-items:center;justify-content:center;color:#8da0bc;font-size:12px}.onvif-stream-controls{position:absolute;inset:0;pointer-events:none;z-index:10}.onvif-stream-controls .ptz-btn{--ptz-tx: 0;--ptz-ty: 0;pointer-events:auto;position:absolute;width:38px;height:38px;border:1px solid rgba(255,255,255,.72);border-radius:50%;background:#091428d1;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:transform .15s ease,background .15s ease;box-shadow:0 2px 10px #00000059;transform:translate(var(--ptz-tx),var(--ptz-ty))}.onvif-stream-controls .ptz-btn:hover{transform:translate(var(--ptz-tx),var(--ptz-ty)) scale(1.05);background:#142d56f2}.onvif-stream-controls .ptz-up{top:10px;left:50%;--ptz-tx: -50%;--ptz-ty: 0}.onvif-stream-controls .ptz-left{top:50%;left:10px;--ptz-tx: 0;--ptz-ty: -50%}.onvif-stream-controls .ptz-right{top:50%;right:10px;--ptz-tx: 0;--ptz-ty: -50%}.onvif-stream-controls .ptz-down{bottom:10px;left:50%;--ptz-tx: -50%;--ptz-ty: 0}.onvif-stream-controls .ptz-zoom-controls{pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;gap:8px;width:fit-content;margin:0}.onvif-stream-controls .ptz-zoom-controls .ptz-btn{position:static;transform:none}.panel .onvif-stream-controls .ptz-zoom-controls{position:absolute;width:fit-content;margin-top:0}.onvif-stream-controls .ptz-zoom-controls .ptz-btn:hover{transform:scale(1.05)}.onvif-stream-slider-panel{position:absolute;left:8px;right:8px;bottom:8px;z-index:9;pointer-events:auto;border:1px solid rgba(255,255,255,.28);border-radius:10px;background:#0812249e;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:6px;display:grid;gap:6px}.onvif-stream-slider-row label{display:flex;justify-content:space-between;align-items:center;color:#f0f5ff;font-size:11px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.03em}.onvif-stream-slider-control{display:grid;grid-template-columns:24px 1fr 24px;align-items:center;gap:6px}.ptz-slider-step{width:24px;height:24px;border:1px solid rgba(255,255,255,.72);border-radius:50%;background:#091428d9;color:#fff;font-size:15px;line-height:1;cursor:pointer}.onvif-stream-slider-control input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:16px;background:transparent;border:none;padding:0;margin:0}.onvif-stream-slider-control input[type=range]::-webkit-slider-runnable-track{height:4px;border-radius:999px;background:linear-gradient(90deg,#2a6fdb,#91b4ef)}.onvif-stream-slider-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;margin-top:-4px;border:2px solid #2a6fdb;background:#fff}.onvif-stream-slider-control input[type=range]::-moz-range-track{height:4px;border-radius:999px;background:linear-gradient(90deg,#2a6fdb,#91b4ef)}.onvif-stream-slider-control input[type=range]::-moz-range-thumb{width:12px;height:12px;border-radius:50%;border:2px solid #2a6fdb;background:#fff}.onvif-slider-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.onvif-slider-item{display:flex;flex-direction:column;justify-content:center;gap:5px;padding:7px 10px;border:1px solid var(--border-color);border-radius:10px;background:color-mix(in srgb,var(--bg-card) 92%,#f6f8fb 8%)}.onvif-slider-item .onvif-slider-label{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;column-gap:8px;position:static;left:auto;top:auto;transform:none;pointer-events:auto;margin:0;color:var(--text-secondary);font-size:12px;line-height:1.2;min-height:16px;transition:none}.onvif-slider-item .onvif-slider-label>span:first-child{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.onvif-slider-item .onvif-slider-value{justify-self:end;color:var(--text-primary);font-weight:700;font-variant-numeric:tabular-nums}.onvif-slider-item input[type=range]{-webkit-appearance:none;appearance:none;margin-top:0;width:100%;height:12px;padding:0;border:none;background:transparent;transform:none!important;cursor:pointer}.panel .camera-advance-grid .onvif-slider-item>input[type=range],.panel .camera-advance-grid .onvif-slider-item>input[type=range]:focus,.panel .camera-advance-grid .onvif-slider-item>input[type=range]:not(:placeholder-shown){background-image:none;background-size:0 0;transform:none;margin-top:0;margin-bottom:0}.panel .camera-advance-grid .onvif-slider-item input[type=range]::-webkit-slider-runnable-track{height:5px;border-radius:999px;background:linear-gradient(90deg,#2a6fdb,#91b4ef)}.panel .camera-advance-grid .onvif-slider-item input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;margin-top:-4px;border:2px solid #2a6fdb;background:#fff}.panel .camera-advance-grid .onvif-slider-item input[type=range]::-moz-range-track{height:5px;border-radius:999px;background:linear-gradient(90deg,#2a6fdb,#91b4ef)}.panel .camera-advance-grid .onvif-slider-item input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;border:2px solid #2a6fdb;background:#fff}@media(max-width:760px){.camera-advance-grid,.onvif-slider-row{grid-template-columns:1fr}.onvif-stream-controls .ptz-btn{width:32px;height:32px}.onvif-stream-controls .ptz-up{top:8px}.onvif-stream-controls .ptz-left{left:8px}.onvif-stream-controls .ptz-right{right:8px}.onvif-stream-controls .ptz-down{bottom:8px}.onvif-stream-controls .ptz-zoom-controls{gap:6px}.onvif-stream-slider-panel{left:6px;right:6px;bottom:6px;padding:5px}.onvif-stream-slider-row label{font-size:10px;margin-bottom:3px}.onvif-stream-slider-control{grid-template-columns:22px 1fr 22px;gap:5px}.ptz-slider-step{width:22px;height:22px;font-size:13px}}.zone-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:nowrap;gap:12px;margin-bottom:18px}.zone-header h1,.camera-header h1{margin:0;font-size:28px;font-weight:700}.zone-header .breadcrumb,.camera-header .breadcrumb{margin-bottom:0}.zone-header .table-search-container.table-search-inline,.camera-header .table-search-container.table-search-inline{width:auto;flex:0 0 auto;margin:0 0 0 auto;justify-content:flex-end}.filter-zone-btn{background:#f3f4f6;border:1px solid #ddd;padding:8px 14px;border-radius:6px;cursor:pointer;outline:none}.filter-zone-btn:hover{outline:none;background:#dcdcdc;transform:translateY(-1px)}.zone-search-input{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;width:320px;min-width:320px;max-width:320px;margin:0;background:var(--card, var(--bg-card));color:var(--text-primary);transition:.2s ease}.zone-search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 20%,transparent)}.filter-popover{position:absolute;top:115px;right:280px;width:300px;background:#fff;padding:18px;border-radius:10px;border:1px solid #e5e7eb;box-shadow:0 8px 25px #00000014;display:flex;flex-direction:column;gap:12px;z-index:999}.filter-popover h3{margin-bottom:8px;font-size:16px;font-weight:600}.filter-menu{background:#fff;padding:20px;border-radius:8px;margin-bottom:20px;border:1px solid #eee;display:flex;flex-direction:column;gap:10px;max-width:350px}.add-zone-btn{background:linear-gradient(135deg,#007bff,#0062d6);color:#fff;padding:10px 18px;border:none;border-radius:8px;font-size:15px;cursor:pointer;transition:.2s ease;box-shadow:0 3px 10px #0000001f}.add-zone-btn:hover{background:linear-gradient(135deg,#0066d6,#004cb5);transform:translateY(-2px)}@media(max-width:1200px){.zone-search-input{width:280px;min-width:280px;max-width:280px}}@media(max-width:768px){.zone-header,.camera-header{flex-wrap:wrap;align-items:flex-start}.zone-header .table-search-container.table-search-inline,.camera-header .table-search-container.table-search-inline{width:100%;justify-content:flex-end}.zone-search-input{width:100%;min-width:0;max-width:100%}}.delete-modal{position:fixed;top:50%;left:50%;width:380px;background:var(--card, var(--bg-card));color:var(--text-primary);transform:translate(-50%,-45%);border-radius:14px;opacity:0;pointer-events:none;transition:all .25s ease;border:1px solid var(--border-color);box-shadow:0 4px 22px #0000002e;z-index:99999}.delete-modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%)}.delete-modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px;border-bottom:1px solid var(--border-color)}.delete-modal-header h2{font-size:20px;font-weight:700;margin:0;color:var(--text-primary)}.delete-modal-content{padding:20px;text-align:center}.delete-warning-title{font-size:22px;font-weight:700;color:var(--danger)}.delete-warning-text{margin-top:10px;color:var(--text-secondary)}.delete-camera-name{margin-top:12px;font-size:20px;font-weight:600;color:var(--text-primary)}.delete-warning-sub{margin-top:6px;color:var(--text-secondary);font-size:14px}.delete-modal-actions{display:flex;justify-content:space-between;margin-top:25px}.btn-cancel{width:48%;padding:10px 0;background:color-mix(in srgb,var(--card, var(--bg-card)) 86%,var(--bg-primary) 14%);color:var(--text-primary);border-radius:8px;border:1px solid var(--border-color);font-weight:600;cursor:pointer;transition:background .2s}.btn-cancel:hover{background:color-mix(in srgb,var(--card, var(--bg-card)) 78%,var(--bg-primary) 22%)}.btn-delete{width:48%;padding:10px 0;background:var(--danger);color:#fff;border-radius:8px;border:none;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.btn-delete:hover{filter:brightness(.94)}.btn-delete:active{transform:scale(.97)}.edit-btn{height:40px;max-height:50px}.zone-camera-polygon-field{margin-top:20px}.zone-camera-polygon-field>label{display:block;margin-bottom:12px}.zone-camera-polygon-row{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;column-gap:16px}.zone-camera-polygon-input{flex:1 1 280px;width:auto!important;max-width:calc(100% - 120px);min-width:0;margin-bottom:-10!important;margin-right:4px}.zone-camera-polygon-edit-btn{flex:0 0 auto;min-width:104px;padding:0 16px;margin-top:18px;border:1px solid var(--primary);border-radius:var(--radius);background:color-mix(in srgb,var(--primary) 14%,transparent);color:var(--primary);font-weight:600;transition:background-color .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease,transform .2s ease}.zone-camera-polygon-edit-btn:hover:not(:disabled){background:var(--primary);color:#fff;box-shadow:0 8px 18px color-mix(in srgb,var(--primary) 28%,transparent);transform:translateY(-1px)}.zone-camera-polygon-edit-btn:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 22%,transparent)}.zone-camera-polygon-edit-btn:disabled{border-color:var(--border-color);background:color-mix(in srgb,var(--card, var(--bg-card)) 85%,transparent);color:var(--text-secondary);cursor:not-allowed;box-shadow:none}@media(max-width:767px){.zone-camera-polygon-field>label{margin-bottom:10px}.zone-camera-polygon-row{align-items:stretch;gap:10px;column-gap:10px}.zone-camera-polygon-input{flex:1 1 100%;width:100%!important;max-width:100%;margin-right:0}.zone-camera-polygon-edit-btn{width:100%;min-width:0;margin-top:0}}@media(max-width:420px){.zone-camera-polygon-row{gap:8px}.zone-camera-polygon-edit-btn{height:38px}}.image-scroll{display:flex;gap:calc(var(--content-gap) * .5);overflow-x:auto;padding:10px 0;height:13rem}.image-scroll img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius)}.add-image{width:130px;height:130px;border:2px dashed #ccc;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:32px}.slider-group{margin-top:12px}.slider-group label{font-size:13px;display:block;margin-bottom:4px;color:#555}.slider-group input[type=range]{width:100%}.flip-controls{display:flex;gap:calc(var(--content-gap) * .5);margin-top:12px}.flip-controls button{flex:1;padding:8px;border-radius:var(--radius);border:1px solid #ccc;background:#f9f9f9;cursor:pointer}.flip-controls button:hover{background:#eee}.image-thumb{position:relative;width:90px;height:90px;flex:0 0 auto;border-radius:var(--radius);overflow:hidden}.image-thumb img{width:100%;height:100%;object-fit:cover}.image-overlay{position:absolute;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;gap:calc(var(--content-gap) * .4);opacity:0;transition:opacity .2s ease}.image-overlay.compact{flex-direction:column;gap:6px;padding:8px}.image-thumb:hover .image-overlay{opacity:1}.image-overlay button{padding:6px 8px;font-size:12px;line-height:1.1;min-width:52px;border-radius:var(--radius);border:none;cursor:pointer}.image-overlay.compact button{width:100%;min-width:0}.image-overlay button.danger{background:#d32f2f;color:#fff}.image-overlay button:not(.danger){background:#1976d2;color:#fff}.camera-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px;border:1px solid var(--border-color);border-radius:var(--card-radius, 8px);background:var(--card, var(--bg-card));transition:all .2s ease;margin-bottom:12px}.camera-card:hover{background:color-mix(in srgb,var(--accent) 8%,var(--card, var(--bg-card)) 92%);border-color:color-mix(in srgb,var(--accent) 20%,var(--border-color) 80%)}.camera-card-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.camera-card-title{font-size:15px;font-weight:600;color:var(--text-primary);margin:0;word-break:break-word}.camera-card-meta{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:6px;flex-wrap:wrap;line-height:1.4}.camera-card-meta-label,.camera-card-meta-badge-label{font-weight:500;color:var(--text-secondary)}.camera-card-meta-item,.camera-card-meta-item-badge{display:inline-flex;align-items:center;gap:4px}.camera-card-meta-separator{color:var(--border-color);margin:0 2px}.camera-card-actions{flex-shrink:0;display:flex;align-items:center;justify-content:flex-end}.camera-card-list{display:flex;flex-direction:column;gap:0}.camera-status-badge{font-size:11px;font-weight:600;padding:4px 8px;border-radius:999px;white-space:nowrap}.camera-status-badge.online{background:color-mix(in srgb,#22c55e 15%,transparent);color:#16a34a;border:1px solid color-mix(in srgb,#22c55e 40%,transparent)}.camera-status-badge.offline{background:color-mix(in srgb,#ef4444 15%,transparent);color:#dc2626;border:1px solid color-mix(in srgb,#ef4444 40%,transparent)}.zone-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px;border:1px solid var(--border-color);border-radius:var(--card-radius, 8px);background:var(--card, var(--bg-card));transition:all .2s ease;margin-bottom:12px}.zone-card:hover{background:color-mix(in srgb,var(--accent) 8%,var(--card, var(--bg-card)) 92%);border-color:color-mix(in srgb,var(--accent) 20%,var(--border-color) 80%)}.zone-card-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.zone-card-title{font-size:15px;font-weight:600;color:var(--text-primary);margin:0;word-break:break-word}.zone-card-meta{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:6px;flex-wrap:wrap;line-height:1.4}.zone-card-meta-label{font-weight:500;color:var(--text-secondary)}.zone-card-meta-item{display:inline-flex;align-items:center;gap:4px}.zone-card-meta-separator{color:var(--border-color);margin:0 2px}.zone-card-actions{flex-shrink:0;display:flex;align-items:center;justify-content:flex-end}.zone-card-list{display:flex;flex-direction:column;gap:0}*{box-sizing:border-box;transition:background-color .25s ease,color .25s ease,border-color .25s ease}*:before,*:after{transition:background-color .25s ease,color .25s ease,border-color .25s ease}html,body,#root{width:100%;height:100%;margin:0;overflow:hidden;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial}html,body{background:linear-gradient(180deg,var(--page-bg),var(--page-bg-secondary))}.app-shell{display:flex;width:100vw;height:100vh}.sidebar{width:250px;min-width:250px;display:flex;flex-direction:column;padding:18px;gap:12px;border-right:1px solid var(--border);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));background:linear-gradient(180deg,#ffffff0f,#ffffff05)}.sidebar-nav{display:flex;flex-direction:column;gap:6px;overflow-y:auto}.nav-footer{margin-top:auto}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur))}.content-area{flex:1;padding:22px;overflow:auto}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.card{min-height:240px;padding:18px;border-radius:14px;background:var(--bg-card);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow);transition:transform .15s ease,box-shadow .15s ease}.card:hover{transform:translateY(-4px)}.primary-btn{width:100%;padding:10px 16px;border-radius:12px;border:none;background:linear-gradient(180deg,#3b82f6,#2563eb);color:#fff;font-weight:600;cursor:pointer}.primary-btn:hover{box-shadow:0 10px 22px #2563eb59}@media(max-width:768px){.sidebar{display:none}.content-area{padding:14px}}:root{--editor-overlay-bg: radial-gradient(circle at top left, color-mix(in srgb, var(--primary) 14%, transparent), transparent 26%), radial-gradient(circle at bottom right, color-mix(in srgb, var(--success) 14%, transparent), transparent 24%), linear-gradient(180deg, rgba(7, 14, 24, .72), rgba(8, 15, 28, .62));--editor-modal-bg: linear-gradient( 135deg, color-mix(in srgb, var(--card, var(--bg-card)) 96%, white 4%), color-mix(in srgb, var(--panel-subtle-bg, var(--bg-card)) 92%, white 8%) );--editor-modal-border: color-mix(in srgb, var(--border-color) 70%, white 30%);--editor-stage-bg: radial-gradient(circle at top left, color-mix(in srgb, var(--primary) 18%, transparent), transparent 30%), radial-gradient(circle at bottom left, color-mix(in srgb, var(--accent) 14%, transparent), transparent 28%), radial-gradient(circle at bottom right, color-mix(in srgb, var(--success) 16%, transparent), transparent 24%), linear-gradient( 180deg, color-mix(in srgb, var(--vx-bg-main, var(--bg-primary)) 86%, black 14%), color-mix(in srgb, var(--vx-bg-main, var(--bg-primary)) 94%, black 6%) );--editor-frame-bg: linear-gradient( 180deg, color-mix(in srgb, var(--vx-bg-panel, var(--card)) 76%, black 24%), color-mix(in srgb, var(--vx-bg-main, var(--bg-primary)) 82%, black 18%) );--editor-video-shell-bg: #000000;--editor-sidebar-bg: linear-gradient( 180deg, color-mix(in srgb, var(--card, var(--bg-card)) 98%, white 2%), color-mix(in srgb, var(--panel-subtle-bg, var(--bg-card)) 94%, white 6%) );--editor-header-bg: radial-gradient(circle at top right, color-mix(in srgb, var(--primary) 10%, transparent), transparent 35%);--editor-card-bg: linear-gradient( 180deg, color-mix(in srgb, var(--card, var(--bg-card)) 98%, white 2%), color-mix(in srgb, var(--panel-subtle-bg, var(--bg-card)) 95%, white 5%) );--editor-card-soft-bg: linear-gradient( 180deg, color-mix(in srgb, var(--panel-subtle-bg, var(--bg-card)) 98%, white 2%), color-mix(in srgb, var(--panel-hover, var(--bg-card)) 94%, white 6%) );--editor-card-border: color-mix(in srgb, var(--border-color) 75%, white 25%);--editor-title: var(--text-primary);--editor-text: var(--text-secondary);--editor-muted: var(--muted-2, var(--text-secondary));--editor-accent: var(--primary);--editor-success: var(--success);--editor-json-bg: linear-gradient( 180deg, color-mix(in srgb, var(--vx-bg-main, var(--bg-primary)) 88%, black 12%), color-mix(in srgb, var(--vx-bg-main, var(--bg-primary)) 96%, black 4%) );--editor-json-text: color-mix(in srgb, var(--text-primary) 92%, white 8%);--editor-btn-text: #ffffff;--editor-btn-shadow: 0 10px 18px rgba(15, 23, 42, .12);--editor-polygon-fill: color-mix(in srgb, var(--primary) 24%, transparent);--editor-polygon-stroke: var(--primary);--editor-polygon-preview: rgba(255, 255, 255, .92);--editor-polygon-handle: var(--danger);--editor-polygon-handle-selected: var(--warning);--editor-polygon-handle-stroke: #ffffff;--editor-polygon-label: #ffffff}.dark{--editor-overlay-bg: radial-gradient(circle at top left, color-mix(in srgb, var(--primary) 16%, transparent), transparent 26%), radial-gradient(circle at bottom right, color-mix(in srgb, var(--success) 16%, transparent), transparent 24%), linear-gradient(180deg, rgba(2, 6, 23, .82), rgba(2, 6, 23, .72));--editor-modal-border: color-mix(in srgb, var(--border-color) 88%, black 12%);--editor-btn-shadow: 0 10px 18px rgba(2, 6, 23, .28);--editor-polygon-preview: rgba(226, 232, 240, .92);--editor-polygon-label: rgba(248, 250, 252, .96)}.editor-overlay{position:fixed;inset:0;z-index:2147483646;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--editor-overlay-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.editor-modal{width:min(96vw,1480px);height:min(88vh,900px);display:grid;grid-template-columns:minmax(0,1.6fr) minmax(320px,360px);background:var(--editor-modal-bg);border:1px solid var(--editor-modal-border);border-radius:28px;overflow:hidden;box-shadow:0 30px 80px color-mix(in srgb,var(--vx-bg-main, #0f172a) 24%,transparent),inset 0 1px color-mix(in srgb,var(--panel-hover, #ffffff) 48%,transparent);opacity:0;transform:translateY(16px) scale(.98);transition:transform .28s ease,opacity .28s ease}.editor-modal.open{opacity:1;transform:translateY(0) scale(1)}.editor-stage{min-width:0;display:flex;align-items:center;justify-content:center;padding:22px;background:var(--editor-stage-bg)}.editor-stage__frame{width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:24px;background:var(--editor-frame-bg);border:1px solid color-mix(in srgb,var(--border-color) 70%,transparent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--panel-hover, #ffffff) 18%,transparent),0 24px 44px color-mix(in srgb,var(--vx-bg-main, #0f172a) 28%,transparent);overflow:hidden}.editor-stage__video-shell{position:relative;display:inline-flex;align-items:center;justify-content:center;max-width:100%;max-height:100%;background:var(--editor-video-shell-bg);border-radius:22px;box-shadow:0 18px 30px color-mix(in srgb,var(--vx-bg-main, #0f172a) 34%,transparent),0 0 0 1px color-mix(in srgb,var(--panel-hover, #ffffff) 14%,transparent);overflow:hidden}.editor-stage__video-shell>div{width:100%;height:100%}.editor-stage__canvas{position:absolute;left:0;top:0;width:100%;height:100%;z-index:3;cursor:crosshair;touch-action:none}.editor-sidebar{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--editor-sidebar-bg);border-left:1px solid color-mix(in srgb,var(--border-color) 56%,transparent);box-shadow:inset 1px 0 color-mix(in srgb,var(--panel-hover, #ffffff) 42%,transparent)}.editor-sidebar__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 24px 18px;border-bottom:1px solid color-mix(in srgb,var(--border-color) 70%,transparent);background:var(--editor-header-bg)}.editor-sidebar__eyebrow{margin:0 0 6px;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--editor-accent)}.editor-sidebar__title{margin:0;font-size:24px;line-height:1.08;letter-spacing:-.03em;color:var(--editor-title)}.editor-sidebar__meta{margin:8px 0 0;font-size:14px;color:var(--editor-text)}.editor-close-btn{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--border-color) 72%,transparent);border-radius:999px;background:color-mix(in srgb,var(--card, var(--bg-card)) 86%,transparent);color:var(--editor-title);cursor:pointer;box-shadow:0 10px 24px color-mix(in srgb,var(--vx-bg-main, #0f172a) 16%,transparent);transition:background .2s ease,transform .2s ease,box-shadow .2s ease}.editor-close-btn:hover{background:color-mix(in srgb,var(--panel-hover, var(--bg-card)) 84%,transparent);transform:translateY(-1px);box-shadow:0 14px 28px color-mix(in srgb,var(--vx-bg-main, #0f172a) 20%,transparent)}.editor-sidebar__body{flex:1;display:flex;flex-direction:column;gap:16px;min-height:0;padding:18px 24px 24px;overflow-y:auto;overscroll-behavior:contain}.editor-card{padding:16px;border-radius:20px;background:var(--editor-card-bg);border:1px solid var(--editor-card-border);box-shadow:0 16px 30px color-mix(in srgb,var(--vx-bg-main, #0f172a) 10%,transparent),inset 0 1px color-mix(in srgb,var(--panel-hover, #ffffff) 60%,transparent)}.editor-card--soft{background:var(--editor-card-soft-bg)}.editor-card--json{flex:1;display:flex;flex-direction:column;min-height:0;padding-bottom:0}.editor-card__label{margin:0 0 12px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--editor-muted)}.editor-card__row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.editor-card__row .editor-card__label{margin-bottom:0}.editor-card__value{font-size:13px;font-weight:700;color:var(--editor-success)}.editor-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.editor-btn{min-height:46px;padding:10px 14px;border:none;border-radius:14px;font-size:14px;font-weight:700;color:var(--editor-btn-text);cursor:pointer;box-shadow:var(--editor-btn-shadow);transition:transform .2s ease,filter .2s ease,box-shadow .2s ease}.editor-btn:hover{transform:translateY(-1px);filter:brightness(1.03);box-shadow:0 14px 22px color-mix(in srgb,var(--vx-bg-main, #0f172a) 16%,transparent)}.editor-btn--neutral{background:linear-gradient(135deg,var(--text-secondary),color-mix(in srgb,var(--text-secondary) 74%,black 26%))}.editor-btn--primary{background:linear-gradient(135deg,var(--primary),color-mix(in srgb,var(--primary) 74%,black 26%))}.editor-btn--danger{background:linear-gradient(135deg,var(--danger),color-mix(in srgb,var(--danger) 74%,black 26%))}.editor-btn--success{background:linear-gradient(135deg,var(--success),color-mix(in srgb,var(--success) 74%,black 26%))}.editor-help{display:grid;gap:8px;color:var(--editor-text);font-size:13px;line-height:1.55}.editor-json{width:100%;flex:1;min-height:0;resize:none;border:1px solid color-mix(in srgb,var(--primary) 24%,transparent);border-radius:14px;padding:14px;background:var(--editor-json-bg);color:var(--editor-json-text);font-size:12px;line-height:1.45;box-sizing:border-box;box-shadow:inset 0 1px color-mix(in srgb,var(--panel-hover, #ffffff) 10%,transparent)}.editor-json:disabled{opacity:1;-webkit-text-fill-color:var(--editor-json-text)}@media(max-width:1100px){.editor-modal{grid-template-columns:minmax(0,1fr) 320px}.editor-sidebar__title{font-size:24px}}@media(max-width:900px){.editor-overlay{padding:14px;align-items:flex-start;overflow-y:auto}.editor-modal{width:min(100vw,960px);height:auto;min-height:calc(100dvh - 28px);grid-template-columns:1fr;grid-template-rows:minmax(320px,52vh) minmax(0,1fr)}.editor-stage{padding:16px}.editor-sidebar{border-left:none;border-top:1px solid color-mix(in srgb,var(--border-color) 70%,transparent)}.editor-sidebar__body{max-height:none;min-height:0;overflow-y:visible}.editor-card--json{min-height:220px}.editor-json{min-height:180px}}@media(max-width:640px){.editor-overlay{padding:10px}.editor-modal{width:100%;min-height:calc(100dvh - 20px);border-radius:22px;grid-template-rows:minmax(240px,46vh) minmax(0,1fr)}.editor-stage{padding:10px}.editor-sidebar__header,.editor-sidebar__body{padding-left:16px;padding-right:16px}.editor-sidebar__title{font-size:20px}.editor-card .editor-card__label{display:none}.editor-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:0}.editor-btn{min-height:38px;padding:8px 10px;border-radius:12px;font-size:12px;line-height:1.2}.editor-card--json{min-height:200px}.editor-json{min-height:160px}}.zone-camera-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px;border:1px solid var(--border-color);border-radius:var(--card-radius, 8px);background:var(--card, var(--bg-card));transition:all .2s ease;margin-bottom:12px}.zone-camera-card:hover{background:color-mix(in srgb,var(--accent) 8%,var(--card, var(--bg-card)) 92%);border-color:color-mix(in srgb,var(--accent) 20%,var(--border-color) 80%)}.zone-camera-card-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.zone-camera-card-title{font-size:15px;font-weight:600;color:var(--text-primary);margin:0;word-break:break-word}.zone-camera-card-meta{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:6px;flex-wrap:wrap;line-height:1.4}.zone-camera-card-meta-label,.zone-camera-card-meta-badge-label{font-weight:500;color:var(--text-secondary)}.zone-camera-card-meta-item,.zone-camera-card-meta-item-badge{display:inline-flex;align-items:center;gap:4px}.zone-camera-card-meta-separator{color:var(--border-color);margin:0 2px}.zone-camera-card-actions{flex-shrink:0;display:flex;align-items:center;justify-content:flex-end}.zone-camera-card-list{display:flex;flex-direction:column;gap:0}.fade-text{position:relative;display:inline-block;max-width:140px;white-space:nowrap;overflow:hidden;vertical-align:bottom}.fade-text:after{content:"";position:absolute;top:0;right:0;width:30px;height:100%;pointer-events:none;background:linear-gradient(to right,transparent,var(--card, var(--bg-card)))}.zone-camera-status-badge{font-size:11px;font-weight:600;padding:4px 8px;border-radius:999px;white-space:nowrap}.zone-camera-status-badge.online{background:color-mix(in srgb,#22c55e 15%,transparent);color:#16a34a;border:1px solid color-mix(in srgb,#22c55e 40%,transparent)}.zone-camera-status-badge.offline{background:color-mix(in srgb,#ef4444 15%,transparent);color:#dc2626;border:1px solid color-mix(in srgb,#ef4444 40%,transparent)}.person-upload__backdrop{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(180deg,color-mix(in srgb,var(--page-bg) 56%,transparent),color-mix(in srgb,var(--page-bg-secondary) 70%,transparent));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:9999}.person-upload__modal{width:min(100%,420px);padding:28px 26px 24px;border-radius:20px;border:1px solid color-mix(in srgb,var(--border-color, var(--border)) 82%,transparent);background:linear-gradient(180deg,color-mix(in srgb,var(--card, var(--bg-card)) 94%,white 6%),color-mix(in srgb,var(--card, var(--bg-card)) 98%,var(--page-bg-secondary) 2%));color:var(--text);box-shadow:var(--shadow),inset 0 1px color-mix(in srgb,white 18%,transparent);text-align:center}.person-upload__modal h3{margin:0 0 18px;font-size:1.15rem;font-weight:600;letter-spacing:.2px;color:var(--text)}.person-upload__modal p{margin:6px 0;font-size:.85rem;color:var(--text-soft)}.person-upload__modal--drive{display:grid;gap:12px}.person-upload__modal--results{max-height:70vh;overflow:hidden}.person-upload__stats{display:grid;gap:2px}.person-upload__circle-wrapper{position:relative;width:140px;height:140px;margin:18px auto}.person-upload__circular-chart{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg);filter:drop-shadow(0 8px 16px color-mix(in srgb,var(--primary) 22%,transparent))}.person-upload__circle-bg{stroke:color-mix(in srgb,var(--border-color, var(--border)) 84%,transparent);stroke-width:3;fill:none}.person-upload__circle{stroke:var(--primary);stroke-width:3;stroke-linecap:round;fill:none;transition:stroke-dasharray .35s ease}.person-upload__circle-image-mask{position:absolute;inset:14px;border-radius:50%;overflow:hidden;background:color-mix(in srgb,var(--panel-subtle-bg) 82%,var(--card, var(--bg-card)) 18%);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--border-color, var(--border)) 75%,transparent);z-index:2}.person-upload__circle-image-mask img{width:100%;height:100%;object-fit:cover;object-position:center}.person-upload__circle-label{display:block;margin-top:10px;font-size:.85rem;font-weight:500;color:var(--text-soft)}.person-upload__success-text{color:var(--success);font-weight:500;margin-bottom:14px}.person-upload__failed-title{margin:16px 0 8px;font-size:.95rem;color:var(--danger)}.person-upload__failed-list{max-height:300px;overflow-y:auto;padding-right:6px}.person-upload__failed-item{display:flex;gap:10px;padding:8px;margin-bottom:6px;border-radius:10px;border:1px solid color-mix(in srgb,var(--border-color, var(--border)) 72%,transparent);background:color-mix(in srgb,var(--panel-subtle-bg) 86%,var(--card, var(--bg-card)) 14%);text-align:left}.person-upload__failed-thumb{width:48px;height:48px;border-radius:8px;overflow:hidden;background:color-mix(in srgb,var(--border-color, var(--border)) 64%,transparent);flex-shrink:0}.person-upload__failed-thumb img{width:100%;height:100%;object-fit:cover}.person-upload__thumb-placeholder{width:100%;height:100%;display:inline-flex;align-items:center;justify-content:center;color:var(--text-soft);font-size:.72rem;font-weight:700}.person-upload__failed-info{flex:1}.person-upload__failed-name{font-size:.85rem;font-weight:500;color:var(--text)}.person-upload__failed-reason{font-size:.75rem;color:var(--text-soft)}.person-upload__primary-btn,.person-upload__secondary-btn{width:100%;padding:10px 14px;border-radius:10px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease,color .2s ease,transform .2s ease,filter .2s ease}.person-upload__primary-btn{margin-top:16px;border:none;background:linear-gradient(135deg,var(--primary),var(--accent-2, var(--primary)));color:#fff;box-shadow:0 14px 28px color-mix(in srgb,var(--primary) 28%,transparent)}.person-upload__secondary-btn{margin-top:14px;border:1px solid color-mix(in srgb,var(--border-color, var(--border)) 82%,transparent);background:linear-gradient(180deg,color-mix(in srgb,var(--card, var(--bg-card)) 92%,transparent),color-mix(in srgb,var(--panel-subtle-bg) 72%,transparent));color:var(--text-soft)}.person-upload__primary-btn:hover:not(:disabled),.person-upload__secondary-btn:hover:not(:disabled){transform:translateY(-1px)}.person-upload__primary-btn:hover:not(:disabled){filter:brightness(1.03)}.person-upload__secondary-btn:hover:not(:disabled){background:linear-gradient(180deg,color-mix(in srgb,var(--card, var(--bg-card)) 98%,white 2%),color-mix(in srgb,var(--panel-hover) 70%,transparent));border-color:color-mix(in srgb,var(--primary) 38%,var(--border-color, var(--border)));color:var(--text)}.person-upload__primary-btn:focus-visible,.person-upload__secondary-btn:focus-visible,.person-upload__dropzone:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 24%,transparent)}.person-upload__primary-btn:active,.person-upload__secondary-btn:active{transform:translateY(1px)}.person-upload__primary-btn:disabled,.person-upload__secondary-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.person-upload__secondary-btn.is-send-progress{background:linear-gradient(180deg,color-mix(in srgb,var(--success) 78%,black 8%) 0%,var(--success) 100%);border-color:transparent;color:#fff;box-shadow:0 12px 24px color-mix(in srgb,var(--success) 28%,transparent)}.person-upload__secondary-btn.is-send-progress:disabled{background:var(--success);opacity:.85}.person-upload__dropzone{display:grid;place-items:center;min-height:132px;padding:18px;border-radius:16px;border:1.5px dashed color-mix(in srgb,var(--primary) 45%,var(--border-color, var(--border)));background:linear-gradient(180deg,color-mix(in srgb,var(--panel-subtle-bg) 78%,transparent),color-mix(in srgb,var(--card, var(--bg-card)) 62%,transparent));color:var(--text-soft);font-weight:500}.person-upload__dropzone:hover{border-color:var(--primary);color:var(--text)}.bulk-upload-btn{background:linear-gradient(135deg,color-mix(in srgb,var(--card, var(--bg-card)) 88%,var(--page-bg-secondary) 12%),color-mix(in srgb,var(--panel-subtle-bg) 76%,var(--card, var(--bg-card)) 24%));color:var(--text);border:1px solid color-mix(in srgb,var(--border-color, var(--border)) 85%,transparent);box-shadow:0 12px 24px color-mix(in srgb,black 10%,transparent),inset 0 1px color-mix(in srgb,white 12%,transparent)}.bulk-upload-btn:hover{background:linear-gradient(135deg,color-mix(in srgb,var(--panel-hover) 72%,var(--card, var(--bg-card)) 28%),color-mix(in srgb,var(--panel-subtle-bg) 64%,var(--card, var(--bg-card)) 36%));border-color:color-mix(in srgb,var(--primary) 36%,var(--border-color, var(--border)))}@media(max-width:640px){.person-upload__modal{width:100%;padding:22px 18px 18px;border-radius:18px}.person-upload__failed-list{max-height:240px}}.tag-input-container{position:relative;width:100%;margin-top:20px}.chips{display:flex;flex-wrap:wrap;align-items:flex-start;border:1px solid #ccc;border-radius:6px;padding:10px}.tag-search-input{border:none;outline:none;flex:1;min-width:120px}.camera-tag-label{margin-bottom:70px;position:absolute;bottom:20%}.camera-dropdown-label{margin-top:38px;width:100%;height:100%}.tag-dropdown{border:1px solid #ddd;background:#fff;max-height:200px;overflow-y:auto}.tag-dropdown-item{padding:8px;cursor:pointer}.tag-dropdown-item:hover{background:#f5f5f5}.chip{display:flex;align-items:center;gap:6px;border:2px solid #779fbb;background:#e6e6e6;color:#000;padding:4px 10px;border-radius:5px;font-size:14px;height:28px;line-height:1;white-space:nowrap}.chips{display:flex;align-items:flex-start;gap:8px;border:1px solid #ccc;border-radius:6px;padding:10px}.chip-list{display:flex;flex-wrap:wrap;gap:6px;flex:1}.chip.remove{cursor:pointer}.add-btn{height:35px;padding:0 12px;background:#07c;color:#fff;border-radius:5px;cursor:pointer;font-size:14px;display:flex;align-items:center;white-space:nowrap;flex-shrink:0}.add-btn:hover{background:#018cf0}.placeholder-text{color:#888;font-size:14px;padding:4px 6px;line-height:28px;-webkit-user-select:none;user-select:none;pointer-events:none}.company-dashboard{width:100%;padding:24px 32px;font-family:Inter,Segoe UI,sans-serif;background:#f4f6f9;min-height:100vh}.company-dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.company-dashboard-header h1{font-size:28px;font-weight:700;color:#1a1a2e;margin:0}.company-dashboard-header-actions{display:flex;gap:12px}.btn-add-company{display:flex;align-items:center;gap:6px;padding:10px 20px;background:#4361ee;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s ease,transform .1s ease}.btn-add-company:hover{background:#3a56d4;transform:translateY(-1px)}.btn-add-company:active{transform:translateY(0)}.company-selector{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding:16px 20px;background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000000f}.company-selector label{font-size:14px;font-weight:600;color:#555;white-space:nowrap}.company-selector select{flex:1;max-width:400px;padding:10px 14px;border:1.5px solid #ddd;border-radius:8px;font-size:14px;color:#333;background:#fafafa;transition:border-color .2s ease;cursor:pointer}.company-selector select:focus{outline:none;border-color:#4361ee;background:#fff}.company-nav-arrows{display:flex;gap:6px}.company-nav-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1.5px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;color:#555;font-size:16px}.company-nav-btn:hover:not(:disabled){border-color:#4361ee;color:#4361ee;background:#f0f3ff}.company-nav-btn:disabled{opacity:.4;cursor:not-allowed}.company-counter{font-size:13px;color:#888;font-weight:500;white-space:nowrap}.profile-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;overflow:hidden;margin-bottom:24px}.profile-card-banner{height:120px;background:linear-gradient(135deg,#3897eb,#345482);position:relative}.profile-card-avatar{position:absolute;bottom:-40px;left:32px;width:80px;height:80px;border-radius:16px;background:#fff;border:4px solid #fff;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#4361ee;overflow:hidden}.profile-card-avatar img{width:100%;height:100%;object-fit:cover}.profile-card-top{display:flex;justify-content:space-between;align-items:flex-start;padding:56px 32px 20px}.profile-card-info h2{font-size:22px;font-weight:700;color:#1a1a2e;margin:0 0 4px}.profile-card-info .company-code-badge{display:inline-block;padding:3px 10px;background:#eef0fb;color:#4361ee;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.5px}.profile-card-top-actions{display:flex;gap:8px}.btn-edit-profile{display:flex;align-items:center;gap:6px;padding:8px 18px;border:1.5px solid #4361ee;background:transparent;color:#4361ee;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-edit-profile:hover{background:#4361ee;color:#fff}.btn-save-profile{display:flex;align-items:center;gap:6px;padding:8px 18px;border:none;background:#10b981;color:#fff;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-save-profile:hover{background:#059669}.btn-cancel-edit{display:flex;align-items:center;gap:6px;padding:8px 18px;border:1.5px solid #e5e7eb;background:#fff;color:#666;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-cancel-edit:hover{background:#f9fafb;border-color:#ccc}.btn-delete-profile{display:flex;align-items:center;gap:6px;padding:8px 18px;border:1.5px solid #ef4444;background:transparent;color:#ef4444;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-delete-profile:hover{background:#ef4444;color:#fff}.profile-details-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding:0 32px 32px}.detail-section{background:#fafbfc;border:1px solid #f0f0f0;border-radius:12px;padding:20px;transition:box-shadow .2s ease}.detail-section:hover{box-shadow:0 2px 8px #0000000a}.detail-section-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.8px;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid #eee}.detail-section-title .section-icon{font-size:16px}.detail-field{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.detail-field:last-child{margin-bottom:0}.detail-field-label{font-size:12px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px}.detail-field-value{font-size:15px;font-weight:500;color:#333;word-break:break-word}.detail-field-value.empty{color:#ccc;font-style:italic}.detail-field-value a{color:#4361ee;text-decoration:none;transition:color .2s ease}.detail-field-value a:hover{color:#3a56d4;text-decoration:underline}.logo-preview-wrapper{min-height:20px;border:1px dashed #d1d5db;border-radius:14px;background:#fff;padding:6px;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 0 0 1px #4361ee08}.logo-preview{max-width:80px;max-height:160px;width:auto;height:auto;object-fit:contain}.detail-field-input{width:100%;padding:10px 12px;border:1.5px solid #ddd;border-radius:8px;font-size:14px;font-weight:500;color:#333;background:#fff;transition:border-color .2s ease,box-shadow .2s ease;font-family:inherit}.detail-field-input:focus{outline:none;border-color:#4361ee;box-shadow:0 0 0 3px #4361ee1a}.detail-field-input::placeholder{color:#bbb}.detail-field-textarea{width:100%;padding:10px 12px;border:1.5px solid #ddd;border-radius:8px;font-size:14px;font-weight:500;color:#333;background:#fff;transition:border-color .2s ease,box-shadow .2s ease;font-family:inherit;resize:vertical;min-height:60px}.detail-field-textarea:focus{outline:none;border-color:#4361ee;box-shadow:0 0 0 3px #4361ee1a}.profile-meta-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 32px;background:#fafbfc;border-top:1px solid #f0f0f0;border-radius:0 0 16px 16px}.meta-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#999}.meta-item span{font-weight:600;color:#666}.company-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;text-align:center}.company-empty-state img{width:180px;margin-bottom:24px;opacity:.7}.company-empty-state h3{font-size:20px;font-weight:700;color:#333;margin:0 0 8px}.company-empty-state p{font-size:14px;color:#888;margin:0 0 24px}@media(max-width:768px){.company-dashboard{padding:16px}.company-dashboard-header{flex-direction:column;gap:12px;align-items:flex-start}.company-selector{flex-wrap:wrap}.profile-details-grid{grid-template-columns:1fr;padding:0 20px 20px}.profile-card-top{flex-direction:column;gap:16px;padding:56px 20px 20px}.profile-card-top-actions{flex-wrap:wrap}.profile-meta-bar{flex-direction:column;gap:8px;align-items:flex-start;padding:16px 20px}}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.save-confirmation{animation:slideIn .3s ease;padding:12px 20px;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:10px;color:#065f46;font-size:14px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px}.dark .company-dashboard{background:radial-gradient(circle at top left,rgba(96,165,250,.1),transparent 24%),radial-gradient(circle at bottom right,rgba(59,130,246,.08),transparent 22%),var(--page-bg)}.dark .profile-card,.dark .company-empty-state,.dark .company-selector,.dark .logo-preview-wrapper{background:var(--card, var(--bg-elevated));border-color:var(--border-color);box-shadow:var(--shadow)}.dark .profile-card-avatar{background:var(--card, var(--bg-elevated));border-color:var(--card, var(--bg-elevated));color:#93c5fd}.dark .profile-card-info h2,.dark .detail-field-value,.dark .company-empty-state h3,.dark .meta-item span{color:var(--text-primary)}.dark .company-selector label,.dark .company-counter,.dark .detail-section-title,.dark .detail-field-label,.dark .meta-item,.dark .company-empty-state p,.dark .detail-field-value.empty{color:var(--text-secondary)}.dark .profile-card-info .company-code-badge{background:#3b82f629;color:#93c5fd}.dark .btn-edit-profile{border-color:#60a5fa73;color:#93c5fd}.dark .btn-edit-profile:hover{background:#2563eb;color:#fff}.dark .btn-cancel-edit{border-color:var(--border-color);background:#1e293be6;color:var(--text-secondary)}.dark .btn-cancel-edit:hover{background:var(--button-hover);border-color:#60a5fa59}.dark .detail-section,.dark .profile-meta-bar{background:color-mix(in srgb,var(--card, var(--bg-elevated)) 88%,var(--page-bg) 12%);border-color:var(--border-color)}.dark .detail-section:hover{box-shadow:0 12px 28px #02061759}.dark .detail-section-title{border-bottom-color:var(--border-color)}.dark .logo-preview-wrapper{border-color:#94a3b847}.dark .detail-field-input,.dark .detail-field-textarea,.dark .company-selector select{background:var(--bg-soft);color:var(--text-primary);border-color:var(--border-color)}.dark .detail-field-input::placeholder,.dark .detail-field-textarea::placeholder{color:var(--text-secondary)}.dark .detail-field-input:focus,.dark .detail-field-textarea:focus,.dark .company-selector select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #60a5fa24}.dark .save-confirmation{background:#10b98129;border-color:#10b98147;color:#86efac}.sd-form-field--multi-select{margin-top:28px}.sd-multi-select{position:relative}.sd-multi-select-label{position:absolute;top:-10px;left:12px;z-index:2;padding:0 6px;font-size:14px;color:var(--accent);background:color-mix(in srgb,var(--card, var(--bg-card)) 96%,transparent);pointer-events:none}.sd-multi-select-control{min-height:84px;padding:22px 12px 10px;border:1px solid color-mix(in srgb,var(--accent) 45%,var(--border-color, var(--border)));border-radius:4px;background:color-mix(in srgb,var(--card, var(--bg-card)) 92%,var(--page-bg) 8%);color:var(--text-primary);display:flex;flex-direction:column;gap:8px}.sd-multi-select-control.is-open{box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 72%,transparent)}.sd-chip-list{display:flex;flex-wrap:wrap;gap:6px}.sd-chip{display:inline-flex;align-items:center;gap:6px;height:28px;padding:4px 10px;border:1px solid color-mix(in srgb,var(--accent) 34%,var(--border-color, var(--border)));border-radius:5px;background:color-mix(in srgb,var(--accent) 10%,var(--panel-subtle-bg) 90%);color:var(--text-primary);font-size:14px;line-height:1;white-space:nowrap}.sd-chip-remove{border:none;background:transparent;color:inherit;font-size:16px;line-height:1;padding:0;cursor:pointer}.sd-input-row{display:flex;align-items:center;gap:8px}.sd-input{flex:1;min-width:120px;border:none;border-bottom:1px solid color-mix(in srgb,var(--accent) 45%,var(--border-color, var(--border)));outline:none;background:transparent;padding:5px 0;font-size:14px;color:var(--text-primary)}.sd-input::placeholder{color:var(--text-secondary)}.sd-input-toggle{border:none;background:transparent;color:var(--text-secondary);padding:4px;line-height:1;cursor:pointer}.sd-chevron{display:inline-block;transition:transform .2s ease}.sd-chevron.open{transform:rotate(180deg)}.sd-multi-select-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:5;margin:0;padding:6px 0;list-style:none;max-height:180px;overflow-y:auto;background:color-mix(in srgb,var(--card, var(--bg-card)) 96%,var(--page-bg) 4%);border:1px solid var(--border-color, var(--border));border-radius:6px;box-shadow:var(--shadow)}.sd-dropdown-item{width:100%;border:none;background:transparent;text-align:left;padding:8px 12px;cursor:pointer;font-size:14px;color:var(--text-primary)}.sd-dropdown-item:hover{background:color-mix(in srgb,var(--accent) 10%,transparent)}.sd-exhausted-text,.sd-no-results{margin:0;padding-top:4px;font-size:13px;color:var(--text-secondary)}.condition-group-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;position:relative}.condition-group-header-title{font-size:16px;color:var(--text-primary);font-weight:600;margin:0}.add-condition-grp-btn{position:relative;top:0;left:0;background:var(--accent);padding:8px 12px;border-radius:4px;color:#fff;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease;white-space:nowrap}.add-condition-grp-btn:hover{background:var(--accent-2)}.add-condition-grp-btn:disabled{background:var(--muted);cursor:not-allowed}.add-action-btn{position:relative;top:0;left:0;background:var(--accent);padding:8px 12px;border-radius:4px;color:#fff;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease;white-space:nowrap}.add-action-btn:hover{background:var(--accent-2)}.add-action-btn:disabled{background:var(--muted);cursor:not-allowed}.add-group-placeholder,.add-action-placeholder{position:relative;padding:20px;border:2px dashed var(--border-color);border-radius:8px;background:var(--page-bg);text-align:center;margin:16px 0}.add-group-placeholder a,.add-action-placeholder a{color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;cursor:default}.condition-group{display:block;width:100%;border:1px solid var(--border-color);border-radius:8px;padding:12px;margin-bottom:16px;background:var(--bg-card);position:relative}.group-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color);gap:12px}.and-or-toggle-button{padding:6px 12px;border:2px solid var(--accent);border-radius:6px;background:transparent;color:var(--accent);font-weight:600;font-size:12px;cursor:pointer;transition:all .2s ease;outline:none;white-space:nowrap;flex-shrink:0}.and-or-toggle-button:hover{background:#1f78ff1a}.and-or-toggle-button:active{transform:scale(.98)}.and-or-toggle-button:focus{outline:none;box-shadow:0 0 0 3px #1f78ff26}.add-condition-btn{position:relative;background:var(--accent);padding:6px 12px;border-radius:4px;color:#fff;border:none;cursor:pointer;font-size:12px;font-weight:500;transition:background-color .2s ease;white-space:nowrap;margin-left:auto;flex-shrink:0}.add-condition-btn:hover{background:var(--accent-2)}.add-condition-btn:disabled{background:var(--muted);cursor:not-allowed;opacity:.6}.condition-row{border:1px solid var(--border-color);padding:12px;border-radius:6px;background:var(--bg-card);margin-top:12px;position:relative;display:flex;flex-direction:column;gap:10px}.condition-row.has-error{border-color:var(--danger);background-color:#dc26261a}.condition-row .condition-fields{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start}.condition-row select,.condition-row input[type=number],.condition-row input[type=time],.condition-row input[type=text]{padding:8px 10px;border:1px solid var(--border-color);border-radius:4px;font-size:13px;flex:1;min-width:120px;background:var(--bg-card);color:var(--text-primary)}.condition-row select:focus,.condition-row input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #1f78ff26}.remove-condition-button,.remove-action-button{position:absolute;top:8px;right:8px;width:28px;height:28px;border:none;border-radius:4px;background:transparent;color:var(--text-secondary);font-size:20px;line-height:1;cursor:pointer;padding:0;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.remove-condition-button:hover:not(:disabled),.remove-action-button:hover:not(:disabled){background:#dc26261a;color:var(--danger)}.remove-condition-button:active:not(:disabled),.remove-action-button:active:not(:disabled){transform:scale(.95)}.remove-condition-button:disabled,.remove-action-button:disabled{color:var(--text-secondary);cursor:not-allowed;opacity:.5}.condition-type-selector{padding:10px;color:var(--text-primary);border-radius:8px;background:var(--page-bg);border:none;margin:10px}.confidence-selector{padding:10px!important;width:150px!important;transform:translateY(0)!important;-webkit-appearance:none!important;appearance:none!important;height:1px!important;border-radius:6px!important;background:var(--page-bg)!important;outline:none!important;transition:background .2s ease!important}.confidence-wrapper{width:20px;max-width:580px;padding-left:2px;flex-direction:column;gap:6px;position:relative;left:10px}.confidence-header{display:flex;justify-content:space-between;align-items:center}.confidence-label{font-size:13px;color:var(--text-secondary)}.confidence-value{font-size:13px;font-weight:600;color:var(--accent)}.confidence-slider{-webkit-appearance:none;appearance:none;width:10%;height:6px;border-radius:6px;outline:none;cursor:pointer;transition:background .2s ease}.confidence-slider::-webkit-slider-runnable-track{height:6px;border-radius:6px;background:transparent}.confidence-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--bg-card);border:3px solid var(--accent);cursor:pointer;margin-top:-5px;transition:transform .15s ease}.confidence-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.confidence-slider::-moz-range-track{height:6px;border-radius:6px;background:transparent}.confidence-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--bg-card);border:3px solid var(--accent);cursor:pointer}.rule-checkbox{appearance:none!important;-webkit-appearance:none!important;width:22px!important;height:22px!important;border:2px solid var(--accent)!important;border-radius:6px!important;cursor:pointer!important;position:relative!important;transition:all .2s ease!important;display:inline-grid!important;place-content:center!important}.rule-checkbox:checked{background-color:var(--accent)!important;border-color:var(--accent)!important}.rule-checkbox:after{content:""!important;width:6px!important;height:12px!important;border:solid white!important;border-width:0 2px 2px 0!important;transform:rotate(45deg) scale(0)!important;transition:transform .2s ease!important}.rule-checkbox:checked:after{transform:rotate(45deg) scale(1)!important}.rule-checkbox:hover{box-shadow:0 0 0 3px #1f78ff33!important}.rule-checkbox:disabled{border-color:var(--border-color)!important;background-color:var(--page-bg)!important;cursor:not-allowed!important}.condition-group{width:100%;display:block;position:relative}.condition-row,.action-item{position:relative;border:1px solid var(--border-color);border-radius:6px;padding:16px 48px 12px 12px;margin-top:10px;background:var(--bg-card)}.condition-fields,.action-fields{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}.condition-row .custom-select,.action-item .custom-select{margin:0;min-width:220px;width:240px;flex:0 0 240px}.condition-row input[type=number],.condition-row input[type=time],.condition-row input[type=text]{width:220px;min-width:220px;margin:0;transform:none}.condition-row .confidence-wrapper{width:240px;max-width:240px;left:0;padding-left:0}.condition-row .confidence-slider{width:100%}.condition-row .custom-select[data-open=true],.action-item .custom-select[data-open=true]{z-index:3000}.rule-details{display:flex;flex-direction:column;gap:16px;padding:16px;background:var(--bg-card);border-radius:8px;margin-bottom:24px}.rule-details input{padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-weight:400;color:var(--text-primary);background:var(--bg-card);transition:all .2s ease}.rule-details input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #1f78ff26}.rule-details input::placeholder{color:var(--text-secondary)}.rule-details .rule-status-select,.rule-details .custom-select{width:100%;min-width:100%}.actions-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.actions-header-title{font-size:16px;color:var(--text-primary);font-weight:600;margin:0}.rule-details input.error,.condition-row.error,.action-item.error{border-color:#dc2626;background-color:#fef2f2}.rule-details input.error:focus{box-shadow:0 0 0 2px #dc26261a}.action-item{position:relative;border:1px solid var(--border-color);padding:12px;border-radius:6px;background:var(--bg-card);margin-top:12px}.action-item.has-error{border-color:var(--danger);background-color:#dc26261a}.action-fields{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start}.action-item .custom-select{margin:0;min-width:200px;width:240px;flex:1}.rule-form-container{display:flex;flex-direction:column;gap:8px}.rule-preview-container{background:var(--bg-card);padding:20px;border-radius:12px;border:1px solid var(--border-color);color:var(--text-primary)}.rule-preview-title{margin-bottom:15px;font-size:18px;color:var(--accent)}.preview-section{margin-bottom:25px}.preview-label{font-size:13px;color:var(--text-secondary);margin-bottom:8px;letter-spacing:1px;text-transform:uppercase;font-weight:600}.preview-group{margin-bottom:15px;padding-left:10px;border-left:3px solid var(--accent)}.group-operator{font-size:12px;color:var(--accent);margin-bottom:6px;font-weight:600}.preview-condition{background:var(--page-bg);padding:8px 12px;border-radius:6px;margin-bottom:6px;border-left:3px solid var(--accent);color:var(--text-primary)}.preview-action{background:var(--accent);padding:8px 12px;border-radius:6px;margin-bottom:6px;font-weight:500;color:#fff}.preview-logic{font-size:12px;color:var(--text-secondary);margin:4px 0;font-weight:500}.group-separator{color:var(--danger);font-weight:600}.preview-placeholder{font-size:13px;color:var(--text-secondary);font-style:italic}.playback-root,.vx-playback-layout{height:100%;min-height:0}.vx-playback-layout{position:relative;display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px;width:100%;padding:16px;box-sizing:border-box;background:radial-gradient(circle at 15% 10%,rgba(138,178,246,.38),transparent 46%),radial-gradient(circle at 85% 80%,rgba(168,206,255,.35),transparent 44%),var(--vx-bg-main);color:var(--vx-text-primary);font-family:Manrope,Segoe UI,Trebuchet MS,sans-serif;animation:vx-page-fade-in .36s ease-out}.vx-camera-panel{border-radius:18px;border:1px solid rgba(166,186,220,.5);background:linear-gradient(180deg,#182238f0,#11192cf5);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 18px 42px #0a122342;overflow:hidden;display:flex;flex-direction:column;min-height:0;position:relative}.vx-camera-panel__header{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:18px 18px 12px;border-bottom:1px solid rgba(96,122,165,.28)}.vx-camera-panel__title-block{min-width:0}.vx-panel-eyebrow{display:inline-flex;margin-bottom:6px;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:#9bb7e7bd}.vx-camera-panel__header h1{margin:0;font-size:1.08rem;letter-spacing:.02em;color:#f4f8ff}.vx-camera-panel__header p{margin:4px 0 0;color:#c3d2eeb3;font-size:.78rem;max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vx-playback-toolbar{padding:14px 16px 12px;border-bottom:1px solid rgba(96,122,165,.24);display:grid;gap:12px}.vx-playback-toolbar__summary{padding:12px 14px;border-radius:14px;border:1px solid rgba(109,137,183,.24);background:linear-gradient(135deg,#ffffff14,#5482d614);box-shadow:inset 0 1px #ffffff0d}.vx-toolbar-label{display:block;margin-bottom:4px;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:#9ab5e2ad}.vx-playback-toolbar__summary strong{display:block;font-size:.92rem;color:#f8fbff}.vx-playback-toolbar__summary small{display:block;margin-top:4px;color:#c4d4ef9e;font-size:.74rem}.vx-datetime-selector{display:flex;gap:8px}.vx-datetime-group{flex:1;display:flex}.vx-datetime-label{width:100%;display:flex;align-items:center;gap:6px;border:1px solid rgba(120,148,194,.28);background:#ffffff14;border-radius:12px;padding:0 8px;cursor:pointer;transition:border-color .2s ease,background-color .2s ease,transform .2s ease}.vx-datetime-label:hover{border-color:#689cf1a3;background:#ffffff1a;transform:translateY(-1px)}.vx-datetime-label:focus-within{border-color:#689cf1f2;box-shadow:0 0 0 2px #689cf126}.vx-datetime-label svg{color:#bcceebc7;flex-shrink:0}.vx-datetime-input{flex:1;border:none;background:transparent;color:#edf4ff;font-size:.85rem;outline:none;padding:8px 0;font-family:Manrope,Segoe UI,sans-serif}.vx-datetime-input::placeholder{color:#5f6f8a80}.vx-ghost-button{border:1px solid rgba(120,149,194,.34);background:#ffffff14;color:#e8f1ff;width:32px;height:32px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s ease,transform .2s ease,background-color .2s ease}.vx-ghost-button:hover{border-color:#689cf1f2;background:#ffffff24;transform:translateY(-1px)}.vx-camera-search{margin:12px 14px;border:1px solid rgba(120,148,194,.28);background:#ffffff14;border-radius:12px;height:38px;display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:8px;padding:0 10px}.vx-camera-search svg{color:#bcceebb8}.vx-camera-search input{border:none;outline:none;background:transparent;color:#f3f8ff;font-size:.84rem}.vx-camera-search input::placeholder{color:#bcceeb75}.vx-camera-panel__error{margin:0 14px 10px;border-radius:10px;border:1px solid rgba(220,116,116,.45);background:#fdececf2;color:#a53737;font-size:.76rem;padding:8px 10px}.vx-camera-panel__subhead{display:flex;align-items:center;justify-content:space-between;margin:2px 16px 8px;color:#abc1e6b3;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase}.vx-camera-panel__subhead strong{color:#f3f8ff;font-size:.8rem}.vx-camera-panel__list{flex:1;min-height:0;overflow-y:auto;padding:4px 12px 14px}.vx-camera-panel__empty{border:1px dashed rgba(176,193,221,.8);border-radius:10px;color:var(--vx-text-secondary);font-size:.84rem;text-align:center;padding:16px 12px;margin:12px 0;background:#fcfdffe6}.vx-camera-group{margin:0 0 12px}.vx-camera-group__title{display:flex;justify-content:space-between;align-items:center;font-size:.71rem;letter-spacing:.08em;text-transform:uppercase;color:#a5badf99;margin:8px 4px}.vx-camera-group__title strong{font-size:.73rem;color:#d8e6ff}.vx-camera-row{width:100%;border:1px solid rgba(112,141,190,.08);border-radius:12px;background:linear-gradient(135deg,#ffffff14,#6582b10d);color:#eff5ff;cursor:pointer;display:grid;grid-template-columns:12px minmax(0,1fr);align-items:center;gap:10px;text-align:left;padding:10px 11px;margin-bottom:6px;transition:border-color .22s ease,background-color .22s ease,transform .22s ease,box-shadow .22s ease}.vx-camera-row:hover{border-color:#70a1f175;background:linear-gradient(135deg,#ffffff1a,#70a1f114);transform:translate(2px)}.vx-camera-row.is-selected{border-color:#5998f4e6;background:linear-gradient(140deg,#527bc55c,#77a8ff24);box-shadow:0 10px 24px #14356f38}.vx-camera-row__status{width:8px;height:8px;border-radius:999px}.vx-camera-row__status.online{background:var(--vx-success);box-shadow:0 0 0 4px #1f9a6729}.vx-camera-row__status.offline{background:var(--vx-danger);box-shadow:0 0 0 4px #d645451f}.vx-camera-row__meta{min-width:0;display:grid;gap:2px}.vx-camera-row__meta strong{font-size:.83rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vx-camera-row__meta small{font-size:.72rem;color:#c3d2ee9e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vx-camera-skeleton-list{display:grid;gap:6px;margin-top:10px}.vx-camera-skeleton-row{height:40px;border-radius:9px;background:linear-gradient(100deg,#e4ecf9e6 8%,#d5e1f4 18%,#e4ecf9e6 33%);background-size:220% 100%;animation:vx-shimmer 1.15s linear infinite}.vx-playback-main{min-height:0;border-radius:20px;border:1px solid rgba(173,194,225,.22);background:linear-gradient(180deg,#101829fa,#0c121ffa);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden;position:relative;box-shadow:0 22px 56px #070e1c47}.vx-video-canvas{position:relative;width:100%;height:100%;min-height:420px;background:#04070d;overflow:hidden}.vx-video-canvas__video{width:100%;height:100%;object-fit:cover;background:#f4f8ff}.vx-video-canvas__meta{position:absolute;left:16px;top:16px;z-index:12;display:flex;align-items:center;justify-content:space-between;gap:18px;width:calc(100% - 32px);pointer-events:none}.vx-video-canvas__meta-copy,.vx-video-canvas__meta-pills{pointer-events:auto}.vx-video-canvas__meta-copy{max-width:55%;padding:14px 16px;border-radius:16px;background:linear-gradient(135deg,#080d18c2,#101a2e6b);border:1px solid rgba(159,186,232,.18);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:vx-float-in .42s ease-out}.vx-video-canvas__meta h2{margin:0;font-size:1rem;font-weight:600;color:#f5f8ff}.vx-video-canvas__meta p{margin:4px 0 0;font-size:.73rem;color:#cfdcf2b8}.vx-video-canvas__meta-pills{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;animation:vx-float-in .48s ease-out}.vx-status-pill{border:1px solid rgba(146,172,214,.2);background:#0b1426c7;border-radius:999px;padding:8px 12px;text-transform:capitalize;font-size:.72rem;color:#dbe8ff;display:inline-flex;gap:4px;align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.vx-status-pill--playing{border-color:#1f9a6757;color:#9af0bf}.vx-status-pill--loading{border-color:#b5851d66;color:#8a6517}.vx-status-pill--error{border-color:#d645457a;color:#a23e3e}.vx-status-pill--idle{border-color:#98add0e6}.vx-video-overlay{position:absolute;z-index:7;inset:0;display:grid;place-content:center;text-align:center;padding:20px;gap:8px;color:#e8f1ff}.vx-video-overlay--empty{background:radial-gradient(circle at center,#122039ad,#070c16e0)}.vx-video-overlay--empty h3{margin:0;font-size:1.18rem}.vx-video-overlay--empty p{margin:0;font-size:.84rem;color:#d3dff4a8}.vx-video-overlay--loading{align-items:center;background:#f3f8ffd1}.vx-video-overlay--loading .MuiCircularProgress-root{color:#2b86ff;margin:0 auto}.vx-video-overlay--loading p{margin:0;font-size:.83rem;color:#345074}.vx-video-overlay--error{background:#fff1f1e6}.vx-video-overlay--error h4{margin:0;font-size:1rem;color:#a03b3b}.vx-video-overlay--error p{margin:0;font-size:.82rem;color:#9f4a4a;max-width:560px}.vx-error-retry{margin:8px auto 0;border:1px solid rgba(214,69,69,.45);color:#8f3535;background:#fffffffa;border-radius:10px;font-size:.8rem;padding:8px 12px;cursor:pointer}.vx-spinner{width:28px;height:28px;border:3px solid rgba(31,120,255,.2);border-top-color:#1f78ff;border-radius:50%;animation:vx-spin .8s linear infinite;margin:0 auto}@keyframes vx-spin{to{transform:rotate(360deg)}}.vx-playback-controls{position:absolute;left:16px;right:16px;bottom:16px;z-index:10;border:1px solid rgba(176,194,223,.94);background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:14px;padding:12px 12px 10px;opacity:0;transform:translateY(14px);pointer-events:none;transition:opacity .2s ease,transform .2s ease}.vx-playback-controls.is-visible{opacity:1;transform:translateY(0);pointer-events:auto}.vx-playback-controls__row{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:12px}.vx-playback-controls__group{display:inline-flex;align-items:center;gap:8px}.vx-control-button{border:1px solid rgba(176,194,223,.96);width:34px;height:34px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;color:#1f3c63;background:#fffffffc;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.vx-control-button:hover{background:#eff6ff;border-color:#72a6f5e6}.vx-control-button:disabled{opacity:.42;cursor:not-allowed}.vx-volume-slider{width:94px;accent-color:var(--vx-accent)}.vx-time-display{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-variant-numeric:tabular-nums;color:#2e4f79;font-weight:600}.vx-time-display__separator{color:#7590b5}.vx-seekbar{position:relative;height:16px;cursor:pointer;display:flex;align-items:center}.vx-seekbar.is-disabled{opacity:.55;cursor:not-allowed}.vx-seekbar__rail,.vx-seekbar__buffer,.vx-seekbar__progress{position:absolute;left:0;height:5px;border-radius:999px}.vx-seekbar__rail{right:0;background:#c4d0e3d9}.vx-seekbar__buffer{background:#9db3d4c2}.vx-seekbar__progress{background:linear-gradient(90deg,var(--vx-accent),var(--vx-accent-strong))}.vx-seekbar__thumb{position:absolute;width:12px;height:12px;border-radius:999px;background:#fff;border:1px solid rgba(86,146,239,.9);transform:translate(-50%);box-shadow:0 0 0 4px #4691ff33}.vx-seekbar.is-dragging .vx-seekbar__thumb{box-shadow:0 0 0 6px #4691ff42}.vx-hover-preview{position:absolute;bottom:calc(100% + 12px);transform:translate(-50%);pointer-events:none;width:168px}.vx-hover-preview__frame{border:1px solid rgba(176,194,223,.94);border-radius:10px;overflow:hidden;background:#fffffffa;box-shadow:0 10px 25px #3b5f9733}.vx-hover-preview__frame img{display:block;width:100%;height:95px;object-fit:cover}.vx-hover-preview__placeholder{height:95px;display:grid;place-items:center;color:#7d94b8;font-size:.72rem}.vx-hover-preview__time{margin-top:6px;border-radius:999px;background:#fffffffa;border:1px solid rgba(176,194,223,.94);color:#2b476d;display:inline-flex;padding:4px 8px;font-size:.72rem;font-variant-numeric:tabular-nums}@keyframes vx-shimmer{to{background-position:-220% 0}}@keyframes vx-page-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes vx-float-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1120px){.vx-playback-layout{grid-template-columns:280px minmax(0,1fr)}.vx-video-canvas{min-height:360px}}@media(max-width:920px){.vx-playback-layout{grid-template-columns:1fr;grid-template-rows:minmax(220px,35vh) minmax(320px,1fr)}.vx-camera-panel{min-height:220px}.vx-playback-main{min-height:320px}}@media(max-width:640px){.vx-playback-layout{padding:10px;gap:10px}.vx-video-canvas{min-height:280px}.vx-video-canvas__meta{width:calc(100% - 20px);left:10px;top:10px}.vx-playback-controls{left:8px;right:8px;bottom:8px;border-radius:12px;padding:10px}.vx-playback-controls__row{flex-direction:column;align-items:stretch;gap:8px}.vx-playback-controls__group{justify-content:space-between}.vx-volume-slider{width:100%}}.vx-iframe-player{position:absolute;top:0;left:0;width:100%;height:100%;border:none;background:#000}.vx-video-canvas{position:relative;width:100%;height:100%;background:#000;overflow:hidden}.vx-playback-main{display:flex;flex-direction:column;transition:all .3s cubic-bezier(.4,0,.2,1)}.playback-player-wrapper{flex:1 1 auto;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f1e3cf2,#1e2d50e6);border-radius:14px;overflow:hidden;position:relative;min-height:360px}.playback-iframe{width:100%;height:100%;border:none;border-radius:14px}.playback-skeleton{position:absolute;inset:0;background:linear-gradient(90deg,#e4ecf91a,#e4ecf94d,#e4ecf91a);animation:skeleton-pulse 2s ease-in-out infinite;border-radius:14px}@keyframes skeleton-pulse{0%,to{opacity:.6}50%{opacity:1}}.playback-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#ffffffb3;height:100%;width:100%;padding:2rem}.playback-empty h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#fffffff2}.playback-empty p{margin:0;font-size:.95rem;opacity:.8}.playback-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;background:#d6454526;border:1px solid rgba(214,69,69,.4);border-radius:12px;padding:2rem;z-index:20;width:85%;max-width:450px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.playback-error p{margin:0 0 1.5rem;color:#d64545;font-size:.95rem;font-weight:500}.playback-error__retry{background:linear-gradient(135deg,var(--vx-accent),var(--vx-accent-strong));color:#fff;border:none;padding:.6rem 1.8rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #1f78ff4d}.playback-error__retry:hover{transform:translateY(-2px);box-shadow:0 6px 16px #1f78ff66}.playback-fullscreen-btn{position:absolute;bottom:1.25rem;right:1.25rem;width:2.75rem;height:2.75rem;background:#ffffff2e;color:#fff;border:1px solid rgba(255,255,255,.35);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:30;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.playback-fullscreen-btn:hover{background:#ffffff47;border-color:#ffffff80;transform:translateY(-2px)}.playback-fullscreen-btn:active{transform:scale(.95)}@media(max-width:1024px){.playback-player-wrapper{min-height:300px}.playback-fullscreen-btn{width:2.5rem;height:2.5rem;bottom:1rem;right:1rem}}@media(max-width:768px){.playback-player-wrapper{border-radius:10px;min-height:240px}.playback-iframe{border-radius:10px}.playback-error{width:90%;padding:1.5rem}.playback-fullscreen-btn{width:2.25rem;height:2.25rem;bottom:.75rem;right:.75rem}}@media(max-width:480px){.playback-player-wrapper{border-radius:8px;min-height:200px}.playback-error{border-radius:10px;padding:1.25rem}.playback-error p{font-size:.9rem}.playback-fullscreen-btn{width:2rem;height:2rem;bottom:.5rem;right:.5rem}}.vx-custom-player{position:relative;width:100%;height:auto;aspect-ratio:16/9;background:#000;overflow:hidden;border-radius:8px}.vx-video-canvas{position:relative;width:100%;height:100%;background:#000;display:flex;align-items:center;justify-content:center}.vx-video-canvas__container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.vx-video-canvas__video{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#000;margin:auto;max-width:100%;max-height:100%}.vx-video-canvas__probe{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.vx-custom-player__debug{position:absolute;top:8px;left:8px;background:#000000b3;color:#0f0;font-family:monospace;font-size:11px;padding:8px;border-radius:4px;z-index:100}.vx-custom-player__loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:20;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .3s ease-out}.vx-custom-player__spinner-container{display:flex;flex-direction:column;align-items:center;gap:16px}.vx-custom-player__spinner{width:40px;height:40px;color:#3b82f6;animation:spin 1s linear infinite}.vx-custom-player__loading-text{color:#fff;font-size:14px;font-weight:500;margin:0;text-align:center}.vx-custom-player__error-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:20;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease-out}.vx-custom-player__error-container{display:flex;flex-direction:column;align-items:center;gap:20px;padding:20px;text-align:center}.vx-custom-player__error-text{color:#ef4444;font-size:14px;font-weight:500;margin:0;max-width:200px}.vx-custom-player__retry-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease-in-out;box-shadow:0 4px 12px #3b82f666;outline:none}.vx-custom-player__retry-button:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 6px 16px #3b82f680}.vx-custom-player__retry-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #3b82f64d}.vx-custom-player__retry-button:disabled{opacity:.7;cursor:not-allowed}.vx-custom-player__retry-spinner{width:18px;height:18px;animation:spin .8s linear infinite}.vx-apply-button{display:flex;align-items:center;justify-content:center;gap:8px;width:90%;padding:10px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-weight:500;font-size:14px;cursor:pointer;transition:all .2s ease-in-out;margin-top:8px;margin-left:5%}.vx-apply-button:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}.vx-apply-button:not(:disabled):hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.vx-apply-button--dirty:not(:disabled){animation:pulse-dirty 2s cubic-bezier(.4,0,.6,1) infinite}.vx-apply-button--applying{opacity:.8}.vx-apply-button--applied{background:#10b981}.vx-apply-button--applied:disabled{background:#10b981}.vx-apply-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse-dirty{0%,to{box-shadow:0 0 #3b82f6b3}50%{box-shadow:0 0 0 4px #3b82f600}}.vx-seek-bar-container{width:100%;padding:12px 16px;position:relative}.vx-seek-bar{position:relative;width:100%;height:5px;background:#fff3;border-radius:2.5px;cursor:pointer;transition:height .2s}.vx-seek-bar:hover{height:6px}.vx-seek-bar.is-disabled{cursor:not-allowed;opacity:.5}.vx-seek-bar__rail{position:absolute;width:100%;height:100%;border-radius:2.5px;background:#ffffff1a;pointer-events:none}.vx-seek-bar__buffered{position:absolute;top:0;left:0;height:100%;background:#fff6;border-radius:2.5px;pointer-events:none}.vx-seek-bar__progress{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#60a5fa,#3b82f6);border-radius:2.5px;pointer-events:none;transition:width .05s linear}.vx-seek-bar__thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000004d;pointer-events:none;transition:width .2s,height .2s}.vx-seek-bar:hover .vx-seek-bar__thumb{width:16px;height:16px}.vx-seek-bar.is-dragging .vx-seek-bar__thumb{width:18px;height:18px;box-shadow:0 4px 12px #0006}.vx-seek-bar__thumbnail-preview{position:absolute;bottom:20px;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:1000;pointer-events:none}.vx-seek-bar__thumbnail-preview img{border:2px solid rgba(255,255,255,.2);border-radius:4px;box-shadow:0 4px 16px #0006}.vx-seek-bar__time-label{background:#000c;color:#fff;padding:4px 8px;border-radius:3px;font-size:12px;font-family:Monaco,Menlo,Consolas,monospace;font-weight:500;white-space:nowrap}.vx-seek-bar:focus-visible{outline:2px solid #fff;outline-offset:2px}.vx-settings-page{display:grid;grid-template-columns:188px minmax(0,1fr);gap:12px;min-height:100%;color:var(--text-primary);background:linear-gradient(180deg,var(--settings-page-bg),transparent);border-radius:var(--card-radius)}.vx-settings-sidebar,.vx-settings-panel,.vx-overview-card,.vx-appearance-groups,.vx-appearance-controls,.vx-settings-placeholder-card,.vx-control-card{border:1px solid var(--border);border-radius:var(--card-radius);background:linear-gradient(180deg,var(--settings-panel),var(--settings-panel-strong));box-shadow:var(--settings-shadow);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur))}.vx-settings-sidebar{display:flex;flex-direction:column;gap:12px;padding:calc(var(--content-gap) * .6);position:sticky;top:0;height:fit-content}.vx-settings-sidebar__brand h1,.vx-appearance-controls__header h3,.vx-settings-placeholder-card h3,.vx-overview-card h3{margin:0;color:var(--text-primary)}.vx-overview-card__label,.vx-control-card__label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary)}.vx-settings-sidebar__tabs,.vx-appearance-groups__list,.vx-preset-grid,.vx-settings-placeholder-grid,.vx-control-grid,.vx-appearance-overview__stack{display:grid;gap:8px}.vx-settings-tab,.vx-appearance-group-tab,.vx-preset-card,.vx-button{border:1px solid transparent;background:transparent;color:inherit;font:inherit;cursor:pointer;transition:background-color var(--transition-fast) ease,border-color var(--transition-fast) ease,color var(--transition-fast) ease,transform var(--transition-fast) ease,box-shadow var(--transition-fast) ease}.vx-settings-tab{position:relative;width:100%;padding:10px 12px 10px 16px;border-radius:var(--radius);text-align:left;color:var(--text-secondary)}.vx-settings-tab span{display:block;font-size:13px;font-weight:500}.vx-settings-tab:before{content:"";position:absolute;left:4px;top:7px;bottom:7px;width:2px;border-radius:999px;background:transparent}.vx-settings-tab:hover,.vx-appearance-group-tab:hover,.vx-preset-card:hover,.vx-button:hover,.vx-control-card:hover{background:var(--settings-hover)}.vx-settings-tab.is-active{background:var(--settings-active);color:var(--text-primary)}.vx-settings-tab.is-active:before{background:var(--accent);box-shadow:0 0 10px color-mix(in srgb,var(--accent) 48%,transparent)}.vx-settings-content{min-width:0}.vx-settings-panel{display:grid;gap:12px;padding:calc(var(--content-gap) * .6)}.vx-settings-panel__header,.vx-appearance-controls__header,.vx-overview-card__header{display:flex;justify-content:space-between;gap:10px;align-items:center}.vx-settings-panel__actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.vx-button{padding:8px 12px;border-radius:var(--radius);font-size:12px;line-height:1}.vx-button--ghost{background:color-mix(in srgb,var(--panel-muted) 78%,transparent);border-color:var(--border);color:var(--text-primary)}.vx-button--danger{background:color-mix(in srgb,var(--danger) 90%,transparent);border-color:transparent;color:var(--visionx-white)}.vx-hidden-input{display:none}.vx-appearance-overview{display:grid;grid-template-columns:214px minmax(0,1fr);gap:10px;align-items:stretch}.vx-overview-card{display:grid;gap:10px;padding:calc(var(--content-gap) * .6)}.vx-overview-card--compact{min-height:94px}.vx-overview-card--preview{padding:10px}.vx-preset-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.vx-preset-card{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:8px 10px;border-radius:var(--radius);background:color-mix(in srgb,var(--panel-muted) 78%,transparent);color:var(--text-primary);font-size:12px;font-weight:600}.vx-preview-shell{display:grid;grid-template-columns:92px minmax(0,1fr);gap:10px;min-height:160px;padding:10px;border-radius:var(--card-radius);background:var(--bg-primary);box-shadow:var(--settings-preview-shadow)}.vx-preview-sidebar{display:grid;gap:8px;align-content:start;padding:10px;border-radius:var(--card-radius);background:var(--side)}.vx-preview-pill{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:.45rem .65rem;border-radius:var(--radius);background:var(--accent);color:var(--visionx-white);font-size:11px}.vx-preview-pill--muted{background:var(--glass);color:var(--text-secondary)}.vx-preview-stage{display:grid;gap:8px}.vx-preview-banner,.vx-preview-card{border:1px solid var(--border);border-radius:var(--card-radius);background:var(--card)}.vx-preview-banner{display:flex;align-items:center;gap:8px;padding:10px 12px;font-size:12px}.vx-preview-dot{width:8px;height:8px;border-radius:999px;background:var(--success)}.vx-preview-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.vx-preview-card{display:grid;gap:8px;padding:10px}.vx-preview-card span,.vx-preview-banner strong{color:var(--text-primary);font-size:12px}.vx-preview-card p{margin:0;color:var(--text-secondary);font-size:11px;line-height:1.35}.vx-preview-card button{width:fit-content;min-width:72px;padding:.55rem .8rem;border:none;border-radius:10px;background:var(--accent);color:var(--visionx-white);font-size:11px}.vx-settings-error{margin:0;padding:.75rem .9rem;border:1px solid color-mix(in srgb,var(--danger) 45%,var(--border));border-radius:12px;background:color-mix(in srgb,var(--danger) 10%,transparent);color:var(--danger);font-size:12px}.vx-appearance-layout{display:grid;grid-template-columns:172px minmax(0,1fr);gap:10px;align-items:start}.vx-appearance-groups,.vx-appearance-controls{display:grid;gap:10px;padding:calc(var(--content-gap) * .5)}.vx-appearance-groups{width:172px;min-width:172px;align-self:start}.vx-appearance-groups__list{grid-auto-rows:40px}.vx-appearance-group-tab{position:relative;width:100%;height:100%;min-height:40px;display:flex;align-items:center;padding:10px 10px 10px 16px;border-radius:var(--radius);text-align:left;color:var(--text-secondary);overflow:hidden}.vx-appearance-group-tab:before{content:"";position:absolute;left:4px;top:8px;bottom:8px;width:2px;border-radius:999px;background:transparent}.vx-appearance-group-tab strong{display:block;color:inherit;font-size:12px;font-weight:600;line-height:1.2}.vx-appearance-group-tab.is-active{background:var(--settings-active);color:var(--text-primary)}.vx-appearance-group-tab.is-locked{opacity:.42;cursor:not-allowed}.vx-appearance-group-tab.is-locked:hover{background:transparent}.vx-appearance-group-tab.is-active:before{background:var(--accent)}.vx-appearance-controls__header{padding-bottom:2px}.vx-control-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.vx-control-card{display:grid;gap:10px;padding:calc(var(--content-gap) * .5)}.vx-control-card__meta{display:flex;justify-content:space-between;gap:8px;align-items:center}.vx-control-card__values span,.vx-color-control span{color:var(--text-secondary);font-size:12px}.vx-control-card__values{justify-items:end}.vx-color-control{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in srgb,var(--panel-muted) 78%,transparent)}.vx-color-control input{width:50px;height:30px;border:none;border-radius:999px;background:transparent;cursor:pointer}.vx-range-control{display:grid;gap:6px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in srgb,var(--panel-muted) 78%,transparent)}.vx-range-control input{width:100%;accent-color:var(--accent)}.vx-range-control__footer{display:flex;justify-content:space-between;gap:8px;color:var(--muted);font-size:11px}.vx-range-control__footer strong{color:var(--text-primary)}.vx-settings-placeholder-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.vx-settings-placeholder-card{display:flex;align-items:center;min-height:72px;padding:calc(var(--content-gap) * .6)}.vx-settings-placeholder-card h3{font-size:13px;font-weight:600}@media(max-width:1100px){.vx-settings-page{grid-template-columns:170px minmax(0,1fr)}.vx-control-grid{grid-template-columns:1fr}}@media(max-width:900px){.vx-settings-page,.vx-appearance-overview,.vx-appearance-layout,.vx-preview-shell,.vx-preview-cards,.vx-settings-placeholder-grid{grid-template-columns:1fr}.vx-settings-sidebar{position:static}}@media(max-width:720px){.vx-settings-page{gap:10px}.vx-settings-sidebar,.vx-settings-panel,.vx-overview-card,.vx-appearance-groups,.vx-appearance-controls,.vx-settings-placeholder-card,.vx-control-card{padding:calc(var(--content-gap) * .5)}.vx-settings-panel__header,.vx-appearance-controls__header,.vx-overview-card__header,.vx-control-card__meta{flex-direction:column;align-items:flex-start}.vx-control-card__values{justify-items:start}}.vx-reports-page{display:grid;gap:18px;padding:24px;color:var(--text-primary)}.vx-reports-hero{position:relative;overflow:hidden;display:grid;grid-template-columns:minmax(0,1.4fr) minmax(280px,.9fr);gap:18px;padding:26px;border:1px solid var(--border);border-radius:22px;background:radial-gradient(circle at top right,color-mix(in srgb,var(--accent) 18%,transparent),transparent 28%),radial-gradient(circle at bottom left,color-mix(in srgb,var(--success) 14%,transparent),transparent 24%),linear-gradient(145deg,color-mix(in srgb,var(--card) 90%,white 10%),color-mix(in srgb,var(--bg-card) 96%,transparent));box-shadow:var(--shadow)}.vx-reports-hero:after{content:"";position:absolute;inset:auto -10% -45% auto;width:260px;height:260px;border-radius:50%;background:color-mix(in srgb,var(--accent) 14%,transparent);filter:blur(40px);pointer-events:none}.vx-reports-hero__copy{position:relative;z-index:1}.vx-reports-hero__eyebrow,.vx-reports-panel__eyebrow{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}.vx-reports-hero h1,.vx-reports-panel h3{margin:8px 0 10px}.vx-reports-hero h1{font-size:clamp(2rem,3vw,3rem);line-height:.98}.vx-reports-hero p{max-width:720px;margin:0;color:var(--text-secondary);line-height:1.6}.vx-reports-hero__stats,.vx-reports-kpi-grid{display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr))}.vx-reports-kpi{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:16px;border:1px solid var(--border);border-radius:18px;background:color-mix(in srgb,var(--card) 80%,transparent);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur))}.vx-reports-kpi--compact{align-items:center;padding:10px 12px;border-radius:14px}.vx-reports-kpi--blue .vx-reports-kpi__icon{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent)}.vx-reports-kpi--emerald .vx-reports-kpi__icon{background:color-mix(in srgb,var(--success) 15%,transparent);color:var(--success)}.vx-reports-kpi--amber .vx-reports-kpi__icon{background:color-mix(in srgb,var(--warning) 18%,transparent);color:var(--warning)}.vx-reports-kpi--rose .vx-reports-kpi__icon{background:color-mix(in srgb,var(--danger) 16%,transparent);color:var(--danger)}.vx-reports-kpi__label{display:block;margin-bottom:6px;font-size:12px;color:var(--text-secondary)}.vx-reports-kpi__value{display:block;font-size:clamp(1.1rem,2vw,1.8rem);line-height:1.1}.vx-reports-kpi--compact .vx-reports-kpi__label{margin-bottom:4px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.vx-reports-kpi--compact .vx-reports-kpi__value{font-size:1rem}.vx-reports-kpi__icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:14px}.vx-reports-kpi--compact .vx-reports-kpi__icon{width:34px;height:34px;border-radius:11px}.vx-reports-kpi__icon svg,.vx-reports-inline-icon,.vx-reports-callout svg,.vx-reports-empty__icon{width:20px;height:20px}.vx-reports-layout{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:18px;align-items:start}.vx-reports-catalog{position:sticky;top:0}.vx-reports-main,.vx-reports-domain-list{display:grid;gap:18px}.vx-reports-notice-anchor{display:flex;justify-content:flex-end;margin-top:-8px;margin-bottom:-6px}.vx-reports-notice{display:inline-flex;align-items:flex-start;gap:8px;justify-self:end}.vx-reports-notice__toggle{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--panel-muted) 74%,transparent);color:var(--text-primary);cursor:pointer;box-shadow:0 10px 24px #0f172a1a}.vx-reports-notice__toggle svg{width:14px;height:14px}.vx-reports-notice__panel{max-width:min(320px,calc(100vw - 72px));padding:8px 10px;border:1px solid var(--border);border-radius:12px;background:color-mix(in srgb,var(--card) 90%,transparent);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));box-shadow:0 12px 30px #0f172a1f}.vx-reports-notice__panel strong{display:block;margin-bottom:4px;font-size:11px}.vx-reports-notice__panel p{margin:0;font-size:12px;line-height:1.4;color:var(--text-secondary)}.vx-reports-notice--info .vx-reports-notice__toggle{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 22%,var(--border))}.vx-reports-notice--error .vx-reports-notice__toggle{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 22%,var(--border))}.vx-reports-notice--error .vx-reports-notice__panel{border-color:color-mix(in srgb,var(--danger) 20%,var(--border))}.vx-reports-panel{border:1px solid var(--border);border-radius:20px;background:linear-gradient(180deg,color-mix(in srgb,var(--card) 90%,transparent),color-mix(in srgb,var(--bg-card) 98%,transparent));box-shadow:var(--shadow);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));padding:20px}.vx-reports-panel__header,.vx-reports-panel__title-row,.vx-reports-domain-card__head,.vx-reports-response-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.vx-reports-panel__title-row{justify-content:flex-start;align-items:center}.vx-reports-inline-icon{flex:0 0 auto;color:var(--accent)}.vx-reports-panel h3{font-size:1.15rem;color:var(--text-primary)}.vx-reports-domain-card{display:grid;gap:14px;padding:16px;border:1px solid var(--border);border-radius:18px;background:color-mix(in srgb,var(--panel-muted) 66%,transparent);transition:transform var(--transition-fast) ease,border-color var(--transition-fast) ease,background-color var(--transition-fast) ease}.vx-reports-domain-card:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 22%,var(--border));background:var(--panel-hover)}.vx-reports-domain-card__head strong{display:block;margin-bottom:4px}.vx-reports-domain-card__head span,.vx-reports-domain-card__section>span,.vx-reports-response-prompt>span{color:var(--text-secondary);font-size:12px}.vx-reports-domain-card__section{display:grid;gap:8px}.vx-reports-chip-group,.vx-reports-samples,.vx-reports-detail-grid,.vx-reports-controls{display:flex;flex-wrap:wrap;gap:8px}.vx-reports-chip,.vx-reports-sample{display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:10px;padding:5px 8px;font-size:11px;font-weight:600;line-height:1}.vx-reports-chip{background:color-mix(in srgb,var(--accent) 10%,transparent);color:var(--text-primary)}.vx-reports-chip--ghost,.vx-reports-sample{background:color-mix(in srgb,var(--panel-muted) 70%,transparent);border-color:var(--border);color:var(--text-primary);cursor:pointer;transition:transform var(--transition-fast) ease,border-color var(--transition-fast) ease,background-color var(--transition-fast) ease}.vx-reports-chip--ghost:hover,.vx-reports-sample:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--accent) 24%,var(--border));background:color-mix(in srgb,var(--accent) 10%,var(--panel-hover))}.vx-reports-chip--muted{background:color-mix(in srgb,var(--panel-muted) 60%,transparent);border:1px solid var(--border);color:var(--text-secondary)}.vx-reports-expand-btn,.vx-reports-icon-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--panel-muted) 72%,transparent);color:var(--text-primary);cursor:pointer;transition:transform var(--transition-fast) ease,border-color var(--transition-fast) ease,background-color var(--transition-fast) ease}.vx-reports-expand-btn{padding:7px 12px;font-size:12px;font-weight:700}.vx-reports-icon-btn{width:40px;height:40px;border-radius:14px}.vx-reports-expand-btn:hover,.vx-reports-icon-btn:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--accent) 24%,var(--border));background:color-mix(in srgb,var(--accent) 10%,var(--panel-hover))}.vx-reports-expand-btn svg,.vx-reports-icon-btn svg{width:16px;height:16px}.vx-reports-chip.is-success{background:color-mix(in srgb,var(--success) 18%,transparent);color:var(--success)}.vx-reports-chip.is-warning{background:color-mix(in srgb,var(--warning) 18%,transparent);color:var(--warning)}.vx-reports-composer,.vx-reports-empty{display:grid;gap:18px}.vx-reports-field{display:grid;gap:8px;flex:1 1 180px}.vx-reports-field>span{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.vx-reports-field textarea,.vx-reports-field select,.vx-reports-field input{width:100%;margin:0;border:1px solid var(--border);border-radius:14px;padding:12px 14px;background:color-mix(in srgb,var(--panel-muted) 70%,transparent);color:var(--text-primary);resize:vertical}.vx-reports-field textarea:focus,.vx-reports-field select:focus,.vx-reports-field input:focus{outline:none;border-color:color-mix(in srgb,var(--accent) 55%,var(--border));box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 15%,transparent)}.vx-reports-toggle{display:inline-flex;align-items:center;gap:10px;padding:0 4px;color:var(--text-primary);min-height:44px}.vx-reports-toggle input{width:16px;height:16px;margin:0}.vx-reports-primary-btn{border:none;border-radius:14px;padding:11px 16px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:700;cursor:pointer;transition:transform var(--transition-fast) ease,opacity var(--transition-fast) ease,box-shadow var(--transition-fast) ease;box-shadow:0 16px 28px color-mix(in srgb,var(--accent) 28%,transparent)}.vx-reports-primary-btn:hover:not(:disabled){transform:translateY(-1px)}.vx-reports-primary-btn:disabled{opacity:.6;cursor:not-allowed}.vx-reports-callout{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:16px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel-muted) 74%,transparent)}.vx-reports-callout--error{border-color:color-mix(in srgb,var(--danger) 26%,var(--border));background:color-mix(in srgb,var(--danger) 10%,transparent);color:var(--text-primary)}.vx-reports-callout p,.vx-reports-empty p{margin:0;color:var(--text-secondary)}.vx-reports-empty{place-items:center;text-align:center;min-height:220px}.vx-reports-empty__icon{width:38px;height:38px;color:var(--accent)}.vx-reports-response-prompt{display:grid;gap:8px}.vx-reports-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.vx-reports-detail-card{display:grid;gap:8px;padding:14px;border:1px solid var(--border);border-radius:16px;background:color-mix(in srgb,var(--panel-muted) 62%,transparent)}.vx-reports-detail-card span{font-size:12px;color:var(--text-secondary)}.vx-reports-detail-card strong{color:var(--text-primary);line-height:1.4}.vx-reports-detail-card--tag{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;background:color-mix(in srgb,var(--panel-muted) 54%,transparent)}.vx-reports-detail-card--tag span,.vx-reports-detail-card--tag strong{margin:0;line-height:1.2}.vx-reports-detail-card--tag span{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.vx-reports-detail-card--tag strong{font-size:11px;font-weight:600;white-space:nowrap}.vx-reports-image-link{display:inline-flex;align-items:center;justify-content:flex-start;max-width:100%}.vx-reports-image-preview{display:block;width:min(140px,100%);max-width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel-muted) 70%,transparent);box-shadow:0 10px 24px #0f172a14}.vx-reports-table td .vx-reports-image-link{justify-content:center}.vx-reports-table td .vx-reports-image-preview{width:52px;min-width:52px;aspect-ratio:1;border-radius:10px}.vx-reports-table-wrap{overflow:auto}.vx-reports-table{width:100%;border-collapse:separate;border-spacing:0;min-width:640px}.vx-reports-table thead th{position:sticky;top:0;padding:12px 14px;text-align:left;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);background:color-mix(in srgb,var(--panel-muted) 82%,transparent)}.vx-reports-table tbody td{padding:14px;border-top:1px solid var(--border);color:var(--text-primary)}.vx-reports-table tbody tr:hover{background:color-mix(in srgb,var(--accent) 4%,transparent)}.vx-reports-table-note{margin:12px 0 0;font-size:12px;color:var(--text-secondary)}.vx-reports-json{margin:0;padding:16px;border-radius:16px;overflow:auto;background:color-mix(in srgb,var(--bg-primary) 82%,transparent);color:var(--text-primary);font-size:12px;line-height:1.6}.vx-reports-fullscreen{position:fixed;inset:0;z-index:3000;display:flex;align-items:stretch;justify-content:stretch;padding:20px;background:color-mix(in srgb,var(--bg-primary) 60%,rgba(2,6,23,.76));backdrop-filter:blur(16px) saturate(135%);-webkit-backdrop-filter:blur(16px) saturate(135%)}.vx-reports-fullscreen__shell{display:grid;gap:16px;width:100%;height:100%;padding:20px;border:1px solid var(--border);border-radius:22px;background:linear-gradient(180deg,color-mix(in srgb,var(--card) 88%,transparent),color-mix(in srgb,var(--bg-card) 98%,transparent));box-shadow:var(--shadow);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur))}.vx-reports-fullscreen__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.vx-reports-fullscreen__body{min-height:0;flex:1 1 auto;border:1px solid var(--border);border-radius:18px;background:color-mix(in srgb,var(--bg-primary) 28%,transparent);overflow:hidden}.vx-reports-table-wrap--fullscreen{width:100%;max-width:100%;min-height:min(68vh,720px);max-height:min(68vh,720px);overflow:auto}.vx-reports-table--fullscreen{min-width:max-content;width:max-content}.vx-reports-table--fullscreen th,.vx-reports-table--fullscreen td{white-space:nowrap}@media(max-width:1100px){.vx-reports-page{padding:18px}.vx-reports-hero,.vx-reports-layout{grid-template-columns:1fr}.vx-reports-catalog{position:static}}@media(max-width:720px){.vx-reports-page{padding:16px}.vx-reports-hero,.vx-reports-panel{padding:18px;border-radius:18px}.vx-reports-fullscreen{padding:12px}.vx-reports-hero__stats,.vx-reports-kpi-grid{grid-template-columns:1fr}.vx-reports-panel__header,.vx-reports-response-head,.vx-reports-controls{flex-direction:column}.vx-reports-fullscreen__shell{padding:16px;border-radius:18px}.vx-reports-fullscreen__header{flex-direction:row}.vx-reports-table{min-width:100%}.vx-reports-table-wrap--fullscreen{min-height:62vh;max-height:62vh}.vx-reports-table thead{display:none}.vx-reports-table,.vx-reports-table tbody,.vx-reports-table tr,.vx-reports-table td{display:block}.vx-reports-table tr{padding:10px 0;border-top:1px solid var(--border)}.vx-reports-table tbody td{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:10px 0;border-top:none}.vx-reports-table tbody td:before{content:attr(data-label);flex:0 0 42%;color:var(--text-secondary);font-size:12px;font-weight:700}.vx-reports-table-wrap--fullscreen .vx-reports-table thead{display:table-header-group}.vx-reports-table-wrap--fullscreen .vx-reports-table,.vx-reports-table-wrap--fullscreen .vx-reports-table tbody,.vx-reports-table-wrap--fullscreen .vx-reports-table tr{display:table;width:max-content}.vx-reports-table-wrap--fullscreen .vx-reports-table tbody{display:table-row-group}.vx-reports-table-wrap--fullscreen .vx-reports-table tr{display:table-row}.vx-reports-table-wrap--fullscreen .vx-reports-table td,.vx-reports-table-wrap--fullscreen .vx-reports-table th{display:table-cell}.vx-reports-table-wrap--fullscreen .vx-reports-table tbody td:before{content:none}}.face-analytics-page{align-items:stretch}.face-analytics-filter-card{display:grid;gap:14px}.face-analytics-filter-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.face-analytics-filter-header-main{display:grid;gap:10px;min-width:0}.face-analytics-filter-actions{display:flex;gap:10px;flex-wrap:wrap}.face-analytics-filter-mobile-toggle{display:none;align-items:center;justify-content:center;width:fit-content;height:36px;border-radius:999px;border:1px solid var(--border-color);background:var(--panel-subtle-bg);color:var(--text-primary);padding:0 14px;font:inherit;font-size:12px;font-weight:600;cursor:pointer}.face-analytics-filter-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.face-analytics-filter-grid-wrap{display:block}.face-analytics-mobile-chip-row{display:none}.face-analytics-filter-field{display:flex;flex-direction:column;gap:6px}.face-analytics-filter-field label{font-size:12px;font-weight:600;color:var(--text-secondary)}.face-analytics-filter-field input,.face-analytics-filter-field select{width:100%;height:38px;border-radius:8px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);padding:0 12px;font:inherit;transition:border-color .18s ease,box-shadow .18s ease}.face-analytics-filter-field select{padding-right:34px;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.face-analytics-filter-field input:focus,.face-analytics-filter-field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1f78ff1f}.face-analytics-filter-field input:disabled,.face-analytics-filter-field select:disabled{cursor:not-allowed;opacity:.65}.face-analytics-filter-date-range{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.face-analytics-filter-button{height:38px;border-radius:8px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);padding:0 16px;font:inherit;font-weight:600;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background-color .18s ease,color .18s ease}.face-analytics-filter-button:hover{transform:translateY(-1px);border-color:var(--accent)}.face-analytics-filter-button.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent;color:#fff}.face-analytics-filter-meta{font-size:12px;color:var(--text-secondary)}.face-analytics-grid{display:grid;gap:20px}.face-analytics-grid--summary{grid-template-columns:repeat(4,minmax(0,1fr))}.face-analytics-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.face-analytics-kpi-card{display:grid;gap:10px}.face-analytics-kpi-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.face-analytics-kpi-value{font-size:32px;line-height:1;font-weight:700;color:var(--text-primary)}.face-analytics-kpi-hint{font-size:12px;color:var(--text-secondary)}.face-analytics-widget-state{min-height:220px;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--text-secondary);font-size:13px;padding:18px}.face-analytics-widget-state.error{color:var(--danger)}.face-analytics-list{display:grid;gap:10px}.face-analytics-list-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:10px;background:var(--panel-subtle-bg);border:1px solid var(--border-color)}.face-analytics-list-main{display:flex;align-items:center;gap:12px;min-width:0}.face-analytics-list-title{display:flex;flex-direction:column;gap:4px;min-width:0}.face-analytics-list-title strong,.face-analytics-location-name{font-size:14px;color:var(--text-primary)}.face-analytics-list-title span,.face-analytics-location-meta,.face-analytics-feed-meta{font-size:12px;color:var(--text-secondary)}.face-analytics-list-count{min-width:48px;text-align:right;font-size:20px;font-weight:700;color:var(--text-primary)}.face-analytics-thumb{flex-shrink:0;overflow:hidden;border-radius:12px;border:1px solid var(--border-color);background:linear-gradient(135deg,#1f78ff24,#0d5de714);display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-size:12px;font-weight:700}.face-analytics-thumb--md{width:46px;height:46px}.face-analytics-thumb img{width:100%;height:100%;object-fit:cover;display:block}.face-analytics-feed{display:grid;gap:10px;max-height:320px;overflow:auto;padding-right:4px}.face-analytics-feed-item{display:grid;grid-template-columns:auto 1fr;gap:12px;padding:12px 14px;border-radius:10px;background:var(--panel-subtle-bg);border:1px solid var(--border-color)}.face-analytics-feed-visuals{display:grid;gap:8px;align-content:start}.face-analytics-feed-content{display:grid;gap:4px}.face-analytics-location-shell{display:grid;gap:12px}.face-analytics-location-topbar{display:flex;justify-content:flex-end}.face-analytics-location-view-toggle{display:inline-flex;align-items:center;gap:4px;border-radius:999px;border:1px solid var(--border-color);background:var(--panel-subtle-bg);padding:3px}.face-analytics-location-view-btn{min-height:30px;border-radius:999px;border:0;background:transparent;color:var(--text-secondary);font:inherit;font-size:12px;font-weight:600;padding:0 12px;cursor:pointer}.face-analytics-location-view-btn.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff}.face-analytics-location-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px}.face-analytics-location-breadcrumb{display:flex;align-items:center;gap:8px;min-width:0;color:var(--text-secondary);font-size:12px}.face-analytics-location-crumb{max-width:220px;border:0;background:transparent;color:inherit;font:inherit;cursor:pointer;padding:0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.face-analytics-location-crumb.active{color:var(--text-primary);font-weight:600}.face-analytics-location-back{height:32px;border-radius:999px;border:1px solid var(--border-color);background:var(--panel-subtle-bg);color:var(--text-primary);font:inherit;font-size:12px;font-weight:600;padding:0 12px;cursor:pointer}.face-analytics-location-back:disabled{opacity:.45;cursor:not-allowed}.face-analytics-location-legend{display:grid;gap:6px}.face-analytics-location-legend span{font-size:12px;color:var(--text-secondary)}.face-analytics-location-legend-scale{width:100%;height:8px;border-radius:999px;background:linear-gradient(90deg,#258d56,#c51616)}.face-analytics-location-legend-labels{display:flex;justify-content:space-between;gap:8px}.face-analytics-location-legend-labels span{font-size:11px}.face-analytics-location-treemap{height:320px;border-radius:12px;border:1px solid var(--border-color);background:color-mix(in srgb,var(--panel-subtle-bg) 72%,transparent);padding:6px}.face-analytics-location-raw-shell{display:grid;gap:8px}.face-analytics-location-raw-title{font-size:12px;font-weight:600;color:var(--text-secondary)}.face-analytics-location-raw-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.face-analytics-location-raw-column{min-height:320px;display:grid;grid-template-rows:auto 1fr;gap:6px}.face-analytics-location-raw-column h5{margin:0;font-size:12px;color:var(--text-primary)}.face-analytics-location-raw-list{max-height:290px;overflow:auto;padding-right:3px;display:grid;gap:6px}.face-analytics-location-raw-item{display:grid;gap:4px;border-radius:8px;border:1px solid var(--border-color);background:var(--panel-subtle-bg);padding:8px}.face-analytics-location-raw-topline{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.face-analytics-location-raw-topline strong{font-size:12px;color:var(--text-primary)}.face-analytics-location-raw-topline span{font-size:13px;font-weight:700;color:var(--text-primary)}.face-analytics-location-raw-meta{display:grid;gap:2px}.face-analytics-location-raw-meta span,.face-analytics-location-raw-split span{font-size:10px;color:var(--text-secondary)}.face-analytics-location-raw-split{display:flex;gap:8px;flex-wrap:wrap}.face-analytics-location-tooltip{display:grid;gap:3px;min-width:160px;border-radius:8px;border:1px solid var(--border-color);background:var(--chart-tooltip-bg);color:var(--text-primary);padding:9px 10px;box-shadow:0 8px 20px #00000024}.face-analytics-location-tooltip strong{font-size:13px;line-height:1.3}.face-analytics-location-tooltip span{font-size:11px;color:var(--text-secondary)}.face-analytics-recent-title{display:flex;align-items:center;gap:8px}@media(max-width:1400px){.face-analytics-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:1200px){.face-analytics-grid--summary,.face-analytics-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.face-analytics-page{gap:12px}.face-analytics-filter-card{position:sticky;top:8px;z-index:12;padding:14px;gap:12px;border-radius:14px;background:color-mix(in srgb,var(--bg-card) 92%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.face-analytics-filter-header{align-items:stretch;gap:10px}.face-analytics-filter-header-main{gap:6px}.face-analytics-filter-header-main .section-header-wrap{margin-bottom:0}.face-analytics-filter-header-main .section-subtitle{display:none}.face-analytics-filter-mobile-toggle{display:inline-flex;height:34px}.face-analytics-mobile-chip-row{display:flex;align-items:center;gap:8px;margin:2px -2px 0;padding:2px;overflow-x:auto;scrollbar-width:none}.face-analytics-mobile-chip-row::-webkit-scrollbar{display:none}.face-analytics-mobile-chip{flex-shrink:0;max-width:95%;border-radius:999px;border:1px solid var(--border-color);background:var(--panel-subtle-bg);color:var(--text-secondary);font-size:11px;line-height:1.2;padding:6px 10px;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.face-analytics-filter-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%}.face-analytics-filter-button{width:100%;min-height:44px}.face-analytics-filter-field input,.face-analytics-filter-field select{min-height:42px}.face-analytics-filter-grid-wrap{display:none}.face-analytics-filter-grid-wrap.is-open{display:block}.face-analytics-filter-grid,.face-analytics-filter-date-range,.face-analytics-grid--summary,.face-analytics-grid--two{grid-template-columns:1fr}.face-analytics-grid--summary{display:flex;overflow-x:auto;gap:10px;padding-bottom:2px;scrollbar-width:none;scroll-snap-type:x mandatory}.face-analytics-grid--summary::-webkit-scrollbar{display:none}.face-analytics-grid--summary .face-analytics-kpi-card{min-width:min(260px,82vw);scroll-snap-align:start}.face-analytics-kpi-value{font-size:34px}.face-analytics-page .chart-container,.face-analytics-page .chart-container-lg{height:250px}.face-analytics-page .chart-container :where(.recharts-wrapper,.recharts-surface){overflow:visible}.face-analytics-feed{max-height:none;padding-right:0}.face-analytics-list-item,.face-analytics-feed-item{align-items:flex-start;border-radius:12px;padding:12px}.face-analytics-list-item{flex-direction:column;gap:10px}.face-analytics-list-main{width:100%}.face-analytics-list-count{width:100%;text-align:left;font-size:18px}.face-analytics-feed-item{display:grid;grid-template-columns:1fr;gap:10px}.face-analytics-feed-visuals{grid-template-columns:auto 1fr;gap:10px;align-items:center}.face-analytics-feed-content{gap:6px}.face-analytics-location-toolbar{flex-direction:column;align-items:flex-start}.face-analytics-location-topbar{justify-content:stretch}.face-analytics-location-view-toggle{width:100%}.face-analytics-location-view-btn{flex:1;text-align:center;min-height:34px}.face-analytics-location-back{min-height:36px}.face-analytics-location-breadcrumb{width:100%;overflow-x:auto;scrollbar-width:none}.face-analytics-location-breadcrumb::-webkit-scrollbar{display:none}.face-analytics-location-crumb{max-width:none}.face-analytics-location-treemap{height:260px;padding:4px}.face-analytics-location-raw-grid{grid-template-columns:1fr}.face-analytics-location-raw-column{min-height:auto}.face-analytics-location-raw-list{max-height:220px}.face-analytics-filter-meta{font-size:11px}}.primary.action-button{background:var(--visionx-blue);color:var(--visionx-white);border:none;border-radius:8px;padding:10px 18px;width:100%;height:48px;display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-top:2.5rem;font-weight:500;cursor:pointer;transition:background .2s ease,box-shadow .2s ease;font-size:16px}.primary.action-button:hover:not(:disabled){background:var(--visionx-blue-hover);box-shadow:0 4px 12px #4da3ff59}.primary.action-button:disabled{background:var(--visionx-blue-disabled);cursor:not-allowed;box-shadow:none}.primary.action-button .spin{color:var(--visionx-white)}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.secret-field{position:relative}.secret-field input{padding-right:72px}.secret-actions{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:flex;gap:10px}.secret-actions button{background:transparent;border:none;padding:10px;cursor:pointer;color:var(--text-muted, #777);display:flex;align-items:center}.secret-actions button:hover{color:var(--text-primary, #000)}.secret-actions button{background:transparent;border:none;padding:0;cursor:pointer;color:var(--visionx-blue);display:flex;align-items:center;transition:color .15s ease,transform .15s ease}.secret-actions button:hover{color:var(--visionx-blue-hover);transform:scale(1.05)}.panel-field.secret-field{position:relative}.panel-field.secret-field input{width:100%;text-align:left}.panel-field.secret-field .secret-actions{position:absolute;top:50%;right:12px;left:auto!important;transform:translate(90%,-90%);display:flex;align-items:center;gap:10px;z-index:3}.panel-field.secret-field .secret-actions button{background:none;border:none;padding:0;margin:0;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--visionx-blue)}.panel-field.secret-field .secret-actions button:hover{color:var(--visionx-blue-hover)}:root{color-scheme:light;--bg-primary: #edf2fa;--border-color: rgba(188, 201, 224, .82);--text-primary: #1a2a44;--text-secondary: #5f6f8a;--accent: #1f78ff;--accent-2: #0d5de7;--success: #1f9a67;--warning: #b5851d;--danger: #d64545;--bg: #edf2fa;--card: rgba(255, 255, 255, .95);--side: #ffffff;--muted: #5f6f8a;--muted-2: #8396b4;--glass: rgba(255, 255, 255, .9);--radius: 10px;--page-bg: #eef2f7;--page-bg-secondary: #f8fbff;--dashboard-bg: #edf2fa;--dashboard-bg-secondary: #f7faff;--bg-card: rgba(255, 255, 255, .7);--text: #0b1220;--text-soft: #475569;--border: rgba(255, 255, 255, .12);--primary: #5b8cff;--glass-blur: 10px;--shadow: 0 8px 30px rgba(3, 12, 28, .18);--chart-grid: rgba(188, 201, 224, .32);--chart-tooltip-bg: rgba(255, 255, 255, .96);--chart-series-1: #1f78ff;--chart-series-2: #0d5de7;--chart-series-3: #1f9a67;--chart-series-4: #b5851d;--chart-series-5: #d64545;--panel-subtle-bg: rgba(247, 250, 255, .72);--panel-muted: rgba(255, 255, 255, .56);--panel-hover: rgba(255, 255, 255, .82);--scrollbar-size: 3px;--scrollbar-track: rgba(188, 201, 224, .02);--scrollbar-thumb: rgba(95, 111, 138, .26);--scrollbar-thumb-hover: rgba(95, 111, 138, .42);--scrollbar-thumb-active: rgba(31, 120, 255, .58);--vx-bg-main: #edf2fa;--vx-bg-panel: rgba(255, 255, 255, .9);--vx-bg-soft: rgba(247, 250, 255, .96);--vx-border: rgba(188, 201, 224, .82);--vx-text-primary: #1a2a44;--vx-text-secondary: #5f6f8a;--vx-accent: #1f78ff;--vx-accent-strong: #0d5de7;--vx-danger: #d64545;--vx-success: #1f9a67;--vx-warning: #b5851d;--visionx-blue: #4da3ff;--visionx-blue-hover: #2f8cff;--visionx-blue-disabled: #9cc9ff;--visionx-white: #ffffff;--side-bg: #ffffff;--card-bg: #ffffff;--side-width: 260px;--side-mini: 64px;--topbar-height: 64px;--content-gap: 20px;--card-radius: 12px;--transition-fast: .18s;--transition-mid: .26s;--settings-page-bg: rgba(255, 255, 255, .22);--settings-shell: rgba(255, 255, 255, .58);--settings-panel: rgba(255, 255, 255, .78);--settings-panel-strong: rgba(255, 255, 255, .96);--settings-hover: rgba(255, 255, 255, .72);--settings-active: rgba(31, 120, 255, .12);--settings-shadow: 0 18px 34px rgba(15, 23, 42, .08);--settings-preview-shadow: 0 20px 36px rgba(15, 23, 42, .14)}.dark{color-scheme:dark;--bg-primary: #0f172a;--border-color: rgba(71, 85, 105, .58);--text-primary: #e2e8f0;--text-secondary: #94a3b8;--accent: #60a5fa;--accent-2: #3b82f6;--success: #34d399;--warning: #fbbf24;--danger: #f87171;--bg: #111827;--card: rgba(15, 23, 42, .92);--side: #0f172a;--muted: #94a3b8;--muted-2: #64748b;--glass: rgba(15, 23, 42, .86);--page-bg: #0b1120;--page-bg-secondary: #111c31;--dashboard-bg: #0b1120;--dashboard-bg-secondary: #12203b;--bg-card: rgba(15, 23, 42, .78);--text: #e5e7eb;--text-soft: #94a3b8;--border: rgba(148, 163, 184, .18);--primary: #60a5fa;--shadow: 0 18px 40px rgba(2, 6, 23, .45);--chart-grid: rgba(71, 85, 105, .26);--chart-tooltip-bg: rgba(15, 23, 42, .96);--chart-series-1: #60a5fa;--chart-series-2: #3b82f6;--chart-series-3: #34d399;--chart-series-4: #fbbf24;--chart-series-5: #f87171;--panel-subtle-bg: rgba(15, 23, 42, .72);--panel-muted: rgba(15, 23, 42, .52);--panel-hover: rgba(30, 41, 59, .84);--scrollbar-track: rgba(71, 85, 105, .04);--scrollbar-thumb: rgba(148, 163, 184, .24);--scrollbar-thumb-hover: rgba(148, 163, 184, .38);--scrollbar-thumb-active: rgba(96, 165, 250, .54);--vx-bg-main: #0b1120;--vx-bg-panel: rgba(15, 23, 42, .92);--vx-bg-soft: rgba(15, 23, 42, .74);--vx-border: rgba(71, 85, 105, .62);--vx-text-primary: #e2e8f0;--vx-text-secondary: #94a3b8;--vx-accent: #60a5fa;--vx-accent-strong: #3b82f6;--vx-danger: #f87171;--vx-success: #34d399;--vx-warning: #fbbf24;--visionx-blue: #60a5fa;--visionx-blue-hover: #3b82f6;--visionx-blue-disabled: #1d4ed8;--visionx-white: #e2e8f0;--side-bg: #0f172a;--card-bg: #111827;--settings-page-bg: rgba(2, 6, 23, .3);--settings-shell: rgba(2, 6, 23, .42);--settings-panel: rgba(15, 23, 42, .78);--settings-panel-strong: rgba(15, 23, 42, .94);--settings-hover: rgba(30, 41, 59, .84);--settings-active: rgba(96, 165, 250, .18);--settings-shadow: 0 22px 36px rgba(2, 6, 23, .28);--settings-preview-shadow: 0 22px 42px rgba(2, 6, 23, .42)}.glass{backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border:1px solid rgba(255,255,255,.25);box-shadow:inset 0 1px #ffffff59,0 8px 32px #0000001f}body.vx-mobile-menu-open{overflow:hidden}.mobile-selected-person-details{display:none}@media(max-width:1024px){.zone-header,.camera-header,.section-header-wrap,.attendance-header,.lm-page-header,.vx-reports-panel__header,.vx-reports-response-head,.vx-settings-panel__header,.vx-appearance-controls__header,.vx-overview-card__header,.selected-name-row,.presence-section__header{flex-wrap:wrap}.vx-content{overflow-x:hidden}}@media(max-width:768px){.vx-content>*,.vx-content section,.vx-content article,.vx-content div,.attendance-shell,.vx-reports-main,.vx-settings-content,.dashboard-card,.card,.vx-reports-panel,.lm-grid-area,.lm-sidebar,.summary-card{min-width:0}.table-wrapper,.vx-reports-table-wrap,.records-table{max-width:100%;-webkit-overflow-scrolling:touch}.vx-side.mobile{width:min(82vw,300px)!important;min-width:min(82vw,300px)!important;max-width:min(82vw,300px);transform:translate(-100%);box-shadow:0 18px 40px #0f172a2e}.vx-side.mobile.open{transform:translate(0)!important}.vx-side-brand{display:flex;align-items:center;justify-content:space-between;gap:12px}.vx-side-close{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-color, var(--border));border-radius:10px;background:transparent;color:var(--text-primary, var(--text));flex-shrink:0}.vx-side-close .vx-icon{width:18px;height:18px}.vx-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.vx-app,.vx-main{width:100%;max-width:100%}.vx-content{padding:12px!important}.vx-top-left,.vx-top-right{width:auto;min-width:0}.vx-top-left{flex:1 1 auto;gap:10px}.vx-top-right{flex:0 0 auto;justify-content:flex-end}.vx-search{flex:1 1 0;min-width:0}.vx-search input{width:100%!important;min-width:0;max-width:100%}.vx-profile-trigger{max-width:100%}.vx-profile-dropdown{right:0;width:min(280px,calc(100vw - 24px));max-width:calc(100vw - 24px)}.section-header-wrap,.camera-header,.zone-header,.people-search-row,.vx-settings-panel__actions,.vx-reports-controls,.vx-reports-chip-group{flex-direction:column;align-items:stretch}.table-search-container,.table-search-container.table-search-inline,.zone-header .table-search-container.table-search-inline,.camera-header .table-search-container.table-search-inline{width:100%!important;justify-content:stretch!important;margin-left:0!important}.zone-search-input{width:100%!important;min-width:0!important;max-width:100%!important}.add-camera-btn,.add-zone-btn,.bulk-upload-btn,.vx-button,.vx-reports-primary-btn{width:100%;justify-content:center}.edit-page,.edit-page-wrapper,.edit-page-container,.vx-modal{width:100%!important;max-width:100%!important}.edit-page,.edit-page-container{padding:16px}.edit-form .row,.flip-controls{flex-direction:column;align-items:stretch}.data-table,.table-row{min-width:640px}.table-wrapper,.records-table{overflow-x:auto;overflow-y:visible}.attendance-page,.lm-page,.vx-reports-page{padding:14px}.attendance-meta,.selected-inline-captures,.persons-breadcrumb-pagination,.persons-pagination{flex-wrap:wrap}.attendance-detail-grid,.vx-settings-page,.vx-appearance-overview,.vx-appearance-layout,.vx-preview-shell,.vx-preview-cards,.vx-settings-placeholder-grid,.vx-reports-hero,.vx-reports-layout,.vx-reports-hero__stats,.vx-reports-kpi-grid,.lm-page-layout,.lm-grid-wide,.vx-control-grid,.selected-capture-grid,.selected-info-grid,.lm-modal-telemetry{grid-template-columns:1fr!important}.vx-settings-sidebar,.vx-reports-catalog{position:static;top:auto}.vx-appearance-groups{width:100%;min-width:0}.desktop-selected-person-details{display:none}.mobile-selected-person-details{display:block;grid-column:1 / -1;margin-top:10px;padding-top:12px;border-top:1px solid var(--border-color, rgba(15, 23, 42, .08))}.selected-person-details-inline{display:grid;gap:12px}.selected-person-details-inline .selected-person{position:relative;gap:12px;padding-right:108px}.selected-person-details-inline .selected-avatar{width:44px;height:44px}.selected-person-details-inline .selected-name{font-size:20px}.selected-person-details-inline .selected-name-row{align-items:flex-start}.selected-person-details-inline .selected-person-copy,.selected-person-details-inline .selected-time-capture-list,.selected-person-details-inline .selected-time-capture-row{width:100%}.selected-person-details-inline .selected-time-value{margin-right:auto}.selected-person-details-inline .selected-time-capture-img{margin-left:auto!important}.selected-person-details-inline .selected-inline-captures{position:absolute;top:0;right:0;gap:6px;flex-wrap:nowrap}.selected-person-details-inline .selected-inline-capture img{width:42px;height:42px;border-radius:8px}.selected-person-details-inline .selected-inline-capture figcaption{font-size:8px}.selected-person-details-inline .selected-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px}.selected-person-details-inline .info-chip{padding:10px 12px}.records-table .table-row.header{display:none}.records-table .table-row.clickable{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 12px;min-width:0;padding:14px;align-items:start}.records-table .table-row.clickable>span{min-width:0;display:flex;flex-direction:row;align-items:flex-start;gap:8px;font-size:14px}.records-table .record-status-cell{display:none!important}.records-table .record-time-cell--entry,.records-table .record-time-cell--exit{grid-column:1 / -1;display:grid!important;grid-template-columns:56px minmax(0,1fr) auto;align-items:center;column-gap:10px;width:100%}.records-table .record-time-cell--entry:before,.records-table .record-time-cell--exit:before{position:static;font-size:12px;font-weight:700;color:var(--text-secondary, #64748b);line-height:1;align-self:center}.records-table .record-time-cell--entry:before{content:"Entry"!important}.records-table .record-time-cell--exit:before{content:"Exit"!important}.records-table .record-time-value{font-weight:700}.records-table .mobile-camera-label{display:block;font-size:12px;color:var(--text-secondary, #64748b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.records-table .desktop-camera-cell{display:none!important}.records-table .record-time-avatar{display:block;width:48px;height:48px;border-radius:10px;margin-left:auto;justify-self:end}.records-table .record-seen-cell{grid-column:1;grid-row:3;justify-self:start;display:flex!important;align-items:center;gap:6px;font-weight:600}.records-table .record-seen-cell:before{content:"Seen"!important;font-size:12px;font-weight:700;color:var(--text-secondary, #64748b)}.records-table .record-duration-cell{grid-column:2;grid-row:3;justify-self:end;text-align:right;display:flex!important;align-items:center;justify-content:flex-end;gap:6px;font-weight:600}.records-table .record-duration-cell:before{content:"Duration"!important;font-size:12px;font-weight:700;color:var(--text-secondary, #64748b)}.records-table .camera-cell{align-items:flex-start;min-height:0;text-align:left}.records-table .camera-label,.records-table .record-capture-inline figcaption,.records-table .camera-placeholder{font-size:11px}.records-table .record-capture-inline{width:auto}.records-table .record-capture-inline img{width:74px;height:92px}.records-table .table-row.placeholder{min-width:0;grid-template-columns:1fr}}@media(max-width:480px){.vx-topbar{align-items:center}.vx-top-left{width:100%}.vx-top-right{width:auto;margin-left:auto;gap:8px}.vx-profile-meta,.vx-profile-caret{display:none}.vx-profile-trigger{padding-right:6px}.vx-side.mobile{width:min(86vw,280px)!important;min-width:min(86vw,280px)!important}.records-table .table-row.clickable{grid-template-columns:repeat(2,minmax(0,1fr))}.selected-person-details-inline .selected-person{flex-direction:column;padding-right:0}.selected-person-details-inline .selected-inline-captures{position:static;align-self:flex-start}.selected-person-details-inline .selected-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px}.selected-person-details-inline .info-chip{padding:8px 10px}.selected-person-details-inline .info-chip strong{font-size:14px}}
