:root{--bg:#f7f9f8;--surface:#fff;--surface-soft:#eef6f4;--line:#d7e2df;--text:#0f2425;--muted:#657579;--teal:#005a5f;--teal-2:#00736f;--teal-dark:#00464c;--green:#127a42;--red:#d93025;--amber:#c77700;--blue:#1665c1}*{box-sizing:border-box}html,body{background:var(--bg);min-height:100%;color:var(--text);margin:0;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px}a{color:inherit;text-decoration:none}button,input,select{font:inherit}.app-shell{grid-template-columns:176px 1fr;min-height:100vh;display:grid}.sidebar{color:#fff;background:linear-gradient(#006c6f1a,#003c4100),#004b52;flex-direction:column;width:176px;height:100vh;padding:22px 10px;display:flex;position:fixed;top:0;left:0;overflow:hidden}.brand{align-items:center;gap:10px;padding:4px 8px 26px;display:flex}.brand-mark{background:#ffffff24;border-radius:8px;flex:none;place-items:center;width:34px;height:34px;display:grid}.brand strong,.brand span{display:block}.brand strong{font-size:17px;font-weight:850;line-height:1.2}.brand span{color:#ffffffb8;margin-top:3px;font-size:12px;font-weight:700}.nav-list{gap:6px;min-height:0;padding-right:2px;display:grid;overflow-y:auto}.nav-item{color:#ffffffe0;border-radius:8px;align-items:center;gap:12px;min-height:48px;padding:0 12px;font-size:16px;font-weight:650;display:flex}.nav-item.active,.nav-item:hover{color:#fff;background:linear-gradient(90deg,#109890cc,#0076787a)}.sidebar-bottom{flex:none;gap:10px;margin-top:auto;display:grid}.sidebar-action{color:#ffffffeb;text-align:left;background:#ffffff0e;border:1px solid #fff3;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;width:100%;min-height:46px;padding:12px;font-weight:750;display:flex}.sidebar-action span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.sidebar-action:hover{background:#ffffff1f}.main{grid-column:2;min-width:0;padding:24px 28px 36px}.topbar{justify-content:space-between;align-items:center;gap:24px;margin-bottom:14px;display:flex}.topbar h1{margin:0;font-size:24px;line-height:1.15}.topbar-meta{color:var(--muted);margin:8px 0 0;font-size:13px;font-weight:650}.eyebrow{color:var(--muted);margin:0 0 6px;font-size:13px;font-weight:700}.topbar-actions{align-items:center;gap:12px;display:flex}.period-switch{background:#fff;border:1px solid #cfdcda;border-radius:8px;min-height:44px;display:inline-flex;overflow:hidden}.period-switch a{border-right:1px solid var(--line);color:var(--muted);align-items:center;padding:0 14px;font-weight:800;display:inline-flex}.period-switch a:last-child{border-right:0}.period-switch a.active{background:var(--teal);color:#fff}.status-pill,.source-strip,.secondary-button,.primary-button{border-radius:8px;align-items:center;gap:8px;min-height:44px;font-weight:700;display:inline-flex}.status-pill{color:var(--green);background:#edf8f0;border:1px solid #b9dcc5;padding:0 14px}.primary-button,.secondary-button{border:1px solid var(--line);cursor:pointer}.primary-button:disabled,.secondary-button:disabled{cursor:not-allowed;opacity:.55}.primary-button{background:var(--teal);color:#fff;padding:0 18px;box-shadow:0 1px #0000000a}.primary-button.disabled{pointer-events:none;opacity:.45}.primary-button.full{justify-content:center;width:100%}.secondary-button{color:var(--text);background:#fff;padding:0 16px}.danger-button{min-height:44px;color:var(--red);cursor:pointer;background:#fff7f6;border:1px solid #d9302547;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:0 16px;font-weight:800;display:inline-flex}.danger-button:disabled{cursor:not-allowed;opacity:.55}.source-strip{border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:8px;grid-template-columns:repeat(6,minmax(0,1fr));gap:0;margin-bottom:16px;padding:0;display:grid;overflow:hidden}.source-strip span{border-right:1px solid var(--line);white-space:nowrap;justify-content:center;align-items:center;gap:10px;min-height:54px;padding:0 14px;font-weight:750;display:flex}.source-strip span:last-child{border-right:0}.source-strip strong{color:var(--text);font-weight:800}.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:16px;display:grid}.kpi,.panel,.upload-panel,.process-panel{border:1px solid var(--line);background:var(--surface);border-radius:8px}.kpi{justify-content:space-between;align-items:center;gap:18px;min-height:132px;padding:20px 22px;display:flex;position:relative;overflow:hidden}.kpi:after{pointer-events:none;content:"";background:linear-gradient(135deg,#00736f0b,#fff0 46%);position:absolute;inset:0}.kpi-icon{width:50px;height:50px;color:var(--teal);background:#ecf6f1;border:1px solid #cfe2dc;border-radius:999px;flex:none;place-items:center;display:grid}.kpi-copy{z-index:1;gap:9px;min-width:0;display:grid;position:relative}.kpi span{color:var(--muted);font-weight:700}.kpi strong{color:#003e46;letter-spacing:0;font-size:34px;line-height:1;display:block}.kpi small{color:var(--muted)}.trend-up{color:var(--red);font-style:normal;font-weight:800}.trend-down{color:var(--green);font-style:normal;font-weight:800}.dashboard-grid{grid-template-columns:1.35fr .95fr;gap:16px;display:grid}.panel{min-width:0;padding:18px;box-shadow:0 1px 2px #10242606}.panel.wide{grid-column:span 1}.panel.full-width,.full-width{width:100%}.panel-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.panel-header h2,.upload-panel h2,.process-panel h2{margin:0;font-size:17px}.panel-header span,.panel-header a,.muted{color:var(--muted)}.bar-list{gap:20px;display:grid}.bar-row{grid-template-columns:76px 1fr 84px 56px;align-items:center;gap:12px;display:grid}.bar-label{font-weight:700}.bar-track{background:#edf1f0;border-radius:4px;height:15px;overflow:hidden}.bar-fill{border-radius:inherit;background:linear-gradient(90deg, var(--teal-2), #005f63);height:100%}.bar-row strong,.bar-row small{text-align:right}.alert-list,.rank-list{gap:12px;display:grid}.alert-row{border-bottom:1px solid var(--line);align-items:flex-start;gap:12px;padding:14px 0;display:flex}.alert-row:last-child{border-bottom:0}.alert-row strong,.alert-row span{display:block}.alert-row span{color:var(--muted);margin-top:4px}.danger-text{color:var(--red)}.warning-text{color:var(--amber)}.info-text{color:var(--blue)}.rank-row{border-bottom:1px solid var(--line);grid-template-columns:28px 1fr auto;align-items:center;gap:10px;padding:10px 0;display:grid}.rank-row:last-child{border-bottom:0}.rank-row span{color:var(--muted)}.rank-row em{font-style:normal;font-weight:750}.partner-card-list{gap:14px;display:grid}.partner-card-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:16px;padding:16px 0;display:flex}.partner-card-row:last-child{border-bottom:0}.partner-card-row strong,.partner-card-row span{display:block}.partner-card-row span{color:var(--muted);margin-top:5px;font-weight:700}.partner-card-row em{color:var(--red);white-space:nowrap;font-style:normal;font-weight:850}.scan-action{align-items:center;gap:10px;display:inline-flex}.scan-action>span{max-width:260px;color:var(--muted);font-size:12px;font-weight:750}.table-panel{overflow:auto}table{border-collapse:collapse;width:100%}th,td{border-bottom:1px solid var(--line);text-align:left;white-space:nowrap;padding:12px 10px}th{color:var(--muted);font-size:12px;font-weight:800}td{color:#1c2f31}.positive{color:var(--green);font-weight:760}.upload-layout{grid-template-columns:minmax(360px,520px) minmax(320px,1fr);gap:18px;display:grid}.compact-upload{display:block}.upload-panel,.process-panel{padding:26px}.compact-upload .upload-panel{background:0 0;border:0;padding:4px 0 0}.compact-upload .upload-panel svg{width:28px;height:28px}.upload-panel{gap:18px;display:grid}.upload-panel svg{color:var(--teal)}.upload-panel p{color:var(--muted);margin:0;line-height:1.7}.upload-panel input[type=file]{background:#f9fbfb;border:1px dashed #9fb6b7;border-radius:8px;width:100%;padding:18px}.date-field{color:var(--muted);gap:8px;font-weight:750;display:grid}.date-field input{border:1px solid var(--line);min-height:44px;color:var(--text);background:#fff;border-radius:8px;padding:0 12px}.city-scope{border:1px solid var(--line);background:var(--surface);border-radius:8px;grid-template-columns:150px 292px 150px minmax(280px,1fr) auto;align-items:center;gap:14px;margin-bottom:16px;padding:16px 18px;display:grid}.city-scope-title{align-items:center;gap:10px;min-width:0;display:flex}.city-scope-title svg{color:var(--teal)}.city-scope-title strong,.city-scope-title span{display:block}.city-scope-title strong{font-size:15px}.city-scope-title span{color:var(--muted);margin-top:3px;font-size:12px;font-weight:700}.scope-fields{grid-template-columns:120px 160px;gap:10px;display:grid}.scope-fields label{color:var(--muted);gap:6px;font-size:12px;font-weight:800;display:grid}.scope-fields select,.scope-fields input{border:1px solid var(--line);min-width:0;min-height:40px;color:var(--text);background:#fff;border-radius:8px;padding:0 10px}.city-scope-options{scrollbar-width:thin;flex-wrap:wrap;justify-content:flex-end;gap:8px;min-width:0;max-height:82px;padding:2px;display:flex;overflow:auto}.city-scope>.secondary-button{white-space:nowrap}.city-chip{border:1px solid var(--line);min-height:34px;color:var(--muted);cursor:pointer;background:#fbfcfc;border-radius:999px;flex:none;align-items:center;gap:7px;padding:0 12px;font-weight:800;display:inline-flex}.city-chip input{width:14px;height:14px;accent-color:var(--teal)}.city-chip.active{color:var(--teal);background:#e9f6f3;border-color:#00736f57}.city-empty{color:var(--muted);align-items:center;font-weight:750;display:inline-flex}.advanced-filter{border:1px solid var(--line);background:var(--surface);border-radius:8px;grid-template-columns:1.3fr repeat(4,minmax(150px,1fr));align-items:end;gap:14px;margin-bottom:16px;padding:18px;display:grid}.filter-title{grid-column:1/-1;align-items:flex-start;gap:12px;padding-bottom:4px;display:flex}.filter-title svg{color:var(--teal)}.filter-title h2{margin:0;font-size:18px}.filter-title p{color:var(--muted);margin:4px 0 0}.advanced-filter label{min-width:0;color:var(--muted);gap:8px;font-weight:750;display:grid}.advanced-filter select,.advanced-filter input{border:1px solid var(--line);min-width:0;min-height:44px;color:var(--text);background:#fff;border-radius:8px;padding:0 12px}.advanced-filter .input-shell input{border:0;min-height:auto;padding:0}.filter-search{grid-column:span 2}.range-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.filter-actions{align-items:center;gap:10px;display:flex}.sort-link{color:var(--muted);align-items:center;gap:4px;display:inline-flex}.sort-link.active{color:var(--teal)}.pagination{justify-content:flex-end;align-items:center;gap:12px;padding-top:16px;display:flex}.pagination a,.pagination span{border:1px solid var(--line);min-height:38px;color:var(--text);background:#fff;border-radius:8px;align-items:center;padding:0 12px;font-weight:750;display:inline-flex}.pagination span{color:var(--muted)}.pagination a.disabled{pointer-events:none;opacity:.45}.upload-message{background:var(--surface-soft);color:var(--teal);border-radius:8px;padding:14px;line-height:1.6}.file-list{color:var(--muted);background:#f5f8f7;border-radius:8px;gap:8px;padding:12px;display:grid}.file-list span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.upload-progress{background:#f5fbf9;border:1px solid #cfe2dc;border-radius:8px;gap:10px;padding:14px;display:grid}.upload-progress-copy{color:var(--muted);justify-content:space-between;align-items:center;gap:12px;font-weight:760;display:flex}.upload-progress-copy strong{color:var(--teal);white-space:nowrap}.upload-progress-track{background:#e4ece9;border-radius:999px;height:10px;position:relative;overflow:hidden}.upload-progress-track>div{border-radius:inherit;background:linear-gradient(90deg, var(--teal-2), var(--teal));height:100%;transition:width .22s}.upload-progress.indeterminate .upload-progress-track>div{min-width:34%;animation:1.2s ease-in-out infinite progressPulse}.process-panel{align-content:start;gap:14px;display:grid}.process-row{border-bottom:1px solid var(--line);color:var(--green);align-items:center;gap:12px;padding:14px 0;font-weight:750;display:flex}.process-row:last-child{border-bottom:0}.settings-section{margin-top:16px}.tab-switch{border:1px solid var(--line);background:#fbfcfc;border-radius:8px;max-width:100%;min-height:42px;margin-bottom:16px;display:inline-flex;overflow:hidden}.tab-switch button,.tab-switch a{border:0;border-right:1px solid var(--line);min-width:120px;color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;justify-content:center;align-items:center;padding:0 16px;font-weight:850;display:inline-flex}.tab-switch button:last-child,.tab-switch a:last-child{border-right:0}.tab-switch button.active,.tab-switch a.active{background:var(--teal);color:#fff}.table-tabs-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.table-tabs-header h2{margin:0;font-size:17px}.table-tabs-header span{color:var(--muted);margin-top:6px;display:block}.table-tab-switch{scrollbar-width:thin;flex:0 auto;overflow-x:auto}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px;display:grid}.stats-grid div{border:1px solid var(--line);background:#fbfcfc;border-radius:8px;gap:8px;padding:14px;display:grid}.stats-grid span{color:var(--muted);font-weight:750}.stats-grid strong{font-size:22px}.cleanup-stack{gap:12px;display:grid}.cleanup-panel{grid-template-columns:220px auto auto 1fr;align-items:end;gap:12px;display:grid}.directory-settings{grid-template-columns:minmax(320px,1fr) auto 120px 130px auto auto;align-items:end;gap:12px;margin-bottom:14px;display:grid}.directory-settings label{min-width:0;color:var(--muted);gap:8px;font-weight:750;display:grid}.directory-settings input[type=text],.directory-settings input:not([type]){border:1px solid var(--line);min-width:0;min-height:44px;color:var(--text);background:#fff;border-radius:8px;padding:0 12px}.directory-settings input[type=number]{border:1px solid var(--line);background:#fff;border-radius:8px;min-width:0;min-height:44px;padding:0 12px}.toggle-row{align-items:center;min-height:44px;gap:10px!important;display:flex!important}.toggle-row input{width:16px;height:16px;accent-color:var(--teal)}.directory-log{max-height:360px;margin-top:14px}.license-grid{grid-template-columns:1fr 1fr 1fr minmax(260px,1.25fr);gap:12px;margin-bottom:18px;display:grid}.license-grid div{border:1px solid var(--line);background:#fbfcfc;border-radius:8px;gap:8px;min-width:0;padding:16px;display:grid}.license-grid span{color:var(--muted);font-weight:750}.license-grid strong{overflow-wrap:anywhere;min-width:0;font-size:21px;line-height:1.25}.license-actions{grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);gap:16px;display:grid}.license-actions>div{border:1px solid var(--line);background:#fbfcfc;border-radius:8px;align-content:start;gap:12px;min-width:0;padding:16px;display:grid}.license-actions h3{align-items:center;gap:8px;margin:0;font-size:15px;display:flex}.license-actions h3 svg{color:var(--teal)}.license-upload{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.sr-only-file{clip:rect(0, 0, 0, 0);white-space:nowrap;clip-path:inset(50%);width:1px;height:1px;position:absolute;overflow:hidden}.selected-file-name{min-width:160px;max-width:280px;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-weight:750;overflow:hidden}.license-upload .auth-message{flex-basis:100%}.profit-rules{gap:10px;display:grid}.profit-rule-head,.profit-rule-row{grid-template-columns:64px minmax(220px,1fr) 160px 52px;align-items:center;gap:12px;display:grid}.profit-rule-head{color:var(--muted);font-size:12px;font-weight:850}.profit-rule-row{border:1px solid var(--line);background:#fbfcfc;border-radius:8px;min-height:54px;padding:8px 10px}.profit-rule-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--teal)}.profit-rule-row input[type=text],.profit-rule-row input:not([type]),.percent-input input{border:1px solid var(--line);min-width:0;min-height:38px;color:var(--text);background:#fff;border-radius:8px;padding:0 10px}.percent-input{align-items:center;gap:8px;display:flex}.percent-input input{width:100%}.percent-input span{color:var(--muted);font-weight:800}.icon-button{border:1px solid var(--line);width:38px;height:38px;color:var(--text);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.danger-icon{color:var(--red);border-color:#d930253d}.settings-actions{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes progressPulse{0%{opacity:.7;transform:translate(-28%)}50%{opacity:1;transform:translate(8%)}to{opacity:.78;transform:translate(28%)}}@media (max-width:1100px){.app-shell{grid-template-columns:1fr}.sidebar{width:auto;height:auto;min-height:auto;position:static}.nav-list{grid-template-columns:repeat(4,minmax(0,1fr))}.sidebar-bottom{display:none}.main{grid-column:1}.kpi-grid,.dashboard-grid,.upload-layout,.source-strip,.stats-grid,.cleanup-panel,.directory-settings,.city-scope,.scope-fields,.advanced-filter,.filter-search,.range-row{grid-template-columns:1fr}.filter-search,.filter-title{grid-column:auto}}@media (max-width:700px){body{font-size:14px}.sidebar{padding:16px 12px}.brand{padding:0 4px 16px}.nav-list{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.nav-item{text-align:center;flex-direction:column;justify-content:center;gap:6px;min-height:64px;padding:8px 6px;font-size:14px;line-height:1.2}.main{padding:18px 14px 28px}.topbar{flex-direction:column;align-items:stretch;gap:14px}.topbar h1{font-size:25px}.topbar-actions{grid-template-columns:1fr 1fr;align-items:stretch;gap:10px;display:grid}.period-switch{grid-column:1/-1;grid-template-columns:repeat(3,1fr);display:grid}.period-switch a,.status-pill,.city-scope .secondary-button,.secondary-button,.primary-button{justify-content:center;min-height:42px;padding:0 10px}.source-strip span{min-height:46px}.kpi{min-height:112px;padding:18px}.kpi strong{font-size:28px}.bar-row{grid-template-columns:58px 1fr 66px 46px;gap:8px}th,td{padding:10px 8px}.profit-rule-head{display:none}.profit-rule-row{grid-template-columns:28px 1fr 92px 40px;gap:8px;padding:8px}.percent-input{gap:5px}.icon-button{width:36px;height:36px}.login-page{padding:18px}.login-shell{min-height:auto}.login-hero,.login-panel{padding:28px}.login-hero h1{font-size:30px}}.login-page{background:var(--bg);place-items:center;min-height:100vh;padding:36px;display:grid}.login-shell{border:1px solid var(--line);background:var(--surface);border-radius:12px;grid-template-columns:1.15fr 440px;width:min(1040px,100%);min-height:640px;display:grid;overflow:hidden}.login-hero{color:#fff;background:linear-gradient(#00474f 0%,#005d62 100%);align-content:space-between;gap:28px;padding:42px;display:grid}.login-brand{gap:6px;display:grid}.login-brand span{font-size:24px;font-weight:850}.login-brand strong{color:#ffffffb8;font-size:14px}.login-hero .eyebrow{color:#ffffffb3}.login-hero h1{letter-spacing:0;max-width:560px;margin:0;font-size:38px;line-height:1.18}.login-hero p{color:#ffffffc7;max-width:560px;margin:16px 0 0;font-size:16px;line-height:1.8}.login-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.login-metrics div{background:#ffffff14;border:1px solid #ffffff29;border-radius:8px;gap:8px;padding:16px;display:grid}.login-metrics span,.login-feature-list{color:#ffffffb8}.login-metrics strong{color:#fff;font-size:24px}.login-feature-list{flex-wrap:wrap;gap:10px;display:flex}.login-feature-list span{background:#ffffff14;border:1px solid #ffffff29;border-radius:999px;align-items:center;gap:8px;padding:10px 12px;display:inline-flex}.login-panel{background:var(--surface);align-content:center;gap:24px;padding:42px;display:grid}.login-panel h2{margin:0 0 10px;font-size:26px}.login-form{gap:16px;display:grid}.login-form label{color:var(--muted);gap:8px;font-weight:700;display:grid}.input-shell{border:1px solid var(--line);min-height:46px;color:var(--muted);background:#fbfcfc;border-radius:8px;align-items:center;gap:10px;padding:0 12px;display:flex}.input-shell input{width:100%;color:var(--text);background:0 0;border:0;outline:0}.login-note,.auth-message{background:var(--surface-soft);color:var(--teal);border-radius:8px;padding:12px;font-weight:750}.auth-message.danger{color:var(--red);background:#fff2f0}.machine-code-box{background:#f7fbfa;border:1px dashed #b8c9c6;border-radius:8px;gap:6px;padding:12px;display:grid}.machine-code-box span,.machine-code-inline{color:var(--muted)}.machine-code-box strong,.machine-code-inline{overflow-wrap:anywhere;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:13px;line-height:1.45}@media (max-width:900px){.login-shell{grid-template-columns:1fr}.login-hero{min-height:420px}.login-metrics{grid-template-columns:1fr}}
