/* =========================
   Design System（全站通用）
   - 只放稳定通用样式
   - 不包含 index 的特殊布局/弹窗
========================= */
:root{
  --bg:#0b1220;
  --card:#121c33;
  --card2:#0f1730;
  --border:rgba(255,255,255,.10);
  --text:#ffffff;
  --muted:rgba(255,255,255,.75);
  --primary:#2b6cff;
  --danger:#ff4d4f;
  --ok:#3ddc97;
  --radius:16px;
  --shadow: 0 12px 40px rgba(0,0,0,.35);
}

/* ===== Admin modal/overlay (admin.html) ===== */
.overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  padding: 18px;
}
.overlay.show{ display:flex; }
.dialog{
  width: min(760px, 94vw);
  max-height: 88vh;
  overflow: auto;
  background: rgba(14,23,48,.98);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
}
body.modal-open{ overflow: hidden; }

*{box-sizing:border-box}
html,body{height:100%;overflow-x:hidden}

body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,"PingFang SC","Microsoft Yahei",Arial;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
}

button{font:inherit}

a{color:inherit;text-decoration:none}

.container{width:min(1200px,94vw);margin:0 auto;padding:16px}

.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
}

.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

.title{font-size:16px;font-weight:800}
.small{font-size:12px;color:var(--muted)}
.muted{color:var(--muted)}
.hr{height:1px;background:var(--border);margin:12px 0}

.badge{
  font-size:12px;padding:2px 8px;border-radius:999px;
  background:rgba(255,255,255,.10);
  color:var(--muted);
}

.pill{
  font-size:12px;padding:7px 10px;border-radius:999px;
  /*background: rgba(255, 255, 255, .7);*/
  border:1px solid var(--border);
  /*background: rgba(54, 126, 255, .22);
  border-color: rgba(54, 126, 255, .55);*/
  color: #fff;
}
.user-pall{
  font-size:12px;padding:7px 10px;border-radius:999px;
  border: 1px solid rgba(255, 255, 255, .12);
  background: rgba(255, 255, 255, .04);
  color: rgba(255, 255, 255, .88);
  height: auto;
}
.input{
  width:100%;
  padding:12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--card2);
  color:#fff;
}


