:root{--primary: #4f6ef7;--primary-dark: #3b5de7;--primary-light: #edf0ff;--success: #10b981;--success-light: #ecfdf5;--danger: #ef4444;--danger-light: #fef2f2;--warning: #f59e0b;--warning-light: #fffbeb;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--radius: 6px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.05), 0 2px 4px -2px rgba(0,0,0,.04);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.06), 0 4px 6px -4px rgba(0,0,0,.04)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;background:var(--gray-50);color:var(--gray-800);line-height:1.6;-webkit-font-smoothing:antialiased}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1rem;color:var(--gray-400);gap:.75rem}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:#1a1a2e;color:#e2e8f0;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;border-right:1px solid #2d2d44}.sidebar-header{padding:1.25rem 1.25rem .75rem;display:flex;align-items:center;gap:.6rem}.sidebar-header .logo{width:32px;height:32px;background:linear-gradient(135deg,#4f6ef7,#6366f1);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#fff}.sidebar-header h1{font-size:.95rem;font-weight:600;letter-spacing:-.01em}.sidebar-nav{flex:1;padding:.5rem .75rem}.sidebar-nav a{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;color:#94a3b8;text-decoration:none;font-size:.85rem;border-radius:6px;transition:all .15s;margin-bottom:.15rem}.sidebar-nav a:hover{background:#ffffff0f;color:#e2e8f0}.sidebar-nav a.active{background:#4f6ef726;color:#93a8ff;font-weight:500}.sidebar-nav a .icon{font-size:1rem;width:20px;text-align:center;opacity:.7}.sidebar-nav a.active .icon{opacity:1}.sidebar-footer{padding:.75rem 1.25rem;border-top:1px solid #2d2d44;font-size:.75rem;color:#64748b}.main-content{margin-left:240px;flex:1;padding:1.5rem 2rem 2rem;max-width:1400px}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.topbar h2{font-size:1.25rem;font-weight:600;color:var(--gray-900);letter-spacing:-.02em}.topbar-right{display:flex;align-items:center;gap:.75rem}.user-info{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.user-info .avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#4f6ef7,#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem}.user-info .role-badge{font-size:.65rem;padding:.12rem .4rem;border-radius:4px;font-weight:600;text-transform:uppercase}.role-badge.admin{background:var(--danger-light);color:var(--danger)}.role-badge.supplier{background:var(--primary-light);color:var(--primary)}.role-badge.viewer{background:var(--gray-200);color:var(--gray-500)}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;border:none;border-radius:var(--radius);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s;text-decoration:none;white-space:nowrap}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);box-shadow:0 2px 8px #4f6ef740}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-outline{background:#fff;color:var(--gray-600);border:1px solid var(--gray-300)}.btn-outline:hover{background:var(--gray-50);border-color:var(--gray-400)}.btn-sm{padding:.3rem .6rem;font-size:.75rem}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);margin-bottom:1.25rem;overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--gray-100);background:var(--gray-50)}.card-header h3{font-size:.95rem;font-weight:600;color:var(--gray-800);letter-spacing:-.01em}.card>.table-wrapper{padding:0}.card>.table-wrapper table th:first-child,.card>.table-wrapper table td:first-child{padding-left:1.25rem}.card>.table-wrapper table th:last-child,.card>.table-wrapper table td:last-child{padding-right:1.25rem}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.825rem}th,td{padding:.6rem .85rem;text-align:left;border-bottom:1px solid var(--gray-100)}th{background:var(--gray-50);font-weight:600;color:var(--gray-500);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}tr:hover{background:var(--gray-50)}.form-group{margin-bottom:.85rem}.form-group label{display:block;margin-bottom:.3rem;font-weight:500;font-size:.8rem;color:var(--gray-600)}.form-control{width:100%;padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.85rem;transition:all .15s;font-family:inherit;background:#fff}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.85rem}.badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;letter-spacing:.02em}.badge-open{background:var(--success-light);color:var(--success)}.badge-closed{background:var(--danger-light);color:var(--danger)}.badge-cancelled{background:var(--gray-200);color:var(--gray-400)}.badge-finished{background:#e0e7ff;color:#4338ca}.badge-active{background:var(--success-light);color:var(--success)}.badge-inactive{background:var(--danger-light);color:var(--danger)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#1a1a2e)}.login-card{background:#fff;border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:400px;box-shadow:0 25px 50px #00000026}.login-card .login-logo{width:48px;height:48px;margin:0 auto .75rem;background:linear-gradient(135deg,#4f6ef7,#6366f1);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.login-card h2{text-align:center;margin-bottom:.15rem;font-size:1.3rem;font-weight:600}.login-card .subtitle{text-align:center;color:var(--gray-400);margin-bottom:1.75rem;font-size:.85rem}.login-card .btn{width:100%;justify-content:center;margin-top:.75rem;padding:.6rem;font-size:.9rem}.error-msg{background:var(--danger-light);color:var(--danger);padding:.6rem .85rem;border-radius:var(--radius);margin-bottom:.85rem;font-size:.8rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:1.1rem 1.25rem;border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:.85rem}.stat-card .stat-icon{font-size:1.5rem;opacity:.85}.stat-card .stat-value{font-size:1.35rem;font-weight:700;color:var(--gray-900);letter-spacing:-.02em}.stat-card .stat-label{font-size:.75rem;color:var(--gray-400)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;width:90%;max-width:700px;max-height:85vh;overflow-y:auto;box-shadow:0 25px 50px #0003;border:1px solid var(--gray-200)}.modal h3{font-size:1.05rem;font-weight:600;margin-bottom:1rem;color:var(--gray-900)}.login-test-accounts{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--gray-100);font-size:.75rem;color:var(--gray-400)}.login-test-accounts p{margin-bottom:.25rem}.login-test-accounts code{background:var(--gray-100);padding:.1rem .35rem;border-radius:3px;font-size:.72rem}.deadline-passed{color:var(--danger);font-weight:600}.compare-table{font-size:.78rem}.compare-table .supplier-col{background:#f0f4ff}.compare-table .total-row td{background:var(--gray-50);font-weight:700}.modal h3{margin-bottom:1.5rem}.items-grid{display:grid;grid-template-columns:60px 1fr 100px 120px auto;gap:.5rem;align-items:end;margin-bottom:1rem}.items-header{font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;padding-bottom:.5rem}.compare-table th,.compare-table td{min-width:130px}.compare-table .supplier-col{background:var(--primary-light)}.compare-table .total-row{font-weight:700;background:var(--gray-50)}.toast{position:fixed;top:1rem;right:1rem;z-index:2000;padding:1rem 1.5rem;border-radius:var(--radius);color:#fff;font-weight:500;box-shadow:var(--shadow-lg);animation:slideIn .3s ease}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.deadline-warning{color:var(--warning)}.deadline-passed{color:var(--danger)}@media (max-width: 768px){.sidebar{display:none}.main-content{margin-left:0}}
