:root{--primary:#1a56db;--primary-dark:#1e429f;--danger:#e02424;--success:#057a55;--warning:#c27803;--bg:#f1f5f9;--surface:#fff;--border:#e5e7eb;--text:#111827;--text-muted:#6b7280;--sidebar-bg:#1e293b;--sidebar-text:#f1f5f9;--sidebar-hover:#334155;--sidebar-active:#1a56db;--sidebar-width:240px;--topbar-height:56px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--radius:6px;--radius-md:8px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}#app{height:100%}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;line-height:1;transition:background .15s,border-color .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:.25rem .625rem;font-size:.8125rem}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:#c81e1e;border-color:#c81e1e}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover:not(:disabled){background:#046c4e;border-color:#046c4e}.btn-ghost{color:var(--text);border-color:var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg)}.btn-warning{background:var(--warning);color:#fff;border-color:var(--warning)}.badge{border-radius:9999px;align-items:center;padding:.125rem .625rem;font-size:.75rem;font-weight:500;display:inline-flex}.badge-pending{color:#92400e;background:#fef3c7}.badge-approved,.badge-active,.badge-confirmed{color:#065f46;background:#d1fae5}.badge-rejected,.badge-terminated,.badge-inactive{color:#991b1b;background:#fee2e2}.badge-cancelled{color:#4b5563;background:#f3f4f6}.badge-cancellation_requested{color:#92400e;background:#fef3c7}.badge-level1_approved{color:#1e40af;background:#dbeafe}.badge-draft{color:#5b21b6;background:#ede9fe}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:1.5rem}.card-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.card-title{color:var(--text);font-size:1rem;font-weight:600}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-label{color:var(--text);font-size:.875rem;font-weight:500}.form-input,.form-select,.form-textarea{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:var(--surface);outline:none;padding:.5rem .75rem;font-family:inherit;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1a56db26}.form-textarea{resize:vertical;min-height:80px}.form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;display:flex}.table-wrapper{overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:.875rem}.table th{background:var(--bg);text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:2px solid var(--border);white-space:nowrap;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:.75rem 1rem}.table tbody tr:nth-child(2n){background:#f8fafc}.table tbody tr:hover{background:#eff6ff}.table-empty{text-align:center;color:var(--text-muted);padding:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}.w-full{width:100%}.alert{border-radius:var(--radius);margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.alert-error{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.alert-success{color:#065f46;background:#d1fae5;border:1px solid #6ee7b7}.alert-info{color:#1e40af;background:#dbeafe;border:1px solid #93c5fd}.loading{color:var(--text-muted);justify-content:center;align-items:center;padding:2rem;display:flex}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:1.25rem 1.5rem}.stat-value{color:var(--text);font-size:2rem;font-weight:700;line-height:1}.stat-label{color:var(--text-muted);margin-top:.25rem;font-size:.875rem}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.page-title{color:var(--text);font-size:1.25rem;font-weight:700}.filter-bar{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.filter-bar .form-input,.filter-bar .form-select{width:auto;min-width:160px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.sticky-tt{z-index:3;text-align:center;background:#f8fafc;border-right:1px solid #cbd5e1;width:36px;min-width:36px;position:sticky;left:0}.sticky-name{z-index:3;background:#f8fafc;border-right:2px solid #94a3b8;width:150px;min-width:150px;padding-left:.5rem;position:sticky;left:36px}thead .sticky-tt,thead .sticky-name{color:#f1f5f9;z-index:4;background:#1e293b}tfoot .sticky-tt,tfoot .sticky-name{background:#f1f5f9}
