:root{--color-brand: #1F4FD8;--color-brand-dark: #15349E;--color-brand-soft: #E5EEFF;--color-ink: #16243A;--color-muted: #6B7A8F;--color-muted-soft: #9AA9BC;--color-border: #D6DCE5;--color-border-soft: #EEF1F5;--color-bg: #F4F6F9;--color-white: #FFFFFF;--color-surface-alt: #E5E9F0;--color-danger: #D14343;--color-danger-soft: #FBE2E2;--color-success: #1F8A4C;--color-success-soft: #DDF4E4;--color-warning: #A1690B;--color-warning-soft: #FFF2D6;--color-info: #1F4FD8;--color-info-soft: #DCE8FF;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-xxl: 28px;--space-xxxl: 36px;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--radius-pill: 999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 28px rgba(0, 0, 0, .16);--font-size-xs: 12px;--font-size-sm: 13px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-xxl: 28px;--motion-fast: .12s;--motion-base: .18s;--motion-slow: .28s;--control-height: 40px}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:var(--color-ink)}button{cursor:pointer;border:none;border-radius:var(--radius-sm);padding:8px 16px;background:var(--color-brand);color:#fff;font-size:var(--font-size-md);font-weight:600;transition:opacity var(--motion-fast) ease,transform var(--motion-fast) ease}button:disabled{opacity:.6;cursor:not-allowed}button.secondary{background:var(--color-surface-alt);color:var(--color-ink)}button:active:not(:disabled){transform:scale(.98)}input,select,textarea{font:inherit;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff;color:var(--color-ink)}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-ink);padding:20px}.auth-card{background:#fff;padding:32px;border-radius:var(--radius-xl);width:100%;max-width:340px;display:flex;flex-direction:column;gap:10px}.auth-card h1{margin:0}.auth-logo{width:100%;max-width:200px;height:auto;object-fit:contain;margin:0 auto 4px}.auth-subtitle{margin:0 0 12px;color:var(--color-muted);font-size:var(--font-size-sm)}.auth-error{color:var(--color-danger);font-size:var(--font-size-sm);margin:0}.app-shell{display:flex;min-height:100vh}.sidebar{width:220px;flex-shrink:0;background:var(--color-ink);color:#fff;display:flex;flex-direction:column;padding:20px 16px}.brand-logo{display:block;width:100%;max-width:168px;height:auto;margin-bottom:24px;object-fit:contain}.sidebar nav{display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto}.nav-section{margin-bottom:var(--space-sm)}.nav-section-title{color:#7c8ba3;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:10px 12px 4px}.nav-link{display:flex;align-items:center;gap:var(--space-sm);color:#b7c2d0;padding:9px 12px;border-radius:var(--radius-sm);text-decoration:none;font-size:var(--font-size-md);transition:background var(--motion-fast) ease,color var(--motion-fast) ease}.nav-link svg{flex-shrink:0;opacity:.85}.nav-link.active,.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active svg{opacity:1}.breadcrumb{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-muted);margin-bottom:var(--space-lg)}.breadcrumb-root,.breadcrumb-sep{color:var(--color-muted-soft)}.breadcrumb-current{color:var(--color-ink);font-weight:600}.sidebar-footer{border-top:1px solid rgba(255,255,255,.15);padding-top:14px}.user-name{font-weight:600;font-size:var(--font-size-md)}.user-role{font-size:var(--font-size-xs);color:#b7c2d0;text-transform:capitalize;margin-bottom:10px}.content{flex:1;min-width:0;padding:32px;overflow-x:auto}.mobile-topbar,.sidebar-backdrop{display:none}@media(max-width:860px){.mobile-topbar{display:flex;align-items:center;justify-content:space-between;background:var(--color-ink);color:#fff;padding:10px 16px;position:sticky;top:0;z-index:30}.mobile-topbar .brand-logo{max-width:120px;margin:0}.hamburger-btn{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;padding:6px 12px;border-radius:var(--radius-sm)}.app-shell{flex-direction:column}.sidebar{position:fixed;top:0;left:0;bottom:0;width:250px;max-width:82vw;transform:translate(-100%);transition:transform .22s ease;z-index:40;overflow-y:auto}.sidebar.open{transform:translate(0)}.sidebar-backdrop.open{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:35}.content{padding:16px;overflow-x:auto}.page-header{flex-direction:column;align-items:stretch;gap:10px}.filter-bar{flex-direction:column;align-items:stretch}.form-grid{grid-template-columns:1fr}.modal-card{width:min(560px,92vw);padding:18px}.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:420px){.auth-card{padding:22px}.kpi-grid{grid-template-columns:1fr}}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}.page-header h1{margin:0 0 4px}.page-subtitle{margin:0;color:var(--color-muted);font-size:var(--font-size-md)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.kpi-card{background:#fff;border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.kpi-value{font-size:var(--font-size-xxl);font-weight:800}.kpi-label{color:var(--color-muted);font-size:var(--font-size-sm);margin-top:4px}.section-title{font-size:var(--font-size-lg);font-weight:700;margin:0 0 12px}.filter-bar{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}.filter-bar label{display:flex;flex-direction:column;gap:4px;font-size:var(--font-size-sm);font-weight:600;color:var(--color-ink)}.search-input-wrap{position:relative;display:flex;align-items:center}.search-input-icon{position:absolute;left:10px;color:var(--color-muted-soft);pointer-events:none}.search-input{width:100%;padding-left:32px!important}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.data-table th,.data-table td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--color-border-soft);font-size:var(--font-size-sm)}.data-table th{color:var(--color-muted);font-weight:600}.row-actions{display:flex;gap:10px}.link-button{background:none;color:var(--color-brand);padding:0;font-weight:600}.link-button.danger{color:var(--color-danger)}.status-pill{display:inline-block;padding:3px 10px;border-radius:var(--radius-pill);font-size:var(--font-size-xs);font-weight:600;background:var(--color-surface-alt)}.status-awarded,.status-running,.status-completed{background:var(--color-success-soft);color:var(--color-success)}.status-lost{background:var(--color-danger-soft);color:var(--color-danger)}.status-submitted,.status-qualified,.status-under_review{background:var(--color-warning-soft);color:var(--color-warning)}.status-on_hold{background:var(--color-danger-soft);color:var(--color-danger)}.status-in_progress{background:var(--color-info-soft);color:var(--color-info)}.priority-urgent{background:var(--color-danger-soft);color:var(--color-danger)}.priority-high{background:#ffe3cc;color:#b5550c}.priority-medium{background:var(--color-warning-soft);color:var(--color-warning)}.priority-low{background:var(--color-surface-alt);color:#5c6b80}.task-board{display:flex;gap:16px;overflow-x:auto;padding-bottom:8px}.task-board-column{background:var(--color-bg);border-radius:var(--radius-lg);padding:12px;min-width:240px;flex:1}.task-board-column h3{margin:0 0 12px;font-size:var(--font-size-md);color:var(--color-ink)}.task-board-column-body{display:flex;flex-direction:column;gap:10px;min-height:60px}.task-board-column-over{background:var(--color-surface-alt)}.task-board-card{background:#fff;border-radius:var(--radius-md);padding:12px;box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;gap:6px}.task-board-card-title{font-weight:700;font-size:var(--font-size-sm);color:var(--color-ink)}.task-board-card-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:var(--font-size-xs);color:var(--color-muted);align-items:center}.notif-bell-wrap{position:fixed;top:16px;right:24px;z-index:20}.notif-bell{background:#fff;border-radius:50%;width:40px;height:40px;box-shadow:0 1px 3px #0000001f;position:relative;display:flex;align-items:center;justify-content:center;color:var(--color-ink)}.notif-badge{position:absolute;top:-4px;right:-4px;background:var(--color-danger);color:#fff;border-radius:var(--radius-pill);font-size:11px;padding:1px 6px}.notif-dropdown{position:absolute;right:0;top:48px;width:280px;max-height:360px;overflow-y:auto;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:12px}.notif-dropdown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.notif-dropdown ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.notif-dropdown li{padding:8px;border-radius:var(--radius-sm);background:var(--color-bg);font-size:var(--font-size-sm)}.notif-unread{background:#e5eeff!important}.empty-card{background:#fff;border-radius:var(--radius-lg);padding:24px;color:var(--color-muted);text-align:center}.error-text{color:var(--color-danger);font-size:var(--font-size-sm)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:50}.modal-card{background:#fff;border-radius:var(--radius-xl);padding:24px;width:560px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.modal-card h2{margin:0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-grid label,.full-width{display:flex;flex-direction:column;gap:4px;font-size:var(--font-size-sm);font-weight:600;color:var(--color-ink)}.form-grid .full-width{grid-column:1 / -1}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}.payslip-page{display:flex;flex-direction:column;align-items:center;padding:24px;background:var(--color-bg);min-height:100vh}.payslip-toolbar{margin-bottom:16px;display:flex;gap:8px}.payslip-sheet{position:relative;background:#fff;width:720px;padding:32px;border-radius:8px;box-shadow:0 1px 3px #00000014;box-sizing:border-box}.payslip-letterhead{width:100%;display:block;margin-bottom:12px}.payslip-sheet h2{margin:0 0 4px}.payslip-sheet h3{margin:20px 0 8px;font-size:var(--font-size-md)}.payslip-form-tag{font-size:var(--font-size-xs);color:var(--color-muted);margin:8px 0}.payslip-row{display:flex;justify-content:space-between;margin:12px 0;font-size:var(--font-size-md)}.payslip-meta,.payslip-table{width:100%;border-collapse:collapse;margin-bottom:8px;table-layout:fixed}.payslip-meta td{padding:6px 4px;font-size:var(--font-size-sm);word-break:break-word}.payslip-table th,.payslip-table td{border:1px solid var(--color-border);padding:6px 4px;font-size:11px;text-align:center;word-break:break-word}.payslip-net{text-align:right;font-size:var(--font-size-lg);font-weight:700;margin:16px 0}.payslip-signatures{display:flex;justify-content:space-between;align-items:flex-end;margin-top:60px;font-size:var(--font-size-sm)}.payslip-sign-block{display:flex;flex-direction:column;align-items:center;gap:4px}.payslip-sign-img{height:56px;max-width:160px;object-fit:contain}.payslip-stamp-img{height:70px;max-width:120px;object-fit:contain;position:absolute;right:40px;bottom:90px;opacity:.85}@media print{@page{size:A4;margin:12mm}.no-print{display:none}.payslip-page{background:#fff;padding:0}.payslip-sheet{box-shadow:none;width:100%;padding:0}}.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);min-height:var(--control-height);padding:0 var(--space-lg);border-radius:var(--radius-sm);border:none;cursor:pointer;font-size:var(--font-size-md);font-weight:600;white-space:nowrap;transition:opacity var(--motion-fast) ease,transform var(--motion-fast) ease,background var(--motion-fast) ease}.ui-btn:active:not(:disabled){transform:scale(.98)}.ui-btn:disabled{opacity:.55;cursor:not-allowed}.ui-btn-sm{min-height:32px;padding:0 var(--space-md);font-size:var(--font-size-sm)}.ui-btn-lg{min-height:48px;padding:0 var(--space-xxl);font-size:var(--font-size-lg)}.ui-btn-primary{background:var(--color-brand);color:#fff}.ui-btn-primary:hover:not(:disabled){background:var(--color-brand-dark)}.ui-btn-secondary{background:#fff;color:var(--color-ink);border:1.5px solid var(--color-border)}.ui-btn-secondary:hover:not(:disabled){background:var(--color-border-soft)}.ui-btn-danger{background:var(--color-danger-soft);color:var(--color-danger);border:1.5px solid #F5C7C3}.ui-btn-danger:hover:not(:disabled){background:#f9d3d1}.ui-btn-ghost{background:transparent;color:var(--color-brand)}.ui-btn-ghost:hover:not(:disabled){background:var(--color-border-soft)}.ui-btn-spinner{width:14px;height:14px;border-radius:50%;border:2px solid currentColor;border-top-color:transparent;animation:ui-spin .6s linear infinite}.ui-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border-soft);padding:var(--space-xl);box-shadow:var(--shadow-sm)}.ui-card-flat{box-shadow:none;border-color:var(--color-border)}.ui-badge{display:inline-flex;align-items:center;max-width:100%;padding:3px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.ui-badge-success{background:var(--color-success-soft);color:var(--color-success)}.ui-badge-warning{background:var(--color-warning-soft);color:var(--color-warning)}.ui-badge-danger{background:var(--color-danger-soft);color:var(--color-danger)}.ui-badge-info{background:var(--color-info-soft);color:var(--color-info)}.ui-badge-brand{background:var(--color-brand-soft);color:var(--color-brand-dark)}.ui-badge-neutral{background:var(--color-surface-alt);color:var(--color-muted)}.ui-field{display:flex;flex-direction:column;gap:6px}.ui-field-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-ink)}.ui-field-label-required:after{content:" *";color:var(--color-danger)}.ui-field-input,.ui-field-select,.ui-field-textarea{min-height:var(--control-height);padding:0 var(--space-md);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:#fff;color:var(--color-ink);font:inherit;font-size:var(--font-size-md);transition:border-color var(--motion-fast) ease,box-shadow var(--motion-fast) ease}.ui-field-textarea{min-height:88px;padding:var(--space-md);resize:vertical}.ui-field-input:focus,.ui-field-select:focus,.ui-field-textarea:focus{outline:none;border-color:var(--color-brand);box-shadow:0 0 0 3px var(--color-brand-soft)}.ui-field-input-error,.ui-field-select-error,.ui-field-textarea-error{border-color:var(--color-danger)}.ui-field-input-error:focus,.ui-field-select-error:focus{box-shadow:0 0 0 3px var(--color-danger-soft)}.ui-field-error{color:var(--color-danger);font-size:var(--font-size-xs);font-weight:600}.ui-field-helper{color:var(--color-muted-soft);font-size:var(--font-size-xs)}.ui-dialog-head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md)}.ui-dialog-close{background:transparent;color:var(--color-muted);font-size:20px;line-height:1;padding:4px 8px;border-radius:var(--radius-sm)}.ui-dialog-close:hover{background:var(--color-border-soft)}.ui-skeleton{display:block;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-border-soft) 25%,var(--color-surface-alt) 37%,var(--color-border-soft) 63%);background-size:400% 100%;animation:ui-shimmer 1.4s ease infinite}.ui-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-xxxl) var(--space-xl);gap:var(--space-sm)}.ui-empty-state-icon{font-size:40px;margin-bottom:var(--space-sm)}.ui-empty-state-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-ink);margin:0}.ui-empty-state-message{color:var(--color-muted);font-size:var(--font-size-md);max-width:360px;margin:0}.ui-confirm-icon{font-size:32px}.attention-banner{background:var(--color-danger-soft);border-color:#f5c7c3}.attention-banner-head{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm)}.attention-banner-title{font-weight:700;color:var(--color-danger)}.attention-banner-row{display:block;width:100%;text-align:left;background:transparent;border:none;padding:var(--space-sm) 0;color:inherit;min-height:var(--control-height)}.attention-banner-row:hover{text-decoration:underline}.attention-banner-label{font-weight:600;color:var(--color-ink)}.attention-banner-sub{font-size:var(--font-size-xs);color:var(--color-muted);margin-top:2px}.dashboard-notif-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-sm)}.dashboard-notif-list li{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);background:var(--color-bg)}.dashboard-notif-list li.notif-unread{background:var(--color-info-soft)}.dashboard-notif-title{flex:1;font-size:var(--font-size-sm);font-weight:600;color:var(--color-ink)}.dashboard-notif-time{display:flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--color-muted);white-space:nowrap}.ui-toast-stack{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:var(--space-sm);z-index:80}.ui-toast{padding:12px 18px;border-radius:var(--radius-md);color:#fff;font-size:var(--font-size-sm);font-weight:600;box-shadow:var(--shadow-md);min-width:240px;max-width:420px;text-align:center;animation:ui-toast-in var(--motion-base) ease}.ui-toast-success{background:var(--color-success)}.ui-toast-error{background:var(--color-danger)}.ui-toast-info{background:var(--color-brand)}@keyframes ui-spin{to{transform:rotate(360deg)}}@keyframes ui-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@keyframes ui-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
