:root{--bg: #0f1419;--surface: #1a2332;--surface-hover: #243044;--border: #2d3a4d;--text: #e6edf3;--text-muted: #8b9cb3;--accent: #3b82f6;--accent-hover: #2563eb;--success: #22c55e;--warning: #eab308;--danger: #ef4444;--radius: 10px;--font: "DM Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace}*{box-sizing:border-box}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}.app{display:flex;flex-direction:column;min-height:100vh}.layout{display:flex;flex:1}.sidebar{width:240px;background:var(--surface);border-right:1px solid var(--border);padding:1.5rem 0}.sidebar a{display:block;padding:.6rem 1.5rem;color:var(--text-muted);text-decoration:none}.sidebar a:hover,.sidebar a.active{color:var(--text);background:var(--surface-hover)}.sidebar a.active{border-left:3px solid var(--accent);padding-left:calc(1.5rem - 3px)}.main{flex:1;padding:2rem;overflow:auto}.page-title{font-size:1.5rem;font-weight:600;margin:0 0 1.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;border-radius:var(--radius);border:none;font-weight:500;font-size:.9rem;transition:background .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface-hover);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{color:var(--text)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.35rem;font-size:.875rem;color:var(--text-muted)}.form-group input,.form-group select,.form-group textarea{width:100%;max-width:320px;padding:.6rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.75rem 1rem;border-bottom:1px solid var(--border)}th{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}tr:hover td{background:var(--surface-hover)}.badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:500}.badge-pending{background:#eab30833;color:var(--warning)}.badge-pending_accounting{background:#3b82f633;color:var(--info, #2563eb)}.badge-approved{background:#22c55e33;color:var(--success)}.badge-rejected{background:#ef444433;color:var(--danger)}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:var(--surface);border-bottom:1px solid var(--border)}.header h1{margin:0;font-size:1.25rem;font-weight:600}.user-menu{display:flex;align-items:center;gap:1rem;color:var(--text-muted);font-size:.875rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-box{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem}.login-box h1{margin:0 0 1.5rem;font-size:1.5rem}.login-box .form-group input{max-width:none}.login-box .btn{width:100%;justify-content:center;margin-top:.5rem}.error-msg{color:var(--danger);font-size:.875rem;margin-top:.5rem}
