*{margin:0;padding:0;box-sizing:border-box}:root{--purple: #6b4dc4;--purple-dark: #5a3db3;--purple-light: #8b72d4;--purple-lighter: #ece8f7;--purple-bg: #f5f3fb;--text: #0c0e19;--text-secondary: #5a5d6e;--text-muted: #8b8fa0;--border: #dde1e8;--border-light: #e8ecf1;--bg: #f0f4f8;--bg-card: #ffffff;--success: #28a745;--success-bg: #e8f5ed;--warning: #d4870a;--warning-bg: #fef6e4;--danger: #dc3545;--danger-bg: #fce8ea;--blue: #2d7dd2;--blue-bg: #e6f0fa;--radius: 8px;--radius-lg: 12px;--shadow: 0 1px 3px rgba(12, 14, 25, .06);--transition: .2s ease}html{font-size:12px}body{font-family:Noto Sans TC,sans-serif;background-color:var(--bg);color:var(--text);font-size:1.4rem;line-height:1.6;font-weight:400;-webkit-font-smoothing:antialiased}.app{min-height:100vh;display:flex;flex-direction:column}.navbar{background:var(--bg-card);display:flex;align-items:center;justify-content:space-between;padding:0 2.8rem;height:5.6rem;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.nav-brand-area{display:flex;align-items:center;gap:1rem;text-decoration:none;cursor:pointer}.nav-logo{width:3.2rem;height:3.2rem;background:var(--purple);color:#fff;border-radius:.6rem;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;letter-spacing:-.5px}.nav-brand-title{font-size:1.6rem;font-weight:700;color:var(--text);line-height:1.2}.nav-brand-sub{font-size:1.1rem;color:var(--text-muted);line-height:1.2}.nav-links{display:flex;align-items:center;gap:.2rem}.nav-link-item{text-decoration:none;padding:.7rem 1.6rem;border-radius:var(--radius);font-size:1.3rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition)}.nav-link-item:hover{background:var(--purple-lighter);color:var(--purple)}.nav-link-item.active{background:var(--purple);color:#fff;font-weight:600}.nav-back{color:var(--text-muted);font-size:1.2rem}.nav-back:hover{color:var(--purple);background:var(--purple-lighter)}.nav-back-arrow{margin-right:.2rem}.nav-divider{width:1px;height:2rem;background:var(--border);margin:0 .8rem}.main-content{max-width:110rem;margin:0 auto;padding:2.8rem 2.4rem;flex:1;width:100%}.page-title{font-size:2.4rem;font-weight:700;margin-bottom:.6rem;color:var(--text);line-height:1.2}.page-subtitle{font-size:1.4rem;color:var(--text-muted);margin-bottom:2.8rem}.dashboard-header{margin-bottom:.4rem}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(32rem,1fr));gap:1.2rem}.module-card{display:flex;align-items:center;gap:1.6rem;padding:2rem 2.4rem;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow);text-decoration:none;border:1px solid var(--border-light);transition:all var(--transition);position:relative;cursor:pointer}.module-card:hover{border-color:var(--purple-light);box-shadow:0 2px 12px #6b4dc41f}.module-card.module-disabled{opacity:.45;cursor:default}.module-card.module-disabled:hover{border-color:var(--border-light);box-shadow:var(--shadow)}.module-index{font-size:2.2rem;font-weight:700;color:var(--purple-light);font-variant-numeric:tabular-nums;flex-shrink:0;width:3.6rem}.module-info{flex:1;min-width:0}.module-title{font-size:1.5rem;font-weight:600;color:var(--text);margin-bottom:.2rem}.module-desc{font-size:1.2rem;color:var(--text-muted);line-height:1.5}.module-arrow{font-size:1.6rem;color:var(--text-muted);flex-shrink:0;transition:transform var(--transition)}.module-card:hover:not(.module-disabled) .module-arrow{transform:translate(3px);color:var(--purple)}.module-badge-soon{position:absolute;top:1rem;right:1.2rem;padding:.2rem .8rem;border-radius:.4rem;font-size:1rem;font-weight:600;background:var(--purple-lighter);color:var(--purple-light);letter-spacing:.5px}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:2.4rem;margin-bottom:1.6rem;border:1px solid var(--border-light)}.card-title{font-size:1.4rem;font-weight:700;margin-bottom:1.6rem;color:var(--text);padding-left:1.2rem;border-left:3px solid var(--purple)}.upload-zone{border:1.5px dashed var(--border);border-radius:var(--radius);padding:3.6rem;text-align:center;cursor:pointer;transition:all var(--transition);background:var(--bg)}.upload-zone:hover{border-color:var(--purple-light);background:var(--purple-bg)}.upload-zone.has-file{border-color:var(--success);background:var(--success-bg);border-style:solid}.upload-icon{font-size:2.8rem;margin-bottom:.8rem;color:var(--text-muted);font-weight:300}.upload-zone.has-file .upload-icon{color:var(--success);font-weight:700}.upload-text{font-size:1.3rem;color:var(--text-secondary)}.file-name{font-size:1.2rem;color:var(--success);font-weight:600;margin-top:.6rem}.upload-dual{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}.upload-triple{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.6rem}.upload-col-label{font-size:1.2rem;font-weight:600;color:var(--text-secondary);margin-bottom:.8rem}.sheet-select{margin-top:1.2rem}.sheet-select label{font-size:1.2rem;color:var(--text-muted);margin-right:.6rem}.sheet-select select{padding:.6rem 1rem;border:1px solid var(--border);border-radius:var(--radius);font-size:1.3rem;font-family:inherit;background:var(--bg-card);outline:none;transition:border var(--transition);color:var(--text)}.sheet-select select:focus{border-color:var(--purple)}.btn{display:inline-block;padding:.8rem 2.4rem;border:none;border-radius:var(--radius);font-size:1.4rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition);text-decoration:none}.btn-primary{background:var(--purple);color:#fff}.btn-primary:hover{background:var(--purple-dark)}.btn-primary:disabled{background:var(--border);cursor:not-allowed}.btn-success{background:var(--bg-card);color:var(--purple);border:1.5px solid var(--purple)}.btn-success:hover{background:var(--purple);color:#fff}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg);border-color:var(--text-muted)}.btn-group{display:flex;gap:1rem;margin-top:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(14rem,1fr));gap:1.2rem;margin-bottom:1.6rem}.stat-card{background:var(--bg-card);border-radius:var(--radius);padding:1.8rem 1.6rem;text-align:center;border:1px solid var(--border-light);border-left:4px solid var(--border)}.stat-value{font-size:2.8rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1}.stat-label{font-size:1.2rem;color:var(--text-muted);margin-top:.6rem;font-weight:500}.stat-card.total{border-left-color:var(--purple)}.stat-card.total .stat-value{color:var(--purple)}.stat-card.pass{border-left-color:var(--success);background:var(--success-bg)}.stat-card.pass .stat-value{color:var(--success)}.stat-card.warning{border-left-color:var(--warning);background:var(--warning-bg)}.stat-card.warning .stat-value{color:var(--warning)}.stat-card.error{border-left-color:var(--danger);background:var(--danger-bg)}.stat-card.error .stat-value{color:var(--danger)}.stat-card.source20{border-left-color:var(--blue);background:var(--blue-bg)}.stat-card.source20 .stat-value{color:var(--blue)}.stat-card.sourceKJ{border-left-color:#8e6bb0;background:#f3eef8}.stat-card.sourceKJ .stat-value{color:#8e6bb0}.filter-group{margin-bottom:1.4rem}.filter-group:last-child{margin-bottom:0}.filter-group-label{font-size:1.1rem;font-weight:600;color:var(--text-muted);margin-bottom:.6rem;letter-spacing:.3px}.filter-bar{display:flex;gap:.6rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1.4rem;border:1.5px solid var(--border);border-radius:2rem;background:var(--bg-card);font-size:1.2rem;font-family:inherit;cursor:pointer;transition:all var(--transition);color:var(--text-secondary);font-weight:500}.filter-btn:hover{background:var(--purple-lighter);border-color:var(--purple-light);color:var(--purple)}.filter-btn.active{background:var(--purple);color:#fff;border-color:var(--purple);font-weight:600}.table-container{overflow-x:auto;max-height:60rem;overflow-y:auto}.error-table{width:100%;border-collapse:collapse;font-size:1.3rem}.error-table th{background:var(--bg);padding:1rem 1.2rem;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border);position:sticky;top:0;font-size:1.2rem}.error-table td{padding:1rem 1.2rem;border-bottom:1px solid var(--border-light);vertical-align:top;color:var(--text)}.error-table tr:hover td{background:var(--purple-bg)}.badge{display:inline-block;padding:.2rem .8rem;border-radius:.4rem;font-size:1.1rem;font-weight:600}.badge-error{background:var(--danger-bg);color:var(--danger)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-pass{background:var(--success-bg);color:var(--success)}.checklist-table td,.checklist-table th{white-space:nowrap}.check-badge{display:inline-flex;align-items:center;justify-content:center;width:2.4rem;height:2.4rem;border-radius:.4rem;font-weight:700;font-size:1.1rem}.check-pass{background:var(--success-bg);color:var(--success)}.check-fail{background:var(--danger-bg);color:var(--danger)}.product-table td,.product-table th{white-space:nowrap}.row-zero td{color:var(--text-muted)}.diff-alert{color:var(--danger);font-weight:700}.diff-ok{color:var(--text-muted)}.box-table{max-width:40rem}.box-table td,.box-table th,.store-summary-table td,.store-summary-table th{white-space:nowrap}.store-summary-total{background:var(--bg);border-top:1px solid var(--border)}.store-summary-total td{padding-top:1.2rem;padding-bottom:1.2rem}.download-list{list-style:none}.download-item{display:flex;align-items:center;justify-content:space-between;padding:1.4rem 0;border-bottom:1px solid var(--border-light)}.download-item:last-child{border-bottom:none}.download-info h4{font-size:1.4rem;font-weight:600;color:var(--text)}.download-info p{font-size:1.2rem;color:var(--text-muted);margin-top:.2rem}.batch-row{display:flex;gap:3.6rem;flex-wrap:wrap}.batch-group{display:flex;flex-direction:column;gap:.6rem}.batch-label{font-size:1.2rem;font-weight:600;color:var(--text-secondary)}.radio-group{display:flex;gap:.6rem}.radio-pill{display:inline-flex;align-items:center;padding:.6rem 1.6rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:1.3rem;font-family:inherit;cursor:pointer;transition:all var(--transition);color:var(--text-secondary);background:var(--bg-card);font-weight:500}.radio-pill input{display:none}.radio-pill:hover{border-color:var(--purple-light);background:var(--purple-lighter);color:var(--purple)}.radio-pill.active{border-color:var(--purple);background:var(--purple);color:#fff;font-weight:600}.batch-tag{margin-top:1.4rem;padding:.6rem 1.2rem;background:var(--purple-lighter);border-radius:var(--radius);font-size:1.2rem;color:var(--purple);display:inline-block;font-weight:500}.batch-badge{display:inline-block;padding:.3rem 1rem;background:var(--purple-lighter);color:var(--purple);border-radius:.4rem;font-size:1.2rem;font-weight:600;margin-left:.8rem;vertical-align:middle}.last-process{font-size:1.2rem;color:var(--text-muted);margin-top:.8rem}.loading{text-align:center;padding:4rem;color:var(--text-muted);font-size:1.3rem}.spinner{display:inline-block;width:2.8rem;height:2.8rem;border:2px solid var(--border);border-top-color:var(--purple);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1.2rem}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:5.6rem 2rem;color:var(--text-muted)}.empty-icon{font-size:3.2rem;margin-bottom:1.2rem;color:var(--border);font-weight:300}.alert{padding:1rem 1.6rem;border-radius:var(--radius);margin-bottom:1.2rem;font-size:1.3rem;border:1px solid transparent}.alert-error{background:var(--danger-bg);color:var(--danger);border-color:#e8c4c4}.alert-success{background:var(--success-bg);color:var(--success);border-color:#bddec8}.placeholder-card{text-align:center;padding:5.6rem 2.4rem}.placeholder-status{font-size:1.1rem;font-weight:700;color:var(--text-muted);letter-spacing:2px;margin-bottom:1.2rem}.placeholder-heading{font-size:1.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.4rem}.placeholder-sub{font-size:1.3rem;color:var(--text-muted);margin-bottom:2.8rem}.placeholder-features{display:flex;flex-direction:column;gap:.8rem;max-width:34rem;margin:0 auto 3.2rem;text-align:left}.placeholder-feature{display:flex;align-items:center;gap:1rem;padding:.8rem 1.4rem;background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius);font-size:1.3rem;color:var(--text-secondary)}.placeholder-feature-dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--purple-light);flex-shrink:0}.guide-section{padding:0;overflow:hidden}.guide-header{display:flex;align-items:center;gap:1.4rem;padding:1.6rem 2.4rem;cursor:pointer;transition:background var(--transition)}.guide-header:hover{background:var(--bg)}.guide-num{width:2.8rem;height:2.8rem;background:var(--purple);color:#fff;border-radius:.6rem;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;flex-shrink:0}.guide-title{font-size:1.4rem;font-weight:600;color:var(--text);flex:1}.guide-arrow{font-size:1.2rem;color:var(--text-muted);transition:transform .2s}.guide-arrow.open{transform:rotate(180deg)}.guide-body{padding:0 2.4rem 1.8rem 6.6rem;display:flex;flex-direction:column;gap:1.2rem}.guide-item{border-left:2px solid var(--purple-lighter);padding-left:1.4rem}.guide-item-label{font-size:1.3rem;font-weight:600;color:var(--text)}.guide-item-desc{font-size:1.2rem;color:var(--text-muted);margin-top:.1rem}.guide-item-list{margin:.4rem 0 0 1.6rem;font-size:1.2rem;color:var(--text-muted);list-style:disc;display:flex;flex-direction:column;gap:.2rem}.guide-legend{display:inline-block;padding:.3rem 1rem;border-radius:.4rem;font-size:1.1rem;font-weight:600}.legend-auto{background:var(--success-bg);color:var(--success)}.legend-manual{background:var(--warning-bg);color:var(--warning)}.legend-future{background:var(--purple-lighter);color:var(--purple)}.app-version-badge{position:fixed;right:1.4rem;bottom:1rem;z-index:99999;font-size:1.15rem;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);padding:.4rem .85rem;border-radius:var(--radius);box-shadow:var(--shadow);pointer-events:auto;letter-spacing:.02em}.app-footer{text-align:center;padding:2rem 1.6rem;margin-top:1.6rem;border-top:1px solid var(--border);background:var(--bg-card)}.footer-copyright{font-size:1.2rem;color:var(--text-muted)}.footer-notice{font-size:1.1rem;color:var(--text-muted);margin-top:.2rem;opacity:.7}@media(max-width:768px){.navbar{padding:0 1.6rem;height:5.2rem}.nav-links{gap:.1rem}.nav-link-item{padding:.6rem 1rem;font-size:1.2rem}.main-content{padding:2rem 1.6rem}.module-grid,.upload-dual{grid-template-columns:1fr}.batch-row{gap:1.6rem}.stats-grid{grid-template-columns:repeat(2,1fr)}}.required-mark{color:var(--danger);font-weight:700;margin-left:.2rem}.upload-hint{font-size:1.1rem;font-weight:400;color:var(--text-muted);margin-left:.4rem}.password-row{display:flex;align-items:center;gap:1.2rem;margin-bottom:1.6rem}.password-label{font-size:1.2rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.password-input-wrap{position:relative;display:inline-flex;align-items:center}.password-input{padding:.6rem 3.2rem .6rem 1rem;border:1px solid var(--border);border-radius:var(--radius);font-size:1.3rem;font-family:inherit;background:var(--bg-card);outline:none;width:22rem;transition:border var(--transition);color:var(--text)}.password-input:focus{border-color:var(--purple)}.password-toggle{position:absolute;right:.6rem;background:none;border:none;cursor:pointer;font-size:1.4rem;color:var(--text-muted);padding:.2rem .4rem;transition:color var(--transition)}.password-toggle:hover{color:var(--purple)}.checklist-row-fail{background:var(--danger-bg)!important}.checklist-row-fail td{border-bottom-color:#e8c4c4!important}.diff-ok-text{color:var(--success);font-weight:600}.table-striped tbody tr:nth-child(2n) td{background:var(--bg)}.table-striped tbody tr:hover td{background:var(--purple-bg)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:2rem}.login-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:4rem 3.5rem 3rem;width:100%;max-width:38rem;box-shadow:0 4px 24px #0000000f}.login-brand{text-align:center;margin-bottom:3rem}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:5.4rem;height:5.4rem;border-radius:50%;background:var(--purple);color:#fff;font-weight:700;font-size:2rem;letter-spacing:.1rem;margin-bottom:1.2rem}.login-title{font-size:2.2rem;font-weight:700;color:var(--text);margin:0}.login-subtitle{font-size:1.3rem;color:var(--text-muted);margin-top:.4rem}.login-form{display:flex;flex-direction:column;gap:1.2rem}.login-label{font-size:1.3rem;font-weight:600;color:var(--text-secondary)}.login-input{width:100%;padding:1rem 1.2rem;border:1px solid var(--border);border-radius:var(--radius);font-size:1.4rem;font-family:inherit;transition:border-color var(--transition);box-sizing:border-box}.login-input:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px #6b4dc41a}.login-error{color:var(--danger);font-size:1.2rem;padding:.8rem 1rem;background:var(--danger-bg);border-radius:var(--radius)}.login-btn{width:100%;margin-top:.8rem;padding:1rem;font-size:1.4rem}.login-notice{text-align:center;margin-top:2.4rem;font-size:1.1rem;color:var(--text-muted)}.nav-logout-btn{background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:1.2rem;font-family:inherit;padding:.4rem 1rem;cursor:pointer;margin-left:1.2rem;transition:all var(--transition)}.nav-logout-btn:hover{color:var(--danger);border-color:var(--danger)}.overview-light-table td,.overview-light-table th{white-space:nowrap}.overview-status{display:inline-block;padding:.25rem .9rem;border-radius:.4rem;font-size:1.1rem;font-weight:700;background:var(--success-bg);color:var(--success);letter-spacing:.3px}.stat-card.sourceNM{border-left:4px solid var(--blue);background-color:var(--blue-bg)}.section-card{border-left:4px solid var(--purple-light)}.section-label{display:inline-flex;align-items:center;justify-content:center;width:2.4rem;height:2.4rem;border-radius:.5rem;background:var(--purple);color:#fff;font-weight:700;font-size:1.2rem;margin-right:.8rem;flex-shrink:0;vertical-align:middle}
