@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--color-primary:#1a56db;--color-primary-dark:#1241a3;--color-primary-light:#e8effd;--color-primary-hover:#1648c2;--color-sidebar-bg:#0f1c2e;--color-sidebar-hover:#1a2d44;--color-sidebar-active:#1a56db;--color-sidebar-text:#94a3b8;--color-sidebar-heading:#64748b;--color-success:#059669;--color-success-light:#d1fae5;--color-warning:#d97706;--color-warning-light:#fef3c7;--color-danger:#dc2626;--color-danger-light:#fee2e2;--color-info:#0891b2;--color-info-light:#cffafe;--color-purple:#7c3aed;--color-purple-light:#ede9fe;--color-orange:#ea580c;--color-orange-light:#ffedd5;--color-bg:#f1f5f9;--color-surface:#fff;--color-border:#e2e8f0;--color-border-strong:#cbd5e1;--color-text:#0f172a;--color-text-secondary:#475569;--color-text-muted:#94a3b8;--color-text-placeholder:#cbd5e1;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #00000012;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #00000014;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #00000014;--sidebar-width:260px;--sidebar-collapsed-w:72px;--header-height:64px;--content-max-width:1400px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.35s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}img,svg{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{color:var(--color-text);font-weight:600;line-height:1.3}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}h4{font-size:var(--font-size-base)}p{line-height:1.6}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar-bg);z-index:100;min-height:100vh;transition:transform .3s ease, width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.main-content{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-base);flex-direction:column;flex:1;display:flex}.app-layout:has(.sidebar-collapsed) .main-content{margin-left:var(--sidebar-collapsed-w)}.page-header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:0 var(--spacing-6);z-index:50;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.page-content{padding:var(--spacing-6);max-width:var(--content-max-width);flex:1;width:100%}.mobile-menu-btn,.mobile-close-btn,.sidebar-backdrop{display:none}.sidebar-logo{padding:var(--spacing-5) var(--spacing-5);align-items:center;gap:var(--spacing-3);border-bottom:1px solid #ffffff0f;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--color-primary) 0%, #3b82f6 100%);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sidebar-logo-text{font-size:var(--font-size-lg);color:#fff;letter-spacing:-.02em;font-weight:700}.sidebar-logo-sub{font-size:var(--font-size-xs);color:var(--color-sidebar-text);font-weight:400}.sidebar-user{padding:var(--spacing-4) var(--spacing-5);align-items:center;gap:var(--spacing-3);border-bottom:1px solid #ffffff0f;display:flex}.sidebar-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-primary) 0%, #60a5fa 100%);width:34px;height:34px;font-size:var(--font-size-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:var(--font-size-sm);color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-user-role{font-size:var(--font-size-xs);color:var(--color-sidebar-text)}.sidebar-nav{padding:var(--spacing-3) 0;flex:1;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.sidebar-section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-sidebar-heading);padding:var(--spacing-4) var(--spacing-5) var(--spacing-2);font-size:10px;font-weight:700}.sidebar-link{align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-5);color:var(--color-sidebar-text);font-size:var(--font-size-sm);transition:all var(--transition-fast);margin:1px var(--spacing-2);border-radius:0;border-radius:var(--radius-md);font-weight:500;display:flex;position:relative}.sidebar-link:hover{background:var(--color-sidebar-hover);color:#e2e8f0}.sidebar-link.active{background:var(--color-sidebar-active);color:#fff}.sidebar-link.active:before{content:"";background:#60a5fa;border-radius:0 2px 2px 0;width:3px;height:20px;position:absolute;top:50%;left:-8px;transform:translateY(-50%)}.sidebar-link-icon{opacity:.8;flex-shrink:0;width:18px;height:18px}.sidebar-link.active .sidebar-link-icon{opacity:1}.sidebar-link-badge{background:var(--color-danger);color:#fff;border-radius:var(--radius-full);justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:auto;padding:0 4px;font-size:10px;font-weight:700;display:flex}.sidebar-bottom{padding:var(--spacing-4) var(--spacing-5);border-top:1px solid #ffffff0f}.sidebar-logout-btn{align-items:center;gap:var(--spacing-3);width:100%;padding:var(--spacing-2) var(--spacing-3);color:var(--color-sidebar-text);font-size:var(--font-size-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);background:0 0;border:none;display:flex}.sidebar-logout-btn:hover{color:#fca5a5;background:#dc262626}.sidebar-logout-btn-collapsed{padding:var(--spacing-2);justify-content:center}.sidebar-collapse-btn{border-radius:var(--radius-md);width:28px;height:28px;color:var(--color-sidebar-text);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0f;border:none;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;display:flex}.sidebar-collapse-btn:hover{color:#e2e8f0;background:#ffffff1f}.sidebar-section-divider{height:1px;margin:var(--spacing-2) var(--spacing-3);background:#ffffff0f}.sidebar-collapsed{width:var(--sidebar-collapsed-w)!important}.sidebar-collapsed .sidebar-link{padding:var(--spacing-2);margin:1px var(--spacing-1);justify-content:center}.sidebar-collapsed .sidebar-link-icon{margin:0}.sidebar-link-text{white-space:nowrap;flex:1;align-items:center;gap:0;min-width:0;display:flex;overflow:hidden}.sidebar-link-text .sidebar-link-badge{margin-left:auto}.sidebar-link-badge-dot{background:var(--color-danger);border:1.5px solid var(--color-sidebar-bg);border-radius:50%;width:7px;height:7px;position:absolute;top:6px;right:6px}.sidebar-collapsed .sidebar-logo{padding:var(--spacing-4) 0;justify-content:center}.sidebar-collapsed .sidebar-user{padding:var(--spacing-3) 0;justify-content:center}.sidebar-collapsed .sidebar-nav{padding:var(--spacing-2) 0}.sidebar-collapsed .sidebar-link.active:before{left:-4px}.header-breadcrumb{align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex}.header-breadcrumb-current{color:var(--color-text);font-weight:600}.header-actions{align-items:center;gap:var(--spacing-3);display:flex}.header-notif-btn{border-radius:var(--radius-full);background:var(--color-bg);border:1px solid var(--color-border);width:38px;height:38px;color:var(--color-text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:relative}.header-notif-btn:hover{background:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary-light)}.header-notif-dot{background:var(--color-danger);border-radius:var(--radius-full);border:2px solid #fff;width:8px;height:8px;position:absolute;top:6px;right:6px}.btn{justify-content:center;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;border:1px solid #0000;padding:.5rem 1rem;font-weight:500;line-height:1;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{font-size:var(--font-size-xs);padding:.375rem .75rem}.btn-lg{font-size:var(--font-size-base);padding:.75rem 1.5rem}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #1a56db4d}.btn-secondary{color:var(--color-text);border-color:var(--color-border);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-border-strong)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.btn-success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn-success:hover:not(:disabled){background:#047857;transform:translateY(-1px)}.btn-warning{background:var(--color-warning);color:#fff;border-color:var(--color-warning)}.btn-ghost{color:var(--color-text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--color-bg);color:var(--color-text)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:var(--spacing-5) var(--spacing-6);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:var(--spacing-4);display:flex}.card-title{font-size:var(--font-size-base);color:var(--color-text);font-weight:600}.card-body{padding:var(--spacing-6)}.card-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-border);justify-content:flex-end;align-items:center;gap:var(--spacing-3);display:flex}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-5);align-items:flex-start;gap:var(--spacing-4);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-card-icon.blue{background:var(--color-primary-light);color:var(--color-primary)}.stat-card-icon.green{background:var(--color-success-light);color:var(--color-success)}.stat-card-icon.warning{background:var(--color-warning-light);color:var(--color-warning)}.stat-card-icon.danger{background:var(--color-danger-light);color:var(--color-danger)}.stat-card-icon.purple{background:var(--color-purple-light);color:var(--color-purple)}.stat-card-icon.orange{background:var(--color-orange-light);color:var(--color-orange)}.stat-card-icon.info{background:var(--color-info-light);color:var(--color-info)}.stat-card-content{flex:1;min-width:0}.stat-card-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--spacing-1);overflow-wrap:break-word;word-break:break-word;font-weight:500}.stat-card-value{font-size:var(--font-size-2xl);color:var(--color-text);overflow-wrap:break-word;word-break:break-word;font-weight:700;line-height:1.2}.stat-card-sub{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.badge{font-size:var(--font-size-xs);border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:4px;padding:.25rem .625rem;font-weight:600;display:inline-flex}.badge-secondary{color:#64748b;background:#f1f5f9}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger)}.badge-info{background:var(--color-info-light);color:var(--color-info)}.badge-blue{background:var(--color-primary-light);color:var(--color-primary)}.badge-purple{background:var(--color-purple-light);color:var(--color-purple)}.badge-orange{background:var(--color-orange-light);color:var(--color-orange)}.badge-green{background:var(--color-success-light);color:var(--color-success)}.table-container{border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.data-table thead th{color:var(--color-text-secondary);font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.04em;padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:1px solid var(--color-border);white-space:nowrap;background:#f8fafc}.data-table tbody td{padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#f8fafc}.data-table tbody tr.clickable{cursor:pointer}.data-table tbody tr.clickable:hover{background:var(--color-primary-light)}.form-group{gap:var(--spacing-1);flex-direction:column;display:flex}.form-label{font-size:var(--font-size-sm);color:var(--color-text);font-weight:500}.form-label.required:after{content:" *";color:var(--color-danger)}.form-control{width:100%;font-size:var(--font-size-sm);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);appearance:none;background:#fff;outline:none;padding:.5625rem .75rem;font-family:inherit}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1a56db1f}.form-control:disabled{color:var(--color-text-muted);cursor:not-allowed;background:#f8fafc}.form-control.error{border-color:var(--color-danger);box-shadow:0 0 0 3px #dc26261a}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-muted)}.form-error{font-size:var(--font-size-xs);color:var(--color-danger)}textarea.form-control{resize:vertical;min-height:100px}.form-grid{gap:var(--spacing-4);display:grid}.form-grid-2{grid-template-columns:1fr 1fr}.form-grid-3{grid-template-columns:1fr 1fr 1fr}.modal-overlay{z-index:200;padding:var(--spacing-4);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn var(--transition-fast) ease;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:560px;max-height:90vh;animation:slideUp var(--transition-base) ease;background:#fff;overflow-y:auto}.modal-lg{max-width:760px}.modal-xl{max-width:960px}.modal-header{padding:var(--spacing-5) var(--spacing-6);border-bottom:1px solid var(--color-border);z-index:1;background:#fff;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.modal-title{font-size:var(--font-size-lg);font-weight:600}.modal-close{border-radius:var(--radius-full);background:var(--color-bg);width:32px;height:32px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--color-danger-light);color:var(--color-danger)}.modal-body{padding:var(--spacing-6)}.modal-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-border);justify-content:flex-end;gap:var(--spacing-3);background:#fff;display:flex;position:sticky;bottom:0}.page-title-bar{justify-content:space-between;align-items:center;gap:var(--spacing-4);margin-bottom:var(--spacing-6);display:flex}.page-title{font-size:var(--font-size-2xl);color:var(--color-text);letter-spacing:-.02em;font-weight:700}.page-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:2px}.filters-bar{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-4);align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-5);background:#fff;flex-wrap:wrap;display:flex}.search-input-wrap{flex:1;min-width:200px;position:relative}.search-input-wrap svg{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-input-wrap .form-control{padding-left:34px}.timeline{padding-left:var(--spacing-8);position:relative}.timeline:before{content:"";background:var(--color-border);width:2px;position:absolute;top:8px;bottom:8px;left:14px}.timeline-item{margin-bottom:var(--spacing-5);position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-dot{left:calc(-1 * var(--spacing-8) + 5px);border-radius:var(--radius-full);border:2px solid var(--color-border);z-index:1;background:#fff;justify-content:center;align-items:center;width:20px;height:20px;display:flex;position:absolute;top:4px}.timeline-dot.approved{border-color:var(--color-success);background:var(--color-success-light)}.timeline-dot.rejected{border-color:var(--color-danger);background:var(--color-danger-light)}.timeline-dot.pending{border-color:var(--color-warning);background:var(--color-warning-light)}.timeline-dot.waiting{border-color:var(--color-border);background:#f8fafc}.timeline-content{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-3) var(--spacing-4);background:#f8fafc}.timeline-header{justify-content:space-between;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-1);display:flex}.timeline-step-name{font-weight:600;font-size:var(--font-size-sm)}.timeline-meta{font-size:var(--font-size-xs);color:var(--color-text-muted)}.timeline-notes{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-2);font-style:italic}.empty-state{padding:var(--spacing-16) var(--spacing-8);text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state svg{width:64px;height:64px;margin-bottom:var(--spacing-4);opacity:.4}.empty-state-title{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--spacing-2);font-weight:600}.empty-state-desc{font-size:var(--font-size-sm);max-width:360px}.spinner{border:2px solid #ffffff4d;border-top-color:currentColor;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.spinner-dark{border-color:#0000001a;border-top-color:var(--color-primary)}.tabs{border-bottom:2px solid var(--color-border);margin-bottom:var(--spacing-6);gap:2px;display:flex}.tab-btn{padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;font-weight:500}.tab-btn:hover{color:var(--color-primary)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.pagination{padding:var(--spacing-4) var(--spacing-5);border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.pagination-info{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pagination-btns{gap:var(--spacing-2);display:flex}.pagination-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);width:32px;height:32px;color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);background:#fff;justify-content:center;align-items:center;display:flex}.pagination-btn:hover:not(:disabled){background:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary-light)}.pagination-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.stock-bar-wrap{align-items:center;gap:var(--spacing-3);display:flex}.stock-bar{background:var(--color-border);border-radius:3px;flex:1;height:6px;overflow:hidden}.stock-bar-fill{height:100%;transition:width var(--transition-slow);border-radius:3px}.stock-bar-fill.critical{background:var(--color-danger)}.stock-bar-fill.warning{background:var(--color-warning)}.stock-bar-fill.normal{background:var(--color-success)}.alert{padding:var(--spacing-4);border-radius:var(--radius-md);gap:var(--spacing-3);font-size:var(--font-size-sm);border:1px solid #0000;display:flex}.alert-info{background:var(--color-info-light);border-color:var(--color-info);color:#0c4a6e}.alert-success{background:var(--color-success-light);border-color:var(--color-success);color:#064e3b}.alert-warning{background:var(--color-warning-light);border-color:var(--color-warning);color:#78350f}.alert-danger{background:var(--color-danger-light);border-color:var(--color-danger);color:#7f1d1d}.divider{background:var(--color-border);height:1px;margin:var(--spacing-6) 0}.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.text-primary{color:var(--color-primary)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--spacing-2)}.gap-3{gap:var(--spacing-3)}.gap-4{gap:var(--spacing-4)}.mt-1{margin-top:var(--spacing-1)}.mt-2{margin-top:var(--spacing-2)}.mt-4{margin-top:var(--spacing-4)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.w-full{width:100%}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:2s infinite pulse}@media (max-width:768px){.mobile-menu-btn{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:40;width:44px;height:44px;box-shadow:var(--shadow-sm);color:var(--color-text);justify-content:center;align-items:center;display:flex;position:fixed;top:1rem;right:1rem}.sidebar-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:90;background:#0f172a99;display:block;position:fixed;inset:0}.mobile-close-btn{color:#fff;border-radius:var(--radius-full);z-index:101;background:#ffffff1a;border:none;justify-content:center;align-items:center;width:36px;height:36px;display:flex;position:absolute;top:16px;right:16px}.sidebar{width:280px;transform:translate(-100%);box-shadow:4px 0 24px #00000080}.sidebar.open{transform:translate(0)}.main-content{width:100%;margin-left:0}.page-content{padding:var(--spacing-4);padding-top:calc(44px + 2rem)}.form-grid-2,.form-grid-3{grid-template-columns:1fr}.page-title-bar{flex-direction:column;align-items:flex-start}.header-actions{margin-top:var(--spacing-2)}}.login-page{min-height:100vh;padding:var(--spacing-6);background:linear-gradient(135deg,#0f1c2e 0%,#1a2d44 50%,#0f1c2e 100%);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle at 20%,#1a56db26 0%,#0000 60%),radial-gradient(circle at 80% 20%,#60a5fa1a 0%,#0000 50%);position:absolute;inset:0}.login-card{border-radius:var(--radius-xl);width:100%;max-width:440px;padding:var(--spacing-10);z-index:1;background:#fffffffa;position:relative;box-shadow:0 25px 50px #0006}.login-logo{align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-8);display:flex}.login-logo-icon{background:linear-gradient(135deg, var(--color-primary) 0%, #60a5fa 100%);border-radius:var(--radius-lg);justify-content:center;align-items:center;width:48px;height:48px;display:flex}.login-logo-text{font-size:var(--font-size-2xl);color:var(--color-text);letter-spacing:-.03em;font-weight:800}.login-logo-sub{font-size:var(--font-size-xs);color:var(--color-text-muted)}.login-title{font-size:var(--font-size-2xl);color:var(--color-text);margin-bottom:var(--spacing-2);font-weight:700}.login-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-8)}.login-form{gap:var(--spacing-4);flex-direction:column;display:flex}.login-error{background:var(--color-danger-light);border:1px solid var(--color-danger);color:#7f1d1d;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.login-footer{margin-top:var(--spacing-6);text-align:center;font-size:var(--font-size-xs);color:var(--color-text-muted)}.mobile-menu-btn{display:none}@media (max-width:768px){.main-content{margin-left:0!important}.page-content{padding:var(--spacing-4)!important}.page-title-bar{align-items:flex-start;gap:var(--spacing-4);height:auto;padding-top:var(--spacing-4);padding-bottom:var(--spacing-4);flex-direction:column}.card-header{flex-direction:column;align-items:flex-start}.table-container{-webkit-overflow-scrolling:touch;width:100%;padding-bottom:2px;overflow-x:auto}div[style*="display: grid"],div[style*=display\:grid]{grid-template-columns:1fr!important}.modal-body{max-height:80vh!important}.sidebar{box-shadow:var(--shadow-xl);z-index:1000;transform:translate(-100%);width:280px!important}.sidebar.open{transform:translate(0)}.sidebar-backdrop{z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:block;position:fixed;inset:0}.mobile-menu-btn{bottom:var(--spacing-6);right:var(--spacing-6);border-radius:var(--radius-full);background:var(--color-primary);color:#fff;width:56px;height:56px;box-shadow:var(--shadow-xl);z-index:900;cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;display:flex;position:fixed}.mobile-menu-btn:hover{background:var(--color-primary-dark);transform:scale(1.05)}.mobile-close-btn{top:var(--spacing-4);right:var(--spacing-4);color:#fff;padding:var(--spacing-2);cursor:pointer;z-index:10;background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:absolute}.sidebar-collapse-btn{display:none!important}}
