/* =========================================================
   全域红包拓客SaaS管理后台 - 全局样式
   深蓝高端企业风 · 北京大秦六河科技有限公司
   ========================================================= */
:root{
  --bg-0:#0a1226;        /* 最深背景 */
  --bg-1:#0e1a36;        /* 页面背景 */
  --bg-2:#13234a;        /* 卡片背景 */
  --bg-3:#1a2e5c;        /* 卡片高亮 */
  --line:#24386e;        /* 边框线 */
  --line-soft:#1c2c54;
  --txt-0:#eaf1ff;       /* 主文字 */
  --txt-1:#9fb0d6;       /* 次文字 */
  --txt-2:#6b7ca6;       /* 弱文字 */
  --pri:#2f7bff;         /* 主蓝 */
  --pri-2:#4f9bff;
  --cyan:#22d3ee;
  --gold:#ffb340;
  --green:#22c98a;
  --red:#ff5d6c;
  --purple:#9d7bff;
  --radius:14px;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --grad-pri:linear-gradient(135deg,#2f7bff 0%,#22d3ee 100%);
  --grad-card:linear-gradient(160deg,#16285380 0%,#0f1d3e80 100%);
}

*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;}
body{
  font-family:"Microsoft YaHei","PingFang SC","Segoe UI",Arial,sans-serif;
  background:var(--bg-1);
  color:var(--txt-0);
  font-size:14px;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
::-webkit-scrollbar{width:8px;height:8px;}
::-webkit-scrollbar-thumb{background:#24386e;border-radius:8px;}
::-webkit-scrollbar-track{background:transparent;}

/* ====================== 登录页（高端品牌版） ====================== */
.login-body{overflow:hidden;background:radial-gradient(1400px 900px at 75% 15%,#16306b 0%,#0a1226 55%,#070d1c 100%);}
.login-bg{position:fixed;inset:0;overflow:hidden;z-index:0;}
.login-grid{
  position:absolute;inset:-2px;
  background-image:linear-gradient(rgba(79,155,255,.05) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(79,155,255,.05) 1px,transparent 1px);
  background-size:52px 52px;
  mask-image:radial-gradient(900px 700px at 55% 40%,#000 35%,transparent 82%);
}
.orb{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;animation:float 14s ease-in-out infinite;}
.orb1{width:460px;height:460px;background:#2f7bff;top:-140px;left:-90px;}
.orb2{width:380px;height:380px;background:#22d3ee;bottom:-140px;right:8%;opacity:.32;animation-delay:-4s;}
.orb3{width:320px;height:320px;background:#9d7bff;top:28%;right:-70px;opacity:.24;animation-delay:-8s;}
.beam{position:absolute;top:-20%;left:50%;width:140%;height:60%;transform:translateX(-50%) rotate(-12deg);
  background:linear-gradient(90deg,transparent,rgba(79,155,255,.08),transparent);filter:blur(30px);}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-26px)}}

.login-wrap{
  position:relative;z-index:1;min-height:100%;
  display:flex;align-items:center;justify-content:center;gap:60px;
  padding:32px;
}
.login-brand{max-width:560px;color:var(--txt-0);}
.brand-head{margin-bottom:30px;}
.brand-logo-img{
  width:100%;max-width:540px;border-radius:18px;display:block;
  border:1px solid rgba(120,160,230,.22);
  box-shadow:0 24px 60px rgba(0,0,0,.55),inset 0 0 0 1px rgba(255,255,255,.04);
}
.brand-title{margin-bottom:26px;}
.brand-title h1{font-size:30px;font-weight:800;letter-spacing:1px;background:linear-gradient(90deg,#eaf1ff,#9fc3ff);-webkit-background-clip:text;background-clip:text;color:transparent;}
.brand-title h1 span{background:linear-gradient(90deg,#22d3ee,#4f9bff);-webkit-background-clip:text;background-clip:text;color:transparent;}
.brand-title p{font-size:11px;color:var(--txt-2);letter-spacing:2px;margin-top:8px;}
.brand-points{list-style:none;margin:26px 0;}
.brand-points li{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px;}
.brand-points .ic{
  width:44px;height:44px;border-radius:13px;flex:0 0 44px;
  background:linear-gradient(135deg,#1c3367,#13234a);
  border:1px solid rgba(120,160,230,.25);position:relative;
  box-shadow:0 6px 16px rgba(0,0,0,.3);
}
.brand-points .ic::after{
  content:"";position:absolute;inset:0;margin:auto;width:18px;height:18px;
  background:var(--cyan);border-radius:4px;opacity:.9;
}
.ic-scan::after{clip-path:polygon(0 0,40% 0,40% 12%,12% 12%,12% 40%,0 40%,100% 60%,100% 100%,60% 100%,60% 88%,88% 88%,88% 60%,100% 60%);background:var(--pri-2);}
.ic-target::after{border-radius:50%;background:radial-gradient(circle,#fff 25%,var(--cyan) 30%,var(--cyan) 55%,transparent 60%);}
.ic-data::after{background:var(--green);clip-path:polygon(0 100%,0 60%,33% 60%,33% 100%,66% 100%,66% 30%,100% 30%,100% 100%);}
.brand-points b{display:block;font-size:15px;margin-bottom:4px;}
.brand-points span{font-size:12px;color:var(--txt-2);}
.brand-stats{display:flex;gap:14px;border-top:1px solid rgba(120,160,230,.18);padding-top:24px;}
.brand-stats > div{flex:1;}
.brand-stats b{font-size:28px;font-weight:800;background:linear-gradient(90deg,#4f9bff,#22d3ee);-webkit-background-clip:text;background-clip:text;color:transparent;}
.brand-stats b i{font-size:14px;font-style:normal;color:var(--txt-1);margin-left:2px;-webkit-text-fill-color:var(--txt-1);}
.brand-stats span{display:block;font-size:12px;color:var(--txt-2);margin-top:6px;}

.login-card{
  width:400px;background:linear-gradient(165deg,rgba(24,40,86,.72),rgba(13,24,52,.72));
  backdrop-filter:blur(18px);position:relative;
  border:1px solid rgba(120,160,230,.22);border-radius:22px;padding:42px 38px;
  box-shadow:0 30px 70px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.06);
}
.login-card::before{content:"";position:absolute;inset:0;border-radius:22px;padding:1px;
  background:linear-gradient(160deg,rgba(79,155,255,.5),transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;}
.card-logo{display:flex;align-items:center;gap:10px;margin-bottom:22px;}
.card-logo-mk{
  font-size:14px;font-weight:800;letter-spacing:2px;color:#cfe0ff;
  padding:7px 14px;border-radius:9px;border:1px solid rgba(120,160,230,.3);
  background:linear-gradient(135deg,rgba(47,123,255,.22),rgba(34,211,238,.1));
}
.login-card h2{font-size:26px;font-weight:800;letter-spacing:1px;}
.login-sub{color:var(--txt-2);font-size:12.5px;margin:8px 0 28px;}
.field{
  display:flex;align-items:center;gap:10px;
  background:rgba(8,16,36,.7);border:1px solid var(--line);border-radius:12px;
  padding:0 14px;margin-bottom:16px;height:50px;transition:.2s;
}
.field:focus-within{border-color:var(--pri);box-shadow:0 0 0 3px rgba(47,123,255,.18);}
.field-ic{font-size:16px;opacity:.7;}
.field input{flex:1;background:transparent;border:0;outline:0;color:var(--txt-0);font-size:14px;height:100%;}
.login-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;}
.remember{display:flex;align-items:center;gap:8px;color:var(--txt-2);font-size:12px;cursor:pointer;}
.forget{color:var(--txt-2);font-size:12px;cursor:pointer;transition:.2s;}
.forget:hover{color:var(--pri-2);}
.btn-login{
  width:100%;height:50px;border:0;border-radius:12px;cursor:pointer;
  background:linear-gradient(135deg,#2f7bff,#22d3ee);color:#fff;font-size:16px;font-weight:700;letter-spacing:8px;
  box-shadow:0 12px 28px rgba(47,123,255,.45);transition:.2s;
}
.btn-login:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 16px 34px rgba(47,123,255,.55);}
.btn-login:active{transform:translateY(0);}
.login-footer{text-align:center;color:var(--txt-2);font-size:11px;margin-top:26px;}

@media(max-width:980px){
  .login-brand{max-width:420px;}
  .brand-points,.brand-title p{display:none;}
}
@media(max-width:820px){
  .login-brand{display:none;}
  .login-wrap{padding:20px;}
}

/* ====================== 主框架 ====================== */
.app-layout{display:flex;min-height:100vh;background:radial-gradient(1200px 700px at 80% -10%,#13265200,#0a1226);}
.sidebar{
  width:240px;flex:0 0 240px;background:linear-gradient(180deg,#0d1a38,#080f22);
  border-right:1px solid var(--line);display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;z-index:30;box-shadow:2px 0 24px rgba(0,0,0,.3);
}
.side-logo{display:flex;align-items:center;gap:12px;padding:20px 18px;border-bottom:1px solid var(--line-soft);}
.side-logo .mk{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,#2f7bff,#22d3ee);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:20px;color:#fff;box-shadow:0 6px 16px rgba(47,123,255,.45);}
.side-logo .tt b{font-size:15px;display:block;letter-spacing:.5px;}
.side-logo .tt span{font-size:10px;color:var(--txt-2);letter-spacing:.5px;}
.side-menu{flex:1;overflow-y:auto;padding:14px 12px;}
.menu-group-title{font-size:11px;color:var(--txt-2);padding:14px 12px 8px;letter-spacing:1px;}
.menu-item{
  display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;
  color:var(--txt-1);cursor:pointer;margin-bottom:4px;font-size:14px;transition:.18s;position:relative;
}
.menu-item .mic{width:18px;height:18px;flex:0 0 18px;opacity:.8;}
.menu-item:hover{background:#13234a;color:#fff;transform:translateX(2px);}
.menu-item.active{background:linear-gradient(90deg,rgba(47,123,255,.28),rgba(34,211,238,.05));color:#fff;box-shadow:inset 0 0 0 1px rgba(79,155,255,.18);}
.menu-item.active .mic{opacity:1;}
.menu-item.active::before{content:"";position:absolute;left:0;top:7px;bottom:7px;width:3px;border-radius:3px;background:linear-gradient(180deg,#2f7bff,#22d3ee);box-shadow:0 0 12px rgba(47,123,255,.8);}
.menu-item .badge{margin-left:auto;font-size:10px;background:var(--red);color:#fff;border-radius:8px;padding:1px 6px;}
.side-foot{padding:14px 18px;border-top:1px solid var(--line-soft);font-size:11px;color:var(--txt-2);}

.main{flex:1;min-width:0;display:flex;flex-direction:column;}
.topbar{
  height:64px;display:flex;align-items:center;gap:16px;padding:0 24px;
  background:linear-gradient(180deg,rgba(16,30,66,.85),rgba(12,25,52,.6));backdrop-filter:blur(12px);border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:20;
}
.topbar .crumb{font-size:13px;color:var(--txt-2);}
.topbar .crumb b{color:var(--txt-0);font-size:16px;margin-right:8px;}
.topbar .spacer{flex:1;}
.top-search{display:flex;align-items:center;gap:8px;background:#0d1830;border:1px solid var(--line);border-radius:8px;padding:0 12px;height:36px;width:240px;}
.top-search input{background:transparent;border:0;outline:0;color:var(--txt-0);flex:1;font-size:13px;}
.top-tools{display:flex;align-items:center;gap:18px;color:var(--txt-1);}
.top-tools .tool{cursor:pointer;position:relative;font-size:18px;}
.top-tools .dot{position:absolute;top:-2px;right:-3px;width:7px;height:7px;background:var(--red);border-radius:50%;}
.top-user{display:flex;align-items:center;gap:10px;cursor:pointer;}
.top-user .ava{width:34px;height:34px;border-radius:50%;background:var(--grad-pri);display:flex;align-items:center;justify-content:center;font-weight:700;}
.top-user .nm{font-size:13px;}
.top-user .nm span{display:block;font-size:11px;color:var(--txt-2);}
.btn-logout{margin-left:6px;font-size:12px;color:var(--txt-2);border:1px solid var(--line);background:transparent;border-radius:6px;padding:6px 12px;cursor:pointer;}
.btn-logout:hover{color:#fff;border-color:var(--pri);}

.page{padding:24px 26px 44px;flex:1;overflow-x:hidden;}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px;}
.page-head h2{font-size:21px;font-weight:800;position:relative;padding-left:14px;letter-spacing:.5px;}
.page-head h2::before{content:"";position:absolute;left:0;top:3px;bottom:3px;width:5px;border-radius:4px;background:linear-gradient(180deg,#2f7bff,#22d3ee);box-shadow:0 0 12px rgba(47,123,255,.6);}
.page-head .desc{color:var(--txt-2);font-size:12px;margin-top:7px;}

/* ====================== 通用组件 ====================== */
.card{background:linear-gradient(160deg,rgba(22,40,83,.6),rgba(13,24,52,.55));border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);transition:.2s;}
.card:hover{border-color:rgba(79,155,255,.35);}
.card-pad{padding:20px;}
.card-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.card-title h3{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;}
.card-title h3::before{content:"";width:4px;height:15px;border-radius:3px;background:var(--grad-pri);display:inline-block;}
.card-title .sub{font-size:12px;color:var(--txt-2);}

.grid{display:grid;gap:16px;}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
@media(max-width:1200px){.grid-4{grid-template-columns:repeat(2,1fr);}.grid-3{grid-template-columns:repeat(2,1fr);}}
@media(max-width:760px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}}

/* 数据卡片 */
.stat{
  position:relative;overflow:hidden;
  background:linear-gradient(160deg,rgba(22,40,83,.65),rgba(13,24,52,.6));border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 18px 16px;transition:.22s;box-shadow:0 8px 22px rgba(0,0,0,.25);
}
.stat::before{content:"";position:absolute;left:0;top:0;right:0;height:2px;background:linear-gradient(90deg,#2f7bff,#22d3ee);opacity:.85;}
.stat::after{content:"";position:absolute;right:-30px;top:-30px;width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,rgba(47,123,255,.25),transparent 70%);}
.stat:hover{transform:translateY(-4px);border-color:rgba(79,155,255,.45);box-shadow:0 16px 34px rgba(0,0,0,.4);}
.stat .st-top{display:flex;align-items:center;justify-content:space-between;}
.stat .st-ic{width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:21px;background:linear-gradient(135deg,#1a2e5c,#13234a);border:1px solid rgba(120,160,230,.22);box-shadow:0 6px 14px rgba(0,0,0,.25);}
.stat .st-label{color:var(--txt-2);font-size:13px;}
.stat .st-val{font-size:29px;font-weight:800;margin-top:10px;letter-spacing:.5px;color:#fff;}
.stat .st-unit{font-size:13px;color:var(--txt-2);font-weight:500;margin-left:4px;}
.stat .st-foot{margin-top:10px;font-size:12px;color:var(--txt-2);display:flex;align-items:center;gap:6px;}
.up{color:var(--green);}.down{color:var(--red);}
.stat.blue::before{background:linear-gradient(90deg,#2f7bff,#4f9bff);}.stat.blue .st-ic{color:var(--pri-2);}
.stat.cyan::before{background:linear-gradient(90deg,#22d3ee,#4f9bff);}.stat.cyan .st-ic{color:var(--cyan);}
.stat.gold::before{background:linear-gradient(90deg,#ffb340,#ff8a3d);}.stat.gold .st-ic{color:var(--gold);}
.stat.green::before{background:linear-gradient(90deg,#22c98a,#22d3ee);}.stat.green .st-ic{color:var(--green);}
.stat.purple::before{background:linear-gradient(90deg,#9d7bff,#4f9bff);}.stat.purple .st-ic{color:var(--purple);}
.stat.red::before{background:linear-gradient(90deg,#ff5d6c,#ffb340);}.stat.red .st-ic{color:var(--red);}

/* 表格 */
.table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--line);}
table.dt{width:100%;border-collapse:collapse;font-size:13px;min-width:720px;}
table.dt thead th{
  background:linear-gradient(180deg,#15294f,#0f1f42);color:#bccdee;font-weight:600;text-align:left;
  padding:13px 14px;white-space:nowrap;border-bottom:1px solid var(--line);position:sticky;top:0;letter-spacing:.3px;
}
table.dt tbody td{padding:12px 14px;border-bottom:1px solid var(--line-soft);white-space:nowrap;color:var(--txt-0);transition:.12s;}
table.dt tbody tr:hover{background:rgba(47,123,255,.1);}
table.dt tbody tr:nth-child(even){background:#0f1d3e33;}
td.editable{position:relative;}
body.edit-on td.editable{cursor:cell;}
body.edit-on td.editable:hover{outline:1px dashed rgba(79,155,255,.7);outline-offset:-3px;background:rgba(47,123,255,.06);}
td.editable.editing{padding:4px 6px;}
td input.cell-input{width:100%;background:#0a1226;border:1px solid var(--pri);border-radius:6px;color:#fff;padding:7px 8px;font-size:13px;outline:none;}
.editable-num{border-bottom:1px dashed transparent;}
body.edit-on .editable-num{cursor:cell;}
body.edit-on .editable-num:hover{border-bottom-color:var(--pri);}

/* 状态标签 */
.tag{display:inline-flex;align-items:center;gap:5px;font-size:12px;padding:3px 10px;border-radius:20px;border:1px solid transparent;}
.tag::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;}
.tag.on{color:var(--green);background:rgba(34,201,138,.12);}
.tag.off{color:var(--txt-2);background:rgba(107,124,166,.14);}
.tag.warn{color:var(--gold);background:rgba(255,179,64,.12);}
.tag.hot{color:var(--red);background:rgba(255,93,108,.12);}
.tag.new{color:var(--pri-2);background:rgba(47,123,255,.14);}
.tag.purple{color:var(--purple);background:rgba(157,123,255,.14);}

/* 按钮 */
.btn{border:1px solid var(--line);background:#13234a;color:var(--txt-0);border-radius:8px;padding:8px 14px;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:.18s;}
.btn:hover{border-color:var(--pri);}
.btn-pri{background:var(--grad-pri);border:0;color:#fff;box-shadow:0 6px 16px rgba(47,123,255,.35);}
.btn-pri:hover{filter:brightness(1.08);}
.btn-sm{padding:5px 10px;font-size:12px;}
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px;}
.toolbar .spacer{flex:1;}
.filter-input{background:#0d1830;border:1px solid var(--line);border-radius:8px;color:var(--txt-0);height:36px;padding:0 12px;font-size:13px;outline:none;}
.filter-input:focus{border-color:var(--pri);}

/* 进度条 */
.bar{height:6px;border-radius:6px;background:#16264e;overflow:hidden;min-width:80px;}
.bar > i{display:block;height:100%;border-radius:6px;background:var(--grad-pri);}

/* 提示条 */
.hint{font-size:12px;color:var(--txt-2);display:flex;align-items:center;gap:6px;}
.hint b{color:var(--cyan);}

/* 图例 */
.legend{display:flex;flex-direction:column;gap:10px;}
.legend .lg{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--txt-1);}
.legend .lg .dot{width:10px;height:10px;border-radius:3px;}
.legend .lg b{margin-left:auto;color:#fff;}

/* toast */
#toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(20px);
  background:#13234a;border:1px solid var(--pri);color:#fff;padding:10px 18px;border-radius:10px;
  box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.25s;z-index:999;font-size:13px;}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* 系统设置 */
.set-grid{display:grid;grid-template-columns:240px 1fr;gap:16px;}
@media(max-width:760px){.set-grid{grid-template-columns:1fr;}}
.set-nav .sn{padding:12px 14px;border-radius:10px;cursor:pointer;color:var(--txt-1);margin-bottom:6px;}
.set-nav .sn.active{background:#13234a;color:#fff;}
.form-row{display:flex;align-items:center;gap:16px;padding:14px 0;border-bottom:1px solid var(--line-soft);}
.form-row label{width:140px;color:var(--txt-1);font-size:13px;}
.form-row .val{flex:1;}
.form-row input,.form-row select{background:#0d1830;border:1px solid var(--line);border-radius:8px;color:var(--txt-0);height:38px;padding:0 12px;width:100%;max-width:320px;outline:none;}
.switch{width:46px;height:24px;border-radius:20px;background:#16264e;position:relative;cursor:pointer;display:inline-block;border:1px solid var(--line);}
.switch i{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#5a6c96;transition:.2s;}
.switch.on{background:rgba(47,123,255,.4);}
.switch.on i{left:24px;background:var(--pri-2);}

/* 物料预览 */
.material{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
@media(max-width:980px){.material{grid-template-columns:repeat(2,1fr);}}
.qr-card{background:#0d1830;border:1px solid var(--line);border-radius:12px;padding:16px;text-align:center;}
.qr-img{width:120px;height:120px;margin:0 auto 12px;border-radius:10px;background:#fff;padding:8px;}
.qr-card b{font-size:13px;display:block;}
.qr-card span{font-size:11px;color:var(--txt-2);}

/* 自绘图表容器 */
.chart-box{width:100%;}
.chart-box svg{display:block;width:100%;height:auto;}

.two-col{display:grid;grid-template-columns:1.6fr 1fr;gap:16px;}
@media(max-width:980px){.two-col{grid-template-columns:1fr;}}
.flex-between{display:flex;align-items:center;justify-content:space-between;}
.mt16{margin-top:16px;}
.rank-list .rk{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line-soft);}
.rank-list .rk .no{width:24px;height:24px;border-radius:7px;background:#16264e;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;}
.rank-list .rk .no.top{background:var(--grad-pri);color:#fff;}
.rank-list .rk .nm{font-size:13px;}
.rank-list .rk .nm span{display:block;font-size:11px;color:var(--txt-2);}
.rank-list .rk .vv{margin-left:auto;text-align:right;font-weight:700;}
.rank-list .rk .vv span{display:block;font-size:11px;color:var(--txt-2);font-weight:400;}

/* 移动端侧边栏 */
.menu-toggle{display:none;font-size:22px;cursor:pointer;margin-right:4px;}
.side-mask{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:25;}
@media(max-width:860px){
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:.25s;}
  .sidebar.open{transform:translateX(0);}
  .side-mask.show{display:block;}
  .menu-toggle{display:block;}
  .top-search{display:none;}
  .top-user .nm{display:none;}
}
.pagination{display:flex;align-items:center;gap:6px;justify-content:flex-end;margin-top:14px;flex-wrap:wrap;}
.pagination .pg{min-width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:#0d1830;color:var(--txt-1);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;padding:0 8px;}
.pagination .pg.active{background:var(--grad-pri);color:#fff;border:0;}
.pagination .pg.disabled{opacity:.4;cursor:not-allowed;}
.pg-info{color:var(--txt-2);font-size:12px;margin-right:auto;}

/* ====================== 顶栏下拉/交互 ====================== */
.top-tools .tool{transition:.18s;width:34px;height:34px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;}
.top-tools .tool:hover{background:#16264e;color:#fff;}
.tool-wrap{position:relative;}
.top-user-wrap{position:relative;}
.top-user{padding:4px 8px;border-radius:10px;transition:.18s;}
.top-user:hover{background:#16264e;}
.top-user .caret{font-size:10px;color:var(--txt-2);margin-left:2px;}
.dropdown{
  position:absolute;right:0;top:calc(100% + 12px);width:300px;z-index:60;
  background:linear-gradient(165deg,rgba(22,40,86,.98),rgba(13,24,52,.98));
  border:1px solid rgba(120,160,230,.25);border-radius:14px;
  box-shadow:0 24px 60px rgba(0,0,0,.55);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:.18s;overflow:hidden;
}
.dropdown.show{opacity:1;visibility:visible;transform:translateY(0);}
.dropdown::before{content:"";position:absolute;top:-6px;right:18px;width:12px;height:12px;
  background:rgba(22,40,86,.98);border-left:1px solid rgba(120,160,230,.25);border-top:1px solid rgba(120,160,230,.25);transform:rotate(45deg);}
.dd-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line-soft);font-weight:700;font-size:14px;}
.dd-head span{font-size:11px;color:var(--cyan);font-weight:500;}
.dd-item{display:flex;gap:12px;align-items:flex-start;padding:12px 16px;border-bottom:1px solid var(--line-soft);cursor:pointer;transition:.15s;}
.dd-item:hover{background:rgba(47,123,255,.08);}
.dd-item .di{width:9px;height:9px;border-radius:50%;margin-top:5px;flex:0 0 9px;background:var(--pri);}
.dd-item .di.on{background:var(--green);}.dd-item .di.gold{background:var(--gold);}.dd-item .di.blue{background:var(--pri-2);}.dd-item .di.purple{background:var(--purple);}
.dd-item b{display:block;font-size:13px;font-weight:600;margin-bottom:3px;}
.dd-item span{font-size:11px;color:var(--txt-2);}
.dd-foot{text-align:center;padding:11px;font-size:12px;color:var(--pri-2);cursor:pointer;}
.dd-foot:hover{background:rgba(47,123,255,.08);}
.dd-user-head{display:flex;gap:12px;align-items:center;padding:16px;border-bottom:1px solid var(--line-soft);}
.dd-user-head .ava{width:42px;height:42px;border-radius:50%;background:var(--grad-pri);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;}
.dd-user-head b{font-size:14px;}
.dd-user-head span{display:block;font-size:11px;color:var(--txt-2);margin-top:3px;}
.dd-link{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:13px;cursor:pointer;transition:.15s;color:var(--txt-1);}
.dd-link span{font-size:15px;width:18px;text-align:center;}
.dd-link:hover{background:rgba(47,123,255,.08);color:#fff;}
.dd-link.danger{color:var(--red);border-top:1px solid var(--line-soft);}
.dd-link.danger:hover{background:rgba(255,93,108,.1);}

/* 编辑模式指示 */
.edit-flag{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  display:flex;align-items:center;gap:8px;z-index:200;
  background:linear-gradient(135deg,#2f7bff,#22d3ee);color:#fff;
  padding:8px 16px;border-radius:30px;font-size:12px;font-weight:600;
  box-shadow:0 10px 26px rgba(47,123,255,.5);opacity:0;visibility:hidden;transition:.25s;
}
.edit-flag.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.edit-flag i{width:8px;height:8px;border-radius:50%;background:#fff;animation:blink 1.2s infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
body.edit-on .topbar{box-shadow:inset 0 -2px 0 rgba(47,123,255,.6);}
#sideLogo{cursor:pointer;user-select:none;}
