: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{align-items:stretch;min-height:100vh;display:flex}.app-main{flex:1;justify-content:center;align-items:flex-start;padding:48px 24px;display:flex;overflow:auto}.sidebar{background:#2a0a4a url(./sidebar-bg-BntuoGPm.png) 50%/cover no-repeat;border-right:1px solid #1c0632;flex-direction:column;flex-shrink:0;align-self:flex-start;gap:22px;width:208px;height:100vh;padding:20px 14px;display:flex;position:sticky;top:0}.sb-logo{justify-content:center;padding:6px 0 2px;display:flex}.sb-logo img{object-fit:contain;width:100%;max-width:160px;height:auto}.sb-nav{flex-direction:column;gap:4px;margin-top:24px;display:flex}.sb-item{width:100%;font:inherit;text-align:left;color:#cfcfcf;cursor:pointer;background:0 0;border:0;border-radius:8px;align-items:center;gap:11px;padding:9px 11px;font-size:13.5px;transition:background .12s,color .12s;display:flex}.sb-item:hover{color:#fff;background:#ffffff1f}.sb-item .sb-ic{color:#fff;flex-shrink:0;width:20px;height:20px}.sb-item:hover .sb-ic{color:#fff}.sb-danger{margin-top:6px}.sb-danger:hover{color:#ffb3b3;background:#c81e1e59}.sb-danger:hover .sb-ic{color:#ffb3b3}.sb-foot{text-align:center;color:#6f6f6f;letter-spacing:.3px;margin-top:auto;font-size:12px}.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}.help-list{flex-direction:column;gap:14px;display:flex;overflow-y:auto}.help-item h3{color:#c07bff;margin:0 0 3px;font-size:14px}.help-item p{color:#cfcfcf;margin:0;font-size:13px;line-height:1.5}.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}.sidebar,.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) .app-main{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}
