*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:DM Sans,sans-serif;background:#f4f2ef;color:#1a1714;-webkit-font-smoothing:antialiased}:root{--amber: #F5A623;--amber-d: #E8920A;--dark: #1A1714;--card: #2A2520;--white: #FFFFFF;--gray: #9B9590;--bg: #F4F2EF;--green: #1D7A4A;--red: #C0392B;--blue: #1A56DB;--orange: #D4520A;--radius: 14px;--shadow: 0 2px 12px rgba(0,0,0,.08)}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:240px;background:var(--dark);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.main-content{flex:1;overflow-y:auto;background:var(--bg)}.page-inner{max-width:1200px;margin:0 auto;padding:24px}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo-icon{width:40px;height:40px;background:var(--amber);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.sidebar-logo-text{color:#fff;font-size:18px;font-weight:800;font-family:Outfit,sans-serif}.sidebar-logo-sub{color:#fff6;font-size:11px}.sidebar-nav{padding:12px 0;flex:1}.nav-link{display:flex;align-items:center;gap:12px;padding:11px 20px;color:#ffffff8c;font-size:14px;font-weight:500;cursor:pointer;border-left:3px solid transparent;transition:all .15s;text-decoration:none;border:none;background:none;width:100%;text-align:left}.nav-link:hover{color:#fff;background:#ffffff0f}.nav-link.active{color:var(--amber);background:#f5a6231a;border-left:3px solid var(--amber)}.nav-link-icon{font-size:18px;width:22px;flex-shrink:0}.sidebar-user{padding:16px 20px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:var(--amber);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;color:var(--dark);flex-shrink:0}.sidebar-user-name{color:#fff;font-size:13px;font-weight:600}.sidebar-user-role{color:#fff6;font-size:11px}.sidebar-logout{background:none;border:none;color:#fff6;cursor:pointer;font-size:16px;margin-left:auto;padding:4px}.sidebar-logout:hover{color:var(--red)}.topbar{background:#fff;border-bottom:1px solid #E8E4DF;padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.topbar-title{font-size:18px;font-weight:700;font-family:Outfit,sans-serif}.topbar-actions{display:flex;align-items:center;gap:10px}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card-header{padding:16px 20px;border-bottom:1px solid #F4F2EF;display:flex;align-items:center;justify-content:space-between}.card-title{font-size:15px;font-weight:700}.card-body{padding:20px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.kpi-card{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);cursor:pointer;transition:transform .15s,box-shadow .15s}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001f}.kpi-icon{font-size:22px;margin-bottom:10px}.kpi-value{font-size:26px;font-weight:800;font-family:Outfit,sans-serif}.kpi-label{font-size:12px;color:var(--gray);margin-top:2px;font-weight:500}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:opacity .15s,transform .1s;font-family:inherit}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--amber);color:var(--dark)}.btn-primary:hover{background:var(--amber-d)}.btn-dark{background:var(--dark);color:#fff}.btn-outline{background:#fff;color:var(--dark);border:2px solid #E8E4DF}.btn-outline:hover{border-color:var(--amber)}.btn-danger{background:#fdf0ee;color:var(--red)}.btn-success{background:#e6f4ea;color:var(--green)}.btn-sm{padding:7px 14px;font-size:13px;border-radius:8px}.btn-full{width:100%}.btn-icon{padding:8px;border-radius:8px}.inp-group{margin-bottom:14px}.inp-label{font-size:11px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;display:block}.inp{width:100%;background:#f9f7f5;border:2px solid transparent;border-radius:10px;padding:11px 14px;font-size:14px;color:var(--dark);outline:none;transition:border-color .15s;font-family:inherit}.inp:focus{border-color:var(--amber);background:#fff}select.inp{cursor:pointer}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;padding:10px 16px;font-size:11px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.5px;background:#f9f7f5;border-bottom:1px solid #E8E4DF}td{padding:12px 16px;font-size:14px;border-bottom:1px solid #F4F2EF;vertical-align:middle}tr:hover td{background:#fafaf8}tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.badge-posted{background:#ebf0fe;color:#1a56db}.badge-bidding{background:#fef3e7;color:#d4520a}.badge-confirmed,.badge-completed{background:#e6f4ea;color:#1d7a4a}.badge-cancelled{background:#fdf0ee;color:#c0392b}.badge-pending{background:#fef3e7;color:#d4520a}.badge-approved{background:#e6f4ea;color:#1d7a4a}.badge-rejected{background:#fdf0ee;color:#c0392b}.badge-active{background:#e6f4ea;color:#1d7a4a}.badge-inactive{background:#f4f2ef;color:#9b9590}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:#fff;border-radius:18px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 60px #0000004d}.modal-header{padding:20px 24px 16px;border-bottom:1px solid #F4F2EF;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:1}.modal-title{font-size:17px;font-weight:800}.modal-close{background:#f4f2ef;border:none;border-radius:50%;width:32px;height:32px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-body{padding:20px 24px 24px}.empty-state{text-align:center;padding:60px 20px;color:var(--gray)}.empty-icon{font-size:48px;margin-bottom:12px}.empty-title{font-size:16px;font-weight:600;color:var(--dark);margin-bottom:6px}.empty-sub{font-size:14px}.toast-container{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:8px}.toast{background:var(--dark);color:#fff;padding:12px 20px;border-radius:10px;font-size:14px;font-weight:500;box-shadow:0 8px 24px #0003;animation:slideIn .2s ease-out;max-width:320px}.toast-success{background:var(--green)}.toast-error{background:var(--red)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:none;opacity:1}}.auth-screen{height:100vh;display:flex;background:var(--dark);overflow:hidden}.auth-hero{flex:1;display:flex;flex-direction:column;justify-content:center;padding:48px;background:linear-gradient(135deg,#1a1714,#2a2520)}.auth-hero-logo{display:flex;align-items:center;gap:14px;margin-bottom:40px}.auth-hero-icon{width:52px;height:52px;background:var(--amber);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px}.auth-hero-brand{color:#fff;font-size:26px;font-weight:800;font-family:Outfit,sans-serif}.auth-hero-sub{color:#fff6;font-size:12px}.auth-hero-headline{font-size:42px;font-weight:800;color:#fff;line-height:1.15;margin-bottom:16px;font-family:Outfit,sans-serif}.auth-hero-headline span{color:var(--amber)}.auth-hero-desc{color:#ffffff80;font-size:15px;line-height:1.6;margin-bottom:40px}.auth-hero-pills{display:flex;gap:10px;flex-wrap:wrap}.auth-hero-pill{background:#ffffff14;color:#ffffffb3;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:500}.auth-panel{width:440px;flex-shrink:0;background:#fff;display:flex;flex-direction:column;justify-content:center;padding:48px 40px;overflow-y:auto}.auth-panel-title{font-size:26px;font-weight:800;margin-bottom:4px;font-family:Outfit,sans-serif}.auth-panel-sub{font-size:14px;color:var(--gray);margin-bottom:28px}.auth-divider{display:flex;align-items:center;gap:12px;margin:18px 0}.auth-divider-line{flex:1;height:1px;background:#e8e4df}.auth-divider-text{font-size:12px;color:#c4bfb8}.auth-switch{text-align:center;font-size:14px;color:var(--gray);margin-top:20px}.auth-switch a{color:var(--amber);font-weight:700;cursor:pointer;text-decoration:none}@media (max-width: 1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.auth-hero{display:none}.auth-panel{width:100%;padding:32px 24px}}@media (max-width: 768px){.sidebar{display:none}.kpi-grid{grid-template-columns:repeat(2,1fr)}.page-inner{padding:16px}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.text-gray{color:var(--gray)}.text-amber{color:var(--amber)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-sm{font-size:13px}.text-xs{font-size:11px}.font-bold{font-weight:700}.font-black{font-weight:800}.rounded{border-radius:var(--radius)}.w-full{width:100%}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
