.toast-container{position:fixed;top:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:400px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026,0 0 0 1px #0000000d;animation:toastSlideIn .4s cubic-bezier(.16,1,.3,1);border-left:4px solid;pointer-events:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes toastSlideIn{0%{transform:translate(100%) scale(.9);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.toast-success{border-left-color:#10b981;background:linear-gradient(135deg,#ecfdf5,#d1fae5)}.toast-success .toast-icon{color:#10b981}.toast-error{border-left-color:#ef4444;background:linear-gradient(135deg,#fef2f2,#fecaca)}.toast-error .toast-icon{color:#ef4444}.toast-warning{border-left-color:#f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.toast-warning .toast-icon{color:#f59e0b}.toast-info{border-left-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#dbeafe)}.toast-info .toast-icon{color:#3b82f6}.toast-icon{flex-shrink:0}.toast-message{flex:1;font-size:14px;font-weight:500;color:#1f2937;line-height:1.4}.toast-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:8px;color:#6b7280;cursor:pointer;transition:all .2s ease;flex-shrink:0}.toast-close:hover{background:#0000001a;color:#1f2937}@media(max-width:480px){.toast-container{left:16px;right:16px;max-width:none}.toast{padding:12px 16px}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--spacing-xl);max-width:400px;width:90%;text-align:center;position:relative;animation:scaleIn .2s ease;box-shadow:var(--shadow-xl)}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.modal-close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.modal-icon{width:64px;height:64px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-md)}.modal-icon.warning{background:var(--warning-light);color:var(--warning)}.modal-icon.danger{background:var(--danger-light);color:var(--danger)}.modal-icon.info{background:var(--info-light);color:var(--info)}.modal-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.modal-message{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-lg);line-height:1.6}.modal-actions{display:flex;gap:var(--spacing-sm);justify-content:center}.modal.form-modal{max-width:600px;text-align:left}.modal.form-modal .modal-title{text-align:center;margin-bottom:var(--spacing-lg)}.modal.form-modal .form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.modal.form-modal .form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.modal.form-modal .form-group.full-width{grid-column:span 2}.modal.form-modal .form-label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary)}.modal.form-modal .form-label.required:after{content:" *";color:var(--danger)}.modal.form-modal .form-input,.modal.form-modal .form-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-sm);background:var(--bg-primary);color:var(--text-primary);transition:border-color var(--transition-fast)}.modal.form-modal .form-input:focus,.modal.form-modal .form-select:focus{outline:none;border-color:var(--primary)}.modal.form-modal .modal-actions{justify-content:flex-end;padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}@media(max-width:600px){.modal.form-modal .form-grid{grid-template-columns:1fr}.modal.form-modal .form-group.full-width{grid-column:span 1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-line,.skeleton-cell,.skeleton-circle{background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-100) 50%,var(--gray-200) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.table-skeleton{padding:var(--spacing-md)}.skeleton-header{display:flex;gap:var(--spacing-md);padding:var(--spacing-md) 0;border-bottom:1px solid var(--border-color)}.skeleton-header .skeleton-cell{height:12px;flex:1}.skeleton-row{display:flex;gap:var(--spacing-md);padding:var(--spacing-md) 0;border-bottom:1px solid var(--border-color)}.skeleton-row .skeleton-cell{height:16px;flex:1}.card-skeleton-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.card-skeleton{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-lg);display:flex;align-items:flex-start;gap:var(--spacing-md)}.skeleton-circle{width:48px;height:48px;border-radius:var(--radius-lg);flex-shrink:0}.skeleton-circle.small{width:32px;height:32px}.skeleton-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.skeleton-line{height:16px}.skeleton-line.wide{width:80%}.skeleton-line.narrow{width:50%;height:12px}.list-skeleton{display:flex;flex-direction:column;gap:var(--spacing-sm)}.list-skeleton-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center}.empty-icon{width:96px;height:96px;background:var(--bg-secondary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:var(--spacing-lg)}.empty-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.empty-description{font-size:var(--text-sm);color:var(--text-secondary);max-width:300px;margin-bottom:var(--spacing-lg)}:root{--primary-50: #E8F5E9;--primary-100: #C8E6C9;--primary-200: #A5D6A7;--primary-300: #81C784;--primary-400: #66BB6A;--primary-500: #2E8B57;--primary-600: #278B4D;--primary-700: #1B7A3E;--primary-800: #166B32;--primary-900: #0D4D22;--secondary-50: #FFFDE7;--secondary-100: #FFF9C4;--secondary-500: #FFD700;--secondary-600: #FFC107;--secondary-700: #FFB300;--success: #10B981;--success-light: #D1FAE5;--warning: #F59E0B;--warning-light: #FEF3C7;--danger: #EF4444;--danger-light: #FEE2E2;--info: #3B82F6;--info-light: #DBEAFE;--gray-50: #F9FAFB;--gray-100: #F3F4F6;--gray-200: #E5E7EB;--gray-300: #D1D5DB;--gray-400: #9CA3AF;--gray-500: #6B7280;--gray-600: #4B5563;--gray-700: #374151;--gray-800: #1F2937;--gray-900: #111827;--bg-primary: #FFFFFF;--bg-secondary: var(--gray-50);--bg-tertiary: var(--gray-100);--text-primary: var(--gray-900);--text-secondary: var(--gray-600);--text-muted: var(--gray-400);--border-color: var(--gray-200);--border-focus: var(--primary-500);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-full: 9999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--sidebar-width: 260px;--sidebar-collapsed-width: 72px;--header-height: 64px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}[data-theme=dark]{--bg-primary: #0F172A;--bg-secondary: #1E293B;--bg-tertiary: #334155;--text-primary: #F1F5F9;--text-secondary: #94A3B8;--text-muted: #64748B;--border-color: #334155;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .3);--shadow: 0 1px 3px 0 rgb(0 0 0 / .4), 0 1px 2px -1px rgb(0 0 0 / .4);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .4), 0 2px 4px -2px rgb(0 0 0 / .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-sm);line-height:1.5;color:var(--text-primary);background-color:var(--bg-secondary);min-height:100vh}a{color:var(--primary-600);text-decoration:none}a:hover{text-decoration:underline}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.bg-primary{background-color:var(--bg-primary)}.bg-secondary{background-color:var(--bg-secondary)}.bg-success{background-color:var(--success-light)}.bg-warning{background-color:var(--warning-light)}.bg-danger{background-color:var(--danger-light)}.font-mono{font-family:var(--font-mono)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.rounded-sm{border-radius:var(--radius-sm)}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow{box-shadow:var(--shadow)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}::selection{background-color:var(--primary-200);color:var(--primary-900)}.form-input,.form-select,.form-textarea{background-color:#fff!important;color:#1f2937!important}input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,input:-webkit-autofill:active,select:-webkit-autofill,textarea:-webkit-autofill{-webkit-box-shadow:0 0 0 30px white inset!important;-webkit-text-fill-color:#1f2937!important}.sidebar{width:var(--sidebar-width);height:100vh;background:var(--bg-primary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:100;transition:width var(--transition-base)}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-md);border-bottom:1px solid var(--border-color)}.logo{display:flex;align-items:center;gap:var(--spacing-sm)}.logo-icon{color:var(--primary-600);flex-shrink:0}.logo-image{width:36px;height:36px;object-fit:contain;flex-shrink:0}.logo-text{font-size:var(--text-lg);font-weight:700;color:var(--primary-700);white-space:nowrap}.toggle-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.toggle-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-nav{flex:1;padding:var(--spacing-md);overflow-y:auto}.nav-item-wrapper{margin-bottom:var(--spacing-xs)}.nav-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;color:var(--text-secondary);font-size:var(--text-sm);font-family:inherit;text-align:left;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-item.active{background:var(--primary-50);color:var(--primary-700)}.nav-icon{flex-shrink:0}.nav-label{flex:1;white-space:nowrap}.nav-chevron{flex-shrink:0;transition:transform var(--transition-fast)}.nav-chevron.rotated{transform:rotate(90deg)}.submenu{margin-left:calc(var(--spacing-md) + 20px + var(--spacing-sm));margin-top:var(--spacing-xs);border-left:2px solid var(--border-color);padding-left:var(--spacing-md)}.submenu-item{display:block;padding:var(--spacing-xs) var(--spacing-sm);color:var(--text-secondary);font-size:var(--text-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);text-decoration:none}.submenu-item:hover{color:var(--text-primary);background:var(--bg-secondary);text-decoration:none}.submenu-item.active{color:var(--primary-700);background:var(--primary-50)}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--border-color)}.version{font-size:var(--text-xs);color:var(--text-muted);text-align:center}.sidebar.collapsed .nav-item{justify-content:center;padding:var(--spacing-sm)}.sidebar.collapsed .toggle-btn{position:absolute;right:-12px;top:50%;transform:translateY(-50%);background:var(--bg-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);z-index:10}.sidebar.collapsed .sidebar-header{justify-content:center;padding:var(--spacing-sm);position:relative}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99;opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.sidebar-overlay.visible{opacity:1;pointer-events:auto}@media(max-width:900px){.sidebar{transform:translate(-100%);transition:transform var(--transition-base);box-shadow:var(--shadow-xl)}.sidebar.open{transform:translate(0)}.sidebar.collapsed{width:var(--sidebar-width);transform:translate(-100%)}.sidebar.collapsed.open{transform:translate(0)}.sidebar-overlay,.sidebar.collapsed .nav-label,.sidebar.collapsed .logo-text,.sidebar.collapsed .nav-chevron,.sidebar.collapsed .submenu,.sidebar.collapsed .version{display:block}.sidebar.collapsed .nav-item{justify-content:flex-start;padding:var(--spacing-sm) var(--spacing-md)}.sidebar.collapsed .sidebar-header{flex-direction:row;justify-content:space-between}}.header{height:var(--header-height);background:var(--bg-primary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg);position:fixed;top:0;left:var(--sidebar-width);right:0;z-index:90;transition:left var(--transition-base)}.header.expanded{left:var(--sidebar-collapsed-width)}.header-left{display:flex;align-items:center;gap:var(--spacing-lg)}.search-box{position:relative;width:320px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;z-index:2}.search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-sm) 40px!important;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-secondary);font-size:var(--text-sm);color:var(--text-primary);transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--primary-400);background:var(--bg-primary);box-shadow:0 0 0 2px var(--primary-100)}.search-input::placeholder{color:var(--text-muted)}.header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.header-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.header-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.notification-btn{position:relative}.notification-badge{position:absolute;top:6px;right:6px;min-width:18px;height:18px;padding:0 4px;background:var(--danger);color:#fff;font-size:11px;font-weight:600;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.user-menu-wrapper{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border:1px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.user-menu-trigger:hover{background:var(--bg-secondary);border-color:var(--border-color)}.user-avatar{width:32px;height:32px;background:var(--primary-100);color:var(--primary-700);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.user-name{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.user-menu-trigger svg:last-child{color:var(--text-muted);transition:transform var(--transition-fast)}.user-menu-trigger svg:last-child.rotated{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + var(--spacing-xs));right:0;min-width:180px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-xs);z-index:100}.dropdown-item{display:block;padding:var(--spacing-sm) var(--spacing-md);color:var(--text-secondary);font-size:var(--text-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);text-decoration:none}.dropdown-item:hover{background:var(--bg-secondary);color:var(--text-primary);text-decoration:none}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:var(--danger-light)}.dropdown-divider{height:1px;background:var(--border-color);margin:var(--spacing-xs) 0}.search-results{position:absolute;top:calc(100% + var(--spacing-xs));left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:300px;overflow-y:auto;z-index:100}.search-result-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;transition:background var(--transition-fast)}.search-result-item:hover{background:var(--bg-secondary);text-decoration:none}.result-icon{color:var(--text-muted)}.result-content{flex:1;display:flex;flex-direction:column;min-width:0}.result-label{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);font-family:var(--font-mono)}.result-description{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-type{padding:2px 6px;border-radius:var(--radius-full);font-size:10px;font-weight:600;text-transform:uppercase}.result-type.asset{background:var(--primary-100);color:var(--primary-700)}.result-type.location{background:var(--success-light);color:var(--success)}.result-type.network{background:var(--warning-light);color:#92400e}.search-no-results{padding:var(--spacing-md);text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.notification-wrapper{position:relative}.notification-dropdown{position:absolute;top:calc(100% + var(--spacing-xs));right:0;width:360px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:100;overflow:hidden}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--border-color)}.notification-header h4{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0}.notification-count{font-size:var(--text-xs);color:var(--primary);background:var(--primary-100);padding:2px 8px;border-radius:var(--radius-full)}.notification-list{max-height:360px;overflow-y:auto}.notification-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--text-muted);gap:var(--spacing-sm)}.notification-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;transition:background var(--transition-fast);position:relative}.notification-item:hover{background:var(--bg-secondary);text-decoration:none}.notification-icon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.notification-icon.warning{background:var(--warning-light);color:var(--warning)}.notification-icon.danger{background:var(--danger-light);color:var(--danger)}.notification-icon.info{background:var(--info-light);color:var(--info)}.notification-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.notification-desc{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-time{font-size:var(--text-xs);color:var(--text-muted)}.notification-dismiss{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:20px;height:20px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all var(--transition-fast)}.notification-item:hover .notification-dismiss{opacity:1}.notification-dismiss:hover{background:var(--bg-secondary);color:var(--danger)}.notification-footer{display:block;text-align:center;padding:var(--spacing-sm);font-size:var(--text-sm);color:var(--primary);text-decoration:none;border-top:1px solid var(--border-color);transition:background var(--transition-fast)}.notification-footer:hover{background:var(--bg-secondary);text-decoration:none}.mobile-menu-btn{display:none;width:40px;height:40px;background:transparent;border:none;border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;align-items:center;justify-content:center;transition:all var(--transition-fast)}.mobile-menu-btn:hover{background:var(--bg-secondary)}@media(max-width:900px){.header{left:0;padding:0 var(--spacing-md)}.header.expanded{left:0}.mobile-menu-btn{display:flex}.search-box{width:100%;max-width:none}.header-left{flex:1;gap:var(--spacing-sm)}.user-name{display:none}.user-menu-trigger svg:last-child{display:none}}@media(max-width:600px){.header{height:56px;padding:0 var(--spacing-sm)}.header-btn{width:36px;height:36px}.user-avatar{width:28px;height:28px}.notification-dropdown{width:calc(100vw - var(--spacing-md) * 2);right:calc(-1 * var(--spacing-sm))}.search-box{display:none}.header-left{gap:var(--spacing-xs)}}.login-page{min-height:100vh;display:flex;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.login-container{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);background:#ffffff05;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-card{width:100%;max-width:420px;background:#fffffff2;padding:40px;border-radius:24px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff1a}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:100px;height:100px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.login-logo-image{width:100px;height:100px;object-fit:contain}.login-logo:hover{transform:scale(1.05)}.login-title{font-size:24px;font-weight:700;color:#1b7a3e;margin-bottom:8px;letter-spacing:-.5px}.login-subtitle{font-size:14px;color:#6b7280}.login-form{display:flex;flex-direction:column;gap:20px}.login-error{padding:12px 16px;background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;border-radius:12px;font-size:14px;text-align:center;border:1px solid rgba(220,38,38,.2);animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:14px;font-weight:600;color:#374151}.input-wrapper{position:relative}.input-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#9ca3af;transition:color .2s ease}.form-input{width:100%;height:52px;padding:14px 16px 14px 48px;border:2px solid #e5e7eb;border-radius:12px;font-size:15px;color:#1f2937;background:#fff;transition:all .2s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:#2e8b57;background:#fff;box-shadow:0 0 0 4px #2e8b571a}.form-input:focus+.input-icon,.input-wrapper:focus-within .input-icon{color:#2e8b57}.form-input::placeholder{color:#9ca3af}.form-input:-webkit-autofill,.form-input:-webkit-autofill:hover,.form-input:-webkit-autofill:focus,.form-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px white inset!important;-webkit-text-fill-color:#1f2937!important;background-color:#fff!important}.password-toggle{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#9ca3af;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.password-toggle:hover{color:#2e8b57;background:#2e8b571a}.login-btn{width:100%;padding:16px;background:linear-gradient(135deg,#2e8b57,#1b7a3e);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:8px;position:relative;overflow:hidden}.login-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.login-btn:hover:not(:disabled):before{left:100%}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 40px #2e8b5766}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-footer{margin-top:24px;text-align:center;font-size:13px;color:#6b7280;padding:12px;background:#f3f4f6;border-radius:8px}.login-footer strong{color:#667eea;font-weight:600}.login-decoration{flex:1;background:linear-gradient(135deg,#2e8b57,#1b7a3e);display:flex;align-items:center;justify-content:center;padding:48px;position:relative;overflow:hidden}.login-decoration:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:pulse 4s ease infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.2);opacity:.8}}.decoration-content{color:#fff;max-width:400px;position:relative;z-index:1}.decoration-content h2{font-size:36px;font-weight:700;margin-bottom:32px;line-height:1.2;text-shadow:0 2px 20px rgba(0,0,0,.2)}.feature-list{list-style:none;display:flex;flex-direction:column;gap:16px}.feature-list li{font-size:18px;opacity:.95;display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ffffff1a;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.feature-list li:hover{background:#fff3;transform:translate(8px)}@media(max-width:900px){.login-decoration{display:none}.login-container{background:linear-gradient(135deg,#1a1a2e,#16213e)}}@media(max-width:480px){.login-card{padding:24px;border-radius:16px}.login-logo{width:64px;height:64px}.login-title{font-size:20px}}.license-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:20px}.license-container{width:100%;max-width:480px}.license-card{background:#fff;border-radius:16px;padding:40px;box-shadow:0 20px 60px #0000004d}.license-card.success{text-align:center}.license-header{text-align:center;margin-bottom:30px}.license-icon{width:80px;height:80px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#fff}.license-header h1{font-size:24px;font-weight:700;color:#1f2937;margin:0 0 8px}.license-header p{color:#6b7280;margin:0}.hardware-info{background:#f3f4f6;border-radius:12px;padding:16px;margin-bottom:24px}.hardware-label{display:flex;align-items:center;gap:8px;color:#374151;font-weight:500;margin-bottom:8px}.hardware-value{display:flex;align-items:center;gap:8px;background:#fff;border-radius:8px;padding:12px;border:1px solid #e5e7eb}.hardware-value code{flex:1;font-family:Monaco,Consolas,monospace;font-size:14px;color:#1f2937;word-break:break-all}.copy-btn{background:#10b981;border:none;border-radius:6px;padding:8px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.copy-btn:hover{background:#059669;transform:scale(1.05)}.hardware-hint{margin:12px 0 0;font-size:12px;color:#6b7280}.license-form{display:flex;flex-direction:column;gap:20px}.license-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px}.form-group label{display:block;font-weight:500;color:#374151;margin-bottom:8px}.license-input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-family:Monaco,Consolas,monospace;font-size:13px;resize:none;transition:all .2s}.license-input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.activate-btn{width:100%;padding:14px 24px;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.activate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.activate-btn:disabled{opacity:.6;cursor:not-allowed}.success-icon{color:#10b981;margin-bottom:20px}.license-loading{text-align:center;color:#fff}.spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.2);border-top-color:#10b981;border-radius:50%;margin:0 auto 16px;animation:spin 1s linear infinite}@media(max-width:480px){.license-card{padding:24px}.license-header h1{font-size:20px}}.analytics-charts{margin-top:2rem}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.chart-card{background:var(--card-bg, #fff);border-radius:12px;border:1px solid var(--border-color, #e2e8f0);overflow:hidden}.chart-card.wide{grid-column:span 2}.chart-header{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color, #e2e8f0);background:var(--card-header-bg, #f8fafc)}.chart-header h3{margin:0;font-size:.95rem;font-weight:600;color:var(--text-primary)}.chart-body{padding:1rem}.analytics-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-secondary)}.analytics-loading .spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color, #3b82f6);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@media(max-width:768px){.charts-grid{grid-template-columns:1fr}.chart-card.wide{grid-column:span 1}}.dashboard-page .page-header{margin-bottom:var(--spacing-lg)}.stat-header{display:flex;align-items:center;gap:var(--spacing-sm)}.stat-trend{display:flex;align-items:center;gap:2px;font-size:var(--text-xs);font-weight:500;padding:2px 6px;border-radius:var(--radius-full)}.stat-trend.up{background:var(--success-light);color:var(--success)}.stat-trend.down{background:var(--danger-light);color:var(--danger)}.stat-trend.down svg{transform:rotate(180deg)}.quick-actions-section{margin-bottom:var(--spacing-lg)}.section-title{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-sm)}@media(max-width:768px){.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}.quick-action-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;color:var(--text-primary);text-decoration:none;transition:all var(--transition-fast)}.quick-action-btn:hover{text-decoration:none;box-shadow:var(--shadow-md);transform:translateY(-2px)}.quick-action-btn.primary:hover{border-color:var(--primary-500);color:var(--primary-600)}.quick-action-btn.secondary:hover{border-color:var(--secondary-500);color:var(--secondary-600)}.quick-action-btn.success:hover{border-color:var(--success);color:var(--success)}.quick-action-btn.warning:hover{border-color:var(--warning);color:var(--warning)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-column{display:flex;flex-direction:column;gap:var(--spacing-lg)}.chart-container{display:flex;gap:var(--spacing-lg);align-items:center}@media(max-width:600px){.chart-container{flex-direction:column}}.donut-chart{position:relative;width:180px;height:180px;flex-shrink:0}.donut-chart svg{width:100%;height:100%}.chart-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.chart-total{display:block;font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);line-height:1}.chart-label{font-size:var(--text-xs);color:var(--text-muted)}.chart-legend{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.legend-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-sm)}.legend-color{width:12px;height:12px;border-radius:var(--radius-sm);flex-shrink:0}.legend-label{flex:1;color:var(--text-secondary)}.legend-value{font-weight:600;color:var(--text-primary)}.alerts-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.alert-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);font-size:var(--text-sm);text-decoration:none;transition:all var(--transition-fast)}.alert-item:hover{text-decoration:none}.alert-item.warning{background:var(--warning-light);color:#92400e}.alert-item.danger{background:var(--danger-light);color:#991b1b}.alert-item.info{background:var(--info-light);color:#1e40af}.alert-item:hover{opacity:.9}.alert-arrow{margin-left:auto;opacity:0;transition:all var(--transition-fast)}.alert-item:hover .alert-arrow{opacity:1;transform:translate(4px)}.license-list{list-style:none;display:flex;flex-direction:column;gap:var(--spacing-sm)}.license-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-lg)}.license-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--primary-100);color:var(--primary-600);border-radius:var(--radius-md)}.license-info{flex:1;display:flex;flex-direction:column}.license-name{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.days-badge{padding:4px 8px;background:var(--bg-tertiary);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;color:var(--text-secondary)}.days-badge.urgent{background:var(--danger-light);color:var(--danger)}.events-list{list-style:none;display:flex;flex-direction:column;gap:var(--spacing-sm)}.event-item{display:flex;align-items:center;gap:var(--spacing-md)}.event-date{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:600;min-width:60px;text-align:center}.event-date.warning{background:var(--warning-light);color:#92400e}.event-date.info{background:var(--info-light);color:#1e40af}.event-date.primary{background:var(--primary-100);color:var(--primary-700)}.event-title{font-size:var(--text-sm);color:var(--text-primary)}.task-stats-widget{display:flex;justify-content:space-around;padding:var(--spacing-md) 0;border-bottom:1px solid var(--border-color);margin-bottom:var(--spacing-md)}.task-stat{display:flex;flex-direction:column;align-items:center}.task-stat-value{font-size:var(--text-xl);font-weight:700;color:var(--text-primary)}.task-stat-value.pending{color:var(--warning)}.task-stat-value.overdue{color:var(--danger)}.task-stat-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.task-list-widget{list-style:none;display:flex;flex-direction:column;gap:var(--spacing-xs)}.task-widget-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-md)}.task-status-icon{flex-shrink:0;color:var(--text-muted)}.task-status-icon.pending{color:var(--warning)}.task-status-icon.in_progress{color:var(--info)}.task-status-icon.completed{color:var(--success)}.task-widget-title{flex:1;font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-widget-due{font-size:var(--text-xs);color:var(--text-muted);padding:2px 6px;background:var(--bg-tertiary);border-radius:var(--radius-sm)}.task-widget-due.overdue{background:var(--danger-light);color:var(--danger)}.hardware-list-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.bulk-actions-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);background:var(--primary-50);border:1px solid var(--primary-200);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md)}.bulk-count{font-size:var(--text-sm);font-weight:600;color:var(--primary-700)}.bulk-buttons{display:flex;gap:var(--spacing-sm)}.checkbox-col{width:40px;text-align:center}.checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--primary-600)}tr.selected{background:var(--primary-50)!important}.search-filter{position:relative;flex:1;min-width:250px;max-width:400px}.type-filters{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.asset-sn{display:flex;align-items:center;gap:var(--spacing-sm)}.asset-type-icon{color:var(--text-muted)}.asset-info .brand{font-weight:500}.asset-info .model{font-size:var(--text-xs);color:var(--text-secondary)}.status-cell{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center}.status-cell .badge-danger{display:flex;align-items:center;gap:4px}.opname-notes{margin-top:4px;font-size:var(--text-xs);color:var(--text-secondary);background:var(--bg-tertiary);padding:2px 6px;border-radius:var(--radius-sm);max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.specs-col .specs-text{font-size:var(--text-xs);color:var(--text-secondary);max-width:150px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ip-col .font-mono{font-size:var(--text-xs);color:var(--primary-600)}.hardware-detail-page{max-width:1200px}.detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.back-btn{display:flex;align-items:center;gap:var(--spacing-sm);background:transparent;border:none;color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}.back-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.detail-overview{display:flex;gap:var(--spacing-xl);padding:var(--spacing-xl);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:var(--spacing-lg)}.qr-section{flex-shrink:0}.qr-placeholder{width:150px;height:150px;background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);color:var(--text-muted)}.overview-info{display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center}.overview-row{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-sm);color:var(--text-secondary)}.overview-row strong{color:var(--text-primary)}.health-bar-mini{width:100px;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.health-bar-mini .health-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-base)}.health-bar-mini.success .health-fill{background:var(--success)}.health-bar-mini.warning .health-fill{background:var(--warning)}.health-bar-mini.danger .health-fill{background:var(--danger)}.detail-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color);padding-bottom:var(--spacing-xs)}.tab-btn{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);position:relative}.tab-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}.tab-btn.active{color:var(--primary-600);background:var(--primary-50)}.tab-btn.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--primary-600)}.specs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-md)}.spec-item{padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-lg)}.spec-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.spec-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.timeline{list-style:none;position:relative;padding-left:var(--spacing-lg)}.timeline:before{content:"";position:absolute;left:4px;top:0;bottom:0;width:2px;background:var(--border-color)}.timeline-item{position:relative;padding-bottom:var(--spacing-lg)}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:calc(-1 * var(--spacing-lg) + 1px);top:4px;width:10px;height:10px;background:var(--primary-500);border-radius:var(--radius-full);border:2px solid var(--bg-primary)}.timeline-content{padding-left:var(--spacing-sm)}.timeline-date{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:2px}.timeline-action{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.timeline-user{font-size:var(--text-xs);color:var(--text-secondary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md);color:var(--text-muted)}.empty-state p{font-size:var(--text-sm)}.searchable-select{position:relative;width:100%}.searchable-select.disabled{opacity:.6;pointer-events:none}.select-trigger{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);cursor:pointer;transition:all var(--transition-fast);min-height:42px}.select-trigger:hover{border-color:var(--primary-300)}.searchable-select.open .select-trigger{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a;border-bottom-left-radius:0;border-bottom-right-radius:0}.select-value{flex:1;font-size:var(--text-sm);color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.select-value.placeholder{color:var(--text-muted)}.select-actions{display:flex;align-items:center;gap:var(--spacing-xs);margin-left:var(--spacing-sm)}.clear-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:var(--gray-200);border-radius:var(--radius-full);color:var(--gray-600);cursor:pointer;transition:all var(--transition-fast)}.chevron{color:var(--text-muted);transition:transform var(--transition-fast)}.chevron.rotated{transform:rotate(180deg)}.select-dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;background:var(--bg-primary);border:1px solid var(--primary);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);box-shadow:0 4px 12px #00000026;max-height:300px;overflow:hidden;display:flex;flex-direction:column}.search-container{padding:var(--spacing-sm);border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.dropdown-search-box{display:flex;align-items:center;padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color .2s,box-shadow .2s;gap:8px;width:100%;box-sizing:border-box}.dropdown-search-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-100)}.dropdown-search-box .search-icon{color:var(--text-muted);flex-shrink:0;width:16px;height:16px}.dropdown-search-input{flex:1;border:none;background:transparent;font-size:var(--text-sm);color:var(--text-primary);outline:none;padding:0;min-width:0;line-height:1.4;box-shadow:none}.dropdown-search-input::placeholder{color:var(--text-muted)}.options-list{list-style:none;margin:0;padding:6px;overflow-y:auto;max-height:240px}.option-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:6px;font-size:14px;color:var(--text-primary);cursor:pointer;transition:all .15s ease;margin-bottom:2px}.option-item:last-child{margin-bottom:0}.option-item:hover{background:#f1f5f9}.option-item.selected{background:#dbeafe;color:#1d4ed8;font-weight:500}.option-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.check-icon{color:#1d4ed8;flex-shrink:0;margin-left:8px}.no-results{padding:20px;text-align:center;color:#94a3b8;font-size:14px}.options-list::-webkit-scrollbar{width:6px}.options-list::-webkit-scrollbar-track{background:transparent}.options-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.options-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.hardware-form-page{max-width:900px}.form-header{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.template-card{margin-bottom:var(--spacing-lg);background:var(--primary-50);border-color:var(--primary-200)}.template-row{display:flex;align-items:center;gap:var(--spacing-md)}.template-row span{font-size:var(--text-sm);font-weight:500;color:var(--primary-700)}.template-row .form-select{flex:1;max-width:300px}.card{margin-bottom:var(--spacing-lg)}@media(max-width:768px){.form-grid{grid-template-columns:1fr}}.form-label.required:after{content:" *";color:var(--danger)}.form-input,.form-select,.form-textarea{padding:var(--spacing-sm) var(--spacing-md);border:1px solid #d1d5db!important;border-radius:var(--radius-lg);font-size:var(--text-sm);color:#1f2937!important;background:#fff!important;transition:all var(--transition-fast);font-family:inherit;box-sizing:border-box}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--spacing-xs)}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.card-header{display:flex;justify-content:space-between;align-items:center}.card-header .btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--text-xs)}.licenses-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.license-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.license-fields{flex:1;display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm)}@media(max-width:1024px){.license-fields{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.license-fields{grid-template-columns:1fr}}.license-item .btn-icon{flex-shrink:0;align-self:flex-end;padding:var(--spacing-sm)}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.input-warning{border-color:var(--warning)!important}.input-warning:focus{box-shadow:0 0 0 3px #f59e0b33!important}.ip-warning{display:flex;align-items:center;gap:6px;margin-top:6px;padding:8px 12px;background:#f59e0b1a;border:1px solid var(--warning);border-radius:var(--radius-md);color:#b45309;font-size:12px;font-weight:500}.ip-warning svg{color:var(--warning);flex-shrink:0}.wizard-mode{max-width:700px;margin:0 auto}.wizard-progress{display:flex;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-lg);overflow-x:auto}.wizard-step{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.wizard-step:hover{background:var(--bg-secondary)}.wizard-step .step-number{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:600;background:var(--bg-tertiary);color:var(--text-muted);transition:all var(--transition-fast)}.wizard-step.active .step-number{background:var(--primary-600);color:#fff}.wizard-step.completed .step-number{background:var(--success);color:#fff}.wizard-step .step-info{display:flex;flex-direction:column}.wizard-step .step-name{font-size:var(--text-sm);font-weight:500;color:var(--text-muted)}.wizard-step.active .step-name{color:var(--primary-700);font-weight:600}.wizard-step.completed .step-name{color:var(--success)}.wizard-card{background:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-md);min-height:300px}.wizard-step-content .step-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.wizard-step-content .step-description{color:var(--text-muted);font-size:var(--text-sm);margin-bottom:var(--spacing-lg)}.wizard-step-content .template-row{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--primary-50);border-radius:var(--radius-lg);border:1px solid var(--primary-200)}.wizard-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.wizard-form-single{max-width:400px}@media(max-width:600px){.wizard-form-grid{grid-template-columns:1fr}.wizard-progress{gap:var(--spacing-xs);padding:var(--spacing-md)}.wizard-step .step-name{display:none}}.wizard-navigation{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-lg);margin-top:var(--spacing-md)}.wizard-navigation .nav-left,.wizard-navigation .nav-right{display:flex;gap:var(--spacing-sm)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn-success{background:var(--success);color:#fff;border:none}.btn-success:hover{background:#059669}.btn-success:disabled{background:var(--success);opacity:.6;cursor:not-allowed}.form-hint.checking{color:var(--primary-600);font-style:italic}.wizard-step-content .licenses-list{margin-top:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.license-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.license-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.license-number{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.license-header .btn-icon{padding:var(--spacing-xs);border-radius:var(--radius-md)}.license-body{padding:var(--spacing-md);display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}@media(max-width:500px){.license-body{grid-template-columns:1fr}}.software-license-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.filter-group{display:flex;gap:var(--spacing-sm)}.software-info{display:flex;flex-direction:column}.software-name{font-weight:500;color:var(--text-primary)}.software-vendor{font-size:var(--text-xs);color:var(--text-secondary)}.license-usage{display:flex;flex-direction:column;gap:var(--spacing-xs)}.usage-bar-mini{width:80px;height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.usage-bar-mini .usage-fill{height:100%;background:var(--primary-500);border-radius:var(--radius-full)}.expiry-info{display:flex;flex-direction:column;gap:2px}.days-left{font-size:var(--text-xs);font-weight:500}.days-left.warning{color:var(--warning)}.days-left.critical{color:var(--danger)}.os-info{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--text-secondary);font-size:var(--text-sm)}.os-info svg{color:var(--primary-500)}.expand-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.expand-btn:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--primary-500)}.expanded-row{background:var(--bg-secondary)}.expanded-row td{padding:0!important}.license-keys-section{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color)}.license-keys-section h4{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md)}.license-key-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.license-key-item.main-key{background:linear-gradient(135deg,var(--primary-50),var(--bg-primary));border-color:var(--primary-200)}.license-key-label{font-size:var(--text-xs);color:var(--text-muted);margin-right:var(--spacing-sm)}.license-key-main{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.license-key-index{font-size:var(--text-xs);color:var(--text-muted);min-width:24px}.license-key-value{font-family:Consolas,Monaco,monospace;font-size:var(--text-sm);background:var(--bg-tertiary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);color:var(--text-primary)}.license-key-desc{font-size:var(--text-xs);color:var(--text-secondary);font-style:italic}.license-key-actions{display:flex;align-items:center;gap:var(--spacing-md)}.license-key-date{font-size:var(--text-xs);color:var(--text-muted)}.action-btn.small{width:24px;height:24px}.additional-licenses-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.additional-licenses-section .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.additional-licenses-section h4{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin:0}.licenses-form-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.license-form-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-md)}.license-form-inputs{display:flex;flex:1;gap:var(--spacing-sm)}.license-form-inputs .form-input{flex:1}.btn-danger{background:var(--danger);color:#fff;border:none}.btn-danger:hover{background:var(--danger-dark)}.info-banner{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,var(--primary-50),var(--bg-primary));border:1px solid var(--primary-200);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);color:var(--text-secondary);font-size:var(--text-sm)}.info-banner svg{color:var(--primary-500);flex-shrink:0}.info-banner strong{color:var(--primary-600)}.asset-info{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--text-secondary);font-size:var(--text-sm)}.asset-info svg{color:var(--primary-500)}.asset-type{font-size:var(--text-xs);color:var(--text-muted)}.license-key{font-family:Consolas,Monaco,monospace;font-size:var(--text-sm);background:var(--bg-tertiary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);color:var(--text-primary)}.stat-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg)}.stat-content{display:flex;flex-direction:column}.stat-icon.secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.badge-unattached{background:var(--bg-tertiary);color:var(--text-muted);border:1px dashed var(--border-color);font-size:var(--text-xs);padding:4px 8px;border-radius:var(--radius-md)}.row-unattached{background:var(--bg-secondary)}.btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-secondary);color:var(--primary-600);border-color:var(--primary-500)}.btn-icon.danger:hover{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-primary);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;overflow:auto;box-shadow:0 20px 50px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;font-size:var(--text-lg);font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-md)}.modal-body{padding:var(--spacing-lg)}.modal-body .form-group{margin-bottom:var(--spacing-md)}.modal-body .form-label{display:block;font-size:var(--text-sm);font-weight:500;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.modal-body .form-label.required:after{content:" *";color:var(--danger)}.modal-body .form-input,.modal-body .form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm)}.modal-body .form-input:focus,.modal-body .form-select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.modal-body .form-hint{margin-top:var(--spacing-xs);font-size:var(--text-xs);color:var(--text-muted)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--border-color)}.templates-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-md)}.template-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-lg);transition:all var(--transition-fast)}.template-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-200)}.template-header{display:flex;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.template-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-50);color:var(--primary-600);border-radius:var(--radius-lg);flex-shrink:0}.template-info h3{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.template-specs{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md) 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);margin-bottom:var(--spacing-md)}.spec-row{display:flex;justify-content:space-between;font-size:var(--text-sm)}.spec-label{color:var(--text-muted);font-size:var(--text-xs);font-weight:500}.spec-value{color:var(--text-primary);font-weight:500}.template-footer{display:flex;align-items:center;justify-content:space-between}.usage-count{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--text-muted)}.template-actions{display:flex;gap:var(--spacing-xs)}.template-actions .action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.template-actions .action-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.template-actions .action-btn.danger:hover{background:var(--danger-light);color:var(--danger)}.disposal-page{display:flex;flex-direction:column;gap:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all .2s ease}.stat-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.primary{background:#4f46e526;color:var(--primary-color)}.stat-icon.success{background:#10b98126;color:var(--success-color)}.stat-icon.warning{background:#f59e0b26;color:var(--warning-color)}.stat-icon.danger{background:#ef444426;color:var(--danger-color)}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.2}.stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.filters-bar{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem;border-bottom:1px solid var(--border-color)}.search-filter{position:relative;flex:1;min-width:200px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-input{width:100%;padding:.625rem .875rem .625rem 2.5rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}.filter-group{display:flex;gap:.5rem}.table th,.table td{padding:.875rem 1rem;text-align:left;font-size:.875rem;border-bottom:1px solid var(--border-color)}.table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-secondary);white-space:nowrap}.table tbody tr:hover{background:var(--bg-hover)}.asset-info{display:flex;flex-direction:column;gap:.25rem}.asset-serial{font-weight:600;color:var(--text-primary)}.asset-details{font-size:.75rem;color:var(--text-muted)}.method-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.method-badge.sold{background:#10b98126;color:#10b981}.method-badge.donated{background:#3b82f626;color:#3b82f6}.method-badge.recycled{background:#10b98126;color:#059669}.method-badge.destroyed{background:#ef444426;color:#ef4444}.method-badge.trade-in{background:#f59e0b26;color:#f59e0b}.bap-number{font-family:monospace;font-size:.875rem;color:var(--primary-color);font-weight:500}.reason-text{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary);font-size:.875rem}.value-display{font-family:monospace;font-size:.875rem}.value-display.positive{color:var(--success-color)}.action-buttons{display:flex;gap:.5rem}.btn-icon{width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.btn-icon:hover{background:var(--bg-hover);color:var(--primary-color);border-color:var(--primary-color)}.btn-icon.danger:hover{color:var(--danger-color);border-color:var(--danger-color)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow-y:auto}.modal{background:var(--bg-primary);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);margin:auto}.modal-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:all .2s ease}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-body{padding:1rem 1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:.875rem;flex:1;min-height:0}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem;flex-shrink:0;background:var(--bg-primary)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.form-label.required:after{content:" *";color:var(--danger-color)}.form-input,.form-select,.form-textarea{padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}.form-textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.form-hint{font-size:.75rem;color:var(--text-muted)}.asset-search-wrapper{position:relative}.asset-search-input{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;background:var(--bg-primary);color:var(--text-primary)}.asset-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);max-height:200px;overflow-y:auto;z-index:100;margin-top:.25rem;box-shadow:var(--shadow-md)}.asset-option{padding:.625rem .875rem;cursor:pointer;display:flex;flex-direction:column;gap:.125rem;border-bottom:1px solid var(--border-color)}.asset-option:hover{background:var(--bg-hover)}.asset-option.selected{background:#4f46e51a}.asset-option-serial{font-weight:600;color:var(--text-primary);font-size:.875rem}.asset-option-details{font-size:.75rem;color:var(--text-muted)}.selected-asset{display:flex;align-items:center;justify-content:space-between;padding:.625rem .875rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.selected-asset-info{display:flex;flex-direction:column;gap:.125rem}.selected-asset-serial{font-weight:600;color:var(--text-primary)}.selected-asset-details{font-size:.75rem;color:var(--text-muted)}.btn-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm)}.btn-clear:hover{color:var(--danger-color)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state-icon{margin-bottom:1rem;opacity:.5}.empty-state-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.empty-state-text{font-size:.875rem;margin-bottom:1rem}.pagination{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-top:1px solid var(--border-color);flex-wrap:wrap;gap:1rem}.pagination-info{font-size:.875rem;color:var(--text-secondary)}.pagination-controls{display:flex;gap:.5rem}.pagination-btn{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.25rem;font-size:.875rem}.pagination-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--primary-color);color:var(--primary-color)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}@media print{.disposal-page{padding:0}.page-header,.filters-bar,.action-buttons,.pagination{display:none!important}.card{box-shadow:none;border:1px solid #ddd}}.selected-assets-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;padding:.5rem;background:var(--bg-secondary);border-radius:.5rem;border:1px solid var(--border-color)}.selected-asset-chip{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:#10b981;color:#fff;border-radius:1rem;font-size:.875rem}.chip-serial{font-weight:600;font-family:var(--font-mono, monospace);color:#fff}.chip-type{opacity:.9;font-size:.75rem;color:#fff}.chip-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;border:none;background:#fff3;color:#fff;border-radius:50%;cursor:pointer;transition:background .2s}.chip-remove:hover{background:#fff6}.btn-clear-all{padding:.375rem .75rem;font-size:.75rem;background:var(--danger-color);color:#fff;border:none;border-radius:.375rem;cursor:pointer;transition:all .2s}.btn-clear-all:hover{background:#dc2626}@media(max-width:768px){.stats-grid{grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}.filters-bar{flex-direction:column}.search-filter{width:100%}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.modal{max-height:100vh;border-radius:0}}.ip-management-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.vlan-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.vlan-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-md);cursor:pointer;transition:all var(--transition-fast)}.vlan-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-300)}.vlan-card.selected{border-color:var(--primary-500);background:var(--primary-50)}.vlan-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.vlan-header svg{color:var(--primary-500)}.vlan-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.vlan-subnet{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.vlan-usage{display:flex;align-items:center;gap:var(--spacing-sm)}.usage-bar{flex:1;height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.usage-fill{height:100%;background:var(--primary-500);border-radius:var(--radius-full)}.vlan-usage span{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap}.row-conflict{background:var(--danger-light)!important}.vlan-mapping-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.search-bar{position:relative;max-width:400px;margin-bottom:var(--spacing-lg)}.search-bar .search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-bar .search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-sm) 44px;border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm);background:var(--bg-primary)}.search-bar .search-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.vlan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-md)}.vlan-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-lg);transition:all var(--transition-fast)}.vlan-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-200)}.vlan-header{display:flex;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.vlan-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-50);color:var(--primary-600);border-radius:var(--radius-lg);flex-shrink:0}.vlan-title{flex:1}.vlan-title h3{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.vlan-actions{display:flex;gap:var(--spacing-xs)}.action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.vlan-details{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md) 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);margin-bottom:var(--spacing-sm)}.detail-row{display:flex;justify-content:space-between;align-items:center}.detail-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;font-weight:500}.detail-value{font-size:var(--text-sm);color:var(--text-primary)}.vlan-description{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-md)}.vlan-stats{display:flex;gap:var(--spacing-lg)}.vlan-stat{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--text-muted)}.switch-ports-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.switch-info{margin-bottom:var(--spacing-lg)}.switch-header{display:flex;align-items:center;gap:var(--spacing-lg)}.switch-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--primary-50);color:var(--primary-600);border-radius:var(--radius-xl);flex-shrink:0}.switch-details{flex:1}.switch-details h3{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.switch-details p{font-size:var(--text-sm);color:var(--text-secondary)}.switch-stats{display:flex;gap:var(--spacing-xl)}.mini-stat{display:flex;flex-direction:column;align-items:center}.stat-num{font-size:var(--text-2xl);font-weight:700}.stat-num.connected{color:var(--success)}.stat-num.unused{color:var(--text-muted)}.stat-label{font-size:var(--text-xs);color:var(--text-muted)}.search-filter{position:relative;flex:1;min-width:200px;max-width:300px}.status-filters{display:flex;gap:var(--spacing-xs)}.port-grid-visual{display:grid;grid-template-columns:repeat(24,1fr);gap:4px;padding:var(--spacing-lg);background:var(--bg-secondary)}@media(max-width:1200px){.port-grid-visual{grid-template-columns:repeat(12,1fr)}}@media(max-width:768px){.port-grid-visual{grid-template-columns:repeat(8,1fr)}}.port-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);gap:2px}.port-cell:hover{transform:scale(1.1);z-index:1;box-shadow:var(--shadow-md)}.port-cell.connected{border-color:var(--success);background:var(--success-light)}.port-cell.disabled{border-color:var(--danger);background:var(--danger-light)}.port-num{font-size:10px;font-weight:600;color:var(--text-primary)}.status-dot{fill:currentColor}.status-dot.success{color:var(--success)}.status-dot.muted{color:var(--text-muted)}.status-dot.danger{color:var(--danger)}.port-badge{display:inline-flex;align-items:center;justify-content:center;width:32px;height:24px;background:var(--bg-secondary);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:600;color:var(--text-primary)}.status-indicator{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm);text-transform:capitalize}.status-indicator.connected{color:var(--success)}.status-indicator.unused{color:var(--text-muted)}.status-indicator.disabled{color:var(--danger)}.device-info{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm)}.switch-navigation{margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.switch-selector{display:flex;gap:var(--spacing-sm);overflow-x:auto;padding-bottom:0}.switch-tab{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.switch-tab:hover{color:var(--primary-600);background:var(--bg-secondary)}.switch-tab.active{color:var(--primary-600);border-bottom-color:var(--primary-600);background:var(--primary-50)}.btn-icon-sm{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-icon-sm:hover{border-color:var(--primary-300);color:var(--primary-600);background:var(--bg-secondary)}.btn-icon-sm.danger:hover{border-color:var(--danger-300);color:var(--danger);background:var(--danger-50)}.device-modal{background:var(--bg-primary);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}.form-error{padding:var(--spacing-sm) var(--spacing-md);background:var(--danger-light);color:var(--danger);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--spacing-md)}.form-label{display:flex;align-items:center;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-sm);background:var(--bg-secondary);color:var(--text-primary);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--primary-500);background:var(--bg-primary)}.type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--spacing-sm)}.type-option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--bg-secondary);border:2px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.type-option:hover{border-color:var(--border-color)}.type-option.active{border-color:var(--primary-500);background:var(--primary-50);color:var(--primary-600)}.type-option span{font-size:var(--text-xs);font-weight:500}.form-row{display:flex;gap:var(--spacing-md)}@media(max-width:500px){.device-modal{max-width:100%;max-height:100%;border-radius:0}.type-grid{grid-template-columns:repeat(3,1fr)}}.monitor-settings-modal{background:var(--bg-primary);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}.modal-header h2{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-lg);font-weight:600;margin:0}.modal-body.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted)}.scheduler-status{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;margin-bottom:var(--spacing-lg)}.scheduler-status.running{background:var(--success-light);color:var(--success)}.scheduler-status.stopped{background:var(--bg-tertiary);color:var(--text-muted)}.scheduler-status .status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.settings-section{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.settings-section:last-of-type{border-bottom:none}.settings-section h3{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md)}.toggle-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.toggle-label input{accent-color:var(--primary-600);width:18px;height:18px}.form-help{font-size:var(--text-xs);color:var(--text-muted);margin-top:4px}.form-input,.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-sm);background:var(--bg-secondary);color:var(--text-primary);transition:all var(--transition-fast)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary-500);background:var(--bg-primary)}.form-input:disabled,.form-select:disabled{opacity:.5;cursor:not-allowed}.test-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}@media(max-width:500px){.monitor-settings-modal{max-width:100%;max-height:100%;border-radius:0}}.network-monitor-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.header-actions{display:flex;gap:var(--spacing-sm);align-items:center;flex-wrap:wrap}.auto-refresh-toggle{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer}.auto-refresh-toggle input{accent-color:var(--primary-600)}.btn-icon{width:40px;height:40px;min-width:40px;display:flex;align-items:center;justify-content:center;padding:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon svg{width:18px!important;height:18px!important;min-width:18px;flex-shrink:0}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--primary-500)}.monitor-stats-bar{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);flex-wrap:wrap}.monitor-stats-bar .stat-item{display:flex;align-items:center;gap:var(--spacing-xs)}.stat-item .stat-value{font-size:var(--text-xl);font-weight:700}.stat-item .stat-label{font-size:var(--text-sm);color:var(--text-muted)}.stat-item.online{color:var(--success)}.stat-item.offline{color:var(--danger)}.stat-item.unknown{color:var(--text-muted)}.stat-item.last-check{margin-left:auto;font-size:var(--text-sm);color:var(--text-muted)}.device-table-container{overflow-x:auto}.device-list-skeleton{padding:var(--spacing-lg)}.device-table{width:100%;border-collapse:collapse}.device-table th,.device-table td{padding:var(--spacing-md) var(--spacing-lg);text-align:left;border-bottom:1px solid var(--border-color)}.device-table th{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-secondary)}.device-table tr:hover{background:var(--bg-secondary)}.device-table tr.disabled{opacity:.5}.device-name{display:flex;flex-direction:column}.device-name strong{font-size:var(--text-sm);color:var(--text-primary)}.device-desc{font-size:var(--text-xs);color:var(--text-muted)}.ip-address{font-family:var(--font-mono);font-size:var(--text-sm);background:var(--bg-tertiary);padding:2px 8px;border-radius:var(--radius-sm)}.device-type{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm);font-weight:500}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500}.status-badge.online{background:var(--success-light);color:var(--success)}.status-badge.offline{background:var(--danger-light);color:var(--danger)}.status-badge.unknown{background:var(--bg-tertiary);color:var(--text-muted)}.action-buttons{display:flex;gap:var(--spacing-xs)}@media(max-width:768px){.monitor-stats-bar{gap:var(--spacing-md)}.stat-item.last-check{margin-left:0;width:100%}.device-table th:nth-child(3),.device-table td:nth-child(3){display:none}}@media(max-width:480px){.header-actions{width:100%;justify-content:flex-end}.device-table th:nth-child(2),.device-table td:nth-child(2){display:none}}.network-scanner{padding:1.5rem}.network-scanner .page-header{margin-bottom:1.5rem}.network-scanner .page-header h1{margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.network-scanner .page-header p{margin:0;color:var(--text-secondary)}.scan-controls{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);margin-bottom:1.5rem}.ip-inputs{display:flex;align-items:flex-end;gap:1rem;flex-wrap:wrap}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.input-group input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;font-family:Monaco,Consolas,monospace;width:160px}.ip-separator{color:var(--text-secondary);font-size:1.25rem;padding-bottom:.5rem}.btn-scan{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem}.btn-scan .spin{animation:spin 1s linear infinite}.alert-error{margin-top:1rem;padding:.75rem 1rem;background:#fee2e2;color:#dc2626;border-radius:8px}.progress-container{margin-top:1rem;display:flex;align-items:center;gap:1rem}.progress-bar{flex:1;height:8px;background:var(--border-color);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--primary-color);transition:width .3s}.progress-fill.scanning{width:100%;background:linear-gradient(90deg,var(--primary-color),#8b5cf6,var(--primary-color));background-size:200% 100%;animation:scanning 1.5s ease-in-out infinite}@keyframes scanning{0%{background-position:200% 0}to{background-position:-200% 0}}.scan-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--card-bg);border-radius:12px;padding:1.25rem;text-align:center;border:1px solid var(--border-color)}.stat-card .stat-value{display:block;font-size:1.75rem;font-weight:700;color:var(--text-primary)}.stat-card .stat-label{font-size:.85rem;color:var(--text-secondary)}.stat-card.online .stat-value{color:#10b981}.stat-card.offline .stat-value{color:#ef4444}.scan-results{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.results-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--card-header-bg)}.results-header h2{margin:0;font-size:1rem;font-weight:600}.results-actions{display:flex;gap:.75rem}.results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;padding:1rem;max-height:500px;overflow-y:auto}.device-card{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;border:1px solid var(--border-color);cursor:pointer;transition:all .2s}.device-card.online{background:#10b9810d;border-color:#10b98133}.device-card.online:hover{background:#10b9811a;border-color:#10b98166}.device-card.online.selected{background:#10b98126;border-color:#10b981}.device-card.offline{background:#ef444408;border-color:#ef44441a;opacity:.6;cursor:default}.device-status{flex-shrink:0}.status-icon.online{color:#10b981}.status-icon.offline{color:#ef4444}.device-info{flex:1;min-width:0}.device-ip{display:block;font-family:Monaco,Consolas,monospace;font-weight:600;font-size:.9rem}.device-hostname{display:block;font-size:.75rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-latency{display:block;font-size:.75rem;color:var(--text-secondary)}.device-card input[type=checkbox]{width:18px;height:18px;cursor:pointer}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary);text-align:center}.empty-state svg{margin-bottom:1rem;opacity:.3}@media(max-width:768px){.ip-inputs{flex-direction:column;align-items:stretch}.input-group input{width:100%}.ip-separator{display:none}.btn-scan{width:100%;justify-content:center}.scan-stats{grid-template-columns:repeat(2,1fr)}.results-header{flex-direction:column;gap:1rem;align-items:stretch}.results-actions{flex-direction:column}}.locations-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.location-tree{padding:var(--spacing-sm) 0}.location-item{border-bottom:1px solid var(--border-color)}.location-item:last-child{border-bottom:none}.location-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);transition:background var(--transition-fast)}.location-row:hover{background:var(--bg-secondary)}.expand-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);flex-shrink:0}.expand-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.expand-placeholder{width:24px;flex-shrink:0}.location-icon{color:var(--text-muted);flex-shrink:0}.location-row.level-0 .location-icon{color:var(--primary-500)}.location-row.level-1 .location-icon{color:var(--secondary-500)}.location-row.level-2 .location-icon{color:var(--success)}.location-name{flex:1;font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.asset-count{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--text-muted);padding:2px 8px;background:var(--bg-secondary);border-radius:var(--radius-full)}.location-actions{display:flex;gap:var(--spacing-xs);opacity:0;transition:opacity var(--transition-fast)}.location-row:hover .location-actions{opacity:1}.location-actions .action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.location-actions .action-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.location-actions .action-btn.danger:hover{background:var(--danger-light);color:var(--danger)}.location-children{background:var(--bg-secondary)}.asset-breakdown{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.asset-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:600;white-space:nowrap}.asset-badge.empty{background:var(--bg-secondary);color:var(--text-muted)}.asset-badge svg{flex-shrink:0}.deployments-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.status-filters{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.filter-chip{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.user-info{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm)}.action-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.transfer-history-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.form-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm);background:var(--bg-primary);color:var(--text-primary);cursor:pointer}.bast-id{color:var(--primary-600);font-weight:500}.asset-info{display:flex;flex-direction:column}.asset-info .text-muted{font-size:var(--text-xs)}.location-flow{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-sm)}.action-btn:hover{background:var(--bg-secondary);color:var(--primary-600)}.bast-page{max-width:800px}.bast-steps{display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--bg-primary);border-radius:var(--radius-xl);border:1px solid var(--border-color)}.step{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-muted)}.step.active{color:var(--primary-600)}.step.completed{color:var(--success)}.step-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--bg-tertiary);font-weight:600;font-size:var(--text-sm)}.step.active .step-number{background:var(--primary-600);color:#fff}.step.completed .step-number{background:var(--success);color:#fff}.step span{font-size:var(--text-sm);font-weight:500}.step-line{flex:1;height:2px;background:var(--border-color);margin:0 var(--spacing-md);max-width:100px}.search-box-wrapper{position:relative;margin-bottom:var(--spacing-md)}.search-box-wrapper .search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-input-full{width:100%;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-sm) 44px;border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm)}.search-input-full:focus{outline:none;border-color:var(--primary-500)}.asset-selection-list{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.asset-checkbox-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.asset-checkbox-item:hover{background:var(--bg-secondary);border-color:var(--primary-300)}.asset-checkbox-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-600)}.asset-checkbox-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.selected-summary{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--primary-50);border-radius:var(--radius-lg);color:var(--primary-700);font-weight:500}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.bast-preview{display:flex;flex-direction:column;gap:var(--spacing-lg)}.preview-section{padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-lg)}.preview-section h4{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.preview-list{list-style:none;display:flex;flex-direction:column;gap:var(--spacing-xs)}.preview-list li{font-size:var(--text-sm);color:var(--text-primary)}.preview-grid{display:flex;flex-direction:column;gap:var(--spacing-sm)}.preview-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-sm);color:var(--text-secondary)}.preview-item strong{color:var(--text-primary)}.preview-notes{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--border-color);font-size:var(--text-sm);color:var(--text-secondary)}.recorded-by{background:var(--success-light)}.recorded-by h4{color:var(--success)}.stock-opname-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.opname-list{display:flex;flex-direction:column}.opname-item{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:var(--spacing-lg);align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color);cursor:pointer;transition:background var(--transition-fast)}.opname-item:hover{background:var(--bg-secondary)}.opname-item.selected{background:var(--primary-50);border-left:3px solid var(--primary-500)}.opname-item:last-child{border-bottom:none}.opname-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.opname-header h4{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0}.opname-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.opname-meta span{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--text-secondary)}.opname-progress{min-width:150px}.progress-header{display:flex;justify-content:space-between;font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--spacing-xs)}.progress-bar{height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--primary-500);border-radius:var(--radius-full);transition:width var(--transition-base)}.opname-stats{display:flex;flex-direction:column;gap:var(--spacing-xs)}.opname-stat{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs)}.opname-stat.success{color:var(--success)}.opname-stat.danger{color:var(--danger)}.opname-stat.warning{color:var(--warning)}.opname-actions{display:flex;gap:var(--spacing-xs)}@media(max-width:900px){.opname-item{grid-template-columns:1fr;gap:var(--spacing-md)}}.qr-scanner-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.scanner-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}@media(max-width:900px){.scanner-layout{grid-template-columns:1fr}}.camera-select-row{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.camera-select-row label{font-size:var(--text-sm);font-weight:500;white-space:nowrap}.camera-select-row .form-select{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);font-size:var(--text-sm)}.scanner-preview{aspect-ratio:16/9;background:var(--gray-900);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-md);overflow:hidden;position:relative}.scanner-inactive{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);color:var(--gray-500)}.scanner-inactive span{font-size:var(--text-xs);opacity:.7}.scanner-icons{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.scanner-error{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);color:var(--danger)}.scanner-actions{margin-bottom:var(--spacing-md)}.qr-reader-active{width:100%;margin-bottom:var(--spacing-md);border-radius:var(--radius-lg);overflow:hidden}#qr-reader{width:100%!important;border:none!important}#qr-reader video{width:100%!important;border-radius:var(--radius-lg)!important;max-height:400px;object-fit:contain}#qr-reader__scan_region{background:var(--gray-900)!important;border-radius:var(--radius-lg);min-height:250px}#qr-reader__scan_region video{width:100%!important;height:auto!important}#qr-reader__dashboard{padding:var(--spacing-md)!important;background:var(--bg-secondary)!important;border-radius:var(--radius-md)!important;margin-top:var(--spacing-sm)!important}#qr-reader__dashboard button{background:var(--primary)!important;color:#fff!important;border:none!important;padding:var(--spacing-sm) var(--spacing-md)!important;border-radius:var(--radius-md)!important;cursor:pointer!important;font-weight:500!important}#qr-reader__dashboard button:hover{background:var(--primary-600)!important}#qr-reader__dashboard select{padding:var(--spacing-sm)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-md)!important;background:var(--bg-primary)!important;color:var(--text-primary)!important}#qr-reader__dashboard_section_csr{display:flex!important;flex-direction:column!important;gap:var(--spacing-sm)!important;align-items:center!important}#qr-reader__status_span{font-size:var(--text-sm)!important;color:var(--text-secondary)!important}.scanner-error{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);color:var(--danger);text-align:center;padding:var(--spacing-lg)}.scanner-error p{font-weight:600;margin:0}.scanner-error span{font-size:var(--text-xs);color:var(--text-muted);max-width:250px}.scanner-active{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}.scanner-frame{width:200px;height:200px;border:3px solid var(--primary-500);border-radius:var(--radius-lg);position:relative;overflow:hidden}.scanner-line{position:absolute;width:100%;height:2px;background:var(--primary-500);box-shadow:0 0 10px var(--primary-500);animation:scan 2s ease-in-out infinite}@keyframes scan{0%,to{top:0}50%{top:calc(100% - 2px)}}.scanner-controls{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.btn-full{width:100%}.manual-input{padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.input-label{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.manual-form{display:flex;gap:var(--spacing-sm)}.manual-form .form-input{flex:1}.results-section{display:flex;flex-direction:column;gap:var(--spacing-lg)}.scan-result.found{border-color:var(--success)}.scan-result.not-found{border-color:var(--danger)}.scan-time{font-size:var(--text-xs);color:var(--text-muted)}.result-content{display:flex;gap:var(--spacing-lg);align-items:flex-start}.result-icon{width:64px;height:64px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.result-icon.success{background:var(--success-light);color:var(--success)}.result-icon.danger{background:var(--danger-light);color:var(--danger)}.result-info h4{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.result-info p{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.result-details{display:flex;gap:var(--spacing-md)}.result-details span{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--text-muted)}.location-mismatch{display:flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-sm);padding:var(--spacing-sm);background:var(--warning-light);color:var(--warning);border-radius:var(--radius-md);font-size:var(--text-xs)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--text-muted);gap:var(--spacing-sm)}.scan-history-list{list-style:none;display:flex;flex-direction:column;gap:var(--spacing-xs)}.history-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-md);font-size:var(--text-sm)}.history-item.found{background:var(--success-light);color:var(--success)}.history-item.not-found{background:var(--danger-light);color:var(--danger)}.history-time{margin-left:auto;font-size:var(--text-xs);opacity:.7}.scan-mode-selector{display:flex;gap:4px;background:var(--bg-secondary);padding:4px;border-radius:var(--radius-md)}.mode-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;font-size:var(--text-xs);font-weight:500;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.mode-btn:hover{color:var(--text-primary)}.mode-btn.active{background:var(--primary);color:#fff}.scanner-icons{display:flex;gap:var(--spacing-lg);color:var(--gray-600);margin-bottom:var(--spacing-sm)}.scan-meta{display:flex;align-items:center;gap:var(--spacing-sm)}.scan-format{font-size:var(--text-xs);padding:2px 6px;background:var(--primary-100);color:var(--primary-700);border-radius:var(--radius-sm);font-weight:500}.history-format{font-size:10px;padding:2px 6px;background:#0000001a;border-radius:var(--radius-sm);font-weight:500}.formats-info .card-body{padding:var(--spacing-md)}.formats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.format-group h4{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.format-group ul{list-style:none;margin:0;padding:0}.format-group li{font-size:var(--text-xs);color:var(--text-muted);padding:2px 0}.camera-controls{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;margin-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.control-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;font-size:var(--text-xs);font-weight:500;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.control-btn:hover:not(:disabled){background:var(--bg-primary);border-color:var(--primary);color:var(--primary)}.control-btn:disabled{opacity:.5;cursor:not-allowed}.control-btn.active{background:var(--warning-light);border-color:var(--warning);color:var(--warning)}.zoom-controls{display:flex;align-items:center;gap:4px}.zoom-level{font-size:var(--text-xs);font-weight:600;color:var(--text-primary);min-width:36px;text-align:center}.scanning-tips{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--info-light);border-radius:var(--radius-md);border-left:3px solid var(--info)}.scanning-tips h4{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0}.scanning-tips ul{margin:0;padding-left:var(--spacing-md)}.scanning-tips li{font-size:var(--text-xs);color:var(--text-secondary);padding:2px 0}.result-content-full{display:flex;flex-direction:column;gap:var(--spacing-md)}.result-header{display:flex;align-items:center;gap:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.result-title h4{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0}.result-title p{font-size:var(--text-sm);color:var(--text-secondary);margin:var(--spacing-xs) 0 0 0}.result-section{padding:var(--spacing-sm) 0}.result-section h5{font-size:var(--text-sm);font-weight:600;color:var(--text-muted);margin:0 0 var(--spacing-sm) 0;text-transform:uppercase;letter-spacing:.5px}.result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-sm)}.result-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-md)}.result-item svg{color:var(--primary);flex-shrink:0}.result-item .label{font-size:var(--text-xs);color:var(--text-muted);min-width:60px}.result-item .value{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);word-break:break-word}.licenses-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.license-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-md);font-size:var(--text-sm)}.license-item svg{color:var(--warning);flex-shrink:0}.license-name{font-weight:500;flex:1}.license-expiry{font-size:var(--text-xs);color:var(--text-muted)}.result-actions{padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.result-actions .btn{width:100%}.zoom-control{display:flex;align-items:center;gap:var(--spacing-xs)}.zoom-value{font-size:var(--text-xs);font-weight:600;color:var(--text-primary);min-width:40px;text-align:center}.mode-tabs{display:flex;gap:var(--spacing-xs);padding:var(--spacing-xs);background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-lg);width:fit-content}.mode-tab{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--text-sm);font-weight:500;background:transparent;border:none;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.mode-tab:hover{background:var(--bg-secondary);color:var(--text-primary)}.mode-tab.active{background:var(--primary);color:#fff}@media(max-width:600px){.mode-tabs{width:100%}.mode-tab{flex:1;justify-content:center;padding:var(--spacing-sm)}.mode-tab span{display:none}}.opname-stats-bar{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--success-light);border:1px solid var(--success);border-radius:var(--radius-xl);margin-bottom:var(--spacing-lg)}.opname-stat{display:flex;flex-direction:column;align-items:center;min-width:80px}.opname-stat .stat-value{font-size:var(--text-2xl);font-weight:700;color:var(--success)}.opname-stat .stat-label{font-size:var(--text-xs);color:var(--text-secondary)}.opname-progress{flex:1;height:8px;background:#0000001a;border-radius:var(--radius-full);overflow:hidden}.opname-progress .progress-bar{height:100%;background:var(--success);border-radius:var(--radius-full);transition:width .3s ease}.transfer-location-bar{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--primary-50);border:1px solid var(--primary-200);border-radius:var(--radius-xl);margin-bottom:var(--spacing-lg)}.transfer-location-bar svg{color:var(--primary);flex-shrink:0}.transfer-location-bar label{font-weight:500;color:var(--text-primary);white-space:nowrap}.transfer-location-bar .form-select{flex:1;max-width:300px;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--primary-300);border-radius:var(--radius-md);background:var(--bg-primary)}.transfer-hint{font-size:var(--text-xs);color:var(--text-muted);font-style:italic}@media(max-width:768px){.transfer-location-bar{flex-wrap:wrap}.transfer-location-bar .form-select{max-width:100%;width:100%}.transfer-hint{width:100%}}.quick-actions{padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md)}.quick-actions h5{font-size:var(--text-sm);font-weight:600;color:var(--text-muted);margin:0 0 var(--spacing-sm) 0;text-transform:uppercase;letter-spacing:.5px}.quick-actions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm)}.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-xs);font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.quick-action-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-50);transform:translateY(-2px);box-shadow:var(--shadow-md);text-decoration:none}.quick-action-btn svg{opacity:.7}.quick-action-btn:hover svg{opacity:1}@media(max-width:500px){.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}.audit-logs-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.filters-bar{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);flex-wrap:wrap}.search-filter{position:relative;flex:1;min-width:250px;max-width:350px}.search-filter .search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-filter .search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-sm) 40px;border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm);background:var(--bg-secondary)}.action-filters{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.filter-chip{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.filter-chip:hover{border-color:var(--primary-300);color:var(--primary-600)}.filter-chip.active{background:var(--primary-600);border-color:var(--primary-600);color:#fff}.logs-list{display:flex;flex-direction:column}.log-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);transition:background var(--transition-fast)}.log-item:hover{background:var(--bg-secondary)}.log-item:last-child{border-bottom:none}.log-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0}.log-icon.success{background:var(--success-light);color:var(--success)}.log-icon.info{background:var(--info-light);color:var(--info)}.log-icon.warning{background:var(--warning-light);color:var(--warning)}.log-icon.danger{background:var(--danger-light);color:var(--danger)}.log-icon.primary{background:var(--primary-100);color:var(--primary-600)}.log-icon.secondary{background:var(--gray-100);color:var(--gray-600)}.log-content{flex:1}.log-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.action-badge{padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;text-transform:uppercase}.action-badge.success{background:var(--success-light);color:var(--success)}.action-badge.info{background:var(--info-light);color:var(--info)}.action-badge.warning{background:var(--warning-light);color:var(--warning)}.action-badge.danger{background:var(--danger-light);color:var(--danger)}.action-badge.primary{background:var(--primary-100);color:var(--primary-700)}.action-badge.secondary{background:var(--gray-100);color:var(--gray-700)}.log-target{font-weight:500;color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-sm)}.log-details{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.log-meta{display:flex;gap:var(--spacing-md)}.log-meta span{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--text-muted)}.pagination-info{font-size:var(--text-sm);color:var(--text-muted)}.pagination-controls{display:flex;gap:var(--spacing-xs)}.user-management{padding:0}.demo-notice{display:flex;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#ff6b6b22,#ee5a2422);border:1px solid #ff6b6b44;border-radius:8px;color:#ff6b6b;font-size:14px;font-weight:500;margin-bottom:16px}.demo-notice svg{flex-shrink:0}.demo-restricted{opacity:.5!important;cursor:not-allowed!important}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.search-bar{position:relative;margin-bottom:1rem}.search-bar .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-bar .form-input{padding-left:40px;width:100%;max-width:400px}.users-table-container{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.users-table th{background:var(--bg-secondary);font-weight:600;font-size:.75rem;text-transform:uppercase;color:var(--text-muted)}.users-table tbody tr:hover{background:var(--bg-hover)}.users-table tbody tr:last-child td{border-bottom:none}.user-name{display:flex;align-items:center;gap:10px;font-weight:500}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.role-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--primary-100);color:var(--primary-700);border-radius:999px;font-size:.75rem;font-weight:500}.actions{display:flex;gap:4px}.btn-icon{padding:6px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s}.btn-icon:hover{background:var(--bg-hover);color:var(--primary-600)}.btn-icon.danger:hover{background:var(--danger-100);color:var(--danger-600)}.empty-state{padding:3rem;text-align:center;color:var(--text-muted)}.empty-state svg{margin-bottom:.5rem;opacity:.5}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:768px){.form-row{grid-template-columns:1fr}.users-table th:nth-child(5),.users-table td:nth-child(5){display:none}}.modal-sm{max-width:400px}.role-management{padding:1rem 0}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.role-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;transition:all .2s}.role-card:hover{border-color:var(--primary-300);box-shadow:0 4px 12px #00000014}.role-card.system{border-left:3px solid var(--primary-500)}.role-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.role-info{display:flex;align-items:center;gap:.5rem}.role-info h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.system-badge{font-size:.625rem;padding:2px 6px;background:var(--primary-100);color:var(--primary-700);border-radius:999px;font-weight:600;text-transform:uppercase}.role-actions{display:flex;gap:4px}.role-description{font-size:.875rem;color:var(--text-muted);margin-bottom:1rem;line-height:1.4}.role-stats{display:flex;gap:1rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.role-stats .stat{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-muted)}.permissions-section{margin-top:1.5rem}.permissions-section>label{display:block;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.permissions-grid{max-height:400px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--radius-md)}.permission-category{border-bottom:1px solid var(--border-color)}.permission-category:last-child{border-bottom:none}.category-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.category-header:hover{background:var(--bg-hover)}.category-checkbox{flex:1;display:flex;align-items:center;gap:.5rem}.category-name{font-weight:600;font-size:.875rem;color:var(--text-primary)}.category-count{font-size:.75rem;color:var(--text-muted);margin-left:auto}.permission-list{padding:.5rem 0;background:var(--card-bg)}.permission-item{display:flex;align-items:flex-start;gap:.75rem;padding:.5rem 1rem .5rem 2.5rem}.permission-item:hover{background:var(--bg-hover)}.permission-info{display:flex;flex-direction:column}.permission-name{font-size:.875rem;color:var(--text-primary)}.permission-desc{font-size:.75rem;color:var(--text-muted)}.checkbox-label{display:flex;align-items:center;cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;margin:0;cursor:pointer;accent-color:var(--primary-600)}.modal-footer{display:flex;justify-content:space-between;align-items:center}.selected-count{font-size:.875rem;color:var(--text-muted)}.footer-buttons{display:flex;gap:.5rem}.modal-lg{max-width:700px;width:100%}@media(max-width:768px){.roles-grid{grid-template-columns:1fr}.modal-footer{flex-direction:column;gap:1rem;align-items:stretch}.footer-buttons{justify-content:flex-end}}.branding-settings{padding:0}.branding-header{margin-bottom:24px}.branding-header h2{display:flex;align-items:center;gap:12px;font-size:1.5rem;color:#fff;margin-bottom:8px}.branding-header p{color:#9ca3af;margin:0}.branding-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#9ca3af}.branding-loading .spin{animation:spin 1s linear infinite}.branding-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:24px}.branding-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:24px}.branding-card.full-width{grid-column:1 / -1}.branding-card h3{display:flex;align-items:center;gap:8px;font-size:1.1rem;color:#fff;margin-bottom:8px}.branding-card>p{color:#6b7280;font-size:.85rem;margin-bottom:16px}.logo-preview,.favicon-preview{display:flex;align-items:center;justify-content:center;background:#0000004d;border-radius:12px;padding:20px;margin-bottom:16px}.logo-preview img{max-width:150px;max-height:150px;object-fit:contain}.favicon-preview img{max-width:64px;max-height:64px;object-fit:contain}.form-group{margin-bottom:16px}.form-group label{display:block;color:#9ca3af;font-size:.9rem;margin-bottom:8px}.form-group input[type=text]{width:100%;padding:12px 16px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:1rem}.form-group input[type=text]:focus{outline:none;border-color:#10b981}.color-picker{display:flex;gap:12px;align-items:center}.color-picker input[type=color]{width:50px;height:50px;border:none;border-radius:8px;cursor:pointer;background:transparent}.color-picker input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker input[type=color]::-webkit-color-swatch{border-radius:8px;border:2px solid rgba(255,255,255,.2)}.color-picker input[type=text]{flex:1;max-width:150px}.branding-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08)}.alert{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;margin-bottom:16px}.alert-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.alert-success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#10b981}.alert button{margin-left:auto;background:none;border:none;color:inherit;font-size:1.2rem;cursor:pointer;padding:0 4px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;border:none;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.btn-secondary{background:#ffffff14;color:#fff;border:1px solid rgba(255,255,255,.15)}.btn-secondary:hover:not(:disabled){background:#ffffff1f}.btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.branding-grid{grid-template-columns:1fr}.branding-actions{flex-direction:column}.branding-actions .btn{width:100%;justify-content:center}}.settings-page .page-header{margin-bottom:var(--spacing-lg)}.settings-layout{display:grid;grid-template-columns:240px 1fr;gap:var(--spacing-lg)}@media(max-width:768px){.settings-layout{grid-template-columns:1fr}}.settings-sidebar{display:flex;flex-direction:column;gap:var(--spacing-lg)}.settings-nav{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs)}.settings-nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:left}.settings-nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.settings-nav-item.active{background:var(--primary-50);color:var(--primary-700)}.logout-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px solid var(--danger);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;color:var(--danger);cursor:pointer;transition:all var(--transition-fast)}.logout-btn:hover{background:var(--danger);color:#fff}.settings-content .card{margin-bottom:var(--spacing-lg)}.profile-header{display:flex;align-items:center;gap:var(--spacing-lg);padding-bottom:var(--spacing-lg);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.avatar-large{width:80px;height:80px;background:var(--primary-100);color:var(--primary-600);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.profile-info h3{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.profile-info p{font-size:var(--text-sm);color:var(--text-secondary)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}@media(max-width:600px){.form-grid{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-label{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.form-input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-primary);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.form-actions{display:flex;justify-content:flex-end;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.save-check{color:var(--success);margin-left:var(--spacing-xs)}.notification-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.notification-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-lg);cursor:pointer;transition:background var(--transition-fast)}.notification-item:hover{background:var(--bg-tertiary)}.notification-info{display:flex;flex-direction:column;gap:2px}.notification-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.notification-desc{font-size:var(--text-xs);color:var(--text-muted)}.toggle{width:44px;height:24px;appearance:none;background:var(--gray-300);border-radius:var(--radius-full);position:relative;cursor:pointer;transition:background var(--transition-fast)}.toggle:checked{background:var(--primary-500)}.toggle:before{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:var(--radius-full);top:2px;left:2px;transition:transform var(--transition-fast);box-shadow:var(--shadow-sm)}.toggle:checked:before{transform:translate(20px)}.theme-selector h4{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md)}.theme-options{display:flex;gap:var(--spacing-md)}.theme-option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast);min-width:100px}.theme-option:hover{border-color:var(--primary-300)}.theme-option.active{border-color:var(--primary-500);background:var(--primary-50)}.theme-option span{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.backup-restore{padding:1.5rem}.backup-restore .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.backup-restore .header-content h1{display:flex;align-items:center;gap:.5rem;margin:0 0 .5rem;font-size:1.5rem}.backup-restore .header-content p{margin:0;color:var(--text-secondary)}.backup-restore .header-actions{display:flex;gap:.75rem}.backup-restore .alert{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:8px;margin-bottom:1rem}.backup-restore .alert-error{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.backup-restore .alert-success{background:#d1fae5;color:#059669;border:1px solid #a7f3d0}.backup-restore .alert button{margin-left:auto;background:none;border:none;font-size:1.25rem;cursor:pointer;opacity:.7}.warning-box{display:flex;gap:1rem;padding:1rem 1.25rem;background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;margin-bottom:1.5rem;color:#92400e}.warning-box svg{flex-shrink:0;margin-top:.1rem}.backup-list{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.list-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--card-header-bg)}.list-header h2{margin:0;font-size:1rem;font-weight:600}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary)}.loading-state .spin,.empty-state svg{margin-bottom:1rem;opacity:.5}.empty-state h3{margin:0 0 .5rem;color:var(--text-primary)}.empty-state p{margin:0}.backup-grid{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.backup-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border:1px solid var(--border-color);border-radius:10px;background:var(--card-bg);transition:all .2s}.backup-card:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #0000000d}.backup-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:10px;color:#fff}.backup-info{flex:1;min-width:0}.backup-name{display:block;font-weight:600;font-size:.9rem;margin-bottom:.25rem;font-family:Monaco,Consolas,monospace}.backup-meta{display:flex;gap:1.5rem;font-size:.8rem;color:var(--text-secondary)}.backup-meta span{display:flex;align-items:center;gap:.35rem}.backup-actions{display:flex;gap:.5rem}.backup-actions .btn-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--border-color);background:var(--card-bg);cursor:pointer;transition:all .2s}.backup-actions .btn-icon:hover{background:var(--hover-bg)}.backup-actions .btn-warning:hover{background:#fef3c7;border-color:#f59e0b;color:#d97706}.backup-actions .btn-danger:hover{background:#fee2e2;border-color:#ef4444;color:#dc2626}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.confirm-modal{background:var(--card-bg);border-radius:16px;max-width:450px;width:100%;overflow:hidden;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header.warning{background:#fef3c7;color:#d97706}.modal-header.danger{background:#fee2e2;color:#dc2626}.modal-header h3{margin:0;font-size:1.1rem}.modal-body{padding:1.5rem}.modal-body p{margin:0 0 .75rem}.modal-body code{display:block;padding:.75rem 1rem;background:var(--hover-bg);border-radius:8px;font-size:.85rem;margin-bottom:1rem;word-break:break-all}.modal-body .warning-text{color:#dc2626;font-weight:500;margin:0}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color);background:var(--card-header-bg)}.btn-warning{background:#f59e0b;color:#fff;border:none}.btn-warning:hover{background:#d97706}.btn-danger{background:#ef4444;color:#fff;border:none}.btn-danger:hover{background:#dc2626}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.backup-restore .page-header{flex-direction:column}.backup-restore .header-actions{width:100%}.backup-restore .header-actions .btn{flex:1}.backup-card{flex-wrap:wrap}.backup-info{flex-basis:calc(100% - 64px)}.backup-actions{width:100%;justify-content:flex-end;margin-top:.5rem}.backup-meta{flex-wrap:wrap;gap:.75rem}}.task-modal{background:var(--bg-primary);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:var(--text-lg);font-weight:600;margin:0}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-sm);background:var(--bg-secondary);color:var(--text-primary);transition:all var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-500);background:var(--bg-primary)}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.input-with-icon{position:relative}.input-icon{position:absolute;left:var(--spacing-sm);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.form-input.with-icon{padding-left:36px}.asset-search,.search-input-wrapper{position:relative}.search-input-wrapper .search-icon{position:absolute;left:var(--spacing-sm);top:50%;transform:translateY(-50%);color:var(--text-muted)}.asset-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;max-height:200px;overflow-y:auto;margin-top:4px}.asset-option{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-bottom:1px solid var(--border-color);cursor:pointer;text-align:left;transition:background var(--transition-fast)}.asset-option:last-child{border-bottom:none}.asset-option:hover{background:var(--bg-secondary)}.asset-option strong{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary)}.asset-option span{font-size:var(--text-xs);color:var(--text-muted)}.selected-asset{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--primary-50);border:1px solid var(--primary-200);border-radius:var(--radius-md)}.selected-asset .asset-info{display:flex;flex-direction:column}.selected-asset .asset-info strong{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--primary-700)}.selected-asset .asset-detail{font-size:var(--text-xs);color:var(--text-muted)}.clear-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer}.clear-btn:hover{background:var(--danger-light);color:var(--danger)}.subtasks-editor{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-sm)}.subtask-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border-bottom:1px solid var(--border-color)}.subtask-row:last-of-type{border-bottom:none}.subtask-checkbox{width:16px;height:16px;accent-color:var(--primary-600)}.subtask-text{flex:1;font-size:var(--text-sm);color:var(--text-primary)}.subtask-text.completed{text-decoration:line-through;color:var(--text-muted)}.subtask-remove{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer}.subtask-remove:hover{background:var(--danger-light);color:var(--danger)}.add-subtask{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--border-color)}.add-subtask .form-input{flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding-top:var(--spacing-lg);margin-top:var(--spacing-md);border-top:1px solid var(--border-color)}@media(max-width:600px){.task-modal{max-width:100%;max-height:100%;border-radius:0}.form-row{grid-template-columns:1fr}}.task-list-page .page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.header-actions{display:flex;gap:var(--spacing-sm)}.task-stats-bar{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.stat-item{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-sm) var(--spacing-lg);min-width:80px}.stat-value{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary)}.stat-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.stat-pending{color:var(--warning)}.stat-progress{color:var(--info)}.stat-completed{color:var(--success)}.stat-overdue{color:var(--danger)}.filters-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);flex-wrap:wrap}.filter-tabs{display:flex;gap:var(--spacing-xs)}.filter-tab{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--spacing-xs)}.filter-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.filter-tab.active{background:var(--primary-600);color:#fff}.tab-badge{background:var(--danger);color:#fff;font-size:10px;padding:2px 6px;border-radius:var(--radius-full);font-weight:600}.search-filter{position:relative;min-width:200px}.search-filter .search-icon{position:absolute;left:var(--spacing-sm);top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-filter .search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-sm) 32px;border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm);background:var(--bg-secondary)}.search-filter .search-input:focus{outline:none;border-color:var(--primary-500);background:var(--bg-primary)}.task-list{padding:var(--spacing-md)}.task-list-skeleton{padding:var(--spacing-lg)}.task-item{background:var(--bg-secondary);border-radius:var(--radius-lg);margin-bottom:var(--spacing-sm);overflow:hidden;transition:all var(--transition-fast);border:1px solid transparent}.task-item:hover{border-color:var(--border-color);box-shadow:var(--shadow-sm)}.task-item.completed{opacity:.7}.task-item.completed .task-title{text-decoration:line-through;color:var(--text-muted)}.task-item.overdue:not(.completed){border-left:3px solid var(--danger)}.task-main{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg)}.task-checkbox{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);margin-top:2px}.task-checkbox:hover{background:var(--bg-tertiary)}.task-checkbox.status-pending{color:var(--text-muted)}.task-checkbox.status-progress{color:var(--info)}.task-checkbox.status-completed{color:var(--success)}.task-content{flex:1;min-width:0;cursor:pointer}.task-header{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.task-title{font-size:var(--text-base);font-weight:500;color:var(--text-primary);margin:0}.priority-badge{padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:600;text-transform:uppercase}.priority-urgent{background:var(--danger);color:#fff}.priority-high{background:#f97316;color:#fff}.priority-medium{background:var(--warning);color:#1f2937}.priority-low{background:var(--success-light);color:var(--success)}.task-description{font-size:var(--text-sm);color:var(--text-secondary);margin:var(--spacing-xs) 0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.task-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.meta-item{display:flex;align-items:center;gap:4px;font-size:var(--text-xs);color:var(--text-muted);padding:2px 8px;background:var(--bg-tertiary);border-radius:var(--radius-sm)}.meta-item.due-date.overdue{background:var(--danger-light);color:var(--danger)}.meta-item.asset{font-family:var(--font-mono)}.task-actions{display:flex;gap:var(--spacing-xs);flex-shrink:0}.action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.action-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.action-btn.danger:hover{background:var(--danger-light);color:var(--danger)}.action-btn.expand-btn{color:var(--text-muted)}.subtasks-list{padding:0 var(--spacing-lg) var(--spacing-md);padding-left:calc(var(--spacing-lg) + 44px);border-top:1px solid var(--border-color);background:var(--bg-primary)}.subtask-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-color)}.subtask-item:last-child{border-bottom:none}.subtask-checkbox{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.subtask-item.completed .subtask-checkbox{color:var(--success)}.subtask-title{font-size:var(--text-sm);color:var(--text-secondary)}.subtask-item.completed .subtask-title{text-decoration:line-through;color:var(--text-muted)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color)}.pagination-info{font-size:var(--text-sm);color:var(--text-secondary)}.pagination-controls{display:flex;gap:var(--spacing-xs);align-items:center}.pagination-page{padding:0 var(--spacing-md);font-size:var(--text-sm);color:var(--text-secondary)}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.task-stats-bar{flex-wrap:wrap;justify-content:space-around}.stat-item{min-width:60px;padding:var(--spacing-xs) var(--spacing-sm)}.stat-value{font-size:var(--text-xl)}.filters-bar{flex-direction:column;align-items:stretch}.filter-tabs{overflow-x:auto;padding-bottom:var(--spacing-sm)}.search-filter{min-width:100%}.task-main{flex-wrap:wrap}.task-actions{width:100%;justify-content:flex-end;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--border-color)}.pagination{flex-direction:column;gap:var(--spacing-sm)}}.app{min-height:100vh}.main-content{margin-left:var(--sidebar-width);margin-top:var(--header-height);padding:var(--spacing-lg);min-height:calc(100vh - var(--header-height));transition:margin-left var(--transition-base)}.main-content.expanded{margin-left:var(--sidebar-collapsed-width)}.page-header{margin-bottom:var(--spacing-lg)}.page-title{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.page-subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.card-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-sm)}.card-body{padding:var(--spacing-lg)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-lg);display:flex;align-items:flex-start;gap:var(--spacing-md);transition:all var(--transition-fast)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.primary{background:var(--primary-100);color:var(--primary-600)}.stat-icon.secondary{background:var(--secondary-100);color:var(--secondary-600)}.stat-icon.success{background:var(--success-light);color:var(--success)}.stat-icon.warning{background:var(--warning-light);color:var(--warning)}.stat-icon.danger{background:var(--danger-light);color:var(--danger)}.stat-content{flex:1}.stat-value{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:var(--spacing-xs)}.stat-label{font-size:var(--text-sm);color:var(--text-secondary)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}@media(max-width:1024px){.grid-2,.grid-3{grid-template-columns:1fr}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--text-sm);font-weight:500;font-family:inherit;border-radius:var(--radius-lg);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn:hover{text-decoration:none}.btn-primary{background:var(--primary-600);color:#fff}.btn-primary:hover{background:var(--primary-700)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover{background:var(--bg-tertiary)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--text-xs)}.badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-full)}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:var(--info-light);color:var(--info)}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-color)}.table th{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:var(--bg-secondary)}.table td{font-size:var(--text-sm);color:var(--text-primary)}.table tbody tr:hover{background:var(--bg-secondary)}.activity-list{list-style:none}.activity-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-color)}.activity-item:last-child{border-bottom:none}.activity-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--primary-500);margin-top:6px;flex-shrink:0}.activity-content{flex:1}.activity-text{font-size:var(--text-sm);color:var(--text-primary)}.activity-time{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}@media(max-width:900px){.main-content{margin-left:0;padding:var(--spacing-md)}.main-content.expanded{margin-left:0}.page-title{font-size:var(--text-xl)}.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.stat-card{padding:var(--spacing-md)}.stat-icon{width:40px;height:40px}.stat-value{font-size:var(--text-xl)}}@media(max-width:600px){:root{--header-height: 56px}.main-content{padding:var(--spacing-sm);margin-top:var(--header-height)}.page-header{margin-bottom:var(--spacing-md)}.page-title{font-size:var(--text-lg)}.page-subtitle{font-size:var(--text-xs)}.card{border-radius:var(--radius-lg)}.card-header{padding:var(--spacing-sm) var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-sm)}.card-body{padding:var(--spacing-md)}.stats-grid{grid-template-columns:1fr 1fr;gap:var(--spacing-xs)}.stat-card{padding:var(--spacing-sm);gap:var(--spacing-sm)}.stat-icon{width:32px;height:32px}.stat-icon svg{width:16px;height:16px}.stat-value{font-size:var(--text-lg)}.stat-label{font-size:var(--text-xs)}.btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--text-xs)}.table-wrapper{margin:0 calc(-1 * var(--spacing-md));padding:0 var(--spacing-md);overflow-x:auto;-webkit-overflow-scrolling:touch}.table th,.table td{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--text-xs);white-space:nowrap}.header-actions{gap:var(--spacing-xs)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.page-header .header-actions{width:100%;justify-content:flex-start}}.demo-banner{position:fixed;top:0;left:0;right:0;background:linear-gradient(90deg,#ff6b6b,#ee5a24,#ff6b6b);background-size:200% 100%;animation:gradientMove 3s ease infinite;color:#fff;text-align:center;padding:8px 16px;font-size:14px;font-weight:600;z-index:10000;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 2px 10px #0003}@keyframes gradientMove{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.demo-banner-icon{font-size:18px}.demo-banner-text{display:flex;gap:8px}.demo-banner-link{color:#fff;text-decoration:underline;cursor:pointer}.demo-banner-link:hover{opacity:.9}.app-with-demo-banner .header{top:40px}.app-with-demo-banner .sidebar{top:40px;height:calc(100vh - 40px)}.app-with-demo-banner .main-content{padding-top:110px}.demo-restricted{opacity:.5;cursor:not-allowed!important;position:relative}.demo-restricted:after{content:"🔒";position:absolute;right:8px;font-size:12px}.demo-restricted-tooltip{position:relative}.demo-restricted-tooltip:hover:before{content:"Tidak tersedia di mode demo";position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;white-space:nowrap;z-index:1000}@media(max-width:768px){.demo-banner{font-size:12px;padding:6px 12px}.demo-banner-text span:last-child{display:none}}
