:root{--bg: #0d0f14;--bg-card: #13161e;--bg-input: #1a1e28;--border: #252a38;--border-hover: #3a4157;--text: #e8ecf5;--text-muted: #7a8299;--text-dim: #4a5168;--accent: #4f7cff;--accent-hover: #6b93ff;--accent-dim: rgba(79,124,255,.12);--success: #22c55e;--success-dim: rgba(34,197,94,.12);--warning: #f59e0b;--warning-dim: rgba(245,158,11,.12);--danger: #ef4444;--danger-dim: rgba(239,68,68,.12);--purple: #a78bfa;--purple-dim: rgba(167,139,250,.12);--cyan: #22d3ee;--cyan-dim: rgba(34,211,238,.12);--font-head: "Outfit", sans-serif;--font-body: "Inter", sans-serif;--radius: 10px;--radius-sm: 6px;--shadow: 0 4px 24px rgba(0,0,0,.4);--transition: .18s ease;--watermark-opacity: .12}[data-theme=light]{--bg: #f0f2f7;--bg-card: #ffffff;--bg-input: #f5f7fc;--border: #dde1ee;--border-hover: #b0b9d4;--text: #111827;--text-muted: #4b5573;--text-dim: #9aa3bb;--accent: #3b6af0;--accent-hover: #2554d4;--accent-dim: rgba(59,106,240,.1);--success: #16a34a;--success-dim: rgba(22,163,74,.1);--warning: #d97706;--warning-dim: rgba(217,119,6,.1);--danger: #dc2626;--danger-dim: rgba(220,38,38,.1);--purple: #7c3aed;--purple-dim: rgba(124,58,237,.1);--cyan: #0891b2;--cyan-dim: rgba(8,145,178,.1);--shadow: 0 4px 24px rgba(0,0,0,.08);--watermark-opacity: .05}.theme-toggle{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition);margin-bottom:8px}.theme-toggle:hover{color:var(--text);border-color:var(--border-hover);background:var(--border)}.theme-toggle-icon{font-size:15px;line-height:1}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.6;min-height:100vh}h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;letter-spacing:-.02em}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width, 280px);background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100}.sidebar-logo{padding:20px 20px 16px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;align-items:flex-start;gap:8px}.sidebar-logo-img{width:40px;height:40px;object-fit:contain;display:block}.sidebar-logo .brand{font-family:var(--font-head);font-size:20px;font-weight:800;color:var(--text);letter-spacing:-.03em;line-height:1}.sidebar-logo .brand span{color:var(--accent)}.sidebar-logo .tagline{font-size:14px;font-weight:700;color:var(--text);margin-top:0;letter-spacing:.04em;text-transform:uppercase}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-section{padding:8px 12px 4px;font-size:10px;font-weight:600;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase}.nav-link{display:flex;align-items:center;gap:10px;padding:9px 16px;color:var(--text-muted);font-size:14px;font-weight:500;border-radius:0;transition:var(--transition);cursor:pointer;border:none;background:none;width:100%;text-align:left;text-decoration:none}.nav-link:hover{color:var(--text);background:var(--accent-dim)}.nav-link.active{color:var(--accent);background:var(--accent-dim);border-right:2px solid var(--accent)}.nav-icon{font-size:16px;width:20px;text-align:center}.sidebar-footer{padding:16px;border-top:1px solid var(--border)}.user-chip{display:flex;align-items:center;gap:10px;margin-bottom:10px}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-dim);border:1px solid var(--accent);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--accent);flex-shrink:0}.user-info .name{font-size:13px;font-weight:600;color:var(--text)}.user-info .role{font-size:11px;color:var(--text-muted);text-transform:capitalize}.main-content{margin-left:var(--sidebar-width, 280px);flex:1;min-height:100vh;display:flex;flex-direction:column}.sidebar-resizer{position:absolute;top:0;right:-3px;width:6px;height:100%;cursor:ew-resize;z-index:101;background:transparent;transition:background .2s}.sidebar-resizer:hover,.sidebar-resizer.is-resizing{background:var(--accent)}.page-header{padding:28px 32px 0;margin-bottom:24px}.page-header h1{font-size:26px;color:var(--text)}.page-header p{color:var(--text-muted);font-size:14px;margin-top:4px}.page-content{padding:0 32px 32px;flex:1}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.card-sm{padding:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.stat-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.stat-value{font-family:var(--font-head);font-size:28px;font-weight:800;color:var(--text);line-height:1}.stat-value.accent{color:var(--accent)}.stat-value.success{color:var(--success)}.stat-value.warning{color:var(--warning)}.stat-value.danger{color:var(--danger)}.form-group{margin-bottom:18px}.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:6px;letter-spacing:.02em}.form-label .req{color:var(--danger);margin-left:2px}.form-input,.form-select,.form-textarea{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:14px;padding:10px 14px;outline:none;transition:border-color var(--transition),box-shadow var(--transition);-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-dim)}.form-select option{background:var(--bg-card)}.form-textarea{resize:vertical;min-height:90px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-error{color:var(--danger);font-size:13px;margin-top:4px}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:var(--transition);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border-hover);background:var(--border)}.btn-warning{background:var(--warning);color:#000}.btn-warning:hover:not(:disabled){background:#d97706}.btn-sm{padding:6px 12px;font-size:13px}.btn-xs{padding:4px 10px;font-size:12px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}thead tr{border-bottom:1px solid var(--border)}th{text-align:left;padding:10px 14px;font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}td{padding:12px 14px;font-size:14px;color:var(--text-muted);border-bottom:1px solid rgba(37,42,56,.5);vertical-align:top}tr:last-child td{border-bottom:none}tr:hover td{background:#4f7cff08}.indent-id{font-family:var(--font-head);font-weight:700;color:var(--text);font-size:13px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}.badge-pending{background:var(--warning-dim);color:var(--warning)}.badge-approved{background:var(--success-dim);color:var(--success)}.badge-rejected{background:var(--danger-dim);color:var(--danger)}.badge-procurement{background:var(--purple-dim);color:var(--purple)}.badge-finance{background:var(--cyan-dim);color:var(--cyan)}.badge-completed{background:var(--accent-dim);color:var(--accent)}.badge-stock{background:#22c55e14;color:#4ade80;border:1px solid rgba(34,197,94,.2)}.badge-neutral{background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border)}.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px}.alert-success{background:var(--success-dim);color:var(--success);border:1px solid rgba(34,197,94,.2)}.alert-error{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.alert-info{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(79,124,255,.2)}.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.filter-btn{padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted);transition:var(--transition)}.filter-btn:hover{border-color:var(--border-hover);color:var(--text)}.filter-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.action-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.divider{border:none;border-top:1px solid var(--border);margin:20px 0}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title{font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--text)}.empty-state{text-align:center;padding:48px 24px;color:var(--text-dim)}.empty-icon{font-size:40px;margin-bottom:12px}.empty-text{font-size:14px}.loading{text-align:center;padding:48px;color:var(--text-muted)}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px}.tab-btn{padding:10px 20px;font-size:14px;font-weight:500;color:var(--text-muted);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:var(--transition);font-family:var(--font-body)}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.public-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column;align-items:center;padding:40px 16px}.public-header{text-align:center;margin-bottom:32px}.public-brand{font-family:var(--font-head);font-size:28px;font-weight:800;color:var(--text);letter-spacing:-.03em}.public-brand span{color:var(--accent)}.public-subtitle{color:var(--text-muted);font-size:14px;margin-top:6px}.public-form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;width:100%;max-width:600px;box-shadow:var(--shadow)}.login-page{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:50%;left:50%;width:800px;height:800px;transform:translate(-50%,-50%);background-image:url(/assets/logo-v4qn04EO.png);background-repeat:no-repeat;background-position:center;background-size:contain;opacity:var(--watermark-opacity);pointer-events:none}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:40px;width:100%;max-width:550px;box-shadow:var(--shadow)}.login-logo{text-align:center;margin-bottom:32px}.login-logo .brand{font-family:var(--font-head);font-size:32px;font-weight:800;letter-spacing:-.04em}.login-logo .brand span{color:var(--accent)}.login-logo .tagline{color:var(--text-dim);font-size:13px;margin-top:4px}.inline-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px;padding:12px;background:var(--bg-input);border-radius:var(--radius-sm);border:1px solid var(--border)}.inline-form .form-input{width:auto;flex:1;min-width:120px}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mb-16{margin-bottom:16px}@media (max-width: 768px){.sidebar{display:none}.main-content{margin-left:0}.form-row{grid-template-columns:1fr}.page-header{padding:20px 16px 0}.page-content{padding:0 16px 24px}}
