.printable-sheet{--brand-primary:#0f766e;--brand-accent:#14b8a6;--brand-ink:#0f172a;--brand-muted:#64748b;--brand-border:#cbd5e1;--brand-bg-soft:#f1f5f9;--brand-success:#15803d;--brand-danger:#b91c1c;color:var(--brand-ink);box-sizing:border-box;border:1px solid var(--brand-border);direction:rtl;background:#fff;border-radius:4px;width:210mm;min-height:297mm;margin:0 auto;padding:18mm 16mm 24mm;font-family:Cairo,Tajawal,IBM Plex Sans Arabic,system-ui,sans-serif;position:relative;box-shadow:0 4px 24px #0f172a14}.printable-sheet__brandbar{border-bottom:3px solid var(--brand-primary);justify-content:space-between;align-items:center;padding-bottom:10mm;display:flex}.printable-sheet__brand-left{flex-direction:column;gap:2mm;display:flex}.printable-sheet__brand-name{color:var(--brand-primary);letter-spacing:-.01em;font-size:18pt;font-weight:700}.printable-sheet__brand-legal{color:var(--brand-muted);font-size:9pt}.printable-sheet__brand-right{text-align:left;flex-direction:column;gap:1.5mm;display:flex}.printable-sheet__doc-title{color:var(--brand-ink);background:var(--brand-bg-soft);border-inline-start:4px solid var(--brand-accent);border-radius:2mm;padding:1.5mm 4mm;font-size:14pt;font-weight:700}.printable-sheet__doc-meta{color:var(--brand-muted);font-variant-numeric:tabular-nums;font-size:9pt}.printable-sheet__body{margin-top:8mm}.printable-sheet__section{margin-bottom:7mm}.printable-sheet__section-title{color:var(--brand-primary);border-bottom:1px solid var(--brand-border);margin-bottom:3mm;padding-bottom:1mm;font-size:11pt;font-weight:700}.printable-sheet__grid-2{grid-template-columns:1fr 1fr;gap:3mm 8mm;display:grid}.printable-sheet__grid-3{grid-template-columns:1fr 1fr 1fr;gap:3mm 6mm;display:grid}.printable-sheet__field{flex-direction:column;gap:.5mm;display:flex}.printable-sheet__label{color:var(--brand-muted);font-size:8.5pt}.printable-sheet__value{color:var(--brand-ink);font-variant-numeric:tabular-nums;font-size:10.5pt;font-weight:600}.printable-sheet__value--mono{font-family:JetBrains Mono,Courier New,monospace}.printable-sheet__value--positive{color:var(--brand-success)}.printable-sheet__value--negative{color:var(--brand-danger)}.printable-sheet__table{border-collapse:collapse;width:100%;margin-top:2mm;font-size:10pt}.printable-sheet__table thead th{background:var(--brand-primary);color:#fff;text-align:start;padding:2mm 3mm;font-size:9.5pt;font-weight:600}.printable-sheet__table tbody td{border-bottom:1px solid var(--brand-border);font-variant-numeric:tabular-nums;padding:1.5mm 3mm}.printable-sheet__table tbody tr:nth-child(2n) td{background:var(--brand-bg-soft)}.printable-sheet__table tfoot td{border-top:2px solid var(--brand-primary);background:#ecfdf5;padding:2.5mm 3mm;font-weight:700}.printable-sheet__totals{background:var(--brand-bg-soft);border-inline-start:4px solid var(--brand-primary);border-radius:2mm;grid-template-columns:1fr auto;gap:2mm 6mm;margin-top:4mm;padding:4mm;display:grid}.printable-sheet__total-row{display:contents}.printable-sheet__total-row>dt{color:var(--brand-muted);font-size:10pt}.printable-sheet__total-row>dd{text-align:end;font-variant-numeric:tabular-nums;font-size:11pt;font-weight:700}.printable-sheet__total-row--grand>dt,.printable-sheet__total-row--grand>dd{color:var(--brand-primary);border-top:1.5px solid var(--brand-primary);padding-top:1.5mm;font-size:13pt}.printable-sheet__signatures{grid-template-columns:1fr 1fr;gap:10mm;margin-top:14mm;display:grid}.printable-sheet__signature-box{border-top:1px dashed var(--brand-border);text-align:center;padding-top:3mm}.printable-sheet__signature-label{color:var(--brand-muted);font-size:9pt}.printable-sheet__signature-name{margin-top:1mm;font-size:10.5pt;font-weight:600}.printable-sheet__footer{bottom:12mm;border-top:1px solid var(--brand-border);color:var(--brand-muted);justify-content:space-between;align-items:center;padding-top:4mm;font-size:8pt;display:flex;position:absolute;inset-inline:16mm}.printable-sheet__qr{align-items:center;gap:3mm;display:flex}.printable-sheet__qr-img{border:1px solid var(--brand-border);background:#fff;border-radius:1.5mm;width:22mm;height:22mm;padding:1mm}.printable-sheet__qr-info{color:var(--brand-muted);text-align:start;font-size:8pt;line-height:1.4}.printable-sheet__qr-info strong{color:var(--brand-ink);font-weight:600}.printable-sheet__stamp{border-radius:2mm;padding:1.5mm 4mm;font-size:10pt;font-weight:700;display:inline-block}.printable-sheet__stamp--approved{color:var(--brand-success);border:1.5px solid var(--brand-success);background:#dcfce7}.printable-sheet__stamp--rejected{color:var(--brand-danger);border:1.5px solid var(--brand-danger);background:#fee2e2}.printable-sheet__stamp--pending{color:#b45309;background:#fef3c7;border:1.5px solid #b45309}.printable-sheet__stamp--paid{color:#0e7490;background:#cffafe;border:1.5px solid #0e7490}.printable-sheet--roster{box-sizing:border-box;width:297mm;min-height:210mm}.roster-summary{grid-template-columns:repeat(4,1fr);gap:3mm;margin-top:2mm;display:grid}.roster-stat{border:1px solid var(--brand-border);border-inline-start:3px solid var(--brand-border);background:#fff;border-radius:2mm;flex-direction:column;gap:1mm;padding:2.5mm 3mm;display:flex}.roster-stat__label{color:var(--brand-muted);font-size:8.5pt}.roster-stat__value{font-variant-numeric:tabular-nums;color:var(--brand-ink);letter-spacing:-.01em;font-size:12pt;font-weight:700}.roster-stat--good{border-inline-start-color:var(--brand-success);background:#f0fdf4}.roster-stat--good .roster-stat__value{color:var(--brand-success)}.roster-stat--bad{border-inline-start-color:var(--brand-danger);background:#fef2f2}.roster-stat--bad .roster-stat__value{color:var(--brand-danger)}.roster-stat--warn{background:#fffbeb;border-inline-start-color:#b45309}.roster-stat--warn .roster-stat__value{color:#b45309}.roster-stat--emphasis{border-inline-start-color:var(--brand-primary);background:#ecfeff}.roster-stat--emphasis .roster-stat__value{color:var(--brand-primary);font-size:13pt}.roster-branch{break-inside:avoid;page-break-inside:avoid;margin-bottom:6mm}.roster-branch__head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:3mm;margin-bottom:1.5mm;display:flex}.roster-branch__title{font-size:12pt;border-bottom:none!important;margin-bottom:0!important;padding-bottom:0!important}.roster-branch__chip{color:var(--brand-primary);background:var(--brand-bg-soft);font-variant-numeric:tabular-nums;border:1px solid var(--brand-border);border-radius:2mm;padding:1mm 3mm;font-size:9pt;font-weight:600}.roster-table{table-layout:fixed;border-collapse:collapse;width:100%;margin-top:2mm;font-size:9pt!important}.roster-table thead th{white-space:nowrap;text-align:center;padding:2mm 2.5mm!important;font-size:9pt!important}.roster-table thead th:nth-child(2){text-align:start}.roster-table tbody td,.roster-table tfoot td{vertical-align:middle;padding:1.8mm 2.5mm!important;font-size:9.5pt!important}.roster-table tbody td:not(:nth-child(2)),.roster-table tfoot td:not(:nth-child(2)){white-space:nowrap}.roster-table col.roster-col-name,.roster-table th.roster-col-name,.roster-table td.roster-col-name{width:28%;min-width:45mm}.roster-table tbody tr:nth-child(2n) td{background:#f8fafc!important}.roster-table tfoot td{color:var(--brand-primary)!important;border-top:1.5px solid var(--brand-primary)!important;background:#ecfeff!important;border-bottom:none!important;font-weight:700!important}.roster-employee{flex-direction:column;gap:.7mm;line-height:1.25;display:flex}.roster-employee__name{color:var(--brand-ink);white-space:normal;word-break:break-word;font-size:10pt;font-weight:700}.roster-employee__role{color:var(--brand-muted);white-space:nowrap;font-size:8pt}.roster-num{text-align:center;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.roster-pos{color:var(--brand-success)}.roster-neg{color:var(--brand-danger)}.roster-warn{color:#b45309}.roster-net{color:var(--brand-ink);font-weight:700;background:#f0f9ff!important}.roster-table tbody tr:nth-child(2n) td.roster-net{background:#e0f2fe!important}.printable-sheet-viewport{background:#e2e8f0;flex-direction:column;align-items:center;min-height:100vh;padding:8mm;display:flex}.printable-sheet-toolbar{justify-content:flex-end;gap:2mm;width:210mm;max-width:100%;margin-bottom:4mm;display:flex}@media print{@page{size:A4 portrait;margin:0}@page rosterPage{size:297mm 210mm;margin:8mm 10mm 10mm}html,body{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#fff!important;margin:0!important;padding:0!important}.printable-sheet-viewport{background:#fff!important;padding:0!important}.printable-sheet-toolbar,.print-hide{display:none!important}.printable-sheet{page-break-after:always;box-shadow:none!important;border:none!important;margin:0!important}.printable-sheet:last-child{page-break-after:auto}.printable-sheet.printable-sheet--roster{page:rosterPage;page-break-after:auto!important;box-sizing:border-box!important;width:100%!important;max-width:none!important;min-height:0!important;padding:0!important}.printable-sheet--roster .printable-sheet__footer{break-inside:avoid;page-break-inside:avoid;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;margin-top:4mm!important}.printable-sheet--roster .printable-sheet__qr,.printable-sheet--roster .printable-sheet__qr svg{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.printable-sheet--roster .roster-table{table-layout:fixed!important;width:100%!important;max-width:100%!important}}
