*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px}body{font-family:IBM Plex Sans,system-ui,sans-serif;background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased}:root{--bg: #f4f6f8;--panel: #ffffff;--ink: #161a1f;--muted: #6a7480;--primary: #2563d4;--primary-soft: #e9f0fc;--primary-hover: #1a4db3;--overs: #2c83c9;--overs-soft: #e4f0fa;--unders: #7857e6;--unders-soft: #ece7fc;--pc: #5a6573;--pc-soft: #eceef1;--test: #0d8a86;--test-soft: #def2f1;--feed: #4a7c2f;--feed-soft: #e7f1de;--ok: #1f9b66;--ok-soft: #e1f4eb;--warn: #c4810c;--warn-soft: #faefd6;--bad: #d83c3c;--bad-soft: #fbe4e4;--border: #e6e9ed;--border-2: #d7dce2;--sans: "IBM Plex Sans", system-ui, sans-serif;--mono: "IBM Plex Mono", "Fira Mono", monospace;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--radius-xl: 20px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow: 0 4px 12px rgba(0,0,0,.08), 0 1px 4px rgba(0,0,0,.04);--shadow-lg: 0 12px 32px rgba(0,0,0,.12), 0 2px 8px rgba(0,0,0,.06);--shadow-xl: 0 24px 64px rgba(0,0,0,.16);--ink-2: #39424d;--faint: #99a2ad;--border-strong: #c5ccd4;--panel-2: #fafbfc;--panel-3: #f5f7f9;--bg-grid: #eef1f4;--primary-700: #1d4fad;--primary-soft-2: #dce8fb;--sh-1: 0 1px 2px rgba(20,26,31,.04), 0 1px 3px rgba(20,26,31,.06);--sh-2: 0 2px 6px rgba(20,26,31,.06), 0 1px 3px rgba(20,26,31,.04);--sh-3: 0 4px 16px rgba(20,26,31,.1), 0 1px 4px rgba(20,26,31,.06);--r-sm: 7px;--r: 10px;--r-lg: 14px;--r-xl: 20px}.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.sidebar{background:#11151b;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;flex-shrink:0}.brand{display:flex;align-items:center;gap:10px;padding:20px 16px 16px;border-bottom:1px solid rgba(255,255,255,.06)}.brand-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#2563d4 0%,#7857e6 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;font-weight:700;color:#fff;letter-spacing:-.5px}.brand-name{font-size:14px;font-weight:600;color:#fff;letter-spacing:.01em}.brand-sub{font-size:10px;color:#fff6;font-weight:400;letter-spacing:.08em;text-transform:uppercase}.nav-group{padding:16px 0 8px}.nav-group+.nav-group{border-top:1px solid rgba(255,255,255,.06)}.nav-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#ffffff47;padding:4px 16px 6px}.nav-item{display:flex;align-items:center;gap:9px;padding:7px 14px;margin:1px 8px;border-radius:8px;cursor:pointer;color:#ffffff8c;font-size:13.5px;font-weight:450;transition:background .12s,color .12s;position:relative;text-decoration:none;border:none;background:transparent;width:calc(100% - 16px);text-align:left}.nav-item:hover{background:rgba(255,255,255,.07);color:#ffffffd9}.nav-item.active{background:#215ad0;color:#fff}.nav-item .icon{opacity:.7;flex-shrink:0}.nav-item.active .icon{opacity:1}.nav-badge{margin-left:auto;background:rgba(255,255,255,.15);color:#ffffffb3;font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.nav-badge.alert{background:var(--bad);color:#fff}.sidebar-foot{margin-top:auto;padding:12px 8px;border-top:1px solid rgba(255,255,255,.06)}.user-chip{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .12s}.user-chip:hover{background:rgba(255,255,255,.06)}.avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#2c83c9 0%,#7857e6 100%);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.user-name{font-size:12.5px;font-weight:500;color:#ffffffb3}.user-role{font-size:10.5px;color:#ffffff59}.main{display:flex;flex-direction:column;min-height:100vh;overflow:hidden}.topbar{height:60px;background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:40;flex-shrink:0}.crumb{display:flex;align-items:center;gap:6px;flex:1}.crumb-group{font-size:12px;color:var(--muted);font-weight:400}.crumb-sep{color:var(--border-2);font-size:14px}.crumb-page{font-size:14px;font-weight:600;color:var(--ink)}.searchbox{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:6px 10px;width:240px;transition:border-color .15s,box-shadow .15s}.searchbox:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #2563d41f;background:#fff}.searchbox input{border:none;background:transparent;font-family:var(--sans);font-size:13px;color:var(--ink);outline:none;width:100%}.searchbox input::placeholder{color:var(--muted)}.search-kbd{font-family:var(--mono);font-size:10px;background:var(--border);color:var(--muted);padding:1px 4px;border-radius:4px;white-space:nowrap}.icon-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:var(--panel);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);transition:background .12s,color .12s,border-color .12s;flex-shrink:0}.icon-btn:hover{background:var(--bg);color:var(--ink);border-color:var(--border-2)}.icon-btn.alert-active{color:var(--bad);border-color:var(--bad-soft);background:var(--bad-soft)}.content{flex:1;overflow-y:auto;padding:28px;background:var(--bg)}.screen{min-height:100%}.content-narrow{max-width:1280px;margin:0 auto}.page-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.page-head-left{display:flex;flex-direction:column;gap:3px}.page-title{font-size:22px;font-weight:700;color:var(--ink);letter-spacing:-.02em;line-height:1.2}.page-sub{font-size:13px;color:var(--muted);font-weight:400}.page-actions{display:flex;align-items:center;gap:8px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);animation:fadeInUp .18s ease;overflow:hidden}.card-head{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);gap:12px}.card-title{font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-.01em}.card-sub{font-size:12px;color:var(--muted);font-weight:400;margin-top:2px}.card-pad{padding:20px}.card-actions{display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;border:1px solid var(--border-2);border-radius:8px;font-family:var(--sans);font-size:13.5px;font-weight:500;color:var(--ink);background:var(--panel);cursor:pointer;transition:background .12s,border-color .12s,box-shadow .12s;text-decoration:none;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:hover{background:var(--bg);border-color:var(--border-2);box-shadow:var(--shadow-sm)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-sm{padding:4px 10px;font-size:12.5px;border-radius:6px}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--bg);border-color:var(--border)}.btn-danger{background:var(--bad-soft);border-color:var(--bad-soft);color:var(--bad)}.btn-danger:hover{background:var(--bad);border-color:var(--bad);color:#fff}.btn-ok{background:var(--ok-soft);border-color:var(--ok-soft);color:var(--ok)}.btn-ok:hover{background:var(--ok);border-color:var(--ok);color:#fff}.btn-group{display:flex;gap:4px}.tbl{width:100%;border-collapse:collapse;font-size:13.5px}.tbl thead th{padding:10px 12px;text-align:left;font-size:11.5px;font-weight:600;color:var(--muted);letter-spacing:.03em;text-transform:uppercase;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg)}.tbl thead th:first-child{border-radius:8px 0 0}.tbl thead th:last-child{border-radius:0 8px 0 0}.tbl tbody td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--ink);vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr:hover td{background:var(--primary-soft);cursor:pointer}.tbl .num{text-align:right;font-family:var(--mono);font-size:13px}.tbl .actions{text-align:right;white-space:nowrap}.field{display:flex;flex-direction:column;gap:5px}.field label{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.02em;text-transform:uppercase}.input,.select,textarea.input{font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--panel);border:1px solid var(--border-2);border-radius:8px;padding:8px 12px;outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.input:focus,.select:focus,textarea.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563d41f}.input::placeholder{color:var(--muted)}.input.mono{font-family:var(--mono)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236a7480' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:32px}.form-row{display:grid;gap:16px}.form-row.cols-2{grid-template-columns:1fr 1fr}.form-row.cols-3{grid-template-columns:1fr 1fr 1fr}.form-row.cols-4{grid-template-columns:1fr 1fr 1fr 1fr}.form-actions{display:flex;align-items:center;gap:10px;padding-top:16px;border-top:1px solid var(--border);margin-top:8px}.chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}.dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.chip-mono{font-family:var(--mono);font-size:11.5px;padding:2px 6px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--ink)}.stream{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap;letter-spacing:.01em}.s-ovr{background:var(--overs-soft);color:var(--overs)}.s-und{background:var(--unders-soft);color:var(--unders)}.s-cbz{background:var(--pc-soft);color:var(--pc)}.s-fs{background:var(--feed-soft);color:var(--feed)}.s-act{background:var(--test-soft);color:var(--test)}.status{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:12px;font-weight:500}.status-active{background:var(--ok-soft);color:var(--ok)}.status-closed{background:var(--pc-soft);color:var(--pc)}.status-coa{background:var(--primary-soft);color:var(--primary)}.status-pending{background:var(--warn-soft);color:var(--warn)}.status-approved{background:var(--ok-soft);color:var(--ok)}.status-rejected{background:var(--bad-soft);color:var(--bad)}.status-progress{background:var(--overs-soft);color:var(--overs)}.status-done{background:var(--ok-soft);color:var(--ok)}.status-void{background:var(--bad-soft);color:var(--bad)}.spc-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.spc-dot.ok{background:var(--ok)}.spc-dot.warn{background:var(--warn)}.spc-dot.bad{background:var(--bad)}.pf{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11.5px;font-weight:600}.pf-pass{background:var(--ok-soft);color:var(--ok)}.pf-fail{background:var(--bad-soft);color:var(--bad)}.ro-pill{display:flex;flex-direction:column;gap:2px;background:var(--panel-2);border:1px solid var(--border);border-radius:9px;padding:8px 12px;font-size:13px}.ro-pill span{font-size:11px;color:var(--muted)}.ro-pill b{font-family:var(--mono);font-weight:600}.t-avatar{width:22px;height:22px;border-radius:50%;flex:none;display:grid;place-items:center;font-family:var(--mono);font-size:9.5px;font-weight:600;background:linear-gradient(135deg,#3a4658,#222a35);color:#fff}.t-avatar.unassigned{background:var(--panel-3);color:var(--faint);border:1px dashed var(--border-2)}.out-block{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:6px 16px 12px}.out-row{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;border-bottom:1px dashed var(--border)}.out-row:last-child{border-bottom:none}.out-row-label{font-size:12.5px;color:var(--ink-2)}.out-row-value{font-family:var(--mono);font-size:13.5px;font-weight:600;color:var(--ink)}.out-row-unit{font-size:11px;color:var(--muted);font-weight:400;margin-left:3px}.out-row-value.bad{color:var(--bad)}.out-row-value.warn{color:var(--warn)}.section-label{display:flex;align-items:center;justify-content:space-between;margin:16px 0 12px}.section-label-left{display:flex;align-items:center;gap:8px;font-size:11.5px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.section-num{width:18px;height:18px;border-radius:5px;background:var(--primary-soft);color:var(--primary-700);display:grid;place-items:center;font-size:10.5px;font-family:var(--mono);flex:none}.spc-gauge-wrap{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:16px;margin-top:16px}.spc-gauge-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:12.5px;font-weight:600}.filter-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border:1px solid var(--border-2);border-radius:20px;font-size:12.5px;font-weight:500;color:var(--muted);cursor:pointer;background:var(--panel);transition:all .12s;white-space:nowrap}.filter-pill:hover,.filter-pill.active{border-color:var(--primary);background:var(--primary-soft);color:var(--primary)}.grid{display:grid;gap:20px}.g-2{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:repeat(3,1fr)}.g-4{grid-template-columns:repeat(4,1fr)}.g-1-2{grid-template-columns:1fr 2fr}.g-2-1{grid-template-columns:2fr 1fr}.g-3-2{grid-template-columns:3fr 2fr}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:20px}.tab{padding:8px 16px;font-size:13.5px;font-weight:500;color:var(--muted);border-bottom:2px solid transparent;cursor:pointer;transition:color .12s,border-color .12s;white-space:nowrap;background:transparent;border-top:none;border-left:none;border-right:none;font-family:var(--sans)}.tab:hover{color:var(--ink)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.tab-count{display:inline-flex;align-items:center;justify-content:center;background:var(--border);color:var(--muted);border-radius:10px;font-size:11px;font-weight:600;padding:0 5px;min-width:18px;height:16px;margin-left:5px}.seg{display:inline-flex;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px}.seg-btn{padding:5px 14px;border-radius:7px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .12s;border:none;background:transparent;font-family:var(--sans)}.seg-btn.active{background:var(--panel);color:var(--ink);box-shadow:var(--shadow-sm)}.stat{padding:20px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);animation:fadeInUp .18s ease;display:flex;flex-direction:column;gap:8px}.stat-label{font-size:12px;font-weight:500;color:var(--muted);display:flex;align-items:center;gap:7px;white-space:nowrap}.stat-value{font-size:28px;font-weight:700;color:var(--ink);font-family:var(--mono);letter-spacing:-.02em;line-height:1}.stat-foot{font-size:12px;color:var(--muted)}.stat-row{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.progress{height:6px;background:var(--bg);border-radius:99px;overflow:hidden;border:1px solid var(--border)}.progress span{display:block;height:100%;border-radius:99px;background:var(--primary);transition:width .3s ease}.progress span.ok{background:var(--ok)}.progress span.warn{background:var(--warn)}.progress span.bad{background:var(--bad)}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(10,12,16,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}.modal{background:var(--panel);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:560px;width:100%;max-height:90vh;overflow-y:auto;animation:fadeInUp .2s ease}.modal-lg{max-width:760px}.modal-xl{max-width:960px}.modal-head{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:16px;font-weight:700;color:var(--ink)}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:16px}.modal-foot{padding:16px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:8px}.toast{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast-item{display:flex;align-items:center;gap:10px;background:var(--ink);color:#fff;padding:12px 16px;border-radius:10px;box-shadow:var(--shadow-lg);font-size:13.5px;font-weight:500;animation:fadeInUp .2s ease;pointer-events:all;min-width:280px;max-width:380px}.toast-ok{border-left:3px solid var(--ok)}.toast-warn{border-left:3px solid var(--warn)}.toast-bad{border-left:3px solid var(--bad)}.toast-info{border-left:3px solid var(--primary)}.alertbar{background:linear-gradient(90deg,var(--bad-soft),#fef0f0);border:1px solid #f3c9c9;border-radius:var(--radius);padding:13px 16px;display:flex;align-items:center;gap:14px;color:#a82626;font-size:13.5px;font-weight:500;margin-bottom:20px}.alertbar .icon{flex-shrink:0}.alertbar .ico{width:34px;height:34px;border-radius:9px;background:var(--bad);color:#fff;display:grid;place-items:center;flex:none}.alertbar .body{flex:1;min-width:0}.alertbar .body .t{font-weight:600;font-size:13.5px;color:#97211f}.alertbar .body .d{font-size:12.5px;color:#b14a4a;margin-top:2px}.callout{background:var(--primary-soft);border:1px solid #c5d8f8;border-radius:var(--radius);padding:12px 16px;display:flex;align-items:flex-start;gap:10px;color:var(--primary);font-size:13px}.callout .icon{flex-shrink:0;margin-top:1px}.callout-body{display:flex;flex-direction:column;gap:2px}.callout-title{font-weight:600;font-size:13.5px}.callout-text{font-size:12.5px;opacity:.85}.kv{display:flex;flex-direction:column;gap:10px}.kv-row{display:flex;align-items:flex-start;gap:12px}.kv .k{font-size:11.5px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;min-width:120px;flex-shrink:0;padding-top:1px}.kv .v{font-size:13.5px;color:var(--ink)}.meta-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--panel);margin-bottom:20px}.meta-cell{padding:12px 16px;border-right:1px solid var(--border)}.meta-cell:last-child{border-right:none}.meta-cell .mk{font-size:10.5px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.meta-cell .mv{font-size:13px;color:var(--ink);font-weight:500}.mono{font-family:var(--mono)}.muted{color:var(--muted)}.divider{height:1px;background:var(--border);margin:16px 0}.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kanban-col{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.kanban-head{padding:12px 14px;background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:12.5px;font-weight:600;color:var(--ink)}.kanban-body{padding:10px;display:flex;flex-direction:column;gap:8px;min-height:200px}.kanban-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:12px;cursor:pointer;transition:box-shadow .12s,border-color .12s;display:flex;flex-direction:column;gap:6px}.kanban-card:hover{box-shadow:var(--shadow);border-color:var(--border-2)}.rail-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;border:1px solid transparent;border-radius:8px;background:transparent;font-family:var(--sans);font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .12s;text-align:left}.rail-item:hover{background:var(--bg);color:var(--ink)}.rail-item.active{background:var(--primary-soft);border-color:#c5d8f8;color:var(--primary)}.touch-btn{display:flex;flex-direction:column;gap:8px;padding:22px;border:2px solid var(--border-2);border-radius:16px;background:var(--panel);cursor:pointer;transition:all .15s;text-align:left;min-height:92px;position:relative}.touch-btn:hover{border-color:var(--border-2);background:var(--bg)}.touch-btn.sel,.touch-btn.active{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 4px #2563d41f}.tb-stream{font-family:var(--mono);font-size:22px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;color:var(--ink)}.tb-name{font-size:13.5px;color:var(--muted)}.touch-check{position:absolute;top:16px;right:16px;width:26px;height:26px;border-radius:50%;background:var(--primary);color:#fff;display:none;place-items:center}.touch-btn.sel .touch-check{display:grid}.touch-section-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}.tablet-wrap{display:flex;justify-content:center;padding:8px 0 40px}.tablet{width:1024px;max-width:100%;background:#0d1117;border-radius:30px;padding:14px;box-shadow:0 12px 40px #00000029,0 0 0 2px #20262e inset;position:relative}.tablet-screen{background:var(--bg);border-radius:18px;overflow:hidden;border:1px solid #000}.tablet-cam{position:absolute;top:50%;left:7px;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:#2a3340}.prog-group{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:14px}.prog-head{font-size:12px;font-weight:600;color:#39424d;display:flex;align-items:center;gap:8px;margin-bottom:12px}.prog-dot{width:9px;height:9px;border-radius:3px;flex:none}.touch-grid{display:grid;gap:14px}.lot-row{display:flex;align-items:center;gap:14px;padding:12px;border:none;border-radius:11px;background:none;cursor:pointer;transition:background .12s;width:100%;text-align:left}.lot-row:hover{background:var(--panel-3)}.lot-spc{width:4px;height:38px;border-radius:3px;flex:none;background:var(--border-strong)}.lot-spc.ok{background:var(--ok)}.lot-spc.warn{background:var(--warn)}.lot-spc.bad{background:var(--bad)}.quick{display:flex;align-items:center;gap:13px;padding:15px 16px;border-radius:var(--r-lg);transition:border-color .12s,box-shadow .12s,transform .05s}.quick:hover{border-color:var(--border-strong);box-shadow:var(--sh-2);transform:translateY(-1px)}.quick-ico{width:38px;height:38px;border-radius:10px;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center;flex:none}.filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:16px}.label-preview{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--panel)}.label-stripe{height:6px}.label-body{padding:16px}.label-id{font-family:var(--mono);font-size:18px;font-weight:600;letter-spacing:.04em;color:var(--ink);margin-bottom:4px}.label-meta{font-size:11.5px;color:var(--muted);display:flex;flex-direction:column;gap:2px}.barcode-vis{display:flex;gap:2px;margin:12px 0;height:40px;align-items:stretch}.barcode-vis span{background:var(--ink);border-radius:1px}.skeleton{background:linear-gradient(90deg,var(--border) 25%,var(--bg) 50%,var(--border) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:6px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:14px;margin-bottom:8px}.skeleton-h2{height:24px;width:40%;margin-bottom:12px}.skeleton-card{height:80px;border-radius:var(--radius-lg);margin-bottom:16px}.collapsible-btn{display:flex;align-items:center;gap:8px;background:none;border:none;font-family:var(--sans);font-size:13.5px;font-weight:600;color:var(--ink);cursor:pointer;padding:0}.collapsible-content{overflow:hidden}.calc-output{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px}.calc-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.calc-value{font-family:var(--mono);font-size:20px;font-weight:600;color:var(--ink)}.calc-unit{font-size:12px;color:var(--muted);margin-left:4px}.meas-tbl{width:100%;border-collapse:collapse;font-size:13.5px}.meas-tbl th{padding:8px 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--border);text-align:center;background:var(--bg)}.meas-tbl td{padding:8px 10px;border-bottom:1px solid var(--border);text-align:center}.meas-tbl tr:last-child td{border-bottom:none}.meas-tbl .meas-input{width:100%;text-align:center;font-family:var(--mono);border:1px solid var(--border);border-radius:6px;padding:5px 8px;background:var(--panel);font-size:13px;outline:none}.meas-tbl .meas-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #2563d41f}.spc-gauge{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius);border:1px solid var(--border)}.spc-gauge.ok{background:var(--ok-soft);border-color:#a8e4c9}.spc-gauge.warn{background:var(--warn-soft);border-color:#f0d49a}.spc-gauge.bad{background:var(--bad-soft);border-color:#f5c6c6}.flex{display:flex}.flex-center{display:flex;align-items:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.text-sm{font-size:12px}.text-xs{font-size:11px}.fw-600{font-weight:600}.fw-500{font-weight:500}.login-bg{min-height:100vh;background:#11151b;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{background:var(--panel);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-xl)}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:16px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;color:var(--muted);text-align:center}.empty-icon{opacity:.3}.empty-title{font-size:15px;font-weight:600;color:var(--ink)}.empty-sub{font-size:13px}.coa-header{border-bottom:3px solid var(--primary);padding-bottom:20px;margin-bottom:24px}.coa-company{font-size:20px;font-weight:700;color:var(--ink)}.coa-title{font-size:14px;color:var(--muted)}.coa-sig-box{border:1px solid var(--border);border-radius:var(--radius);padding:20px;min-height:80px;display:flex;flex-direction:column;justify-content:flex-end;gap:8px}.sig-line{height:1px;background:var(--ink);margin-bottom:6px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}
