@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css";@import "https://fonts.googleapis.com/css2?family=Libre+Barcode+128&family=Libre+Barcode+39&display=swap";:root{--page-bg:#f8f9fa;--panel-bg:#fff;--header-bg:#fff;--input-bg:#f9fafb;--border-color:#eaecef;--border-radius-sm:8px;--border-radius-md:12px;--border-radius-lg:16px;--border-radius-xl:20px;--text-primary:#111;--text-secondary:#6b7684;--text-tertiary:#8b95a1;--accent-blue:#3182f6;--accent-green:#00c781;--accent-teal:#00a88f;--accent-red:#f04452;--accent-orange:#f59e0b;--accent-amber:#ffb800;--accent-purple:#8b5cf6;--accent-count:#a855f7;--gray-100:#f2f4f6;--gray-200:#eaecef;--gray-250:#e5e8eb;--gray-300:#d1d6db;--gray-400:#b0b8c1;--gray-450:#a0aab5;--gray-500:#8b95a1;--gray-600:#6b7684;--gray-700:#4e5968;--shadow-soft:0 2px 8px #00000008;--shadow-md:0 4px 12px #0000000f;--shadow-lg:0 8px 24px #00000014;--gap-sm:8px;--gap-md:16px;--gap-lg:20px;--gap-xl:24px;--pop-header-height:72px}*{box-sizing:border-box;margin:0;padding:0}body{letter-spacing:-.02em;background:var(--page-bg);color:var(--text-primary);height:100vh;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif;overflow:hidden}.badge{white-space:nowrap;border-radius:6px;align-items:center;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge-pending{background:var(--gray-100);color:var(--gray-600)}.badge-progress{color:var(--accent-blue);background:#e8f3ff}.badge-complete{color:var(--accent-teal);background:#00a88f1a}.badge-count{color:var(--accent-count);background:#a855f71a}.badge-fail{color:var(--accent-red);background:#f044521a}.badge-warning{color:var(--accent-orange);background:#f59e0b1a}.badge-purple{color:var(--accent-purple);background:#8b5cf61a}.btn{border-radius:var(--border-radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:700;transition:all .15s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--text-primary);color:#fff}.btn-blue{background:var(--accent-blue);color:#fff}.btn-blue:hover{background:#1b64da}.btn-green{background:var(--accent-green);color:#fff}.btn-green:hover{background:#00b070}.btn-red{background:var(--accent-red);color:#fff}.btn-red:hover{background:#d93b49}.btn-secondary{background:var(--gray-100);color:var(--text-primary);border:1px solid var(--gray-300)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--gray-300);background:0 0}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.barcode-128{font-family:"Libre Barcode 128",cursive}.barcode-39{font-family:"Libre Barcode 39",cursive}.monospace{font-family:Courier New,monospace}.login-page{background:var(--page-bg);flex-direction:column;height:100vh;display:flex}.login-header{background:var(--header-bg);border-bottom:1px solid var(--border-color);height:80px;box-shadow:var(--shadow-soft);justify-content:space-between;align-items:center;padding:0 30px;display:flex}.login-header-left,.login-header-right{align-items:center;gap:24px;display:flex}.login-logo{font-size:28px;font-weight:900}.login-logo span{color:var(--accent-blue)}.login-header-info{color:var(--text-secondary);font-size:16px;font-weight:600}.login-header-info span{color:var(--text-primary);font-weight:800}.login-clock{color:var(--accent-green);font-variant-numeric:tabular-nums;font-size:24px;font-weight:800}.login-main{flex:1;justify-content:center;align-items:center;display:flex}.login-container{background:var(--panel-bg);border-radius:var(--border-radius-xl);width:480px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);padding:40px 48px}.process-display{background:var(--gray-100);border-radius:var(--border-radius-md);border:1px solid var(--border-color);margin-bottom:32px;padding:20px 24px;position:relative}.status-dot{background:var(--accent-green);width:12px;height:12px;box-shadow:0 0 8px var(--accent-green);border-radius:50%;position:absolute;top:20px;right:20px}.process-display label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:8px;font-size:12px;font-weight:700;display:block}.process-name{color:var(--accent-blue);font-size:22px;font-weight:900}.login-input-group{margin-bottom:20px}.login-input-group label{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:700;display:block}.login-input-group input{background:var(--input-bg);border:2px solid var(--border-color);border-radius:var(--border-radius-md);width:100%;color:var(--text-primary);outline:none;padding:16px;font-family:inherit;font-size:16px;font-weight:700;transition:all .15s}.login-input-group input:focus{border-color:var(--accent-blue);background:#f0f4ff;box-shadow:0 0 0 3px #3182f61a}.btn-login{background:var(--accent-blue);color:#fff;border-radius:var(--border-radius-md);cursor:pointer;border:none;width:100%;margin-top:12px;padding:18px;font-size:18px;font-weight:900;transition:all .15s;box-shadow:0 4px 12px #3182f640}.btn-login:hover{background:#1b64da}.btn-login:active{transform:scale(.98)}.login-footer{border-top:1px solid var(--border-color);color:var(--text-tertiary);text-align:center;margin-top:28px;padding-top:20px;font-size:12px}.login-error{border-radius:var(--border-radius-sm);color:var(--accent-red);background:#f0445214;border:1px solid #f0445233;margin-bottom:12px;padding:12px 16px;font-size:13px;font-weight:700}.btn-login:disabled{opacity:.4;cursor:not-allowed}.terminal-error{text-align:center;padding:40px 20px}.terminal-error-icon{color:var(--accent-red);margin-bottom:16px;font-size:48px}.terminal-error-title{color:var(--accent-red);margin-bottom:12px;font-size:22px;font-weight:900}.terminal-error-message{color:var(--text-secondary);font-size:14px;line-height:1.6}.pop-layout{background:var(--page-bg);flex-direction:column;height:100vh;display:flex;overflow:hidden}.pop-header{border-bottom:1px solid var(--border-color);height:90px;box-shadow:var(--shadow-soft);background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 30px;display:flex}.pop-header-left{align-items:center;gap:24px;display:flex}.pop-header-right{align-items:center;gap:28px;display:flex}.pop-logo{color:#111;font-size:32px;font-weight:900}.pop-logo span{color:#111}.pop-line-badge{color:var(--accent-blue);background:#e8f3ff;border-radius:24px;padding:8px 18px;font-size:16px;font-weight:800}.pop-header-info{color:var(--text-secondary);font-size:18px;font-weight:600}.pop-header-info span{color:var(--text-primary);font-weight:800}.pop-clock{color:var(--accent-green);font-variant-numeric:tabular-nums;min-width:100px;font-size:28px;font-weight:800}.pop-main{flex:1;gap:12px;padding:12px;display:flex;overflow:hidden}.pop-panel{background:var(--panel-bg);border-radius:var(--border-radius-lg);border:1px solid var(--border-color);flex-direction:column;display:flex;overflow:hidden}.pop-panel-header{border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.pop-panel-title{color:var(--text-primary);font-size:14px;font-weight:800}.pop-panel-body{flex:1;padding:12px;overflow-y:auto}.info-card{background:var(--panel-bg);border:1px solid var(--border-color);border-radius:var(--border-radius-md);gap:4px;padding:16px 20px;display:grid}.info-card-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em;font-size:11px;font-weight:600}.info-card-value{color:var(--text-primary);font-size:14px;font-weight:800}.scan-input-wrapper{position:relative}.scan-input{background:var(--input-bg);border:2px solid var(--border-color);border-radius:var(--border-radius-md);width:100%;color:var(--text-primary);outline:none;padding:14px 16px;font-family:Courier New,monospace;font-size:18px;font-weight:700;transition:all .15s}.scan-input:focus{border-color:var(--accent-blue);background:#f0f4ff;box-shadow:0 0 0 3px #3182f61a}.scan-input::placeholder{color:var(--text-tertiary);font-weight:500}.progress-bar{background:var(--gray-100);border-radius:12px;height:24px;position:relative;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--accent-blue), var(--accent-green));border-radius:12px;height:100%;transition:width .4s}.progress-bar-text{color:var(--text-primary);justify-content:center;align-items:center;font-size:12px;font-weight:800;display:flex;position:absolute;inset:0}.module-item{border-radius:var(--border-radius-md);border:1px solid var(--border-color);background:var(--panel-bg);cursor:pointer;margin-bottom:8px;padding:12px 14px;transition:all .15s}.module-item:hover{background:var(--gray-100)}.module-item.active{border-color:var(--accent-blue);background:#e8f3ff}.module-item.completed{opacity:.4}.module-item-id{color:var(--accent-blue);font-family:Courier New,monospace;font-size:13px;font-weight:700}.module-item-desc{color:var(--text-secondary);margin-top:2px;font-size:11px}.time-badge{border-radius:4px;padding:3px 8px;font-family:Courier New,monospace;font-size:11px;font-weight:700;display:inline-flex}.time-badge-in{color:var(--accent-blue);background:#e8f3ff}.time-badge-out{color:var(--accent-green);background:#00c7811a}.pop-table{border-collapse:collapse;width:100%;font-size:12px}.pop-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;background:var(--gray-100);border-bottom:1px solid var(--border-color);padding:10px 12px;font-size:11px;font-weight:700;position:sticky;top:0}.pop-table td{border-bottom:1px solid var(--border-color);color:var(--text-primary);padding:10px 12px;font-weight:500}.pop-table tr:hover td{background:#3182f608}.modal-backdrop{z-index:1000;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--panel-bg);border-radius:var(--border-radius-xl);border:1px solid var(--border-color);max-width:90vw;padding:32px;box-shadow:0 20px 60px #00000026}.modal-title{margin-bottom:20px;font-size:20px;font-weight:900}.mod-left-panel{flex-shrink:0;width:320px}.mod-right-panel{flex:1;position:relative}.mod-lock-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;border-radius:var(--border-radius-lg);background:#ffffffe6;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.mod-lock-icon{opacity:.3;margin-bottom:12px;font-size:48px}.mod-lock-text{color:var(--text-tertiary);font-size:16px;font-weight:700}.mod-work-area{flex-direction:column;gap:12px;display:flex}.jc-item{border-radius:var(--border-radius-md);border:1px solid var(--border-color);background:var(--panel-bg);cursor:pointer;margin-bottom:8px;padding:12px 14px;transition:all .15s}.jc-item:hover{background:var(--gray-100)}.jc-item.active{border-left:3px solid var(--accent-blue);background:#e8f3ff}.jc-item-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.jc-item-id{color:var(--accent-blue);font-size:13px;font-weight:700}.jc-barcode{color:var(--text-primary);font-family:"Libre Barcode 128",cursive;font-size:40px;line-height:1}.jc-barcode-text{color:var(--text-tertiary);margin-bottom:8px;font-size:9px}.jc-detail-grid{grid-template-columns:1fr 1fr;gap:4px;display:grid}.jc-detail-label{color:var(--text-tertiary);font-size:10px;font-weight:600}.jc-detail-value{color:var(--text-primary);font-size:11px;font-weight:700;display:block}.mod-scan-grid-area{gap:16px;display:flex}.mod-scan-section{flex:1}.mod-module-progress{text-align:center;background:var(--gray-100);border-radius:var(--border-radius-md);border:1px solid var(--border-color);width:180px;padding:16px}.mod-module-id-row{align-items:center;gap:12px;margin-bottom:12px;display:flex}.mod-module-label{color:var(--text-secondary);font-size:12px;font-weight:700}.mod-module-id{color:var(--accent-green);font-family:Courier New,monospace;font-size:18px;font-weight:900}.mod-scan-hint{color:var(--text-tertiary);margin-bottom:8px;font-size:12px}.mod-cell-grid{grid-template-columns:repeat(8,1fr);gap:6px;margin-top:12px;display:grid}.mod-cell-box{aspect-ratio:1.4;border:1px solid var(--border-color);background:var(--panel-bg);color:var(--text-tertiary);border-radius:8px;justify-content:center;align-items:center;font-size:11px;font-weight:600;transition:all .2s;display:flex}.mod-cell-box.scanned{border-color:var(--accent-green);color:var(--accent-green);background:#00c7811a;font-weight:800;animation:.3s cellPop}@keyframes cellPop{0%{transform:scale(.8)}50%{transform:scale(1.1)}to{transform:scale(1)}}.mod-progress-count{justify-content:center;align-items:baseline;gap:4px;margin-bottom:4px;display:flex}.mod-progress-current{color:var(--accent-blue);font-size:36px;font-weight:900}.mod-progress-sep{color:var(--text-tertiary);font-size:24px;font-weight:600}.mod-progress-target{color:var(--text-secondary);font-size:24px;font-weight:700}.mod-progress-label{color:var(--text-tertiary);margin-bottom:12px;font-size:12px;font-weight:700}.mod-completed-list{flex-direction:column;gap:4px;display:flex}.mod-empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.mod-empty-icon{opacity:.3;margin-bottom:8px;font-size:40px}.mod-empty-text{color:var(--text-tertiary);font-size:14px;font-weight:700}.mod-lot-list{background:var(--gray-100);border-radius:var(--border-radius-sm);flex-wrap:wrap;min-height:40px;margin-top:12px;padding:12px;display:flex}.mod-print-modal{text-align:center;width:440px}.mod-print-ticket{border:2px solid var(--border-color);border-radius:var(--border-radius-md);background:#fff;margin-top:16px;padding:24px}.mod-print-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:11px;font-weight:700}.mod-print-barcode{color:#000;font-family:"Libre Barcode 128",cursive;font-size:64px;line-height:1.2}.mod-print-id{color:var(--text-primary);letter-spacing:.05em;margin-top:4px;font-size:16px;font-weight:800}.mod-print-meta{color:var(--text-secondary);margin-top:12px;font-size:11px}.process-scan-area{gap:12px;display:flex}.scan-section{border-radius:var(--border-radius-md);border:1px solid var(--border-color);flex:1;padding:16px}.scan-section-in{background:#3182f608}.scan-section-out{background:#00c78108}.scan-section-label{color:var(--text-primary);margin-bottom:10px;font-size:14px;font-weight:900}.scan-time{margin-top:8px}.scan-input:disabled{opacity:.4;cursor:not-allowed}.wo-progress-area{background:var(--gray-100);border-radius:var(--border-radius-md);border:1px solid var(--border-color);padding:16px}.wo-progress-header{align-items:center;gap:8px;margin-bottom:14px;display:flex}.insp-scan-row{border-radius:var(--border-radius-md);border:1px solid var(--border-color);background:#3182f608;align-items:center;gap:12px;padding:12px 16px;display:flex}.insp-scan-row .scan-input{flex:1}.insp-items{flex-direction:column;gap:8px;transition:opacity .2s;display:flex}.insp-items.disabled{opacity:.35;pointer-events:none}.insp-row{background:var(--gray-100);border-radius:var(--border-radius-md);border:1px solid var(--border-color);align-items:center;gap:12px;padding:12px 16px;display:flex}.insp-row-name{flex:1}.insp-item-name{font-size:14px;font-weight:800}.insp-item-spec{color:var(--text-tertiary);margin-top:2px;font-size:11px;font-weight:600}.insp-input{background:var(--panel-bg);border:2px solid var(--border-color);border-radius:var(--border-radius-sm);text-align:center;outline:none;width:120px;padding:10px 12px;font-family:Courier New,monospace;font-size:16px;font-weight:700;transition:border-color .15s}.insp-input:focus{border-color:var(--accent-blue)}.insp-buttons{gap:6px;display:flex}.insp-btn{border-radius:var(--border-radius-sm);cursor:pointer;border:2px solid var(--border-color);background:var(--panel-bg);color:var(--text-secondary);padding:8px 16px;font-size:13px;font-weight:800;transition:all .15s}.insp-btn-ok.active{border-color:var(--accent-green);color:var(--accent-green);background:#00c7811a}.insp-btn-ng.active{border-color:var(--accent-red);color:var(--accent-red);background:#f044521a}.insp-decision{margin-top:8px}.insp-decision-lock{text-align:center;color:var(--text-tertiary);background:var(--gray-100);border-radius:var(--border-radius-md);padding:32px;font-size:14px;font-weight:700}.insp-decision-buttons{gap:12px;display:flex}.insp-decision-btn{flex:1;padding:20px;border-radius:var(--border-radius-lg)!important;font-size:24px!important;font-weight:900!important}.insp-decision-btn.disabled{opacity:.3;cursor:not-allowed}.module-item.rework{border-color:var(--accent-orange);background:#f59e0b0d}.sot-container{flex-direction:column;flex:1;gap:12px;display:flex;overflow:hidden}.sot-search{background:var(--panel-bg);border-radius:var(--border-radius-md);border:1px solid var(--border-color);flex-shrink:0;align-items:center;gap:8px;padding:12px 16px;display:flex}.sot-master{flex:4;min-height:0}.sot-detail{flex:6;min-height:0}.sot-row-selected td{background:#3182f614!important}.sot-progress-cell{align-items:center;gap:8px;display:flex}.sot-time-cell{flex-direction:column;gap:2px;display:flex}
