:root{--sheet-bg:#1a1a1a;--grid-line:#cfcfcf;--zebra-col:#f2f2f2;--zebra-row:#f6f6f6;--zebra-both:#eaeaea;--total-bg:#dcdcdc;--bad-bg:#ffd6d6;--bad-fg:#c00}*{box-sizing:border-box}body{color:#eee;background:#2b2b2b;margin:0;font-family:system-ui,-apple-system,sans-serif}.app{flex-direction:column;align-items:center;gap:28px;min-height:100vh;padding:64px 12px 48px;display:flex}.toolbar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.toolbar button,.toolbar .upload{font:inherit;color:#eee;cursor:pointer;background:#3a3a3a;border:1px solid #555;border-radius:6px;padding:7px 12px;font-size:13px}.toolbar button:hover,.toolbar .upload:hover{background:#474747}.toolbar .upload{align-items:center;display:inline-flex}.modal-backdrop{z-index:100;background:#0009;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{color:#eee;background:#2f2f2f;border:1px solid #555;border-radius:10px;flex-direction:column;gap:12px;width:min(560px,100%);max-height:90vh;padding:20px;display:flex}.modal h2{margin:0;font-size:18px}.modal-hint{color:#aaa;margin:0;font-size:13px}.import-text{resize:vertical;color:#eee;background:#1e1e1e;border:1px solid #555;border-radius:6px;width:100%;min-height:260px;padding:10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;line-height:1.4}.modal-actions{justify-content:flex-end;gap:8px;display:flex}.modal-actions button{font:inherit;color:#eee;cursor:pointer;background:#3a3a3a;border:1px solid #555;border-radius:6px;padding:8px 16px;font-size:13px}.modal-actions button.primary{color:#10240f;background:#3bb54a;border-color:#3bb54a;font-weight:700}.sheet{background:var(--sheet-bg);color:#fff;border-radius:4mm;flex-direction:column;width:87mm;height:187mm;font-family:system-ui,sans-serif;display:flex;overflow:hidden;box-shadow:0 4px 24px #00000073}.s-top{height:26mm;display:flex}.s-logo{justify-content:center;align-items:center;width:33mm;display:flex}.logo-img{object-fit:contain;max-width:82%;max-height:74%}.s-heads{background:#fff;flex:1;align-items:stretch;display:flex}.mh{writing-mode:vertical-rl;color:#222;white-space:nowrap;text-transform:uppercase;border-left:.2mm solid #ccc;flex:1;justify-content:flex-start;align-items:center;height:26mm;padding:1mm 0;font-size:2.4mm;font-weight:600;display:flex;position:relative;overflow:hidden;transform:rotate(180deg)}.mh.even{background:#ededed}.s-row{min-width:0;display:flex}.s-side{background:var(--sheet-bg);color:#fff;writing-mode:vertical-rl;letter-spacing:.6mm;justify-content:flex-end;align-items:center;width:5mm;padding-bottom:1.5mm;font-size:2.6mm;font-weight:800;display:flex;transform:rotate(180deg)}table.g{border-collapse:collapse;color:#222;table-layout:fixed;background:#fff;flex:1;width:100%;min-width:0}table.g td{border:.2mm solid var(--grid-line);height:var(--row-h,4.6mm);text-align:center;vertical-align:middle;font-size:2.3mm}table.g td.q{color:#999;width:5mm}table.g td.n{white-space:nowrap;text-align:left;width:23mm;padding-left:1.2mm;font-size:2.2mm;font-weight:600;overflow:hidden}td.c.even{background:var(--zebra-col)}tr.odd td.n,tr.odd td.q,tr.odd td.c{background:var(--zebra-row)}tr.odd td.c.even{background:var(--zebra-both)}tr.total td{font-weight:800;background:var(--total-bg)!important}tr.total td.bad{color:var(--bad-fg);background:var(--bad-bg)!important}.sheet-wrap{width:87mm;margin:0 auto;position:relative}.del-layer{opacity:0;pointer-events:none;width:100%;height:100%;transition:opacity .12s;position:absolute;top:0;left:0}.sheet-wrap:hover .del-layer{opacity:1}.del-row{width:5mm;height:var(--row-h,4.6mm);color:#b00;cursor:pointer;pointer-events:auto;background:0 0;border:0;justify-content:center;align-items:center;padding:0;font-size:3.4mm;line-height:1;display:flex;position:absolute;left:-6.5mm}.del-row:hover{color:red}.q-input,.n-input,.c-input,.mh-input{box-sizing:border-box;width:100%;min-width:0;font:inherit;color:inherit;text-transform:inherit;background:0 0;border:0;outline:none;padding:0}.c-input,.q-input{text-align:center}.n-input{text-align:left}.mh-input{writing-mode:vertical-rl;text-align:left;height:100%}.c-input:focus,.n-input:focus,.q-input:focus,.mh-input:focus{background:#eef6ff}@page{size:87mm 187mm;margin:0}@media print{body{background:#fff}.toolbar,.del-layer{display:none!important}input::placeholder{color:#0000!important;opacity:0!important}tr.total td.bad{background:var(--total-bg)!important;color:inherit!important}*{-webkit-print-color-adjust:exact;print-color-adjust:exact}body:not(.blanks) .app{gap:0;min-height:0;padding:0}body:not(.blanks) *{visibility:hidden}body:not(.blanks) .sheet,body:not(.blanks) .sheet *{visibility:visible}body:not(.blanks) .sheet{box-shadow:none;border-radius:0;position:absolute;top:0;left:0}body.blanks .app{display:none}body.blanks .print-blanks{display:flex}}.print-blanks{flex-direction:row;justify-content:center;align-items:center;gap:3mm;width:11in;height:8.5in;display:none}.print-blanks .sheet{box-shadow:none;border-radius:0}
