@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap";:root{--bg: #f8fafc;--surface: #ffffff;--surface-alt: #f8fafc;--surface-deep: #eef2ff;--input-bg: #f1f5f9;--hover-bg: #f1f5f9;--tabs-bg: #f1f5f9;--border: #e2e8f0;--border-soft: #f1f5f9;--text1: #0f172a;--text2: #334155;--text3: #475569;--text4: #64748b;--text-cell: #334155;--accent-text: #4f46e5;--skeleton: #e2e8f0;--shadow: 0 2px 12px rgba(0,0,0,.08);--rank-n-bg: #e2e8f0;--rank-n-color: #475569;--rank-n-border: #cbd5e1;--rev-color: #059669;--unit-color: #1d4ed8;--prof-color: #6d28d9;--badge-ok-bg: #dcfce7;--badge-ok-text: #166534;--badge-err-bg: #fee2e2;--badge-err-text: #991b1b;--badge-load-bg: #e0e7ff;--badge-load-text: #3730a3;--badge-idle-bg: #f1f5f9;--badge-idle-text: #475569;--chip-bg: #ede9fe;--chip-text: #4c1d95;--chip-border: #ddd6fe;--drop-fill: rgba(99,102,241,.04)}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--surface-alt: #162032;--surface-deep: #1a2744;--input-bg: #0f172a;--hover-bg: #243044;--tabs-bg: #0f172a;--border: #334155;--border-soft: #1e293b;--text1: #f1f5f9;--text2: #e2e8f0;--text3: #94a3b8;--text4: #64748b;--text-cell: #cbd5e1;--accent-text: #818cf8;--skeleton: #334155;--shadow: 0 4px 16px rgba(0,0,0,.45);--rank-n-bg: #0f172a;--rank-n-color: #64748b;--rank-n-border: #334155;--rev-color: #34d399;--unit-color: #93c5fd;--prof-color: #c084fc;--badge-ok-bg: rgba(16,185,129,.15);--badge-ok-text: #34d399;--badge-err-bg: rgba(239,68,68,.15);--badge-err-text: #f87171;--badge-load-bg: rgba(99,102,241,.15);--badge-load-text: #818cf8;--badge-idle-bg: #334155;--badge-idle-text: #94a3b8;--chip-bg: rgba(99,102,241,.1);--chip-text: #a5b4fc;--chip-border: rgba(99,102,241,.2);--drop-fill: rgba(99,102,241,.06)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f1f5f9;color:#0f172a;min-height:100vh;transition:background .2s,color .2s}.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f1f5f9}.login-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:40px;width:100%;max-width:400px;display:flex;flex-direction:column;box-shadow:0 4px 24px #0000000f}.login-logo{margin-bottom:20px;display:flex;justify-content:center}.login-title{font-size:22px;font-weight:700;color:#0f172a}.login-sub{color:#6b7280;font-size:14px;margin-top:4px;margin-bottom:28px}.login-error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;font-size:13px;margin-bottom:16px}.field-label{font-size:13px;color:#374151;font-weight:500;margin-bottom:6px;display:block}.field-input{width:100%;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:10px 14px;color:#0f172a;font-size:14px;outline:none;transition:border-color .15s}.field-input:focus{border-color:#6366f1}.login-btn{margin-top:24px;background:#6366f1;color:#fff;border:none;border-radius:8px;padding:11px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}.login-btn:hover:not(:disabled){background:#4f46e5}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-hint{color:#9ca3af;font-size:12px;text-align:center;margin-top:16px}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:240px;min-width:240px;background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;padding:20px 12px;box-shadow:1px 0 8px #0000000a}.sidebar-header{display:flex;align-items:center;gap:10px;padding:4px 8px 24px}.sidebar-brand{font-size:18px;font-weight:700;color:#0f172a}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;color:#6b7280;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;text-align:left;transition:background .12s,color .12s}.nav-item:hover{background:#f1f5f9;color:#0f172a}.nav-active{background:#ede9fe!important;color:#6366f1!important}.nav-chevron{margin-left:auto}.sub-nav{display:flex;flex-direction:column;gap:1px;padding-left:14px;margin-top:2px}.sub-nav-item{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;color:#9ca3af;padding:8px 12px;border-radius:7px;cursor:pointer;font-size:13px;font-weight:500;text-align:left;transition:background .12s,color .12s}.sub-nav-item:hover{background:#f1f5f9;color:#0f172a}.sub-active{color:#6366f1!important;background:#f5f3ff!important}.sidebar-footer{border-top:1px solid #e2e8f0;padding-top:16px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 12px 12px}.user-avatar{width:32px;height:32px;background:#6366f1;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.user-info{overflow:hidden}.user-name{font-size:13px;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:11px;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;color:#9ca3af;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;transition:background .12s,color .12s}.logout-btn:hover{background:#fee2e2;color:#dc2626}.main-content{flex:1;overflow-y:auto;background:#f1f5f9}.page{padding:32px;max-width:960px}.page-header{margin-bottom:28px}.page-title{font-size:22px;font-weight:700;color:#0f172a}.page-sub{color:#475569;font-size:14px;margin-top:4px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}@media (max-width: 800px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px 22px;box-shadow:0 1px 4px #0000000a}.stat-label{font-size:12px;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.stat-value{font-size:28px;font-weight:700;margin-bottom:6px}.stat-change{font-size:12px;color:#9ca3af}.section-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px}.section-title{font-size:14px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:18px}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{text-align:left;padding:8px 12px;color:#6b7280;font-weight:600;border-bottom:1px solid #e2e8f0}.data-table td{padding:12px;border-bottom:1px solid #f1f5f9;color:#374151}.data-table tr:last-child td{border-bottom:none}.mono{font-family:monospace;color:#6366f1}.badge{padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600}.tab-bar{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid #e2e8f0;padding-bottom:0}.tab-btn{background:none;border:none;color:#6b7280;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s,border-color .12s}.tab-btn:hover{color:#0f172a}.tab-active{color:#6366f1!important;border-bottom-color:#6366f1!important}.upload-form{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:28px;max-width:640px;box-shadow:0 1px 4px #0000000a}.form-title{font-size:16px;font-weight:700;color:#0f172a;margin-bottom:22px}.form-status{border-radius:8px;padding:10px 14px;font-size:13px;margin-bottom:18px}.status-ok{background:#d1fae5;color:#059669;border:1px solid #a7f3d0}.status-err{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:12px;color:#374151;font-weight:500}.form-group input,.form-group textarea,.form-group select{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:9px 12px;color:#0f172a;font-size:13px;outline:none;resize:vertical;transition:border-color .15s;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:#6366f1}.form-group select{cursor:pointer}.submit-btn{background:#6366f1;color:#fff;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.submit-btn:hover:not(:disabled){background:#4f46e5}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.upload-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:28px;max-width:600px;box-shadow:0 1px 4px #0000000a}.upload-desc{font-size:13px;color:#6b7280;margin-bottom:16px;line-height:1.5}.col-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.col-chip{background:#ede9fe;color:#6366f1;border:1px solid #ddd6fe;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:600;font-family:monospace}.drop-zone{border:2px dashed #e2e8f0;border-radius:10px;padding:36px 24px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;margin-bottom:16px}.drop-zone:hover{border-color:#6366f1;background:#f5f3ff}.drop-zone-active{border-color:#6366f1!important;background:#ede9fe!important}.drop-zone-filled{border-color:#a7f3d0;border-style:solid;background:#f0fdf4}.drop-prompt{display:flex;flex-direction:column;align-items:center;gap:10px}.drop-text{color:#374151;font-size:14px;font-weight:500}.drop-hint{color:#9ca3af;font-size:12px}.file-selected{display:flex;align-items:center;gap:14px;text-align:left}.file-name{font-size:14px;font-weight:600;color:#0f172a}.file-size{font-size:12px;color:#6b7280;margin-top:2px}.form-status{display:flex;align-items:flex-start;gap:8px}.coming-soon{display:flex;flex-direction:column;align-items:center;gap:14px;padding:40px;color:#9ca3af;font-size:13px;text-align:center;line-height:1.6}.large-file-notice{display:flex;align-items:center;gap:8px;background:#fef3c7;border:1px solid #fde68a;color:#d97706;border-radius:8px;padding:9px 14px;font-size:12px;font-weight:500;margin-bottom:12px}.large-file-notice:before{content:"⚠";font-size:14px}@keyframes spin{to{transform:rotate(360deg)}}.dash-page{padding:32px;max-width:1600px}.fbar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:18px 22px;margin-bottom:24px;box-shadow:0 1px 4px #0000000a}.fgroup{display:flex;flex-direction:column;gap:5px;min-width:130px}.fgroup-wide{min-width:200px;flex:1;max-width:320px}.flabel{font-size:11px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.fsel,.finp{background:#f8fafc;border:1px solid #e2e8f0;border-radius:7px;padding:7px 10px;color:#0f172a;font-size:13px;outline:none;font-family:inherit}.fsel{cursor:pointer}.fsel:focus,.finp:focus{border-color:#6366f1}.fload-btn{background:#6366f1;color:#fff;border:none;border-radius:8px;padding:8px 22px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap;align-self:flex-end}.fload-btn:hover:not(:disabled){background:#4f46e5}.fload-btn:disabled{opacity:.6;cursor:not-allowed}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}@media (max-width: 1000px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:20px 22px 16px;display:flex;flex-direction:column;box-shadow:0 1px 6px #0000000d}.kpi-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.kpi-label{font-size:13px;color:#374151;font-weight:600}.kpi-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:var(--kpi-cl, #f1f5f9);color:var(--kpi-c, #374151);flex-shrink:0}.kpi-value{font-size:22px;font-weight:700;color:#0f172a;line-height:1.1;margin-bottom:5px}.kpi-sub{font-size:11px;color:#9ca3af;flex:1}.kpi-skeleton{height:34px;background:#e2e8f0;border-radius:6px;animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.w-grid{display:grid;grid-template-columns:1fr;gap:20px}.w-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 1px 4px #0000000a}.w-header{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 18px 12px;border-bottom:1px solid #e2e8f0}.w-title{font-size:13px;font-weight:700;color:#0f172a}.w-sub{font-size:11px;color:#6b7280;margin-top:2px;line-height:1.4}.w-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;white-space:nowrap}.w-idle{background:#f1f5f9;color:#9ca3af}.w-loading{background:#ede9fe;color:#6366f1}.w-ok{background:#d1fae5;color:#059669}.w-err{background:#fee2e2;color:#dc2626}.w-body{flex:1;min-height:100px}.w-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px;color:#9ca3af;font-size:13px;text-align:center}.w-state-err{color:#dc2626;font-size:12px;word-break:break-word}.w-scroll{overflow-x:auto;max-height:300px;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.w-scroll::-webkit-scrollbar{display:none}.w-table{width:100%;border-collapse:collapse;font-size:12px}.w-table th{position:sticky;top:0;z-index:1;text-align:left;padding:7px 12px;color:#6b7280;font-weight:600;background:#fff;border-bottom:1px solid #e2e8f0;white-space:nowrap}.w-table td{padding:7px 12px;border-bottom:1px solid #f1f5f9;color:#374151;white-space:nowrap}.w-table tr:last-child td{border-bottom:none}.w-table tr:hover td{background:#f8fafc}.w-table td.col-lock{position:sticky;z-index:1;background:#fff}.w-table tr:hover td.col-lock{background:#f8fafc}.w-table th.col-lock{position:sticky;z-index:4;background:#fff}.w-table-roomy td{padding:11px 12px}.w-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0;margin-left:12px}.w-tabs{display:flex;gap:2px;background:#f1f5f9;border-radius:6px;padding:2px}.w-tab{background:none;border:none;color:#6b7280;padding:4px 11px;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;transition:all .12s}.w-tab:hover{color:#0f172a}.w-tab-active{background:#fff!important;color:#0f172a!important;box-shadow:0 1px 3px #00000014}.w-chart-wrap{padding:16px 8px 8px}.store-table-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #0000000a}.store-table-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e2e8f0}.store-table-title{font-size:15px;font-weight:600;color:#0f172a}.store-table-count{font-size:12px;color:#6b7280;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;padding:2px 10px}.store-table-state{padding:40px 20px;text-align:center;color:#9ca3af;font-size:14px;display:flex;align-items:center;justify-content:center;gap:8px}.store-table-scroll{overflow-x:auto;max-height:520px;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.store-table-scroll::-webkit-scrollbar{display:none}.store-table{width:100%;border-collapse:collapse;font-size:13px}.store-table thead th{position:sticky;top:0;z-index:1;background:#f8fafc;color:#6b7280;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:10px 16px;text-align:left;white-space:nowrap;border-bottom:1px solid #e2e8f0}.store-table thead th.num{text-align:right}.store-table tbody td{padding:10px 16px;border-bottom:1px solid #f1f5f9;color:#374151;white-space:nowrap}.store-table tbody td.num{text-align:right;font-variant-numeric:tabular-nums}.store-table tbody tr:last-child td{border-bottom:none}.store-table tbody tr:hover td{background:#f8fafc}.reg-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}@media (max-width: 800px){.reg-charts-row{grid-template-columns:1fr}}.reg-pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:14px 18px;border-top:1px solid #e2e8f0}.reg-page-btn{background:#f1f5f9;color:#374151;border:1px solid #e2e8f0;border-radius:7px;padding:7px 18px;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s}.reg-page-btn:hover:not(:disabled){background:#e2e8f0}.reg-page-btn:disabled{opacity:.4;cursor:not-allowed}.reg-page-info{font-size:13px;color:#9ca3af}.reg-total-row td{padding:9px 12px;font-weight:700;color:#0f172a;background:#ede9fe;border-top:2px solid #6366f1;white-space:nowrap}.dash-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}@media (max-width: 900px){.dash-charts-row{grid-template-columns:1fr}}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;font-size:11px;font-weight:700}.rank-1{background:#fef3c7;color:#d97706}.rank-2{background:#f1f5f9;color:#475569}.rank-3{background:#fff7ed;color:#c2410c}.rank-n{background:#f1f5f9;color:#9ca3af;font-weight:600}.region-chip{display:inline-block;background:#ede9fe;color:#6366f1;border-radius:5px;padding:2px 8px;font-size:11px;font-weight:600}.unit-cell{color:#6366f1;font-weight:600;text-align:right}.rev-cell{color:#059669;font-weight:600;text-align:right}.prof-cell{color:#0891b2;font-weight:600;text-align:right}.w-table th.unit-cell,.w-table th.rev-cell,.w-table th.prof-cell{color:#6b7280;text-align:right}.store-name-cell{display:flex;flex-direction:column;gap:1px}.store-name{font-size:13px;font-weight:600;color:#0f172a}.store-num{font-size:11px;color:#94a3b8}
