:root{--blue: #0b3d91;--blue-2: #1457c8;--bg: #eef2f7;--panel: #ffffff;--ink: #14202e;--muted: #6b7a8d;--ok: #1f9d57;--bad: #cc2e2e;--line: #dde4ee}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--ink)}.muted{color:var(--muted);font-weight:400}.error{background:#fdecec;color:var(--bad);border:1px solid #f3c4c4;padding:10px 12px;border-radius:8px;font-size:14px}button{font:inherit;cursor:pointer;border-radius:10px;border:1px solid transparent}button:disabled{opacity:.55;cursor:not-allowed}.primary{background:var(--blue-2);color:#fff;padding:12px 18px;font-weight:600}.primary:hover:not(:disabled){background:var(--blue)}.ghost{background:transparent;border:1px solid var(--line);color:var(--ink);padding:8px 14px}.ghost:hover{background:#f4f7fb}.big{font-size:18px;padding:16px 20px;width:100%}.role-pill{background:#eaf0fb;color:var(--blue);border-radius:999px;padding:2px 10px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.role-pill.small{font-size:10px;padding:1px 8px}.login-screen{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,var(--blue),#08245a)}.login-card{background:var(--panel);width:min(420px,92vw);padding:32px;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;gap:16px}.login-title{margin:0 0 8px;font-size:24px}.login-card label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:600}.login-card input,.field select{padding:12px;border:1px solid var(--line);border-radius:10px;font-size:16px}.hint{font-size:13px;color:var(--muted);text-align:center;margin:4px 0 0}.topbar{display:flex;align-items:center;gap:16px;background:var(--blue);color:#fff;padding:12px 20px}.brand{display:flex;align-items:center;gap:12px;font-weight:700;font-size:18px}.brand-logo{height:30px;width:auto;display:block;background:#fff;padding:4px 6px;border-radius:8px}.brand-sub{font-weight:700}.brand .muted{color:#b9cdf0}.station-tag{margin-left:8px;background:#ffffff24;padding:6px 12px;border-radius:8px;font-size:14px}.user-box{margin-left:auto;display:flex;align-items:center;gap:10px}.user-name{font-weight:600}.topbar .role-pill{background:#fff3;color:#fff}.topbar .ghost{color:#fff;border-color:#fff6}.content{padding:20px}.station1{display:grid;gap:16px;grid-template-columns:1.1fr 1fr;grid-template-areas:"gen result" "units result";max-width:1100px;margin:0 auto}.generate-panel{grid-area:gen}.result-panel{grid-area:result}.units-panel{grid-area:units}.panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px}.panel h2{margin:0 0 14px;font-size:17px}.field{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:14px;margin-bottom:14px}.spec-preview{background:#f6f9fd;border:1px solid var(--line);border-radius:10px;padding:12px;margin-bottom:16px;display:grid;gap:6px;font-size:14px}.spec-preview .k{color:var(--muted);display:inline-block;width:110px}.spec-preview .v{font-weight:600}.dummy-note{color:#b58100;font-size:12px;font-style:italic}.model-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;max-height:300px;overflow:auto;padding:2px;margin-bottom:16px}.model-card{display:flex;flex-direction:column;gap:2px;text-align:left;background:#fff;border:1px solid var(--line);padding:10px 12px;min-height:56px}.model-card:hover{border-color:var(--blue-2);background:#f4f7fb}.model-card.selected{border-color:var(--blue-2);background:#eaf0fb;box-shadow:inset 0 0 0 2px #1457c859}.model-card .mc-code{font-weight:800;font-size:15px}.model-card .mc-name{color:var(--muted);font-size:12px}.qty-heading{margin-top:4px}.qty-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:16px}.qty-btn{width:48px;height:48px;font-size:26px;line-height:1;font-weight:700;background:#fff;border:1px solid var(--line);color:var(--blue)}.qty-btn:hover:not(:disabled){background:#eaf0fb;border-color:var(--blue-2)}.qty-input{width:84px;height:48px;text-align:center;font-size:20px;font-weight:700;border:1px solid var(--line);border-radius:10px}.qty-chips{display:flex;gap:6px;margin-left:4px}.chip{padding:8px 14px;border:1px solid var(--line);background:#fff;border-radius:999px;font-size:14px;font-weight:600}.chip.active{background:#eaf0fb;border-color:var(--blue-2);color:var(--blue)}.generate-btn{margin-top:4px}.qr-bulk{width:100%;display:flex;flex-direction:column;gap:14px}.bulk-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.qr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(116px,1fr));gap:12px;max-height:420px;overflow:auto;padding:2px}.qr-cell{display:grid;justify-items:center;gap:6px;background:#fff;border:1px solid var(--line);padding:10px}.qr-cell:hover{border-color:var(--blue-2);background:#f4f7fb}.qr-cell .serial-sm{font-size:13px;font-weight:800;font-family:monospace}.result-panel{display:grid;place-items:center}.qr-result{text-align:center;display:grid;gap:8px;justify-items:center}.qr-result .serial{font-size:24px;font-weight:800;letter-spacing:.04em;font-variant-numeric:tabular-nums}.qr-result .model-line{color:var(--muted)}.qr-result .actions{display:flex;gap:10px;margin-top:8px}.empty{color:var(--muted);padding:24px;text-align:center}.units-list{display:flex;flex-direction:column;gap:8px;max-height:320px;overflow:auto}.unit-row{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);padding:10px 12px;text-align:left}.unit-row:hover{background:#f4f7fb}.u-serial{font-weight:700;font-variant-numeric:tabular-nums}.u-model{color:var(--muted);margin-left:auto}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#08142880;display:grid;place-items:center;z-index:20;padding:16px}.modal{background:#fff;border-radius:14px;width:min(560px,95vw);max-height:85vh;overflow:auto;padding:20px}.modal-head{display:flex;align-items:center;justify-content:space-between}.detail-top{margin:8px 0 16px;display:grid;gap:4px}.detail-top .serial{font-size:22px;font-weight:800}.timeline{list-style:none;padding:0;margin:0;display:grid;gap:10px}.tl-item{border-left:3px solid var(--ok);padding:8px 12px;background:#f6f9fd;border-radius:0 10px 10px 0}.tl-item.fail{border-left-color:var(--bad)}.tl-station{font-weight:700}.tl-meta{font-size:13px;color:var(--muted)}.station-tag.clickable{cursor:pointer;border:1px solid rgba(255,255,255,.3)}.station-tag.clickable:hover{background:#ffffff3d}.picker{max-width:900px;margin:0 auto}.picker h2{margin:8px 0 4px}.station-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:16px}.station-card{display:grid;gap:4px;text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px}.station-card:hover{border-color:var(--blue-2);background:#f4f7fb}.sc-order{width:32px;height:32px;border-radius:8px;background:var(--blue);color:#fff;display:grid;place-items:center;font-weight:800}.sc-name{font-weight:700;font-size:16px;margin-top:6px}.sc-code{color:var(--muted);font-size:12px;font-family:monospace}.capture{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}.scan-screen{max-width:520px}.scan-panel{text-align:center}.scan-input{width:100%;padding:14px 16px;font-size:20px;font-weight:700;letter-spacing:.03em;border:2px solid var(--line);border-radius:12px;margin:12px 0;text-align:center}.scan-input:focus{outline:none;border-color:var(--blue-2)}.unit-banner{display:flex;align-items:center;justify-content:space-between}.unit-banner .serial{font-size:22px;font-weight:800}.block-notice{background:#fdf3e6;border:1px solid #f0cd9b;color:#8a5a00;padding:14px 16px;border-radius:12px;font-size:16px}.block-notice.ok{background:#e9f8ef;border-color:#b6e3c8;color:var(--ok)}.guidance h3,.compressor-panel h3,.checks h3{margin:0 0 12px;font-size:16px}.g-grid{display:grid;gap:8px;font-size:15px}.g-grid .k{color:var(--muted);display:inline-block;width:120px}.g-grid .v{font-weight:600}.g-grid .v.hl{background:#fff3bf;padding:1px 8px;border-radius:6px}.compressor-panel{border-color:var(--blue-2)}.override-row{display:flex;align-items:flex-start;gap:8px;margin-top:10px;font-size:13px;color:var(--muted)}.check-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--line)}.check-row:last-child{border-bottom:none}.cr-label{font-weight:600}.cr-label .req{color:var(--bad);margin-left:3px}.cr-unit{color:var(--muted);font-weight:400;margin-left:6px;font-size:13px}.cr-control{display:flex;align-items:center;gap:10px}.toggle{display:flex;gap:6px}.tg{padding:10px 18px;border:1px solid var(--line);background:#fff;font-weight:700;min-width:70px}.tg:hover{border-color:var(--blue-2)}.tg.on-ok{background:var(--ok);color:#fff;border-color:var(--ok)}.tg.on-bad{background:var(--bad);color:#fff;border-color:var(--bad)}.value-control{display:flex;align-items:center;gap:10px}.val-input{width:130px;padding:10px;font-size:18px;font-weight:700;text-align:center;border:2px solid var(--line);border-radius:10px}.val-input.good{border-color:var(--ok)}.val-input.bad{border-color:var(--bad)}.ir{font-size:12px;font-weight:700}.ir.ok{color:var(--ok)}.ir.bad{color:var(--bad)}.text-input{width:220px;padding:10px;border:1px solid var(--line);border-radius:10px}.capture-actions{display:flex;align-items:center;gap:14px}.capture-actions .big{width:auto;min-width:240px}.result-banner{border-radius:14px;padding:18px 20px;color:#fff}.result-banner.ok{background:var(--ok)}.result-banner.bad{background:var(--bad)}.rb-head{font-size:20px;font-weight:800}.rb-serial{font-size:16px;font-family:monospace;opacity:.9}.result-items{list-style:none;padding:0;margin:0;display:grid;gap:6px}.result-items li{display:flex;justify-content:space-between;padding:10px 14px;border-radius:10px;background:#f6f9fd;border-left:3px solid var(--ok)}.result-items li.bad{border-left-color:var(--bad)}.result-items li.warn{border-left-color:#d9a300}.evidence-panel h3{margin:0 0 12px;font-size:16px}.file-drop{display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:1px dashed var(--blue-2);border-radius:10px;padding:12px 18px;background:#f4f7fb}.file-drop input{display:none}.file-drop span{font-weight:700;color:var(--blue)}.evidence-list{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:6px}.evidence-list li{display:flex;align-items:center;gap:10px;background:#f6f9fd;border:1px solid var(--line);border-radius:8px;padding:8px 12px}.ev-name{font-weight:600}.evidence-list .muted{margin-left:auto}.ev-remove{border:none;background:transparent;color:var(--bad);font-weight:800;cursor:pointer}.detail-section{margin-top:18px}.detail-section h4{margin:0 0 8px;font-size:14px}.kv-list{list-style:none;padding:0;margin:0;display:grid;gap:6px}.kv-list li{display:flex;align-items:center;gap:10px;background:#f6f9fd;border-radius:8px;padding:8px 12px}.kv-list li>:last-child{margin-left:auto}.kv-list .mono,.mono{font-family:monospace}.role-pill.warn{background:#fdf0d8;color:#9a6700}.small-btn{padding:4px 12px;font-size:13px}.role-pill.packed{background:var(--ok);color:#fff}.dash-card{border-style:dashed;border-color:var(--blue-2)}.dash-card .sc-order{background:#0b3d91}.dashboard{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}.kpi{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;text-align:center}.kpi-value{font-size:34px;font-weight:800;line-height:1.1}.kpi-label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;margin-top:4px}.kpi.ok .kpi-value{color:var(--ok)}.kpi.bad .kpi-value{color:var(--bad)}.kpi.warn .kpi-value{color:#b8860b}.station-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.station-tile{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px}.station-tile.active{border-color:var(--blue-2);box-shadow:inset 0 0 0 2px #1457c826}.st-order{width:28px;height:28px;border-radius:8px;background:var(--blue);color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px}.st-name{font-weight:700;margin:8px 0;font-size:14px;min-height:34px}.st-stats{display:flex;gap:18px}.st-wip,.st-done{display:flex;flex-direction:column;font-size:24px;font-weight:800;line-height:1}.st-wip{color:var(--blue)}.st-wip small,.st-done small{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;margin-top:2px}.dash-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dash-list{list-style:none;padding:0;margin:0;display:grid;gap:6px;max-height:320px;overflow:auto}.dash-list li{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#f6f9fd;border-radius:8px}.dash-list li>:last-child{margin-left:auto}.dash-foot{text-align:right;font-size:12px}@media (max-width: 760px){.dash-cols{grid-template-columns:1fr}}.print-label{display:none}@media print{body *{visibility:hidden}.print-label,.print-label *{visibility:visible}.print-label{display:grid;grid-template-columns:repeat(2,1fr);gap:8mm;position:absolute;top:0;left:0;width:100%;padding:8mm}.p-label{break-inside:avoid;text-align:center;display:grid;justify-items:center;gap:3px;border:1px dashed #999;padding:5mm}.p-label .pl-serial{font-size:13pt;font-weight:800;font-family:monospace}.p-label .pl-model{font-size:10pt}}@media (max-width: 760px){.station1{grid-template-columns:1fr;grid-template-areas:"gen" "result" "units"}}
