@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Be+Vietnam+Pro:wght@400;500;600;700&display=swap";:root{--navy:#1e2a4a;--navy-deep:#161d33;--accent:#7c3aed;--accent-hover:#6d28d9;--accent-light:#a78bfa;--accent-soft:#f4f0fe;--accent-border:#e0d4fb;--accent-glow:#7c3aed47;--blue-accent:var(--accent);--blue-light:var(--accent-light);--green:#1e8c45;--green-soft:#e8f9ee;--orange:#e8840f;--red:#d72134;--border:#e7eaf1;--border-soft:#eef1f6;--bg:#f5f6fa;--white:#fff;--text-primary:#161c2d;--text-secondary:#4a5568;--text-muted:#8b95a5;--shadow-sm:0 1px 2px #1018280d, 0 1px 3px #1018280a;--shadow-md:0 6px 20px #10182814;--shadow-lg:0 16px 40px #10182821;--radius-lg:16px;--radius:12px;--radius-sm:8px}body{background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Be Vietnam Pro,sans-serif}::selection{background:var(--accent-soft);color:var(--accent-hover)}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#d3d8e3;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#bcc3d1}.app-sider{z-index:10;position:relative;box-shadow:2px 0 12px #1018280f}.app-logo{cursor:pointer;border-bottom:1px solid #ffffff12;align-items:center;gap:11px;height:60px;padding:0 18px;display:flex}.app-logo-mark{color:#fff;background:linear-gradient(135deg,#7c3aed 0%,#ec4899 100%);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:700;display:inline-flex;box-shadow:0 4px 12px #7c3aed66}.app-logo-text{color:#fff;flex-direction:column;font-family:Space Grotesk,sans-serif;font-size:16px;font-weight:700;line-height:1.15;display:flex}.app-logo-text small{letter-spacing:1px;text-transform:uppercase;color:#ffffff6b;font-family:Be Vietnam Pro,sans-serif;font-size:10px;font-weight:500}.app-menu-section{color:#ffffff61;letter-spacing:1.2px;text-transform:uppercase;margin-top:6px;padding:0 24px 6px;font-size:10.5px;font-weight:600}.app-menu.ant-menu{font-size:13.5px}.app-menu .ant-menu-item{height:40px;line-height:40px;border-radius:10px!important;width:auto!important;margin:2px 12px!important}.app-menu .ant-menu-item .ant-menu-title-content{flex:1;min-width:0;font-weight:500;overflow:visible}.app-menu .ant-menu-item-selected{box-shadow:0 6px 14px #7c3aed59}.app-menu .ant-menu-item-selected .ant-menu-title-content,.app-menu .ant-menu-item-selected .anticon{color:#fff!important}.app-header{border-bottom:1px solid var(--border-soft);z-index:9;justify-content:space-between;align-items:center;height:60px;padding:0 20px 0 8px;display:flex;position:sticky;top:0;box-shadow:0 1px 3px #1018280a}.app-header-toggle.ant-btn{color:var(--text-secondary);font-size:17px}.app-user-chip{cursor:pointer;border-radius:30px;align-items:center;gap:10px;padding:5px 12px 5px 6px;transition:background .15s;display:flex}.app-user-chip:hover{background:var(--accent-soft)}.app-user-meta{flex-direction:column;max-width:180px;line-height:1.2;display:flex}.app-user-name{color:var(--text-primary);text-transform:capitalize;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.app-user-sub{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.app-content{background:var(--bg);height:calc(100vh - 60px);overflow:auto}.app-content-inner{max-width:1240px;margin:0 auto;padding:26px 28px 40px}@media (width<=640px){.app-content-inner{padding:18px 14px 32px}.app-user-meta{display:none}}.login-shell{background:#fff;grid-template-columns:1fr 1.1fr;min-height:100vh;display:grid}.login-form-side{justify-content:center;align-items:center;padding:40px 32px;display:flex}.login-form-box{width:100%;max-width:380px}.login-logo{align-items:center;gap:10px;margin-bottom:44px;display:inline-flex}.login-logo-mark{color:#fff;background:linear-gradient(135deg,#7c3aed 0%,#ec4899 100%);border-radius:11px;justify-content:center;align-items:center;width:40px;height:40px;font-family:Space Grotesk,sans-serif;font-size:15px;font-weight:700;display:inline-flex;box-shadow:0 6px 16px #7c3aed52}.login-logo-text{color:#1a1f36;font-family:Space Grotesk,sans-serif;font-size:17px;font-weight:700}.login-form-heading{color:#1a1f36;letter-spacing:-.3px;margin-bottom:8px;font-family:Space Grotesk,sans-serif;font-size:30px;font-weight:700}.login-form-subheading{color:#8b95a5;margin-bottom:32px;font-size:14px}.login-field-label{color:#4a5568;margin-bottom:7px;font-size:13px;font-weight:600;display:block}.login-row-between{justify-content:space-between;align-items:center;margin-bottom:22px;display:flex}.login-submit.ant-btn{background:linear-gradient(135deg,#7c3aed 0%,#8b5cf6 50%,#ec4899 100%) 0 0/150% 150%;border:none;border-radius:12px;height:48px;font-size:15px;font-weight:600;transition:background-position .4s,transform .1s,box-shadow .2s;box-shadow:0 8px 20px #7c3aed4d}.login-submit.ant-btn:hover{background-position:100% 100%;box-shadow:0 10px 26px #7c3aed66}.login-submit.ant-btn:active{transform:translateY(1px)}.login-brand{color:#fff;background:linear-gradient(140deg,#6d28d9 0%,#8b5cf6 42%,#ec4899 100%);border-radius:28px;flex-direction:column;justify-content:space-between;margin:16px;padding:56px 52px;display:flex;position:relative;overflow:hidden}.login-brand:before,.login-brand:after{content:"";pointer-events:none;border-radius:50%;position:absolute}.login-brand:before{background:radial-gradient(circle,#ffffff38 0%,#0000 68%);width:320px;height:320px;top:-90px;right:-70px}.login-brand:after{background:radial-gradient(circle,#ec489973 0%,#0000 68%);width:260px;height:260px;bottom:-70px;left:-50px}.login-ring{pointer-events:none;border:2px solid #ffffff2e;border-radius:50%;position:absolute}.login-ring.r1{width:130px;height:130px;top:18%;left:-40px}.login-ring.r2{border-color:#ffffff40;width:70px;height:70px;bottom:26%;right:12%}.login-brand-top{z-index:1;position:relative}.login-brand-emoji{margin-bottom:20px;font-size:30px}.login-brand-title{max-width:420px;margin-bottom:16px;font-family:Space Grotesk,sans-serif;font-size:32px;font-weight:700;line-height:1.2}.login-brand-sub{color:#ffffffd1;max-width:380px;font-size:15px;line-height:1.65}.login-quote-card{z-index:1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff24;border:1px solid #ffffff38;border-radius:18px;margin-top:36px;padding:22px 24px;position:relative}.login-quote-text{margin-bottom:16px;font-size:15px;line-height:1.6}.login-quote-author{align-items:center;gap:12px;display:flex}.login-quote-avatar{color:#7c3aed;background:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:700;display:inline-flex}.login-quote-name{font-size:13px;font-weight:600}.login-quote-role{color:#ffffffa6;font-size:12px}.login-brand-footer{z-index:1;color:#fff9;font-size:12px;position:relative}.login-mobile-logo{display:none}@media (width<=880px){.login-shell{grid-template-columns:1fr}.login-brand{display:none}.login-form-side{min-height:100vh;padding:36px 22px}}.skel{background:linear-gradient(90deg,#eef1f6 25%,#e2e7f0 37%,#eef1f6 63%) 0 0/400% 100%;border-radius:6px;animation:1.4s infinite skel-shimmer}@keyframes skel-shimmer{0%{background-position:100%}to{background-position:0}}@media (prefers-reduced-motion:reduce){.skel{animation:none}}.status-pill{white-space:nowrap;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.sp-pending{color:#c07a00;background:#fff4e0}.sp-approved{background:var(--green-soft);color:var(--green)}.sp-rejected{color:var(--red);background:#fde8ea}.sp-informed{color:var(--text-secondary);background:#f0f2f5}.sp-default{color:var(--text-muted);background:#f0f2f5}.org-badge{letter-spacing:.5px;white-space:nowrap;border-radius:6px;flex-shrink:0;align-self:flex-start;margin-top:2px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.org-vlc{color:#1d4ed8;background:#dbeafe}.org-vlu{color:#065f46;background:#d1fae5}.org-betu{color:#5b21b6;background:#ede9fe}.org-default{color:var(--text-muted);background:#f0f2f5}.page-heading{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.page-title{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:20px;font-weight:700}.status-tabs{border-bottom:2px solid var(--border);gap:4px;margin-bottom:12px;padding-bottom:0;display:flex}.status-tab{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:2px solid #0000;border-radius:4px 4px 0 0;align-items:center;gap:6px;margin-bottom:-2px;padding:8px 14px;font-size:13px;font-weight:500;transition:color .15s,border-color .15s;display:flex}.status-tab:hover{color:var(--blue-accent)}.status-tab.active{color:var(--blue-accent);border-bottom-color:var(--blue-accent);font-weight:600}.tab-count{background:var(--orange);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.pr-list{flex-direction:column;gap:8px;display:flex}.pr-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;box-shadow:var(--shadow-sm);grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:12px 14px;transition:box-shadow .15s,border-color .15s;display:grid}.pr-card:hover{box-shadow:var(--shadow-md);border-color:#c5d3e8}.pr-card-body{min-width:0}.pr-card-top{flex-wrap:wrap;align-items:baseline;gap:10px;margin-bottom:3px;display:flex}.pr-code{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:600}.pr-date{color:var(--text-muted);font-size:11px}.pr-dept{color:var(--text-secondary);margin-bottom:1px;font-size:12px}.pr-memo{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.pr-amount{color:var(--blue-accent);margin-top:3px;font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:600}.pr-card-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.detail-header-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px 24px}.detail-header-top{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.detail-pr-id{color:var(--text-primary);margin-bottom:4px;font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700}.detail-pr-date{color:var(--text-secondary);font-size:13px}.detail-info-grid{border-top:1px solid var(--border);grid-template-columns:repeat(3,1fr);gap:12px 24px;padding-top:16px;display:grid}@media (width<=640px){.detail-info-grid{grid-template-columns:1fr}}.detail-info-item{flex-direction:column;gap:2px;display:flex}.detail-info-item label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:600}.detail-info-item .val{color:var(--text-primary);font-size:13px;font-weight:500}.detail-info-item .val-amount{color:var(--blue-accent);font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:700}.detail-info-item .val-link{color:var(--blue-accent);font-size:13px;text-decoration:none}.detail-info-item .val-link:hover{text-decoration:underline}.detail-tabs-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.detail-tab-bar{border-bottom:2px solid var(--border);gap:0;padding:0 20px;display:flex}.detail-tab-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:12px 16px;font-family:Be Vietnam Pro,sans-serif;font-size:13px;font-weight:500;transition:color .15s,border-color .15s}.detail-tab-btn:hover{color:var(--blue-accent)}.detail-tab-btn.active{color:var(--blue-accent);border-bottom-color:var(--blue-accent);font-weight:600}.detail-tab-body{padding:20px 24px}.info-rows{flex-direction:column;gap:0;display:flex}.info-row{border-bottom:1px solid var(--border);align-items:baseline;gap:12px;padding:8px 0;display:flex}.info-row:last-child{border-bottom:none}.info-label{width:150px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;font-size:12px;font-weight:600}.info-value{color:var(--text-primary);flex:1;font-size:13px}.info-value-amount{color:var(--blue-accent);font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:700}.info-value-link{color:var(--blue-accent);font-size:13px;text-decoration:none}.info-value-link:hover{text-decoration:underline}.doc-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;margin:12px 0 6px;font-size:11px;font-weight:700;display:block}.doc-section-label:first-child{margin-top:0}.doc-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;justify-content:space-between;align-items:center;margin-bottom:6px;padding:7px 12px;transition:background .12s,border-color .12s;display:flex}.doc-item:hover{background:#edf2fb;border-color:#c5d3e8}.doc-item.no-nav{cursor:default}.doc-item.no-nav:hover{background:var(--bg);border-color:var(--border)}.doc-item-name{color:var(--blue-accent);font-size:13px;font-weight:500}.doc-item-amount{color:var(--blue-accent);flex-shrink:0;font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:600}.hist-timeline{flex-direction:column;gap:0;padding-left:8px;display:flex}.hist-item{align-items:flex-start;gap:16px;padding-bottom:20px;display:flex;position:relative}.hist-item:before{content:"";background:var(--border);width:2px;position:absolute;top:16px;bottom:0;left:7px}.hist-item:last-child:before{display:none}.hist-dot{width:16px;height:16px;box-shadow:0 0 0 2px var(--border);background:var(--text-muted);z-index:1;border:2px solid #fff;border-radius:50%;flex-shrink:0;margin-top:2px}.hist-dot.approved{background:var(--green);box-shadow:0 0 0 2px #b7e8cb}.hist-dot.rejected{background:var(--red);box-shadow:0 0 0 2px #f5b8be}.hist-dot.pending{background:var(--orange);box-shadow:0 0 0 2px #fde8c0}.hist-header{flex:1;justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.hist-role{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:2px;font-size:11px}.hist-person{color:var(--text-primary);margin-bottom:4px;font-size:13px;font-weight:600}.hist-date{color:var(--text-muted);white-space:nowrap;flex-shrink:0;margin-top:2px;font-size:12px}.hist-status{margin-bottom:4px}.hist-note{color:var(--text-secondary);margin-top:4px;font-size:12px;font-style:italic}.history-empty{color:var(--text-muted);padding:8px 0;font-size:13px}.action-bar-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px 20px}.list-page{flex-direction:column;gap:14px;display:flex}.list-banner{background:var(--white);border:1px solid var(--border);border-left:4px solid var(--blue-accent);border-radius:var(--radius);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.list-banner-left{flex-direction:column;gap:3px;display:flex}.list-banner-title{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700}.list-banner-sub{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.list-banner-right{align-items:center;gap:12px;display:flex}.list-stat-wrap{background:#fff4e0;border-radius:10px;align-items:center;gap:8px;padding:8px 14px;display:flex}.list-stat-num{font-family:Space Grotesk,sans-serif;font-size:26px;font-weight:700;line-height:1}.list-stat-label{color:var(--text-muted);font-size:11px;line-height:1.4}.list-search-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.adv-filter-panel{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 20px}.adv-filter-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px 16px;margin-bottom:14px;display:grid}.adv-filter-field{flex-direction:column;gap:5px;display:flex}.adv-filter-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:600}.adv-date-input{height:32px;color:var(--text-primary);background:var(--white);box-sizing:border-box;border:1px solid #d9d9d9;border-radius:6px;outline:none;width:100%;padding:0 10px;font-family:inherit;font-size:13px}.adv-date-input:focus{border-color:var(--blue-accent);box-shadow:0 0 0 2px #3b6fd41f}.adv-filter-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding-top:12px;display:flex}.home-page{flex-direction:column;gap:20px;display:flex}.home-banner{background:linear-gradient(135deg, var(--navy) 0%, #2e4a8a 100%);border-radius:var(--radius);color:#fff;justify-content:space-between;align-items:center;padding:24px 28px;display:flex;box-shadow:0 4px 24px #1e2a4a2e}.home-banner-left{flex-direction:column;gap:6px;display:flex}.home-greeting{color:#fff;font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:600}.home-name{color:#a8c4ff;font-weight:700}.home-date{color:#fff9;font-size:13px}.home-banner-right{align-items:center;display:flex}.home-total-wrap{background:#ffffff1f;border:1px solid #fff3;border-radius:12px;align-items:center;gap:10px;padding:12px 20px;display:flex}.home-total-num{font-family:Space Grotesk,sans-serif;font-size:36px;font-weight:700;line-height:1}.home-total-label{color:#ffffffb3;font-size:12px;line-height:1.4}.home-section-heading{align-items:baseline;gap:10px;display:flex}.home-section-title{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:15px;font-weight:700}.home-section-sub{color:var(--text-muted);font-size:12px}.overview-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.overview-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-sm);-webkit-user-select:none;user-select:none;border-top:3px solid #0000;flex-direction:column;gap:10px;padding:16px 18px;transition:box-shadow .15s,border-color .15s,transform .1s;display:flex}.overview-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.overview-card-header{align-items:center;gap:8px;display:flex}.overview-short-label{letter-spacing:.4px;border-radius:6px;flex-shrink:0;padding:2px 8px;font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:700}.overview-doc-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;line-height:1.3;overflow:hidden}.overview-count-row{align-items:baseline;gap:8px;display:flex}.overview-count-num{font-family:Space Grotesk,sans-serif;font-size:32px;font-weight:700;line-height:1}.overview-pending-badge{color:#c07a00;background:#fff4e0;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.overview-empty-label{color:var(--text-muted);font-size:12px}.overview-status-row{border-top:1px solid var(--border);flex-wrap:wrap;gap:6px;margin-top:2px;padding-top:8px;display:flex}.overview-status-chip{font-size:11px;font-weight:500}.page-title{letter-spacing:-.3px;font-size:22px}.overview-card,.pr-card,.detail-header-card,.adv-filter-panel,.list-banner,.action-bar-wrap,.detail-tabs-wrap{border-radius:var(--radius-lg);border-color:var(--border-soft);transition:box-shadow .2s,transform .12s,border-color .2s}.overview-card{box-shadow:var(--shadow-sm)}.overview-card:hover,.pr-card:hover{box-shadow:var(--shadow-lg);border-color:var(--accent-border);transform:translateY(-3px)}.overview-card:hover .overview-short-label{transition:transform .15s;transform:scale(1.05)}.pr-code{letter-spacing:-.2px}.pr-card{transition:box-shadow .2s,transform .12s,border-color .2s}.status-tab{border-radius:9px;padding:8px 16px}.status-tab.active{background:var(--accent-soft);color:var(--accent-hover);border-bottom-color:#0000}.status-tabs{border-bottom-color:var(--border-soft)}.detail-tab-btn.active{color:var(--accent-hover)}.ant-input-affix-wrapper,.ant-input,.ant-select .ant-select-selector,.ant-picker{border-radius:10px!important}.ant-input-affix-wrapper:focus-within,.ant-input:focus,.ant-select-focused .ant-select-selector,.ant-picker-focused{box-shadow:0 0 0 3px var(--accent-glow)!important;border-color:var(--accent)!important}.ant-btn{border-radius:10px;font-weight:500;transition:all .15s}.ant-btn-primary{box-shadow:0 4px 12px #7c3aed38}.ant-btn-primary:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 6px 18px #7c3aed52}.ant-table-wrapper .ant-table{border:1px solid var(--border-soft);border-radius:var(--radius)!important}.ant-table-thead>tr>th{text-transform:uppercase;letter-spacing:.3px;font-size:12px;color:var(--text-secondary)!important;background:#f7f8fc!important;font-weight:600!important}.ant-table-tbody>tr:hover>td{background:var(--accent-soft)!important}.ant-modal-content{border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-lg)!important}.ant-dropdown-menu{box-shadow:var(--shadow-lg)!important;border-radius:12px!important;padding:6px!important}.ant-dropdown-menu-item{border-radius:8px!important}.ant-tag{border-radius:6px}.tab-count{background:linear-gradient(135deg,#7c3aed,#ec4899)}.app-menu .ant-menu-item:after{display:none!important}.app-menu .ant-menu-item .anticon{font-size:16px}.app-menu.ant-menu-inline-collapsed .ant-menu-item{margin:4px auto!important}.home-name{color:#c4b5fd}
