@import"https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--ink: #0B2341;--ink-2: #2C3E55;--ink-3: #4E5D6C;--paper: #F5F7FA;--paper-2: #EDF1F6;--paper-3: #E3E8EF;--accent: #1F5FBF;--accent-l: #EAF2FC;--accent-m: #00A3FF;--warn: #B45309;--warn-l: #FEF3C7;--danger: #DC2626;--danger-l: #FDEAEA;--info: #1F5FBF;--info-l: #EAF2FC;--purple: #1163A6;--purple-l: #E9F6FF;--teal: #0E9F6E;--teal-l: #E7F7F1;--border: #E3E8EF;--shadow: 0 1px 3px rgba(11,35,65,.08), 0 4px 16px rgba(11,35,65,.06);--shadow-lg: 0 4px 6px rgba(11,35,65,.06), 0 12px 40px rgba(11,35,65,.12);--radius: 10px;--font-d: "Outfit", system-ui, sans-serif;--font-b: "DM Sans", system-ui, sans-serif;--sw: 228px;--hh: 60px}body{font-family:var(--font-b);background:var(--paper);color:var(--ink);min-height:100vh;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.layout{display:flex;min-height:100vh}.main-content{margin-left:var(--sw);flex:1;display:flex;flex-direction:column}.page-body{flex:1;padding:28px}.page-max{max-width:1200px}.page-header{margin-bottom:24px}.page-header h1{font-family:var(--font-d);font-size:30px;font-weight:400;letter-spacing:-.4px}.page-header p{color:var(--ink-3);margin-top:4px;font-size:14px}.sidebar{width:var(--sw);background:var(--ink);color:var(--paper);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sb-logo{padding:22px 20px 18px;border-bottom:1px solid rgba(255,255,255,.08)}.logo-mark{font-family:var(--font-d);font-size:22px;color:#fff;letter-spacing:-.5px}.logo-mark span{color:#00a3ff}.logo-sub{font-size:10px;color:#ffffff4d;letter-spacing:.12em;text-transform:uppercase;margin-top:2px}.sb-user{padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}.av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.sb-name{font-size:13px;font-weight:500;color:#fff}.sb-role{font-size:11px;color:#fff6}.sb-nav{flex:1;padding:10px 0;overflow-y:auto}.nav-section{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#ffffff40;padding:12px 20px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 20px;color:#ffffff8c;cursor:pointer;font-size:13.5px;transition:all .15s;border-left:3px solid transparent;text-decoration:none}.nav-item:hover{color:#fff;background:#ffffff0d}.nav-item.active{color:#fff;background:#00a3ff1f;border-left-color:#00a3ff}.nav-icon{font-size:15px;width:20px;text-align:center;display:flex;align-items:center;justify-content:center}.nav-badge{margin-left:auto;background:var(--warn);color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.sb-footer{padding:14px 20px;border-top:1px solid rgba(255,255,255,.08)}.topbar{height:var(--hh);background:var(--paper);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 26px;gap:14px;position:sticky;top:0;z-index:50}.topbar-title{font-size:17px;font-weight:500;flex:1}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:15px;font-weight:600}.card-sub{font-size:12px;color:var(--ink-3);margin-top:2px}.card-body{padding:20px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 15px;border-radius:8px;font-family:var(--font-b);font-size:13px;font-weight:500;cursor:pointer;border:1.5px solid transparent;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:#184e9e}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--ink);border-color:var(--border)}.btn-secondary:hover{background:var(--paper-2);border-color:var(--ink-3)}.btn-secondary:disabled{opacity:.45;cursor:not-allowed}.btn-warn{background:var(--warn);color:#fff}.btn-warn:hover{background:#a64a15}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#a01818}.btn-danger:disabled{opacity:.45;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--ink-2);border-color:transparent}.btn-ghost:hover{background:var(--paper-2)}.btn-sm{padding:5px 11px;font-size:12px}.btn-lg{padding:10px 20px;font-size:15px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}.badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}.badge-draft{background:var(--paper-2);color:var(--ink-3)}.badge-submitted{background:var(--info-l);color:var(--info)}.badge-partial{background:#fff3cd;color:#856404}.badge-approved{background:var(--accent-l);color:var(--accent)}.badge-rejected{background:var(--danger-l);color:var(--danger)}.badge-closed{background:var(--paper-3);color:var(--ink-2)}.badge-processing{background:var(--purple-l);color:var(--purple)}.badge-pending{background:#fff3cd;color:#856404}.form-group{margin-bottom:14px}.form-label{display:block;font-size:11px;font-weight:600;color:var(--ink-2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em}.form-input,.form-select,.form-textarea{width:100%;padding:8px 11px;border:1.5px solid var(--border);border-radius:8px;font-family:var(--font-b);font-size:14px;color:var(--ink);background:#fff;transition:border-color .15s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1f5fbf1a}.form-input::placeholder{color:var(--ink-3)}.form-textarea{resize:vertical;min-height:72px}.form-error{font-size:12px;color:var(--danger);margin-top:4px}.ts-table{width:100%;border-collapse:collapse;font-size:13px}.ts-table th{background:var(--paper-2);padding:9px 7px;text-align:center;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);border-bottom:2px solid var(--border);white-space:nowrap}.ts-table th.th-l{text-align:left}.ts-table td{padding:3px;border-bottom:1px solid var(--border);vertical-align:middle}.ts-table td.td-l{padding:3px 8px}.ts-table tr:hover td{background:#1f5fbf06}.ts-table tr.row-totals td{background:var(--paper-2);font-weight:600;border-top:2px solid var(--border);border-bottom:none}.h-input{width:58px;padding:6px 4px;text-align:center;border:1.5px solid var(--border);border-radius:6px;font-family:var(--font-b);font-size:13px;font-weight:500;color:var(--ink);background:#fff;outline:none;transition:all .15s;display:block;margin:0 auto}.h-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1f5fbf1a}.h-input.hv{border-color:#1f5fbf59;color:var(--accent);background:var(--accent-l)}.h-input.we{background:var(--paper-2)}.h-input[readonly]{background:var(--paper-2);color:var(--ink-3);cursor:default;border-color:transparent}.h-input.hv[readonly]{background:var(--accent-l);color:var(--accent);border-color:#1f5fbf33}.row-total-td{text-align:center;font-weight:600;font-size:14px;padding:0 8px}.row-total-td.ot{color:var(--warn)}.del-btn{width:26px;height:26px;border-radius:6px;border:1.5px solid var(--border);background:#fff;cursor:pointer;color:var(--ink-3);font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .15s;margin:0 auto}.del-btn:hover{background:var(--danger-l);border-color:var(--danger);color:var(--danger)}.sig-panel{background:var(--paper-2);border:1.5px dashed var(--border);border-radius:var(--radius);padding:20px;text-align:center}.sig-panel.signed{background:var(--accent-l);border-color:var(--accent);border-style:solid}.sig-name{font-family:var(--font-d);font-size:28px;font-style:italic;color:var(--accent)}.steps{display:flex;align-items:center;margin-bottom:26px}.step{display:flex;align-items:center;gap:8px}.step-line{flex:1;height:1px;background:var(--border);margin:0 10px;min-width:24px}.step-line.done{background:var(--accent)}.step-circle{width:26px;height:26px;border-radius:50%;border:2px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink-3);flex-shrink:0}.step.active .step-circle{border-color:var(--accent);color:var(--accent);background:var(--accent-l)}.step.done .step-circle{border-color:var(--accent);background:var(--accent);color:#fff}.step-lbl{font-size:12px;color:var(--ink-3);font-weight:500;white-space:nowrap}.step.active .step-lbl,.step.done .step-lbl{color:var(--ink)}.overlay{display:flex;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0e0c80;z-index:200;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease}.modal{background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);width:90%;max-width:520px;overflow:hidden;animation:modalIn .2s ease}.modal.wide{max-width:720px}@keyframes modalIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}.modal-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:16px;font-weight:600}.modal-x{background:none;border:none;font-size:20px;cursor:pointer;color:var(--ink-3);line-height:1;padding:4px}.modal-body{padding:22px;max-height:70vh;overflow-y:auto}.modal-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;background:var(--paper-2)}.data-table{width:100%;border-collapse:collapse}.data-table th{padding:9px 13px;text-align:left;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);background:var(--paper-2);border-bottom:2px solid var(--border);white-space:nowrap}.data-table td{padding:12px 13px;border-bottom:1px solid var(--border);font-size:13.5px;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--paper-2);cursor:pointer}.kpi-grid{display:grid;gap:14px;margin-bottom:22px}.kpi{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px;position:relative;overflow:hidden}.kpi:after{content:"";position:absolute;top:0;right:0;width:4px;height:100%}.kpi.g:after{background:var(--accent)}.kpi.a:after{background:var(--warn)}.kpi.b:after{background:var(--info)}.kpi.p:after{background:var(--purple)}.kpi.r:after{background:var(--danger)}.kpi-num{font-size:34px;font-weight:600;font-family:var(--font-d);line-height:1}.kpi-lbl{font-size:11px;color:var(--ink-3);margin-top:5px;text-transform:uppercase;letter-spacing:.06em}.kpi-sub{font-size:12px;color:var(--ink-2);margin-top:6px}.notice{padding:11px 14px;border-radius:8px;font-size:13px;display:flex;align-items:flex-start;gap:9px}.notice-info{background:var(--info-l);color:var(--info);border:1px solid rgba(26,74,138,.2)}.notice-warn{background:var(--warn-l);color:var(--warn);border:1px solid rgba(200,90,26,.2)}.notice-ok{background:var(--accent-l);color:var(--accent);border:1px solid rgba(31,95,191,.2)}.notice-purple{background:var(--purple-l);color:var(--purple);border:1px solid rgba(109,40,217,.2)}.notice-danger{background:var(--danger-l);color:var(--danger);border:1px solid rgba(196,28,28,.2)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:18px}.stat{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;text-align:center}.stat-val{font-size:26px;font-weight:600;font-family:var(--font-d)}.stat-val.ac{color:var(--accent)}.stat-val.w{color:var(--warn)}.stat-val.p{color:var(--purple)}.stat-val.b{color:var(--info)}.stat-lbl{font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.period-tabs{display:flex;background:var(--paper-2);border:1px solid var(--border);border-radius:8px;padding:3px}.period-tab{padding:5px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;color:var(--ink-3);border:none;background:transparent;font-family:var(--font-b);transition:all .15s}.period-tab.active{background:#fff;color:var(--ink);box-shadow:0 1px 3px #0000001a}.timeline{list-style:none;position:relative;padding-left:18px}.timeline:before{content:"";position:absolute;left:5px;top:8px;bottom:8px;width:1px;background:var(--border)}.tl-item{position:relative;padding:0 0 16px 18px}.tl-item:before{content:"";position:absolute;left:-13px;top:5px;width:10px;height:10px;border-radius:50%;background:var(--paper);border:2px solid var(--border)}.tl-item.approved:before{border-color:var(--accent);background:var(--accent)}.tl-item.submitted:before{border-color:var(--info);background:var(--info)}.tl-item.rejected:before{border-color:var(--danger);background:var(--danger)}.tl-item.signed:before{border-color:var(--purple);background:var(--purple)}.tl-item.closed:before{border-color:var(--ink-3);background:var(--ink-3)}.tl-time{font-size:11px;color:var(--ink-3);margin-bottom:2px}.tl-event{font-size:13px;font-weight:500}.tl-note{font-size:12px;color:var(--ink-2);margin-top:2px;font-style:italic}.export-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.export-card{border:1.5px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center;cursor:pointer;transition:all .15s;background:#fff}.export-card:hover{border-color:var(--accent);background:var(--accent-l);transform:translateY(-1px)}.export-icon{font-size:26px;margin-bottom:6px}.export-name{font-size:13px;font-weight:600}.export-fmt{font-size:11px;color:var(--ink-3);margin-top:2px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.text-sm{font-size:12px}.muted{color:var(--ink-3)}.font-medium{font-weight:500}.font-bold{font-weight:600}.text-accent{color:var(--accent)}.text-warn{color:var(--warn)}.text-danger{color:var(--danger)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.w-full{width:100%}hr.divider{border:none;border-top:1px solid var(--border);margin:20px 0}.rounded{border-radius:var(--radius)}.overflow-x-auto{overflow-x:auto}.fade-in{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.empty-state{text-align:center;padding:60px 20px}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.4}.empty-state h3{font-size:18px;font-weight:500;color:var(--ink-2);margin-bottom:8px}.empty-state p{font-size:14px;color:var(--ink-3)}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;min-height:200px}.proj-band-0{border-left:4px solid var(--accent)}.proj-band-1{border-left:4px solid var(--purple)}.proj-band-2{border-left:4px solid var(--teal)}.proj-band-3{border-left:4px solid var(--warn)}.proj-band-4{border-left:4px solid var(--info)}.approval-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:14px;transition:box-shadow .15s}.approval-card:hover{box-shadow:var(--shadow)}.approval-card-head{padding:14px 18px;display:flex;align-items:center;gap:12px;background:var(--paper-2);border-bottom:1px solid var(--border)}.approval-card-body{padding:14px 18px}.section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin-bottom:10px;display:block}.search-input{padding:7px 12px 7px 34px;border:1.5px solid var(--border);border-radius:8px;font-family:var(--font-b);font-size:13px;outline:none;background:#fff;width:240px}.search-input:focus{border-color:var(--accent)}.search-wrap{position:relative}.search-wrap svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--ink-3)}.mini-bar{display:flex;gap:5px;align-items:flex-end;height:48px}.mini-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}.mini-bar-fill{width:100%;border-radius:3px 3px 0 0;transition:height .3s;min-height:2px}.mini-bar-day{font-size:9px;color:var(--ink-3)}.mini-bar-val{font-size:9px;color:var(--ink-3);font-weight:600}