/* 表单下拉：深色背景下 option 可读（部分浏览器可生效，移动端多数为系统原生） */
select.input{ color:#fff; }
select.input option{ background:#0b1220; color:#fff; }
.btn{
  border:0;
  border-radius:12px;
  padding:10px 12px;
  background:var(--primary);
  color:#fff;
  font-weight:700;
  cursor:pointer;
}
.btn-block{width:100%;display:flex;justify-content:center}
/* 兼容命名：有些页面/组件习惯用 btn-danger */
.btn-danger{background:var(--danger) !important}
.btn.secondary{background:#2a3558}
.btn.danger{background:var(--danger)}
.btn.ghost{background:rgba(255,255,255,.06);border:1px solid var(--border)}
.btn:disabled{opacity:.55;cursor:not-allowed}

.msg{font-size:12px;color:var(--muted);margin-top:8px}
.msg.ok{color:var(--ok)}
.msg.err{color:#ffd0d0}

/* 顶部栏（admin/user/login 用） */
.header{
  position:sticky;top:0;z-index:20;
  background:rgba(11,18,32,.92);
  border-bottom:1px solid var(--border);
  backdrop-filter: blur(10px);
}
.header .in{
  width:min(1200px,94vw);
  margin:0 auto;
  padding:12px 16px;
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap
}
.brand{display:flex;gap:10px;align-items:center;font-weight:800}
.brand .dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--primary);
  box-shadow:0 0 16px rgba(43,108,255,.55)
}

/* 使用统一壳后：隐藏旧 .header（避免出现重复标题/重复按钮） */
/*
  旧页面里都有一条 .header（legacy 顶栏）。
  Shell 注入后我们会生成新的 .app-header，避免把新顶栏一起隐藏。
*/
html.has-shell .header:not(.app-header){display:none !important}

/* =========================
   App Shell（全站统一骨架）
   - Phase-1：除 index 外，页面内容会被 layout.js 包进 .app-main
========================= */
.app-layout{min-height:calc(100vh - 58px)}

/* 侧边栏：桌面“浮动”形态（不占用页面宽度），移动端保留抽屉体验 */
.app-sidebar{
  width:240px;
  border-right:1px solid var(--border);
  background:rgba(11,18,32,.78);
  backdrop-filter: blur(10px);
  position:fixed;
  left:14px;
  top:72px;
  bottom:14px;
  z-index:90;
  border-radius:18px;
  box-shadow:0 12px 40px rgba(0,0,0,.35);
  transform:translateX(0);
  transition:transform .22s ease, opacity .22s ease;
}
.app-sidebar__inner{padding:12px}
.app-sidebar__top{position:relative;display:flex;align-items:center;justify-content:flex-end;margin-bottom:6px;min-height:44px;gap:8px}
.app-sidebar__title{flex:1;color:var(--muted);font-size:18px;letter-spacing:.12em;text-transform:uppercase;padding-left:6px}
.app-sidebar__collapse{
  width:40px;
  height:40px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 10px 26px rgba(0,0,0,.35);
}
.app-sidebar__collapse .chev{display:inline-block;width:10px;height:10px;border-right:2px solid rgba(255,255,255,.7);border-bottom:2px solid rgba(255,255,255,.7);transform:rotate(135deg)}

/* ✅ PC 也可收起侧栏：不占用页面宽度，保留一个“小把手”可再次展开 */
html.nav-hidden .app-sidebar{transform:translateX(calc(-100% + 54px))}
html.nav-hidden .app-nav__text{display:none}
html.nav-hidden .app-nav__item{justify-content:center}
html.nav-hidden .app-sidebar__title{opacity:.0}
html.nav-hidden .app-sidebar__collapse .chev{transform:rotate(-45deg)}
.app-nav{display:flex;flex-direction:column;gap:6px}
.app-nav__item{
  display:flex;align-items:center;gap:10px;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid transparent;
  color:rgba(255,255,255,.90);
}
.app-nav__item:hover{background:rgba(255,255,255,.06);border-color:var(--border)}
.app-nav__item.is-active{background:rgba(43,108,255,.16);border-color:rgba(43,108,255,.35)}
.app-nav__item--danger{color:rgba(255,120,120,.95)}
.app-nav__item--danger:hover{background:rgba(255,80,80,.12);border-color:rgba(255,80,80,.18)}
.app-nav__icon{width:22px;text-align:center}
.app-nav__sep{height:1px;background:var(--border);margin:10px 6px}
.app-sidebar__foot{margin-top:10px;padding:10px 8px;border-top:1px solid var(--border)}

.app-main{min-width:0}

.app-footer{
  border-top:1px solid var(--border);
  background:rgba(11,18,32,.72);
  backdrop-filter: blur(10px);
}
.app-footer__in{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}

.app-header__right{gap:10px}
.app-navbtn{display:none}

/* 首页：调度参数按钮（PC 显示文字 + 图标；手机只显示图标） */
.btn-cfg{gap:8px}
.btn-cfg .cfg-ico{display:inline-flex;align-items:center;justify-content:center}
@media (max-width: 920px){
  .btn-cfg .btn-label{display:none}
  .btn-cfg{padding:10px 12px}
}

.app-user{position:relative}
.app-user__menu{
  position:absolute;
  right:0;
  top:calc(100% + 8px);
  width:min(220px, 70vw);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:6px;
  display:none;
  z-index:50;
}
.app-user__menu.open{display:block}
.app-user__item{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  padding:10px;
  border-radius:12px;
  background:transparent;
  border:0;
  cursor:pointer;
  color:rgba(255,255,255,.92);
  font:inherit;
  text-align:left;
}
.app-user__item:hover{background:rgba(255,255,255,.06)}
.app-user__item.danger{color:#ffd0d0}
.app-user__sep{height:1px;background:var(--border);margin:6px 4px}

.app-nav-mask{display:none}

/* 移动端：顶部汉堡菜单按钮 */
.app-hamburger{padding:10px 12px;border-radius:999px}
.hamburger{
  display:inline-block;
  width:18px;
  height:2px;
  background:rgba(255,255,255,.82);
  border-radius:999px;
  position:relative;
}
.hamburger::before,.hamburger::after{
  content:"";
  position:absolute;
  left:0;
  width:18px;
  height:2px;
  background:rgba(255,255,255,.82);
  border-radius:999px;
}
.hamburger::before{top:-6px}
.hamburger::after{top:6px}

/* 齿轮图标（调度参数） */
.icon-gear{
  width:18px;
  height:18px;
  display:inline-block;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  position:relative;
  margin-right:8px;
}
.icon-gear::before{
  content:"";
  position:absolute;
  inset:4px;
  border:2px solid rgba(255,255,255,.75);
  border-radius:999px;
}
.icon-gear::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:2px;
  height:8px;
  background:rgba(255,255,255,.75);
  transform:translate(-50%,-50%) rotate(30deg);
  border-radius:2px;
}

@media (max-width: 980px){
  .app-navbtn{display:inline-flex}
  .app-layout{position:relative}
  .app-nav-mask{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.45);
    opacity:0;
    pointer-events:none;
    transition:opacity .18s ease;
    z-index:30;
  }
  .app-sidebar{
    position:fixed;
    left:-260px;
    top:58px;
    bottom:0;
    z-index:40;
    transition:left .18s ease;
    /* 移动端侧栏用 left 推拉，不走桌面端的 transform 收起逻辑 */
    transform:none !important;
  }
  html.nav-open .app-sidebar{left:0}
  html.nav-open .app-nav-mask{opacity:1;pointer-events:auto}
}

/* 旧页面顶部按钮：统一隐藏，但不要误伤移动端汉堡按钮 */
.header .in .row > .btn:not(#btnNavToggle),
.header .in .row > a{display:none !important}

/* 首页 topbar：隐藏“个人中心/退出”，仅保留“调度参数”（按钮存在时才显示） */
.topbar #btnGoUser,
.topbar #btnLogout{display:none !important}

/* 首页：移动端也要能打开调度参数 */
@media (max-width: 980px){
  .topbar #btnOpenCfg{display:inline-flex !important}
  .topbar #btnOpenCfg{padding:10px 12px;border-radius:999px}
  .topbar #btnOpenCfg .btn-label{display:none}
  .topbar #btnOpenCfg .icon-gear{margin-right:0;background:transparent}
}

/* 防止内容区横向溢出 */
.app-layout,.app-main,.container,.card{min-width:0;max-width:100%;margin-top: 12px}
.table-wrap{max-width:100%;overflow-x:auto}
.table{min-width:640px}
/* 表格横向滚动：避免页面整体出现横向滚动条 */
.table{display:block;overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}
.table thead,.table tbody{display:table;width:100%}

/* Admin Tabs：兼容旧 is-active 类名，补齐样式 */
.tabs{display:flex;gap:10px;flex-wrap:wrap}
.tab{
  appearance:none;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.9);
  padding:10px 14px;
  border-radius:999px;
  cursor:pointer;
  font:inherit;
}
.tab:hover{background:rgba(255,255,255,.07)}
.tab.is-active,.tab.active{background:rgba(54,126,255,.22);border-color:rgba(54,126,255,.55)}
.tab-panel{display:none}
.tab-panel.is-active,.tab-panel.active{display:block}

/* 顶部栏：移动端标题不要太挤 */
@media (max-width: 520px){
  .app-brand__badge{display:none}
  .app-brand__text{font-size:15px}
  .pill{/*max-width:42vw;*/white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
}

/* =========================
   后台通用组件：Toolbar / Table / Pager
========================= */
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between}
.toolbar__left,.toolbar__right{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* 二级导航（用于个人中心等页面） */
.subtabs{display:flex;gap:10px;flex-wrap:nowrap;font-size: 12px;margin:12px 0}
.subtab{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.88);
  cursor:pointer;
  user-select:none;
}
.subtab:hover{background:rgba(255,255,255,.07)}
.subtab.is-active{
  border-color:rgba(46,125,255,.45);
  background:rgba(46,125,255,.18);
  box-shadow:0 0 0 1px rgba(46,125,255,.18) inset;
}

.tab-panel{display:none}
.tab-panel.active{display:block}
.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:14px}
.table{width:100%;border-collapse:separate;border-spacing:0;min-width:760px}
.table thead th{
  position:sticky;top:0;
  background:rgba(18,28,51,.92);
  backdrop-filter: blur(10px);
  text-align:left;
  font-size:12px;
  color:rgba(255,255,255,.80);
  padding:10px 12px;
  border-bottom:1px solid var(--border);
}
.table tbody td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.06);font-size:13px;vertical-align:top}
.table tbody tr:hover td{background:rgba(255,255,255,.03)}
.table tbody tr:last-child td{border-bottom:0}

