:root{--bg:#f2eee6;--panel:#fffdf8;--panel-strong:#f7f0e3;--ink:#1f2a2a;--muted:#61706f;--line:#d9cfbf;--accent:#145c4c;--accent-soft:#d9efe8;--warning:#af5b2f;--shadow:0 24px 60px #1f2a2a14}*{box-sizing:border-box}html{font-size:15px}body{background:radial-gradient(circle at top left, #145c4c1f, transparent 28%), linear-gradient(180deg, #f8f4ec 0%, var(--bg) 100%);color:var(--ink);margin:0;font-family:IBM Plex Sans,Avenir Next,Segoe UI,sans-serif}a{color:inherit;overflow-wrap:anywhere;text-decoration:none}button,input,select,textarea{font:inherit}.shell{min-height:100vh;padding:18px}.frame{gap:18px;max-width:1520px;margin:0 auto;display:grid}.topbar{color:#f5f0e6;box-shadow:var(--shadow);z-index:20;background:#1f2a2af5;border-radius:24px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:18px 24px;padding:18px 22px;display:flex;position:sticky;top:14px}.brand{gap:8px;min-width:0;display:grid}.brand-lockup{align-items:center;gap:14px;display:flex}.brand-mark{object-fit:contain;background:#fffdf8f5;border-radius:16px;flex:none;width:56px;height:56px;padding:6px}.brand-text{min-width:0}.brand-title{margin:0;font-family:IBM Plex Serif,Georgia,serif;font-size:1.55rem;line-height:1}.brand-copy{color:#f5f0e6c2;max-width:40rem;margin:0;font-size:.88rem;line-height:1.45}.nav{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.topbar-user-area{justify-items:end;gap:6px;display:grid}.topbar-user-meta{text-align:right;gap:2px;display:grid}.topbar-user-meta strong{color:#f5f0e6;font-size:.9rem}.topbar-user-meta span{color:#f5f0e6b3;text-transform:uppercase;letter-spacing:.08em;font-size:.76rem}.nav a,.nav-group-toggle{color:#f5f0e6db;background:#ffffff05;border:1px solid #f5f0e614;border-radius:12px;padding:10px 13px;font-size:.92rem}.nav-group{position:relative}.nav-group-toggle{cursor:pointer;min-width:72px;font:inherit;justify-content:space-between;align-items:center;gap:10px;display:flex}.nav-group-toggle:after{content:"+";opacity:.76;font-size:1rem;line-height:1}.nav-group-toggle[aria-expanded=true]:after{content:"-"}.nav-children{min-width:220px;box-shadow:var(--shadow);background:#1f2a2afa;border:1px solid #f5f0e614;border-radius:16px;gap:8px;padding:10px;display:none;position:absolute;top:calc(100% + 8px);right:0}.nav-children.open{display:grid}.nav-children a{background:#ffffff0a;border-style:dashed}.main{gap:24px;display:grid}.auth-panel{max-width:520px;margin:40px auto 0}.auth-actions{justify-content:flex-start}.hero,.card,.panel{box-shadow:var(--shadow);background:#fffdf8eb;border:1px solid #d9cfbfcc;border-radius:28px}.hero{padding:24px}.overview-hero{justify-content:space-between;align-items:center;gap:20px;display:flex}.overview-hero-copy{min-width:0}.overview-brand-card{border:1px solid var(--line);text-align:center;background:linear-gradient(#fffdf8fa,#f7f0e3cc);border-radius:24px;flex:none;justify-items:center;gap:12px;width:min(100%,270px);padding:18px;display:grid}.overview-brand-logo{object-fit:contain;width:100%;max-width:180px;height:auto;max-height:88px}.overview-brand-name{color:var(--accent);font-weight:600}.hero-profile{align-items:center;gap:20px;display:flex}.hero-profile-copy{min-width:0}.hero-avatar,.hero-avatar-fallback{border-radius:24px;flex:0 0 96px;width:96px;height:96px;overflow:hidden}.hero-avatar{border:1px solid var(--line);background:var(--panel)}.hero-avatar img{object-fit:cover;width:100%;height:100%;display:block}.hero-avatar-fallback{background:linear-gradient(135deg, var(--accent) 0%, #2b7d68 100%);color:#fff;justify-content:center;align-items:center;font-size:2rem;font-weight:700;display:flex}.employee-photo-thumb,.employee-photo-thumb-fallback{border-radius:12px;flex:0 0 42px;width:42px;height:42px;overflow:hidden}.employee-photo-thumb{border:1px solid var(--line);background:var(--panel)}.employee-photo-thumb img{object-fit:cover;width:100%;height:100%;display:block}.employee-photo-thumb-fallback{background:linear-gradient(135deg, var(--accent) 0%, #2b7d68 100%);color:#fff;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.eyebrow{color:var(--accent);background:var(--accent-soft);letter-spacing:.08em;text-transform:uppercase;border-radius:999px;margin-bottom:12px;padding:8px 14px;font-size:.82rem;display:inline-block}.eyebrow.danger{color:#8a3324;background:#f6dfd8}.hero h1,.panel h1,.panel h2{margin:0;font-family:IBM Plex Serif,Georgia,serif}.hero p{color:var(--muted);max-width:58rem;margin:14px 0 0;line-height:1.7}.hero-actions{flex-wrap:wrap;gap:12px;margin-top:22px;display:flex}.overview-toolbar{flex-wrap:wrap;align-items:flex-end;gap:14px;margin-top:22px;display:flex}.overview-filter{min-width:180px;padding:0}.grid{gap:18px;display:grid}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;display:grid}.card{padding:20px}.employee-name-cell{align-items:center;gap:10px;display:flex}.card-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.86rem}.card-value{margin-top:10px;font-size:1.8rem;font-weight:700}.card-value-money{font-size:1.45rem}.panel{padding:22px}.panel-head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.panel-copy{color:var(--muted);margin:10px 0 0;font-size:.92rem;line-height:1.5}.cta{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;padding:10px 15px;font-size:.92rem;display:inline-flex}.cta.secondary{color:var(--accent);background:0 0;border:1px solid #145c4c3d}.monthly-payroll-nav{gap:14px}.monthly-nav-link{color:#0c6a5d;min-height:50px;box-shadow:none;background:#fffdf8eb;border:1px solid #145c4c2e;border-radius:18px;padding:13px 20px;font-size:.92rem}.monthly-nav-link.secondary,.cta.secondary.monthly-nav-link{color:#0c6a5d;background:#fffdf8eb;border:1px solid #145c4c2e}.monthly-nav-link.active,.cta.monthly-nav-link.active{color:#fffdf8;background:#145c4c;border-color:#145c4c}.cta.danger{background:#8a3324}.table{border-collapse:collapse;width:100%;min-width:760px}.table-shell{-webkit-overflow-scrolling:touch;width:100%;overflow:auto hidden}.table th,.table td{text-align:left;border-bottom:1px solid var(--line);vertical-align:top;overflow-wrap:anywhere;word-break:break-word;padding:11px 8px;font-size:.92rem}.table th{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:.74rem}.status-pill{background:var(--accent-soft);color:var(--accent);border-radius:999px;align-items:center;padding:5px 9px;font-size:.78rem;font-weight:600;display:inline-flex}.status-pill.warning{color:var(--warning);background:#f7e6db}.status-pill.error{color:#8a3324;background:#f6dfd8}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.detail-item{border:1px solid var(--line);background:var(--panel);border-radius:18px;min-width:0;padding:14px}.detail-item span{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;display:block}.detail-item strong{overflow-wrap:anywhere;word-break:break-word;margin-top:8px;font-size:.95rem;display:block}.detail-item.full-width{grid-column:1/-1}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.field{border-radius:16px;gap:8px;padding:10px;transition:background-color .16s,box-shadow .16s;display:grid}.field.full{grid-column:1/-1}.field label{color:var(--muted);font-size:.82rem}.field.field-invalid{background:#fff1ef;box-shadow:inset 0 0 0 1px #d67d7138}.field.field-invalid label{color:#a6483a;font-weight:600}.field input,.field select,.field textarea{border:1px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:14px;min-width:0;min-height:42px;padding:0 12px}.field textarea{resize:vertical;min-height:110px;padding:12px}.field input.invalid,.field select.invalid,.field textarea.invalid{color:#8a3324;background:#fff8f7;border-color:#e7a39a}.multi-select{min-height:180px;padding:10px 12px}.summary-grid{align-items:start}.summary-total{border-top:1px solid var(--line);justify-content:space-between;align-items:center;gap:16px;margin-top:16px;padding-top:14px;font-size:.92rem;display:flex}.summary-total strong{font-size:.98rem}.total-pay-highlight,.total-pay-cell{color:#145c2f;background:#edf9f1}.detail-item.total-pay-highlight{border-color:#145c2f38}.detail-item.total-pay-highlight strong,.total-pay-cell{color:#145c2f}.total-pay-cell{font-weight:700}.salary-slip-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;margin-top:20px;display:grid}.salary-slip-sheet{gap:20px}.print-slip-page{break-after:page}.settings-logo-preview{border:1px solid var(--line);background:#fff;border-radius:18px;justify-content:flex-start;align-items:center;padding:18px;display:flex}.settings-logo-preview img{object-fit:contain;max-width:240px;max-height:96px}.salary-slip-document{color:#111;background:#fff;border:3px solid #85cf2f}.salary-slip-header{border-bottom:3px solid #85cf2f;justify-content:space-between;align-items:flex-start;gap:16px;padding:18px 18px 10px;display:flex}.salary-slip-header h1{letter-spacing:.03em;color:#000;margin:0;font-size:clamp(2.6rem,5vw,3.5rem);line-height:1}.salary-slip-header p{margin:8px 0 0;font-size:1rem;font-weight:700}.salary-slip-logo{object-fit:contain;max-width:150px;max-height:92px}.salary-slip-period{text-align:center;border-bottom:2px solid #85cf2f;padding:10px 18px;font-size:clamp(1.2rem,2vw,1.8rem);font-weight:800}.salary-slip-table{border-collapse:collapse;width:100%}.salary-slip-table th,.salary-slip-table td{vertical-align:middle;border:2px solid #85cf2f;padding:8px 10px;font-size:.98rem}.salary-slip-table th{text-align:left;font-weight:800}.salary-slip-meta td,.salary-slip-meta th{font-size:.96rem}.salary-slip-breakdown thead th{text-align:center;background:#d6d6d6;font-size:1rem}.salary-slip-breakdown td:nth-child(2),.salary-slip-breakdown td:nth-child(3),.salary-slip-breakdown th:nth-child(2),.salary-slip-breakdown th:nth-child(3){text-align:center;width:18%}.salary-slip-total-row td{border-top-width:4px;font-weight:800}.salary-slip-footer-grid{grid-template-columns:2fr 1.1fr;display:grid}.salary-slip-netpay{border-top:2px solid #85cf2f;border-left:2px solid #85cf2f;border-right:2px solid #85cf2f}.salary-slip-netpay-label{color:#fff;text-align:center;letter-spacing:.04em;background:#5c5c5c;padding:8px 10px;font-size:1rem;font-weight:800}.salary-slip-netpay-value{text-align:center;padding:16px 10px;font-size:clamp(1.8rem,3vw,2.8rem);font-weight:900}.salary-slip-note-grid{border-top:2px solid #85cf2f;grid-template-columns:2fr 1.1fr;display:grid}.salary-slip-note,.salary-slip-printed{min-height:110px;padding:16px 12px}.salary-slip-note{border-right:2px solid #85cf2f;font-size:.95rem}.salary-slip-note strong,.salary-slip-printed strong{margin-bottom:8px;font-size:.92rem;display:block}.salary-slip-note p{margin:0 0 8px;font-style:italic}.salary-slip-printed{text-align:center;align-content:center;justify-items:center;font-size:1.1rem;display:grid}@media print{@page{size:A4 portrait;margin:7mm}html,body{background:#fff!important}body{font-size:11px}.shell,.frame,.main{gap:0!important;max-width:none!important;margin:0!important;padding:0!important}.topbar,.hero,.hero-actions,.monthly-payroll-nav,.salary-slip-sheet>.panel-head{display:none!important}.salary-slip-sheet,.salary-slip-grid .panel,.salary-slip-sheet .panel{box-shadow:none!important;background:0 0!important;border:none!important}.salary-slip-sheet{background:0 0;border:none;border-radius:0;margin:0;padding:0}.print-slip-page{break-after:page}.salary-slip-document{border-width:2px;width:100%}.salary-slip-header{border-bottom-width:2px;padding:10px 12px 6px}.salary-slip-header h1{font-size:2.45rem}.salary-slip-header p{margin-top:4px;font-size:.9rem}.salary-slip-logo{max-width:112px;max-height:64px}.salary-slip-period{border-bottom-width:2px;padding:7px 10px;font-size:1rem}.salary-slip-table th,.salary-slip-table td{border-width:1px;padding:5px 6px;font-size:.88rem;line-height:1.2}.salary-slip-breakdown thead th{font-size:.88rem}.salary-slip-total-row td{border-top-width:2px}.salary-slip-note-grid{border-top-width:1px}.salary-slip-note,.salary-slip-printed{min-height:72px;padding:9px 8px}.salary-slip-note p{margin-bottom:4px;font-size:.82rem;line-height:1.2}.salary-slip-printed{font-size:.92rem}.salary-slip-netpay-label{padding:6px 8px;font-size:.9rem}.salary-slip-netpay-value{padding:10px 8px;font-size:2rem}}.field-error{color:#b24b3b;font-size:.88rem;line-height:1.4}.payroll-grid-table input,.payroll-grid-table select{border:1px solid var(--line);width:100%;min-width:92px;font:inherit;background:#fffdf9;border-radius:10px;padding:8px 10px}.payroll-grid-table input[type=number]{appearance:textfield}.payroll-grid-table input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.payroll-grid-table input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.payroll-grid-table .payroll-input-compact{min-width:70px;max-width:88px;padding:7px 8px}.payroll-grid-table .field-error{color:inherit;background:#fff0ed;border-color:#d16a5d}.payroll-grid-table .payroll-col-narrow{width:88px}.payroll-grid-shell{max-height:calc(100vh - 240px);overflow:auto}.payroll-grid-table thead th{z-index:4;box-shadow:inset 0 -1px 0 var(--line);background:#f8f4ec;position:sticky;top:0}.table-group-row td{color:var(--ink);letter-spacing:.04em;background:#f4f1e7;font-size:.86rem}.payroll-grid-summary{gap:16px;margin-top:18px;display:grid}.payroll-shared-workdays{min-width:220px;max-width:260px}.form-actions{flex-wrap:wrap;justify-content:flex-end;gap:12px;margin-top:22px;display:flex}.asset-stack{gap:18px;display:grid}.asset-form{border:1px solid var(--line);background:var(--panel);border-radius:18px;padding:16px}.asset-form-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.payroll-form-grid,.attendance-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.inline-action{color:var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #145c4c3d;border-radius:999px;justify-content:center;align-items:center;padding:7px 10px;font-size:.85rem;display:inline-flex}.inline-action-danger{color:#8a3324;border-color:#8a332438}.action-group{flex-wrap:wrap;align-items:flex-start;gap:8px;display:flex}.top-gap{margin-top:10px}.hint{color:var(--muted);overflow-wrap:anywhere;word-break:break-word;font-size:.84rem}.employee-name-disabled,.employee-name-disabled a{color:#af5b2f;font-weight:600}.error{color:var(--warning);overflow-wrap:anywhere;word-break:break-word;background:#f7e6db;border-radius:14px;padding:12px 14px}.success{color:#216b46;overflow-wrap:anywhere;word-break:break-word;background:#e5f4ec;border-radius:14px;padding:12px 14px}.file-preview{white-space:pre-wrap;overflow-wrap:anywhere;border:1px solid var(--line);background:#f8f4ec;border-radius:18px;margin:0;padding:18px;font:.88rem/1.6 IBM Plex Mono,SFMono-Regular,monospace}.danger-zone{justify-content:space-between;align-items:flex-start;gap:20px;display:flex}.danger-zone-copy{gap:10px;min-width:0;display:grid}.advance-stack{gap:18px;display:grid}.advance-card{border:1px solid var(--line);background:var(--panel);border-radius:22px;gap:18px;padding:22px;display:grid}.advance-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.panel.panel-nested{box-shadow:none;border-radius:22px;padding:20px}@media (max-width:980px){.stats,.grid.two,.attendance-summary-grid,.detail-grid,.form-grid,.asset-form-grid,.advance-grid{grid-template-columns:1fr}.shell{padding:12px}.topbar{padding:16px;position:static}.nav{justify-content:flex-start}.topbar-actions{justify-content:flex-start;width:100%}.topbar-user-area,.topbar-user-meta{text-align:left;justify-items:start}.nav-group,.nav-group-toggle{width:100%}.nav-children{min-width:0;margin-top:8px;position:static}.hero-profile,.brand-lockup,.overview-hero{flex-direction:column;align-items:flex-start}.overview-brand-card{width:100%}.danger-zone{flex-direction:column}}
