:root,[data-theme=light]{--bg:#fff;--card:#fff;--ink:#111;--muted:#6b6b6b;--line:#e3e3e3;--line-strong:#111;--field-bg:#fff;--topbar-bg:#111;--topbar-ink:#fff;--btn-bg:#111;--btn-ink:#fff;--btn-bg-hover:#000;--chip-bg:#f2f2f2;--danger:#c0392b;--ok:#1e8e5a;--warn:#9a6a00;--radius:10px}[data-theme=dark]{--bg:#0e0e0e;--card:#1a1a1a;--ink:#f3f3f3;--muted:#9a9a9a;--line:#2c2c2c;--line-strong:#f3f3f3;--field-bg:#161616;--topbar-bg:#000;--topbar-ink:#f3f3f3;--btn-bg:#f3f3f3;--btn-ink:#111;--btn-bg-hover:#fff;--chip-bg:#242424;--danger:#ff6b5e;--ok:#5ccf9b;--warn:#d9b04a}*{box-sizing:border-box}.toast-wrap{position:fixed;bottom:20px;right:20px;z-index:1100;flex-direction:column}.toast,.toast-wrap{display:flex;gap:10px}.toast{align-items:center;background:var(--card);color:var(--ink);border:1px solid var(--line);border-left:4px solid var(--ok);border-radius:var(--radius);box-shadow:0 8px 28px rgba(0,0,0,.22);padding:12px 16px;min-width:220px;max-width:360px;font-size:14px;cursor:pointer;animation:toast-in .18s ease-out}.toast-check{color:var(--ok);font-weight:700}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;background:rgba(0,0,0,.45);animation:modal-fade .12s ease-out}.modal{width:100%;max-width:420px;background:var(--card);color:var(--ink);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 16px 48px rgba(0,0,0,.3);padding:22px 22px 18px;animation:modal-pop .12s ease-out}.modal-title{margin:0 0 8px;font-size:18px}.modal-body{margin:0 0 20px;color:var(--muted);line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:10px}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}@keyframes modal-pop{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:none}}body,html{margin:0;padding:0;background:var(--bg);font-family:Segoe UI,Noto Sans Khmer,Khmer OS,system-ui,-apple-system,Arial,sans-serif;font-size:15px;line-height:1.5;transition:background .15s ease,color .15s ease}a,body,html{color:var(--ink)}a{text-decoration:underline;text-underline-offset:2px}a:hover{opacity:.7}.km{font-family:Noto Sans Khmer,Khmer OS,Khmer OS Battambang,sans-serif}.topbar{background:var(--topbar-bg);padding:12px 20px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}.topbar,.topbar a{color:var(--topbar-ink)}.topbar a{font-weight:500;text-decoration:none}.topbar a:hover{opacity:.75}.topbar .brand{font-weight:700;font-size:18px;margin-right:auto}.nav-links{display:flex;align-items:center;gap:20px}.nav-toggle{display:none;align-items:center;justify-content:center;width:40px;height:34px;padding:0;border-radius:8px;background:transparent;border:1px solid hsla(0,0%,100%,.4);color:var(--topbar-ink);cursor:pointer}.nav-toggle:hover{background:hsla(0,0%,100%,.12)}@media (max-width:860px){.nav-toggle{display:inline-flex}.nav-links{display:none;flex-direction:column;align-items:stretch;gap:0;width:100%}.nav-links.open{display:flex}.nav-links a{padding:11px 4px;width:100%;border-top:1px solid hsla(0,0%,100%,.14)}.nav-links .theme-toggle{margin:10px 0 2px;align-self:flex-start}}.container{max-width:920px;margin:24px auto;padding:0 16px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;margin-bottom:18px}.row{display:flex;gap:14px;flex-wrap:wrap}.row>*{flex:1 1;min-width:160px}h1{font-size:22px;margin:0 0 14px}h2{font-size:17px;margin:0 0 12px}.muted{color:var(--muted)}label{display:block;font-size:13px;font-weight:600;margin-bottom:4px;color:var(--ink)}label.req:after{content:"*";color:var(--danger);margin-left:4px;font-weight:700}.req-note{font-size:12px;color:var(--muted)}.req-note b{color:var(--danger)}input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font:inherit;background:var(--field-bg);color:var(--ink)}input:focus,select:focus,textarea:focus{outline:2px solid var(--ink);outline-offset:-1px;border-color:var(--ink)}input:required:invalid,textarea:required:invalid{border-color:var(--danger)}.field{margin-bottom:14px}.checkbox{display:flex;align-items:center;gap:8px}.checkbox input{width:auto}.btn{display:inline-block;background:var(--btn-bg);color:var(--btn-ink);border:1px solid var(--btn-bg);border-radius:8px;padding:10px 18px;font:inherit;font-weight:600;cursor:pointer}.btn:hover{background:var(--btn-bg-hover);border-color:var(--btn-bg-hover);text-decoration:none}.btn.secondary{background:transparent;color:var(--ink);border:1px solid var(--line-strong)}.btn.secondary:hover{background:var(--chip-bg)}.topbar .btn.secondary{color:var(--topbar-ink);border-color:hsla(0,0%,100%,.45)}.topbar .btn.secondary:hover{background:hsla(0,0%,100%,.14);border-color:hsla(0,0%,100%,.7)}.btn.small{padding:6px 12px;font-size:13px}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0;border-radius:8px;background:transparent;border:1px solid hsla(0,0%,100%,.4);color:var(--topbar-ink);cursor:pointer}.theme-toggle:hover{background:hsla(0,0%,100%,.12)}.theme-toggle svg{width:18px;height:18px}table{width:100%;border-collapse:collapse}td,th{text-align:left;padding:9px 8px;border-bottom:1px solid var(--line);font-size:14px}th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em}td.num,th.num{text-align:right}.pill{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid var(--line-strong)}.pill.draft{background:transparent;color:var(--muted);border-color:var(--line)}.pill.sent{background:transparent;color:var(--ink)}.pill.paid{background:var(--ink);color:var(--bg)}.pill.overdue{background:transparent;color:var(--danger);border-color:var(--danger)}.stats{display:flex;gap:14px;flex-wrap:wrap}.stat{flex:1 1;min-width:150px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px}.stat .v{font-size:24px;font-weight:700}.stat .k{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.doc{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:32px}.doc-head{display:flex;justify-content:space-between;gap:20px;border-bottom:2px solid var(--line-strong);padding-bottom:16px;margin-bottom:18px}.doc-title{font-size:26px;font-weight:800;color:var(--ink);letter-spacing:.04em}.totals{margin-left:auto;width:320px}.totals td{border:none;padding:4px 0}.totals .grand td{border-top:2px solid var(--ink);font-size:18px;font-weight:700;padding-top:8px}.khqr-box{text-align:center;border:1px dashed var(--line-strong);border-radius:10px;padding:14px;width:200px}.khqr-box img{width:170px;height:170px}@media print{.no-print,.topbar{display:none!important}body,html{background:#fff!important;color:#000!important}.container{margin:0;max-width:none}.doc{border:none;border-radius:0;padding:0;background:#fff!important;color:#000!important}}