/* ===================== 表格：省空间显示 + 双击展开 ===================== */
/* 默认：单行省略号，避免手机端被长字段撑开；双击可展开查看 */
.table thead th,
.table tbody td{
  /*max-width:260px;*/
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
/* 操作列通常有按钮，保持完整 */
.table .actions,
.table td.actions,
.table th.actions{
  max-width:none;
  overflow:visible;
  text-overflow:clip;
  white-space:nowrap;
}
/* 双击展开 */
.table td.is-expanded{
  white-space:normal;
  overflow:visible;
}

.pager{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.pager__nav{display:flex;gap:8px;flex-wrap:wrap;align-items:center}


/* packs UI（user 页需要） */
.packs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
@media (max-width: 900px){ .packs{grid-template-columns:1fr} }
.pack{
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:12px
}
.pack.is-selected{
  border-color:rgba(56,141,255,.9);
  box-shadow:0 0 0 2px rgba(56,141,255,.22);
}
.pack-head{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:10px;margin-bottom:10px
}
.pack-name{font-weight:800}
.file{
  font-size:12px;color:var(--muted);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:520px
}

/* user/admin 的“浏览/删除弹窗” —— 保持这套（不要再被 index 覆盖） */
.modal{
  position:fixed;
  inset:0;
  z-index:9999;
}
.modal-mask{
  position:absolute;inset:0;
  background:rgba(0,0,0,.55);
}
.modal-card{
  position:relative;
  max-width:860px;
  width:min(92vw,860px);
  max-height:82vh;
  overflow:auto;
  margin:8vh auto;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:16px;
  padding:14px;
}
.modal-head{display:flex;justify-content:space-between;align-items:center;gap:10px}

.list{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
  margin-top:10px
}
.item{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
  padding:10px;
  border-radius:12px;
  background:var(--card2);
  border:1px solid var(--border);
}

/* =========================
   Index（调度中心）专属样式
   ✅ 全部加 #page-index 作用域，避免污染 user/admin/login
========================= */

/* index 自己的视觉变量（只在 #page-index 生效，不覆盖全局 :root） */
#page-index{
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(77,163,255,.25), transparent),
    radial-gradient(900px 500px at 90% 0%, rgba(120,255,220,.10), transparent),
    var(--bg);
  color:var(--text);
}

