@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--bg-sidebar:#0f172a;--bg-sidebar-hover:#1e293b;--bg-sidebar-active:#1e40af;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--text-inverse:#fff;--text-sidebar:#cbd5e1;--text-sidebar-active:#fff;--accent-blue:#3b82f6;--accent-blue-hover:#2563eb;--accent-blue-light:#eff6ff;--accent-blue-border:#bfdbfe;--accent-green:#10b981;--accent-green-light:#ecfdf5;--accent-green-border:#a7f3d0;--accent-amber:#f59e0b;--accent-amber-light:#fffbeb;--accent-amber-border:#fde68a;--accent-red:#ef4444;--accent-red-light:#fef2f2;--accent-red-border:#fecaca;--accent-purple:#8b5cf6;--accent-purple-light:#f5f3ff;--accent-indigo:#6366f1;--accent-indigo-light:#eef2ff;--border-color:#e2e8f0;--border-color-dark:#cbd5e1;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000000d;--transition-fast:.15s ease;--transition-normal:.2s ease;--transition-slow:.3s ease;--sidebar-width:260px}[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-sidebar:#020617;--bg-sidebar-hover:#1e293b;--bg-sidebar-active:#1e40af;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-tertiary:#64748b;--text-inverse:#0f172a;--text-sidebar:#cbd5e1;--text-sidebar-active:#fff;--accent-blue-light:#3b82f626;--accent-blue-border:#3b82f64d;--accent-green-light:#10b98126;--accent-green-border:#10b9814d;--accent-amber-light:#f59e0b26;--accent-amber-border:#f59e0b4d;--accent-red-light:#ef444426;--accent-red-border:#ef44444d;--accent-purple-light:#8b5cf626;--accent-indigo-light:#6366f126;--border-color:#334155;--border-color-dark:#475569;--shadow-sm:0 1px 2px 0 #0000004d;--shadow-md:0 4px 6px -1px #0000004d;--shadow-lg:0 10px 15px -3px #0000004d;--shadow-xl:0 20px 25px -5px #0006}[data-theme=dark] .badge-green{color:#34d399}[data-theme=dark] .badge-amber{color:#fbbf24}[data-theme=dark] .badge-red{color:#f87171}[data-theme=dark] .master-list-search input:focus{background:var(--bg-tertiary)}[data-theme=dark] .recharts-cartesian-grid-bg{fill:#0000}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}a{color:var(--accent-blue);text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.app-layout{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);padding:var(--space-8);max-width:calc(100vw - var(--sidebar-width));flex:1;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);z-index:100;height:100vh;transition:width var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-brand{padding:var(--space-6);align-items:center;gap:var(--space-3);border-bottom:1px solid #ffffff14;display:flex}.sidebar-brand-icon{background:linear-gradient(135deg, var(--accent-blue), var(--accent-indigo));border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;font-weight:700;display:flex}.sidebar-brand-text{color:var(--text-inverse);letter-spacing:-.02em;font-size:16px;font-weight:700}.sidebar-brand-sub{color:var(--text-tertiary);margin-top:1px;font-size:11px;font-weight:400}.sidebar-nav{padding:var(--space-4) var(--space-3);flex:1}.sidebar-section-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-2) var(--space-3);margin-top:var(--space-4);font-size:11px;font-weight:600}.sidebar-section-label:first-child{margin-top:0}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);color:var(--text-sidebar);border-radius:var(--radius-md);transition:all var(--transition-fast);margin-bottom:2px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{background:var(--bg-sidebar-hover);color:var(--text-inverse)}.sidebar-link.active{background:var(--bg-sidebar-active);color:var(--text-sidebar-active);box-shadow:0 1px 3px #1e40af4d}.sidebar-link svg{opacity:.7;flex-shrink:0;width:18px;height:18px}.sidebar-link.active svg{opacity:1}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.page-header-left{gap:var(--space-1);flex-direction:column;display:flex}.page-title{color:var(--text-primary);letter-spacing:-.02em;font-size:24px;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:13px}.page-header-actions{gap:var(--space-3);align-items:center;display:flex}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md)}.card-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.card-title{color:var(--text-primary);font-size:15px;font-weight:600}.card-body{padding:var(--space-6)}.stat-cards{gap:var(--space-5);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);align-items:flex-start;gap:var(--space-4);transition:all var(--transition-normal);cursor:default;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-card-icon.blue{background:var(--accent-blue-light);color:var(--accent-blue)}.stat-card-icon.green{background:var(--accent-green-light);color:var(--accent-green)}.stat-card-icon.amber{background:var(--accent-amber-light);color:var(--accent-amber)}.stat-card-icon.red{background:var(--accent-red-light);color:var(--accent-red)}.stat-card-icon.purple{background:var(--accent-purple-light);color:var(--accent-purple)}.stat-card-icon.indigo{background:var(--accent-indigo-light);color:var(--accent-indigo)}.stat-card-info{flex:1;min-width:0}.stat-card-label{color:var(--text-secondary);margin-bottom:var(--space-1);font-size:12px;font-weight:500}.stat-card-value{color:var(--text-primary);letter-spacing:-.02em;font-size:22px;font-weight:700}.stat-card-trend{color:var(--text-tertiary);margin-top:var(--space-1);font-size:12px}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);transition:all var(--transition-fast);white-space:nowrap;height:36px;font-size:13px;font-weight:500;display:inline-flex}.btn svg{width:16px;height:16px}.btn-primary{background:var(--accent-blue);color:#fff;box-shadow:0 1px 2px #3b82f64d}.btn-primary:hover{background:var(--accent-blue-hover);transform:translateY(-1px);box-shadow:0 2px 4px #3b82f666}.btn-success{background:var(--accent-green);color:#fff;box-shadow:0 1px 2px #10b9814d}.btn-success:hover{background:#059669;transform:translateY(-1px)}.btn-danger{background:var(--accent-red);color:#fff;box-shadow:0 1px 2px #ef44444d}.btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.btn-outline{color:var(--text-secondary);border:1px solid var(--border-color);background:0 0}.btn-outline:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color-dark)}.btn-ghost{color:var(--text-secondary);padding:var(--space-2);background:0 0}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-sm{height:30px;padding:var(--space-1) var(--space-3);font-size:12px}.btn-lg{height:42px;padding:var(--space-3) var(--space-6);font-size:14px}.form-group{margin-bottom:var(--space-4)}.form-label{color:var(--text-secondary);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);background:var(--bg-secondary);transition:all var(--transition-fast);height:36px;font-size:13px}.form-textarea{resize:vertical;height:auto;min-height:80px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-blue);outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:var(--text-tertiary)}.form-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.form-row-3{gap:var(--space-4);grid-template-columns:1fr 1fr 1fr;display:grid}.badge{align-items:center;gap:var(--space-1);border-radius:var(--radius-full);letter-spacing:.02em;white-space:nowrap;padding:2px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-blue{background:var(--accent-blue-light);color:var(--accent-blue);border:1px solid var(--accent-blue-border)}.badge-green{background:var(--accent-green-light);color:#047857;border:1px solid var(--accent-green-border)}.badge-amber{background:var(--accent-amber-light);color:#b45309;border:1px solid var(--accent-amber-border)}.badge-red{background:var(--accent-red-light);color:#b91c1c;border:1px solid var(--accent-red-border)}.badge-purple{background:var(--accent-purple-light);color:var(--accent-purple);border:1px solid #c4b5fd}.badge-gray{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.data-table-wrapper{overflow-x:auto}.data-table{border-collapse:separate;border-spacing:0;width:100%}.data-table th{background:var(--bg-tertiary);padding:var(--space-3) var(--space-4);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;text-align:left;border-bottom:1px solid var(--border-color);font-size:11.5px;font-weight:600;position:sticky;top:0}.data-table th:first-child{border-top-left-radius:var(--radius-md)}.data-table th:last-child{border-top-right-radius:var(--radius-md)}.data-table td{padding:var(--space-3) var(--space-4);color:var(--text-primary);border-bottom:1px solid var(--border-color);vertical-align:middle;font-size:13px}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-tertiary)}.data-table tbody tr.selected{background:var(--accent-blue-light)}.data-table tbody tr:last-child td{border-bottom:none}.master-detail{gap:var(--space-5);grid-template-columns:380px 1fr;min-height:calc(100vh - 140px);display:grid}.master-list{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.master-list-header{padding:var(--space-4);border-bottom:1px solid var(--border-color);gap:var(--space-3);flex-direction:column;display:flex}.master-list-search{position:relative}.master-list-search input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) 36px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-tertiary);height:36px;transition:all var(--transition-fast);font-size:13px}.master-list-search input:focus{border-color:var(--accent-blue);background:#fff;outline:none;box-shadow:0 0 0 3px #3b82f61a}.master-list-search svg{width:16px;height:16px;color:var(--text-tertiary);position:absolute;top:50%;left:10px;transform:translateY(-50%)}.master-list-items{flex:1;overflow-y:auto}.master-list-item{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast)}.master-list-item:hover{background:var(--bg-tertiary)}.master-list-item.active{background:var(--accent-blue-light);border-left:3px solid var(--accent-blue)}.master-list-item-title{color:var(--text-primary);margin-bottom:2px;font-size:13.5px;font-weight:600}.master-list-item-subtitle{color:var(--text-secondary);font-size:12px}.master-list-item-meta{margin-top:var(--space-2);justify-content:space-between;align-items:center;display:flex}.detail-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.detail-panel-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.detail-panel-title{color:var(--text-primary);font-size:18px;font-weight:700}.detail-panel-body{padding:var(--space-6);max-height:calc(100vh - 240px);overflow-y:auto}.detail-panel-actions{gap:var(--space-2);display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0f172a80;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);flex-direction:column;width:90%;max-width:600px;max-height:85vh;animation:.25s slideUp;display:flex;overflow:hidden}.modal-lg{max-width:800px}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.modal-title{color:var(--text-primary);font-size:17px;font-weight:700}.modal-close{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-tertiary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:var(--space-6);flex:1;overflow-y:auto}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);justify-content:flex-end;gap:var(--space-3);display:flex}.items-table{border-collapse:collapse;width:100%;margin-top:var(--space-3)}.items-table th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;padding:var(--space-2) var(--space-2);text-align:left;background:var(--bg-tertiary);font-size:11px;font-weight:600}.items-table td{padding:var(--space-2)}.items-table .form-input,.items-table .form-select{height:32px;font-size:12px}.items-table .btn-ghost{width:28px;height:28px;padding:0}.items-total{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;color:var(--text-primary);font-size:15px;font-weight:700;display:flex}.detail-section{margin-bottom:var(--space-6)}.detail-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-color);font-size:12px;font-weight:600}.detail-grid{gap:var(--space-3) var(--space-6);grid-template-columns:1fr 1fr;display:grid}.detail-field{flex-direction:column;gap:2px;display:flex}.detail-field-label{color:var(--text-tertiary);font-size:11.5px;font-weight:500}.detail-field-value{color:var(--text-primary);font-size:14px;font-weight:500}.pipeline{margin-bottom:var(--space-6);align-items:center;gap:0;display:flex}.pipeline-stage{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-tertiary);color:var(--text-tertiary);border:1px solid var(--border-color);font-size:12px;font-weight:600;display:flex;position:relative}.pipeline-stage:first-child{border-radius:var(--radius-full) 0 0 var(--radius-full)}.pipeline-stage:last-child{border-radius:0 var(--radius-full) var(--radius-full) 0}.pipeline-stage.active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue);z-index:1}.pipeline-stage.completed{background:var(--accent-green-light);color:#047857;border-color:var(--accent-green-border)}.tabs{border-bottom:2px solid var(--border-color);margin-bottom:var(--space-5);gap:0;display:flex}.tab{padding:var(--space-3) var(--space-5);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;border-bottom:2px solid #0000;margin-bottom:-2px;font-size:13px;font-weight:500}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue);font-weight:600}.empty-state{padding:var(--space-12) var(--space-6);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state svg{width:48px;height:48px;color:var(--text-tertiary);margin-bottom:var(--space-4);opacity:.5}.empty-state-title{color:var(--text-primary);margin-bottom:var(--space-2);font-size:15px;font-weight:600}.empty-state-text{color:var(--text-secondary);max-width:300px;font-size:13px}.currency{font-variant-numeric:tabular-nums}.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:var(--text-secondary)}.text-small{font-size:12px}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.quick-access{gap:var(--space-3);margin-bottom:var(--space-6);padding-bottom:var(--space-1);display:flex;overflow-x:auto}.quick-access-btn{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);white-space:nowrap;transition:all var(--transition-fast);cursor:pointer;font-size:13px;font-weight:600;text-decoration:none;display:flex}.quick-access-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.quick-access-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.quick-access-btn.blue .quick-access-icon{background:var(--accent-blue-light);color:var(--accent-blue)}.quick-access-btn.blue:hover{border-color:var(--accent-blue);background:var(--accent-blue-light)}.quick-access-btn.purple .quick-access-icon{background:var(--accent-purple-light);color:var(--accent-purple)}.quick-access-btn.purple:hover{border-color:var(--accent-purple);background:var(--accent-purple-light)}.quick-access-btn.green .quick-access-icon{background:var(--accent-green-light);color:var(--accent-green)}.quick-access-btn.green:hover{border-color:var(--accent-green);background:var(--accent-green-light)}.quick-access-btn.amber .quick-access-icon{background:var(--accent-amber-light);color:var(--accent-amber)}.quick-access-btn.amber:hover{border-color:var(--accent-amber);background:var(--accent-amber-light)}.quick-access-btn.indigo .quick-access-icon{background:var(--accent-indigo-light);color:var(--accent-indigo)}.quick-access-btn.indigo:hover{border-color:var(--accent-indigo);background:var(--accent-indigo-light)}.dashboard-grid{gap:var(--space-5);margin-bottom:var(--space-5);grid-template-columns:1fr 1fr;display:grid}.dashboard-grid-3{gap:var(--space-5);margin-bottom:var(--space-5);grid-template-columns:1fr 1fr 1fr;display:grid}.chart-legend{padding:var(--space-3) var(--space-5) var(--space-4);gap:var(--space-3) var(--space-5);border-top:1px solid var(--border-color);flex-wrap:wrap;display:flex}.chart-legend-item{align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:12px;display:flex}.chart-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.chart-legend-count{color:var(--text-primary);font-weight:700}.compact-list{padding:0!important}.compact-list-item{padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--border-color);transition:background var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.compact-list-item:last-child{border-bottom:none}.compact-list-item:hover{background:var(--bg-tertiary)}.compact-list-left{min-width:0}.compact-list-title{color:var(--text-primary);font-size:13px;font-weight:600}.compact-list-sub{color:var(--text-tertiary);margin-top:1px;font-size:11.5px}.compact-list-right{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.compact-list-amount{color:var(--text-primary);font-size:13px;font-weight:600}.skeleton{background:linear-gradient(90deg, var(--bg-tertiary) 25%, #e8edf3 50%, var(--bg-tertiary) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color-dark);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}@media (max-width:1024px){.master-detail{grid-template-columns:320px 1fr}}@media (max-width:768px){.sidebar{transform:translate(-100%)}.main-content{max-width:100%;padding:var(--space-4);margin-left:0}.master-detail{grid-template-columns:1fr}.stat-cards{grid-template-columns:repeat(2,1fr)}.form-row,.form-row-3{grid-template-columns:1fr}}.sidebar-footer{padding:var(--space-3);border-top:1px solid #ffffff14;margin-top:auto}.sidebar-logout{opacity:.7;justify-content:flex-start;width:100%;color:var(--text-sidebar)!important}.sidebar-logout:hover{opacity:1;color:#fca5a5!important;background:#ef444426!important}.sidebar-footer-row{justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.theme-toggle{align-items:center;gap:var(--space-2);cursor:pointer;border-radius:var(--radius-sm);color:var(--text-sidebar);opacity:.7;transition:all var(--transition-fast);background:0 0;border:none;padding:6px 10px;font-size:12px;display:flex}.theme-toggle:hover{opacity:1;background:#ffffff14}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast)}.sortable-header:hover{color:var(--accent-blue)}.sort-icon{opacity:.4;vertical-align:middle;margin-left:4px;display:inline-flex}.sort-icon.active{opacity:1;color:var(--accent-blue)}.print-btn{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:0 0}.print-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}@media print{.sidebar,.page-header,.master-list,.detail-panel-actions,.pipeline{display:none!important}.main-content{max-width:100%!important;margin-left:0!important;padding:0!important}.master-detail{display:block!important}.detail-panel{box-shadow:none!important;border:none!important}.app-layout{display:block!important}}.low-stock-bar{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--accent-amber-light);border:1px solid var(--accent-amber-border);border-radius:var(--radius-sm);color:var(--accent-amber);margin-bottom:var(--space-4);font-size:12px;font-weight:500;display:flex}[data-theme=dark] .low-stock-bar{color:#fbbf24}.kbd{color:var(--text-sidebar);opacity:.5;background:#ffffff1a;border:1px solid #ffffff26;border-radius:3px;justify-content:center;align-items:center;margin-left:auto;padding:1px 5px;font-family:monospace;font-size:10px;display:inline-flex}.login-page{background:#050d1a;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg{z-index:0;position:absolute;inset:0}.login-bg-shape{filter:blur(120px);opacity:.25;border-radius:50%;position:absolute}.shape-1{background:radial-gradient(circle,#3b82f6 0%,#0000 70%);width:700px;height:700px;animation:10s ease-in-out infinite float1;top:-300px;right:-200px}.shape-2{background:radial-gradient(circle,#8b5cf6 0%,#0000 70%);width:500px;height:500px;animation:12s ease-in-out infinite float2;bottom:-200px;left:-150px}.shape-3{background:radial-gradient(circle,#06b6d4 0%,#0000 70%);width:400px;height:400px;animation:14s ease-in-out infinite float3;top:60%;left:40%}@keyframes float1{0%,to{transform:translate(0)scale(1)}50%{transform:translate(-60px,40px)scale(1.1)}}@keyframes float2{0%,to{transform:translate(0)scale(1)}50%{transform:translate(40px,-50px)scale(1.05)}}@keyframes float3{0%,to{transform:translate(-50%,-50%)scale(1)}50%{transform:translate(-45%,-55%)scale(1.15)}}.login-scene{z-index:0;pointer-events:none;position:absolute;inset:0}.float-box{opacity:.15;font-size:28px;animation:8s ease-in-out infinite floatItem;position:absolute}.box-1{font-size:36px;animation-duration:9s;animation-delay:0s;top:10%;left:8%}.box-2{font-size:32px;animation-duration:11s;animation-delay:1.5s;top:25%;right:12%}.box-3{animation-duration:10s;animation-delay:3s;bottom:30%;left:5%}.box-4{font-size:24px;animation-duration:12s;animation-delay:2s;top:60%;right:8%}.box-5{font-size:30px;animation-duration:8s;animation-delay:4s;bottom:15%;left:25%}.box-6{font-size:26px;animation-duration:13s;animation-delay:5s;top:15%;left:45%}@keyframes floatItem{0%,to{opacity:.12;transform:translateY(0)rotate(0)}25%{opacity:.2;transform:translateY(-20px)rotate(5deg)}50%{opacity:.15;transform:translateY(-35px)rotate(-3deg)}75%{opacity:.2;transform:translateY(-15px)rotate(2deg)}}.login-container{z-index:1;-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);background:#ffffff05;border:1px solid #ffffff0f;border-radius:24px;grid-template-columns:1.1fr .9fr;width:920px;max-width:95vw;min-height:540px;animation:.6s cubic-bezier(.16,1,.3,1) slideUp;display:grid;position:relative;overflow:hidden;box-shadow:0 0 0 1px #ffffff0a,0 25px 60px -12px #000000b3,0 0 80px #3b82f60f}.login-brand-side{background:linear-gradient(160deg,#0c1929 0%,#122244 40%,#1a3566 70%,#1e40af 100%);flex-direction:column;justify-content:center;padding:48px 40px;display:flex;position:relative;overflow:hidden}.login-brand-side:before{content:"";background:radial-gradient(at 20% 80%,#3b82f633 0%,#0000 50%),radial-gradient(at 80% 20%,#8b5cf626 0%,#0000 50%);position:absolute;inset:0}.login-brand-side:after{content:"";background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 0v40M0 20h40' stroke='rgba(255,255,255,0.03)' stroke-width='1'/%3E%3C/svg%3E");position:absolute;inset:0}.login-brand-content{z-index:1;position:relative}.login-brand-logo{background:linear-gradient(135deg,#3b82f6,#8b5cf6,#3b82f6) 0 0/200% 200%;border-radius:18px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:28px;animation:4s ease-in-out infinite gradientShift;display:flex;box-shadow:0 8px 32px #3b82f64d}@keyframes gradientShift{0%,to{background-position:0%}50%{background-position:100%}}.login-logo-text{color:#fff;letter-spacing:-.04em;font-size:26px;font-weight:800}.login-brand-title{color:#fff;letter-spacing:-.04em;background:linear-gradient(135deg,#fff 0%,#93c5fd 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:32px;font-weight:800}.login-brand-tagline{color:#fff9;margin-bottom:32px;font-size:14px;line-height:1.8}.login-stats-ticker{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff14;border-radius:14px;align-items:center;gap:16px;margin-bottom:24px;padding:14px 20px;display:flex}.login-stat-item{flex-direction:column;flex:1;align-items:center;display:flex}.login-stat-num{color:#60a5fa;letter-spacing:-.02em;font-size:20px;font-weight:700}.login-stat-label{color:#fff6;text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-size:11px}.login-stat-divider{background:#ffffff1a;width:1px;height:32px}.login-clock{background:#ffffff08;border:1px solid #ffffff0d;border-radius:10px;padding:12px 16px}.login-clock-time{color:#ffffffd9;font-variant-numeric:tabular-nums;letter-spacing:.02em;font-size:22px;font-weight:600}.login-clock-date{color:#ffffff59;margin-top:2px;font-size:12px}.login-form-side{background:#fff;justify-content:center;align-items:center;padding:48px 40px;display:flex}[data-theme=dark] .login-form-side{background:#1e293b}.login-form{width:100%;max-width:340px}.login-form-header{margin-bottom:32px}.login-form-title{color:#0f172a;letter-spacing:-.03em;margin-bottom:6px;font-size:24px;font-weight:700}[data-theme=dark] .login-form-title{color:#f1f5f9}.login-form-subtitle{color:#64748b;font-size:13.5px}.login-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;align-items:center;gap:8px;margin-bottom:20px;padding:10px 14px;font-size:13px;font-weight:500;animation:.2s slideUp;display:flex}.login-field{margin-bottom:20px}.login-label{color:#0f172a;margin-bottom:6px;font-size:13px;font-weight:600;display:block}[data-theme=dark] .login-label{color:#e2e8f0}.login-input-wrapper{align-items:center;display:flex;position:relative}.login-input-icon{color:#94a3b8;pointer-events:none;z-index:1;position:absolute;left:12px}.login-input{color:#0f172a;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;width:100%;height:44px;padding:10px 12px 10px 40px;font-size:14px;transition:all .15s}[data-theme=dark] .login-input{color:#f1f5f9;background:#334155;border-color:#475569}.login-input:focus{background:#fff;border-color:#3b82f6;outline:none;box-shadow:0 0 0 4px #3b82f61a}[data-theme=dark] .login-input:focus{background:#1e293b}.login-input::placeholder{color:#94a3b8}.login-eye-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex;position:absolute;right:10px}.login-eye-btn:hover{color:#0f172a;background:#f1f5f9}.login-submit{color:#fff;cursor:pointer;letter-spacing:.01em;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;height:46px;margin-bottom:16px;font-size:15px;font-weight:600;transition:all .2s cubic-bezier(.16,1,.3,1);display:flex;box-shadow:0 4px 14px #3b82f659}.login-submit:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 6px 20px #3b82f673}.login-submit:active{transform:translateY(0)}.login-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-hint{color:#94a3b8;background:#f1f5f9;border-radius:6px;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:12px;display:flex}[data-theme=dark] .login-hint{color:#94a3b8;background:#334155}.login-hint strong{color:#475569}.login-footer{color:#ffffff26;letter-spacing:.08em;text-transform:uppercase;z-index:1;font-size:11px;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}@media (max-width:768px){.login-container{grid-template-columns:1fr;width:95vw;max-width:420px}.login-brand-side{display:none}.login-form-side{padding:32px 24px}.login-scene{display:none}}
