@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--navy:#0f1a2e;--navy-light:#1a2d4a;--navy-mid:#243b5e;--teal:#14b8a6;--teal-dark:#0d9488;--teal-light:#5eead4;--orange:#f97316;--orange-light:#fdba74;--white:#fff;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--green:#10b981;--red:#ef4444;--yellow:#f59e0b;--blue:#3b82f6;--purple:#8b5cf6;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 30px #0000001f;--shadow-xl:0 20px 60px #00000026;--transition:all .2s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--gray-50);color:var(--navy);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,sans-serif;line-height:1.6}.app-layout{min-height:100vh;display:flex}.sidebar{background:linear-gradient(180deg, var(--navy) 0%, var(--navy-light) 100%);width:260px;color:var(--white);z-index:100;flex-direction:column;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid #ffffff14;padding:24px 20px}.sidebar-brand h1{background:linear-gradient(135deg, var(--teal-light), var(--teal));-webkit-text-fill-color:transparent;letter-spacing:-.3px;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:700}.sidebar-brand .tagline{color:var(--gray-400);letter-spacing:.5px;text-transform:uppercase;margin-top:4px;font-size:11px}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto}.nav-section{margin-bottom:20px}.nav-section-title{text-transform:uppercase;letter-spacing:1.2px;color:var(--gray-400);padding:8px 12px 4px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--radius-md);color:var(--gray-300);cursor:pointer;transition:var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{color:var(--white);background:#ffffff0f}.nav-item.active{color:var(--teal-light);background:#14b8a626}.nav-item svg{flex-shrink:0;width:18px;height:18px}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 12px}.sidebar-user{border-radius:var(--radius-md);align-items:center;gap:10px;padding:8px;display:flex}.sidebar-user .avatar{background:linear-gradient(135deg, var(--teal), var(--blue));width:36px;height:36px;color:var(--white);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.sidebar-user .user-info{flex:1;min-width:0}.sidebar-user .user-name{color:var(--white);font-size:13px;font-weight:600}.sidebar-user .user-role{color:var(--gray-400);text-transform:capitalize;font-size:11px}.main-content{flex:1;min-height:100vh;margin-left:260px}.page-header{background:var(--white);border-bottom:1px solid var(--gray-200);z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;padding:20px 32px;display:flex;position:sticky;top:0}.page-header h2{color:var(--navy);font-size:20px;font-weight:700}.page-header .subtitle{color:var(--gray-500);margin-top:2px;font-size:13px}.page-body{padding:24px 32px}.card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-md)}.card-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-header h3{font-size:15px;font-weight:600}.card-body{padding:20px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-200);transition:var(--transition);cursor:default;align-items:flex-start;gap:14px;padding:20px;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-icon svg{width:22px;height:22px;color:var(--white)}.stat-icon.teal{background:linear-gradient(135deg, var(--teal), var(--teal-dark))}.stat-icon.blue{background:linear-gradient(135deg, var(--blue), #2563eb)}.stat-icon.orange{background:linear-gradient(135deg, var(--orange), #ea580c)}.stat-icon.green{background:linear-gradient(135deg, var(--green), #059669)}.stat-icon.red{background:linear-gradient(135deg, var(--red), #dc2626)}.stat-icon.yellow{background:linear-gradient(135deg, var(--yellow), #d97706)}.stat-icon.purple{background:linear-gradient(135deg, var(--purple), #7c3aed)}.stat-icon.navy{background:linear-gradient(135deg, var(--navy-mid), var(--navy))}.stat-info{flex:1}.stat-value{color:var(--navy);font-size:26px;font-weight:800;line-height:1}.stat-label{color:var(--gray-500);margin-top:4px;font-size:12px;font-weight:500}.btn{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);white-space:nowrap;border:none;align-items:center;gap:8px;padding:9px 18px;font-family:inherit;font-size:13.5px;font-weight:600;text-decoration:none;display:inline-flex}.btn svg{width:16px;height:16px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--teal), var(--teal-dark));color:var(--white)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #14b8a666}.btn-secondary{background:var(--gray-100);color:var(--navy);border:1px solid var(--gray-200)}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-danger{background:var(--red);color:var(--white)}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-outline{color:var(--teal-dark);border:1.5px solid var(--teal);background:0 0}.btn-outline:hover:not(:disabled){background:#14b8a614}.btn-ghost{color:var(--gray-600);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--gray-100)}.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{padding:12px 24px;font-size:15px}.btn-icon{padding:8px}.btn-group{flex-wrap:wrap;gap:8px;display:flex}.form-group{margin-bottom:16px}.form-label{color:var(--navy);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{border:1.5px solid var(--gray-200);border-radius:var(--radius-md);width:100%;color:var(--navy);background:var(--white);transition:var(--transition);padding:10px 14px;font-family:inherit;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 3px #14b8a61a}.form-textarea{resize:vertical;min-height:80px}.form-hint{color:var(--gray-500);margin-top:4px;font-size:12px}.form-error{color:var(--red);margin-top:4px;font-size:12px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.file-upload{border:2px dashed var(--gray-300);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:var(--transition);background:var(--gray-50);padding:32px}.file-upload:hover{border-color:var(--teal);background:#14b8a608}.file-upload.dragging{border-color:var(--teal);background:#14b8a60f}.file-upload svg{width:40px;height:40px;color:var(--gray-400);margin-bottom:8px}.file-upload p{color:var(--gray-500);font-size:14px}.file-upload .file-name{color:var(--teal-dark);margin-top:8px;font-size:13px;font-weight:600}.table-container{border-radius:var(--radius-lg);border:1px solid var(--gray-200);background:var(--white);overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table thead{background:var(--gray-50)}.data-table th{text-align:left;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--gray-200);white-space:nowrap;padding:12px 16px;font-size:11.5px;font-weight:600}.data-table td{border-bottom:1px solid var(--gray-100);color:var(--gray-700);padding:12px 16px}.data-table tbody tr{transition:var(--transition)}.data-table tbody tr:hover{background:#14b8a608}.data-table tbody tr:last-child td{border-bottom:none}.badge{white-space:nowrap;border-radius:20px;align-items:center;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-unallocated{color:#64748b;background:#f1f5f9}.badge-allocated{color:#2563eb;background:#dbeafe}.badge-wip{color:#d97706;background:#fef3c7}.badge-delivered{color:#059669;background:#d1fae5}.badge-partial{color:#ea580c;background:#ffedd5}.badge-rejected{color:#dc2626;background:#fee2e2}.badge-completed{color:#047857;background:#d1fae5}.badge-success{color:#059669;background:#d1fae5}.badge-warning{color:#d97706;background:#fef3c7}.badge-error{color:#dc2626;background:#fee2e2}.badge-info{color:#2563eb;background:#dbeafe}.tabs{border-bottom:2px solid var(--gray-200);gap:0;margin-bottom:20px;display:flex}.tab-btn{color:var(--gray-500);cursor:pointer;transition:var(--transition);background:0 0;border:none;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;position:relative}.tab-btn:hover{color:var(--navy)}.tab-btn.active{color:var(--teal-dark)}.tab-btn.active:after{content:"";background:var(--teal);border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:-2px;left:0;right:0}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f1a2e80;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:90%;max-width:560px;max-height:85vh;animation:.3s slideUp;overflow-y:auto}.modal-lg{max-width:780px}.modal-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{font-size:17px;font-weight:700}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--gray-100);justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.filters-bar{flex-wrap:wrap;align-items:center;gap:12px;padding:16px 0;display:flex}.filter-select{border:1.5px solid var(--gray-200);border-radius:var(--radius-md);color:var(--navy);background:var(--white);min-width:140px;padding:8px 12px;font-family:inherit;font-size:13px}.search-input{border:1.5px solid var(--gray-200);border-radius:var(--radius-md);background:var(--white);width:240px;padding:8px 14px 8px 36px;font-family:inherit;font-size:13px}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{border-radius:var(--radius-md);box-shadow:var(--shadow-lg);align-items:center;gap:10px;min-width:300px;padding:14px 20px;font-size:13.5px;font-weight:500;animation:.3s slideInRight;display:flex}.toast-success{color:var(--white);background:#065f46}.toast-error{color:var(--white);background:#991b1b}.toast-info{background:var(--navy);color:var(--white)}.login-page{background:linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 50%, #1e3a5f 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle,#14b8a61f,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-200px;right:-200px}.login-page:after{content:"";background:radial-gradient(circle,#f9731614,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-100px;left:-100px}.login-card{border-radius:var(--radius-xl);width:440px;max-width:95vw;box-shadow:var(--shadow-xl);z-index:1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff7;padding:40px;position:relative}.login-brand{text-align:center;margin-bottom:32px}.login-brand .logo-icon{background:linear-gradient(135deg, var(--teal), var(--teal-dark));border-radius:var(--radius-lg);width:56px;height:56px;color:var(--white);justify-content:center;align-items:center;margin:0 auto 16px;font-size:24px;font-weight:800;display:flex}.login-brand h1{color:var(--navy);font-size:22px;font-weight:800}.login-brand .tagline{color:var(--gray-500);margin-top:4px;font-size:13px}.login-brand .portal-name{color:var(--teal-dark);margin-top:2px;font-size:14px;font-weight:600}.otp-input-group{justify-content:center;gap:8px;margin:16px 0;display:flex}.otp-box{border:2px solid var(--gray-200);border-radius:var(--radius-md);text-align:center;width:48px;height:54px;color:var(--navy);transition:var(--transition);font-family:inherit;font-size:22px;font-weight:700}.otp-box:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 3px #14b8a626}.progress-bar{background:var(--gray-200);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--teal), var(--teal-dark));border-radius:4px;height:100%;transition:width .4s}.checkbox-label{cursor:pointer;color:var(--gray-700);align-items:center;gap:8px;font-size:13.5px;display:flex}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--teal);cursor:pointer}.empty-state{text-align:center;color:var(--gray-400);padding:48px 24px}.empty-state svg{width:56px;height:56px;color:var(--gray-300);margin-bottom:12px}.empty-state h3{color:var(--gray-500);margin-bottom:4px;font-size:16px}.empty-state p{font-size:13px}.spinner{border:3px solid var(--gray-200);border-top-color:var(--teal);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.loading-screen{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.loading-screen p{color:var(--gray-500);font-size:14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}.mobile-toggle{color:var(--navy);cursor:pointer;background:0 0;border:none;padding:8px;display:none}.mobile-toggle svg{width:24px;height:24px}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.mobile-toggle{display:block}.page-body,.page-header{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.form-row{grid-template-columns:1fr}.filters-bar{flex-direction:column;align-items:stretch}.modal{width:95%}.login-card{padding:28px 20px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.sidebar-overlay{z-index:99;background:#0006;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar-overlay.active{display:block}}.pagination{justify-content:center;align-items:center;gap:4px;padding:16px 0;display:flex}.page-btn{border:1px solid var(--gray-200);border-radius:var(--radius-sm);background:var(--white);color:var(--gray-600);cursor:pointer;transition:var(--transition);padding:6px 12px;font-family:inherit;font-size:13px}.page-btn:hover{background:var(--gray-100)}.page-btn.active{background:var(--teal);color:var(--white);border-color:var(--teal)}.validation-summary{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:20px;display:grid}.validation-item{border-radius:var(--radius-md);text-align:center;padding:16px}.validation-item .val-count{font-size:28px;font-weight:800}.validation-item .val-label{margin-top:4px;font-size:12px;font-weight:500}.validation-item.success{color:#047857;background:#ecfdf5}.validation-item.warning{color:#b45309;background:#fffbeb}.validation-item.error{color:#b91c1c;background:#fef2f2}.validation-item.info{color:#1d4ed8;background:#eff6ff}