/* index 顶栏（注意：用 #page-index .topbar，不覆盖全局 .topbar 概念） */
#page-index .topbar{
  position:sticky;
  top:0;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 18px;
  border-bottom:1px solid rgba(255,255,255,.06);
  backdrop-filter: blur(10px);
  background: rgba(11,18,32,.72);
}

#page-index .brand-title{font-weight:700; letter-spacing:.3px}
#page-index .brand-sub{font-size:12px; color:var(--muted); margin-top:4px}
#page-index .topbar-right{display:flex; gap:10px; align-items:center}

/* index 主体布局 */
#page-index .wrap{
  padding:18px;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:16px;
}
@media (max-width: 980px){
  #page-index .wrap{grid-template-columns:1fr}
}

#page-index .col{display:flex; flex-direction:column; gap:16px}

#page-index .card-hd{margin-bottom:10px}
#page-index .card-title{font-weight:700}
#page-index .card-desc{font-size:12px; color:var(--muted); margin-top:4px}

#page-index .divider{height:1px; background:rgba(255,255,255,.08); margin:12px 0}

/* index 的 row / card 只做“补充”，不重写全局行为 */
#page-index .row{margin:10px 0}
#page-index .label{width:92px; color:var(--muted); font-size:13px}
#page-index .grow{flex:1}

