*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f4f6f9;--surface: #ffffff;--border: #dde1e7;--primary: #2563eb;--primary-h: #1d4ed8;--danger: #dc2626;--success: #16a34a;--warn: #d97706;--muted: #6b7280;--text: #111827;--radius: 6px;--shadow: 0 1px 4px rgba(0,0,0,.08);font-family:system-ui,-apple-system,sans-serif;font-size:14px;color:var(--text);background:var(--bg)}body{min-height:100vh}#root{display:flex;flex-direction:column;min-height:100vh}.app-shell{display:flex;flex:1}nav.sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);padding:24px 12px;display:flex;flex-direction:column;gap:4px}nav.sidebar .brand{font-size:15px;font-weight:700;color:var(--primary);padding:0 8px 16px;border-bottom:1px solid var(--border);margin-bottom:8px}nav.sidebar a{display:block;padding:8px 12px;border-radius:var(--radius);color:var(--text);text-decoration:none;font-weight:500;transition:background .15s}nav.sidebar a:hover{background:var(--bg)}nav.sidebar a.active{background:#eff6ff;color:var(--primary)}main.content{flex:1;padding:28px 32px;overflow-y:auto}h1{font-size:22px;font-weight:700;margin-bottom:18px}h2{font-size:17px;font-weight:600;margin-bottom:12px}h3{font-size:14px;font-weight:600;margin-bottom:8px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);margin-bottom:16px}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.4px;text-transform:uppercase}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s;white-space:nowrap}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-h)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover:not(:disabled){background:#15803d}.btn-warn{background:var(--warn);color:#fff;border-color:var(--warn)}.btn-warn:hover:not(:disabled){background:#b45309}.btn-ghost{background:transparent;color:var(--text);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg)}.btn-sm{padding:4px 10px;font-size:12px}.form-row{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}.form-row label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.form-row input,.form-row select,.form-row textarea{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;background:var(--surface);outline:none;width:100%}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px #dbeafe}.form-row textarea{resize:vertical;min-height:72px}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--border)}th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}tr:hover td{background:#fafafa}.flex{display:flex}.flex-col{flex-direction:column}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.items-center{align-items:center}.justify-between{justify-content:space-between}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.muted{color:var(--muted);font-size:12px}.mono{font-family:ui-monospace,monospace;font-size:12px}.w-full{width:100%}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}.error-box{background:#fff1f2;border:1px solid #fecdd3;color:var(--danger);border-radius:var(--radius);padding:12px 16px;margin-bottom:16px;font-size:13px}.tree-node{margin-left:0}.tree-node-inner{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:var(--radius);cursor:pointer;transition:background .12s}.tree-node-inner:hover{background:var(--bg)}.tree-node-inner.selected{background:#eff6ff}.tree-children{padding-left:20px;border-left:2px solid var(--border);margin-left:14px}.tree-toggle{font-size:10px;color:var(--muted);width:12px;flex-shrink:0}.amount-pos{color:var(--success);font-weight:600}.amount-neg{color:var(--danger);font-weight:600}.report-row td:first-child{padding-left:calc(12px + var(--depth, 0) * 20px)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.stat-card{text-align:center}.stat-card .stat-value{font-size:26px;font-weight:700;margin:8px 0 4px}.stat-card .stat-label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.alert-indicator{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--danger);margin-right:6px;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.tag{display:inline-block;padding:2px 8px;background:#f3f4f6;border-radius:4px;font-size:12px;margin:2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}.modal{background:var(--surface);border-radius:var(--radius);padding:28px 32px;width:520px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000038}.modal h2{margin-bottom:18px;font-size:18px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.toast-container{position:fixed;top:20px;right:20px;z-index:999;display:flex;flex-direction:column;gap:8px;max-width:360px}.toast{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:var(--radius);box-shadow:0 4px 16px #00000024;font-size:13px;font-weight:500;animation:slideIn .2s ease}.toast-success{background:#166534;color:#fff}.toast-error{background:#991b1b;color:#fff}.toast-info{background:#1d4ed8;color:#fff}.toast-dismiss{background:none;border:none;color:#ffffffbf;cursor:pointer;padding:0;margin-left:auto;font-size:16px;line-height:1}.toast-dismiss:hover{color:#fff}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.confirm-modal{max-width:400px}.confirm-modal p{color:var(--muted);font-size:13px;margin-top:6px}.badge-risk-LOW{background:#dcfce7;color:#15803d}.badge-risk-MEDIUM{background:#fef9c3;color:#92400e}.badge-risk-HIGH{background:#fee2e2;color:#991b1b}.badge-PROPOSED{background:#f3f4f6;color:#374151}.badge-PENDING_APPROVAL{background:#ede9fe;color:#5b21b6}.badge-IN_PROGRESS{background:#dbeafe;color:#1d4ed8}.badge-SUSPENDED{background:#fef9c3;color:#92400e}.badge-COMPLETED{background:#dcfce7;color:#15803d}.badge-REOPENED{background:#e0f2fe;color:#0369a1}.badge-ABANDONED{background:#fee2e2;color:#991b1b}.field-error{font-size:11px;color:var(--danger);margin-top:3px}input.invalid,select.invalid,textarea.invalid{border-color:var(--danger)!important}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{color:var(--text)}th.sortable .sort-arrow{margin-left:4px;opacity:.4}th.sortable.active .sort-arrow{opacity:1;color:var(--primary)}.diff-table td:first-child{font-weight:600;width:120px;color:var(--muted)}.diff-table td.changed{color:var(--primary);font-weight:600}.transition-btns{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}.btn-submit-approval{background:#7c3aed;color:#fff;border-color:#7c3aed}.btn-submit-approval:hover:not(:disabled){background:#6d28d9}.btn-approve{background:#16a34a;color:#fff;border-color:#16a34a}.btn-approve:hover:not(:disabled){background:#15803d}.btn-reject{background:#dc2626;color:#fff;border-color:#dc2626}.btn-reject:hover:not(:disabled){background:#b91c1c}.btn-reopen{background:#0891b2;color:#fff;border-color:#0891b2}.btn-reopen:hover:not(:disabled){background:#0e7490}.btn-complete{background:#16a34a;color:#fff;border-color:#16a34a}.btn-complete:hover:not(:disabled){background:#15803d}.btn-suspend{background:#d97706;color:#fff;border-color:#d97706}.btn-suspend:hover:not(:disabled){background:#b45309}.btn-resume{background:#0891b2;color:#fff;border-color:#0891b2}.btn-resume:hover:not(:disabled){background:#0e7490}.btn-abandon{background:#dc2626;color:#fff;border-color:#dc2626}.btn-abandon:hover:not(:disabled){background:#b91c1c}.section-header{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:20px 0 10px}.section-divider{border:none;border-top:1px solid var(--border);margin:20px 0}.step-block{border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:10px;background:var(--bg)}.step-block-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.report-pre{font-family:ui-monospace,monospace;font-size:12.5px;background:#0f172a;color:#e2e8f0;border-radius:var(--radius);padding:20px;overflow-x:auto;white-space:pre;line-height:1.7;margin-top:16px}.page-section{margin-top:28px}.inline-form{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}.text-right{text-align:right}.balance-display{font-size:22px;font-weight:700}.over-consumed{color:var(--danger)}
