@import url(https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600&family=Geist+Mono:wght@400;500&display=swap);@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap);@import url(https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap);@import url(https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&family=DM+Mono:wght@400;500&display=swap);html{font-size:16px}@media (max-width:768px){html{font-size:14px}}.container{margin-left:auto;margin-right:auto;padding-left:15px;padding-right:15px;width:100%}@media (min-width:576px){.container{max-width:540px}}@media (min-width:768px){.container{max-width:720px}}@media (min-width:992px){.container{max-width:960px}}@media (min-width:1200px){.container{max-width:1140px}}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}@media (max-width:768px){h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:1rem}.p-4{padding:1.5rem}.p-5{padding:3rem}.m-1{margin:.25rem}.m-2{margin:.5rem}.m-3{margin:1rem}.m-4{margin:1.5rem}.m-5{margin:3rem}.d-none{display:none}.d-block{display:block}.d-flex{display:flex}.d-grid{display:grid}@media (max-width:576px){.d-sm-none{display:none}.d-sm-block{display:block}.d-sm-flex{display:flex}}@media (min-width:768px){.d-md-none{display:none}.d-md-block{display:block}.d-md-flex{display:flex}}@media (min-width:992px){.d-lg-none{display:none}.d-lg-block{display:block}.d-lg-flex{display:flex}}.flex-column{flex-direction:column}.flex-row{flex-direction:row}.justify-content-center{justify-content:center}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.flex-wrap{flex-wrap:wrap}@media (max-width:768px){.flex-md-column{flex-direction:column}.flex-md-row{flex-direction:row}}.w-100{width:100%}.w-75{width:75%}.w-50{width:50%}.w-25{width:25%}@media (max-width:768px){.w-md-100{width:100%}}@media (hover:none) and (pointer:coarse){a,button,input[type=button],input[type=submit]{min-height:44px;min-width:44px}}html{scroll-behavior:smooth}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}.data-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.data-table-wrapper{overflow-x:auto}.data-table{border-collapse:collapse;font-size:14px;width:100%}.data-table th{background-color:#f8f9fa;border-bottom:2px solid #dee2e6;color:#495057;font-weight:600;padding:12px 16px;text-align:left;white-space:nowrap}.data-table th.sortable{cursor:pointer;transition:background-color .2s;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover{background-color:#e9ecef}.th-content{align-items:center;display:flex;gap:8px;justify-content:space-between}.sort-icon{color:#6c757d;font-size:12px;opacity:.6;transition:opacity .2s}.sort-icon.active{color:#007bff;opacity:1}.data-table td{border-bottom:1px solid #dee2e6;padding:12px 16px;vertical-align:middle}.data-table tbody tr{transition:background-color .2s}.data-table tbody tr:hover{background-color:#f8f9fa}.data-table tbody tr.clickable{cursor:pointer}.data-table tbody tr.clickable:hover{background-color:#e3f2fd}.no-data{color:#6c757d;font-style:italic;padding:40px 16px;text-align:center}.data-table-loading{align-items:center;color:#6c757d;display:flex;gap:12px;justify-content:center;padding:40px}.loading-spinner{border:2px solid #f3f3f3;border-top-color:#007bff;height:20px;width:20px}.data-table-pagination{align-items:center;background-color:#f8f9fa;border-top:1px solid #dee2e6;display:flex;justify-content:space-between;padding:16px}.pagination-info{color:#6c757d;font-size:14px}.pagination-controls{align-items:center;display:flex;gap:16px}.pagination-btn{background:#fff;border:1px solid #dee2e6;color:#495057;font-size:14px;padding:6px 12px;transition:all .2s}.pagination-btn:hover:not(:disabled){background-color:#007bff;border-color:#007bff;color:#fff}.pagination-btn:disabled{opacity:.5}.pagination-current{color:#495057;font-size:14px;font-weight:500}@media (max-width:768px){.data-table-pagination{flex-direction:column;gap:12px}.data-table td,.data-table th{font-size:13px;padding:8px 12px}}.search-bar{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:16px}.search-input-container{align-items:center;display:flex;gap:12px;padding:16px}.search-input-wrapper{flex:1 1;position:relative}.search-input{border:1px solid #dee2e6;border-radius:6px;font-size:14px;padding:12px 16px;transition:border-color .2s,box-shadow .2s;width:100%}.search-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.search-actions{align-items:center;display:flex;gap:8px}.filter-toggle-btn{align-items:center;background:#fff;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:pointer;display:flex;font-size:14px;gap:6px;padding:8px 16px;transition:all .2s}.filter-toggle-btn:hover{background-color:#f8f9fa;border-color:#adb5bd}.filter-toggle-btn.active{background-color:#007bff;border-color:#007bff;color:#fff}.filter-count{color:#ffc107;font-size:12px}.clear-filters-btn{background:#fff;border:1px solid #dc3545;border-radius:6px;color:#dc3545;font-size:14px;padding:8px 12px;transition:all .2s}.clear-filters-btn:hover{background-color:#dc3545;color:#fff}.filter-panel{background-color:#f8f9fa;border-top:1px solid #dee2e6}.filter-panel-header{align-items:center;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:16px}.filter-panel-header h4{color:#495057;font-size:16px;margin:0}.close-panel-btn{align-items:center;background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;font-size:20px;height:24px;justify-content:center;padding:0;transition:background-color .2s;width:24px}.close-panel-btn:hover{background-color:#dee2e6}.filter-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));padding:16px}.filter-item{display:flex;flex-direction:column;gap:6px}.filter-label{color:#495057;font-size:14px;font-weight:500}.filter-input,.filter-select{border:1px solid #dee2e6}.filter-input:focus,.filter-select:focus{border-color:#007bff}.date-range-inputs{align-items:center;display:flex;gap:8px}.date-range-inputs .filter-input{flex:1 1}.date-separator{color:#6c757d;font-size:14px;white-space:nowrap}@media (max-width:768px){.search-input-container{align-items:stretch;flex-direction:column;gap:12px}.search-actions{justify-content:center}.filter-grid{grid-template-columns:1fr}.date-range-inputs{flex-direction:column;gap:8px}.date-separator{text-align:center}}.modal-overlay{background-color:#00000080;opacity:0;padding:16px;transition:opacity .3s ease,visibility .3s ease;visibility:hidden}.modal-overlay.modal-open{opacity:1;visibility:visible}.modal-container{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;transform:scale(.9);transition:transform .3s ease}.modal-open .modal-container{transform:scale(1)}.modal-small{max-width:400px;width:100%}.modal-medium{max-width:600px;width:100%}.modal-large{max-width:900px;width:100%}.modal-fullscreen{border-radius:0;height:100%;max-height:none;max-width:none;width:100%}.modal-header{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:20px 24px}.modal-title{color:#495057;font-size:18px;font-weight:600;margin:0}.modal-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:background-color .2s,color .2s;width:32px}.modal-close-btn:hover{background-color:#dee2e6;color:#495057}.modal-body{flex:1 1;overflow-y:auto;padding:24px}.modal-footer{background-color:#f8f9fa;border-top:1px solid #dee2e6;padding:16px 24px}.btn{min-width:80px}.btn-danger{background-color:#dc3545;border-color:#dc3545}.btn-danger:hover:not(:disabled){background-color:#c82333;border-color:#c82333}.confirm-modal-content{align-items:center;display:flex;gap:16px;padding:8px 0}.confirm-icon{align-items:center;background:#f1f3f5;border:1px solid #0000;border-radius:999px;color:#495057;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:40px;justify-content:center;line-height:1;width:40px}.confirm-message{color:#495057;font-size:16px;line-height:1.5;margin:0}.confirm-danger .confirm-message{color:#721c24}.confirm-warning .confirm-message{color:#856404}.confirm-info .confirm-message{color:#084298}.confirm-info .confirm-icon{background:#e7f1ff;border-color:#b6d4fe;color:#0d6efd}.confirm-warning .confirm-icon{background:#fff3cd;border-color:#ffecb5;color:#856404}.confirm-danger .confirm-icon{background:#f8d7da;border-color:#f5c2c7;color:#dc3545}@media (max-width:768px){.modal-overlay{padding:8px}.modal-container{max-height:95vh}.modal-large,.modal-medium,.modal-small{max-width:none;width:100%}.modal-body,.modal-footer,.modal-header{padding-left:16px;padding-right:16px}.modal-actions{flex-direction:column-reverse}.btn{width:100%}.confirm-modal-content{flex-direction:column;gap:12px;text-align:center}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-open .modal-container{animation:modalSlideIn .3s ease-out}.loading-spinner-container{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center}.loading-spinner{display:inline-block;position:relative}.spinner-circle{animation:spin 1s linear infinite;border-radius:50%;border-style:solid}.spinner-small .spinner-circle{border-width:2px;height:16px;width:16px}.spinner-medium .spinner-circle{border-width:3px;height:24px;width:24px}.spinner-large .spinner-circle{border-width:4px;height:40px;width:40px}.spinner-primary .spinner-circle{border-color:#007bff #f3f3f3 #f3f3f3}.spinner-secondary .spinner-circle{border-color:#6c757d #f3f3f3 #f3f3f3}.spinner-white .spinner-circle{border-color:#fff #ffffff4d #ffffff4d}.loading-text{color:#6c757d;font-size:14px;text-align:center}.loading-overlay{align-items:center;background-color:#fffc;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:999}.loading-overlay .loading-text{color:#495057;font-size:16px;font-weight:500}.page-loading{align-items:center;display:flex;justify-content:center;min-height:200px;padding:40px}.page-loading .loading-text{color:#495057;font-size:16px}.inline-loading{align-items:center;display:inline-flex;gap:8px;padding:8px 0}.inline-loading .loading-spinner-container{flex-direction:row;gap:8px}.inline-loading .loading-text{font-size:13px;margin:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading-spinner.pulse .spinner-circle{animation:pulse 1.5s ease-in-out infinite}.dots-loading{align-items:center;display:inline-flex;gap:4px}.dots-loading:after,.dots-loading:before{animation:dots 1.4s ease-in-out infinite both;background-color:currentColor;border-radius:50%;content:"";display:inline-block;height:4px;width:4px}.dots-loading:before{animation-delay:-.16s;margin-right:4px}@keyframes dots{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.skeleton{animation:skeleton-loading 1.5s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{border-radius:4px;height:16px;margin-bottom:8px}.skeleton-text.short{width:60%}.skeleton-text.medium{width:80%}.skeleton-text.long{width:100%}@media (max-width:768px){.loading-overlay .loading-text{font-size:14px}.page-loading{min-height:150px;padding:20px}}.error-boundary{align-items:center;background-color:#f8f9fa;display:flex;justify-content:center;min-height:400px;padding:40px 20px}.error-boundary-content{background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;max-width:600px;padding:40px;text-align:center}.error-icon{font-size:48px;margin-bottom:16px}.error-title{color:#dc3545;font-size:24px;font-weight:600;margin:0 0 16px}.error-message{color:#6c757d;font-size:16px;line-height:1.5;margin:0 0 24px}.error-actions{display:flex;gap:12px;justify-content:center;margin-bottom:24px}.error-details{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;margin-top:24px;padding:16px;text-align:left}.error-details summary{color:#495057;cursor:pointer;font-weight:600;margin-bottom:12px}.error-details summary:hover{color:#007bff}.error-stack{font-family:Courier New,monospace;font-size:12px}.error-stack h4{color:#495057;font-size:14px;margin:12px 0 8px}.error-stack pre{word-wrap:break-word;background-color:#fff;border:1px solid #dee2e6;border-radius:4px;color:#dc3545;margin:0 0 12px;overflow-x:auto;padding:12px;white-space:pre-wrap}.simple-error-fallback{align-items:center;background-color:#fff5f5;border:1px solid #fed7d7;border-radius:8px;display:flex;flex-direction:column;justify-content:center;margin:16px 0;padding:40px 20px;text-align:center}.simple-error-fallback .error-icon{font-size:32px;margin-bottom:12px}.simple-error-fallback h3{color:#dc3545;font-size:18px;margin:0 0 8px}.simple-error-fallback .error-text{color:#721c24;font-size:14px;margin:0 0 16px}.btn-primary{background-color:#007bff;border-color:#007bff}.btn-primary:hover:not(:disabled){background-color:#0056b3;border-color:#0056b3}.btn-secondary:hover:not(:disabled){background-color:#545b62;border-color:#545b62}@media (max-width:768px){.error-boundary{min-height:300px;padding:20px 16px}.error-boundary-content{padding:24px 20px}.error-icon{font-size:36px}.error-title{font-size:20px}.error-message{font-size:14px}.error-actions{align-items:center;flex-direction:column}.btn{max-width:200px;width:100%}.error-stack{font-size:11px}}@keyframes errorSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.error-boundary-content,.simple-error-fallback{animation:errorSlideIn .3s ease-out}.btn.loading{color:#0000;position:relative}.btn.loading:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;color:#fff;content:"";height:16px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:16px}.notification-container{display:flex;flex-direction:column;gap:10px;max-width:400px;position:fixed;right:20px;top:20px;z-index:1000}.notification{align-items:flex-start;animation:slideIn .3s ease-out;background:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 4px 12px #00000026;cursor:pointer;display:flex;gap:12px;padding:16px;transition:transform .2s,opacity .2s}.notification:hover{transform:translateX(-4px)}.notification-success{border-left-color:#27ae60}.notification-error{border-left-color:#e74c3c}.notification-warning{border-left-color:#f39c12}.notification-info{border-left-color:#3498db}.notification-content{flex:1 1}.notification-title{color:#2c3e50;font-size:14px;font-weight:600;margin-bottom:4px}.notification-message{color:#7f8c8d;font-size:13px;line-height:1.4}.notification-close{align-items:center;background:none;border:none;color:#bdc3c7;cursor:pointer;display:flex;font-size:20px;height:20px;justify-content:center;padding:0;transition:color .2s;width:20px}.notification-close:hover{color:#7f8c8d}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.progress-linear{margin:10px 0;width:100%}.progress-label{color:#333;font-size:14px;font-weight:500;margin-bottom:8px}.progress-linear-bar{background-color:#e0e0e0;border-radius:4px;overflow:hidden;position:relative;width:100%}.progress-linear-small .progress-linear-bar{height:4px}.progress-linear-medium .progress-linear-bar{height:8px}.progress-linear-large .progress-linear-bar{height:12px}.progress-linear-fill{background:linear-gradient(90deg,#4caf50,#45a049);border-radius:4px;height:100%;transition:width .3s ease}.progress-percentage{color:#666;font-size:12px;margin-top:4px;text-align:right}.progress-circular{align-items:center;display:inline-flex;flex-direction:column;position:relative}.progress-circular-small{height:60px;width:60px}.progress-circular-medium{height:100px;width:100px}.progress-circular-large{height:150px;width:150px}.progress-circular-svg{height:100%;transform:rotate(-90deg);width:100%}.progress-circular-bg{stroke:#e0e0e0}.progress-circular-fill{stroke:#4caf50;stroke-linecap:round;transition:stroke-dasharray .3s ease}.progress-circular-text{color:#333;font-size:18px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.progress-circular-small .progress-circular-text{font-size:14px}.progress-circular-large .progress-circular-text{font-size:24px}.progress-indeterminate{margin:10px 0;width:100%}.progress-indeterminate-bar{background-color:#e0e0e0;border-radius:4px;overflow:hidden;position:relative;width:100%}.progress-indeterminate-small .progress-indeterminate-bar{height:4px}.progress-indeterminate-medium .progress-indeterminate-bar{height:8px}.progress-indeterminate-large .progress-indeterminate-bar{height:12px}.progress-indeterminate-fill{animation:indeterminate 1.5s ease-in-out infinite;background:linear-gradient(90deg,#4caf50,#45a049);border-radius:4px;height:100%;width:30%}@keyframes indeterminate{0%{transform:translateX(-100%)}to{transform:translateX(400%)}}@media (prefers-color-scheme:dark){.progress-circular-text,.progress-label{color:#f0f0f0}.progress-percentage{color:#ccc}.progress-indeterminate-bar,.progress-linear-bar{background-color:#424242}.progress-circular-bg{stroke:#424242}}.keyboard-shortcuts-help{padding:.5rem 0}.shortcuts-category{margin-bottom:2rem}.shortcuts-category:last-child{margin-bottom:0}.category-title{border-bottom:2px solid #dee2e6;color:#495057;font-size:1.125rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem}.shortcuts-list{display:flex;flex-direction:column;gap:.75rem}.shortcut-item{align-items:center;background-color:#f8f9fa;border-radius:.375rem;display:flex;justify-content:space-between;padding:.75rem;transition:background-color .2s}.shortcut-item:hover{background-color:#e9ecef}.shortcut-keys{align-items:center;display:flex;gap:.25rem;min-width:120px}.shortcut-key{align-items:center;background-color:#fff;border:1px solid #ced4da;border-radius:.25rem;box-shadow:0 1px 2px #0000001a;color:#495057;display:inline-flex;font-family:Courier New,monospace;font-size:.875rem;font-weight:600;justify-content:center;min-width:2rem;padding:.25rem .5rem}.key-separator{color:#6c757d;font-weight:600;margin:0 .125rem}.shortcut-description{color:#6c757d;flex:1 1;font-size:.9375rem;text-align:right}@media (max-width:768px){.shortcut-item{align-items:flex-start;flex-direction:column;gap:.5rem}.shortcut-keys{min-width:auto}.shortcut-description{text-align:left;width:100%}.category-title{font-size:1rem}}.password-requirements{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem;padding:.75rem}.requirement{align-items:center;display:flex;font-size:.8125rem;gap:.5rem;transition:color .2s}.requirement.met{color:#059669}.requirement.unmet{color:#dc2626}.requirement-icon{font-size:.875rem;font-weight:700;min-width:1rem;text-align:center}.requirement.met .requirement-icon{color:#059669}.requirement.unmet .requirement-icon{color:#dc2626}.requirement-text{line-height:1.4}.contextual-help{margin-bottom:20px;position:relative}.contextual-help-toggle{align-items:center;background:#f0f7ff;border:1px solid #b3d9ff;border-radius:6px;color:#06c;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:8px 14px;transition:all .2s}.contextual-help-toggle:hover{background:#e6f2ff;border-color:#80bfff}.contextual-help-toggle svg{flex-shrink:0}.contextual-help-content{animation:slideDown .3s ease-out;background:#f9fafb;border:1px solid #e0e0e0;border-radius:8px;margin-top:12px;padding:20px}.contextual-help-content h4{color:#1a1a1a;font-size:16px;font-weight:600;margin:0 0 16px}.help-steps{display:flex;flex-direction:column;gap:12px}.help-step{align-items:flex-start;display:flex;gap:12px}.help-step-number{align-items:center;background:#06c;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:600;height:24px;justify-content:center;width:24px}.help-step-content{flex:1 1}.help-step-content strong{color:#1a1a1a;display:block;font-size:14px;font-weight:600;margin-bottom:4px}.help-step-content p{color:#4d4d4d;font-size:14px;line-height:1.5;margin:0}.help-tips{border-top:1px solid #e0e0e0;margin-top:16px;padding-top:16px}.help-tips strong{color:#1a1a1a;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.help-tips ul{margin:0;padding-left:20px}.help-tips li{color:#4d4d4d;font-size:13px;line-height:1.6;margin-bottom:4px}.help-tips li:last-child{margin-bottom:0}@media (max-width:768px){.contextual-help-content{padding:16px}.help-step-number{font-size:11px;height:20px;width:20px}.help-step-content p,.help-step-content strong{font-size:13px}}.navigation{background:linear-gradient(180deg,#1e293b,#0f172a);box-shadow:2px 0 12px #00000026;color:#fff;overflow-y:auto;padding:24px 0;position:relative;transition:transform .3s ease;width:260px;z-index:90}.nav-content{position:relative;z-index:2}.nav-overlay,.nav-toggle{display:none}.nav-toggle{align-items:center;background:#3b82f6;border:none;border-radius:8px;box-shadow:0 4px 12px #3b82f64d;cursor:pointer;flex-direction:column;gap:5px;height:44px;justify-content:center;left:16px;position:fixed;top:16px;transition:all .3s ease;width:44px;z-index:100}.nav-toggle:hover{background:#2563eb;transform:scale(1.05)}.nav-toggle span{background:#fff;border-radius:2px;display:block;height:2px;transition:all .3s ease;width:22px}.nav-section{margin-bottom:28px;padding:0 20px}.nav-section h3{border-bottom:1px solid #94a3b833;color:#94a3b8;font-size:11px;font-weight:700;letter-spacing:1.2px;margin-bottom:10px;padding-bottom:6px;text-transform:uppercase}.nav-link{border-radius:8px;color:#e2e8f0;font-size:14px;font-weight:500;gap:12px;margin:3px 0;padding:10px 14px;position:relative;text-decoration:none;transition:all .2s ease}.nav-icon,.nav-link{align-items:center;display:flex}.nav-icon{flex-shrink:0;justify-content:center;width:20px}.nav-icon svg{height:16px;width:16px}.nav-link:hover{background:#3b82f61f;color:#60a5fa;transform:translateX(4px)}.nav-link.active{background:#3b82f633;color:#60a5fa;font-weight:600}.nav-link.active:before{background:linear-gradient(180deg,#3b82f6,#2563eb);border-radius:0 4px 4px 0;bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.navigation::-webkit-scrollbar{width:6px}.navigation::-webkit-scrollbar-track{background:#0000001a}.navigation::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.navigation::-webkit-scrollbar-thumb:hover{background:#94a3b880}@media (max-width:1024px){.navigation{width:220px}.nav-section{padding:0 16px}.nav-link{font-size:13px;padding:9px 12px}}@media (max-width:768px){.nav-toggle{display:flex}.navigation{height:100vh;left:0;padding-top:80px;position:fixed;top:0;transform:translateX(-100%);width:280px;z-index:99}.navigation.open{transform:translateX(0)}.navigation.open .nav-overlay{background:#00000080;bottom:0;display:block;left:0;position:fixed;right:0;top:0;z-index:1}.nav-section{margin-bottom:20px}}@media (max-width:480px){.navigation{width:260px}.nav-toggle{height:40px;left:12px;top:12px;width:40px}.nav-toggle span{width:20px}.nav-section{margin-bottom:18px;padding:0 14px}.nav-link{font-size:13px;padding:8px 10px}.nav-icon{font-size:16px;width:20px}}.header{align-items:center;background-color:#34495e;box-shadow:0 2px 8px #0000001a;color:#fff;display:flex;height:64px;justify-content:space-between;padding:0 24px;position:relative;z-index:100}.header-left h1{color:#fff;font-size:20px;font-weight:600;margin:0}.header-right,.user-info{align-items:center;display:flex}.user-info{gap:12px;padding:8px 0}.username{color:#fff;font-weight:600}.role{background-color:#ffffff1a;border-radius:12px;color:#bdc3c7;padding:2px 8px}.logout-btn,.role{font-size:14px;font-weight:500}.logout-btn{background-color:#e74c3c;border:none;border-radius:6px;color:#fff;cursor:pointer;margin-left:8px;padding:8px 16px;transition:all .2s}.logout-btn:hover{background-color:#c0392b;box-shadow:0 2px 4px #0003;transform:translateY(-1px)}.logout-btn:active{transform:translateY(0)}@media (max-width:768px){.header{height:56px;padding:0 16px}.header-left h1{font-size:18px}.user-info{gap:8px}.username{display:none}.logout-btn{font-size:13px;padding:6px 12px}}@media (max-width:480px){.header{padding:0 12px}.header-left h1{font-size:16px}.role{font-size:12px;padding:1px 6px}}.app-layout{background-color:#f8f9fa;display:flex;flex-direction:column;height:100vh}.app-content{display:flex;flex:1 1;overflow:hidden}.main-content{background-color:#f8f9fa;flex:1 1;overflow-y:auto;padding:24px;position:relative}@media (max-width:768px){.app-content{flex-direction:column}.main-content{padding:16px}}@media (max-width:480px){.main-content{padding:12px}}.login-container{align-items:center;background-image:url(/static/media/bg-1.47f0d07c938a9befa114.jpg);background-position:50%;background-size:cover;display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;max-width:400px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-header h1{color:#2c3e50;font-size:24px;font-weight:600;margin-bottom:8px}.login-header p{color:#7f8c8d;font-size:14px;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{gap:6px}.form-group label{color:#2c3e50;font-size:14px}.form-group input{border:2px solid #e1e8ed;border-radius:8px;font-size:16px;padding:12px 16px;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.form-group input:disabled{background-color:#f8f9fa;cursor:not-allowed}.form-group input.error{border-color:#e74c3c}.form-group input.error:focus{box-shadow:0 0 0 3px #e74c3c1a}.error-message{color:#e74c3c;font-size:12px}.login-button{align-items:center;background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;margin-top:10px;padding:14px 20px;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){box-shadow:0 4px 12px #3498db4d;transform:translateY(-1px)}.login-button:disabled{background:#bdc3c7;box-shadow:none;cursor:not-allowed;transform:none}.button-spinner{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.public-catalog-section{border-top:1px solid #e1e8ed;margin-top:20px;padding-top:20px;text-align:center}.public-catalog-section p{color:#7f8c8d;font-size:14px;margin-bottom:10px}.catalog-button{background:#0000;border:2px solid #3498db;border-radius:8px;color:#3498db;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.catalog-button:hover{background:#3498db;box-shadow:0 4px 12px #3498db4d;color:#fff;transform:translateY(-1px)}.login-footer{border-top:1px solid #e1e8ed;margin-top:30px;padding-top:20px;text-align:center}.login-footer p{color:#7f8c8d;font-size:12px;margin:0}.loading-spinner{align-items:center;color:#7f8c8d;display:flex;flex-direction:column;justify-content:center;padding:40px}.spinner{border:4px solid #e1e8ed;height:40px;margin-bottom:16px;width:40px}:root{--bg:#f5f5f4;--border:#e5e5e3;--border-mid:#d4d4d0;--text-1:#18181b;--text-2:#52525b;--text-3:#a1a1aa;--red:#dc2626;--green:#16a34a;--shadow:0 1px 3px #00000012,0 1px 2px #0000000a}.dashboard{background:#f5f5f4;background:var(--bg);color:#18181b;color:var(--text-1);font-family:Geist,-apple-system,sans-serif;min-height:100%;padding:36px 40px 60px}.dashboard-header{margin-bottom:32px}.header-content{align-items:flex-end;gap:24px}.header-eyebrow{color:#a1a1aa;color:var(--text-3);font-size:.7rem;font-weight:500;letter-spacing:.1em;margin-bottom:5px;text-transform:uppercase}.dashboard-header h1{color:#18181b;color:var(--text-1);font-size:1.5rem;font-weight:600;letter-spacing:-.02em;line-height:1.2;margin:0 0 4px}.dashboard-header p{color:#52525b;color:var(--text-2);font-size:.875rem;margin:0}.header-actions{display:flex;flex-shrink:0;gap:8px}.refresh-button{align-items:center;background:#fff;background:var(--surface);border:1px solid #e5e5e3;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#52525b;color:var(--text-2);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.8rem;font-weight:500;gap:6px;padding:7px 14px;transition:border-color .15s,color .15s}.refresh-button:hover:not(:disabled){border-color:#d4d4d0;border-color:var(--border-mid);color:#18181b;color:var(--text-1)}.refresh-button:disabled{cursor:not-allowed;opacity:.5}.refresh-button svg{display:block;flex-shrink:0}.spin-icon{animation:spin 1s linear infinite}.dashboard-content{display:flex;flex-direction:column;gap:20px}.metrics-section{margin-bottom:0}.metrics-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.metric-card{background:#fff;background:var(--surface);border:1px solid #e5e5e3;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px #00000012,0 1px 2px #0000000a;box-shadow:var(--shadow);padding:20px 22px;transition:border-color .15s}.metric-card:hover{border-color:#d4d4d0;border-color:var(--border-mid)}.metric-header{justify-content:space-between;margin-bottom:16px}.metric-header,.metric-icon{align-items:center;display:flex}.metric-icon{background:#f5f5f4;background:var(--bg);border:1px solid #e5e5e3;border:1px solid var(--border);border-radius:6px;color:#52525b;color:var(--text-2);flex-shrink:0;height:30px;justify-content:center;width:30px}.metric-card.metric-red .metric-icon{background:#fef2f2;border-color:#fecaca;color:#dc2626;color:var(--red)}.metric-card h3{color:#a1a1aa;color:var(--text-3);font-size:.7rem;font-weight:500;letter-spacing:.07em;margin:0;text-transform:uppercase}.metric-trend{border-radius:4px;font-family:Geist Mono,monospace;font-size:.68rem;padding:2px 6px}.metric-trend.positive{background:#f0fdf4;color:#16a34a;color:var(--green)}.metric-trend.negative{background:#fef2f2;color:#dc2626;color:var(--red)}.metric-value{color:#18181b;color:var(--text-1);font-size:2.1rem;font-weight:600;letter-spacing:-.03em;line-height:1;margin-bottom:6px}.metric-card.metric-red .metric-value{color:#dc2626;color:var(--red)}.metric-label{color:#52525b;color:var(--text-2);font-size:.825rem;font-weight:500;margin-bottom:2px}.metric-sublabel{color:#a1a1aa;color:var(--text-3);font-size:.75rem}.dashboard-sections{grid-gap:12px;align-items:start;display:grid;gap:12px;grid-template-columns:1fr 340px}.dashboard-section{background:#fff;background:var(--surface);border:1px solid #e5e5e3;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px #00000012,0 1px 2px #0000000a;box-shadow:var(--shadow);overflow:hidden}.section-header{align-items:center;border-bottom:1px solid #e5e5e3;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:15px 20px}.dashboard-section h2{color:#18181b;color:var(--text-1);font-size:.875rem;font-weight:600;margin:0}.view-all-button{background:none;border:none;color:#a1a1aa;color:var(--text-3);cursor:pointer;font-family:inherit;font-size:.775rem;font-weight:500;padding:0;transition:color .15s}.view-all-button:hover{color:#18181b;color:var(--text-1)}.activity-list{display:flex;flex-direction:column;max-height:360px;overflow-y:auto;scrollbar-color:#e5e5e3 #0000;scrollbar-color:var(--border) #0000;scrollbar-width:thin}.activity-list::-webkit-scrollbar{width:3px}.activity-list::-webkit-scrollbar-thumb{background:#d4d4d0;background:var(--border-mid);border-radius:3px}.activity-item{border-bottom:1px solid #e5e5e3;border-bottom:1px solid var(--border);padding:12px 20px;transition:background .12s}.activity-item:last-child{border-bottom:none}.activity-item:hover{background:#f5f5f4;background:var(--bg)}.activity-content{align-items:baseline;display:flex;gap:16px;justify-content:space-between}.activity-description{color:#52525b;color:var(--text-2);flex:1 1;font-size:.825rem;line-height:1.45}.activity-time{flex-shrink:0;font-family:Geist Mono,monospace;font-size:.68rem;white-space:nowrap}.activity-time,.no-activity{color:#a1a1aa;color:var(--text-3)}.no-activity{font-size:.825rem;padding:40px 20px;text-align:center}.quick-actions{display:flex;flex-direction:column}.action-button{background:#0000;border:none;border-bottom:1px solid #e5e5e3;border-bottom:1px solid var(--border);display:flex;gap:12px;padding:13px 20px;text-align:left;transition:background .12s;width:100%}.action-button:last-child{border-bottom:none}.action-button:hover,.action-icon-wrap{background:#f5f5f4;background:var(--bg)}.action-icon-wrap{align-items:center;border:1px solid #e5e5e3;border:1px solid var(--border);border-radius:6px;display:flex;flex-shrink:0;font-size:.875rem;height:32px;justify-content:center;width:32px}.action-content{flex:1 1;min-width:0}.action-title{color:#18181b;color:var(--text-1);font-size:.825rem;font-weight:500;margin-bottom:1px}.action-description{color:#a1a1aa;color:var(--text-3);font-size:.74rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.action-chevron{color:#a1a1aa;color:var(--text-3);display:block;flex-shrink:0;transition:transform .15s,color .15s}.action-button:hover .action-chevron{color:#52525b;color:var(--text-2);transform:translateX(2px)}.charts-section{margin-top:0}.chart-card{background:#fff;background:var(--surface);border:1px solid #e5e5e3;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px #00000012,0 1px 2px #0000000a;box-shadow:var(--shadow);overflow:hidden}.chart-card-header{border-bottom:1px solid #e5e5e3;border-bottom:1px solid var(--border);padding:15px 20px}.chart-card h3{color:#18181b;color:var(--text-1);font-size:.875rem;font-weight:600;margin:0}.chart-body{padding:18px 20px}.chart-summary{display:flex;flex-wrap:wrap;gap:8px}.chart-item{align-items:center;background:#f5f5f4;background:var(--bg);border:1px solid #e5e5e3;border:1px solid var(--border);border-radius:6px;display:flex;gap:8px;padding:7px 12px;transition:border-color .15s}.chart-item:hover{border-color:#d4d4d0;border-color:var(--border-mid)}.chart-dot{background:#a1a1aa;background:var(--text-3);border-radius:50%;flex-shrink:0;height:6px;width:6px}.chart-label{color:#52525b;color:var(--text-2);font-size:.8rem}.chart-value{color:#18181b;color:var(--text-1);font-family:Geist Mono,monospace;font-size:.8rem;font-weight:500;margin-left:4px}.dashboard-error{background:#fff;background:var(--surface);border:1px solid #e5e5e3;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px #00000012,0 1px 2px #0000000a;box-shadow:var(--shadow);padding:64px 40px;text-align:center}.dashboard-error h2{color:#18181b;color:var(--text-1);font-size:1.05rem;font-weight:600;margin-bottom:8px}.dashboard-error p{color:#52525b;color:var(--text-2);font-size:.875rem;margin-bottom:24px}.retry-button{background:#18181b;background:var(--text-1);border:none;border-radius:8px;border-radius:var(--radius);color:#fff;cursor:pointer;font-family:inherit;font-size:.825rem;font-weight:500;padding:9px 20px;transition:opacity .15s}.retry-button:hover{opacity:.8}.dashboard .loading-container{align-items:center;display:flex;justify-content:center;min-height:60vh}@media (max-width:1280px){.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:1024px){.dashboard-sections{grid-template-columns:1fr}}@media (max-width:768px){.dashboard{padding:24px 20px 48px}.header-content{align-items:flex-start;flex-direction:column;gap:12px}.metrics-grid{grid-template-columns:repeat(2,1fr)}.metric-value{font-size:1.75rem}}@media (max-width:480px){.metrics-grid{grid-template-columns:1fr}}.unauthorized-container{align-items:center;display:flex;justify-content:center;min-height:60vh;padding:20px}.unauthorized-content{max-width:500px;text-align:center}.unauthorized-icon{font-size:64px;margin-bottom:20px}.unauthorized-content h1{color:#e74c3c;font-size:32px;font-weight:600;margin-bottom:16px}.unauthorized-content p{color:#7f8c8d;font-size:16px;line-height:1.6;margin-bottom:12px}.back-button{background:#3498db;border-radius:8px;color:#fff;display:inline-block;margin-top:20px;padding:12px 24px;transition:background-color .2s}.back-button:hover{background:#2980b9}.entity-preview-modal{max-width:600px;width:100%}.archive-info{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:24px;padding:16px}.archive-meta{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.meta-item{display:flex;flex-direction:column;gap:4px}.meta-item label{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.meta-item span{color:#374151;font-size:14px}.entity-data{margin-bottom:24px}.entity-data h4{border-bottom:1px solid #e5e7eb;color:#374151;font-size:16px;font-weight:600;margin:0 0 16px;padding-bottom:8px}.entity-fields{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.field-group{display:flex;flex-direction:column;gap:4px}.field-group label{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.field-group span{background:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;color:#374151;font-size:14px;padding:8px 12px}.serial-number{font-family:Courier New,monospace;font-weight:600}.status-badge{border:none!important;border-radius:12px!important;font-size:12px!important;font-weight:500!important;padding:4px 8px!important;text-align:center;text-transform:uppercase!important}.status-badge.archived{background:#fef3c7!important;color:#92400e!important}.status-badge.available,.status-badge.restored{background:#d1fae5!important;color:#065f46!important}.status-badge.assigned{background:#dbeafe!important;color:#1e40af!important}.status-badge.maintenance{background:#fef3c7!important;color:#92400e!important}.status-badge.retired{background:#f3f4f6!important;color:#6b7280!important}.role-badge{border:none!important;border-radius:12px!important;font-size:12px!important;font-weight:500!important;padding:4px 8px!important;text-align:center;text-transform:uppercase!important}.role-badge.admin{background:#fecaca!important;color:#991b1b!important}.role-badge.manager{background:#fed7aa!important;color:#9a3412!important}.role-badge.viewer{background:#e0e7ff!important;color:#3730a3!important}.raw-data{grid-column:1/-1}.raw-data pre{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;font-size:12px;overflow-x:auto;padding:16px}.btn{padding:8px 16px}@media (max-width:768px){.entity-preview-modal{max-width:100%}.archive-meta,.entity-fields{grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.archive-list{padding:20px}.archive-list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.archive-list-header h2{color:#333;font-size:24px;margin:0}.archive-stats{display:flex;gap:20px}.archive-stats .stat{background:#f5f5f5;border-radius:4px;color:#666;font-size:14px;padding:8px 16px}.archive-search{margin-bottom:20px}.archive-table{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.status-badge{font-size:12px}.status-badge.archived{background:#fef3c7;color:#92400e}.status-badge.restored{background:#d1fae5;color:#065f46}.btn.btn-danger{background:#ef4444;border-color:#ef4444;color:#fff}.btn.btn-danger:hover{background:#dc2626;border-color:#dc2626}.modal-content{padding:20px}.modal-content p{line-height:1.5;margin-bottom:16px}.warning-text{color:#dc2626;font-weight:500}.entity-info{background:#f9fafb;border-left:4px solid #3b82f6;border-radius:4px;margin-bottom:20px;padding:12px}@media (max-width:768px){.archive-list{padding:10px}.archive-list-header{align-items:flex-start;flex-direction:column;gap:10px}.archive-stats{justify-content:space-between;width:100%}.action-buttons{gap:4px}.action-buttons,.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.archive-filters{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:20px}.filters-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:12px 16px}.filters-toggle{align-items:center;background:none;border:none;border-radius:4px;color:#374151;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:4px 8px;transition:all .2s}.filters-toggle:hover{background:#f3f4f6}.filters-toggle.active{color:#3b82f6}.filter-indicator{color:#3b82f6;font-size:12px}.toggle-icon{font-size:12px;transition:transform .2s}.toggle-icon.expanded{transform:rotate(180deg)}.clear-filters{background:none;border:1px solid #e5e7eb;border-radius:4px;color:#6b7280;cursor:pointer;font-size:12px;padding:4px 12px;transition:all .2s}.clear-filters:hover{background:#f3f4f6;border-color:#d1d5db}.filters-panel{padding:16px}.filters-grid{grid-gap:16px;align-items:end;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-group{gap:6px}.filter-group label{color:#374151;letter-spacing:.05em}.filter-input,.filter-select{border:1px solid #d1d5db;border-radius:4px;color:#374151;font-size:14px;padding:8px 12px;transition:border-color .2s}.filter-input:focus,.filter-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:8px;padding:8px 0}.filter-checkbox{accent-color:#3b82f6;height:16px;width:16px}.checkbox-text{color:#374151;font-size:14px;font-weight:400;letter-spacing:normal;text-transform:none}@media (max-width:768px){.filters-header{padding:10px 12px}.filters-panel{padding:12px}.filters-grid{gap:12px;grid-template-columns:1fr}.filters-header{align-items:stretch;flex-direction:column;gap:8px}.clear-filters{align-self:flex-end}}@media (max-width:480px){.filter-input,.filter-select{font-size:16px;padding:10px 12px}}.archive-statistics-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;transition:all .2s ease}.archive-statistics-card.clickable{cursor:pointer}.archive-statistics-card.clickable:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.card-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:16px 20px}.entity-info{gap:12px}.entity-icon,.entity-info{align-items:center;display:flex}.entity-icon{background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:24px;height:40px;justify-content:center;width:40px}.entity-info h3{color:#374151;font-size:18px;font-weight:600;margin:0}.card-content{padding:20px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:20px}.stat-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:12px;text-align:center}.stat-value{color:#1f2937;font-size:24px;margin-bottom:4px}.stat-label{color:#6b7280;font-size:12px;font-weight:500;letter-spacing:.05em}.date-info{border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:8px;padding-top:16px}.date-item{align-items:center;justify-content:space-between}.date-label{color:#6b7280;font-size:12px;font-weight:500}.date-value{color:#374151;font-size:12px;font-weight:600}.card-footer{background:#f9fafb;border-top:1px solid #e5e7eb;padding:12px 20px;text-align:center}.view-link{color:#3b82f6;font-size:14px;font-weight:500;text-decoration:none}.archive-statistics-card.clickable:hover .view-link{color:#2563eb}@media (max-width:768px){.stats-grid{gap:12px;grid-template-columns:1fr}.stat-item{padding:16px}.stat-value{font-size:20px}.date-item{align-items:flex-start;flex-direction:column;gap:4px}.card-content{padding:16px}.card-header{padding:12px 16px}.entity-info h3{font-size:16px}.entity-icon{font-size:20px;height:32px;width:32px}}@media (max-width:480px){.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-item:last-child{grid-column:1/-1}}.archives-page{margin:0 auto;max-width:1200px;padding:20px}.archives-header{margin-bottom:32px;text-align:center}.archives-header h1{color:#1f2937;font-size:32px;font-weight:700;margin:0 0 12px}.archives-description{color:#6b7280;font-size:16px;line-height:1.6;margin:0 auto;max-width:600px}.archive-detail-header{margin-bottom:20px}.back-button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;text-decoration:none;transition:all .2s}.back-button:hover{background:#f9fafb;border-color:#9ca3af}.loading-container{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:60px 20px}.loading-spinner{border:3px solid #e5e7eb;height:32px;width:32px}.loading-container span{color:#6b7280;font-size:14px}.archives-overview{margin-bottom:40px}.no-archives{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:60px 20px;text-align:center}.no-archives-icon{font-size:48px;margin-bottom:16px}.no-archives h3{color:#374151;font-size:20px;font-weight:600;margin:0 0 8px}.no-archives p{color:#6b7280;font-size:14px;margin:0}.statistics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.archives-actions{margin-top:40px}.action-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.action-card h3{color:#374151;font-size:18px;font-weight:600;margin:0 0 16px}.action-buttons{gap:12px}.action-button{align-items:center;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;justify-content:center;padding:10px 16px;text-decoration:none;transition:all .2s}.action-button:hover{background:#e5e7eb;border-color:#9ca3af}.action-button:active{transform:translateY(1px)}@media (max-width:768px){.archives-page{padding:16px}.archives-header h1{font-size:28px}.archives-description{font-size:14px}.statistics-grid{gap:16px;grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-button{width:100%}.action-card{padding:20px}}@media (max-width:480px){.archives-page{padding:12px}.archives-header{margin-bottom:24px}.archives-header h1{font-size:24px}.back-button{justify-content:center;width:100%}.no-archives{padding:40px 16px}.no-archives-icon{font-size:36px}}.activity-log-viewer{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.activity-log-header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px}.header-content{gap:20px}.header-content h2{color:#374151;font-size:20px;font-weight:600}.activity-stats{display:flex;gap:16px}.activity-stats .stat{background:#fff;border:1px solid #e5e7eb;border-radius:4px;color:#6b7280;font-size:12px;padding:4px 8px}.export-actions{display:flex;gap:8px}.activity-search{margin:20px 20px 0}.activity-table{border:1px solid #e5e7eb;box-shadow:none;margin:20px}.action-badge{border-radius:10px;font-size:10px;font-weight:500;letter-spacing:.05em;padding:2px 6px;text-transform:uppercase}.action-badge.create{background:#d1fae5;color:#065f46}.action-badge.update{background:#dbeafe;color:#1e40af}.action-badge.delete{background:#fecaca;color:#991b1b}.action-badge.archive{background:#fef3c7;color:#92400e}.action-badge.restore{background:#d1fae5;color:#065f46}.action-badge.assign{background:#e0e7ff;color:#3730a3}.action-badge.return{background:#fed7aa;color:#9a3412}.action-badge.login{background:#d1fae5;color:#065f46}.action-badge.logout{background:#f3f4f6;color:#4b5563}.user-info-cell{display:flex;flex-direction:column;line-height:1.2}.user-fullname{color:#111827;font-weight:500}.user-username{font-size:11px}.action-details{align-items:center;display:flex;gap:8px}.action-badge.default{background:#f3f4f6;color:#6b7280}.btn{background:#fff;border:1px solid #ddd;border-radius:4px;color:#333;font-size:12px;padding:6px 12px}.btn:hover{background:#f5f5f5}.btn.btn-sm{font-size:11px;padding:4px 8px}.btn.btn-outline{background:#0000;border-color:#ddd}.btn.btn-primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.btn.btn-primary:hover{background:#2563eb;border-color:#2563eb}.activity-details{padding:20px}.details-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item label{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.detail-item span{color:#374151;font-size:14px}.description-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;margin-bottom:20px;padding:16px}.description-section label{color:#6b7280;display:block;font-size:12px;font-weight:600;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}.description-section p{color:#374151;font-size:14px;line-height:1.5;margin:0}.changes-section{margin-bottom:20px}.changes-section h4{color:#374151;font-size:14px;font-weight:600;margin:0 0 12px}.changes-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.change-item{display:flex;flex-direction:column;gap:8px}.change-item label{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.change-item pre{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;font-size:11px;margin:0;overflow-x:auto;padding:12px}.modal-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding-top:16px}.modal-actions .btn{font-size:14px;padding:8px 16px}@media (max-width:768px){.activity-log-header{gap:12px}.activity-log-header,.header-content{align-items:flex-start;flex-direction:column}.header-content{gap:8px}.activity-stats{flex-wrap:wrap;gap:8px}.export-actions{justify-content:flex-end;width:100%}.changes-grid,.details-grid{grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}@media (max-width:480px){.activity-log-header{padding:16px}.activity-search{margin:16px 16px 0}.activity-table{margin:16px}.export-actions{flex-direction:column;width:100%}.export-actions .btn{width:100%}.value-list{display:flex;flex-direction:column;gap:4px;list-style:none;margin:0;padding:0}.value-list li{font-size:.875rem}.value-list-key{color:#555;font-weight:600;text-transform:capitalize}.value-list-val{color:#222}}.activity-log-page{margin:0 auto;max-width:1200px;padding:20px}@media (max-width:768px){.activity-log-page{padding:16px}.page-header h1{font-size:28px}.page-description{font-size:14px}}@media (max-width:480px){.activity-log-page{padding:12px}.page-header h1{font-size:24px}}:root{--ink:#1a1a2e;--ink-2:#4a4a68;--ink-3:#6b6b8a;--ink-4:#9a9ab0;--rule:#e8e8ef;--rule-heavy:#d4d4e0;--ground:#f7f7fa;--accent:#4f46e5;--accent-soft:#eef2ff;--success:#22c55e;--radius-sm:6px;--mono:"JetBrains Mono",ui-monospace,monospace;--sans:"Inter",system-ui,-apple-system,sans-serif;--shadow-sm:0 1px 2px #0000000a;--shadow:0 1px 3px #00000014,0 1px 2px #0000000a}*{margin:0;padding:0}.report-generator{background:#f7f7fa;background:var(--ground);color:#1a1a2e;color:var(--ink);font-family:Inter,system-ui,-apple-system,sans-serif;font-family:var(--sans);margin:0 auto;max-width:1400px;min-height:100vh;padding:48px 56px}.report-header{align-items:flex-end;border-bottom:1px solid #d4d4e0;border-bottom:1px solid var(--rule-heavy);display:flex;justify-content:space-between;margin-bottom:40px;padding-bottom:24px}.report-header h2{color:#6b6b8a;color:var(--ink-3);font-size:13px;font-weight:600;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.report-header-title{color:#1a1a2e;color:var(--ink);font-size:32px;font-weight:600;letter-spacing:-.02em;line-height:1.1}.report-actions{align-items:center;display:flex;gap:12px}.btn{border-radius:var(--radius);font-family:Inter,system-ui,-apple-system,sans-serif;font-family:var(--sans);font-size:14px;gap:8px;letter-spacing:.01em;padding:10px 20px;transition:all .15s ease}.btn-primary{background:#4f46e5;box-shadow:0 1px 2px #0000000a;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:#4338ca;box-shadow:0 4px 12px #4f46e540}.btn-outline{background:#fff;background:var(--surface);border-color:#d4d4e0;border-color:var(--rule-heavy);color:#4a4a68;color:var(--ink-2)}.btn-outline:hover:not(:disabled){background:#f7f7fa;background:var(--ground);border-color:#6b6b8a;border-color:var(--ink-3);color:#1a1a2e;color:var(--ink)}.btn-sm{padding:6px 14px}.btn-ghost{border-color:#0000;color:#6b6b8a;color:var(--ink-3)}.btn-ghost:hover:not(:disabled){background:#f7f7fa;background:var(--ground);color:#1a1a2e;color:var(--ink)}.report-configuration{grid-gap:0;background:#fff;background:var(--surface);border:1px solid #e8e8ef;border:1px solid var(--rule);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow);display:grid;gap:0;grid-template-columns:240px 1fr;margin-bottom:32px;overflow:hidden}.report-type-selection{background:#f7f7fa;background:var(--ground);border-right:1px solid #e8e8ef;border-right:1px solid var(--rule);padding:28px 0}.report-type-selection h3{color:#9a9ab0;color:var(--ink-4);font-size:12px;font-weight:600;letter-spacing:.06em;padding:0 24px 20px;text-transform:uppercase}.report-type-grid{display:flex;flex-direction:column}.report-type-option{align-items:center;border-left:3px solid #0000;cursor:pointer;display:flex;gap:12px;padding:14px 24px;transition:all .12s ease}.report-type-option:hover{background:#fff9}.report-type-option input[type=radio]{display:none}.report-type-option:has(input:checked){background:#fff;background:var(--surface);border-left-color:#4f46e5;border-left-color:var(--accent)}.report-type-option:has(input:checked) .report-type-label{color:#4f46e5;color:var(--accent);font-weight:500}.report-type-dot{background:#d4d4e0;background:var(--rule-heavy);border-radius:50%;flex-shrink:0;height:8px;transition:background .1s;width:8px}.report-type-option:has(input:checked) .report-type-dot{background:#4f46e5;background:var(--accent)}.report-type-label{color:#4a4a68;color:var(--ink-2);font-size:15px;line-height:1.4}.report-filters{padding:28px 32px}.report-filters h3{color:#9a9ab0;color:var(--ink-4);font-size:12px;font-weight:600;letter-spacing:.06em;margin-bottom:24px;text-transform:uppercase}.filters-grid{grid-gap:20px 24px;display:grid;gap:20px 24px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:24px}.filter-group{display:flex;flex-direction:column;gap:8px}.presets-group{align-items:center;border-bottom:1px solid #e8e8ef;border-bottom:1px solid var(--rule);flex-direction:row;flex-wrap:wrap;gap:10px;grid-column:1/-1;margin-bottom:8px;padding-bottom:20px}.presets-group label{flex-shrink:0;margin-right:8px}.filter-group label{color:#6b6b8a;color:var(--ink-3);font-size:12px;font-weight:500;letter-spacing:.03em;text-transform:uppercase}.filter-input,.filter-select{appearance:none;-webkit-appearance:none;background:#fff;background:var(--surface);border:1px solid #d4d4e0;border:1px solid var(--rule-heavy);border-radius:6px;border-radius:var(--radius-sm);color:#1a1a2e;color:var(--ink);font-family:Inter,system-ui,-apple-system,sans-serif;font-family:var(--sans);font-size:15px;padding:10px 14px;transition:all .15s ease}.filter-select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='m1 1.5 5 5 5-5' stroke='%236b6b8a' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.filter-input:focus,.filter-select:focus{border-color:#4f46e5;border-color:var(--accent);box-shadow:0 0 0 3px #4f46e51a;outline:none}.timezone-info{background:#f7f7fa;background:var(--ground);border:1px solid #e8e8ef;border:1px solid var(--rule);border-radius:6px;border-radius:var(--radius-sm);color:#6b6b8a;color:var(--ink-3);font-family:JetBrains Mono,ui-monospace,monospace;font-family:var(--mono);font-size:12px;padding:8px 14px;white-space:nowrap}.filter-actions{border-top:1px solid #e8e8ef;border-top:1px solid var(--rule);display:flex;gap:10px;justify-content:flex-end;padding-top:20px}.report-results{background:#fff;background:var(--surface);border:1px solid #e8e8ef;border:1px solid var(--rule);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow);overflow:hidden}.report-summary{border-bottom:1px solid #e8e8ef;border-bottom:1px solid var(--rule);padding:32px}.report-summary h3{color:#9a9ab0;color:var(--ink-4);font-size:12px;font-weight:600;letter-spacing:.06em;margin-bottom:24px;text-transform:uppercase}.summary-grid{grid-gap:0;display:grid;gap:0;grid-template-columns:repeat(6,1fr)}.summary-item{align-items:center;border-right:1px solid #e8e8ef;border-right:1px solid var(--rule);display:flex;flex-direction:column;padding:20px 24px;position:relative;text-align:center}.summary-item:last-child{border-right:none}.summary-item:before{background:#4f46e5;background:var(--accent);border-radius:0 0 2px 2px;content:"";height:3px;left:24px;opacity:0;position:absolute;right:24px;top:0;transition:opacity .2s ease}.summary-item:hover:before{opacity:1}.summary-value{color:#1a1a2e;color:var(--ink);font-family:JetBrains Mono,ui-monospace,monospace;font-family:var(--mono);font-size:28px;font-weight:500;letter-spacing:-.02em;line-height:1;margin-bottom:10px}.summary-label{color:#6b6b8a;color:var(--ink-3);font-size:12px;letter-spacing:.04em;text-transform:uppercase}.summary-meta{border-top:1px solid #e8e8ef;border-top:1px solid var(--rule);color:#9a9ab0;color:var(--ink-4);font-family:JetBrains Mono,ui-monospace,monospace;font-family:var(--mono);font-size:13px;margin-top:24px;padding-top:20px}.report-data{padding:32px}.report-data-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.report-data h3{color:#9a9ab0;color:var(--ink-4);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.report-table{border:1px solid #e8e8ef;border:1px solid var(--rule);border-radius:6px;border-radius:var(--radius-sm);box-shadow:none;font-size:14px;overflow:hidden}.no-results{border:1px dashed #d4d4e0;border:1px dashed var(--rule-heavy);border-radius:6px;border-radius:var(--radius-sm);font-size:15px;padding:60px 48px;text-align:center}.no-results,.report-status-bar{background:#f7f7fa;background:var(--ground);color:#6b6b8a;color:var(--ink-3)}.report-status-bar{align-items:center;border-top:1px solid #e8e8ef;border-top:1px solid var(--rule);display:flex;font-family:JetBrains Mono,ui-monospace,monospace;font-family:var(--mono);font-size:13px;gap:12px;padding:14px 32px}.status-dot{background:#22c55e;background:var(--success);border-radius:50%;flex-shrink:0;height:8px;width:8px}@media (max-width:1024px){.report-generator{padding:32px 28px}.report-configuration{grid-template-columns:1fr}.report-type-selection{border-bottom:1px solid #e8e8ef;border-bottom:1px solid var(--rule);border-right:none;padding:20px 0}.report-type-grid{flex-direction:row;flex-wrap:wrap;gap:6px;padding:0 20px}.report-type-option{border-bottom:2px solid #0000;border-left:none;padding:10px 16px}.report-type-option:has(input:checked){border-bottom-color:#4f46e5;border-bottom-color:var(--accent);border-left-color:#0000}.summary-grid{grid-template-columns:repeat(3,1fr)}.summary-item{border-bottom:1px solid #e8e8ef;border-bottom:1px solid var(--rule);padding:16px 20px}.summary-item:nth-child(3n){border-right:none}.summary-value{font-size:24px}}@media (max-width:768px){.report-header{align-items:flex-start;flex-direction:column;gap:20px}.report-header-title{font-size:26px}.report-actions{width:100%}.report-actions .btn{flex:1 1;justify-content:center}.summary-grid{grid-template-columns:repeat(2,1fr)}.filters-grid{grid-template-columns:1fr}.presets-group{flex-wrap:wrap}.filter-input,.filter-select{font-size:16px}.report-data,.report-summary{padding:24px}}.reports-page{margin:0 auto;max-width:1200px;padding:20px}.page-header{text-align:center}.page-header h1{color:#1f2937;font-size:32px;font-weight:700;margin:0 0 12px}.page-description{color:#6b7280;font-size:16px;line-height:1.6;margin:0 auto;max-width:600px}@media (max-width:768px){.reports-page{padding:16px}.page-header h1{font-size:28px}.page-description{font-size:14px}}@media (max-width:480px){.reports-page{padding:12px}.page-header h1{font-size:24px}}:root{--bg:#f7f7f5;--border:#e8e8e4;--border-focus:#222;--text-primary:#141414;--text-secondary:#6b6b68;--text-muted:#a8a8a4;--accent:#141414;--accent-hover:#333;--danger:#c0392b;--overdue:#fef3f2;--overdue-text:#c0392b;--badge-bg:#f0f0ec;--badge-text:#444;--radius:8px;--shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;--transition:150ms ease}.profile-page{background:#f7f7f5;background:var(--bg);color:#141414;color:var(--text-primary);font-family:DM Sans,sans-serif;min-height:100vh;padding:40px 24px 80px}.profile-inner{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:680px}.section-label{color:#a8a8a4;color:var(--text-muted);font-size:.68rem;font-weight:600;letter-spacing:.12em;margin-bottom:10px;text-transform:uppercase}.change-password-card,.profile-assignments-card,.profile-card{background:#fff;background:var(--surface);border:1px solid #e8e8e4;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;box-shadow:var(--shadow);overflow:hidden}.profile-header{align-items:center;border-bottom:1px solid #e8e8e4;border-bottom:1px solid var(--border);display:flex;gap:18px;padding:24px}.avatar img{background:#f0f0ec;background:var(--badge-bg);border:1px solid #e8e8e4;border:1px solid var(--border);border-radius:50%;display:block;height:52px;width:52px}.profile-meta{flex:1 1;min-width:0}.profile-meta h2{color:#141414;color:var(--text-primary);font-size:1.05rem;font-weight:600;margin:0 0 3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-meta .meta-sub{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.profile-meta .email{color:#6b6b68;color:var(--text-secondary);font-family:DM Mono,monospace;font-size:.83rem}.role-badge{background:#f0f0ec;background:var(--badge-bg);border:1px solid #e8e8e4;border:1px solid var(--border);border-radius:99px;color:#444;color:var(--badge-text);font-size:.7rem;font-weight:600;letter-spacing:.06em;padding:2px 8px}.profile-body{padding:0}.profile-row{align-items:center;border-bottom:1px solid #e8e8e4;border-bottom:1px solid var(--border);display:flex;gap:16px;padding:14px 24px}.profile-row:last-of-type{border-bottom:none}.profile-row label{color:#6b6b68;color:var(--text-secondary);flex-shrink:0;font-size:.8rem;font-weight:500;width:130px}.profile-row span{font-size:.9rem}.profile-row input,.profile-row span{color:#141414;color:var(--text-primary)}.profile-row input{background:#f7f7f5;background:var(--bg);border:1px solid #e8e8e4;border:1px solid var(--border);border-radius:6px;flex:1 1;font-family:DM Sans,sans-serif;font-size:.88rem;outline:none;padding:7px 10px;transition:border-color .15s ease;transition:border-color var(--transition)}.profile-row input:focus{background:#fff;border-color:#222;border-color:var(--border-focus)}.password-input-wrapper{flex:1 1}.password-input-wrapper input{flex:1 1;padding-right:40px}.password-input-wrapper input.success-input,.password-input-wrapper input.success-input:focus{border-color:#059669}.password-input-wrapper input.error-input{border-color:#c0392b;border-color:var(--danger)}.password-toggle-btn{align-items:center;background:none;border:none;border-radius:4px;color:#6b6b68;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:4px;position:absolute;right:8px;z-index:1}.password-match-indicator,.password-toggle-btn{transition:color .15s ease;transition:color var(--transition)}.password-match-indicator{right:40px}.password-match-indicator.no-match{color:#c0392b;color:var(--danger)}.password-toggle-btn:hover{color:#141414;color:var(--text-primary)}.error-message{color:#c0392b;color:var(--danger)}.error-message,.success-message{display:block;margin-top:4px}.card-footer{background:#f7f7f5;background:var(--bg);border-top:1px solid #e8e8e4;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;padding:14px 24px}.btn{font-family:DM Sans,sans-serif;font-size:.83rem;padding:7px 16px;transition:background .15s ease,color .15s ease,border-color .15s ease;transition:background var(--transition),color var(--transition),border-color var(--transition)}.btn-primary{background:#141414;background:var(--accent);border-color:#141414;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:#333;background:var(--accent-hover)}.btn-primary:disabled{cursor:not-allowed;opacity:.45}.btn-ghost{background:#0000;border-color:#e8e8e4;border-color:var(--border);color:#6b6b68;color:var(--text-secondary)}.btn-ghost:hover{background:#f0f0ec;background:var(--badge-bg);color:#141414;color:var(--text-primary)}.change-password-card .card-header{border-bottom:1px solid #e8e8e4;border-bottom:1px solid var(--border);padding:18px 24px 14px}.change-password-card .card-header h3{color:#141414;color:var(--text-primary);font-size:.88rem;font-weight:600;margin:0}.profile-assignments-card .card-header{border-bottom:1px solid #e8e8e4;border-bottom:1px solid var(--border);padding:18px 24px 14px}.profile-assignments-card .card-header h3{color:#141414;color:var(--text-primary);font-size:.88rem;font-weight:600;margin:0}.assignments-tabs{border-bottom:1px solid #e8e8e4;border-bottom:1px solid var(--border);display:flex;gap:0;padding:0 24px}.tab-btn{color:#6b6b68;color:var(--text-secondary);font-family:DM Sans,sans-serif;font-size:.8rem;margin-right:24px;padding:11px 0;transition:color .15s ease,border-color .15s ease;transition:color var(--transition),border-color var(--transition)}.tab-btn.active,.tab-btn:hover{color:#141414;color:var(--text-primary)}.tab-btn.active{border-bottom-color:#141414;border-bottom-color:var(--text-primary)}.tab-count{align-items:center;background:#f0f0ec;background:var(--badge-bg);border-radius:99px;color:#6b6b68;color:var(--text-secondary);display:inline-flex;font-size:.68rem;font-weight:600;height:18px;justify-content:center;margin-left:5px;min-width:18px;padding:0 5px}.tab-count.danger{background:#fef3f2;background:var(--overdue);color:#c0392b;color:var(--overdue-text)}.assignment-list{list-style:none;margin:0;padding:0}.assignment-item{align-items:center;border-bottom:1px solid #e8e8e4;border-bottom:1px solid var(--border);display:flex;font-size:.85rem;gap:12px;justify-content:space-between;padding:13px 24px}.assignment-item:last-child{border-bottom:none}.assignment-serial{color:#141414;color:var(--text-primary);font-family:DM Mono,monospace;font-size:.82rem;font-weight:500}.assignment-dates{color:#6b6b68;color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:.78rem;gap:12px;justify-content:flex-end}.assignment-dates .due-overdue{color:#c0392b;color:var(--overdue-text);font-weight:500}.empty-state{color:#a8a8a4;color:var(--text-muted);font-size:.84rem;padding:32px 24px}.user-form{display:flex;flex-direction:column;gap:1rem;margin:0 auto;max-width:500px}.form-input,.form-select{border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;padding:.75rem;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-input.error,.form-select.error{border-color:#ef4444}.form-input:disabled,.form-select:disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper .form-input{flex:1 1;padding-right:3rem}.password-input-wrapper .form-input.success{border-color:#059669}.password-input-wrapper .form-input.success:focus{border-color:#059669;box-shadow:0 0 0 3px #0596691a}.password-toggle{background:none;border:none;border-radius:.25rem;color:#6b7280;cursor:pointer;font-size:1rem;padding:.25rem;position:absolute;right:.75rem;transition:color .2s;z-index:1}.password-match-indicator{font-size:1.1rem;font-weight:700;pointer-events:none;position:absolute;right:2.75rem;transition:color .2s}.password-match-indicator.match{color:#059669}.password-match-indicator.no-match{color:#ef4444}.password-toggle:hover{color:#374151}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.success-message{color:#059669;font-weight:500}.form-hint,.success-message{font-size:.75rem;margin-top:.25rem}.form-hint{color:#6b7280;line-height:1.4}@media (max-width:640px){.user-form{max-width:100%;padding:.5rem}.form-actions{flex-direction:column-reverse}.btn{width:100%}.btn,.form-input,.form-select{min-height:44px}}@media (max-width:1024px) and (min-width:641px){.user-form{max-width:90%}}@media (max-width:768px) and (orientation:landscape){.user-form{max-height:80vh;overflow-y:auto}}.user-list{margin:0 auto;max-width:1200px;padding:1.5rem}.user-list-header{margin-bottom:2rem}.user-search{margin-bottom:1rem}.user-table{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a}@media (max-width:768px){.user-list{padding:1rem}.header-content{align-items:stretch;flex-direction:column;gap:1rem}.header-content h2{text-align:center}.action-buttons{flex-direction:column;gap:.25rem}.btn-sm{justify-content:center;width:100%}}.department-form{display:flex;flex-direction:column;gap:1rem;margin:0 auto;max-width:500px}.auto-save-indicator .spinner-border{margin-right:.5rem}.form-group{gap:.5rem}.form-label{font-size:.875rem}.form-input,.form-textarea{border:1px solid #d1d5db;border-radius:.375rem;font-family:inherit;font-size:.875rem;padding:.75rem;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-input.error,.form-textarea.error{border-color:#ef4444}.form-input:disabled,.form-textarea:disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.form-textarea{min-height:100px;resize:vertical}.character-count{color:#6b7280;font-size:.75rem}.error-message{color:#ef4444;font-size:.75rem;margin-top:.25rem}.form-actions{border-top:1px solid #e5e7eb;margin-top:1.5rem}@media (max-width:640px){.department-form{max-width:100%;padding:.5rem}.form-actions{flex-direction:column-reverse}.btn{width:100%}.btn,.form-input,.form-textarea{min-height:44px}}@media (max-width:1024px) and (min-width:641px){.department-form{max-width:90%}}@media (max-width:768px) and (orientation:landscape){.department-form{max-height:80vh;overflow-y:auto}}.department-users{margin-top:2rem}.department-users-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.department-users-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.user-count{background-color:#f3f4f6;border-radius:9999px;color:#6b7280;font-size:.875rem;font-weight:500;padding:.25rem .75rem}.error-state,.loading-state{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;gap:1rem;justify-content:center;padding:2rem}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:1.5rem;width:1.5rem}.error-state{background-color:#fef2f2;border-color:#fecaca;color:#dc2626}.empty-state{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:3rem 2rem}.empty-icon{opacity:.5}.empty-state h4{color:#374151;font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.empty-state p{font-size:.875rem}.department-users-table{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a}.role-badge{border-radius:9999px;display:inline-block;font-size:.75rem;font-weight:500;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.role-admin{background-color:#fef3c7;color:#d97706}.role-manager{background-color:#dbeafe;color:#2563eb}.role-viewer{background-color:#f3f4f6;color:#6b7280}@media (max-width:768px){.department-users-header{align-items:flex-start;flex-direction:column;gap:.5rem}.empty-state{padding:2rem 1rem}}.department-list{margin:0 auto;max-width:1200px;padding:1.5rem}.department-list-header{margin-bottom:2rem}.header-content{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.header-content h2{color:#1f2937;font-size:1.875rem;font-weight:700;margin:0}.department-search,.error-banner{margin-bottom:1rem}.error-banner{align-items:center;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.375rem;color:#dc2626;display:flex;justify-content:space-between;padding:.75rem 1rem}.error-close{background:none;border:none;color:#dc2626;cursor:pointer;font-size:1.25rem;margin-left:1rem;padding:0}.error-close:hover{color:#b91c1c}.department-table{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a}.status-badge{border-radius:9999px;display:inline-block;font-weight:500;letter-spacing:.05em}.status-active{background-color:#dcfce7;color:#16a34a}.status-archived{background-color:#fef2f2;color:#dc2626}.action-buttons{flex-wrap:wrap;gap:.5rem}.btn{font-size:.875rem;transition:all .2s}.btn-sm{font-size:.75rem;padding:.375rem .75rem}.btn-primary{border-color:#3b82f6}.btn-primary:hover:not(:disabled){border-color:#2563eb}.btn-secondary{background-color:#fff}.btn-secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.btn-danger{background-color:#ef4444;border-color:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626}@media (max-width:768px){.department-list{padding:1rem}.header-content{align-items:stretch;flex-direction:column;gap:1rem}.header-content h2{text-align:center}.action-buttons{flex-direction:column;gap:.25rem}.btn-sm{justify-content:center;width:100%}}@media (max-width:640px){.action-buttons{flex-direction:row;justify-content:center}.btn-sm{font-size:.625rem;min-width:60px;padding:.25rem .5rem;width:auto}}.device-form{padding:1rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.form-group{display:flex;flex-direction:column}.form-label.required:after{color:#dc3545;content:" *"}.alert-warning{background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.auto-save-indicator{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:.375rem;color:#6c757d;font-size:.875rem;margin-bottom:1rem;padding:.5rem .75rem}.auto-save-indicator.saved{background-color:#d4edda;border-color:#c3e6cb;color:#155724}@media (max-width:768px){.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}.device-form{padding:.5rem}}@media (max-width:1024px) and (min-width:769px){.form-row{gap:.75rem}}@media (max-width:768px) and (orientation:landscape){.device-form{max-height:80vh;overflow-y:auto}}.device-status-badge{align-items:center;border-radius:.375rem;display:inline-flex;font-size:.875rem;font-weight:500;gap:.25rem;letter-spacing:.025em;padding:.25rem .5rem;text-transform:uppercase;white-space:nowrap}.device-status-badge.size-sm{font-size:.75rem;padding:.125rem .375rem}.device-status-badge.size-md{font-size:.875rem;padding:.25rem .5rem}.device-status-badge.size-lg{font-size:1rem;padding:.375rem .75rem}.device-status-badge.status-available{background-color:#d1e7dd;border:1px solid #badbcc;color:#0f5132}.device-status-badge.status-assigned{background-color:#cff4fc;border:1px solid #b6effb;color:#055160}.device-status-badge.status-maintenance{background-color:#fff3cd;border:1px solid #ffecb5;color:#664d03}.device-status-badge.status-retired{background-color:#e9ecef;border:1px solid #dee2e6;color:#495057}.device-status-badge.status-unknown{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}@media (max-width:576px){.device-status-badge .status-text{display:none}.device-status-badge{justify-content:center;min-width:2rem;padding:.25rem}}.device-list{padding:1.5rem}.device-list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.device-list-header h2{color:#333;font-weight:600;margin:0}.device-list-filters{margin-bottom:1.5rem}.device-actions{display:flex;flex-wrap:wrap;gap:.5rem}.device-actions .btn{border-radius:.25rem;font-size:.875rem;padding:.25rem .5rem}.btn-outline-success{color:#007bff}@media (max-width:768px){.device-list{padding:1rem}.device-list-header{align-items:stretch;gap:1rem}.device-actions,.device-list-header{flex-direction:column}.device-actions .btn{width:100%}}.device-history{max-height:70vh;overflow-y:auto;padding:1rem}.device-history-header{border-bottom:1px solid #dee2e6;margin-bottom:1.5rem;padding-bottom:1rem}.device-history-header h3{color:#333;font-weight:600;margin:0 0 .5rem}.device-history-error{padding:1rem}.device-history-actions{border-top:1px solid #dee2e6;display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem}.history-timeline{position:relative}.timeline-item{display:flex;margin-bottom:1.5rem}.timeline-item:last-child{margin-bottom:0}.timeline-marker{flex-direction:column;flex-shrink:0;margin-right:1rem}.timeline-dot,.timeline-marker{align-items:center;display:flex}.timeline-dot{border-radius:50%;color:#fff;font-size:.875rem;font-weight:700;height:2rem;justify-content:center;width:2rem;z-index:1}.timeline-dot.completed{background-color:#198754}.timeline-dot.active{background-color:#0d6efd}.timeline-line{background-color:#dee2e6;flex-grow:1;margin-top:.5rem;width:2px}.timeline-content{flex-grow:1;min-width:0}.assignment-card{background:#f8f9fa;border:1px solid #dee2e6;border-radius:.5rem;padding:1rem}.assignment-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.assignment-user{display:flex;flex-direction:column;gap:.25rem}.assignment-user strong{color:#333;font-size:1rem}.user-username{color:#6c757d;font-size:.875rem}.assignment-department{background-color:#e9ecef;border-radius:.25rem;color:#495057;font-size:.875rem;font-weight:500;padding:.25rem .5rem}.assignment-details{display:flex;flex-direction:column;gap:.75rem}.assignment-dates{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.date-item{display:flex;flex-direction:column;gap:.25rem}.date-label,.duration-label,.notes-label{color:#6c757d;font-size:.875rem;font-weight:500}.date-value,.duration-value,.notes-value{color:#333;font-size:.875rem}.current-assignment{color:#0d6efd;font-weight:500}.assignment-duration,.assignment-notes{display:flex;flex-direction:column;gap:.25rem}.notes-value{background-color:#fff;border:1px solid #dee2e6;border-radius:.25rem;font-style:italic;padding:.5rem}.empty-history{color:#6c757d;padding:3rem 1rem;text-align:center}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-history h4{color:#495057;margin-bottom:.5rem}.empty-history p{font-size:.875rem;margin:0}.btn-secondary:hover{background-color:#5c636a;border-color:#565e64;color:#fff}@media (max-width:768px){.device-history{padding:.5rem}.assignment-header{align-items:stretch;flex-direction:column;gap:.5rem}.assignment-dates{gap:.5rem;grid-template-columns:1fr}.timeline-marker{margin-right:.5rem}.timeline-dot{font-size:.75rem;height:1.5rem;width:1.5rem}}.device-details-tabs{padding:1rem}.tabs-header{border-bottom:1px solid #dee2e6;display:flex;gap:.5rem;margin-bottom:1.5rem}.tab-btn{background:none;border:none;border-bottom:2px solid #0000;color:#6c757d;cursor:pointer;font-weight:500;padding:.75rem 1.25rem;transition:all .2s}.tab-btn:hover{background-color:#f8f9fa;color:#495057}.tab-btn.active{border-bottom-color:#0d6efd;color:#0d6efd}.tab-content{min-height:300px}.specs-container{max-width:900px}.specs-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.specs-header h3{color:#212529;font-size:1.5rem;font-weight:600;margin:0}.btn-specs-edit{background:#fff;border:1px solid #0d6efd;border-radius:6px;color:#0d6efd;cursor:pointer;font-weight:500;padding:.5rem 1.25rem;transition:all .2s}.btn-specs-edit:hover{background:#0d6efd;color:#fff}.specs-list-view{background:#fff;border:1px solid #e9ecef;border-radius:8px;overflow:hidden}.spec-row{border-bottom:1px solid #f1f3f5;display:grid;grid-template-columns:200px 1fr;transition:background .15s}.spec-row:last-child{border-bottom:none}.spec-key,.spec-row:hover{background:#f8f9fa}.spec-key{border-right:1px solid #e9ecef;color:#495057;font-weight:600;padding:.875rem 1rem}.spec-value{color:#212529;padding:.875rem 1rem;word-break:break-word}.specs-empty{align-items:center;background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.specs-empty svg{color:#adb5bd;margin-bottom:1rem}.specs-empty p{color:#6c757d;font-size:1rem;margin-bottom:1.5rem}.btn-add-specs{background:#0d6efd;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.625rem 1.5rem;transition:all .2s}.btn-add-specs:hover{background:#0b5ed7}.specs-form{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:1.5rem}.specs-form-toolbar{border-bottom:1px solid #e9ecef;display:flex;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem}.spec-search{border:1px solid #ced4da;border-radius:6px;flex:1 1;font-size:.9375rem;padding:.625rem 1rem}.spec-search:focus{border-color:#0d6efd;box-shadow:0 0 0 3px #0d6efd1a;outline:none}.btn-template{background:#fff;border:1px solid #ced4da;border-radius:6px;color:#495057;cursor:pointer;font-weight:500;padding:.625rem 1.25rem;transition:all .2s;white-space:nowrap}.btn-template:hover{background:#f8f9fa;border-color:#adb5bd}.specs-list-edit{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;max-height:400px;overflow-y:auto}.spec-row-edit{grid-gap:.75rem;align-items:center;background:#f8f9fa;border-radius:6px;display:grid;gap:.75rem;grid-template-columns:200px 1fr auto;padding:.5rem}.spec-key-locked{background:#e9ecef;border-radius:4px;color:#495057;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spec-key-locked,.spec-value-input{font-size:.9375rem;padding:.625rem 1rem}.spec-value-input{background:#fff;border:1px solid #ced4da;border-radius:4px}.spec-value-input:focus{border-color:#0d6efd;box-shadow:0 0 0 3px #0d6efd1a;outline:none}.btn-remove-spec{align-items:center;background:#fff;border:1px solid #dc3545;border-radius:4px;color:#dc3545;cursor:pointer;display:flex;font-size:1.25rem;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.btn-remove-spec:hover{background:#dc3545;color:#fff}.add-field-section{background:#f8f9fa;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.add-field-header{color:#495057;font-size:.9375rem;font-weight:600;margin-bottom:1rem}.add-field-row{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:200px 1fr auto;margin-bottom:1rem}.add-field-input{background:#fff;border:1px solid #ced4da;border-radius:6px;font-size:.9375rem;padding:.625rem 1rem}.add-field-input:focus{border-color:#0d6efd;box-shadow:0 0 0 3px #0d6efd1a;outline:none}.btn-add-field{background:#0d6efd;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.625rem 1.5rem;transition:all .2s;white-space:nowrap}.btn-add-field:hover{background:#0b5ed7}.quick-add-chips{display:flex;flex-wrap:wrap;gap:.5rem}.chip-btn{background:#fff;border:1px solid #ced4da;border-radius:16px;color:#495057;cursor:pointer;font-size:.875rem;padding:.375rem .75rem;transition:all .2s}.chip-btn:hover{background:#0d6efd;border-color:#0d6efd;color:#fff}.specs-form-actions{border-top:1px solid #e9ecef;display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem}.btn-cancel{background:#fff;border:1px solid #ced4da;border-radius:6px;color:#495057;cursor:pointer;font-weight:500;padding:.625rem 1.5rem;transition:all .2s}.btn-cancel:hover{background:#f8f9fa}.btn-save{background:#0d6efd;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.625rem 2rem;transition:all .2s}.btn-save:hover{background:#0b5ed7}.attachments-container{display:flex;flex-direction:column;gap:1.5rem}.file-input-wrapper{display:inline-block;position:relative}.file-input-wrapper input[type=file]{cursor:pointer;height:100%;left:0;opacity:0;position:absolute;top:0;width:100%}.attachments-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.attachment-card{background-color:#fff;border:1px solid #dee2e6;border-radius:.5rem;display:flex;flex-direction:column;padding:1rem;transition:transform .2s,box-shadow .2s}.attachment-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.attachment-info{flex-grow:1;margin-bottom:1rem}.attachment-name{display:block;font-weight:600;margin-bottom:.25rem;word-break:break-all}.attachment-meta{color:#6c757d;font-size:.75rem}.attachment-actions{display:flex;gap:.5rem;margin-top:auto}.attachment-actions .btn{flex:1 1;font-size:.875rem;padding:.4rem}.empty-attachments{background-color:#f8f9fa;border-radius:.5rem;color:#6c757d;padding:3rem;text-align:center}@media (max-width:768px){.add-field-row,.spec-row,.spec-row-edit{grid-template-columns:1fr}.spec-key{border-bottom:1px solid #e9ecef;border-right:none}.btn-remove-spec{width:100%}.specs-form-toolbar{flex-direction:column}}.device-view-page{display:flex;flex-direction:column;gap:18px;margin:0 auto;max-width:1200px;padding:24px}.device-view-header{align-items:flex-end;border-bottom:1px solid #e5e7eb;display:flex;gap:12px;justify-content:space-between;padding-bottom:14px}.device-view-heading h2{margin:0}.device-view-eyebrow{color:#6b7280;font-size:11px;letter-spacing:.14em;text-transform:uppercase}.device-view-subtitle{color:#6b7280;margin:4px 0 0}.device-view-tabs{border-bottom:2px solid #e5e7eb;display:flex;gap:.5rem;overflow-x:auto}.device-tab{background:none;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;font-size:.9375rem;font-weight:500;padding:.875rem 1.5rem;transition:all .2s;white-space:nowrap}.device-tab:hover{background-color:#f9fafb;color:#374151}.device-tab.active{background-color:#f0f7ff;border-bottom-color:#0d6efd;color:#0d6efd}.device-view-content{min-height:400px}.device-view-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:20px}.device-view-card-title{color:#111827;font-size:1.125rem;font-weight:600;margin-bottom:1.25rem}.device-view-grid{grid-gap:12px 14px;display:grid;gap:12px 14px;grid-template-columns:repeat(4,minmax(0,1fr))}.device-view-field{background:#f8fafc;border:1px solid #f1f5f9;border-radius:8px;padding:10px 12px}.device-view-label{color:#6b7280;font-size:12px;font-weight:600;margin-bottom:4px}.device-view-value{color:#111827;font-size:14px}.device-view-value.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.device-view-table-container{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px}@media (max-width:1024px){.device-view-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:640px){.device-view-header{align-items:flex-start;flex-direction:column}.device-view-grid{grid-template-columns:1fr}.device-view-tabs{gap:0}.device-tab{font-size:.875rem;padding:.75rem 1rem}}.modern-assignment-form{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin:0 auto;max-width:600px;padding:2rem}.form-header{border-bottom:2px solid #f0f0f0;margin-bottom:2rem;padding-bottom:1.5rem}.form-header h2{color:#1a1a1a;font-size:1.75rem;font-weight:600;letter-spacing:-.02em;margin:0 0 .5rem}.form-subtitle{color:#6b7280;font-size:.95rem;margin:0}.form-section{margin-bottom:2rem}.section-title{border-bottom:1px solid #e5e7eb;color:#374151;font-size:1rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem}.form-group label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.required{color:#ef4444;margin-left:.25rem}.form-control{border:1.5px solid #d1d5db;border-radius:8px;color:#1f2937;font-size:.95rem;line-height:1.5;padding:.75rem 1rem}.form-control:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-control:disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed}select.form-control{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%236b7280' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;cursor:pointer;padding-right:2.5rem}select.device-select{font-family:Courier New,monospace;font-size:.875rem;height:auto;padding:.5rem}select.device-select option{padding:.5rem}textarea.form-control{min-height:80px;resize:vertical}.form-text{color:#6b7280;display:block;font-size:.8125rem;margin-top:.375rem}.alert{font-size:.875rem;margin-bottom:1.5rem;padding:1rem}.alert-danger{border:1px solid #fecaca}.form-actions{border-top:2px solid #f0f0f0;gap:.75rem;padding-top:1.5rem}.btn{border:none;border-radius:8px;font-size:.9375rem;font-weight:500;min-width:120px;padding:.75rem 1.5rem;transition:all .2s ease}.btn:disabled{opacity:.6}.btn-primary{background-color:#3b82f6}.btn-primary:hover:not(:disabled){background-color:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.btn-secondary{background-color:#f3f4f6}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb}.modern-assignment-form .spinner-container{align-items:center;display:flex;justify-content:center;min-height:300px}@media (max-width:640px){.modern-assignment-form{margin:1rem;padding:1.5rem}.form-header h2{font-size:1.5rem}.form-actions{flex-direction:column-reverse}.btn{width:100%}}.modern-assignment-form{animation:fadeIn .3s ease}.return-device-error,.return-device-form{padding:1rem}.assignment-summary{margin-bottom:2rem}.assignment-summary h3{color:#333;font-weight:600;margin-bottom:1rem}.summary-card{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:.5rem;padding:1.5rem}.summary-row{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.summary-row:last-child{margin-bottom:0}.summary-label{color:#6c757d;flex-shrink:0;font-weight:500;min-width:120px}.summary-value{color:#333;flex-grow:1;text-align:right}.summary-value.overdue{color:#dc3545;font-weight:500}.overdue-badge{background-color:#dc3545;border-radius:.25rem;color:#fff;display:inline-block;font-size:.75rem;font-weight:500;margin-left:.5rem;padding:.125rem .375rem;text-transform:uppercase}.assignment-notes{word-wrap:break-word;background-color:#fff;border:1px solid #dee2e6;border-radius:.25rem;font-style:italic;max-width:300px;padding:.5rem}.return-form{border-top:1px solid #dee2e6;padding-top:1.5rem}.form-group{margin-bottom:1.5rem}.form-label{color:#333;font-weight:500;margin-bottom:.5rem}.form-control{border:1px solid #ced4da;border-radius:.375rem;font-family:inherit;font-size:1rem;padding:.5rem .75rem;resize:vertical;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.form-control:focus{border-color:#86b7fe;box-shadow:0 0 0 .25rem #0d6efd40}.form-control.is-invalid{border-color:#dc3545}.form-control.is-invalid:focus{border-color:#dc3545;box-shadow:0 0 0 .25rem #dc354540}.character-count{color:#6c757d;text-align:right}.character-count,.invalid-feedback{font-size:.875rem;margin-top:.25rem}.invalid-feedback{color:#dc3545;display:block}.form-actions{border-top:1px solid #dee2e6;display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem}.btn:disabled{opacity:.65}.btn-primary:hover:not(:disabled){background-color:#0b5ed7;border-color:#0a58ca}.btn-secondary{background-color:#6c757d;border-color:#6c757d;color:#212529}.btn-secondary:hover:not(:disabled){background-color:#5c636a;border-color:#565e64;color:#fff}.spinner-border{border:.125em solid;border-right:.125em solid #0000;height:1rem;vertical-align:-.125em;width:1rem}.spinner-border-sm{border-width:.125em;height:.875rem;width:.875rem}.me-2{margin-right:.5rem}@media (max-width:768px){.return-device-form{padding:.5rem}.summary-row{align-items:stretch;flex-direction:column;gap:.25rem}.summary-label{min-width:auto}.summary-value{text-align:left}.assignment-notes{max-width:none}.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}}.assignment-status-badge{align-items:center;border-radius:.375rem;display:inline-flex;font-size:.875rem;font-weight:500;gap:.25rem;letter-spacing:.025em;padding:.25rem .5rem;text-transform:uppercase;white-space:nowrap}.assignment-status-badge.size-sm{font-size:.75rem;padding:.125rem .375rem}.assignment-status-badge.size-md{font-size:.875rem;padding:.25rem .5rem}.assignment-status-badge.size-lg{font-size:1rem;padding:.375rem .75rem}.assignment-status-badge.status-active{background-color:#cff4fc;border:1px solid #b6effb;color:#055160}.assignment-status-badge.status-returned{background-color:#d1e7dd;border:1px solid #badbcc;color:#0f5132}.assignment-status-badge.status-overdue{background-color:#f8d7da;border:1px solid #f5c2c7;color:#842029}.assignment-status-badge.status-unknown{background-color:#e9ecef;border:1px solid #dee2e6;color:#495057}.status-icon{font-size:.875em}.status-icon,.status-text{line-height:1}@media (max-width:576px){.assignment-status-badge .status-text{display:none}.assignment-status-badge{justify-content:center;min-width:2rem;padding:.25rem}}.assignment-list{padding:1.5rem}.assignment-list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.assignment-list-header h2{color:#333;font-weight:600;margin:0}.assignment-list-filters{margin-bottom:1.5rem}.assignment-actions{display:flex;flex-wrap:wrap;gap:.5rem}.assignment-actions .btn{border-radius:.25rem;font-size:.875rem;padding:.25rem .5rem}.device-serial,.user-name{color:#333;font-weight:500}.text-muted{color:#6c757d;font-size:.875rem}.alert{border:1px solid #0000;border-radius:.375rem;margin-bottom:1rem;padding:.75rem 1rem}.alert-danger{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24}.btn{border-radius:.375rem;font-size:1rem;font-weight:400;padding:.5rem 1rem;transition:all .15s ease-in-out}.btn-primary{background-color:#0d6efd;border-color:#0d6efd}.btn-primary:hover{background-color:#0b5ed7;border-color:#0a58ca}.btn-sm{font-size:.875rem;padding:.25rem .5rem}.btn-outline-primary{background-color:initial;border-color:#0d6efd;color:#0d6efd}.btn-outline-primary:hover{background-color:#0d6efd;border-color:#0d6efd;color:#fff}.btn-outline-info{background-color:initial;border-color:#0dcaf0;color:#0dcaf0}.btn-outline-info:hover{background-color:#0dcaf0;border-color:#0dcaf0;color:#000}@media (max-width:768px){.assignment-list{padding:1rem}.assignment-list-header{align-items:stretch;flex-direction:column;gap:1rem}.assignment-actions{flex-direction:column}.assignment-actions .btn{width:100%}}.assignment-workflow{background:#fff;max-height:85vh;overflow-x:hidden;overflow-y:auto;padding:0}.workflow-steps{align-items:center;background:linear-gradient(135deg,#f8f9ff,#f0f4ff);border-radius:0;box-shadow:0 2px 8px #0000000a;display:flex;justify-content:center;margin-bottom:20px;padding:16px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.step{flex-direction:column;gap:6px}.step,.step-number{align-items:center;display:flex;position:relative}.step-number{background-color:#fff;border:2px solid #e5e7eb;border-radius:50%;box-shadow:0 2px 4px #0000000d;color:#9ca3af;font-size:14px;font-weight:700;height:36px;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);width:36px;z-index:2}.step.active .step-number{background:linear-gradient(135deg,#4f46e5,#6366f1);border-color:#4f46e5;box-shadow:0 4px 12px #4f46e54d;color:#fff;transform:scale(1.1)}.step.completed .step-number{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;box-shadow:0 2px 8px #10b98133;color:#fff}.step.completed .step-number:after{content:"✓";font-size:18px;font-weight:900;position:absolute}.step-label{color:#9ca3af;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;transition:color .3s ease}.step.active .step-label{color:#4f46e5;font-weight:700}.step.completed .step-label{color:#10b981;font-weight:600}.step-connector{background-color:#e5e7eb;border-radius:2px;height:2px;margin:0 12px;position:relative;transition:background-color .3s ease;width:50px}.step.completed+.step-connector{background:linear-gradient(90deg,#10b981,#059669)}.workflow-content{animation:fadeInUp .4s ease;margin-bottom:16px;padding:0 20px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.workflow-step h3{color:#111827;font-size:18px;font-weight:700;letter-spacing:-.02em;margin-bottom:6px}.step-description{color:#6b7280;font-size:13px;line-height:1.6;margin-bottom:16px}.department-grid,.device-grid,.user-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));margin-bottom:16px}.department-card,.device-card,.user-card{background-color:#fff;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;overflow:hidden;padding:14px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.department-card:before,.device-card:before,.user-card:before{background:linear-gradient(90deg,#4f46e5,#6366f1);content:"";height:4px;left:0;position:absolute;top:0;transform:scaleX(0);transition:transform .3s ease;width:100%}.department-card:hover,.device-card:hover,.user-card:hover{border-color:#4f46e5;box-shadow:0 8px 16px #4f46e51f;transform:translateY(-4px)}.department-card:hover:before,.device-card:hover:before,.user-card:hover:before{transform:scaleX(1)}.department-card.selected,.device-card.selected,.user-card.selected{background:linear-gradient(135deg,#f8f9ff,#fff);border-color:#4f46e5;box-shadow:0 8px 24px #4f46e533;transform:translateY(-2px)}.department-card.selected:before,.device-card.selected:before,.user-card.selected:before{transform:scaleX(1)}.department-card.selected:after,.device-card.selected:after,.user-card.selected:after{align-items:center;background:linear-gradient(135deg,#4f46e5,#6366f1);border-radius:50%;box-shadow:0 2px 8px #4f46e54d;color:#fff;content:"✓";display:flex;font-size:14px;font-weight:700;height:24px;justify-content:center;position:absolute;right:12px;top:12px;width:24px}.department-name{text-align:center}.department-name,.user-name{color:#111827;font-size:14px;font-weight:700;letter-spacing:-.01em}.user-name{margin-bottom:4px}.user-username{color:#6b7280;font-family:Courier New,monospace;font-size:12px;margin-bottom:6px}.user-role{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-radius:6px;color:#374151;display:inline-block;font-size:11px;font-weight:700;letter-spacing:.05em;padding:4px 10px;text-transform:uppercase}.device-serial{color:#111827;font-size:13px;font-weight:700;letter-spacing:-.01em;margin-bottom:4px}.device-type{color:#4f46e5;font-size:12px;font-weight:700;margin-bottom:6px}.device-details{color:#6b7280;font-size:11px;line-height:1.5;margin-bottom:6px}.device-details span:not(:last-child):after{color:#d1d5db;content:" • ";margin:0 4px}.device-category{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-radius:6px;color:#374151;display:inline-block;font-size:11px;font-weight:700;letter-spacing:.05em;padding:4px 10px;text-transform:uppercase}.assignment-details{background:linear-gradient(135deg,#fafbfc,#fff);border-radius:10px;border-top:2px solid #e5e7eb;margin-top:20px;padding:16px}.assignment-details h4{color:#111827;font-size:15px;font-weight:700;letter-spacing:-.01em;margin-bottom:14px}.form-group{margin-bottom:14px}.form-label{color:#374151;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.form-control{background-color:#fff;border:2px solid #d1d5db;border-radius:6px;color:#111827;font-size:13px;padding:9px 12px;transition:all .2s ease;width:100%}.form-control:focus{background-color:#fff;border-color:#4f46e5;box-shadow:0 0 0 4px #4f46e51a;outline:0}.form-control::placeholder{color:#9ca3af}.form-control.is-invalid{background-color:#fef2f2;border-color:#ef4444}.form-control.is-invalid:focus{box-shadow:0 0 0 4px #ef44441a}.invalid-feedback{align-items:center;color:#dc2626;display:flex;font-size:13px;font-weight:500;gap:4px;margin-top:6px}.invalid-feedback:before{content:"⚠";font-size:14px}.workflow-actions{background-color:#fafbfc;border-top:2px solid #e5e7eb;bottom:0;display:flex;gap:10px;justify-content:flex-end;margin-top:auto;padding:16px 20px;position:-webkit-sticky;position:sticky}.btn{border:2px solid #0000;border-radius:6px;font-size:13px;min-width:100px;padding:9px 18px;text-align:center;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn:disabled{opacity:.5;transform:none!important}.btn-primary{background:linear-gradient(135deg,#4f46e5,#6366f1);border-color:#4f46e5;box-shadow:0 2px 4px #4f46e533}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#4338ca,#4f46e5);border-color:#4338ca;box-shadow:0 4px 12px #4f46e54d;transform:translateY(-2px)}.btn-primary:active:not(:disabled){box-shadow:0 2px 4px #4f46e533;transform:translateY(0)}.btn-secondary{background:linear-gradient(135deg,#6b7280,#4b5563);border-color:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,#4b5563,#374151);border-color:#4b5563;transform:translateY(-2px)}.btn-outline-secondary{background-color:#fff;border-color:#d1d5db;color:#6b7280}.btn-outline-secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af;color:#374151}.btn-outline-secondary:active:not(:disabled){background-color:#f3f4f6}.spinner-border{animation:spinner-border .75s linear infinite;border:2px solid;border-radius:50%;border-right:2px solid #0000;display:inline-block;height:16px;vertical-align:middle;width:16px}.spinner-border-sm{border-width:2px;height:14px;width:14px}.me-2{margin-right:8px}@keyframes spinner-border{to{transform:rotate(1turn)}}.alert{align-items:center;animation:slideDown .3s ease;border:2px solid #0000;border-radius:8px;display:flex;font-size:13px;font-weight:500;gap:8px;margin-bottom:14px;padding:10px 14px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert:before{content:"⚠";font-size:18px}.alert-danger{background-color:#fef2f2;border-color:#fecaca;color:#991b1b}.empty-state{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:2px dashed #d1d5db;border-radius:12px;margin:20px 0;padding:60px 40px}.empty-state:before{content:"📦";display:block;font-size:48px;margin-bottom:16px;opacity:.5}.empty-state p{color:#6b7280;font-size:15px;font-weight:500;margin:0}@media (max-width:768px){.assignment-workflow{padding:0}.workflow-steps{flex-direction:column;gap:16px;padding:20px 16px}.step{flex-direction:row;gap:12px;justify-content:flex-start;width:100%}.step-connector{height:40px;margin:8px 0 8px 20px;width:3px}.workflow-content{padding:0 16px}.department-grid,.device-grid,.user-grid{grid-template-columns:1fr}.workflow-actions{flex-direction:column-reverse;padding:16px}.workflow-actions .btn{width:100%}.assignment-details{padding:16px}}.btn:focus-visible,.department-card:focus-visible,.device-card:focus-visible,.form-control:focus-visible,.user-card:focus-visible{outline:2px solid #4f46e5;outline-offset:2px}.assignment-workflow::-webkit-scrollbar{width:8px}.assignment-workflow::-webkit-scrollbar-track{background:#f3f4f6}.assignment-workflow::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.assignment-workflow::-webkit-scrollbar-thumb:hover{background:#9ca3af}.maintenance-form{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:24px}.maintenance-form .alert{align-items:center;border-radius:6px;display:flex;font-size:14px;gap:8px;margin-bottom:20px;padding:12px 16px}.maintenance-form .alert-danger{background-color:#fee;border:1px solid #fcc;color:#c33}.maintenance-form .alert-danger:before{content:"⚠";font-size:16px}.maintenance-form .form-group{margin-bottom:20px}.maintenance-form label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.maintenance-form .form-control{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;color:#495057;font-size:14px;line-height:1.5;padding:10px 12px;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;width:100%}.maintenance-form .form-control:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.maintenance-form .form-control:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.maintenance-form select.form-control{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23333' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;cursor:pointer;padding-right:36px}.maintenance-form textarea.form-control{min-height:80px;resize:vertical}.maintenance-form .form-row{display:flex;flex-wrap:wrap;margin-left:-12px;margin-right:-12px}.maintenance-form .col-md-6{flex:0 0 50%;max-width:50%;padding-left:12px;padding-right:12px}.maintenance-form .input-group{display:flex;width:100%}.maintenance-form .input-group-prepend{display:flex}.maintenance-form .input-group-prepend .input-group-text{align-items:center;background-color:#f9fafb;border:1px solid #d1d5db;border-radius:6px 0 0 6px;border-right:none;color:#6b7280;display:flex;font-size:14px;font-weight:600;padding:10px 12px}.maintenance-form .input-group .form-control{border-left:none;border-radius:0 6px 6px 0}.maintenance-form .input-group .form-control:focus{border-left:none}.maintenance-form .form-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin-top:28px;padding-top:24px}.maintenance-form .btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;justify-content:center;min-width:120px;padding:10px 20px;transition:all .15s ease-in-out}.maintenance-form .btn:disabled{cursor:not-allowed;opacity:.5}.maintenance-form .btn-primary{background-color:#4f46e5;color:#fff}.maintenance-form .btn-primary:hover:not(:disabled){background-color:#4338ca;box-shadow:0 2px 4px #4f46e533}.maintenance-form .btn-primary:active:not(:disabled){background-color:#3730a3}.maintenance-form .btn-secondary{background-color:#fff;border:1px solid #d1d5db;color:#374151}.maintenance-form .btn-secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.maintenance-form .btn-secondary:active:not(:disabled){background-color:#f3f4f6}@media (max-width:768px){.maintenance-form{padding:16px}.maintenance-form .col-md-6{flex:0 0 100%;max-width:100%;padding-left:0;padding-right:0}.maintenance-form .form-row{margin-left:0;margin-right:0}.maintenance-form .form-actions{flex-direction:column-reverse}.maintenance-form .btn{width:100%}}.maintenance-form .btn:disabled{position:relative}.maintenance-form .btn:disabled:after{animation:spinner .6s linear infinite;border:2px solid;border-radius:50%;border-top:2px solid #0000;content:"";height:14px;margin-left:8px;position:absolute;width:14px}@keyframes spinner{to{transform:rotate(1turn)}}.maintenance-form .btn:focus-visible{outline:2px solid #4f46e5;outline-offset:2px}.maintenance-form .form-control:focus-visible{outline:none}.maintenance-form .form-control::placeholder{color:#9ca3af;opacity:1}.maintenance-form label[for]{position:relative}.maintenance-form input:required+label:after,.maintenance-form select:required+label:after{color:#ef4444;content:"*";margin-left:4px}.maintenance-list-page{padding:20px}.maintenance-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.maintenance-filters{margin-bottom:20px}.status-badge{border-radius:4px;font-size:.85rem;padding:4px 8px}.status-pending{background-color:#fff3cd;color:#856404}.status-in-progress{background-color:#cce5ff;color:#004085}.status-completed{background-color:#d4edda;color:#155724}.status-cancelled{background-color:#f8d7da;color:#721c24}.maintenance-actions{display:flex;gap:5px}.public-catalog{background:#f5f7fa;margin:0 auto;max-width:1400px;min-height:100vh;padding:2rem}.catalog-header{margin-bottom:2rem;text-align:center}.catalog-header h1{color:#2c3e50;font-size:2.5rem;margin-bottom:.5rem}.catalog-header p{color:#7f8c8d;font-size:1.1rem}.summary-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;text-align:center;transition:transform .2s}.stat-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.stat-value{color:#2c3e50;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:#7f8c8d;font-size:.9rem;letter-spacing:.5px;text-transform:uppercase}.stat-available .stat-value{color:#27ae60}.stat-assigned .stat-value{color:#3498db}.stat-maintenance .stat-value{color:#f39c12}.catalog-filters{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding:1.5rem}.filter-group{flex:1 1;min-width:200px}.filter-select,.search-input{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .2s;width:100%}.filter-select:focus,.search-input:focus{border-color:#3498db;outline:none}.clear-filters-btn{background:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background .2s}.clear-filters-btn:hover{background:#c0392b}.device-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;overflow-x:auto}.device-table{border-collapse:collapse;min-width:800px;width:100%}.device-table thead{background:#f8f9fa;border-bottom:2px solid #dee2e6}.device-table th{color:#495057;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.device-table tbody tr{border-bottom:1px solid #dee2e6;transition:background-color .2s}.device-table tbody tr:hover{background-color:#f8f9fa}.device-table tbody tr:last-child{border-bottom:none}.device-table td{color:#495057;padding:1rem}.device-table .device-id{color:#2c3e50;font-family:Courier New,monospace;font-weight:600}.view-details-btn{background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:background .2s}.view-details-btn:hover{background:#2980b9}.device-table .status-badge{display:inline-block;padding:.35rem .75rem}.device-table .status-badge,.status-badge{border-radius:12px;font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.status-badge{padding:.25rem .75rem}.status-available{background:#d4edda;color:#155724}.status-assigned{background:#d1ecf1;color:#0c5460}.status-maintenance{background:#fff3cd;color:#856404}.status-unavailable{background:#f8d7da;color:#721c24}.stat-unavailable .stat-value{color:#e74c3c}.loading-state{padding:4rem 2rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:50px;margin:0 auto 1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-state{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:4rem 2rem;text-align:center}.error-state p{color:#e74c3c;font-size:1.1rem;margin-bottom:1rem}.error-state button{background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem}.empty-state{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:4rem 2rem;text-align:center}.empty-state p{color:#7f8c8d;font-size:1.1rem}.pagination{align-items:center;display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.pagination-btn{background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background .2s}.pagination-btn:hover:not(:disabled){background:#2980b9}.pagination-btn:disabled{background:#bdc3c7;cursor:not-allowed}.pagination-info{color:#7f8c8d;font-size:1rem}.last-updated{color:#95a5a6;font-size:.9rem;margin-top:2rem;text-align:center}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:100%}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#7f8c8d;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;line-height:1;padding:0;position:absolute;right:1rem;top:1rem;transition:background .2s;width:32px}.modal-close:hover{background:#ecf0f1;color:#2c3e50}.modal-content h2{border-bottom:1px solid #ecf0f1;color:#2c3e50;margin:0;padding:2rem 2rem 1rem}.modal-body{padding:2rem}.detail-row{align-items:center;border-bottom:1px solid #ecf0f1;display:flex;justify-content:space-between;padding:.75rem 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#7f8c8d;font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-value{color:#2c3e50;font-size:1rem}.specifications{border-top:2px solid #ecf0f1;margin-top:1.5rem;padding-top:1.5rem}.specifications h3{color:#2c3e50;font-size:1.1rem;margin-bottom:1rem}.modal-footer{background:#f8f9fa;border-top:1px solid #ecf0f1;padding:1.5rem 2rem}.contact-info{color:#7f8c8d;font-size:.9rem;margin:0;text-align:center}@media (max-width:768px){.public-catalog{padding:1rem}.catalog-header h1{font-size:2rem}.summary-stats{grid-template-columns:repeat(2,1fr)}.catalog-filters{flex-direction:column}.device-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.device-table{font-size:.9rem}.device-table td,.device-table th{padding:.75rem .5rem}.view-details-btn{font-size:.85rem;padding:.4rem .8rem}.modal-content{margin:1rem}.pagination{flex-direction:column;gap:.5rem}.pagination-info{margin-bottom:.5rem;order:-1}}.tab-navigation{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;gap:.5rem;margin-bottom:2rem;padding:.5rem}.tab-button{background:#0000;border:none;border-radius:6px;color:#7f8c8d;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:1rem 2rem;position:relative;transition:all .3s ease}.tab-button:hover{background:#f8f9fa;color:#2c3e50}.tab-button.active{background:#3498db;box-shadow:0 2px 8px #3498db4d;color:#fff}.tab-button.active:after{border-left:8px solid #0000;border-right:8px solid #0000;border-top:8px solid #3498db;bottom:-.5rem;content:"";height:0;left:50%;position:absolute;transform:translateX(-50%);width:0}.inventory-tab-content{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:3rem 2rem}.coming-soon{padding:2rem;text-align:center}.coming-soon h2{color:#2c3e50;font-size:2rem;margin-bottom:1rem}.coming-soon p{color:#7f8c8d;font-size:1.1rem;margin-bottom:.5rem}.coming-soon .info-text{line-height:1.6;margin:1.5rem auto 0;max-width:600px}@media (max-width:768px){.tab-navigation{flex-direction:column;gap:.25rem}.tab-button{padding:.75rem 1rem}.tab-button.active:after{display:none}.coming-soon h2{font-size:1.5rem}.coming-soon p{font-size:1rem}}:root{--warning-rule:#fcd34d}.inventory-dashboard-page{color:#0f1117;color:var(--ink);display:flex;flex-direction:column;font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-sans);gap:32px;margin:0 auto;max-width:1400px;padding:40px 48px 80px}.inventory-dashboard-header{align-items:flex-end;border-bottom:2px solid #0f1117;border-bottom:2px solid var(--ink);display:flex;justify-content:space-between;padding-bottom:20px}.inventory-dashboard-eyebrow{color:#9ca3af;color:var(--ink-4);font-size:10px;font-weight:600;letter-spacing:.16em;margin-bottom:5px;text-transform:uppercase}.inventory-dashboard-header h2{color:#0f1117;color:var(--ink);font-size:28px;font-weight:300;letter-spacing:-.025em;line-height:1}.inventory-quick-links{align-items:center;display:flex;gap:8px}.btn-primary:hover{background:#1d4ed8;background:var(--accent);border-color:#1d4ed8;border-color:var(--accent)}.btn-secondary:hover{border-color:#0f1117;border-color:var(--ink);color:#0f1117;color:var(--ink)}.inventory-metrics-grid{grid-gap:1px;background:#e5e7eb;background:var(--rule);border:1px solid #e5e7eb;border:1px solid var(--rule);display:grid;gap:1px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.inventory-metric-card{background:#fff;background:var(--surface);padding:32px 28px 28px;position:relative;transition:background .12s}.inventory-metric-card:before{background:#1d4ed8;background:var(--accent);content:"";height:2px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transform-origin:left;transition:transform .2s ease}.inventory-metric-card:hover:before{transform:scaleX(1)}.inventory-metric-card.warning:before{background:#b45309;background:var(--warning)}.inventory-metric-card.warning:hover{background:#fffbeb;background:var(--warning-light)}.inventory-metric-card.danger:before{background:#dc2626}.inventory-metric-card.danger:hover{background:#fef2f2}.inventory-metric-card h3{color:#9ca3af;color:var(--ink-4);font-size:10px;font-weight:700;letter-spacing:.14em;margin-bottom:12px;text-transform:uppercase}.inventory-metric-card.warning h3{color:#b45309;color:var(--warning)}.inventory-metric-card.danger h3{color:#dc2626}.inventory-metric-value{color:#0f1117;color:var(--ink);font-family:DM Mono,ui-monospace,monospace;font-family:var(--font-mono);font-size:40px;font-weight:500;letter-spacing:-.03em;line-height:1}.inventory-metric-card.warning .inventory-metric-value{color:#b45309;color:var(--warning)}.inventory-metric-card.danger .inventory-metric-value{color:#dc2626}.inventory-metric-label{color:#9ca3af;color:var(--ink-4);font-size:13px;line-height:1.4;margin-top:8px}.inventory-dashboard-sections{grid-gap:1px;background:#e5e7eb;background:var(--rule);border:1px solid #e5e7eb;border:1px solid var(--rule);display:grid;gap:1px;grid-template-columns:1fr 1fr}.inventory-panel{background:#fff;background:var(--surface);min-width:0;padding:28px}.inventory-panel-header{align-items:baseline;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--rule);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:14px}.inventory-panel h3{color:#9ca3af;color:var(--ink-4);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.inventory-panel-link{color:#1e40af;color:var(--accent-text);font-size:12px;font-weight:500;letter-spacing:.02em;text-decoration:none}.inventory-panel-link:hover{text-decoration:underline}.inventory-list{display:flex;flex-direction:column;list-style:none;margin:0;padding:0}.inventory-list li{grid-gap:16px;align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--rule);display:grid;font-size:15px;gap:16px;grid-template-columns:1fr auto auto;padding:12px 0}.inventory-list li:last-child{border-bottom:none}.inventory-list-name{color:#374151;color:var(--ink-2);font-size:15px;font-weight:400;min-width:0;overflow:hidden;text-decoration:none;text-overflow:ellipsis;white-space:nowrap}.inventory-list-name:hover{color:#1d4ed8;color:var(--accent)}.inventory-list-code{color:#9ca3af;color:var(--ink-4);font-size:12px}.inventory-list-code,.inventory-list-qty{flex-shrink:0;font-family:DM Mono,ui-monospace,monospace;font-family:var(--font-mono);text-align:right}.inventory-list-qty{color:#b45309;color:var(--warning);font-size:14px;font-weight:500;white-space:nowrap}.inventory-list-tx-type{color:#374151;color:var(--ink-2);font-size:14px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inventory-list-tx-id{color:#9ca3af;color:var(--ink-4);font-size:12px}.inventory-list-delta,.inventory-list-tx-id{flex-shrink:0;font-family:DM Mono,ui-monospace,monospace;font-family:var(--font-mono);text-align:right}.inventory-list-delta{font-size:14px;font-weight:500}.inventory-list-delta.positive{color:#16a34a;color:var(--success)}.inventory-list-delta.negative{color:#dc2626}.inventory-panel-empty{color:#9ca3af;color:var(--ink-4);font-size:14px;padding:32px 0;text-align:center}.inventory-panel-loading{display:flex;flex-direction:column;gap:10px;padding:4px 0}.skeleton-line{animation:shimmer 1.4s infinite;background:linear-gradient(90deg,#f6f7f9 25%,#e5e7eb 50%,#f6f7f9 75%);background:linear-gradient(90deg,var(--ground) 25%,var(--rule) 50%,var(--ground) 75%);background-size:200% 100%;border-radius:2px;height:16px}.skeleton-line:nth-child(2){animation-delay:.1s;width:80%}.skeleton-line:nth-child(3){animation-delay:.2s;width:65%}.skeleton-line:nth-child(4){animation-delay:.15s;width:85%}.skeleton-line:nth-child(5){animation-delay:.25s;width:70%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width:900px){.inventory-dashboard-page{padding:24px 20px 48px}.inventory-dashboard-sections{grid-template-columns:1fr}}@media (max-width:600px){.inventory-dashboard-page{padding:16px 16px 40px}.inventory-dashboard-header{align-items:flex-start;flex-direction:column;gap:16px}.inventory-quick-links{width:100%}.inventory-quick-links .btn{flex:1 1}.inventory-dashboard-header h2{font-size:20px}}.inventory-items-page{color:#0f1117;display:flex;flex-direction:column;font-family:DM Sans,system-ui,sans-serif;gap:24px;margin:0 auto;max-width:1400px;padding:36px 40px 60px}.inventory-items-header{align-items:flex-end;border-bottom:2px solid #0f1117;display:flex;justify-content:space-between;padding-bottom:20px}.inventory-items-header .header-actions{align-items:center;display:flex;gap:8px}.inventory-items-header h2{color:#0f1117;font-size:24px;font-weight:300;letter-spacing:-.025em;line-height:1;margin:0}.inventory-stats-grid{grid-gap:1px;background:#e5e7eb;border:1px solid #e5e7eb;display:grid;gap:1px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.inventory-stat-card{background:#fff;padding:24px;position:relative;transition:background .12s}.inventory-stat-card:before{background:#1d4ed8;content:"";height:2px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transform-origin:left;transition:transform .2s ease}.inventory-stat-card:hover:before{transform:scaleX(1)}.inventory-stat-card.warning:before{background:#b45309}.inventory-stat-card.warning:hover{background:#fffbeb}.inventory-stat-card.success:before{background:#16a34a}.inventory-stat-card.success:hover{background:#f0fdf4}.inventory-stat-label{color:#9ca3af;font-size:9px;font-weight:700;letter-spacing:.14em;margin-bottom:10px;text-transform:uppercase}.inventory-stat-card.warning .inventory-stat-label{color:#b45309}.inventory-stat-card.success .inventory-stat-label{color:#16a34a}.inventory-stat-value{color:#0f1117;font-family:DM Mono,ui-monospace,monospace;font-size:32px;font-weight:500;letter-spacing:-.03em;line-height:1}.inventory-stat-card.warning .inventory-stat-value{color:#b45309}.inventory-stat-card.success .inventory-stat-value{color:#16a34a}.item-actions{align-items:center;display:flex;gap:8px}.stock-low{color:#b91c1c;font-weight:700}.stock-badge{align-items:center;border:1px solid;border-radius:2px;display:inline-flex;font-family:DM Mono,ui-monospace,monospace;font-size:13px;font-weight:500;gap:6px;line-height:1;padding:6px 12px}.stock-badge.low{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.stock-badge.medium{background:#fffbeb;border-color:#fde68a;color:#b45309}.stock-badge.good{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.stock-badge-icon{background:currentColor;border-radius:50%;height:6px;width:6px}.item-form{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;padding:8px}.item-form label{color:#374151;display:flex;flex-direction:column;font-size:11px;font-weight:600;gap:8px;letter-spacing:.06em;text-transform:uppercase}.item-form input,.item-form textarea{background:#fff;border:1px solid #d1d5db;border-radius:2px;color:#0f1117;font-family:inherit;font-size:14px;padding:10px 12px;transition:all .12s ease;width:100%}.item-form input::placeholder,.item-form textarea::placeholder{color:#9ca3af}.item-form input:hover,.item-form textarea:hover{border-color:#6b7280}.item-form input:focus,.item-form textarea:focus{border-color:#1d4ed8;box-shadow:0 0 0 3px #1d4ed81a;outline:none}.item-form textarea{min-height:100px;resize:vertical}.item-form .field-full{grid-column:1/-1}.item-form-actions{border-top:1px solid #e5e7eb;display:flex;gap:8px;grid-column:1/-1;justify-content:flex-end;margin-top:8px;padding-top:20px}.category-badge{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:2px;color:#374151;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}@media (max-width:900px){.inventory-items-page{padding:24px 20px 48px}.inventory-stats-grid,.item-form{grid-template-columns:1fr}}@media (max-width:600px){.inventory-items-page{padding:16px 16px 40px}.inventory-items-header{align-items:flex-start;flex-direction:column;gap:16px}.inventory-items-header h2{font-size:20px}.inventory-items-header .header-actions{flex-wrap:wrap;width:100%}}.bulk-action-form{display:flex;flex-direction:column;gap:20px}.bulk-items-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.bulk-item-row,.bulk-items-list{border:1px solid #e5e7eb;border-radius:2px;padding:12px}.bulk-item-row{grid-gap:16px;align-items:center;background:#f9fafb;display:grid;gap:16px;grid-template-columns:1fr auto}.bulk-item-info{display:flex;flex-direction:column;gap:4px;min-width:0}.bulk-item-code{color:#6b7280;font-family:DM Mono,ui-monospace,monospace;font-size:12px;font-weight:500}.bulk-item-name{color:#0f1117;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bulk-item-quantity{border:1px solid #d1d5db;border-radius:2px;font-family:DM Mono,ui-monospace,monospace;font-size:14px;padding:8px 12px;text-align:right;width:100px}.bulk-item-quantity:focus{border-color:#1d4ed8;box-shadow:0 0 0 3px #1d4ed81a;outline:none}.bulk-reason-field{display:flex;flex-direction:column;gap:8px}.bulk-reason-field label{color:#374151;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.bulk-reason-field input{background:#fff;border:1px solid #d1d5db;border-radius:2px;color:#0f1117;font-size:14px;padding:10px 12px;transition:all .12s ease;width:100%}.bulk-reason-field input:focus{border-color:#1d4ed8;box-shadow:0 0 0 3px #1d4ed81a;outline:none}.data-table thead th:first-child .th-content{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table thead th:first-child .th-content:hover{opacity:.7}:root{--ink:#0f1117;--ink-2:#374151;--ink-3:#6b7280;--ink-4:#9ca3af;--rule:#e5e7eb;--rule-heavy:#d1d5db;--surface:#fff;--ground:#f6f7f9;--accent:#1d4ed8;--accent-light:#eff6ff;--accent-text:#1e40af;--warning:#b45309;--warning-light:#fffbeb;--success:#16a34a;--danger:#dc2626;--font-sans:"DM Sans",system-ui,sans-serif;--font-mono:"DM Mono",ui-monospace,monospace}*,:after,:before{box-sizing:border-box;margin:0;padding:0}.inventory-item-detail-page{color:#0f1117;color:var(--ink);display:flex;flex-direction:column;font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-sans);gap:24px;margin:0 auto;max-width:1200px;padding:36px 40px 60px}.inventory-item-detail-header{align-items:flex-end;border-bottom:2px solid #0f1117;border-bottom:2px solid var(--ink);display:flex;gap:16px;justify-content:space-between;padding-bottom:20px}.inventory-item-detail-header-left{align-items:center;display:flex;gap:16px}.inventory-item-eyebrow{color:#9ca3af;color:var(--ink-4);font-size:10px;font-weight:600;letter-spacing:.16em;margin-bottom:5px;text-transform:uppercase}.inventory-item-detail-header h2{color:#0f1117;color:var(--ink);font-size:24px;font-weight:300;letter-spacing:-.025em;line-height:1}.action-buttons{align-items:center;display:flex;gap:8px}.btn{align-items:center;border:1px solid #0000;border-radius:2px;cursor:pointer;display:inline-flex;font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-sans);font-size:11px;font-weight:600;gap:6px;height:36px;justify-content:center;letter-spacing:.06em;line-height:1;padding:0 18px;text-decoration:none;text-transform:uppercase;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.45}.btn-primary{background:#0f1117;background:var(--ink);border-color:#0f1117;border-color:var(--ink);color:#fff}.btn-primary:hover:not(:disabled){background:#1d4ed8;background:var(--accent);border-color:#1d4ed8;border-color:var(--accent)}.btn-secondary{background:#fff;background:var(--surface);border-color:#d1d5db;border-color:var(--rule-heavy);color:#374151;color:var(--ink-2)}.btn-secondary:hover:not(:disabled){border-color:#0f1117;border-color:var(--ink);color:#0f1117;color:var(--ink)}.btn-outline-primary{background:#0000;border-color:#1d4ed8;border-color:var(--accent);color:#1e40af;color:var(--accent-text)}.btn-outline-primary:hover:not(:disabled){background:#eff6ff;background:var(--accent-light)}.inventory-item-card{grid-gap:1px;background:#fff;background:var(--surface);background-color:#e5e7eb;background-color:var(--rule);border:1px solid #e5e7eb;border:1px solid var(--rule);display:grid;gap:1px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.inventory-item-field{background:#fff;background:var(--surface);display:flex;flex-direction:column;gap:5px;padding:18px 20px;position:relative}.inventory-item-field:before{background:#1d4ed8;background:var(--accent);content:"";height:2px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transform-origin:left;transition:transform .2s ease}.inventory-item-field:hover:before{transform:scaleX(1)}.inventory-item-field-label{color:#9ca3af;color:var(--ink-4);font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.inventory-item-field-value{color:#374151;color:var(--ink-2);font-size:15px;font-weight:400;line-height:1.3}.inventory-item-field-value.mono{font-size:14px}.inventory-item-field-value.large,.inventory-item-field-value.mono{font-family:DM Mono,ui-monospace,monospace;font-family:var(--font-mono)}.inventory-item-field-value.large{color:#0f1117;color:var(--ink);font-size:22px;font-weight:500;letter-spacing:-.02em}.inventory-item-field-value.warning{color:#b45309;color:var(--warning)}.stock-min{color:#9ca3af;color:var(--ink-4);font-size:11px;margin-top:2px}.inventory-item-field.full-width{grid-column:1/-1}.inventory-transactions-section{display:flex;flex-direction:column;gap:14px}.inventory-transactions-heading{color:#9ca3af;color:var(--ink-4);font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.delta-positive{color:#16a34a;color:var(--success)}.delta-negative,.delta-positive{font-family:DM Mono,ui-monospace,monospace;font-family:var(--font-mono);font-size:13px;font-weight:500}.delta-negative{color:#dc2626;color:var(--danger)}.stock-action-form{gap:18px;padding-top:4px}.form-field,.stock-action-form{display:flex;flex-direction:column}.form-field{gap:6px}.form-field label{color:#6b7280;color:var(--ink-3);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.form-field input{background:#fff;background:var(--surface);border:1px solid #d1d5db;border:1px solid var(--rule-heavy);border-radius:2px;color:#0f1117;color:var(--ink);font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-sans);font-size:14px;height:38px;padding:0 12px;transition:border-color .12s,box-shadow .12s;width:100%}.form-field input:focus{border-color:#1d4ed8;border-color:var(--accent);box-shadow:0 0 0 2px #1d4ed81a;outline:none}.stock-action-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--rule);display:flex;gap:8px;justify-content:flex-end;margin-top:4px;padding-top:8px}@media (max-width:900px){.inventory-item-detail-page{padding:24px 20px 48px}.inventory-item-card{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.inventory-item-detail-page{padding:16px 16px 40px}.inventory-item-detail-header{align-items:flex-start;flex-direction:column}.action-buttons{width:100%}.action-buttons .btn{flex:1 1}.inventory-item-card{grid-template-columns:1fr}}.inventory-transactions-page{display:flex;flex-direction:column;gap:.9rem}.inventory-transactions-header{align-items:center;display:flex;justify-content:space-between}.delta-positive{color:#166534;font-weight:700}.delta-negative{color:#b91c1c;font-weight:700}.inventory-archives-page{padding:24px}.page-header{margin-bottom:24px}.page-header h1{color:#1e293b;font-size:28px;margin:0 0 8px}.page-header p{color:#64748b;font-size:14px;margin:0}.btn-sm{font-size:13px;padding:6px 12px}.help-page{margin:0 auto;max-width:900px;padding:24px}.help-header{margin-bottom:32px}.help-header h1{color:#1a1a1a;color:var(--ink-1,#1a1a1a);font-size:32px;font-weight:600;margin:0 0 8px}.help-header p{color:#666;color:var(--ink-3,#666);font-size:16px;margin:0}.help-tabs{border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);display:flex;gap:8px;margin-bottom:32px}.help-tab{background:none;border:none;border-bottom:2px solid #0000;color:#666;color:var(--ink-3,#666);cursor:pointer;font-size:15px;font-weight:500;padding:12px 24px;transition:all .2s}.help-tab:hover{color:#1a1a1a;color:var(--ink-1,#1a1a1a)}.help-tab.active{border-bottom-color:#06c;border-bottom-color:var(--primary-color,#06c);color:#06c;color:var(--primary-color,#06c)}.help-content{animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.help-section h2{color:#1a1a1a;color:var(--ink-1,#1a1a1a);font-size:24px;font-weight:600;margin:0 0 24px}.help-card{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:8px;margin-bottom:20px;padding:24px}.help-card h3{color:#1a1a1a;color:var(--ink-1,#1a1a1a);font-size:18px;font-weight:600;margin:0 0 16px}.help-card h4{color:#333;color:var(--ink-2,#333);font-size:16px;font-weight:600;margin:20px 0 12px}.help-card h4:first-of-type{margin-top:0}.help-card p{color:#333;color:var(--ink-2,#333);font-size:15px;line-height:1.6;margin:0 0 12px}.help-card ol,.help-card ul{margin:0;padding-left:24px}.help-card li{color:#333;color:var(--ink-2,#333);font-size:15px;line-height:1.8;margin-bottom:8px}.help-card li:last-child{margin-bottom:0}.help-card strong{color:#1a1a1a;color:var(--ink-1,#1a1a1a);font-weight:600}@media (max-width:768px){.help-page{padding:16px}.help-header h1{font-size:24px}.help-header p,.help-tab{font-size:14px}.help-tab{padding:10px 16px}.help-card{padding:16px}.help-card h3{font-size:16px}.help-card h4{font-size:15px}.help-card li,.help-card p{font-size:14px}}.App{height:100vh;overflow:hidden}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@media (max-width:768px){.App{overflow-y:auto}}.auto-save-indicator{align-items:center;background-color:#e3f2fd;border:1px solid #90caf9;border-radius:4px;color:#1976d2;display:flex;font-size:14px;margin-bottom:16px;padding:8px 12px}.auto-save-indicator.saved{background-color:#e8f5e9;border-color:#81c784;color:#388e3c}.auto-save-indicator .spinner-border{border-width:2px;height:16px;width:16px}@media (max-width:576px){.action-buttons,.form-actions{flex-direction:column;gap:8px}.action-buttons button,.form-actions button{width:100%}}@media (max-width:768px){.data-table{overflow-x:auto}.data-table table{min-width:600px}}@media (max-width:576px){.modal-content{border-radius:0;width:100%}.modal-content,.modal-dialog{margin:0;max-width:100%}}@media (max-width:768px){.btn,button{min-height:44px;padding:12px 16px}.btn-sm{min-height:36px;padding:8px 12px}.form-row{flex-direction:column}.form-group{width:100%}.sidebar{left:-250px;position:fixed;transition:left .3s ease;z-index:1000}.sidebar.open{left:0}.main-content{margin-left:0}}@media (max-width:992px){.dashboard-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:576px){.dashboard-cards{grid-template-columns:1fr}}@media (max-width:768px){.search-bar{flex-direction:column;gap:12px}.search-bar input{width:100%}.filter-group{flex-direction:column;width:100%}}.visually-hidden{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}:focus-visible{outline:2px solid #1976d2;outline-offset:2px}.skip-to-main{background:#1976d2;color:#fff;left:0;padding:8px;position:absolute;text-decoration:none;top:-40px;z-index:100}.skip-to-main:focus{top:0}
/*# sourceMappingURL=main.075d928f.css.map*/