#page-index .inputlike{
  padding:10px 12px;
  border-radius:12px;
  background: rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.10);
  color:var(--text);
  min-height:40px;
  display:flex; align-items:center;
}

#page-index .range{flex:1}
#page-index .volnum{
  width:38px;
  text-align:right;
  color:var(--muted);
  font-variant-numeric: tabular-nums;
}

/* index 的按钮（只改 index 自己的 btn-xxx，不碰全局 .btn） */
#page-index .btnbar{display:flex; gap:10px; margin-top:10px; flex-wrap:wrap}

#page-index .btn-primary{
  background: rgba(77,163,255,.18);
  border:1px solid rgba(77,163,255,.55);
  color:var(--text);
}
#page-index .btn-danger{
  background: rgba(255,91,110,.15);
  border:1px solid rgba(255,91,110,.55);
  color:var(--text);
}
#page-index .btn-ghost{
  background: transparent;
  border:1px solid rgba(255,255,255,.12);
  color:var(--text);
}

#page-index .chips{display:flex; flex-wrap:wrap; gap:8px}
#page-index .chip{
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  color:var(--muted);
  cursor:pointer;
}
#page-index .chip.active{
  color: var(--text);
  border-color: rgba(77,163,255,.65);
  background: rgba(77,163,255,.15);
}

#page-index .grid2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
#page-index .grid3{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
@media (max-width: 980px){
  #page-index .grid2{grid-template-columns:1fr}
}

#page-index .kv{
  background: rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding:10px 12px;
}
#page-index .k{color:var(--muted); font-size:12px}
#page-index .v{margin-top:6px}
#page-index .mono{font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size:12px}

#page-index .note{margin-top:10px; color:var(--muted); font-size:12px; line-height:1.6}

#page-index .logbox{
  height:220px;
  overflow:auto;
  padding:10px 12px;
  border-radius: 14px;
  background: rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.10);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size:12px;
  line-height:1.55;
  white-space:pre-wrap;
}

#page-index .progress{
  height:10px;
  border-radius:999px;
  background: rgba(255,255,255,.10);
  overflow:hidden;
  margin-top:10px;
}
#page-index .bar{height:100%; background: rgba(77,163,255,.75)}
#page-index .hint{margin-top:8px; color:var(--muted)}

/* ===== index 的“目录选择弹窗”只在 index 生效（关键：别再覆盖全局 .modal） ===== */
#page-index #dirModal.modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:50; /* 低于 user/admin 的 9999，不互相抢 */
}
#page-index #dirModal.modal.show{display:block}

#page-index #dirModal .mask{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.55);
}
#page-index #dirModal .panel{
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%,-50%);
  width:min(720px, 92vw);
  max-height: 86vh;
  background: rgba(12,22,39,.98);
  border:1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  box-shadow: var(--shadow);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
#page-index #dirModal .panel-hd{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 14px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
#page-index #dirModal .panel-title{font-weight:700}
#page-index #dirModal .iconbtn{
  border:none;
  background:transparent;
  color:var(--muted);
  font-size:18px;
  cursor:pointer;
}
#page-index #dirModal .panel-body{padding:12px 14px; overflow:auto}
#page-index #dirModal .path{color:var(--muted); margin-bottom:10px}

/* index 弹窗里自己的 list/item（不覆盖 user/admin 的 .list/.item） */
#page-index #dirModal .list{display:flex; flex-direction:column; gap:8px; margin-top:0}
#page-index #dirModal .item{
  padding:10px 12px;
  border-radius: 12px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  gap:10px;
}
#page-index #dirModal .item:hover{border-color:rgba(255,255,255,.22)}
#page-index #dirModal .item.active{
  border-color: rgba(77,163,255,.65);
  background: rgba(77,163,255,.12);
}
#page-index #dirModal .panel-ft{
  padding:12px 14px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  justify-content:space-between;
  gap:10px;
}

