:root{
  /* 陕康艺足品牌色：品牌蓝主色 + 暖橙点缀（变量名沿用，全站自动变蓝） */
  --green:#1f66b0; --green-d:#16487d; --green-l:#e8f1fa;
  --accent:#b8651a; --pink:#a8c8e8;
  --bg:#f3f7fb; --card:#fff; --line:#dbe7f2; --text:#22303f; --muted:#6b7c92;
  --danger:#d9534f; --shadow:0 2px 14px rgba(31,102,176,.10);
  --radius:12px;
}
*{box-sizing:border-box}
body{margin:0;font-family:"PingFang SC","Microsoft YaHei",system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px}
.hidden{display:none!important}
a{cursor:pointer;text-decoration:none;color:inherit}

/* 按钮 */
.btn{border:1px solid var(--line);background:#fff;border-radius:8px;padding:7px 14px;cursor:pointer;font-size:13px;color:var(--text);transition:.15s}
.btn:hover{border-color:var(--green);color:var(--green)}
.btn-primary{background:var(--green);border-color:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-d);color:#fff}
.btn-danger{color:var(--danger);border-color:#f0c9c9}
.btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-mini{padding:4px 10px;font-size:12px}
.btn-block{width:100%;padding:11px;font-size:15px;margin-top:6px}

/* 登录 */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1f66b0,#16487d)}
.login-card{background:#fff;padding:40px 36px;border-radius:16px;width:340px;max-width:92vw;box-shadow:0 10px 40px rgba(0,0,0,.2);display:flex;flex-direction:column;gap:14px}
.login-logo{font-size:28px;font-weight:700;text-align:center;color:var(--green)}
.login-sub{text-align:center;color:var(--muted);margin-bottom:4px;font-size:13px}
.login-slogan{text-align:center;color:var(--accent);margin-bottom:12px;font-size:12px;letter-spacing:2px}
.login-card input{padding:11px 13px;border:1px solid var(--line);border-radius:8px;font-size:14px}
.login-card input:focus{outline:none;border-color:var(--green)}
.err-msg{color:var(--danger);font-size:13px;text-align:center;min-height:18px}

/* 顶栏 */
.topbar{display:flex;align-items:center;background:#fff;border-bottom:1px solid var(--line);padding:0 22px;height:58px;position:sticky;top:0;z-index:50;box-shadow:var(--shadow)}
.brand{font-size:19px;font-weight:700;color:var(--green)}
.brand span{font-size:13px;color:var(--muted);font-weight:400;margin-left:4px}
.nav{display:flex;gap:6px;margin-left:36px;flex:1}
.nav-item{padding:8px 15px;border-radius:8px;color:var(--muted);font-size:14px;display:flex;align-items:center;gap:5px}
.nav-item:hover{background:var(--green-l);color:var(--green)}
.nav-item.active{background:var(--green);color:#fff}
.user-area{display:flex;align-items:center;gap:8px}
.me-name{font-size:13px;color:var(--text);margin-right:4px}
.badge{background:var(--accent);color:#fff;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:700}
.nav-item.active .badge{background:#fff;color:var(--accent)}

.main{max-width:1280px;margin:0 auto;padding:24px 22px 60px}

/* 卡片/区块 */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.section-title{font-size:18px;font-weight:700;margin:0 0 16px;display:flex;align-items:center;gap:10px}
.row-between{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}

/* 统计卡 */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:22px}
.stat-grid.center{display:flex;justify-content:center;flex-wrap:wrap}
.stat-grid.center .stat{width:240px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.stat .label{color:var(--muted);font-size:13px}
.stat .value{font-size:26px;font-weight:700;margin-top:6px;color:var(--green)}
.stat .value.money{color:var(--accent)}
.stat .value.neg{color:var(--danger)}
.stat.clickable{cursor:pointer;transition:.15s}
.stat.clickable:hover{border-color:var(--green);box-shadow:0 4px 18px rgba(31,102,176,.18);transform:translateY(-2px)}
.status-box.clickable{cursor:pointer;transition:.15s}
.status-box.clickable:hover{box-shadow:0 4px 14px rgba(31,102,176,.22);transform:translateY(-2px)}
.filter-chip{background:var(--green);color:#fff;border-radius:16px;padding:6px 13px;font-size:12px;cursor:pointer;font-weight:600}
.filter-chip:hover{background:var(--green-d)}
.stat small{font-size:13px;color:var(--muted);font-weight:400}
.stat .sub{margin-top:8px;font-size:13px;color:var(--accent);font-weight:600;border-top:1px dashed var(--line);padding-top:7px}

.charts{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.chart-card{padding:18px;display:flex;flex-direction:column}
.chart-card h3{margin:0 0 14px;font-size:15px}
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:9px;font-size:13px}
.bar-row .bl{width:90px;color:var(--muted);text-align:right;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{flex:1;background:var(--green-l);border-radius:6px;height:18px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--green-d));border-radius:6px}
.bar-row .bv{width:36px;text-align:right;font-weight:600}
.status-sub{font-size:12px;color:var(--accent);margin:-4px 0 9px 100px;font-weight:600}
.status-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;flex:1;grid-auto-rows:1fr}
.status-box{background:var(--green-l);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;justify-content:center}
.status-box .sb-name{font-size:13px;color:var(--green-d);font-weight:600}
.status-box .sb-total{font-size:24px;font-weight:700;color:var(--green);margin:4px 0 6px}
.status-box .sb-extra{font-size:12px;color:var(--green-d);font-weight:600;margin-top:4px}
.status-box .sb-month{font-size:12px;color:var(--accent);font-weight:600;border-top:1px dashed #cfe6da;padding-top:6px;margin-top:6px}
.pie-wrap{display:flex;flex-direction:column;align-items:center;gap:18px}
.pie{position:relative;width:240px;height:240px;border-radius:50%;flex-shrink:0;box-shadow:inset 0 0 0 1px rgba(0,0,0,.05)}
.pie-label{position:absolute;transform:translate(-50%,-50%);color:#fff;text-align:center;line-height:1.15;text-shadow:0 1px 3px rgba(0,0,0,.6);pointer-events:none}
.pie-label .pl-name{font-weight:700;font-size:13px;white-space:nowrap}
.pie-label .pl-num{font-size:11px;opacity:.95}
.pie-clickable{cursor:zoom-in;transition:transform .15s}
.pie-clickable:hover{transform:scale(1.03)}
.rank-title{font-size:14px;margin:18px 0 10px;color:var(--text)}
.pie-rank{display:flex;flex-direction:column;gap:7px;width:100%;max-height:230px;overflow:auto}
.rank-row{display:flex;align-items:center;gap:8px;font-size:13px}
.rank-no{width:20px;height:20px;border-radius:50%;background:var(--green-l);color:var(--green-d);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rank-no.top{background:var(--green);color:#fff}
.rank-name{width:80px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rank-bar-wrap{flex:1;background:var(--green-l);border-radius:5px;height:14px;overflow:hidden}
.rank-bar{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--green-d));border-radius:5px}
.rank-count{width:28px;text-align:right;font-weight:700;color:var(--green-d)}
.rank-row-link{cursor:pointer;border-radius:6px;padding:3px 5px;margin:0 -5px;transition:background .12s}
.rank-row-link:hover{background:var(--green-l)}
.rank-row-link:hover .rank-name{color:var(--green-d)}
.pie-legend{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px}
.pie-li{display:flex;align-items:center;gap:8px;font-size:13px}
.pie-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}
.pie-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pie-val{color:var(--muted);font-weight:600;font-size:12px}
.warn-card.active{border:2px solid var(--danger);box-shadow:0 4px 20px rgba(224,86,86,.25)}
.warn-card.active h3 span:first-child{color:var(--danger)}
.warn-card-h{display:flex;align-items:center;justify-content:space-between;gap:8px}
.warn-count{background:var(--danger);color:#fff;border-radius:14px;padding:3px 12px;font-size:13px;font-weight:700;animation:warnpulse 1.4s ease-in-out infinite}
.warn-ok{background:#e3f5ea;color:var(--green-d);border-radius:14px;padding:3px 12px;font-size:12px;font-weight:600}
@keyframes warnpulse{0%,100%{box-shadow:0 0 0 0 rgba(224,86,86,.5)}50%{box-shadow:0 0 0 6px rgba(224,86,86,0)}}
.overdue-list{display:flex;flex-direction:column;gap:7px;max-height:300px;overflow-y:auto;padding-right:3px}
.overdue-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:9px}
.overdue-item{display:flex;align-items:center;gap:8px;padding:8px 11px;background:#fdecec;border-radius:8px;cursor:pointer;font-size:13px}
.overdue-item:hover{background:#fbe0e0}
.overdue-item .od-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}
.overdue-item .od-days{color:var(--danger);font-weight:700;font-size:12px;white-space:nowrap}

/* 工具栏 */
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.toolbar input,.toolbar select{padding:8px 11px;border:1px solid var(--line);border-radius:8px;font-size:13px;background:#fff}
.toolbar input:focus,.toolbar select:focus{outline:none;border-color:var(--green)}
.search-box{min-width:220px}
.spacer{flex:1}

/* 表格 */
.table-wrap{overflow:auto;border-radius:var(--radius);border:1px solid var(--line);background:#fff;box-shadow:var(--shadow)}
table{border-collapse:collapse;width:100%;font-size:13px;min-width:760px}
th,td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
th{background:#f0f5f2;color:var(--muted);font-weight:600;position:sticky;top:0}
tbody tr:hover{background:var(--green-l)}
td.wrap,th.wrap{white-space:normal}
.link{color:var(--green);font-weight:600;cursor:pointer}
.link:hover{text-decoration:underline}
.muted{color:var(--muted)}
.empty{text-align:center;padding:50px;color:var(--muted)}

/* 列表排序 */
.sort-label{font-size:12px;margin-left:4px}
.sort-hint{font-size:12px;margin:0 2px 8px;padding:6px 11px;background:#f0f5f2;border-radius:8px;display:inline-block}
td.drag-handle{cursor:grab;color:#9aa;text-align:center;width:30px;font-size:15px;user-select:none}
td.drag-handle:active{cursor:grabbing}
tr.drag-row.dragging{opacity:.45;background:var(--green-l)}
th.th-sort{cursor:pointer;user-select:none}
th.th-sort:hover{color:var(--green)}
th.th-sort.active{color:var(--green)}

/* 督导行程 */
.sup-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:14px 0}
.sup-toolbar input[type=month],.sup-toolbar input[type=date]{padding:7px 10px;border:1px solid var(--line);border-radius:8px;font-size:13px;background:#fff}
.sup-legend{display:flex;gap:14px;margin:4px 0 12px;font-size:12px;color:var(--muted);flex-wrap:wrap;align-items:center}
.sup-legend i{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:5px;vertical-align:-1px}
.sup-wrap{max-height:72vh}
table.sup-grid{min-width:auto;font-size:12px}
table.sup-grid th,table.sup-grid td{padding:5px 6px;border:1px solid var(--line);text-align:center;white-space:nowrap}
table.sup-grid th.sup-day{min-width:30px;color:var(--muted);font-weight:600}
table.sup-grid th.sup-day.weekend{background:#fde9e9;color:#c0392b}
.sup-name-col{position:sticky;left:0;z-index:2;background:#f0f5f2;font-weight:600;text-align:left;min-width:80px;box-shadow:1px 0 0 var(--line)}
.sup-row-handle{cursor:grab;color:#9aa;margin-right:5px;user-select:none;letter-spacing:-2px}
.sup-row-handle:active{cursor:grabbing}
tr.row-dragging{opacity:.5;background:var(--green-l)}
table.sup-grid th.sup-name-col{z-index:3}
.sup-cell{max-width:62px;overflow:hidden;text-overflow:ellipsis}
.sup-cell.editable,.sup-name-col.editable{cursor:pointer}
.sup-cell.editable{user-select:none}
.sup-cell.editable:hover{outline:2px solid var(--green);outline-offset:-2px}
.sup-cell.sup-sel{background:#cdeacd!important;outline:2px solid var(--green-d);outline-offset:-2px}
.sup-name-col.editable:hover{color:var(--green)}
.sup-cell.c-visit{background:#e3f3e6;color:#1c6b32}
.sup-cell.c-site{background:#ece6f8;color:#5b3fa0}
.sup-cell.c-site-ok{background:#d8f0dd;color:#1c6b32}
.sup-cell.c-site-fail{background:#fadddd;color:#b5302f}
.sup-cell.c-patrol{background:#e2f0f6;color:#2a6f89}
.sup-cell.c-company{background:#eef1f4;color:#5a6577}
.sup-cell.c-rest{background:#fbf3e0;color:#9a7a22}
.sup-cell.c-other,.sup-cell.c-note{background:#fff4f0;color:#b5552f}
.sup-cards{display:flex;gap:14px;flex-wrap:wrap;margin:8px 0 18px}
.sup-card{flex:1;min-width:120px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px}
.sup-card.clickable{cursor:pointer;transition:box-shadow .15s,transform .15s}
.sup-card.clickable:hover{box-shadow:0 4px 14px rgba(0,0,0,.12);transform:translateY(-1px)}
.sup-card .v{font-size:24px;font-weight:700;color:var(--green-d)}
.sup-card .l{font-size:12px;color:var(--muted);margin-top:3px}
.sup-bar-row{display:flex;align-items:center;gap:10px;margin:5px 0;font-size:12px}
.sup-bar-label{width:62px;color:var(--muted)}
.sup-bar-track{flex:1;background:#eef1f4;border-radius:6px;height:16px;overflow:hidden}
.sup-bar-fill{height:100%;background:var(--green);border-radius:6px;min-width:2px}
.sup-bar-val{width:36px;text-align:right;font-weight:600}
.sup-fields{display:flex;flex-direction:column;gap:8px}
.sup-field{display:flex;align-items:center;gap:10px}
.sup-field label{width:42px;flex:none;color:var(--muted);font-size:13px;text-align:right}
.sup-field .search-box{flex:1}

/* 状态标签 */
.tag{display:inline-block;padding:2px 9px;border-radius:20px;font-size:12px;background:#eef1ef;color:var(--muted)}
.tag.s-已开业,.tag.s-正常经营{background:#e3f5ea;color:var(--green-d)}
.tag.s-装修中,.tag.s-待开业{background:#fdf0e1;color:#b9701f}
.tag.s-老师选址中,.tag.s-待选址{background:#eaf0fb;color:#3a6abf}
.tag.s-已交定金{background:#efe9fb;color:#6a45c0}
.tag.s-需重点跟进{background:#fde6ec;color:#c33a63}
.tag.s-已关店,.tag.s-已解除协议{background:#f0e1e1;color:#a85050}
.due-over{color:var(--danger);font-weight:700}
.due-soon{color:var(--accent);font-weight:600}
.due-ok{color:var(--green)}
.warn-title{font-size:16px;margin:6px 0 10px;color:var(--danger)}
tr.warn-row{background:#fdecec}
tr.warn-row:hover{background:#fbe0e0}

/* 弹窗 */
.modal-backdrop{position:fixed;inset:0;background:rgba(20,40,30,.5);display:flex;align-items:flex-start;justify-content:center;z-index:100;padding:30px 16px;overflow:auto}
.modal{background:#fff;border-radius:14px;width:100%;max-width:760px;box-shadow:0 20px 60px rgba(0,0,0,.3);animation:pop .15s}
.modal.wide{max-width:1060px}
@keyframes pop{from{transform:translateY(-12px);opacity:.6}to{transform:none;opacity:1}}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 22px;border-bottom:1px solid var(--line)}
.modal-head span{font-size:17px;font-weight:700}
.modal-x{border:none;background:none;font-size:18px;cursor:pointer;color:var(--muted)}
.modal-x:hover{color:var(--danger)}
.modal-body{padding:22px}

/* 表单 */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid.wide-form{grid-template-columns:repeat(3,1fr);gap:14px 20px}
.form-section{grid-column:1 / -1;font-size:14px;font-weight:700;color:var(--green-d);padding:8px 0 4px;border-bottom:2px solid var(--green-l);margin-top:6px}
.form-section:first-child{margin-top:0}
.mat-rows{display:flex;flex-direction:column;gap:8px}
.mat-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.mat-row .mat-label{width:48px;font-size:13px;color:var(--muted);flex-shrink:0}
.field{display:flex;flex-direction:column;gap:5px}
.field.full{grid-column:1 / -1}
.field label{font-size:12px;color:var(--muted);font-weight:600}
.field input,.field select,.field textarea{padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-size:13px;font-family:inherit}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green)}
.field textarea{resize:vertical;min-height:62px}
.field input[type=file]{font-size:12px;padding:6px 0;border:none}
.img-preview{max-width:160px;max-height:140px;border-radius:8px;border:1px solid var(--line);object-fit:cover}
.img-thumb{max-width:130px;max-height:110px;border-radius:6px;border:1px solid var(--line);object-fit:cover;cursor:pointer;margin-top:4px}
/* 资料文件画廊（多图/多视频/PDF） */
.file-gallery{width:100%}
.fg-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.fg-cell{position:relative;width:104px;height:104px;border-radius:8px;overflow:hidden;border:1px solid var(--line);background:#eef4fb;display:flex;align-items:center;justify-content:center}
.fg-grid.view .fg-cell{width:120px;height:120px}
.fg-media{width:104px;height:104px;object-fit:cover;display:block;background:#000}
.fg-grid.view .fg-media{width:120px;height:120px}
.fg-pdf{display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#c0392b;background:#fdeceb;text-decoration:none}
.fg-del{position:absolute;top:3px;right:3px;width:20px;height:20px;line-height:18px;text-align:center;border:none;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;cursor:pointer;font-size:14px;padding:0}
.fg-del:hover{background:var(--danger)}
.fg-badge{position:absolute;left:3px;bottom:3px;background:rgba(0,0,0,.6);color:#fff;font-size:10px;padding:1px 6px;border-radius:8px}
.fg-progress{font-size:12px;color:var(--accent);font-weight:600}
/* 跟进面板内嵌的「加盟商信息 / 补充资料」 */
.fu-info-panel{background:#eef4fb;border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin:2px 0 6px}
.fu-info-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:8px}
.fu-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 18px;font-size:13px;margin-bottom:6px}
.fu-info-item .k{color:var(--muted)}
.doc-badge{display:inline-block;padding:5px 14px;border-radius:20px;font-size:13px;background:#fdf0e1;color:#b9701f;font-weight:600}
.doc-badge.done{background:#e3f5ea;color:var(--green-d)}
.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;grid-column:1 / -1}

/* 详情页 */
.detail-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--line);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.detail-grid .di{background:#fff;padding:13px 16px}
.detail-grid .di .k{font-size:12px;color:var(--muted)}
.detail-grid .di .v{font-size:14px;margin-top:3px;word-break:break-all}
.fu-item{border-left:3px solid var(--green);background:#fff;border:1px solid var(--line);border-left:3px solid var(--green);border-radius:8px;padding:13px 16px;margin-bottom:10px}
.fu-meta{display:flex;gap:12px;align-items:center;font-size:12px;color:var(--muted);margin-bottom:6px;flex-wrap:wrap}
.fu-meta b{color:var(--green-d)}
.fu-content{font-size:14px;white-space:pre-wrap;line-height:1.55}
.fu-next{margin-top:7px;font-size:12px}

.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%);background:#2b3a34;color:#fff;padding:11px 22px;border-radius:24px;font-size:14px;z-index:200;box-shadow:0 6px 20px rgba(0,0,0,.25)}
.tab-bar{display:flex;gap:4px;border-bottom:2px solid var(--line);margin-bottom:20px}
.tab{padding:9px 18px;font-size:14px;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer}
.tab:hover{color:var(--green)}
.tab.active{color:var(--green);border-bottom-color:var(--green);font-weight:700}
.log-list{display:flex;flex-direction:column;gap:6px}
.log-item{display:flex;gap:12px;align-items:baseline;font-size:13px;padding:8px 12px;background:#f7faf9;border-radius:8px;flex-wrap:wrap}
.log-item .log-time{color:var(--muted);width:120px;flex-shrink:0}
.log-item .log-user{font-weight:600;color:var(--green-d);width:64px;flex-shrink:0}
.log-item .log-act{color:var(--text)}
.log-item .log-detail{color:var(--muted)}
.back-link{color:var(--muted);font-size:13px;margin-bottom:14px;display:inline-block}
.back-link:hover{color:var(--green)}
/* ============ 手机端自适应 ============ */
@media(max-width:760px){
  /* 顶栏：换行成两行——品牌+用户区一行，导航单独占一整行可横向滑动 */
  .topbar{height:auto;flex-wrap:wrap;padding:8px 12px;gap:6px;position:sticky}
  .brand{font-size:16px;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .brand span{display:none}
  .user-area{order:2;gap:6px}
  .me-name{display:none}
  .nav{order:3;flex-basis:100%;margin-left:0;gap:5px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:3px}
  .nav::-webkit-scrollbar{display:none}
  .nav-item{flex:0 0 auto;padding:7px 12px;font-size:13px}
  .nav-item span:not(.badge){display:inline}

  /* 设置页标签栏：不换行、文字不竖排、可横向滑动 */
  .tab-bar{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:2px}
  .tab-bar::-webkit-scrollbar{display:none}
  .tab{flex:0 0 auto;white-space:nowrap;padding:9px 13px}

  /* 主体内边距收紧 */
  .main{padding:14px 12px 48px}
  .section-title{font-size:16px;margin-bottom:12px}

  /* 统计卡：两列 */
  .stat-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
  .stat-grid.center .stat,.stat{width:auto}
  .stat{padding:14px}
  .stat .value{font-size:22px}

  /* 图表：单列 */
  .charts{grid-template-columns:1fr;gap:12px}
  .chart-card{padding:14px}
  .pie{width:200px;height:200px}

  /* 工具栏：搜索框占满整行 */
  .toolbar{gap:8px}
  .search-box{min-width:0;flex:1 1 100%}

  /* 表格：保留横向滑动 + 触摸惯性 */
  .table-wrap,.sup-wrap{-webkit-overflow-scrolling:touch}

  /* 弹窗：贴边、内边距收紧 */
  .modal-backdrop{padding:12px 8px}
  .modal-body{padding:16px}
  .modal-head{padding:13px 16px}

  /* 表单：单列 */
  .form-grid,.form-grid.wide-form{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr 1fr}
  .form-actions{flex-direction:column-reverse}
  .form-actions .btn{width:100%}

  /* 防止 iOS 聚焦输入框时自动放大（字号需 ≥16px） */
  .login-card input,.field input,.field select,.field textarea,
  .toolbar input,.toolbar select,.sup-toolbar input,.import-map select{font-size:16px}
}
@media(max-width:430px){
  .stat-grid{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr}
  .fu-info-grid{grid-template-columns:1fr}
  .pie-legend{grid-template-columns:1fr}
}

/* 批量导入 · 列对应表 */
.import-map{width:100%;border-collapse:collapse;margin:10px 0}
.import-map th{text-align:left;font-size:12px;color:var(--muted);padding:6px 10px;border-bottom:1px solid var(--line)}
.import-map td{padding:6px 10px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}
.import-map select{width:100%;padding:6px 8px;border:1px solid var(--line);border-radius:6px;font-size:13px;background:#fff}
