:root{--bg: #f1f5f9;--surface: #fff;--surface-alt: #f8fafc;--border: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--text-dim: #94a3b8;--text-dark: #0f172a;--primary: #2563eb;--primary-hover: #1d4ed8;--shadow: 0 1px 4px rgba(0,0,0,.08);--input-bg: #fff;--input-text: #1e293b}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--surface-alt: #162032;--border: #334155;--text: #e2e8f0;--text-muted: #94a3b8;--text-dim: #64748b;--text-dark: #f1f5f9;--shadow: 0 1px 4px rgba(0,0,0,.3);--input-bg: #0f172a;--input-text: #e2e8f0}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;transition:background .2s,color .2s}a{text-decoration:none;color:inherit}.app-layout{display:flex;min-height:100vh}.sidebar{width:220px;min-width:220px;background:#1e293b;color:#cbd5e1;display:flex;flex-direction:column;padding:0}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:22px 20px;font-size:16px;font-weight:700;color:#fff;border-bottom:1px solid #334155}.brand-icon{font-size:20px}.sidebar-nav{flex:1;padding:16px 0;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;border-radius:6px;margin:0 8px;color:#94a3b8;font-size:14px;transition:all .15s}.nav-item:hover{background:#334155;color:#e2e8f0}.nav-item.active{background:#2563eb;color:#fff}.btn-logout{margin:16px;padding:9px;background:none;border:1px solid #334155;color:#94a3b8;border-radius:6px;cursor:pointer;font-size:13px;transition:all .15s}.btn-logout:hover{background:#334155;color:#e2e8f0}.main-content{flex:1;padding:32px;overflow-y:auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header h1{font-size:22px;font-weight:700;color:var(--text-dark)}.card{background:var(--surface);border-radius:10px;box-shadow:var(--shadow);padding:24px}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--surface);border-radius:10px;padding:20px 24px;box-shadow:var(--shadow)}.stat-card .stat-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.stat-card .stat-value{font-size:22px;font-weight:700;color:var(--text-dark)}.stat-card .stat-sub{font-size:11px;color:var(--text-dim);margin-top:4px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}thead th{text-align:left;padding:10px 14px;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border);background:var(--surface-alt)}tbody tr{border-bottom:1px solid var(--border);transition:background .1s}tbody tr:hover{background:var(--surface-alt)}tbody td{padding:12px 14px}.text-right{text-align:right}.text-mono{font-family:Courier New,monospace}.badge{display:inline-flex;align-items:center;justify-content:center;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;text-align:center;line-height:1}.badge-draft{background:#e2e8f0;color:#475569}.badge-sent{background:#dbeafe;color:#1d4ed8}.badge-paid{background:#dcfce7;color:#15803d}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:7px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover{background:#1d4ed8}.btn-secondary{background:var(--surface-alt);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-danger{background:#fee2e2;color:#b91c1c}.btn-danger:hover{background:#fecaca}.btn-success{background:#dcfce7;color:#15803d}.btn-success:hover{background:#bbf7d0}.btn-sm{padding:5px 11px;font-size:12px}.btn-group{display:flex;gap:6px;flex-wrap:wrap}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.form-full{grid-column:1 / -1}.form-group{display:flex;flex-direction:column;gap:5px}label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}input[type=text],input[type=number],input[type=date],input[type=email],input[type=password],select,textarea{padding:9px 12px;border:1px solid var(--border);border-radius:7px;font-size:14px;color:var(--input-text);background:var(--input-bg);transition:border-color .15s;outline:none;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}input[readonly]{background:var(--surface-alt);color:var(--text-muted);cursor:default}textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:10px;margin-top:24px;justify-content:flex-end}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b,#0f172a)}.login-card{background:var(--surface);border-radius:14px;padding:40px 36px;width:100%;max-width:380px;box-shadow:0 20px 60px #0000004d}.login-card h1{font-size:22px;color:var(--text-dark);margin-bottom:6px}.login-card p{color:var(--text-muted);font-size:13px;margin-bottom:28px}.login-card .form-group{margin-bottom:16px}.login-btn{width:100%;margin-top:8px;justify-content:center;padding:11px;font-size:14px}.login-error{color:#dc2626;font-size:13px;margin-top:10px;text-align:center}.lines-editor{margin:0}.lines-editor table{border:1px solid var(--border);border-radius:8px;overflow:hidden}.lines-editor thead th{background:var(--surface-alt)}.lines-editor td input{border:none;background:transparent;padding:6px 8px;color:var(--input-text)}.lines-editor td input:focus{background:#2563eb14;border-radius:4px}.lines-editor td{padding:6px 8px}.amount-cell{font-weight:600;color:var(--text-dark);font-family:Courier New,monospace}.totals-box{background:var(--surface-alt);border:1px solid var(--border);border-radius:8px;padding:16px 20px;min-width:280px}.totals-row{display:flex;justify-content:space-between;padding:5px 0;font-size:13px}.totals-row.grand{font-size:16px;font-weight:700;border-top:2px solid var(--border);margin-top:8px;padding-top:10px}.totals-row .label{color:var(--text-muted)}.totals-row .value{font-family:Courier New,monospace;font-weight:500}.invoice-preview{background:var(--surface);border-radius:10px;padding:40px 50px;max-width:760px;box-shadow:var(--shadow)}.invoice-preview h1{text-align:center;font-size:26px;letter-spacing:3px;margin-bottom:24px;color:var(--text-dark)}.preview-meta{display:flex;justify-content:space-between;margin-bottom:24px;font-size:13px}.preview-meta .from,.preview-meta .to{line-height:1.7}.preview-meta .to{text-align:right}.preview-section-title{font-weight:700;font-size:13px;color:var(--text);border-bottom:1px solid var(--border);padding-bottom:4px;margin:20px 0 10px;text-transform:uppercase;letter-spacing:.05em}.preview-highlight{background:var(--surface-alt);border-radius:6px;padding:12px 16px;font-size:13px;line-height:1.7;color:var(--text)}.preview-lines-table{font-size:13px}.preview-lines-table thead th{border-bottom:2px solid var(--border);background:var(--surface-alt)}.preview-lines-table tbody td{border-bottom:1px solid var(--border)}.preview-lines-table .subtotal-row td{font-weight:700;border-top:2px solid var(--border);border-bottom:none;background:var(--surface-alt)}.preview-totals{margin-top:16px}.preview-total-row{display:flex;justify-content:flex-end;gap:0;font-size:13px;padding:4px 0}.preview-total-row .label{min-width:280px;text-align:right;padding-right:20px;color:var(--text-muted)}.preview-total-row .value{min-width:120px;text-align:right;font-family:Courier New,monospace}.preview-total-row.grand{font-size:16px;font-weight:700;border-top:2px solid var(--border);margin-top:8px;padding-top:10px}.preview-total-row.grand .label{color:var(--text-dark)}.filters-bar{display:flex;gap:10px;margin-bottom:20px;align-items:center;flex-wrap:wrap}.filters-bar select,.filters-bar input{width:auto}.search-input{min-width:220px}.filter-count{font-size:12px;color:var(--text-muted);margin-left:auto}.btn-theme{margin:0 16px 8px;padding:9px;background:none;border:1px solid #334155;color:#94a3b8;border-radius:6px;cursor:pointer;font-size:13px;transition:all .15s;display:flex;align-items:center;gap:6px;justify-content:center}.btn-theme:hover{background:#334155;color:#e2e8f0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border-radius:12px;padding:28px 32px;width:100%;max-width:520px;box-shadow:0 20px 60px #0000004d}.modal h2{font-size:17px;margin-bottom:20px;color:var(--text-dark)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-dim)}.empty-state .icon{font-size:48px;margin-bottom:12px}.empty-state p{font-size:15px}.alert{padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:16px}.alert-error{background:#fee2e2;color:#b91c1c}.alert-success{background:#dcfce7;color:#15803d}.actions-col{display:flex;gap:6px;justify-content:flex-end}.divider{height:1px;background:#e2e8f0;margin:24px 0}.section-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title-row h2{font-size:15px;font-weight:700;color:var(--text-dark)}.accounting-stats{grid-template-columns:repeat(auto-fit,minmax(148px,1fr))}.stat-value-md{font-size:18px!important}.stat-card-highlight{background:linear-gradient(135deg,#1e40af,#1d4ed8)!important;color:#fff}.stat-card-highlight .stat-label{color:#ffffffbf!important}.stat-card-highlight .stat-value{color:#fff!important}.stat-card-highlight .stat-sub{color:#fff9!important}.tax-calc-note{font-size:12px;color:var(--text-muted);background:#fef9c3;border:1px solid #fde68a;border-radius:6px;padding:8px 12px;margin-bottom:18px;line-height:1.5}[data-theme=dark] .tax-calc-note{background:#422006;border-color:#92400e;color:#fcd34d}.tax-rates-editor{background:var(--surface-alt);border:1px solid var(--border);border-radius:8px;padding:14px 18px;margin-bottom:20px}.tax-rates-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:12px}.tax-rates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.tax-rates-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.tax-rate-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:12px}.tax-rate-label{flex:1;color:var(--text)}.tax-rate-row input{padding:4px 7px;font-size:12px}.tax-rate-row span:last-child{min-width:16px;color:var(--text-muted)}.tax-calc-body{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}@media (max-width: 900px){.tax-calc-body{grid-template-columns:1fr}}.tax-calc-input-row{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;font-size:13px;border-bottom:1px solid var(--border)}.tax-calc-input-row:last-of-type{border-bottom:none}.tax-calc-label{color:var(--text)}.tax-calc-detail{font-size:11px;color:var(--text-muted);margin-left:4px}.tax-calc-value{font-family:Courier New,monospace;font-weight:500;white-space:nowrap}.tax-minus .tax-calc-label{color:var(--text-muted)}.tax-minus .tax-calc-value{color:#dc2626}.tax-calc-total-collected{background:var(--surface-alt);border-radius:6px;padding:10px 8px!important;margin-bottom:4px}.tax-calc-total-collected .tax-calc-label{font-weight:700;color:var(--text-dark);font-size:14px}.tax-calc-total-collected .tax-calc-value{font-weight:700;font-size:15px}.tax-subtotal{font-weight:700}.tax-subtotal .tax-calc-label{color:var(--text-dark)}.tax-total .tax-calc-label{font-weight:700;color:var(--text-dark)}.tax-total .tax-calc-value{font-weight:700}.tax-available .tax-calc-label{font-weight:700;color:var(--text-dark);font-size:14px}.tax-available .tax-calc-value{font-weight:700;font-size:15px}.tax-calc-section-sep{height:1px;background:var(--border);margin:6px 0}.tax-calc-actions{display:flex;align-items:center;gap:12px;margin-top:14px;flex-wrap:wrap}.tax-calc-salary{background:var(--surface-alt);border:1px solid var(--border);border-radius:10px;padding:20px}.tax-calc-salary-title{font-size:14px;font-weight:700;color:var(--text-dark);margin-bottom:14px}.tax-calc-salary-params{margin-bottom:14px}.tax-calc-salary-result{margin-top:12px}.salary-calc-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;border-bottom:1px solid var(--border)}.salary-calc-row span:last-child{font-family:Courier New,monospace;font-weight:500}.salary-monthly-result{font-size:15px;font-weight:700;border-top:2px solid var(--text-dark)!important;padding-top:10px!important;border-bottom:none!important}.salary-monthly-result span:first-child{color:var(--text-dark)}.salary-monthly-result span:last-child{color:#1d4ed8}.salary-dash-controls{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:20px}@media (max-width: 700px){.salary-dash-controls{grid-template-columns:1fr}}.salary-dash-param label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.salary-dash-slider-row{display:flex;align-items:center;gap:14px}.salary-dash-slider-row input[type=range]{flex:1;accent-color:#2563eb}.salary-dash-pct{font-size:20px;font-weight:800;color:#2563eb;min-width:52px;text-align:right}.salary-dash-hint{font-size:11px;color:var(--text-muted);margin-top:4px;display:block}.salary-dash-result{display:grid;grid-template-columns:1fr 280px;gap:24px;align-items:start}@media (max-width: 800px){.salary-dash-result{grid-template-columns:1fr}}.sdf-row{display:flex;justify-content:space-between;padding:7px 10px;font-size:13px;border-bottom:1px solid var(--border)}.sdf-row span:last-child{font-family:Courier New,monospace;font-weight:500}.sdf-header{background:var(--surface-alt);font-weight:700;border-radius:6px 6px 0 0}.sdf-minus span:first-child{color:var(--text-muted)}.sdf-minus span:last-child{color:#dc2626}.sdf-sub{font-weight:600;background:var(--surface-alt)}.sdf-total{font-size:15px;font-weight:800;border-top:2px solid #1e293b!important;background:#f0fdf4;border-radius:0 0 6px 6px}.sdf-total span:last-child{color:#15803d!important}[data-theme=dark] .sdf-total{background:#052e16}.salary-dash-monthly{background:linear-gradient(135deg,#1e40af,#2563eb);border-radius:12px;padding:24px;color:#fff;text-align:center}.sdm-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;opacity:.8;margin-bottom:8px}.sdm-amount{font-size:32px;font-weight:900;letter-spacing:-1px;margin-bottom:4px}.sdm-detail{font-size:12px;opacity:.7}.salary-dash-monthly .btn-primary{background:#fff3!important;border:1px solid rgba(255,255,255,.4);color:#fff!important;font-weight:700}.salary-dash-monthly .btn-primary:hover{background:#ffffff59!important}.salary-dash-monthly .alert-success{background:#fff3;color:#fff;border:none}.payslip-moneyflow{border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-bottom:8px}.pmf-row{display:flex;justify-content:space-between;align-items:center;padding:9px 14px;font-size:13px}.pmf-label{flex:1}.pmf-value{font-family:Courier New,monospace;font-weight:600;white-space:nowrap;margin-left:16px}.pmf-minus .pmf-label{color:var(--text-muted)}.pmf-minus .pmf-value{color:#dc2626}.pmf-subtotal{background:var(--surface-alt);font-weight:700}.pmf-subtotal .pmf-label{color:var(--text-dark)}.pmf-total-collected{background:#f0f9ff;border-bottom:2px solid var(--border)}.pmf-total-collected .pmf-label{font-weight:700;color:var(--text-dark);font-size:14px}.pmf-total-collected .pmf-value{font-size:15px;color:var(--text-dark)}[data-theme=dark] .pmf-total-collected{background:#0c2340}.pmf-block{border-top:1px solid var(--border)}.pmf-block-title{padding:6px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--surface-alt)}.pmf-block-total{background:var(--surface-alt);font-weight:600}.pmf-block-gov .pmf-block-title,.pmf-block-gov .pmf-value{color:#b45309}.pmf-block-exp .pmf-block-title{color:#dc2626}.pmf-block-tax .pmf-block-title,.pmf-block-tax .pmf-value{color:#7c3aed}.pmf-note{padding:4px 14px 8px;font-size:11px;color:var(--text-muted);font-style:italic;background:var(--surface-alt)}.pmf-salary-available{background:#f0fdf4;border-top:2px solid #15803d;font-size:15px;font-weight:800}.pmf-salary-available .pmf-label{color:#15803d}.pmf-salary-available .pmf-value{color:#15803d;font-size:16px}[data-theme=dark] .pmf-salary-available{background:#052e16}.pmf-residual{background:var(--surface-alt);font-weight:700}.pmf-summary-boxes{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-top:4px}.pmf-box{border-radius:10px;padding:14px 16px;text-align:center}.pmf-box-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;opacity:.8}.pmf-box-amount{font-size:20px;font-weight:800;margin-bottom:4px}.pmf-box-detail{font-size:11px;opacity:.7}.pmf-box-gov{background:#fef3c7;color:#92400e}.pmf-box-exp{background:#fee2e2;color:#991b1b}.pmf-box-salary{background:#dcfce7;color:#14532d}[data-theme=dark] .pmf-box-gov{background:#422006;color:#fcd34d}[data-theme=dark] .pmf-box-exp{background:#450a0a;color:#fca5a5}[data-theme=dark] .pmf-box-salary{background:#052e16;color:#86efac}.month-detail-expand{background:var(--surface-alt);padding:12px 24px 16px;border-bottom:2px solid var(--border)}.month-detail-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.monthly-total-row{background:var(--surface-alt)}.monthly-total-row td{font-weight:700;border-top:2px solid var(--border)}.invoice-salary-panel{margin-top:24px;border-top:3px solid #15803d}.isp-flow{border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-bottom:16px}.isp-row{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;font-size:14px;gap:16px}.isp-row span:last-child{font-family:Courier New,monospace;font-weight:600;white-space:nowrap}.isp-total{background:#f0f9ff;font-weight:700;font-size:15px;border-bottom:2px solid var(--border)}.isp-total span:last-child{font-size:16px}.isp-minus{color:var(--text-muted)}.isp-sub{background:var(--surface-alt);font-weight:600;border-top:1px solid var(--border)}.isp-result{background:#f0fdf4;border-top:2px solid #15803d;font-weight:800;font-size:15px;color:#15803d}.isp-result span:last-child{font-size:18px}[data-theme=dark] .isp-total{background:#0c2340}[data-theme=dark] .isp-result{background:#052e16}.isp-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.isp-note{font-size:12px;color:var(--text-muted);font-style:italic;flex:1;min-width:200px}.payslip-modal{background:#fff;border-radius:12px;width:100%;max-width:760px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px #00000059;color:#1e293b}[data-theme=dark] .payslip-modal .pmf-block-title{background:#f8fafc!important;color:#475569!important}[data-theme=dark] .payslip-modal .pmf-block-gov .pmf-block-title{color:#92400e!important}[data-theme=dark] .payslip-modal .pmf-block-exp .pmf-block-title{color:#991b1b!important}[data-theme=dark] .payslip-modal .pmf-block-tax .pmf-block-title{color:#6d28d9!important}[data-theme=dark] .payslip-modal .pmf-subtotal{background:#f8fafc!important;color:#0f172a!important}[data-theme=dark] .payslip-modal .pmf-subtotal .pmf-label{color:#0f172a!important}[data-theme=dark] .payslip-modal .pmf-block-total{background:#f8fafc!important}[data-theme=dark] .payslip-modal .pmf-note{background:#f8fafc!important;color:#64748b!important}[data-theme=dark] .payslip-modal .pmf-total-collected{background:#f0f9ff!important}[data-theme=dark] .payslip-modal .pmf-total-collected .pmf-label,[data-theme=dark] .payslip-modal .pmf-total-collected .pmf-value{color:#0f172a!important}[data-theme=dark] .payslip-modal .pmf-row{color:#1e293b!important}[data-theme=dark] .payslip-modal .pmf-minus .pmf-label{color:#475569!important}[data-theme=dark] .payslip-modal .pmf-residual{background:#f8fafc!important;color:#0f172a!important}[data-theme=dark] .payslip-modal .pmf-moneyflow{border-color:#e2e8f0!important}[data-theme=dark] .payslip-modal .pmf-box-gov{background:#fef3c7!important;color:#92400e!important}[data-theme=dark] .payslip-modal .pmf-box-exp{background:#fee2e2!important;color:#991b1b!important}[data-theme=dark] .payslip-modal .pmf-box-salary{background:#dcfce7!important;color:#14532d!important}[data-theme=dark] .payslip-modal .payslip-section h2{color:#475569!important;border-color:#e2e8f0!important}[data-theme=dark] .payslip-modal .payslip-table thead th{color:#64748b!important;background:#f8fafc!important;border-color:#e2e8f0!important}[data-theme=dark] .payslip-modal .payslip-table tbody tr{border-color:#f1f5f9!important}[data-theme=dark] .payslip-modal .payslip-table tfoot td{background:#f8fafc!important;border-color:#e2e8f0!important}[data-theme=dark] .payslip-modal .payslip-header{border-color:#1e293b!important}[data-theme=dark] .payslip-modal .payslip-header h1,[data-theme=dark] .payslip-modal .payslip-owner strong{color:#0f172a!important}[data-theme=dark] .payslip-modal .payslip-footer{color:#94a3b8!important;border-color:#e2e8f0!important}[data-theme=dark] .payslip-modal .payslip-sum-row{border-color:#f1f5f9!important}[data-theme=dark] .payslip-modal td{color:#1e293b!important}.payslip-actions{display:flex;gap:10px;padding:16px 24px;border-bottom:1px solid #e2e8f0;background:#f8fafc;border-radius:12px 12px 0 0}.payslip-content{padding:32px 40px;color:#1e293b}.payslip-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;padding-bottom:20px;border-bottom:2px solid #1e293b}.payslip-header h1{font-size:22px;font-weight:800;letter-spacing:2px;color:#0f172a}.payslip-period{font-size:15px;color:#64748b;margin-top:4px}.payslip-owner{text-align:right;display:flex;flex-direction:column;gap:3px;font-size:13px;color:#475569}.payslip-owner strong{font-size:15px;color:#0f172a}.payslip-section{margin-bottom:24px}.payslip-section h2{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#475569;border-bottom:1px solid #e2e8f0;padding-bottom:6px;margin-bottom:12px}.payslip-section h3{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:8px}.payslip-table{width:100%;border-collapse:collapse;font-size:13px}.payslip-table thead th{text-align:left;padding:7px 10px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid #e2e8f0;background:#f8fafc}.payslip-table tbody tr{border-bottom:1px solid #f1f5f9}.payslip-table tbody td{padding:7px 10px}.payslip-table tfoot td{padding:8px 10px;font-weight:700;border-top:2px solid #e2e8f0;background:#f8fafc}.payslip-bold{font-weight:700}.payslip-summary-grid{max-width:420px;margin-left:auto}.payslip-sum-row{display:flex;justify-content:space-between;padding:5px 0;font-size:13px;border-bottom:1px solid #f1f5f9}.payslip-sum-row span:last-child{font-family:Courier New,monospace}.payslip-tax{color:#b45309}.payslip-subtotal{font-weight:600;border-top:1px solid #cbd5e1!important;padding-top:8px!important;margin-top:4px}.payslip-grand-total{font-size:15px;font-weight:700;border-top:2px solid #1e293b!important;padding-top:10px!important;margin-top:4px}.payslip-footer{text-align:center;font-size:11px;color:#94a3b8;margin-top:24px;padding-top:16px;border-top:1px solid #e2e8f0}.print-only{display:none}.print-report{padding:32px 40px;font-family:Segoe UI,sans-serif;color:#1e293b;font-size:13px}.print-report-header{margin-bottom:28px;padding-bottom:16px;border-bottom:3px solid #1e293b}.print-report-header h1{font-size:20px;font-weight:800;letter-spacing:1px}.print-report-header p{font-size:13px;color:#475569;margin-top:4px}.print-section{margin-bottom:28px}.print-section h2{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#475569;border-bottom:1px solid #e2e8f0;padding-bottom:6px;margin-bottom:12px}.print-section h3{font-size:11px;font-weight:700;color:#94a3b8;margin-bottom:6px;text-transform:uppercase}.print-payslip-month{page-break-inside:avoid}.receipt-upload-section{margin:16px 0;padding:14px;background:var(--surface-alt);border:1px dashed var(--border);border-radius:8px}.receipt-upload-label{font-size:13px;font-weight:600;color:var(--text-dark);margin-bottom:10px;display:flex;align-items:center;gap:8px}.receipt-upload-hint{font-size:11px;font-weight:400;color:var(--text-muted);background:#fef3c7;border-radius:4px;padding:2px 7px}[data-theme=dark] .receipt-upload-hint{background:#422006;color:#fcd34d}.receipt-upload-btns{display:flex;gap:10px;flex-wrap:wrap}.receipt-camera-btn{font-size:14px}.receipt-preview-wrap{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap}.receipt-preview-img{width:120px;height:90px;object-fit:cover;border-radius:6px;border:2px solid var(--border);cursor:zoom-in;transition:border-color .15s}.receipt-preview-img:hover{border-color:var(--primary)}.receipt-preview-actions{display:flex;flex-direction:column;gap:6px}.receipt-thumb-btn{font-size:15px!important}.receipt-missing{color:var(--text-dim);font-size:12px;padding:0 6px}.receipt-fullview{position:relative;background:#000;border-radius:10px;max-width:92vw;max-height:90vh;overflow:hidden;display:flex;align-items:center;justify-content:center}.receipt-fullview img{max-width:92vw;max-height:88vh;object-fit:contain;display:block}.receipt-fullview-close{position:absolute;top:10px;right:14px;background:#0009;color:#fff;border:none;border-radius:50%;width:32px;height:32px;font-size:16px;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center}.mobile-topbar,.mobile-bottom-nav,.mobile-menu-overlay{display:none}@media (max-width: 768px){.sidebar{display:none!important}.mobile-topbar{display:flex;align-items:center;justify-content:space-between;position:fixed;top:0;left:0;right:0;z-index:200;height:52px;padding:0 16px;background:#1e293b;color:#fff;box-shadow:0 2px 6px #00000040}.mobile-brand{font-size:16px;font-weight:700}.mobile-icon-btn{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:6px 8px;border-radius:6px;line-height:1;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center}.mobile-icon-btn:hover{background:#ffffff1f}.mobile-menu-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#0006}.mobile-menu{position:absolute;top:52px;right:0;background:var(--surface);padding:12px;border-radius:0 0 0 8px;box-shadow:0 4px 16px #00000040;min-width:180px}.app-layout{display:block;padding-top:52px;padding-bottom:64px}.main-content{padding:16px}.mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:200;height:60px;background:#1e293b;border-top:1px solid #334155;box-shadow:0 -2px 8px #0003}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:#94a3b8;text-decoration:none;font-size:10px;transition:color .15s;min-height:60px}.mobile-nav-item.active{color:#60a5fa}.mobile-nav-item:hover{color:#e2e8f0}.mobile-nav-icon{font-size:20px;line-height:1}.mobile-nav-label{font-size:10px;font-weight:500}.page-header{flex-wrap:wrap;gap:10px}.page-header h1{font-size:18px}.card{padding:16px}.stats-row{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:14px 16px}.stat-card .stat-value{font-size:18px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:480px}.modal-backdrop{align-items:flex-end;padding:0;z-index:300}.modal{width:100vw;max-width:100vw;border-radius:16px 16px 0 0;max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px 16px 32px;display:block}.modal h2{padding:0}.modal-body{overflow-y:visible;padding:0}.modal>.form-actions,.modal .form-actions:last-child{margin-top:20px;padding:0;background:none;border-top:none}.form-grid{grid-template-columns:1fr!important}.form-full{grid-column:1!important}.form-grid-3{grid-template-columns:1fr!important}.btn{min-height:42px;padding:10px 16px}.btn-sm{min-height:34px}.receipt-upload-btns{flex-direction:column}.receipt-upload-btns .btn{width:100%;justify-content:center;font-size:15px}.receipt-preview-wrap{flex-direction:column}.receipt-preview-img{width:100%;height:180px}.isp-actions{flex-direction:column;align-items:stretch}.isp-actions .btn{width:100%;justify-content:center}.tax-calc-body{grid-template-columns:1fr!important}.section-title-row{flex-wrap:wrap;gap:8px}}@media print{.no-print,.sidebar{display:none!important}.main-content{padding:0!important}.app-layout{display:block!important}body.printing-annual .accounting-page>*:not(.print-report){display:none!important}body.printing-annual .print-only,body.printing-annual .print-report{display:block!important}body.printing-payslip *{visibility:hidden!important}body.printing-payslip .payslip-modal,body.printing-payslip .payslip-modal *{visibility:visible!important}body.printing-payslip .payslip-modal{position:fixed!important;top:0!important;left:0!important;width:100%!important;max-width:none!important;max-height:none!important;overflow:visible!important;border-radius:0!important;box-shadow:none!important}body.printing-payslip .payslip-actions,body.printing-payslip .payslip-actions *{visibility:hidden!important;height:0!important;overflow:hidden!important;padding:0!important;border:none!important}.payslip-table tbody tr{page-break-inside:avoid}.print-payslip-month{page-break-before:always}}
