:root{--navy-900: #0b1f33;--navy-800: #14304f;--navy-700: #1a4d7a;--primary: #4f46e5;--primary-600: #4338ca;--primary-400: #818cf8;--accent: #06b6d4;--green: #10b981;--green-bg: #d1fae5;--amber: #f59e0b;--amber-bg: #fef3c7;--red: #ef4444;--red-bg: #fee2e2;--blue: #3b82f6;--blue-bg: #dbeafe;--slate: #64748b;--slate-bg: #e2e8f0;--violet: #8b5cf6;--violet-bg: #ede9fe;--bg: #f1f5f9;--surface: #ffffff;--border: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--text-light: #94a3b8;--radius: 14px;--radius-sm: 9px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow: 0 4px 16px rgba(15, 23, 42, .08);--shadow-lg: 0 12px 40px rgba(15, 23, 42, .16);--sidebar-w: 264px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer;border:none}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,var(--navy-900) 0%,var(--navy-800) 100%);color:#cbd5e1;display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;z-index:40;box-shadow:4px 0 24px #0b1f332e}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:22px 22px 18px}.sidebar-brand .logo{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--primary-400),var(--primary-600));display:grid;place-items:center;color:#fff;box-shadow:0 6px 18px #4f46e573}.sidebar-brand h1{font-size:15px;color:#fff;font-weight:700;line-height:1.15}.sidebar-brand span{font-size:11px;color:var(--primary-400);font-weight:500}.nav-section{padding:4px 14px}.nav-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.09em;color:#5b7595;font-weight:700;padding:16px 12px 7px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;margin:2px 0;color:#aab8cc;font-weight:500;font-size:13.5px;transition:all .16s ease;position:relative}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:linear-gradient(90deg,#4f46e5f2,#4338cad9);color:#fff;box-shadow:0 6px 16px #4f46e559}.nav-item.active:before{content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:4px;border-radius:0 4px 4px 0;background:var(--accent)}.sidebar-footer{margin-top:auto;padding:16px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-user{display:flex;align-items:center;gap:11px}.sidebar-user .avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--primary));display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px}.sidebar-user .meta{line-height:1.25}.sidebar-user .meta strong{color:#fff;font-size:13px;font-weight:600}.sidebar-user .meta small{color:#7e93ad;font-size:11px}.main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-width:0}.topbar{height:66px;background:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:30}.topbar-search{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--border);border-radius:11px;padding:9px 14px;width:340px;color:var(--text-muted);transition:all .15s}.topbar-search:focus-within{border-color:var(--primary-400);background:#fff;box-shadow:0 0 0 4px #818cf826}.topbar-search input{border:none;background:none;outline:none;flex:1;font-size:13.5px;color:var(--text)}.topbar-actions{display:flex;align-items:center;gap:14px}.icon-btn{width:40px;height:40px;border-radius:11px;background:var(--bg);display:grid;place-items:center;color:var(--text-muted);position:relative;transition:all .15s;border:1px solid transparent}.icon-btn:hover{background:#fff;border-color:var(--border);color:var(--primary)}.icon-btn .dot{position:absolute;top:9px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--red);border:2px solid #fff}.content{padding:28px;flex:1}.page-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-head h2{font-size:23px;font-weight:800;color:var(--navy-800);letter-spacing:-.02em}.page-head .sub{color:var(--text-muted);font-size:13.5px;margin-top:4px}.breadcrumb{font-size:12px;color:var(--text-light);margin-bottom:6px;display:flex;gap:7px;align-items:center}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.card-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-head h3{font-size:15.5px;font-weight:700;color:var(--navy-800)}.card-head .sub{font-size:12.5px;color:var(--text-muted)}.card-body{padding:22px}.stat-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:transform .18s,box-shadow .18s}.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.stat-card:after{content:"";position:absolute;right:-28px;top:-28px;width:90px;height:90px;border-radius:50%;opacity:.1;background:var(--accent-color, var(--primary))}.stat-card .stat-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:#fff;margin-bottom:10px;box-shadow:var(--shadow-sm);background:var(--accent-color, var(--primary))}.stat-card .stat-value{font-size:22px;font-weight:800;color:var(--navy-800);letter-spacing:-.02em}.stat-card .stat-label{color:var(--text-muted);font-size:12px;margin-top:2px;font-weight:500}.stat-trend{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;margin-top:10px;padding:3px 8px;border-radius:20px}.stat-trend.up{color:var(--green);background:var(--green-bg)}.stat-trend.down{color:var(--red);background:var(--red-bg)}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap}.badge .pip{width:6px;height:6px;border-radius:50%;background:currentColor}.badge.green{color:#047857;background:var(--green-bg)}.badge.amber{color:#b45309;background:var(--amber-bg)}.badge.red{color:#b91c1c;background:var(--red-bg)}.badge.blue{color:#1d4ed8;background:var(--blue-bg)}.badge.slate{color:#475569;background:var(--slate-bg)}.badge.violet{color:#6d28d9;background:var(--violet-bg)}.table-wrap{overflow-x:auto}table.data{width:100%;border-collapse:collapse;font-size:13.5px}table.data thead th{text-align:left;padding:13px 18px;font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:700;background:#f8fafc;border-bottom:1px solid var(--border);white-space:nowrap}table.data tbody td{padding:14px 18px;border-bottom:1px solid #f1f5f9;color:var(--text);vertical-align:middle}table.data tbody tr{transition:background .12s}table.data tbody tr:hover{background:#f8fafc}table.data tbody tr:last-child td{border-bottom:none}.cell-strong{font-weight:600;color:var(--navy-800)}.cell-mono{font-family:SF Mono,Consolas,monospace;font-size:12.5px;color:var(--primary-600);font-weight:600}.cell-muted{color:var(--text-muted);font-size:12.5px}.row-actions{display:flex;gap:6px}.row-actions button{width:32px;height:32px;border-radius:8px;background:var(--bg);color:var(--text-muted);display:grid;place-items:center;transition:all .14s}.row-actions button:hover{background:#fff;box-shadow:var(--shadow-sm)}.row-actions button.danger:hover{color:var(--red)}.row-actions button.edit:hover{color:var(--primary)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:11px;font-weight:600;font-size:13.5px;transition:all .15s;white-space:nowrap}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;pointer-events:none;background:#e2e8f0;color:var(--text-muted);box-shadow:none;transform:none}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-600));color:#fff;box-shadow:0 6px 16px #4f46e552}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 9px 22px #4f46e56b}.btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg);border-color:#cbd5e1}.btn-soft{background:var(--violet-bg);color:var(--primary-600)}.btn-soft:hover{background:#e0e7ff}.btn-sm{padding:7px 13px;font-size:12.5px;border-radius:9px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.field{display:flex;flex-direction:column;gap:7px}.field label{font-size:12.5px;font-weight:600;color:var(--text)}.field label .req{color:var(--red)}.field input,.field select,.field textarea{padding:11px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:13.5px;background:#fff;color:var(--text);transition:all .15s;outline:none;width:100%}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary-400);box-shadow:0 0 0 4px #818cf826}.field input:disabled,.field select:disabled{background:#f1f5f9;color:var(--text-muted);cursor:not-allowed}.field .hint{font-size:11.5px;color:var(--text-light)}.field-autofill input{background:#f0fdf4;border-color:#bbf7d0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b1f3373;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;z-index:80;padding:20px;animation:fade .15s ease}.modal{background:var(--surface);border-radius:18px;width:100%;max-width:620px;box-shadow:var(--shadow-lg);animation:pop .2s ease;max-height:90vh;display:flex;flex-direction:column}.modal-head{padding:22px 26px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-head h3{font-size:18px;font-weight:700;color:var(--navy-800)}.modal-body{padding:26px;overflow-y:auto}.modal-foot{padding:18px 26px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:12px}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:scale(.96) translateY(8px)}}.login-shell{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-hero{background:linear-gradient(150deg,var(--navy-900),var(--navy-700) 60%,var(--primary-600));color:#fff;padding:60px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.login-hero:before{content:"";position:absolute;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(6,182,212,.35),transparent 70%);top:-120px;right:-120px}.login-hero:after{content:"";position:absolute;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(129,140,248,.4),transparent 70%);bottom:-100px;left:-80px}.login-hero .hero-brand{display:flex;align-items:center;gap:13px;position:relative;z-index:2}.login-hero .hero-brand .logo{width:46px;height:46px;border-radius:13px;background:#ffffff24;display:grid;place-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.login-hero h1{font-size:38px;font-weight:800;line-height:1.15;position:relative;z-index:2;letter-spacing:-.02em}.login-hero p{font-size:15px;color:#c7d6ea;line-height:1.6;margin-top:16px;position:relative;z-index:2;max-width:420px}.hero-stats{display:flex;gap:34px;position:relative;z-index:2}.hero-stats .hs strong{font-size:26px;font-weight:800;display:block}.hero-stats .hs span{font-size:12.5px;color:#9fb3cc}.hero-flow{display:flex;flex-wrap:wrap;gap:8px;position:relative;z-index:2}.hero-flow span{background:#ffffff1a;padding:6px 12px;border-radius:20px;font-size:12px}.login-form-side{display:grid;place-items:center;padding:40px;background:var(--surface)}.login-card{width:100%;max-width:380px}.login-card h2{font-size:26px;font-weight:800;color:var(--navy-800)}.login-card .muted{color:var(--text-muted);margin:8px 0 28px;font-size:14px}.login-card .field{margin-bottom:18px}.role-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:22px}.role-pill{padding:7px 13px;border-radius:20px;border:1.5px solid var(--border);font-size:12px;font-weight:600;color:var(--text-muted);transition:all .14s;background:#fff}.role-pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}.grid-2{display:grid;grid-template-columns:2fr 1fr;gap:20px}.grid-ops{display:grid;grid-template-columns:1fr 1.7fr;gap:20px;align-items:start}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.flex{display:flex}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.empty-state{text-align:center;padding:50px 20px;color:var(--text-light)}.empty-state svg{margin-bottom:12px;opacity:.5}.timeline{position:relative;padding-left:28px}.timeline:before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--border)}.tl-item{position:relative;padding-bottom:22px}.tl-item:before{content:"";position:absolute;left:-23px;top:3px;width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--primary)}.tl-item.done:before{border-color:var(--green)}.tl-item .tl-title{font-weight:600;color:var(--navy-800);font-size:13.5px}.tl-item .tl-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.pill-tabs{display:inline-flex;background:var(--bg);padding:4px;border-radius:12px;gap:4px}.pill-tab{padding:8px 16px;border-radius:9px;font-size:13px;font-weight:600;color:var(--text-muted);background:none;transition:all .14s}.pill-tab.active{background:#fff;color:var(--primary-600);box-shadow:var(--shadow-sm)}.weight-calc{background:linear-gradient(135deg,#f8fafc,#eef2ff);border:1.5px dashed var(--primary-400);border-radius:14px;padding:20px}.weight-calc .calc-row{display:flex;justify-content:space-between;padding:7px 0;font-size:14px}.weight-calc .calc-row.total{border-top:1.5px solid var(--border);margin-top:6px;padding-top:12px;font-weight:700;font-size:16px}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1024px){.login-shell{grid-template-columns:1fr}.login-hero{display:none}.grid-2,.grid-ops{grid-template-columns:1fr}}