#page-index .toast{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  background: rgba(0,0,0,.72);
  border:1px solid rgba(255,255,255,.18);
  color:var(--text);
  padding:10px 12px;
  border-radius: 12px;
  box-shadow: var(--shadow);
  z-index:60;
  font-size:13px;
}
/* ===== 控制区：按钮尽量一排、更紧凑 ===== */
#page-index .btnbar{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}

/* 主按钮：在宽屏尽量同一排，不要挤成两层 */
#page-index .btnbar .btn{
  white-space:nowrap;
}

/* 快捷按钮那排更像“工具条” */
#page-index #quickBar .btn{
  padding:9px 12px;
}

/* 指定话术内联行：按钮 + 文本框更紧凑 */
#page-index #pickInlineRow .label{width:92px}
#page-index #pickInlineRow .btn{flex:0 0 auto}
#page-index #pickInlineRow .inputlike{
  min-height:38px;
}


/* =========================
   Index（手机主用）布局补丁
   - 只作用于 #page-index
========================= */
#page-index .container{width:min(1200px,94vw);margin:0 auto;padding:16px}
#page-index .only-desktop{display:inline-flex}
#page-index .pill-btn{cursor:pointer;border:0}
#page-index .userbox{position:relative;display:flex;align-items:center;gap:10px}

/* 用户下拉菜单 */
#page-index .usermenu{
  position:absolute;
  right:0;
  top:44px;
  width:180px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:8px;
  display:none;
  z-index:50;
}
#page-index .usermenu[aria-hidden="false"]{display:block}
#page-index .um-item{
  width:100%;
  text-align:left;
  border:0;
  background:transparent;
  color:var(--text);
  padding:10px 10px;
  border-radius:10px;
  cursor:pointer;
  font-size:14px;
}
#page-index .um-item:hover{background:rgba(255,255,255,.06)}
#page-index .um-item.danger{color:#ffd3d3}
#page-index .um-sep{height:1px;background:var(--border);margin:6px 2px}

/* 仪表盘两窗格 */
#page-index .dash-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

/* 播放控制右侧信息 */
#page-index .card-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
#page-index .card-right{display:flex;flex-direction:column;gap:6px;align-items:flex-end}
#page-index .mini-meta{display:flex;gap:8px;align-items:center}
#page-index .muted{color:var(--muted)}

/* 主按钮区 */
#page-index .primary-actions{justify-content:flex-start;gap:10px;flex-wrap:wrap}

/* 快捷按钮区（默认） */
#page-index .quick-grid{justify-content:flex-start;gap:10px;flex-wrap:wrap}
#page-index .pickline .inputlike{min-height:42px;display:flex;align-items:center}

/* BGM 模式放右上角 */
#page-index .chips-right{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
#page-index .bgm-grid{justify-content:flex-start;gap:10px;flex-wrap:wrap}

/* 调度参数抽屉 */
#page-index .drawer{
  position:fixed;
  inset:0;
  display:none;
  z-index:60;
}
#page-index .drawer[aria-hidden="false"]{display:block}
#page-index .drawer .mask{
  position:absolute;inset:0;
  background:rgba(0,0,0,.55);
}
#page-index .drawer-panel{
  position:absolute;
  top:0;right:0;
  width:min(420px,92vw);
  height:100%;
  background:var(--card);
  border-left:1px solid var(--border);
  box-shadow:var(--shadow);
  transform:translateX(100%);
  transition:transform .22s ease;
  display:flex;
  flex-direction:column;
}
#page-index .drawer[aria-hidden="false"] .drawer-panel{transform:translateX(0)}
#page-index .drawer .panel-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 12px;border-bottom:1px solid var(--border)}
#page-index .drawer .panel-body{padding:12px;overflow:auto}
#page-index .cfg-inner .row{align-items:center}

