@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand-50:#eef6ff;--brand-100:#d8eaff;--brand-200:#aed3ff;--brand-300:#79b4fb;--brand-400:#4596f4;--brand-500:#1c7fe6;--brand-600:#1467c2;--brand-700:#0f4f9c;--brand-900:#0b2f5e;--navy-700:#133a66;--navy-900:#0d2747;--success:#10b981;--success-50:#ecfdf5;--success-100:#d1fae5;--success-700:#047857;--warning:#f59e0b;--warning-50:#fffbeb;--warning-100:#fef3c7;--warning-700:#b45309;--danger:#ef4444;--danger-50:#fef2f2;--danger-100:#fee2e2;--danger-700:#b91c1c;--info:#06b6d4;--info-50:#ecfeff;--info-100:#cffafe;--purple:#8b5cf6;--purple-50:#f5f3ff;--purple-100:#ede9fe;--white:#fff;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--bg:#f4f6f9;--surface:var(--white);--surface-2:var(--gray-50);--border:var(--gray-200);--border-2:var(--gray-300);--text:var(--gray-900);--text-2:var(--gray-600);--text-3:var(--gray-400);--accent:var(--brand-500);--sidebar-bg:#0d2747;--sidebar-w:256px;--topbar-h:64px;--r-xs:4px;--r-sm:6px;--r:10px;--r-lg:14px;--r-xl:20px;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow:0 4px 6px -1px #00000012, 0 2px 4px -1px #0000000d;--shadow-md:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000a;--shadow-lg:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--shadow-xl:0 25px 50px -12px #00000040}html{font-size:14px}body{color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}button,input,textarea,select{font-family:inherit}.app-shell{background:var(--bg);height:100vh;display:flex;overflow:hidden}.main-area{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.page-content{flex:1;padding:28px 32px;overflow-y:auto}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);scrollbar-width:none;border-right:1px solid #ffffff0a;flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.sidebar::-webkit-scrollbar{display:none}.sidebar-logo{border-bottom:1px solid #ffffff0f;padding:22px 18px 18px}.logo-mark{align-items:center;gap:11px;display:flex}.logo-icon{background:linear-gradient(135deg, var(--brand-500), var(--brand-700));color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;font-weight:800;display:flex;box-shadow:0 4px 12px #3b82f666}.logo-text .app-name{color:#f1f5f9;letter-spacing:-.2px;font-size:15px;font-weight:800}.logo-text .app-sub{color:var(--gray-500);margin-top:1px;font-size:11px}.sidebar-section{padding:20px 12px 8px}.sidebar-section-label{color:var(--gray-600);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:4px;padding:0 8px;font-size:10px;font-weight:700}.sidebar-nav{flex-direction:column;gap:1px;list-style:none;display:flex}.sidebar-nav li a{border-radius:var(--r-sm);color:var(--gray-400);align-items:center;gap:10px;padding:9px 12px;font-size:13.5px;font-weight:500;transition:all .15s;display:flex;position:relative}.sidebar-nav li a:hover{color:#e2e8f0;background:#ffffff0f}.sidebar-nav li a.active{color:#93c5fd;background:#3b82f626}.sidebar-nav li a.active .nav-icon{color:#60a5fa}.nav-icon{opacity:.8;flex-shrink:0;width:18px;height:18px}.sidebar-nav li a.active .nav-icon{opacity:1}.nav-badge{background:var(--danger);color:#fff;text-align:center;border-radius:999px;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.sidebar-footer{border-top:1px solid #ffffff0f;margin-top:auto;padding:12px}.sidebar-user{border-radius:var(--r-sm);cursor:pointer;background:#ffffff0a;align-items:center;gap:10px;padding:10px;transition:background .15s;display:flex}.sidebar-user:hover{background:#ffffff14}.sidebar-user-info .name{color:#e2e8f0;font-size:12.5px;font-weight:600}.sidebar-user-info .role{color:var(--gray-500);font-size:11px}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-xs);flex-shrink:0;align-items:center;gap:16px;padding:0 32px;display:flex}.topbar-left{flex:1;min-width:0}.topbar-title{color:var(--text);letter-spacing:-.3px;font-size:18px;font-weight:700;line-height:1.2}.topbar-subtitle{color:var(--text-3);margin-top:1px;font-size:12px;font-weight:400}.topbar-right{align-items:center;gap:8px;display:flex}.icon-btn{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text-2);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex;position:relative}.icon-btn:hover{background:var(--gray-100);color:var(--text);border-color:var(--border-2)}.icon-btn svg{width:16px;height:16px}.notif-dot{background:var(--danger);border:2px solid var(--surface);border-radius:50%;width:7px;height:7px;position:absolute;top:7px;right:7px}.avatar{background:linear-gradient(135deg, var(--brand-500), var(--purple));color:#fff;cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:700;display:flex;box-shadow:0 2px 8px #3b82f64d}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}@media (width<=1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);align-items:flex-start;gap:18px;padding:22px 24px;transition:box-shadow .2s,transform .2s;display:flex;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-card:before{content:"";background:linear-gradient(90deg, var(--kpi-color,var(--brand-500)), transparent);border-radius:var(--r-lg) var(--r-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.kpi-card.blue{--kpi-color:var(--brand-500)}.kpi-card.green{--kpi-color:var(--success)}.kpi-card.red{--kpi-color:var(--danger)}.kpi-card.amber{--kpi-color:var(--warning)}.kpi-icon-wrap{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.kpi-icon-wrap svg{width:22px;height:22px}.kpi-icon-wrap.blue{background:var(--brand-100);color:var(--brand-600)}.kpi-icon-wrap.green{background:var(--success-100);color:var(--success-700)}.kpi-icon-wrap.red{background:var(--danger-100);color:var(--danger-700)}.kpi-icon-wrap.amber{background:var(--warning-100);color:var(--warning-700)}.kpi-body{flex:1;min-width:0}.kpi-value{color:var(--text);letter-spacing:-.5px;font-size:30px;font-weight:800;line-height:1}.kpi-label{color:var(--text-2);margin-top:5px;font-size:12.5px;font-weight:500}.card{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.card-title{color:var(--text);font-size:15px;font-weight:700}.card-subtitle{color:var(--text-3);margin-top:2px;font-size:12px}.card-body{padding:20px 24px}.btn{border-radius:var(--r-sm);cursor:pointer;white-space:nowrap;letter-spacing:-.1px;border:none;justify-content:center;align-items:center;gap:7px;padding:9px 18px;font-family:inherit;font-size:13.5px;font-weight:600;line-height:1;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn svg{flex-shrink:0;width:15px;height:15px}.btn-primary{background:linear-gradient(135deg, var(--brand-500), var(--brand-700));color:#fff;box-shadow:0 2px 8px #3b82f659}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--brand-600), var(--brand-700));transform:translateY(-1px);box-shadow:0 4px 14px #3b82f673}.btn-secondary{background:var(--surface);color:var(--text-2);border:1.5px solid var(--border);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);color:var(--text);border-color:var(--border-2);box-shadow:var(--shadow-sm)}.btn-ghost{color:var(--text-2);background:0 0;border:1.5px solid #0000}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--text);border-color:var(--border)}.btn-success{background:linear-gradient(135deg, var(--success), var(--success-700));color:#fff;box-shadow:0 2px 8px #10b98159}.btn-success:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #10b98173}.btn-danger{background:linear-gradient(135deg, var(--danger), var(--danger-700));color:#fff;box-shadow:0 2px 8px #ef444459}.btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #ef444473}.btn-warning{background:linear-gradient(135deg, var(--warning), var(--warning-700));color:#fff}.btn-sm{border-radius:var(--r-xs);padding:6px 13px;font-size:12.5px}.btn-lg{border-radius:var(--r-sm);padding:13px 26px;font-size:15px}.btn-xl{border-radius:var(--r);padding:16px 32px;font-size:16px}.btn-icon-only{border-radius:var(--r-sm);justify-content:center;align-items:center;width:34px;height:34px;padding:0;display:inline-flex}.form-group{flex-direction:column;gap:5px;display:flex}.form-group label{color:var(--gray-600);letter-spacing:.1px;font-size:12.5px;font-weight:600}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-input,.form-select,.form-textarea{border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text);background:var(--surface);outline:none;padding:9px 13px;font-family:inherit;font-size:13.5px;line-height:1.5;transition:border-color .15s,box-shadow .15s}.form-input:hover,.form-select:hover{border-color:var(--border-2)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61f}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-3)}.form-select{cursor:pointer}textarea.form-input,.form-textarea{resize:vertical;min-height:88px}.form-hint{color:var(--text-3);margin-top:3px;font-size:11.5px}.form-error{color:var(--danger);margin-top:3px;font-size:11.5px}.toggle{flex-shrink:0;width:42px;height:24px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{cursor:pointer;background:var(--gray-300);border-radius:999px;transition:background .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0003}.toggle input:checked+.toggle-slider{background:var(--success)}.toggle input:checked+.toggle-slider:before{transform:translate(18px)}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table thead th{background:var(--gray-50);color:var(--gray-500);text-transform:uppercase;letter-spacing:.6px;border-bottom:2px solid var(--border);text-align:left;white-space:nowrap;padding:11px 16px;font-size:11px;font-weight:600}.data-table tbody td{border-bottom:1px solid var(--gray-100);color:var(--text);vertical-align:middle;padding:13px 16px}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background .1s}.data-table tbody tr:hover td{background:var(--gray-50)}.badge{text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;background:var(--gray-100);color:var(--gray-600);border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge svg{width:10px;height:10px}.badge-success{background:var(--success-100);color:var(--success-700)}.badge-danger{background:var(--danger-100);color:var(--danger-700)}.badge-warning{background:var(--warning-100);color:var(--warning-700)}.badge-info{background:var(--info-100);color:#0e7490}.badge-purple{background:var(--purple-100);color:#6d28d9}.badge-primary{background:var(--brand-100);color:var(--brand-700)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a99;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)scale(.98)}to{opacity:1;transform:none}}.modal{background:var(--surface);border-radius:var(--r-xl);width:100%;max-height:88vh;box-shadow:var(--shadow-xl);border:1px solid var(--border);animation:.2s cubic-bezier(.16,1,.3,1) slideUp;overflow-y:auto}.modal-sm{max-width:440px}.modal-md{max-width:560px}.modal-lg{max-width:740px}.modal-xl{max-width:940px}.modal-header{border-bottom:1px solid var(--border);background:var(--surface);z-index:1;justify-content:space-between;align-items:flex-start;padding:24px 28px 20px;display:flex;position:sticky;top:0}.modal-header h2{color:var(--text);letter-spacing:-.2px;font-size:17px;font-weight:700}.modal-header p{color:var(--text-2);margin-top:3px;font-size:13px}.modal-close{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--gray-50);cursor:pointer;width:32px;height:32px;color:var(--text-2);flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.modal-close:hover{background:var(--gray-100);color:var(--text);border-color:var(--border-2)}.modal-close svg{width:14px;height:14px}.modal-body{flex-direction:column;gap:18px;padding:24px 28px;display:flex}.modal-footer{border-top:1px solid var(--border);background:var(--surface);justify-content:flex-end;gap:10px;padding:16px 28px 24px;display:flex;position:sticky;bottom:0}.accordion-item{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);transition:box-shadow .2s;overflow:hidden}.accordion-item:hover{box-shadow:var(--shadow-sm)}.accordion-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:16px 20px;transition:background .15s;display:flex}.accordion-header:hover{background:var(--gray-50)}.accordion-toggle{justify-content:space-between;align-items:center;gap:12px;width:100%;display:flex}.accordion-chevron{color:var(--text-3);flex-shrink:0;align-items:center;font-size:11px;transition:transform .2s;display:flex}.accordion-chevron svg{width:14px;height:14px}.accordion-body{border-top:1px solid var(--border);background:var(--gray-50);padding:18px 20px}.role-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);flex-direction:column;gap:14px;padding:20px;transition:box-shadow .2s,transform .2s;display:flex}.role-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.role-card-header{align-items:center;gap:12px;display:flex}.role-avatar{background:linear-gradient(135deg, var(--brand-500), var(--purple));color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:15px;font-weight:800;display:flex;box-shadow:0 4px 10px #3b82f64d}.role-info .role-name{color:var(--text);font-size:14px;font-weight:700}.role-info .role-code{color:var(--text-3);margin-top:2px;font-family:Consolas,monospace;font-size:11px}.role-desc{color:var(--text-2);font-size:12.5px;line-height:1.6}.role-stats{justify-content:space-between;align-items:center;display:flex}.role-actions{gap:8px;display:flex}.page-loading{min-height:320px;color:var(--text-3);flex-direction:column;justify-content:center;align-items:center;gap:14px;font-size:13.5px;display:flex}.page-loading .spinner{margin:0}.empty-state{text-align:center;flex-direction:column;align-items:center;padding:56px 24px;display:flex}.empty-icon{margin-bottom:14px;font-size:44px}.empty-icon svg{width:52px;height:52px;color:var(--gray-300)}.empty-title{color:var(--text);margin-bottom:6px;font-size:16px;font-weight:700}.empty-body{color:var(--text-2);max-width:340px;font-size:13px;line-height:1.6}.alert{border-radius:var(--r-sm);align-items:center;gap:10px;padding:12px 16px;font-size:13px;display:flex}.alert svg{flex-shrink:0;width:16px;height:16px}.alert-danger{background:var(--danger-50);color:var(--danger-700);border:1px solid #fca5a5}.alert-warning{background:var(--warning-50);color:var(--warning-700);border:1px solid #fcd34d}.alert-success{background:var(--success-50);color:var(--success-700);border:1px solid #6ee7b7}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:36px;height:36px;animation:.65s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.approve-shell{background:var(--gray-100);min-height:100vh;display:flex}.approve-doc-panel{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex:1;min-width:0;display:flex}.approve-doc-header{background:var(--gray-900);border-bottom:1px solid #ffffff1a;flex-shrink:0;align-items:center;gap:20px;padding:22px 32px;display:flex}.doc-type-badge{color:#fff;letter-spacing:.5px;background:#ffffff1f;border:1.5px solid #fff3;border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:15px;font-weight:800;display:flex}.doc-no{color:#f1f5f9;letter-spacing:-.3px;font-size:20px;font-weight:800}.doc-sub{color:var(--gray-400);margin-top:3px;font-size:12px}.doc-amount{color:#f1f5f9;letter-spacing:-.3px;font-size:22px;font-weight:800}.approve-doc-body{flex:1;padding:28px 32px;overflow-y:auto}.print-hdr-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}@media (width<=800px){.print-hdr-grid{grid-template-columns:1fr 1fr}}.print-hdr-field{background:var(--gray-50);border:1px solid var(--border);border-radius:var(--r-sm);padding:11px 13px}.print-hdr-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:4px;font-size:10px;font-weight:700;display:block}.print-hdr-value{color:var(--text);font-size:13.5px;font-weight:500;display:block}.approve-decision-panel{background:var(--surface);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:390px;display:flex}@media (width<=900px){.approve-shell{flex-direction:column}.approve-decision-panel{width:100%}}.decision-header{background:var(--gray-50);border-bottom:1px solid var(--border);padding:26px 26px 22px}.decision-step-label{text-transform:uppercase;letter-spacing:.8px;color:var(--text-3);margin-bottom:5px;font-size:10.5px;font-weight:700}.decision-step-name{color:var(--text);letter-spacing:-.3px;font-size:18px;font-weight:800}.decision-body{flex-direction:column;flex:1;gap:20px;padding:24px 26px;display:flex}.decision-options{grid-template-columns:1fr 1fr 1fr;gap:10px;display:grid}.decision-opt{border-radius:var(--r);border:2px solid var(--border);background:var(--gray-50);cursor:pointer;color:var(--text-2);flex-direction:column;align-items:center;gap:8px;padding:14px 8px;font-size:12.5px;font-weight:700;line-height:1;transition:all .15s;display:flex}.decision-opt:hover{transform:translateY(-2px)}.decision-opt-icon{justify-content:center;align-items:center;width:24px;height:24px;display:flex}.decision-opt-icon svg{width:22px;height:22px}.decision-opt-approve:hover,.decision-opt-approve.selected{background:var(--success-50);border-color:var(--success);color:var(--success-700);box-shadow:0 2px 12px #10b98140}.decision-opt-reject:hover,.decision-opt-reject.selected{background:var(--danger-50);border-color:var(--danger);color:var(--danger-700);box-shadow:0 2px 12px #ef444440}.decision-opt-return:hover,.decision-opt-return.selected{background:var(--warning-50);border-color:var(--warning);color:var(--warning-700);box-shadow:0 2px 12px #f59e0b40}.decision-info{background:var(--gray-50);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-2);flex-direction:column;gap:6px;padding:14px 16px;font-size:12.5px;display:flex}.decision-info strong{color:var(--text);font-weight:600}.decision-submit{border-radius:var(--r);justify-content:center;width:100%;padding:14px 24px;font-size:15px}.decision-submit-approve{background:linear-gradient(135deg, var(--success), var(--success-700));color:#fff;box-shadow:0 4px 14px #10b98166}.decision-submit-approve:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #10b98180}.decision-submit-reject{background:linear-gradient(135deg, var(--danger), var(--danger-700));color:#fff;box-shadow:0 4px 14px #ef444466}.decision-submit-reject:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #ef444480}.decision-submit-return{background:linear-gradient(135deg, var(--warning), var(--warning-700));color:#fff;box-shadow:0 4px 14px #f59e0b59}.decision-submit-return:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #f59e0b73}.approve-loading,.approve-invalid,.approve-result{background:var(--gray-100);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;min-height:100vh;padding:40px;display:flex}.approve-loading{color:var(--text-3);font-size:14px}.invalid-icon,.result-icon{font-size:60px}.invalid-icon svg,.result-icon svg{width:64px;height:64px}.invalid-title,.result-title{color:var(--text);letter-spacing:-.4px;font-size:24px;font-weight:800}.invalid-body,.result-body{color:var(--text-2);max-width:360px;font-size:14px;line-height:1.7}.divider{background:var(--border);height:1px;margin:16px 0}.font-mono{font-family:Consolas,Monaco,monospace}.text-muted{color:var(--text-3)}.text-sm{font-size:12px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}
