@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Noto+Sans+Tamil:wght@300;400;500;600;700&family=Noto+Sans+Bengali:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";
:root{--color-primary-50:#eef2ff;--color-primary-100:#dce4ff;--color-primary-200:#b9c9ff;--color-primary-300:#839eff;--color-primary-400:#5b75fc;--color-primary-500:#3b52e6;--color-primary-600:#2d3fc4;--color-primary-700:#25339e;--color-primary-800:#1e2a7f;--color-primary-900:#141c5a;--color-accent-400:#06d6a0;--color-accent-500:#05b88a;--color-accent-600:#049a74;--color-warning-400:#ffb74d;--color-warning-500:#ff9800;--color-warning-600:#f57c00;--color-danger-400:#ef5350;--color-danger-500:#f44336;--color-danger-600:#e53935;--color-success-400:#66bb6a;--color-success-500:#4caf50;--color-success-600:#43a047;--color-info-400:#42a5f5;--color-info-500:#2196f3;--color-info-600:#1e88e5;--bg-primary:#0a0e1a;--bg-secondary:#111827;--bg-tertiary:#1a2035;--bg-card:#151c2e;--bg-elevated:#1e2742;--bg-hover:#3b52e614;--bg-active:#3b52e626;--bg-glass:#151c2ebf;--bg-input:#0d1220;--border-default:#ffffff0f;--border-hover:#ffffff1f;--border-focus:var(--color-primary-500);--border-glass:#ffffff14;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-tertiary:#64748b;--text-inverse:#0a0e1a;--text-accent:var(--color-primary-400);--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 8px 32px #0006;--shadow-xl:0 16px 48px #00000080;--shadow-glow:0 0 20px #3b52e626;--shadow-card:0 4px 24px #00000040;--font-sans:"Inter", "Noto Sans Tamil", "Noto Sans Bengali", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", monospace;--text-xs:.75rem;--text-sm:.8125rem;--text-base:.875rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px;--content-max-width:1440px;--assist-width:420px;--z-base:1;--z-dropdown:100;--z-sticky:200;--z-modal:500;--z-toast:700;--z-tooltip:800;--z-assist:900}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px;border-radius:var(--radius-sm)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}a{color:var(--text-accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-300)}::selection{background:var(--color-primary-500);color:#fff}.sidebar{width:var(--sidebar-width);background:var(--bg-card);border-right:1px solid var(--border-default);height:100vh;z-index:var(--z-sticky);transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--border-default);min-height:var(--header-height);display:flex}.sidebar-brand-logo{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--color-primary-500), var(--color-accent-400));width:36px;height:36px;font-weight:800;font-size:var(--text-lg);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-brand-name{font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.sidebar-brand-subtitle{font-size:var(--text-xs);color:var(--text-tertiary);white-space:nowrap}.sidebar-nav{padding:var(--space-3) var(--space-2);flex:1;overflow-y:auto}.sidebar-section-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-4) var(--space-3) var(--space-2);font-size:.6875rem;font-weight:600}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);transition:all var(--transition-fast);cursor:pointer;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-link.active{background:var(--bg-active);color:var(--color-primary-400)}.sidebar-link.active:before{content:"";background:var(--color-primary-500);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link-icon{opacity:.7;flex-shrink:0;width:20px;height:20px}.sidebar-link.active .sidebar-link-icon{opacity:1}.sidebar-link-badge{background:var(--color-danger-500);color:#fff;border-radius:var(--radius-full);text-align:center;min-width:18px;margin-left:auto;padding:1px 6px;font-size:.6875rem;font-weight:600}.header{top:0;left:var(--sidebar-width);height:var(--header-height);background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-glass);padding:0 var(--space-6);z-index:var(--z-sticky);transition:left var(--transition-base);justify-content:space-between;align-items:center;display:flex;position:fixed;right:0}.header-left{align-items:center;gap:var(--space-4);display:flex}.header-title{font-size:var(--text-lg);color:var(--text-primary);font-weight:700}.header-breadcrumb{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-tertiary);display:flex}.header-breadcrumb-separator{color:var(--text-tertiary);opacity:.5}.header-right{align-items:center;gap:var(--space-3);display:flex}.main-content{margin-left:var(--sidebar-width);margin-top:var(--header-height);padding:var(--space-6);min-height:calc(100vh - var(--header-height));transition:margin-left var(--transition-base)}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.page-title{font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.02em;font-weight:800}.page-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-card)}.card-glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:var(--space-5)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-md);color:var(--text-primary);font-weight:700}.card-subtitle{font-size:var(--text-xs);color:var(--text-tertiary)}.stat-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(90deg, var(--stat-color,var(--color-primary-500)), transparent);height:3px;position:absolute;top:0;left:0;right:0}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-card-value{font-size:var(--text-3xl);color:var(--text-primary);letter-spacing:-.02em;margin-top:var(--space-2);font-weight:800}.stat-card-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.stat-card-change{align-items:center;gap:var(--space-1);font-size:var(--text-xs);margin-top:var(--space-2);border-radius:var(--radius-full);padding:2px 8px;font-weight:600;display:inline-flex}.stat-card-change.positive{color:var(--color-success-400);background:#4caf501a}.stat-card-change.negative{color:var(--color-danger-400);background:#f443361a}.form-group{margin-bottom:var(--space-5)}.form-label{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2);font-weight:600;display:block}.form-label.required:after{content:" *";color:var(--color-danger-500)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-2) var(--space-3);font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--transition-fast);line-height:1.5}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:var(--border-hover)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #3b52e626}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--color-danger-500);box-shadow:0 0 0 3px #f443361a}.form-error{font-size:var(--text-xs);color:var(--color-danger-400);margin-top:var(--space-1)}.form-hint{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-1)}.form-textarea{resize:vertical;min-height:80px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 8px center;background-repeat:no-repeat;background-size:20px;padding-right:36px}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-family:var(--font-sans);font-size:var(--text-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;font-weight:600;line-height:1.5;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg, var(--color-primary-500), var(--color-primary-600));color:#fff;box-shadow:0 2px 8px #3b52e64d}.btn-primary:hover{background:linear-gradient(135deg, var(--color-primary-400), var(--color-primary-500));transform:translateY(-1px);box-shadow:0 4px 16px #3b52e666}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-hover)}.btn-accent{background:linear-gradient(135deg, var(--color-accent-400), var(--color-accent-600));color:#fff}.btn-accent:hover{transform:translateY(-1px);box-shadow:0 4px 16px #06d6a04d}.btn-danger{background:var(--color-danger-500);color:#fff}.btn-danger:hover{background:var(--color-danger-600)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-md)}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.table-container{border:1px solid var(--border-default);border-radius:var(--radius-lg);background:var(--bg-card);overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.table thead{background:var(--bg-tertiary)}.table th{padding:var(--space-3) var(--space-4);text-align:left;color:var(--text-secondary);font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-default);white-space:nowrap}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-default);color:var(--text-primary);vertical-align:middle}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--bg-hover)}.table tbody tr:last-child td{border-bottom:none}.badge{font-size:var(--text-xs);border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:4px;padding:2px 10px;font-weight:600;display:inline-flex}.badge-primary{color:var(--color-primary-400);background:#3b52e626}.badge-success{color:var(--color-success-400);background:#4caf5026}.badge-warning{color:var(--color-warning-400);background:#ff980026}.badge-danger{color:var(--color-danger-400);background:#f4433626}.badge-info{color:var(--color-info-400);background:#2196f326}.badge-accent{color:var(--color-accent-400);background:#06d6a026}.badge-neutral{color:var(--text-secondary);background:#94a3b826}.brand-tag{font-size:var(--text-xs);border-radius:var(--radius-sm);border:1px solid;align-items:center;gap:4px;padding:3px 10px;font-weight:600;display:inline-flex}.brand-genetec{color:#4da3ff;background:#007bff14;border-color:#007bff4d}.brand-honeywell{color:#ff8040;background:#ff590014;border-color:#ff59004d}.brand-hikvision{color:#f05545;background:#eb332314;border-color:#eb33234d}.brand-salto{color:#3c7;background:#00b05014;border-color:#00b0504d}.brand-custom{color:var(--text-secondary);background:#94a3b814;border-color:#94a3b84d}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);animation:fadeIn var(--transition-fast) ease-out;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-6);width:90vw;max-width:560px;max-height:85vh;box-shadow:var(--shadow-xl);animation:slideUp var(--transition-base) ease-out;overflow-y:auto}.modal-header{margin-bottom:var(--space-5);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-lg);font-weight:700}.modal-footer{justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--border-default);display:flex}.modal-body{max-height:60vh;overflow-y:auto}.modal-lg{max-width:720px}.modal-xl{max-width:960px}.mobile-menu-btn{display:none}.toast-container{top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);gap:var(--space-2);flex-direction:column;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:320px;max-width:480px;animation:slideInRight var(--transition-base) ease-out;display:flex}.toast-success{border-left:4px solid var(--color-success-500)}.toast-error{border-left:4px solid var(--color-danger-500)}.toast-warning{border-left:4px solid var(--color-warning-500)}.toast-info{border-left:4px solid var(--color-info-500)}.toast-icon{font-size:var(--text-md);flex-shrink:0}.toast-success .toast-icon{color:var(--color-success-400)}.toast-error .toast-icon{color:var(--color-danger-400)}.toast-warning .toast-icon{color:var(--color-warning-400)}.toast-info .toast-icon{color:var(--color-info-400)}.toast-message{font-size:var(--text-sm);color:var(--text-primary);flex:1}.toast-close{color:var(--text-tertiary);cursor:pointer;font-size:var(--text-md);transition:color var(--transition-fast);background:0 0;border:none;padding:2px;line-height:1}.toast-close:hover{color:var(--text-primary)}.assist-trigger{bottom:var(--space-6);right:var(--space-6);border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-primary-500), var(--color-accent-400));color:#fff;cursor:pointer;width:56px;height:56px;z-index:var(--z-assist);transition:all var(--transition-base);border:none;justify-content:center;align-items:center;animation:3s ease-in-out infinite pulse;display:flex;position:fixed;box-shadow:0 4px 20px #3b52e666}.assist-trigger:hover{transform:scale(1.1);box-shadow:0 6px 28px #3b52e680}.assist-panel{width:var(--assist-width);background:var(--bg-card);border-left:1px solid var(--border-default);height:100vh;z-index:var(--z-assist);transition:transform var(--transition-base);box-shadow:var(--shadow-xl);flex-direction:column;display:flex;position:fixed;top:0;right:0;transform:translate(100%)}.assist-panel.open{transform:translate(0)}.assist-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-default);background:linear-gradient(135deg,#3b52e614,#06d6a014);justify-content:space-between;align-items:center;display:flex}.assist-messages{padding:var(--space-4);gap:var(--space-3);flex-direction:column;flex:1;display:flex;overflow-y:auto}.assist-message{max-width:85%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);animation:fadeInUp var(--transition-fast) ease-out;line-height:1.6}.assist-message.user{background:var(--color-primary-600);color:#fff;border-bottom-right-radius:var(--radius-sm);align-self:flex-end}.assist-message.assistant{background:var(--bg-elevated);color:var(--text-primary);border-bottom-left-radius:var(--radius-sm);align-self:flex-start}.assist-input-area{padding:var(--space-4);border-top:1px solid var(--border-default);align-items:center;gap:var(--space-2);display:flex}.assist-input{padding:var(--space-2) var(--space-3);background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);flex:1}.assist-input:focus{border-color:var(--border-focus);outline:none}.assist-btn-mic,.assist-btn-camera,.assist-btn-upload,.assist-btn-send{border-radius:var(--radius-full);cursor:pointer;width:36px;height:36px;transition:all var(--transition-fast);background:var(--bg-elevated);color:var(--text-secondary);border:none;justify-content:center;align-items:center;display:flex}.assist-btn-mic:hover{background:var(--color-danger-500);color:#fff}.assist-btn-camera:hover{background:var(--color-info-500);color:#fff}.assist-btn-upload:hover{background:var(--color-warning-500);color:#fff}.assist-btn-send{background:var(--color-primary-500);color:#fff}.assist-btn-send:hover{background:var(--color-primary-400)}.assist-lang-selector{gap:var(--space-1);padding:var(--space-1);display:flex}.assist-lang-btn{font-size:var(--text-xs);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:2px 8px}.assist-lang-btn.active{background:var(--color-primary-500);border-color:var(--color-primary-500);color:#fff}.grid-stats{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.grid-2{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.text-right{text-align:right}.text-center{text-align:center}.text-mono{font-family:var(--font-mono)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-muted{color:var(--text-tertiary)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.w-full{width:100%}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sr-only{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg, var(--bg-elevated) 25%, var(--bg-tertiary) 50%, var(--bg-elevated) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}@media (max-width:768px){:root{--sidebar-width:0px}.sidebar{z-index:var(--z-modal);transform:translate(-100%)}.sidebar.mobile-open{width:280px;transform:translate(0)}.header{left:0}.main-content{padding:var(--space-4);margin-left:0}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.assist-panel{width:100vw}.modal{width:95vw;margin:var(--space-4)}.mobile-menu-btn{display:flex!important}.page-header{gap:var(--space-3);flex-direction:column;align-items:flex-start}.table-toolbar{flex-direction:column}.table-toolbar-left{flex-direction:column;width:100%}.search-input-wrapper{max-width:100%}.pagination{gap:var(--space-3);flex-direction:column}}@media (max-width:480px){.page-title{font-size:var(--text-xl)}.stat-card-value{font-size:var(--text-2xl)}}.login-page{background:var(--bg-primary);min-height:100vh;padding:var(--space-4);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-bg{pointer-events:none;position:absolute;inset:0;overflow:hidden}.login-bg-orb{filter:blur(100px);opacity:.3;border-radius:50%;animation:12s ease-in-out infinite orbFloat;position:absolute}.login-bg-orb-1{background:var(--color-primary-600);width:500px;height:500px;animation-delay:0s;top:-200px;right:-100px}.login-bg-orb-2{background:var(--color-accent-500);width:400px;height:400px;animation-delay:-4s;bottom:-150px;left:-100px}.login-bg-orb-3{background:var(--color-primary-400);width:300px;height:300px;animation-delay:-8s;top:50%;left:50%}@keyframes orbFloat{0%,to{transform:translate(0)scale(1)}25%{transform:translate(30px,-40px)scale(1.05)}50%{transform:translate(-20px,20px)scale(.95)}75%{transform:translate(15px,30px)scale(1.02)}}.login-container{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:var(--radius-2xl);width:100%;max-width:960px;box-shadow:var(--shadow-xl);z-index:1;grid-template-columns:1fr 1fr;min-height:560px;display:grid;position:relative;overflow:hidden}.login-branding{background:linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);padding:var(--space-10);justify-content:center;gap:var(--space-8);border-right:1px solid var(--border-default);flex-direction:column;display:flex}.login-logo{align-items:center;gap:var(--space-4);display:flex}.login-logo-circle{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--color-primary-500), var(--color-accent-400));width:52px;height:52px;font-weight:800;font-size:var(--text-2xl);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.login-logo h1{font-size:var(--text-xl);color:var(--text-primary);letter-spacing:-.02em;font-weight:800}.login-logo p{font-size:var(--text-sm);color:var(--text-tertiary)}.login-tagline h2{font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.02em;font-weight:800;line-height:1.3}.login-tagline p{margin-top:var(--space-3);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6}.login-brands{gap:var(--space-2);flex-wrap:wrap;display:flex}.login-brand-tag{font-size:var(--text-xs);border-radius:var(--radius-sm);border:1px solid;padding:4px 12px;font-weight:600}.login-brand-tag.genetec{color:#4da3ff;background:#007bff14;border-color:#007bff4d}.login-brand-tag.honeywell{color:#ff8040;background:#ff590014;border-color:#ff59004d}.login-brand-tag.hikvision{color:#f05545;background:#eb332314;border-color:#eb33234d}.login-brand-tag.salto{color:#3c7;background:#00b05014;border-color:#00b0504d}.login-footer-text p{font-size:var(--text-xs);color:var(--text-tertiary)}.login-form-panel{padding:var(--space-10);justify-content:center;gap:var(--space-6);flex-direction:column;display:flex}.login-form-header h2{font-size:var(--text-2xl);color:var(--text-primary);font-weight:800}.login-form-header p{margin-top:var(--space-1);font-size:var(--text-sm);color:var(--text-secondary)}.login-form .form-group{margin-bottom:var(--space-4)}.login-form label{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2);font-weight:600;display:block}.input-with-icon{align-items:center;display:flex;position:relative}.input-icon{font-size:var(--text-base);z-index:1;pointer-events:none;position:absolute;left:12px}.input-with-icon input{width:100%;padding:var(--space-3) var(--space-3) var(--space-3) 40px;font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--transition-fast)}.input-with-icon input:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #3b52e626}.input-with-icon input::placeholder{color:var(--text-tertiary)}.input-toggle-password{cursor:pointer;font-size:var(--text-base);padding:var(--space-1);opacity:.6;transition:opacity var(--transition-fast);background:0 0;border:none;position:absolute;right:8px}.input-toggle-password:hover{opacity:1}.login-error{align-items:center;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-md);color:var(--color-danger-400);font-size:var(--text-sm);background:#f443361a;border:1px solid #f4433633;animation:.4s ease-in-out shake;display:flex}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.login-options{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.login-remember{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;display:flex}.login-remember input[type=checkbox]{accent-color:var(--color-primary-500)}.login-forgot{font-size:var(--text-sm);color:var(--color-primary-400)}.login-submit{width:100%;padding:var(--space-3) var(--space-6);font-size:var(--text-md);font-weight:700}.login-spinner{align-items:center;gap:var(--space-2);display:flex}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-demo-info{padding:var(--space-3);border-radius:var(--radius-md);text-align:center;background:#3b52e60d;border:1px solid #3b52e61a}.login-demo-info p{font-size:var(--text-xs);color:var(--text-tertiary);margin-bottom:var(--space-1)}.login-demo-info code{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-primary-400)}@media (max-width:768px){.login-container{grid-template-columns:1fr;max-width:440px}.login-branding{display:none}}.table-toolbar{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.table-toolbar-left{align-items:center;gap:var(--space-3);flex:1;display:flex}.search-input-wrapper{flex:1;max-width:360px;position:relative}.search-input-wrapper .search-icon{color:var(--text-tertiary);font-size:var(--text-sm);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) 36px;font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--transition-fast)}.search-input:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #3b52e626}.search-input::placeholder{color:var(--text-tertiary)}.filter-select{padding:var(--space-2) var(--space-8) var(--space-2) var(--space-3);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-md);appearance:none;cursor:pointer;transition:all var(--transition-fast);background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 8px center;background-repeat:no-repeat;background-size:16px}.filter-select:focus{border-color:var(--border-focus);outline:none}.pagination{margin-top:var(--space-4);padding:var(--space-3) 0;justify-content:space-between;align-items:center;display:flex}.pagination-info{font-size:var(--text-sm);color:var(--text-secondary)}.pagination-controls{align-items:center;gap:var(--space-1);display:flex}.pagination-btn{padding:var(--space-1) var(--space-3);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-secondary);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.pagination-btn.active{background:var(--color-primary-500);color:#fff;border-color:var(--color-primary-500)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.empty-state{padding:var(--space-12) var(--space-6);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--space-4);opacity:.4;font-size:3rem}.empty-state-title{font-size:var(--text-lg);color:var(--text-primary);margin-bottom:var(--space-2);font-weight:700}.empty-state-text{font-size:var(--text-sm);color:var(--text-secondary);max-width:400px}.loading-container{padding:var(--space-16);justify-content:center;align-items:center;display:flex}.loading-spinner{border:3px solid var(--border-default);border-top-color:var(--color-primary-500);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.detail-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.detail-field{gap:var(--space-1);flex-direction:column;display:flex}.detail-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.detail-value{font-size:var(--text-base);color:var(--text-primary);font-weight:500}.detail-value.mono{font-family:var(--font-mono)}.module-page{animation:.3s ease-out pageEnter}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.table-cell-primary{color:var(--text-primary);font-weight:600}.table-cell-secondary{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:1px}.table-actions{gap:var(--space-1);display:flex}.money{font-family:var(--font-mono);white-space:nowrap;font-weight:600}.money.positive{color:var(--color-success-400)}.money.negative{color:var(--color-danger-400)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