/* =========================
   手机端优化（按你图的“横排列/紧凑”）
========================= */
@media (max-width: 720px){
  #page-index .only-desktop{display:none}

  #page-index .brand-sub{display:none}
  #page-index .container{padding:12px}
  #page-index .card{padding:12px}

  /* 仪表盘仍然两格横排 */
  #page-index .dash-grid{gap:10px}

  /* 播放控制：右上信息换行更紧凑 */
  #page-index .card-hd{flex-direction:column;align-items:flex-start}
  #page-index .card-right{align-items:flex-start}

  /* 主按钮：第一行满宽，第二行两列 */
  #page-index .primary-actions{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
  }
  #page-index #btnPlayNow{grid-column:1 / -1}

  /* 快捷按钮：两列网格（手机更像遥控器） */
  #page-index .quick-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
  }
  #page-index #btnReportNow{grid-column:1 / -1}
  #page-index #btnClearTasks{grid-column:1 / -1}

  /* 指定文件行：更紧凑 */
  #page-index #pickInlineRow{gap:10px;flex-wrap:nowrap}
  #page-index #pickInlineRow .label{width:74px}
  #page-index #pickInlineRow .btn{padding:10px 12px}

  /* BGM 控制：两列 */
  #page-index .bgm-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
  }
  #page-index #bgmStop{grid-column:1 / -1}

  /* 日志高度别太吓人 */
  #page-index #logBox{min-height:280px}
}

/* 授权（license）专用：只在授权页生效 */
.page-license .keyItem {
  padding: 14px 10px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.page-license .keyTop {
  display: grid;
  grid-template-columns: 2fr 170px 1fr; /* Key+状态 / 到期 / 备注 */
  gap: 10px;
  align-items: center;
}

.page-license .keyLeft {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.page-license .keyText {
  font-weight: 700;
  font-size: 16px;
  line-height: 1.25;
  cursor: pointer;
  user-select: text;
  word-break: break-all;
  flex: 1;
  min-width: 0;
}

.page-license .keyInputs {
  display: flex;
  gap: 10px;
  align-items: center;
}

.page-license .keyInputs .input {
  width: 100%;
  min-width: 0;
}

.page-license .keyActions {
  margin-top: 10px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.page-license .keyDetailRow {
  margin-top: 10px;
  display: none;
}

.page-license .keyDetailRow .code {
  margin-top: 0;
}

/* 手机端：强制纵向，绝不挤（也只作用于授权页） */
@media (max-width: 720px) {
  .page-license .keyTop {
    grid-template-columns: 1fr;
  }
  .page-license .keyInputs {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .page-license .keyText {
    font-size: 15px;
  }
}

/* =========================
   首页快捷入口（统一风格）
   ========================= */
.entry-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 10px;
}

.entry-tile{
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
  text-decoration: none;
  color: inherit;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}

.entry-tile:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.14);
}

.entry-ico{
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: rgba(0,0,0,0.28);
  border: 1px solid rgba(255,255,255,0.10);
  font-size: 18px;
  flex: 0 0 auto;
}

.entry-name{ font-weight: 800; letter-spacing: .2px; }
.entry-sub{ margin-top: 2px; font-size: 12px; opacity: .78; }

@media (max-width: 980px){
  .entry-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 560px){
  .entry-grid{ grid-template-columns: 1fr; }
}

/* ===== Admin modal/overlay (admin.html) ===== */
.overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  padding: 18px;
}
.overlay.show{ display:flex; }
.dialog{
  width: min(760px, 94vw);
  max-height: 88vh;
  overflow: auto;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(10, 18, 34, 0.92);
  box-shadow: 0 24px 80px rgba(0,0,0,0.55);
  padding: 16px;
}
.dialog .row{ flex-wrap: wrap; }
.dialog .btn{ white-space: nowrap; }

body.no-scroll{ overflow: hidden; }


/* ✅ 手机端侧边栏：导航可上下滚动，底部信息固定可见 */
.app-sidebar__inner{
height: 100dvh; 
height: 100vh; 
display: flex;
flex-direction: column;
overflow: hidden; }
.app-sidebar__top {flex: 0 0 auto;}

.app-nav{
flex: 1 1 auto;
min-height: 0; 
overflow-y: auto;
-webkit-overflow-scrolling: touch;
overscroll-behavior: contain;
padding-bottom: 12px;
/* 新增：隐藏滚动条 */
scrollbar-width: none;
-ms-overflow-style: none; 
}
.app-nav::-webkit-scrollbar {display: none;}
/* 底部区域固定显示，不参与滚动 */
.app-sidebar__foot {flex: 0 0 auto;}
.app-sidebar {height: 100dvh;height: 100vh;}