:root{
  --brand:#7C3AED; --brand-2:#9D5CFF; --brand-d:#5B21B6;
  --violet:#7C3AED; --violet2:#9D5CFF; --violet-d:#5B21B6;
  --pink:#FF4D8D; --coral:#FF7A45; --cyan:#13C2B6; --yellow:#FFB020; --blue:#3D8BFF; --green:#22C55E;
  --ink:#221B3D; --ink2:#564E73; --muted:#948FB0;
  --bg:#F5F3FB; --card:#FFFFFF; --surface2:#FBFAFE; --line:#ECE7F6; --line2:#E1DAF0;
  --radius:18px; --r-ctl:12px; --r-sm:10px; --r-pill:999px;
  --shadow:0 1px 2px rgba(34,27,61,.05),0 10px 28px -14px rgba(80,50,150,.22);
  --shadow-sm:0 1px 2px rgba(34,27,61,.04),0 6px 18px -12px rgba(80,50,150,.20);
  --shadow-pop:0 24px 60px -20px rgba(50,30,100,.42);
  --disp:'Fredoka',-apple-system,"PingFang SC","Microsoft YaHei",sans-serif;
  --body:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei","Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--body);color:var(--ink);background:var(--bg);min-height:100vh;-webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(42rem 42rem at 100% -12%, rgba(157,92,255,.10), transparent 62%),
    radial-gradient(32rem 32rem at -10% 6%, rgba(255,77,141,.07), transparent 60%),
    radial-gradient(44rem 44rem at 60% 128%, rgba(19,194,182,.06), transparent 60%);}
.hide{display:none!important}

.card{background:var(--card);border-radius:var(--radius);padding:20px 22px;margin-bottom:16px;
  box-shadow:var(--shadow);border:1px solid var(--line);animation:rise .4s cubic-bezier(.2,.7,.3,1) both}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
label{display:block;font-size:12.5px;font-weight:600;color:var(--ink2);margin:13px 0 6px;letter-spacing:.1px}
input,select,textarea{width:100%;padding:11px 13px;border:1.5px solid var(--line2);border-radius:var(--r-ctl);
  font-size:14.5px;background:#fff;color:var(--ink);font-family:inherit;transition:border-color .15s,box-shadow .15s}
textarea{resize:vertical;line-height:1.6}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px rgba(124,58,237,.13)}
input:disabled{background:#f5f3fb;color:var(--muted);cursor:not-allowed}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:12px 18px;border:none;
  border-radius:var(--r-ctl);background:linear-gradient(135deg,var(--brand-2),var(--brand));color:#fff;font-size:15px;
  font-weight:700;font-family:inherit;margin-top:16px;cursor:pointer;
  box-shadow:0 10px 22px -12px rgba(124,58,237,.6);transition:transform .12s,box-shadow .12s,filter .12s}
.btn:hover{filter:brightness(1.04);box-shadow:0 16px 28px -14px rgba(124,58,237,.66)}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:#fff;color:var(--brand);border:1.5px solid var(--line2);box-shadow:none}
.btn.ghost:hover{border-color:var(--brand);background:#faf8ff;filter:none}
.btn.coral{background:linear-gradient(135deg,#FF9466,var(--coral));box-shadow:0 10px 22px -12px rgba(255,122,69,.5)}
.btn.danger{background:linear-gradient(135deg,#FF6E8A,#E8485F)}
.btn.sm{width:auto;padding:8px 15px;font-size:13px;margin-top:0;border-radius:var(--r-sm)}
.hint{font-size:12px;color:var(--muted);margin-top:9px;line-height:1.65}
.empty{text-align:center;color:var(--muted);font-size:13.5px;padding:38px 10px}

.mark{width:52px;height:52px;border-radius:50%;object-fit:cover;flex-shrink:0;background:#fff;
  box-shadow:0 10px 22px -12px rgba(124,58,237,.5);border:2.5px solid #fff;display:block}
.mark.sm{width:40px;height:40px;border-width:2px;border-radius:50%}

/* 登录页 */
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(125% 125% at 82% 6%, #A77BFF 0%, #7C3AED 46%, #4C1D95 100%)}
.login-card{width:100%;max-width:392px;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.85);border-radius:26px;padding:40px 34px;
  box-shadow:0 44px 96px -42px rgba(40,20,90,.55);text-align:center;animation:rise .5s both}
.login-card .mark{width:80px;height:80px;border-radius:50%;margin:0 auto 16px}
.login-card h1{font-family:var(--disp);font-size:27px;margin:0;font-weight:700;
  background:linear-gradient(120deg,var(--brand),var(--pink));-webkit-background-clip:text;background-clip:text;color:transparent}
.login-card .brand-sub{color:var(--muted);font-size:13.5px;margin:6px 0 22px;font-weight:500}
.login-card label{text-align:left}
.login-card .hint{margin-top:18px}

/* 骨架 */
.app-shell{display:flex;min-height:100vh}
.sidebar{width:256px;flex-shrink:0;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:20px 14px;color:#EDE7FB;
  background:linear-gradient(178deg,var(--brand) 0%,var(--brand-d) 62%,var(--brand-d) 100%);
  box-shadow:14px 0 40px -28px rgba(40,20,90,.6)}
.side-top{display:flex;align-items:center;gap:11px;margin:2px 4px 4px}
.hamburger{display:none;margin-left:auto;align-items:center;justify-content:center;width:42px;height:42px;flex-shrink:0;padding:0;border:none;border-radius:12px;background:rgba(255,255,255,.16);color:#fff;font-size:21px;line-height:1;cursor:pointer;font-family:inherit}
.hamburger:hover{background:rgba(255,255,255,.28)}
.brand-name{font-family:var(--disp);font-size:18px;font-weight:700;line-height:1.1;color:#fff}
.brand-tag{font-size:11px;opacity:.74;margin-top:2px}
.who{font-size:12px;opacity:.92;margin:12px 4px 12px;padding:11px 13px;background:rgba(255,255,255,.12);border-radius:13px;line-height:1.5;border:1px solid rgba(255,255,255,.08)}
.tabs{display:flex;flex-direction:column;gap:3px;flex:1;overflow-y:auto;padding-right:2px}
.tabs::-webkit-scrollbar{width:0}
.nav-group{font-size:10.5px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,.5);margin:15px 14px 6px;user-select:none}
.nav-group:first-child{margin-top:6px}
.tabs a{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:12px;cursor:pointer;
  color:rgba(255,255,255,.82);font-size:14px;font-weight:600;text-decoration:none;transition:background .15s,color .15s}
.tabs a .ic{font-size:17px;width:21px;text-align:center}
.tabs a:hover{background:rgba(255,255,255,.12);color:#fff}
.tabs a.on{background:#fff;color:var(--brand);font-weight:700;box-shadow:0 10px 22px -12px rgba(0,0,0,.4)}
.side-foot{margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.12)}
.side-foot .btn{background:rgba(255,255,255,.15);box-shadow:none}
.side-foot .btn:hover{background:rgba(255,255,255,.26);filter:none}

.content{flex:1;min-width:0;padding:26px 32px;overflow-x:hidden}
.content-inner{max-width:1560px;margin:0 auto;width:100%}
.page-head{font-family:var(--disp);font-size:23px;font-weight:700;color:var(--ink);margin:2px 0 18px;display:flex;align-items:center;gap:11px}
.page-head::before{content:"";width:6px;height:23px;border-radius:6px;background:linear-gradient(var(--brand-2),var(--pink))}

/* 概览卡 */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px}
#homeStats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px 20px;align-items:start}
.stat-group{margin-bottom:0}
.stat-group:last-child{margin-bottom:0}
.sg-title{font-family:var(--disp);font-size:14px;font-weight:700;color:var(--muted);margin:0 0 10px;padding-left:10px;border-left:3px solid var(--brand);letter-spacing:1px}
.sg-grid{display:flex;flex-direction:column;gap:12px}
@media(max-width:980px){#homeStats{grid-template-columns:repeat(2,1fr)}}
.stat{border-radius:var(--radius);padding:20px 18px;text-align:center;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(140deg,var(--brand-2),var(--brand));box-shadow:0 14px 30px -18px rgba(124,58,237,.5)}
.stat:nth-child(4n+2){background:linear-gradient(140deg,#FF7DAE,var(--pink))}
.stat:nth-child(4n+3){background:linear-gradient(140deg,#FF9D6B,var(--coral))}
.stat:nth-child(4n+4){background:linear-gradient(140deg,#3CDCCB,var(--cyan))}
.stat.sc0{background:linear-gradient(140deg,var(--brand-2),var(--brand))}
.stat.sc1{background:linear-gradient(140deg,#FF7DAE,var(--pink))}
.stat.sc2{background:linear-gradient(140deg,#FF9D6B,var(--coral))}
.stat.sc3{background:linear-gradient(140deg,#3CDCCB,var(--cyan))}
.stat b{display:block;font-family:var(--disp);font-size:29px;font-weight:700;line-height:1;overflow-wrap:anywhere}
.stat span{font-size:12.5px;opacity:.94;margin-top:7px;display:block}

/* 会员核销 */
.member{display:flex;align-items:center;gap:13px;margin-bottom:10px}
.avatar{width:54px;height:54px;border-radius:16px;background:linear-gradient(135deg,#EFE6FF,#FFE6F1);display:flex;align-items:center;justify-content:center;font-size:27px;flex-shrink:0}
.member b{font-size:16px}
.bal{display:flex;gap:12px;margin:14px 0;flex-wrap:wrap}
.bal div{text-align:center;background:var(--surface2);border:1px solid var(--line);border-radius:14px;padding:12px 18px;min-width:80px}
.bal b{display:block;font-family:var(--disp);font-size:23px;color:var(--brand);line-height:1}
.bal span{font-size:12px;color:var(--muted)}
.seg{display:flex;gap:10px;margin-top:6px}
.aud-typeseg{display:inline-flex;gap:8px}
.aud-typeseg button{appearance:none;border:1.5px solid #e2e8f0;background:#fff;cursor:pointer;font-size:14px;font-weight:700;color:var(--ink2);padding:9px 22px;border-radius:12px;transition:all .15s;line-height:1.2}
.aud-typeseg button:hover{border-color:var(--brand);color:var(--brand)}
.aud-typeseg button.on{background:linear-gradient(135deg,var(--brand-2),var(--brand));color:#fff;border-color:transparent;box-shadow:0 8px 18px -10px rgba(124,58,237,.7)}
.seg button{flex:1;padding:11px;border-radius:var(--r-ctl);border:1.5px solid var(--line2);background:#fff;font-size:14px;font-family:inherit;cursor:pointer;color:var(--ink2);transition:.15s}
.seg button.on{border-color:var(--brand);color:var(--brand);background:#F4EEFF;font-weight:700}
#reader{margin-top:12px;border-radius:var(--r-ctl);overflow:hidden}

/* 列表/记录 */
.log{font-size:13.5px;border-bottom:1px solid var(--line);padding:12px 2px;display:flex;justify-content:space-between;align-items:center}
.log:last-child{border-bottom:none}
.log .r{color:var(--coral);font-weight:700;font-family:var(--disp)}
.row-item{padding:13px 8px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:12px;align-items:center;border-radius:var(--r-sm);transition:background .12s}
.row-item:last-child{border-bottom:none}
.row-item:hover{background:var(--surface2)}
.row-item .left{flex:1;min-width:0}
.row-item .left .t{font-size:14.5px;font-weight:700;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row-item .left .sub{font-size:12.5px;color:var(--muted);margin-top:4px}
.row-item .acts{display:flex;gap:12px;flex-shrink:0}
.row-item .acts a{color:var(--pink);font-size:13px;cursor:pointer;text-decoration:none;font-weight:600}
.row-item .acts a:hover{text-decoration:underline}
.row-item .acts a.edit{color:var(--brand)}
.row-item .acts a.resume{color:#16a34a}
.row-item .acts a.lk-ledger{color:#0EA89A}
.row-item .acts a.lk-freeze{color:#E08A00}
.row-item .acts a.lk-unfreeze{color:#16a34a}
.row-item .acts a.lk-del{color:var(--coral)}

/* 分账 */
.sum{display:flex;gap:14px;margin-bottom:14px;flex-wrap:wrap}
.sum .box{flex:1;min-width:160px;background:linear-gradient(135deg,var(--brand),var(--pink));color:#fff;border-radius:16px;padding:18px;text-align:center;box-shadow:0 14px 30px -18px rgba(124,58,237,.45)}
.sum .box.alt{background:linear-gradient(135deg,var(--cyan),var(--blue))}
.sum b{display:block;font-family:var(--disp);font-size:24px;font-weight:700}
.sum span{font-size:11.5px;opacity:.93}
.srow{border-bottom:1px solid var(--line);padding:13px 0}
.srow:last-child{border-bottom:none}
.srow .top{display:flex;justify-content:space-between;font-weight:700;font-size:15px}
.srow .det{font-size:12.5px;color:var(--muted);margin-top:5px;display:flex;justify-content:space-between}
.pend{color:var(--coral);font-weight:700}
.badge{display:inline-block;font-size:11px;padding:3px 10px;border-radius:var(--r-pill);background:#F1EAFF;color:var(--brand);font-weight:700}
.badge.ok{background:#E3FBF4;color:#0a9b8a}
.badge.off{background:#F0EEF4;color:#8a7ea8}
.badge.del{background:#FDE7EC;color:#c2305a}
.pager{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line);font-size:12.5px;color:var(--muted)}
.pager select{width:auto;padding:5px 8px;font-size:12.5px}
.pager .pgnav{display:flex;align-items:center;gap:8px}
.pager .pgnav .btn{margin-top:0}
.pager b{color:var(--ink)}
.pager .btn[disabled]{opacity:.45;cursor:not-allowed}
.setrow{display:flex;gap:16px;flex-wrap:wrap}
.setbox{flex:1;min-width:250px;background:var(--surface2);border:1px solid var(--line);border-radius:14px;padding:15px 16px}
.setlbl{font-weight:700;font-size:13.5px;color:var(--ink);margin-bottom:10px}
.setline{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.setline input{width:96px;margin:0}
.setline .btn{margin-top:0}
.setunit{color:var(--muted);font-size:13px}
.sethint{font-size:12px;color:var(--muted);margin-top:10px;line-height:1.6}

/* 数据面板（成长卡/通用 KPI） */
.cs-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:6px}
.cs-tile{position:relative;border-radius:16px;padding:16px 16px 14px;background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);overflow:hidden}
.cs-tile::before{content:'';position:absolute;left:0;top:0;bottom:0;width:5px;border-radius:5px 0 0 5px}
.cs-tile.v1::before{background:linear-gradient(var(--brand-2),var(--brand))} .cs-tile.v1 .cs-v{color:var(--brand)}
.cs-tile.v2::before{background:linear-gradient(#FF7DAE,var(--pink))} .cs-tile.v2 .cs-v{color:var(--pink)}
.cs-tile.v3::before{background:linear-gradient(#36E0CC,var(--cyan))} .cs-tile.v3 .cs-v{color:#0a9b8a}
.cs-tile.v4::before{background:linear-gradient(#FFB97A,var(--coral))} .cs-tile.v4 .cs-v{color:#e07b1f}
.cs-tile .cs-ic{position:absolute;right:12px;top:12px;font-size:22px;opacity:.45}
.cs-tile.cs-clickable{cursor:pointer;transition:transform .12s,box-shadow .12s}
.cs-tile.cs-clickable:hover{transform:translateY(-2px);box-shadow:0 14px 30px -16px rgba(80,50,150,.4)}
.cs-tile .cs-more{font-size:11px;font-weight:600;color:var(--brand);opacity:.85}
/* 实心渐变色块(借鉴会员管理首页 .stat), 用于营销中心可点击统计 */
.csolid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:6px}
.csolid .ct{position:relative;border-radius:16px;padding:18px 16px 15px;color:#fff;overflow:hidden;cursor:default;
  box-shadow:0 14px 30px -18px rgba(80,50,150,.5);transition:transform .12s,box-shadow .12s}
.csolid .ct.v1{background:linear-gradient(140deg,#9D5CFF,#7C3AED)}
.csolid .ct.v2{background:linear-gradient(140deg,#FF7DAE,#FF4D8D)}
.csolid .ct.v3{background:linear-gradient(140deg,#3CDCCB,#13C2B6)}
.csolid .ct.v4{background:linear-gradient(140deg,#FFB97A,#FF7A45)}
.csolid .ct.clk{cursor:pointer}
.csolid .ct.clk:hover{transform:translateY(-3px);box-shadow:0 20px 40px -16px rgba(80,50,150,.6)}
.csolid .ct .ct-ic{position:absolute;right:12px;top:12px;font-size:22px;opacity:.5}
.csolid .ct .ct-l{font-size:12.5px;opacity:.95;font-weight:600}
.csolid .ct .ct-v{font-size:27px;font-weight:800;line-height:1.15;margin-top:5px;font-family:var(--disp,inherit)}
.csolid .ct .ct-s{font-size:11px;opacity:.9;margin-top:3px}
.csolid .ct .ct-more{display:inline-block;font-size:10.5px;font-weight:700;background:rgba(255,255,255,.25);padding:1px 7px;border-radius:999px;margin-left:6px}
.cs-tile .cs-l{font-size:12.5px;color:var(--muted);font-weight:600}
.cs-tile .cs-v{font-size:25px;font-weight:800;line-height:1.15;margin-top:4px;font-family:var(--disp,inherit)}
.cs-tile .cs-s{font-size:11.5px;color:var(--muted);margin-top:3px}
.cs-sec{display:flex;align-items:center;gap:8px;font-weight:800;font-size:14px;color:var(--ink);margin:20px 0 10px}
.cs-sec::before{content:'';width:6px;height:18px;border-radius:4px;background:linear-gradient(var(--brand-2),var(--brand))}
.cs-sec .cs-sec-x{font-weight:600;font-size:12px;color:var(--muted);margin-left:2px}
.cs-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;background:#fff;
  border:1px solid var(--line);border-radius:14px;overflow:hidden}
.cs-table th{text-align:left;padding:10px 12px;background:var(--surface2);color:var(--ink2);font-weight:700;font-size:12px}
.cs-table td{padding:10px 12px;border-top:1px solid var(--line);color:var(--ink)}
.cs-table td.num{font-weight:700;color:var(--brand);font-variant-numeric:tabular-nums}
.cs-table tr:hover td{background:var(--surface2)}
.cs-table.cs-fixed3{table-layout:fixed}
.cs-table.cs-fixed3 td{word-break:break-word}
.cs-table .cs-time{white-space:nowrap;color:var(--muted);font-variant-numeric:tabular-nums}
.cs-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}
.cs-trio{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:10px}
.cs-trig{position:relative;border-radius:14px;padding:14px 12px 12px;text-align:center;overflow:hidden;border:1px solid transparent;min-width:0}
.cs-trig .cs-ti{font-size:24px;line-height:1}
.cs-trig .cs-tl{font-size:12.5px;font-weight:700;margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cs-trig .cs-tn{font-size:24px;font-weight:800;line-height:1.1;margin-top:2px}
.cs-trig .cs-tu{font-size:11px;opacity:.7;font-weight:600}
.cs-trig.sm{padding:11px 5px 10px}
.cs-trig.sm .cs-ti{font-size:20px}
.cs-trig.sm .cs-tl{font-size:11px;margin-top:4px}
.cs-trig.sm .cs-tn{font-size:19px}
.cs-trig.sm .cs-tu{font-size:10px;white-space:nowrap}
.cs-trig.t-open{background:linear-gradient(160deg,#FFF3DC,#FFE7C2);border-color:#ffe0a8;color:#9a6a00}
.cs-trig.t-bday{background:linear-gradient(160deg,#FFE9F1,#FFD6E6);border-color:#ffc7dd;color:#c43c74}
.cs-trig.t-month{background:linear-gradient(160deg,#E3FBF4,#CFF6EC);border-color:#b8f0e2;color:#0a9b8a}
.cs-trig.rw-coin{background:linear-gradient(160deg,#FFF6E6,#FFEAC6);border-color:#ffe0a8;color:#9a6a00}
.cs-trig.rw-points{background:linear-gradient(160deg,#EEF4FF,#DCE8FF);border-color:#cfe0ff;color:#2c5fb3}
.cs-trig.rw-count{background:linear-gradient(160deg,#E6FBF5,#D2F6EC);border-color:#b8f0e2;color:#0a9b8a}
.cs-trig.rw-coupon{background:linear-gradient(160deg,#FFECF3,#FFD8E6);border-color:#ffc7dd;color:#c43c74}
.cs-trig.rw-gift{background:linear-gradient(160deg,#F2EDFF,#E6DBFF);border-color:#ddcffb;color:#6a37c9}
.cs-subcap{font-size:12px;color:var(--muted);font-weight:600;margin:12px 0 6px}
.gtag{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:8px;white-space:nowrap}
.gtag.v{background:#F1ECFF;color:#6a37c9;border:1px solid #e2d8fb}
.gtag.p{background:#E3FBF4;color:#0a9b8a;border:1px solid #c5f1e6}
.cs-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 13px;border-radius:var(--r-pill);font-size:12.5px;font-weight:600;
  background:#F4EEFF;color:#6a37c9;border:1px solid #e7ddff}
.cs-chip b{font-weight:800}
.cs-chip.r-coin{background:#FFF3DC;color:#9a6a00;border-color:#ffe7bd}
.cs-chip.r-points{background:#E9F1FF;color:#2c5fb3;border-color:#d4e3ff}
.cs-chip.r-count{background:#E3FBF4;color:#0a9b8a;border-color:#c5f1e6}
.cs-chip.r-coupon{background:#FFE9F1;color:#c43c74;border-color:#ffd2e2}
.cs-chip.r-gift{background:#F1ECFF;color:#6a37c9;border-color:#e2d8fb}
.cs-empty{font-size:13px;color:var(--muted);background:var(--surface2);border:1px dashed var(--line2);border-radius:var(--r-ctl);padding:18px;text-align:center}

/* 子标签 */
.opsTabs{display:flex;flex-wrap:wrap;gap:7px;padding:8px;background:#fff;border-radius:16px;margin-bottom:16px;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.opsTabs::-webkit-scrollbar{height:0}
.opsTabs button{flex-shrink:0;padding:9px 17px;border:none;background:transparent;color:var(--muted);border-radius:var(--r-sm);font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;transition:.15s}
.opsTabs button:hover{background:var(--surface2);color:var(--brand)}
.opsTabs button.on{background:linear-gradient(135deg,var(--brand-2),var(--brand));color:#fff;font-weight:700}
/* 营销中心统一模块布局 */
.mkt-sec{margin-bottom:16px}
.mkt-sec-h{display:flex;align-items:center;gap:8px;font-weight:800;font-size:15px;color:var(--ink);margin:0 0 12px}
.mkt-sec-h::before{content:"";width:6px;height:18px;border-radius:4px;background:linear-gradient(var(--brand-2),var(--pink))}
.mkt-sec-h .mkt-sec-x{font-weight:500;font-size:12px;color:var(--muted);margin-left:2px}
.mkt-sec-h .mkt-sec-act{margin-left:auto;display:flex;gap:8px}
.mkt-form-toggle{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--brand-2),var(--brand));padding:9px 16px;border-radius:var(--r-pill);border:none;box-shadow:0 10px 22px -12px rgba(124,58,237,.6)}
.mkt-form-toggle:hover{filter:brightness(1.04)}
.mkt-form-wrap{display:none;border:1px solid var(--line2);border-radius:var(--r-ctl);padding:16px;margin-bottom:14px;background:var(--surface2);animation:rise .3s both}
.mkt-form-wrap.open{display:block}
.mkt-form-wrap .mkt-form-title{font-weight:700;font-size:14px;color:var(--ink);margin-bottom:10px}
/* ===== 营销中心 v2 重构: 统一模块外壳 ===== */
.mod{margin:0}
.mod-block{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);padding:18px 18px 16px;margin-bottom:16px}
.mod-block-h{display:flex;align-items:center;gap:9px;font-weight:800;font-size:15px;color:var(--ink);margin:0 0 14px}
.mod-block-h::before{content:"";width:6px;height:18px;border-radius:4px;background:linear-gradient(var(--brand-2),var(--pink))}
.mod-block-h .x{font-weight:500;font-size:12px;color:var(--muted)}
.mod-block-h .right{margin-left:auto;display:flex;gap:8px;align-items:center}
.ksk-item{padding:16px 2px;border-bottom:1px solid var(--line)}
.ksk-item:first-child{padding-top:4px}
.ksk-item:last-child{border-bottom:none;padding-bottom:2px}
.mod-add-btn{display:inline-flex;align-items:center;gap:5px;cursor:pointer;font-size:13px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--brand-2),var(--brand));padding:9px 18px;border-radius:var(--r-pill);border:none;box-shadow:0 10px 22px -12px rgba(124,58,237,.6)}
.mod-add-btn:hover{filter:brightness(1.05)}
.mod-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px}
.mod-toolbar .search{flex:1;min-width:160px}
/* 列表项(统一) */
.mod-list .row-item{display:flex;align-items:center;gap:12px;padding:14px 4px;border-bottom:1px solid var(--line)}
.mod-list .row-item:last-child{border-bottom:none}
/* 弹层表单内的网格 */
.mf-grid{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
.mf-grid .fld{flex:1;min-width:140px}
.mf-grid .fld.full{flex-basis:100%;min-width:100%}
.mf-grid .fld label{display:block;font-size:12.5px;color:var(--ink2);font-weight:600;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.modal-box.form-modal{max-width:520px;max-height:88vh;display:flex;flex-direction:column}
.modal-box.form-modal .fm-body{overflow:auto;flex:1;padding-right:4px;margin:-2px 0 14px}

/* 筛选工具栏 */
.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px;background:#fff;
  border:1px solid var(--line);border-radius:16px;padding:12px 14px;box-shadow:var(--shadow-sm)}
.toolbar input{width:auto}
.toolbar input[type=date]{flex:0 0 auto;padding:9px 11px;font-size:13.5px}
.toolbar .search{flex:1 1 220px;min-width:160px;padding:10px 13px}
.toolbar .sep{color:var(--muted);font-size:13px}
.toolbar .count{margin-left:auto;color:var(--brand);font-size:12.5px;font-weight:700;background:#F4EEFF;padding:5px 12px;border-radius:var(--r-pill)}
.toolbar label{margin:0;font-size:13px;color:var(--ink2)}
.toolbar select{width:auto}

/* 表格 */
.dtable-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:14px}
.trend-blk{margin-bottom:14px}
.trend-blk:last-child{margin-bottom:0}
.trend-t{font-size:13px;font-weight:700;color:var(--ink2);margin-bottom:4px}
.dtable{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
.dtable th{text-align:left;padding:11px 13px;font-size:12px;font-weight:700;color:var(--ink2);background:var(--surface2);white-space:nowrap}
.dtable td{padding:11px 13px;border-top:1px solid var(--line);color:var(--ink);white-space:nowrap}
.dtable tbody tr:hover td{background:var(--surface2)}
/* 票务三张表: 固定列宽, 列与列上下对齐 */
.tk-fixed{table-layout:fixed;min-width:980px}
.tk-fixed th,.tk-fixed td{white-space:normal;word-break:break-word;overflow-wrap:anywhere;vertical-align:top}
.tk-fixed .tkops{display:flex;flex-direction:column;gap:5px;align-items:flex-start}
.tk-fixed .tkops-row{display:flex;flex-wrap:wrap;gap:5px}
.tk-fixed .tkops .btn{margin:0}

/* Toast */
.toast{position:fixed;left:50%;top:30px;transform:translateX(-50%);background:rgba(34,27,61,.96);color:#fff;padding:13px 22px;border-radius:14px;font-size:14px;z-index:300;display:none;max-width:84%;box-shadow:var(--shadow-pop);align-items:center;gap:9px;animation:tin .2s ease}
.toast.show{display:inline-flex}
.toast .tic{font-size:16px;line-height:1}
.toast.ok{background:linear-gradient(120deg,#2C2456,#1d5a44)}
.toast.err{background:linear-gradient(120deg,#5a1d2b,#a3242e)}
@keyframes tin{from{transform:translateX(-50%) translateY(-10px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}
.modal-mask{position:fixed;inset:0;background:rgba(34,22,70,.5);display:none;align-items:center;justify-content:center;z-index:280;padding:20px;backdrop-filter:blur(2px)}
.modal-mask.show{display:flex}
/* 通用确认/输入弹窗(uiConfirm/uiPrompt/uiForm)永远置顶, 避免被其他弹窗(如合并会员)遮挡 */
#modalMask{z-index:600}
.modal-box{background:#fff;border-radius:20px;max-width:380px;width:100%;padding:24px 22px 18px;box-shadow:var(--shadow-pop);animation:mpop .18s cubic-bezier(.2,.9,.3,1.2);max-height:92vh;overflow-y:auto}
@keyframes mpop{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}
.modal-title{font-family:var(--disp);font-weight:700;font-size:18px;color:var(--ink);margin-bottom:10px}
.modal-msg{color:var(--ink2);font-size:14px;line-height:1.7;white-space:pre-wrap;margin-bottom:20px}
.modal-acts{display:flex;gap:10px}
.modal-acts .btn{margin:0;flex:1}
.modal-box.wide{max-width:600px}
.modal-box.mid{max-width:460px}
.dep-tabs{display:flex;gap:6px;background:#f5f3fa;border-radius:12px;padding:4px}
.dep-tabs button{flex:1;appearance:none;border:none;background:transparent;cursor:pointer;font-size:13.5px;font-weight:700;color:var(--ink2);padding:9px;border-radius:9px;transition:all .15s}
.dep-tabs button.on{background:#fff;color:var(--brand);box-shadow:0 2px 6px rgba(0,0,0,.06)}
.dep-switch{display:flex;align-items:center;gap:9px;cursor:pointer;font-size:14px;font-weight:600;color:var(--ink)}
.dep-switch input{width:18px;height:18px;accent-color:var(--brand);cursor:pointer}
#modalForm .ff{margin-bottom:13px}
#modalForm .ff:last-child{margin-bottom:4px}
#modalForm .ff label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px;font-weight:600}
#modalForm .ff input,#modalForm .ff select{width:100%;padding:10px 12px;border:1.5px solid var(--line2);border-radius:var(--r-ctl);font-size:14px;box-sizing:border-box;font-family:inherit;background:#fff}
#modalForm .ff .ff-hint{font-size:11px;color:var(--muted);margin-top:5px;line-height:1.5}

/* 流水 */
.ledger-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.ledger-tabs .lgt{width:auto;padding:6px 14px;border-radius:var(--r-pill);border:1.5px solid var(--line2);background:var(--surface2);color:var(--ink2);font-size:13px;cursor:pointer;margin:0}
.ledger-tabs .lgt.on{border-color:var(--brand);background:#F2ECFF;color:var(--brand);font-weight:700}
.ledger-body{max-height:42vh;overflow:auto;border:1px solid var(--line);border-radius:var(--r-ctl)}
.lg-row{padding:10px 14px;border-bottom:1px solid var(--line)}
.lg-row:last-child{border-bottom:none}
.lg-main{display:flex;align-items:center;justify-content:space-between;gap:10px}
.lg-biz{font-weight:700;color:var(--ink)}
.lg-meta{color:var(--muted);font-size:12px;margin-top:3px;line-height:1.6}
#ledgerCards{margin-bottom:10px}
.lg-card{display:flex;justify-content:space-between;gap:10px;align-items:center;background:var(--surface2);border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 12px;margin-bottom:6px;font-size:13px}
.lg-card .lg-exp{font-weight:700;color:var(--brand)}
.lg-card .lg-exp.expired{color:var(--coral)}

/* 会员档案 */
.prof-back{display:inline-flex;align-items:center;gap:4px;color:var(--brand);cursor:pointer;font-size:13px;font-weight:600;margin-bottom:14px;background:#F4EEFF;padding:7px 13px;border-radius:var(--r-pill)}
.prof-back:hover{background:#EBE2FF}
.prof-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.prof-av{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,var(--brand-2),var(--brand));color:#fff;display:flex;align-items:center;justify-content:center;font-size:23px;font-weight:800;flex:0 0 auto;box-shadow:0 12px 26px -14px rgba(124,58,237,.55)}
.prof-name{font-size:18px;font-weight:800;display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:var(--ink)}
.prof-sub{font-size:12.5px;color:var(--muted);margin-top:4px}
.prof-acts{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.prof-acts .pa{display:inline-flex;align-items:center;gap:4px;font-size:12px;padding:7px 13px;border-radius:var(--r-pill);border:1.5px solid var(--line2);background:#fff;cursor:pointer;color:var(--ink2);font-weight:600}
.prof-acts .pa:hover{background:var(--surface2);border-color:var(--brand)}
.prof-acts .pa.danger{color:var(--coral);border-color:#F4C7BB}
.prof-acts .pa.danger:hover{background:#FFF3F0;border-color:var(--coral)}
.prof-assets{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;margin-bottom:16px}
.prof-asset{background:linear-gradient(160deg,var(--surface2),#F4EFFC);border:1px solid var(--line);border-radius:15px;padding:14px 10px;text-align:center}
.prof-asset .v{font-size:22px;font-weight:800;color:var(--brand);font-family:var(--disp,inherit)}
.prof-asset .l{font-size:11.5px;color:var(--muted);margin-top:3px;font-weight:600}
.prof-tabs{display:flex;flex-wrap:wrap;gap:7px;border-top:1px solid var(--line);padding-top:14px}
.prof-tab{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;padding:7px 13px;border-radius:var(--r-pill);border:1.5px solid var(--line2);background:#fff;cursor:pointer;color:var(--ink2);font-weight:600;transition:.13s}
.prof-tab:hover{background:var(--surface2);border-color:var(--brand)}
.prof-tab.on{background:linear-gradient(135deg,var(--brand-2),var(--brand));color:#fff;border-color:transparent}
.pf-h{font-weight:800;margin-bottom:8px;font-size:15px;color:var(--ink)}

/* 富文本编辑器 */
.rt-tools{display:flex;flex-wrap:wrap;gap:5px;align-items:center;background:var(--surface2);border:1.5px solid var(--line2);border-bottom:0;border-radius:var(--r-ctl) var(--r-ctl) 0 0;padding:8px}
.rt-tools button{width:auto;min-width:32px;height:30px;margin:0;padding:0 9px;border:1px solid var(--line2);background:#fff;border-radius:8px;font-size:13px;color:var(--ink);cursor:pointer;font-family:inherit;line-height:1}
.rt-tools button:hover{background:#F0E9FF}
.rt-sep{width:1px;height:18px;background:var(--line2);margin:0 2px}
.rt-colors{display:inline-flex;gap:5px}
.rt-colors i{width:19px;height:19px;border-radius:5px;cursor:pointer;border:1px solid rgba(0,0,0,.12);display:inline-block}
.rt-editor{min-height:150px;border:1.5px solid var(--line2);border-radius:0 0 var(--r-ctl) var(--r-ctl);padding:12px 14px;font-size:15px;background:#fff;line-height:1.7;outline:none;overflow:auto}
.rt-editor:empty:before{content:attr(data-ph);color:#c2b8da}
.rt-editor:focus{border-color:var(--brand)}
.rt-editor img{max-width:100%;border-radius:8px;margin:6px 0;display:block}
.rt-editor h2,.pv-content h2{font-size:19px;font-weight:800;margin:14px 0 8px;color:var(--ink);line-height:1.4}
.rt-editor h3,.pv-content h3{font-size:16px;font-weight:800;margin:12px 0 6px;color:var(--ink);line-height:1.4}
.rt-editor blockquote,.pv-content blockquote{margin:10px 0;padding:8px 14px;border-left:4px solid #C9B8FF;background:var(--surface2);border-radius:0 8px 8px 0;color:#5a5278}
.rt-editor ul,.rt-editor ol,.pv-content ul,.pv-content ol{padding-left:22px;margin:8px 0}
.rt-editor li,.pv-content li{margin:3px 0}
.rt-tools .rt-grp{display:inline-flex;gap:5px;align-items:center}
/* 图片裁剪器 */
.crop-mask,.pv-mask{position:fixed;inset:0;background:rgba(20,16,40,.64);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}
.crop-box{background:#fff;border-radius:18px;padding:18px;width:min(440px,94vw)}
.crop-h{font-weight:800;font-size:15px;margin-bottom:4px}
.crop-tip{font-size:12px;color:var(--muted);margin-bottom:12px;line-height:1.5}
.crop-stage{position:relative;width:100%;overflow:hidden;background:#1c1830;border-radius:var(--r-ctl);touch-action:none;cursor:grab;user-select:none}
.crop-stage:active{cursor:grabbing}
.crop-stage img{position:absolute;left:0;top:0;transform-origin:0 0;pointer-events:none;-webkit-user-drag:none}
.crop-grid{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.22) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.22) 1px,transparent 1px);background-size:33.33% 33.33%}
.crop-stage.crop-round::after{content:"";position:absolute;left:50%;top:50%;width:100%;height:100%;transform:translate(-50%,-50%);border-radius:50%;box-shadow:0 0 0 9999px rgba(28,24,48,.55);pointer-events:none}
.crop-ctrl{display:flex;align-items:center;gap:10px;margin:13px 0}
.crop-ctrl input[type=range]{flex:1}
.crop-acts{display:flex;gap:10px}
.crop-acts .btn{flex:1;width:auto;margin:0}
/* 手机预览 */
.pv-card{width:min(400px,92vw);background:#f3f0fa;border-radius:18px;padding:20px;box-shadow:0 20px 60px rgba(0,0,0,.3);overflow:hidden;max-height:88vh;display:flex;flex-direction:column}
.pv-card-h{font-size:16px;font-weight:800;color:var(--ink);margin-bottom:10px;flex-shrink:0}
.pv-card-h span{font-size:12px;font-weight:400;color:var(--muted);margin-left:6px}
.pv-scroll{overflow:auto;-webkit-overflow-scrolling:touch;background:#fff;border-radius:12px;flex:1}
.pv-cover{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.pv-cover.ph{background:linear-gradient(135deg,var(--brand),var(--pink));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:17px;padding:0 18px;text-align:center}
.pv-body{padding:16px 16px 22px}
.pv-cat{display:inline-block;font-size:11px;color:var(--brand);background:#F1EBFF;border-radius:6px;padding:2px 9px;margin-bottom:9px}
.pv-title{font-size:19px;font-weight:800;line-height:1.4;color:var(--ink)}
.pv-meta{font-size:12px;color:#9890ad;margin:9px 0 14px;border-bottom:1px solid var(--line);padding-bottom:12px}
.pv-content{font-size:15px;line-height:1.75;color:#3a3357;word-break:break-word}
.pv-content img{max-width:100%;border-radius:8px;margin:6px 0;display:block}
.pv-empty{color:#b8b0cc;font-size:14px}
.pv-acts{display:flex;gap:10px;padding:14px 0 0;flex-shrink:0}
.pv-acts .btn{flex:1;width:auto;margin:0}
#verify{width:100%}
.cascade3{display:flex;gap:8px;align-items:center;width:100%}
.acfilter{display:inline-flex;align-items:center;gap:8px;flex:1 1 320px}
.acfilter>label{flex:0 0 auto;white-space:nowrap}
.acfilter select{flex:1;min-width:0;width:auto}
.cascade3 select{flex:1;min-width:0;width:auto}
.perm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:8px;margin:6px 0 4px}
.perm-grid label{display:flex;align-items:center;gap:7px;margin:0;font-weight:500;background:var(--surface2);border:1.5px solid var(--line2);border-radius:var(--r-sm);padding:9px 11px;cursor:pointer;font-size:13.5px}
.perm-grid label.on{border-color:var(--brand);background:#F2ECFF}
.perm-grid input{width:auto;margin:0}
.perm-tree{margin:6px 0 4px}
.perm-tree .perm-group{margin:0 0 10px}
.sw-toggle{appearance:none;-webkit-appearance:none;width:46px;height:25px;background:#d4d0dd;border-radius:13px;position:relative;cursor:pointer;transition:background .2s;flex:0 0 auto;outline:none;border:none;margin:0;padding:0;vertical-align:middle;box-sizing:border-box;align-self:center;display:inline-block}
.sw-toggle:checked{background:var(--brand)}
.sw-toggle::after{content:"";position:absolute;top:2.5px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.sw-toggle:checked::after{left:23px}
.sw-toggle:disabled{opacity:.45;cursor:not-allowed}
.acc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;margin-top:14px}
.acc-card{border:1px solid var(--line);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:9px;background:var(--surface2)}
.acc-card .acc-h{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--ink);font-size:14px}
.acc-card .acc-ic{width:30px;height:30px;border-radius:9px;background:#F1EBFF;display:flex;align-items:center;justify-content:center;font-size:15px;flex:0 0 auto}
.acc-card .acc-st{font-size:13px;color:var(--muted);flex:1;word-break:break-all;line-height:1.5}
.acc-card .acc-st b{color:var(--ink);font-weight:600}
.acc-card .acc-act{display:flex;gap:6px}
.acc-card .acc-act .btn{margin:0;width:auto;flex:1;padding:9px 0;font-size:13px}
.perm-tree .perm-top{display:inline-flex;align-items:center;gap:7px;font-weight:600;background:var(--surface2);border:1.5px solid var(--line2);border-radius:var(--r-sm);padding:9px 12px;cursor:pointer;font-size:14px;margin:0}
.perm-tree .perm-top.on{border-color:var(--brand);background:#F2ECFF}
.perm-tree .perm-top input{width:auto;margin:0}
.perm-subs{display:grid;grid-template-columns:repeat(auto-fill,minmax(116px,1fr));gap:6px;margin:7px 0 0 16px;padding-left:12px;border-left:2px solid var(--line2)}
.perm-subs label{display:flex;align-items:center;gap:6px;margin:0;font-weight:500;background:#fff;border:1.5px solid var(--line);border-radius:9px;padding:7px 9px;cursor:pointer;font-size:12.5px}
.perm-subs label.on{border-color:var(--brand);background:var(--surface2)}
.perm-subs input{width:auto;margin:0}
.perm-subs .perm-subcat{grid-column:1/-1;font-size:11.5px;color:var(--brand);font-weight:700;margin:4px 0 0;padding-top:6px;border-top:1px dashed var(--line2)}
.staff-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 0;border-bottom:1px solid var(--line);flex-wrap:wrap}
.staff-row>div:first-child{flex:1 1 100%}
.staff-row .ops{display:flex;gap:6px;flex-wrap:wrap;flex:1 1 100%;margin-top:4px}
#verify .vf-h{font-family:var(--disp);font-weight:700;color:var(--ink);font-size:16px;display:flex;align-items:center;gap:8px;margin:0 0 12px}
#verify .vf-h.sm{font-size:13px;color:var(--ink2);margin:14px 0 8px}
#verify .vf-ic{font-size:20px}
#verify .vf-input{width:100%;padding:13px 14px;border:1.5px solid var(--line2);border-radius:var(--r-ctl);font-size:15px;background:#fff}
#verify .vf-input:focus{border-color:var(--brand);outline:none}
#verify .vf-row{display:flex;gap:10px;margin-top:10px;align-items:flex-end}
#verify .vf-or{display:flex;align-items:center;text-align:center;color:var(--muted);font-size:12px;margin:16px 0 8px}
#verify .vf-or:before,#verify .vf-or:after{content:"";flex:1;height:1px;background:var(--line)}
#verify .vf-or span{padding:0 12px}
#verify #reader{margin-top:10px;border-radius:var(--r-ctl);overflow:hidden}
.vf-member .vf-top{display:flex;align-items:center;gap:14px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.vf-avatar{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,var(--coral),var(--pink));display:flex;align-items:center;justify-content:center;font-size:28px;flex:none;box-shadow:0 12px 26px -14px rgba(255,77,141,.55)}
.vf-id b{font-size:18px;color:var(--ink)}
.vf-bal{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:14px 0}
@media(max-width:560px){.vf-bal{grid-template-columns:repeat(2,1fr)}}
.vf-tile{position:relative;border-radius:15px;padding:14px 8px;text-align:center;color:#fff;box-shadow:0 12px 26px -16px rgba(60,30,110,.5)}
.vf-tile b{display:block;font-size:24px;font-family:var(--disp);line-height:1.1}
.vf-tile span{font-size:12px;opacity:.92}
.vf-tile.tap{cursor:pointer;transition:transform .12s,box-shadow .12s}
.vf-tile.tap:hover{transform:translateY(-2px);box-shadow:0 18px 32px -16px rgba(60,30,110,.6)}
.vf-tile.tap:active{transform:translateY(0)}
.vf-tile .vf-cnt{position:absolute;top:7px;right:8px;display:none;align-items:center;gap:3px;font-size:10.5px;font-weight:700;background:rgba(255,255,255,.28);padding:2px 7px;border-radius:var(--r-pill);line-height:1.4}
.vf-tile .vf-cnt.show{display:inline-flex}
.vf-tile .vf-tap-tip{display:block;font-size:10px;opacity:.78;margin-top:3px;font-weight:600}
.vf-tile.coin{background:linear-gradient(135deg,#FF9466,var(--coral))}
.vf-tile.count{background:linear-gradient(135deg,var(--brand),var(--brand-2))}
.vf-tile.growth{background:linear-gradient(135deg,var(--cyan),#0FB6A6)}
.vf-tile.points{background:linear-gradient(135deg,#94a3b8,#64748b)}
/* 卡明细弹窗 */
.cardpop-h{display:flex;align-items:center;gap:9px;font-family:var(--disp);font-weight:700;font-size:17px;color:var(--ink);margin-bottom:4px}
.cardpop-h .cp-ic{width:34px;height:34px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;flex:0 0 auto}
.cardpop-h .cp-ic.coin{background:linear-gradient(135deg,#FF9466,var(--coral))}
.cardpop-h .cp-ic.count{background:linear-gradient(135deg,var(--brand),var(--brand-2))}
.cardpop-h .cp-ic.growth{background:linear-gradient(135deg,var(--cyan),#0FB6A6)}
.cardpop-h .cp-ic.points{background:linear-gradient(135deg,#94a3b8,#64748b)}
.pts-sum{display:flex;gap:10px;margin:4px 0 10px}
.pts-box{flex:1;border-radius:12px;padding:12px;text-align:center}
.pts-box.ok{background:#ecfdf5;border:1px solid #a7f3d0}
.pts-box.exp{background:#f8fafc;border:1px solid #e2e8f0}
.pts-box .pts-n{font-family:var(--disp);font-size:24px;font-weight:800;line-height:1}
.pts-box.ok .pts-n{color:#059669}
.pts-box.exp .pts-n{color:#94a3b8}
.pts-box .pts-l{font-size:12px;color:#64748b;margin-top:4px}
.pts-warn{background:#fff7ed;border:1px solid #fed7aa;color:#c2410c;border-radius:10px;padding:8px 12px;font-size:13px;margin-bottom:10px}
.cardrow.soon{background:#fff7ed}
.cardpop-sub{font-size:12.5px;color:var(--muted);margin:0 0 14px}
.cardpop-body{max-height:54vh;overflow:auto}
.cardpop-tabs{display:flex;gap:8px;margin:0 0 12px}
.seg-tabs{display:inline-flex;background:var(--surface2,#f5f3fa);border:1px solid var(--line2);border-radius:999px;padding:3px;gap:2px;margin:0 0 12px}
.seg-tabs button{appearance:none;border:none;background:transparent;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink2);padding:7px 16px;border-radius:999px;transition:all .15s;white-space:nowrap;line-height:1.2}
.seg-tabs button:hover{color:var(--brand)}
.seg-tabs button.on{background:var(--brand,#7A35FF);color:#fff;box-shadow:0 1px 4px rgba(122,53,255,.35)}
.seg-tabs button.on .seg-n{color:#fff;opacity:.9}
.seg-tabs .seg-n{margin-left:5px;font-size:12px;opacity:.7;font-weight:700}
.cardpop-tabs .cpt{flex:1;text-align:center;padding:9px 0;border-radius:var(--r-ctl);border:1.5px solid var(--line2);background:#fff;font-size:13.5px;font-weight:600;color:var(--ink2);cursor:pointer}
.cardpop-tabs .cpt.on{border-color:var(--brand);background:#F4EEFF;color:var(--brand)}
.cardpop-tabs .cpt .cpt-n{font-size:11px;opacity:.8;margin-left:3px}
.cardpop-perbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line);font-size:12.5px;color:var(--muted)}
.cardpop-perbar select{width:auto;padding:5px 8px;font-size:12.5px}
.cardpop-perbar .pgnav{display:flex;align-items:center;gap:8px}
.cardpop-perbar .pgnav .btn{margin:0}
#vfCards{margin:4px 0 6px}
#vfCards .vfc-h{font-size:12px;font-weight:700;color:var(--brand);margin:8px 0 6px}
#vfCards .vfc{display:flex;justify-content:space-between;align-items:center;gap:10px;background:var(--surface2);border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 12px;margin-bottom:6px;font-size:13px}
#vfCards .vfc .nm{font-weight:600;color:var(--ink2)}
#vfCards .vfc .ex{font-weight:700;color:var(--brand);white-space:nowrap}
#vfCards .vfc .ex.expired{color:var(--coral)}
.cardrow{display:flex;justify-content:space-between;align-items:center;gap:10px;border-radius:var(--r-sm);padding:9px 12px;margin-bottom:6px;font-size:13px;background:#ECFDF3;border:1px solid #BBF7D0;border-left:4px solid #22c55e}
.cardrow.exp{background:#FEF2F2;border-color:#FECACA;border-left-color:#ef4444}
.cardrow .ci-l{display:flex;flex-direction:column;gap:2px;min-width:0}
.cardrow .ci-nm{font-weight:600;color:var(--ink2)}
.cardrow.exp .ci-nm{color:var(--ink2)}
.cardrow .ci-pd{font-size:11.5px;color:var(--muted)}
.fam-banner{margin:2px 0 8px;border-radius:var(--r-ctl);padding:10px 12px;font-size:12.5px;line-height:1.6;background:#F1ECFF;border:1px solid #e2d8fb;color:#5b34b0}
.fam-banner b{color:#4a2a93}
.fam-banner .fb-assets{display:block;margin-top:4px;font-weight:700;color:#4a2a93}
.fam-banner .fb-roster{display:block;margin-top:8px;background:rgba(255,255,255,.6);border-radius:var(--r-sm);padding:6px 10px;font-weight:600;color:#3a2a6e;font-size:12.5px}
.fam-banner .fb-rrow{display:flex;justify-content:space-between;gap:12px;padding:3px 0;border-top:1px solid rgba(124,58,237,.10)}
.fam-banner .fb-rrow:first-child{border-top:none}
.fam-banner .fb-pool{background:rgba(10,155,138,.12);margin:-6px -10px 2px;padding:6px 10px;border-radius:var(--r-sm) var(--r-sm) 0 0;color:#0a7d70}
.fam-banner.off{background:#FFF7ED;border-color:#fed7aa;color:#b3700f}
.fam-banner.off b{color:#92560a}
.cd-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:var(--r-pill);white-space:nowrap}
.cd-badge.yes{background:#DCFCE7;color:#16a34a}
.cd-badge.no{background:#FFE0DB;color:#d6402c}
.cards-sub{font-size:12px;font-weight:700;margin:8px 0 6px;color:var(--brand)}
.cards-sub.exp{color:#d6402c}
.mf-title{font-weight:800;font-size:17px;margin-bottom:14px;color:var(--ink)}
.mf-sec{background:var(--surface2);border:1px solid var(--line);border-radius:14px;padding:15px 16px;margin-bottom:12px}
.mf-sec-h{font-weight:800;font-size:15px;margin-bottom:10px;color:var(--ink)}
.mf-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.mf-grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.mf-actions{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.mf-actions .btn{width:100%;margin:0}
.op-edit-row{display:flex;gap:10px;margin-top:16px}
.op-edit-row .btn{width:auto;flex:1;margin:0}
.fam-share-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px 22px;margin-top:14px}
.fam-share-row>label{margin:0}
.fam-share-row .opt{display:inline-flex;align-items:center;gap:5px;font-weight:500;color:var(--ink2);cursor:pointer}
.fam-share-row .opt input{width:auto;min-width:0;height:auto;padding:0;margin:0;border:0;border-radius:0;box-shadow:none;transform:scale(1.3);accent-color:var(--brand);cursor:pointer}
.fam-share-row .full{flex-basis:100%;margin:2px 0 0}
.mf-note{margin-top:13px;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 12px}
.cardgrid{display:flex;flex-direction:column}
.cg-row{display:grid;grid-template-columns:minmax(150px,1.5fr) 120px 170px 150px;gap:0 26px;align-items:center;padding:11px 2px;border-bottom:1px solid var(--line)}
.cg-row:last-child{border-bottom:0}
.cg-row.cg-head{padding:0 2px 9px}
.cg-row.cg-head>div{font-size:11.5px;font-weight:700;color:var(--muted)}
.cg-row.cg-head>div:nth-child(2),.cg-row.cg-head>div:nth-child(3){padding-left:6px}
.cg-c1{min-width:0}
.cg-main{font-weight:600;display:flex;align-items:center;gap:6px;white-space:nowrap}
.cg-sub{font-size:11px;color:var(--muted);margin-top:3px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cg-day{font-size:13px;color:var(--ink2);white-space:nowrap;padding-left:6px}
.cg-row input[type=date]{width:100%;max-width:160px;padding:8px 10px 8px 5px;font-size:13px;border:1px solid var(--line2);border-radius:9px;font-family:inherit;background:#fff;box-sizing:border-box}
.cg-row input.cg-rem{width:60px;padding:8px 9px;font-size:13px;border:1px solid var(--line2);border-radius:9px;font-family:inherit}
.cg-acts{display:flex;gap:8px;white-space:nowrap}
.cg-acts .btn{width:auto;margin:0;padding:7px 14px}
.cg-row.cg-void{opacity:.62}
.cg-void-tip{font-size:12px;color:var(--muted);font-weight:600}
.cardfilter{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:0 0 12px;background:var(--surface2);border:1px solid var(--line);border-radius:var(--r-ctl);padding:10px 12px}
.cardfilter select{flex:1 1 130px;min-width:110px;width:auto}
.cardfilter input[type=date]{flex:1 1 130px;min-width:120px;width:auto}
.cardfilter span{color:var(--muted);font-size:13px;flex:0 0 auto}
.cardfilter select,.cardfilter input[type=date]{padding:9px 11px;border:1.5px solid var(--line2);border-radius:var(--r-ctl);font-size:13px;font-family:inherit;background:#fff;box-sizing:border-box}
.cardpager{display:flex;gap:10px;align-items:center;justify-content:center;margin-top:12px;font-size:13px;color:var(--ink2)}
.cardpager .btn{width:auto;margin:0;padding:6px 14px}
.vf-confirm{margin-top:16px;font-size:16px;padding:15px}
.vf-exit{width:100%;margin-top:10px;font-size:16px;padding:15px;background:linear-gradient(135deg,#FF7A5D,#E0533D);color:#fff;box-shadow:0 12px 26px -14px rgba(224,83,61,.5)}
.vf-exit:hover{filter:brightness(1.04)}
table{width:100%;border-collapse:collapse}

@media(max-width:600px){.mf-grid2{grid-template-columns:1fr}.mf-grid4{grid-template-columns:repeat(2,1fr)}.cg-row{grid-template-columns:1fr 1fr;gap:9px 14px}.cg-row.cg-head{display:none}.cg-c1{grid-column:1/-1}.cg-row>div::before{content:attr(data-l);display:block;font-size:10px;color:var(--muted);font-weight:600;margin-bottom:3px}.cg-c1::before{display:none}.cg-row input[type=date]{padding-left:3px;padding-right:3px;max-width:none}}
@media(max-width:520px){.cs-trio{grid-template-columns:repeat(3,1fr);gap:6px}.cs-trig{padding:10px 6px}.cs-trig .cs-tn{font-size:20px}}
@media(max-width:920px){
  .app-shell{flex-direction:column}
  .sidebar{width:100%;height:auto;position:sticky;top:0;z-index:30;flex-direction:column;padding:12px 14px;box-shadow:0 14px 30px -24px rgba(40,20,90,.6)}
  .side-top{justify-content:flex-start}
  .who{display:none}
  .hamburger{display:inline-flex}
  .nav-group{display:none}
  .tabs{flex-direction:row;flex-wrap:wrap;gap:7px;margin-top:0;flex:none;overflow:visible;display:none}
  .tabs::-webkit-scrollbar{height:0}
  .tabs a{white-space:nowrap;padding:8px 13px;font-size:13.5px}
  .tabs a .ic{display:none}
  .side-foot{display:none}
  .sidebar.menu-open{position:fixed;inset:0;width:100%;height:100vh;height:100dvh;z-index:100;overflow-y:auto;padding:16px;border-radius:0}
  .sidebar.menu-open .nav-group{display:block;margin:16px 6px 4px}
  .sidebar.menu-open .tabs{display:flex;flex-direction:column;gap:8px;margin-top:6px}
  .sidebar.menu-open .tabs a{display:flex;align-items:center;gap:13px;width:100%;padding:15px 18px;font-size:16px;border-radius:14px;background:rgba(255,255,255,.08)}
  .sidebar.menu-open .tabs a.on{background:#fff;color:var(--brand)}
  .sidebar.menu-open .tabs a .ic{display:inline-flex;font-size:20px;width:24px;justify-content:center}
  .sidebar.menu-open .who{display:block;margin:14px 2px 2px}
  .sidebar.menu-open .side-foot{display:block;margin-top:12px}
  .content{padding:18px 16px}
  .login-card{padding:32px 24px}
  .toolbar{gap:8px}
  .toolbar .count{margin-left:0}
  .toolbar .search{flex:1 1 100%}
  .toolbar select{flex:1 1 auto;min-width:0}
  .entfilter,.acfilter,.cascade3{width:100%;flex-wrap:wrap;gap:8px}
  .entfilter select,.acfilter select,.cascade3 select{flex:1 1 30%;min-width:0}
}
@media(max-width:560px){.stats{grid-template-columns:1fr 1fr}.content{padding:14px 12px}.sum .box{min-width:0}.sum b{font-size:21px}.stat b{font-size:25px}.prof-assets{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){
  #ops .opsTabs{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;flex-wrap:nowrap}
  #ops .opsTabs button{width:100%;text-align:center;padding:11px 4px;font-size:12.5px;white-space:nowrap}
}

.notice-cfg{margin-top:10px;padding:12px 14px;background:#faf8ff;border:1px solid #ece4ff;border-radius:12px}
.promo-sec-label{font-weight:700;font-size:13px;color:var(--ink);margin-bottom:10px;padding-left:10px;border-left:3px solid var(--brand)}
.promo-qr-card{display:flex;align-items:center;gap:12px;background:#faf8ff;border:1.5px solid #ece4ff;border-radius:14px;padding:15px 16px;cursor:pointer;transition:all .15s}
.promo-qr-card:hover{border-color:var(--brand);background:#f5f1ff;transform:translateY(-1px)}
.promo-qr-arrow{font-size:22px;color:var(--brand);opacity:.6;font-weight:700}
.audit-dot{display:inline-block;min-width:16px;height:16px;line-height:16px;padding:0 4px;margin-left:6px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;border-radius:8px;text-align:center}
.aud-tab{padding:9px 18px;border:1.5px solid #ece4ff;background:#fff;border-radius:10px;font-size:14px;font-weight:600;color:var(--ink2);cursor:pointer}
.aud-tab.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.aud-badge{display:inline-block;min-width:16px;height:16px;line-height:16px;padding:0 4px;margin-left:4px;background:#ef4444;color:#fff;font-size:11px;border-radius:8px}
.aud-tab.on .aud-badge{background:#fff;color:var(--brand)}
.aud-item{border:1px solid #ece4ff;border-radius:12px;padding:14px;margin-bottom:12px;background:#fff}
.aud-item-body{font-size:13px;color:var(--ink2);margin-top:8px;line-height:1.6;background:#faf8ff;padding:8px 10px;border-radius:8px}
.aud-item-acts{display:flex;gap:8px;margin-top:10px;justify-content:flex-end}
.aud-st{font-size:11px;font-weight:600;padding:2px 8px;border-radius:6px;margin-left:6px}
.aud-st.pend{background:#fff4e6;color:#c2410c}
.aud-st.pub{background:#ecfdf5;color:#047857}
.aud-st.rej{background:#fef2f2;color:#dc2626}
.aud-st.off{background:#f1f5f9;color:#64748b}
.sa-sheet{background:#faf8ff;border:1px solid #ece4ff;border-radius:14px;padding:16px 18px}
.sa-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:14px;color:var(--ink)}
.sa-row b{font-size:16px;font-weight:800}
.sa-row.sub{font-size:13px;color:var(--muted)}
.sa-row.total{font-size:15px}
.sa-row.total b{font-size:24px;font-weight:800;color:var(--coral)}
.sa-line{height:1px;background:#ece4ff;margin:8px 0}
.sa-line.strong{height:2px;background:#d8c9ff;margin:10px 0}
.pp-seg{display:flex;gap:8px}
.pp-line{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.pp-label{flex:0 0 32px;font-weight:700;font-size:13px;color:var(--ink)}
.pp-line .pp-seg{flex:1}
.pp-opt{flex:1;padding:10px;border:1.5px solid #e2e8f0;background:#fff;border-radius:10px;font-size:13px;font-weight:600;color:var(--ink2);cursor:pointer;transition:all .12s}
.pp-opt:hover{border-color:var(--brand)}
.pp-opt.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.notice-cfg .nc-switch{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink);font-weight:600;cursor:pointer}
.notice-cfg .nc-switch input{width:18px;height:18px}
.notice-cfg .nc-row{display:flex;gap:12px;margin-top:10px}
.notice-cfg .nc-row>div{flex:1}
.notice-cfg .nc-row label{display:block;font-size:12px;color:var(--ink2);font-weight:600;margin-bottom:4px}
.notice-cfg .nc-row input,.notice-cfg .nc-row select{width:100%;padding:9px 10px;border:1px solid #ece4ff;border-radius:8px;font-size:13.5px;background:#fff}

.hqn-styles{display:flex;gap:10px;margin-top:6px}
.hqn-style{flex:1 1 calc(20% - 8px);min-width:90px;display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;border:1.5px solid #ece4ff;border-radius:12px;cursor:pointer;background:#fff}
.hqn-style.on{border-color:#7c5cff;background:#faf8ff}
.hqn-style .hqn-sw{width:100%;height:36px;border-radius:8px}
.hqn-style span{font-size:13px;font-weight:600;color:var(--ink);text-align:center}
.hqn-style small{display:block;font-size:10.5px;color:var(--muted);font-weight:400;margin-top:2px}
.hqn-ipimg{display:flex;gap:14px;align-items:flex-start;margin-top:6px}
.hqn-ipimg>img{width:74px;height:74px;border-radius:14px;object-fit:cover;background:#f3f0fa;border:1px solid #ece4ff;flex:0 0 auto}
.hqn-ipimg-r{flex:1;min-width:0}
.hqn-ipimg-btns{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

.hqn-checks{display:flex;flex-wrap:wrap;gap:8px;max-height:180px;overflow-y:auto;padding:10px;background:#faf8ff;border:1px solid #ece4ff;border-radius:10px}
.hqn-chk{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--ink);padding:5px 10px;background:#fff;border:1px solid #ece4ff;border-radius:8px;cursor:pointer}
.hqn-chk input{width:15px;height:15px}
.hqn-picked{margin-top:8px}
.hqn-tag{display:inline-block;font-size:12px;color:#7c5cff;background:#f0ecff;border-radius:8px;padding:3px 10px;margin:3px 4px 0 0;cursor:pointer}

.merge-keep{padding:12px 14px;background:#f0f7ff;border:1px solid #cfe4ff;border-radius:10px;font-size:13.5px;color:var(--ink)}
.merge-candi{max-height:220px;overflow-y:auto;margin-top:8px;border:1px solid #ece4ff;border-radius:10px}
.merge-item{padding:10px 12px;font-size:13px;border-bottom:1px solid #f3eefe;cursor:pointer}
.merge-item:last-child{border-bottom:none}
.merge-item:hover{background:#faf8ff}
.merge-item.on{background:#f0ecff;font-weight:600}
.merge-pv{margin-top:14px;padding:14px;background:#fff8f0;border:1px solid #ffe0c0;border-radius:12px}
.merge-pv-h{font-weight:700;margin-bottom:8px;color:#C2410C}

.mg-pick-h{font-weight:700;margin:14px 0 6px;font-size:13.5px}
.mg-rec{padding:8px 12px;background:#fff8e6;border:1px solid #ffe0a3;border-radius:8px;font-size:12.5px;color:#B26A00;margin-bottom:10px}
.mg-cards{display:flex;gap:10px}
.mg-card{flex:1;padding:12px;border:2px solid #ece4ff;border-radius:12px;cursor:pointer;background:#fff;position:relative}
.mg-card.on{border-color:#16a34a;background:#f0fdf4}
.mg-card-h{font-weight:700;font-size:14px;margin-bottom:4px}
.mg-card-no{font-size:12px;color:var(--ink2);margin-bottom:3px}
.mg-card-meta{font-size:11.5px;color:var(--muted)}
.mg-card-bal{font-size:11.5px;color:#7c5cff;margin-top:4px}
.mg-badge{display:inline-block;font-size:10.5px;padding:1px 7px;border-radius:6px;margin-left:4px;vertical-align:middle}
.mg-badge.wx{background:#dcfce7;color:#16a34a}
.mg-badge.man{background:#f1f0f5;color:#888}
.mg-keep-tag{display:block;margin-top:8px;font-size:12px;font-weight:700;color:#16a34a}
.mg-del-tag{display:block;margin-top:8px;font-size:12px;font-weight:600;color:#E2553D}

#opHqNotice .nc-row{display:flex;gap:12px;margin-top:8px}
#opHqNotice .nc-row>div{flex:1}
#opHqNotice .nc-row label{display:block;font-size:12px;color:var(--ink2);font-weight:600;margin-bottom:4px}
#opHqNotice .nc-row input,#opHqNotice .nc-row select{width:100%;padding:10px 12px;border:1px solid #ece4ff;border-radius:8px;font-size:14px;background:#fff;box-sizing:border-box}

.hqn-pv-card{width:280px;margin:20px auto 0;border-radius:20px;overflow:hidden;background:#fff;box-shadow:0 8px 30px rgba(0,0,0,.15)}
.hqn-pv-cloud{height:70px}
.hqn-pv-body{padding:16px 20px 20px;text-align:center}
.hqn-pv-title{font-size:18px;font-weight:800;color:#333}
.hqn-pv-content{font-size:14px;color:#555;line-height:1.6;margin-top:10px;text-align:left;word-break:break-all}
.hqn-pv-content img{max-width:100%}
.hqn-pv-btn{margin-top:16px;padding:11px;border-radius:22px;color:#fff;font-weight:700;font-size:14px}
.hqn-pv-festive .hqn-pv-cloud{background:linear-gradient(160deg,#FF5FBF,#D63AA8)} .hqn-pv-festive .hqn-pv-btn{background:linear-gradient(135deg,#FFB454,#FF8A3D)}
.hqn-pv-important .hqn-pv-cloud{background:linear-gradient(160deg,#4A4570,#2A2545)} .hqn-pv-important .hqn-pv-btn{background:linear-gradient(135deg,#FF5A5A,#E03333)}
.hqn-pv-cool .hqn-pv-cloud{background:linear-gradient(160deg,#FFB454,#FF7A2E)} .hqn-pv-cool .hqn-pv-btn{background:linear-gradient(135deg,#9D5CFF,#7C3AED)}
.hqn-pv-purple .hqn-pv-cloud{background:linear-gradient(160deg,#A78BFA,#7C3AED)} .hqn-pv-purple .hqn-pv-btn{background:linear-gradient(135deg,#FF8A3D,#FF6B2E)}
.hqn-pv-night .hqn-pv-cloud{background:linear-gradient(160deg,#3A3550,#18152A)} .hqn-pv-night .hqn-pv-btn{background:linear-gradient(135deg,#FF4D8D,#E0337A)}
.hqn-pv-meta{margin:16px auto 0;max-width:280px;padding:12px 16px;background:#f7f5ff;border-radius:12px;font-size:12.5px;color:var(--ink2);line-height:1.9}

/* 公告标题预设 chip */
.ttl-chip{padding:6px 14px;border:1.5px solid #ece4ff;border-radius:18px;background:#fff;font-size:13px;color:var(--ink);cursor:pointer}
.ttl-chip.on{border-color:#7c5cff;background:#f0ecff;color:#5b3cff;font-weight:600}
/* 投放范围篮子 */
.bsk-bar{display:flex;gap:8px;margin-bottom:8px}
.bsk-add{flex:1;padding:9px;border:1.5px dashed #c9b8ff;border-radius:10px;background:#faf8ff;color:#7c5cff;font-size:13px;font-weight:600;cursor:pointer}
.bsk-add:hover{background:#f0ecff}
.bsk-list{display:flex;flex-wrap:wrap;gap:8px;min-height:36px;padding:10px;background:#fafafe;border:1px solid #ece4ff;border-radius:10px}
.bsk-tag{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:16px;font-size:12.5px;color:#fff;cursor:pointer}
.bsk-tag.prov{background:#7c5cff} .bsk-tag.city{background:#2E90F5} .bsk-tag.store{background:#16a34a}
.bsk-tag:hover{opacity:.85}
.bsk-picker{margin-top:10px;padding:12px;border:1px solid #ece4ff;border-radius:10px;background:#fff}
.bsk-pk-h{font-weight:600;font-size:13px;margin-bottom:8px}
.bsk-grid{display:flex;flex-wrap:wrap;gap:6px;max-height:200px;overflow-y:auto}
.bsk-opt{padding:5px 12px;border:1px solid #ece4ff;border-radius:14px;font-size:12.5px;cursor:pointer;background:#fff}
.bsk-opt.on{background:#f0ecff;border-color:#7c5cff;color:#5b3cff;font-weight:600}
.bsk-opt:hover{background:#faf8ff}

/* 统一核销确认弹窗 */
.vfc-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.vfc-ic{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex:0 0 auto;padding:0;box-shadow:none}
.vfc-h-txt b{display:block;font-size:17px;color:var(--ink)}
.vfc-h-txt span{font-size:13px;color:var(--muted)}
.vfc-card{margin-bottom:14px}
.vfc-big{border-radius:16px;padding:18px 20px;color:#fff}
.vfc-big.vf-coin{background:linear-gradient(135deg,#FF9466,#FF6B3D)}
.vfc-big.vf-count{background:linear-gradient(135deg,#7c5cff,#5b3cff)}
.vfc-big.vf-growth{background:linear-gradient(135deg,#22C8D6,#0FB6A6)}
.vfc-line{display:flex;justify-content:space-between;align-items:center;font-size:14px;padding:5px 0}
.vfc-line b{font-size:17px;font-weight:700;font-family:var(--disp)}
.vfc-line.dim{opacity:.85;font-size:13px}
.vfc-line.dim b{font-size:14px;font-weight:600}
.vfc-line.big{font-size:15px;font-weight:600}
.vfc-line.big b{font-size:26px}
.vfc-line.big.neg b{color:#FFE08A}
.vfc-div{height:1px;background:rgba(255,255,255,.28);margin:6px 0}
.vfc-row1{font-size:13px;opacity:.9}
.vfc-num{font-size:34px;font-weight:800;font-family:var(--disp);line-height:1.2;margin:2px 0}
.vfc-num i{font-size:16px;font-style:normal;opacity:.9}
.vfc-sub{font-size:12.5px;opacity:.9}
.vfc-tip{font-size:12.5px;line-height:1.7;color:var(--ink2)}
.vfc-t-row{padding:7px 10px;background:#f7f5ff;border-radius:8px;margin-bottom:6px}
.vfc-t-warn{padding:7px 10px;background:#fff3f0;border:1px solid #ffd5c8;border-radius:8px;color:#E2553D;font-weight:600}

#vfConfirmMask .modal-acts{margin-top:16px}
.vfc-tip:not(:empty){margin-bottom:2px}

/* 分页按钮文字不换行(修复"上一页/下一页"竖排) */
.pgnav .btn,.pgnav b{white-space:nowrap;flex:0 0 auto}
.pgnav{flex-wrap:nowrap}
.btn.sm{white-space:nowrap}
/* 卡片弹窗底部分页整体不换行 */
.cardpop-pager,.cp-pager{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;white-space:nowrap}
/* 冻结相关 */
.vf-frozen-badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 9px;border-radius:8px;background:#fde2e2;color:#D92D2D;vertical-align:middle;margin-left:6px}
.vf-frozen-banner{margin-top:12px;margin-bottom:12px;padding:11px 14px;background:#fff3f0;border:1px solid #ffd0c2;border-radius:12px;color:#D92D2D;font-size:13px;line-height:1.6}

#vfConfirmMask .vfc-tip:not(:empty){margin-bottom:14px}
#vfConfirmMask .modal-acts{margin-top:14px !important}

/* 兑换码模块 */
.rdm-rewards{margin-top:12px;padding:14px;background:#faf8ff;border:1px solid #ece4ff;border-radius:14px}
.rdm-rw-h{font-weight:700;font-size:13px;margin-bottom:8px;color:#5b3cff}
.rdm-codes-box{max-height:50vh;overflow-y:auto;display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.rdm-code-item{display:flex;justify-content:space-between;align-items:center;padding:9px 14px;background:#fff;border:1px solid #eee;border-radius:10px;font-family:ui-monospace,Menlo,monospace}
.rdm-code-item.used{background:#f5f5f7;opacity:.7}
.rdm-code-item.void{background:#fff3f0;opacity:.6;text-decoration:line-through}
.rdm-code{font-size:15px;font-weight:700;letter-spacing:1px}
.rdm-code-st{font-size:11px;color:var(--muted);font-family:var(--sans, sans-serif)}

/* 兑换码弹窗: 起止时间并排不撑破 + 按钮与上方留间距 */
#redeemFormMask .nc-row input{ width:100%; min-width:0; box-sizing:border-box; }
#redeemFormMask .modal-acts{ margin-top:18px; }
#redeemFormMask #rdmStoreSearch{ width:100%; box-sizing:border-box; }

/* 门店二维码弹窗 */
.sqr-body{ min-height:120px; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.sqr-img{ width:240px; height:240px; border-radius:12px; box-shadow:0 8px 24px -10px rgba(0,0,0,.2); }
.sqr-store{ margin-top:12px; font-weight:700; font-size:15px; color:var(--ink); }
.sqr-fail{ color:#E2553D; font-weight:600; padding:16px; background:#fff3f0; border:1px solid #ffd5c8; border-radius:10px; }
.shop-qr-sec{ margin-top:8px; padding-top:8px; }

/* 门店二维码弹窗按钮: 防文字竖排 */
#storeQrMask .modal-acts{ flex-wrap:nowrap; }
#storeQrMask .modal-acts .btn{ white-space:nowrap; padding-left:10px; padding-right:10px; font-size:14px; }

/* 兑换码弹窗: 起止时间强制并排(datetime-local 不撑破) */
#redeemFormMask .nc-row{ flex-wrap:nowrap; }
#redeemFormMask .nc-row>div{ min-width:0; flex:1 1 0; }
#redeemFormMask input[type="datetime-local"]{ width:100%; min-width:0; box-sizing:border-box; font-size:13px; }

/* 二维码门店搜索结果 */
.sqr-sresult{ padding:10px 14px; cursor:pointer; font-size:14px; border-bottom:1px solid #f3eeff; }
.sqr-sresult:last-child{ border-bottom:none; }
.sqr-sresult:hover{ background:#f7f3ff; color:#5b3cff; }

/* ===== 分账对账明细 ===== */
.sd-summary{ margin-bottom:14px; }
.sd-formula{ display:flex; align-items:stretch; gap:8px; flex-wrap:wrap; background:linear-gradient(135deg,#faf8ff,#f3eeff); border:1px solid #e9e0ff; border-radius:14px; padding:16px; }
.sd-f-item{ flex:1; min-width:90px; display:flex; flex-direction:column; gap:4px; padding:8px 12px; background:#fff; border-radius:10px; }
.sd-f-item.main{ background:linear-gradient(135deg,#7c5cff,#5b3cff); }
.sd-f-lbl{ font-size:12px; color:var(--muted); }
.sd-f-item.main .sd-f-lbl{ color:rgba(255,255,255,.85); }
.sd-f-val{ font-size:19px; font-weight:800; font-family:var(--disp); color:var(--ink); }
.sd-f-val.neg{ color:#E2553D; }
.sd-f-item.main .sd-f-val{ color:#fff; font-size:22px; }
.sd-f-op{ display:flex; align-items:center; font-size:20px; font-weight:700; color:#b9a7ff; }
.sd-cnt{ margin-top:8px; font-size:13px; color:var(--muted); text-align:right; }
.sd-cnt b{ color:var(--violet); font-size:15px; }

.sd-toolbar{ display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:14px; }
.sd-seg{ display:inline-flex; background:#f1ecff; border-radius:10px; padding:3px; flex:0 0 auto; }
.sd-seg button{ border:none; background:transparent; padding:7px 16px; border-radius:8px; font-size:13px; font-weight:600; color:var(--ink2); cursor:pointer; white-space:nowrap; }
.sd-seg button.on{ background:linear-gradient(135deg,var(--brand-2),var(--brand)); color:#fff; box-shadow:0 2px 8px -3px rgba(124,58,237,.5); }
/* 筛选区: 快捷 + 日期范围 + 查询 + 导出, 紧凑一行 */
.sd-filter{ display:inline-flex; align-items:center; gap:8px; flex-wrap:wrap; }
.sd-quick{ display:inline-flex; background:#f5f3fa; border-radius:9px; padding:3px; gap:2px; }
.sd-qbtn{ border:none; background:transparent; padding:6px 12px; border-radius:7px; font-size:12.5px; font-weight:600; color:var(--ink2); cursor:pointer; white-space:nowrap; }
.sd-qbtn.on{ background:#fff; color:var(--brand); box-shadow:0 1px 4px -1px rgba(124,58,237,.3); }
.sd-range{ display:inline-flex; align-items:center; gap:6px; background:#faf8ff; border:1px solid #ece4ff; border-radius:9px; padding:3px 8px; }
.sd-range input[type=date]{ border:none; background:transparent; padding:5px 2px; font-size:12.5px; color:var(--ink); width:120px; }
.sd-tilde{ color:#b9a7ff; font-weight:700; }
.sd-go{ border:none; background:linear-gradient(135deg,var(--brand-2),var(--brand)); color:#fff; padding:8px 18px; border-radius:9px; font-size:13px; font-weight:700; cursor:pointer; white-space:nowrap; box-shadow:0 6px 14px -8px rgba(124,58,237,.6); }
.sd-go:hover{ filter:brightness(1.05); }
.sd-csv{ border:1.5px solid #e0d6ff; background:#fff; color:var(--brand); padding:7px 14px; border-radius:9px; font-size:13px; font-weight:600; cursor:pointer; white-space:nowrap; }
.sd-csv:hover{ background:#faf8ff; border-color:var(--brand); }

.sd-table-wrap{ flex:1; overflow:auto; border:1px solid var(--line); border-radius:12px; }
.sd-table{ width:100%; border-collapse:collapse; font-size:13px; }
.sd-table thead th{ position:sticky; top:0; background:#f7f5ff; color:#5b4a8a; font-weight:700; padding:7px 8px; text-align:left; white-space:nowrap; border-bottom:2px solid #e9e0ff; z-index:1; }
.sd-table thead th.r{ text-align:right; }
.sd-table thead th.c{ text-align:center; }
.sd-table thead th.hl{ color:#5b3cff; }
.sd-table tbody td{ padding:7px 8px; border-bottom:1px solid #f2eefc; vertical-align:middle; }
.sd-table tbody tr:hover{ background:#faf8ff; }
.sd-item{ max-width:130px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; cursor:default; }
.sd-table td.r{ text-align:right; font-family:var(--disp); white-space:nowrap; }
.sd-badge{ white-space:nowrap; }
.sd-table td.c{ text-align:center; white-space:nowrap; }
.sd-table td.hl{ font-weight:800; color:#5b3cff; font-family:var(--disp); }
.sd-table td.neg{ color:#E2553D; }
.sd-table td.dim{ color:#bbb; }
.sd-table td.nowrap{ white-space:nowrap; }
.sd-sub{ font-size:11px; color:var(--muted); margin-top:2px; }
.sd-txn{ font-size:11px; color:#999; font-family:ui-monospace,Menlo,monospace; max-width:100px; word-break:break-all; }
.sd-badge{ display:inline-block; font-size:10px; padding:1px 6px; border-radius:6px; margin-left:5px; vertical-align:middle; }
.sd-badge.refund{ background:#fff0eb; color:#E2553D; }
.sd-pager{ display:flex; align-items:center; justify-content:center; gap:14px; padding:14px; font-size:13px; color:var(--muted); }

/* 权限模板 chip */
.tpl-chips{ display:flex; gap:8px; flex-wrap:wrap; margin-top:4px; }
.tpl-chip{ padding:7px 18px; border:1.5px solid #ece4ff; border-radius:18px; background:#fff; font-size:13px; color:var(--ink); cursor:pointer; min-width:56px; text-align:center; }
.tpl-chip.on{ border-color:var(--brand); background:#f0ecff; color:#5b3cff; font-weight:700; }
.tpl-chip:hover{ background:#faf8ff; }

/* 修复: 开关行内的状态说明文字(i.hint)不应带上边距, 否则破坏 align-items:center 使开关偏上 */
.feat-sw-card label .hint, label > span .hint, label .sw-toggle + .hint{ margin-top:0 !important; }
.feat-sw-card label{ align-items:center; }
.feat-sw-card label > span{ display:inline-flex; align-items:center; gap:6px; }

/* 全局能力授权勾选 */
.gcap-list{ display:flex; flex-direction:column; gap:8px; margin-top:6px; }
.gcap-item{ display:flex; align-items:flex-start; gap:10px; padding:12px 14px; border:1.5px solid #ece4ff; border-radius:12px; cursor:pointer; }
.gcap-item:hover{ background:#faf8ff; }
.gcap-item input{ margin-top:3px; flex:0 0 auto; width:16px; height:16px; }
.gcap-item span{ display:flex; flex-direction:column; gap:2px; }
.gcap-item b{ font-size:14px; color:var(--ink); }
.gcap-item i{ font-style:normal; font-size:12px; color:var(--muted); line-height:1.5; }

/* 总部公告预览卡(对照前台公告卡, 含IP+云朵+各样式配色) */
.ntcpv-wrap{ padding:80px 0 10px; display:flex; justify-content:center; }
.ntcpv-card{ position:relative; width:300px; border-radius:20px; background:#fff; box-shadow:0 12px 40px rgba(0,0,0,.22); overflow:visible; }
.ntcpv-ip{ position:absolute; top:-58px; left:50%; transform:translateX(-50%); width:120px; height:120px; object-fit:contain; z-index:5; filter:drop-shadow(0 4px 8px rgba(0,0,0,.25)); }
.ntcpv-cloud{ position:relative; height:118px; border-radius:20px 20px 0 0; overflow:hidden; }
.ntcpv-cloud::after{ content:''; position:absolute; left:-6px; right:-6px; bottom:-2px; height:36px; background:#fff; border-radius:50% 50% 0 0/100% 100% 0 0; }
.ntcpv-bub{ position:absolute; border-radius:50%; background:rgba(255,255,255,.5); }
.ntcpv-bub.b1{ width:36px; height:36px; top:16px; left:26px; }
.ntcpv-bub.b2{ width:22px; height:22px; top:40px; right:40px; }
.ntcpv-bub.b3{ width:16px; height:16px; top:14px; right:70px; }
.ntcpv-star{ position:absolute; color:rgba(255,255,255,.85); font-size:18px; }
.ntcpv-star.s1{ top:20px; right:24px; }
.ntcpv-star.s2{ top:54px; left:34px; font-size:13px; }
.ntcpv-body{ position:relative; background:#fff; padding:10px 22px 22px; text-align:center; border-radius:0 0 20px 20px; z-index:2; }
.ntcpv-title{ font-size:19px; font-weight:800; color:#333; }
.ntcpv-content{ font-size:14px; color:#555; line-height:1.7; margin-top:10px; white-space:pre-wrap; word-break:break-all; text-align:left; }
.ntcpv-btn{ margin-top:16px; height:44px; line-height:44px; border-radius:22px; color:#fff; font-size:15px; font-weight:700; box-shadow:0 4px 12px rgba(0,0,0,.15); }
/* 各样式配色(对照前台 ntc-*) */
.ntcpv-festive .ntcpv-cloud{ background:linear-gradient(160deg,#B36BFF,#8A3DEC); } .ntcpv-festive .ntcpv-btn{ background:linear-gradient(135deg,#FFB454,#FF8A3D); }
.ntcpv-important .ntcpv-cloud{ background:linear-gradient(160deg,#4A4570,#2A2545); } .ntcpv-important .ntcpv-btn{ background:linear-gradient(135deg,#FF5A5A,#E03333); }
.ntcpv-cool .ntcpv-cloud{ background:linear-gradient(160deg,#FFB454,#FF7A2E); } .ntcpv-cool .ntcpv-btn{ background:linear-gradient(135deg,#9D5CFF,#7C3AED); }
.ntcpv-purple .ntcpv-cloud{ background:linear-gradient(160deg,#A78BFA,#7C3AED); } .ntcpv-purple .ntcpv-btn{ background:linear-gradient(135deg,#FF8A3D,#FF6B2E); }
.ntcpv-night .ntcpv-cloud{ background:linear-gradient(160deg,#3A3550,#18152A); } .ntcpv-night .ntcpv-btn{ background:linear-gradient(135deg,#FF4D8D,#E0337A); }
.ntcpv-store .ntcpv-cloud{ background:linear-gradient(160deg,#5BB8FF,#2E90F5); } .ntcpv-store .ntcpv-btn{ background:linear-gradient(135deg,#FF9F45,#FF7A2E); }

/* 公告预览弹窗容器(无手机框) */
.ntcpv-modal{ background:#f3f0fa; border-radius:18px; padding:20px; width:380px; max-width:92vw; max-height:88vh; overflow:auto; box-shadow:0 20px 60px rgba(0,0,0,.3); }
.ntcpv-modal-h{ font-size:16px; font-weight:800; color:var(--ink); margin-bottom:6px; }
.ntcpv-modal-h span{ font-weight:400; font-size:12px; color:var(--muted); margin-left:6px; }
.ntcpv-scroll{ }
.ntcpv-scroll .hqn-pv-meta{ margin-top:18px; background:#fff; border-radius:12px; padding:12px 14px; font-size:13px; color:#555; line-height:1.9; }
.ntcpv-scroll .hqn-pv-meta b{ color:#333; }

/* 账号管理筛选框紧凑 */
.acc-toolbar{ flex-wrap:wrap; gap:8px; }
.acc-toolbar .search{ flex:1 1 180px; min-width:160px; padding:8px 12px; font-size:13px; }
.acc-toolbar select{ flex:0 1 auto; width:auto; min-width:96px; padding:8px 10px; font-size:13px; }
.acc-toolbar .count{ flex:0 0 auto; font-size:12px; color:var(--muted); }
.rg-tag{ display:inline-block; padding:2px 9px; border-radius:11px; font-size:12px; }

/* 页面图标管理 */
.ico-tabs{ display:flex; gap:8px; flex-wrap:wrap; }
.ico-tab{ padding:8px 16px; border:1.5px solid #ece4ff; background:#fff; color:var(--muted); border-radius:10px; font-size:13px; font-weight:600; cursor:pointer; }
.ico-tab.on{ background:linear-gradient(135deg,var(--brand-2),var(--brand)); color:#fff; border-color:transparent; }
.ico-row{ display:flex; align-items:center; gap:10px; padding:10px 12px; border:1px solid var(--line); border-radius:12px; margin-bottom:8px; background:#fff; }
.ico-row.off{ opacity:.5; background:#fafafe; }
.ico-handle{ cursor:grab; color:#bbb; font-size:18px; flex:0 0 auto; }
.ico-pv{ width:40px; height:40px; border-radius:11px; flex:0 0 auto; }
.ico-text{ flex:1 1 90px; min-width:70px; padding:7px 10px; border:1px solid var(--line); border-radius:8px; font-size:13px; }
.ico-sel{ flex:0 0 auto; width:auto; min-width:64px; padding:7px 8px; border:1px solid var(--line); border-radius:8px; font-size:13px; }
.ico-sw{ flex:0 0 auto; display:inline-flex; align-items:center; gap:4px; font-size:13px; color:var(--muted); cursor:pointer; }
.ico-move{ flex:0 0 auto; display:inline-flex; gap:3px; }
.ico-move .btn{ padding:5px 9px; min-width:30px; }
/* 图标预览弹窗(模拟小程序) */
.icopv-modal{ background:#f3f0fa; border-radius:18px; padding:20px; width:380px; max-width:92vw; max-height:88vh; overflow:auto; box-shadow:0 20px 60px rgba(0,0,0,.3); }
.icopv-h{ font-size:15px; font-weight:800; color:var(--ink); margin-bottom:14px; text-align:center; }
/* ===== 页面图标预览: 整页还原小程序 首页/我的页 (品牌色取 --violet) ===== */
.ipv-phone{ width:340px; max-width:100%; margin:0 auto; border:8px solid #15102a; border-radius:30px; overflow:hidden; background:#FFF6EA; max-height:66vh; overflow-y:auto; box-shadow:0 18px 50px -16px rgba(0,0,0,.55); }
.ipv-phone::-webkit-scrollbar{ width:0; }
.ipv-page{ font-family:-apple-system,'PingFang SC','Microsoft YaHei',sans-serif; color:#2A1A47; }
.ipv-hero{ position:relative; background:radial-gradient(120% 95% at 80% -10%, #FF8A4D 0%, #FF3D8B 34%, var(--violet,#7A35FF) 66%, #211038 105%); padding:13px 14px 18px; color:#fff; overflow:hidden; }
.ipv-topbar{ display:flex; align-items:center; justify-content:space-between; font-size:11px; }
.ipv-store{ background:rgba(255,255,255,.18); padding:4px 10px; border-radius:999px; }
.ipv-brand{ font-weight:800; font-size:15px; letter-spacing:.5px; }
.ipv-herobody{ display:flex; align-items:center; margin-top:10px; }
.ipv-herocopy{ flex:1; min-width:0; }
.ipv-badge{ display:inline-block; background:rgba(255,255,255,.2); border:1px solid rgba(255,255,255,.35); padding:3px 9px; border-radius:999px; font-size:9.5px; font-weight:700; }
.ipv-htitle{ font-size:23px; font-weight:900; line-height:1.12; margin:8px 0 5px; text-shadow:0 4px 14px rgba(33,16,56,.4); }
.ipv-hsub{ font-size:10.5px; color:rgba(255,255,255,.9); }
.ipv-join{ display:inline-block; margin-top:10px; background:#fff; color:var(--violet,#7A35FF); font-weight:800; font-size:10.5px; padding:6px 13px; border-radius:999px; box-shadow:0 6px 14px -6px rgba(0,0,0,.3); }
.ipv-hvis{ width:90px; height:94px; position:relative; display:flex; align-items:flex-end; justify-content:center; flex:0 0 auto; }
.ipv-eq{ position:absolute; bottom:5px; display:flex; gap:4px; align-items:flex-end; height:52px; opacity:.85; }
.ipv-eq i{ width:6px; border-radius:4px; background:linear-gradient(#10D7C3,#FFC93A); }
.ipv-eq i:nth-child(1){ height:42%; } .ipv-eq i:nth-child(2){ height:72%; } .ipv-eq i:nth-child(3){ height:55%; } .ipv-eq i:nth-child(4){ height:90%; } .ipv-eq i:nth-child(5){ height:35%; }
.ipv-cat{ width:76px; height:76px; border-radius:50%; object-fit:cover; background:#fff; border:3px solid rgba(255,255,255,.85); position:relative; z-index:2; filter:drop-shadow(0 6px 12px rgba(33,16,56,.45)); }
.ipv-cat-ph{ display:flex; align-items:center; justify-content:center; font-size:36px; }
.ipv-mcard{ position:relative; display:flex; margin:-12px 14px 0; background:linear-gradient(135deg,#2A1A47,#3A1D63,#5B2A8F); border-radius:16px; padding:13px 4px 13px 14px; color:#fff; box-shadow:0 12px 30px -16px rgba(42,26,71,.6); }
.ipv-mc-l{ flex:1; border-right:1px dashed rgba(255,255,255,.25); padding-right:8px; }
.ipv-mc-head{ display:flex; align-items:center; gap:8px; }
.ipv-mc-av{ width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,.85); object-fit:cover; border:2px solid rgba(255,255,255,.5); flex:0 0 auto; }
.ipv-mc-name{ font-size:13px; font-weight:800; }
.ipv-mc-tag{ display:inline-block; margin-top:3px; background:linear-gradient(90deg,#FFC93A,#FF6A3D); color:#2A1A47; font-size:9px; font-weight:800; padding:2px 8px; border-radius:999px; }
.ipv-balrow{ display:flex; margin-top:11px; }
.ipv-balrow>div{ flex:1; text-align:center; }
.ipv-balrow b{ display:block; font-size:15px; font-weight:900; }
.ipv-balrow span{ font-size:9px; opacity:.82; }
.ipv-mc-r{ width:56px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; flex:0 0 auto; }
.ipv-mc-qr{ width:34px; height:34px; background:#fff; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:21px; color:#2A1A47; }
.ipv-mc-r span{ font-size:9px; }
.ipv-card{ background:#fff; margin:14px; border-radius:16px; padding:16px 14px 10px; box-shadow:0 12px 30px -20px rgba(42,26,71,.35); }
.ipv-card.menu{ background:#FFFDF8; }
.ipv-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px 12px; }
.ipv-cell{ display:flex; flex-direction:column; align-items:center; text-align:center; }
.ipv-cell img{ width:48px; height:48px; border-radius:13px; box-shadow:0 7px 13px -7px rgba(42,26,71,.55); }
.ipv-cell span{ font-size:11.5px; color:#2A1A47; font-weight:600; margin-top:8px; line-height:1.25; }
.ipv-sec{ font-weight:800; font-size:13px; color:#2A1A47; margin:2px 14px 8px; }
.ipv-news{ display:flex; align-items:center; background:#fff; margin:0 14px 16px; border-radius:14px; padding:8px; box-shadow:0 12px 30px -22px rgba(42,26,71,.4); }
.ipv-news-cov{ width:72px; height:50px; border-radius:10px; background:linear-gradient(135deg,#FFEEDA,#FFD3A6); margin-right:10px; flex:0 0 auto; }
.ipv-news-info b{ display:block; font-size:12px; color:#2A1A47; }
.ipv-news-info span{ font-size:10px; color:#9a93a8; }
.ipv-mhead{ position:relative; background:radial-gradient(120% 90% at 85% 0%, var(--violet2,#9B5BFF) 0%, var(--violet,#7A35FF) 45%, #5B2A8F 100%); padding:14px 16px 18px; color:#fff; overflow:hidden; }
.ipv-mtitle{ font-size:15px; font-weight:800; margin-bottom:12px; }
.ipv-profile{ display:flex; align-items:center; }
.ipv-pav{ width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.85); object-fit:cover; border:2px solid rgba(255,255,255,.45); flex:0 0 auto; }
.ipv-pinfo{ flex:1; margin-left:11px; min-width:0; }
.ipv-pname{ font-size:15px; font-weight:800; }
.ipv-pbadge{ display:inline-block; margin-top:5px; background:rgba(255,255,255,.22); font-size:9.5px; padding:2px 9px; border-radius:999px; }
.ipv-pedit{ width:28px; height:28px; border-radius:50%; background:rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; font-size:13px; flex:0 0 auto; }
.ipv-balcard{ margin-top:14px; background:rgba(255,255,255,.16); border-radius:14px; padding:13px 0 0; overflow:hidden; }
.ipv-balgrid{ display:flex; flex-wrap:wrap; padding:0 4px; }
.ipv-balgrid>div{ width:25%; text-align:center; margin-bottom:12px; }
.ipv-balgrid b{ display:block; font-size:15px; font-weight:900; }
.ipv-balgrid span{ font-size:9px; opacity:.85; }
.ipv-qrbar{ display:flex; align-items:center; justify-content:center; gap:6px; padding:9px; background:rgba(255,255,255,.12); border-top:1px solid rgba(255,255,255,.2); font-size:10.5px; font-weight:600; }
.ipv-tabpage{ min-height:330px; display:flex; flex-direction:column; }
.ipv-tabhero{ background:radial-gradient(120% 95% at 80% -10%, #FF8A4D 0%, #FF3D8B 34%, var(--violet,#7A35FF) 66%, #211038 105%); height:96px; }
.ipv-tabfill{ flex:1; background:#FFF6EA; }
.ipv-tabbar{ display:flex; align-items:flex-end; justify-content:space-around; background:#fff; border-top:1px solid #efe9f7; padding:7px 6px 7px; position:relative; }
.ipv-tab{ flex:1; text-align:center; color:#9a93a8; font-size:10px; display:flex; flex-direction:column; align-items:center; gap:3px; }
.ipv-tab.on{ color:var(--violet,#7A35FF); font-weight:700; }
.ipv-tab img{ width:22px; height:22px; border-radius:7px; }
.ipv-tabph{ width:22px; height:22px; border-radius:7px; background:#d9d2ec; }
.ipv-tabc{ width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--violet2,#9B5BFF),var(--violet,#7A35FF)); color:#fff; display:flex; align-items:center; justify-content:center; font-size:19px; margin:0 6px -4px; box-shadow:0 5px 14px rgba(124,58,237,.45); flex:0 0 auto; }

/* 功能由总部统一开启的正向提示卡(推广/家庭等) */
.feat-locked-tip{ display:flex; align-items:flex-start; gap:12px; padding:16px 18px; background:#f0fdf4; border:1px solid #bbf7d0; border-radius:14px; }
.feat-locked-tip .fl-ic{ flex:0 0 auto; width:28px; height:28px; border-radius:50%; background:#22c55e; color:#fff; display:flex; align-items:center; justify-content:center; font-size:16px; font-weight:700; }
.feat-locked-tip b{ display:block; font-size:14px; color:#15803d; font-weight:700; }
.feat-locked-tip i{ display:block; font-style:normal; font-size:12.5px; color:#16a34a; margin-top:3px; line-height:1.6; }

/* 根治: 功能开关行——强制占满整行宽度并两端对齐, 开关靠右(只命中直接含开关的label, 不影响其他label) */
label:has(> .sw-toggle){ display:flex !important; width:100% !important; box-sizing:border-box !important; align-items:center !important; justify-content:space-between !important; gap:12px; }
label:has(> .sw-toggle) > span:first-child{ flex:1 1 auto; min-width:0; }
label > .sw-toggle{ align-self:center !important; margin:0 !important; flex:0 0 auto !important; }
.sw-toggle + *, * + .sw-toggle{ vertical-align:middle; }

/* 营销中心 列表行内"推荐置顶"星标 */
.row-item .acts a.rec{ color:#e0922b; }
.row-item .acts a.rec:hover{ color:#c2410c; }
.row-item .acts a.rec.on{ color:#f59e0b; font-weight:700; }

/* 分账核心公式卡: 桌面横排(收入 − 退款 − 抽成 = 应结), 手机竖排账单式(避免溢出) */
.settle-fx{display:flex;align-items:center;justify-content:space-between;gap:4px;background:linear-gradient(135deg,var(--brand-2),var(--brand));border-radius:18px;padding:18px 12px;margin-bottom:16px;color:#fff;box-shadow:0 14px 30px -16px rgba(124,58,237,.7)}
.settle-fx .fx-item{flex:1;min-width:0;text-align:center;border-radius:12px;padding:6px 3px}
.settle-fx .fx-item[onclick]{cursor:pointer;transition:background .12s}
.settle-fx .fx-item[onclick]:hover{background:rgba(255,255,255,.16)}
.settle-fx .fx-l{font-size:12px;opacity:.88;margin-bottom:5px;white-space:nowrap}
.settle-fx .fx-tag{font-size:9.5px;opacity:.95;border:1px solid rgba(255,255,255,.5);border-radius:6px;padding:0 4px;line-height:1.5;white-space:nowrap}
.settle-fx .fx-v{font-size:20px;font-weight:800;white-space:nowrap;font-family:var(--disp)}
.settle-fx .fx-op{flex:0 0 auto;font-size:16px;opacity:.7;font-weight:700}
.settle-fx .fx-net{flex:1.12;background:rgba(255,255,255,.18)}
.settle-fx .fx-net .fx-v{font-size:22px}
@media (max-width:560px){
  .settle-fx{flex-direction:column;align-items:stretch;gap:0;padding:14px 16px}
  .settle-fx .fx-item{display:flex;align-items:center;justify-content:space-between;text-align:left;padding:11px 10px;border-radius:10px}
  .settle-fx .fx-l{margin-bottom:0}
  .settle-fx .fx-v{font-size:19px}
  .settle-fx .fx-op{padding:2px 0;text-align:center;font-size:14px}
  .settle-fx .fx-net{margin-top:2px}
  .settle-fx .fx-net .fx-v{font-size:21px}
}

/* ====== 单门店版: 隐藏连锁专属界面 ======
 * 由 00-config.js 在单店模式给 <body> 加 .single-store 类。
 * 凡标了 .chain-only 的元素(分账结算、跨店概览、新增门店、总部公告、内容审核等)
 * 在单店版自动隐藏; 连锁版无此 body 类, 不受影响。 */
body.single-store .chain-only,
html.single-store .chain-only{display:none !important;}

/* 数据保留 / 自动清理 统一卡片 */
.dr-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:11px 0;border-bottom:1px solid var(--line)}
.dr-row:last-of-type{border-bottom:none}
.dr-name{font-weight:700;min-width:64px}
.dr-desc{color:var(--muted);font-size:12px;flex:1;min-width:70px}
.dr-keep input{width:64px}
.dr-act{font-size:12px;color:var(--muted);display:inline-flex;align-items:center;gap:4px;flex-wrap:wrap}

/* ===== 扫码核销页·票券核销(多选弹窗) ===== */
.vf-voucher-bar{display:flex;align-items:center;gap:10px;margin:0 0 14px;padding:12px 14px;border-radius:14px;background:linear-gradient(135deg,#FFF4E6,#FFEAD6);border:1.5px solid #FFD9AE;cursor:pointer;transition:transform .12s,box-shadow .12s}
.vf-voucher-bar:hover{transform:translateY(-1px);box-shadow:0 12px 26px -16px rgba(230,140,40,.5)}
.vf-voucher-bar:active{transform:translateY(0)}
.vf-voucher-bar .vfv-ic{font-size:20px;flex:0 0 auto}
.vf-voucher-bar .vfv-tx{flex:1;font-size:13.5px;font-weight:700;color:#9A5B12}
.vf-voucher-bar .vfv-tx b{font-family:var(--disp);font-size:17px;color:var(--coral);margin:0 2px}
.vf-voucher-bar .vfv-go{font-size:12px;font-weight:700;color:#C2741A;flex:0 0 auto}
.cardpop-h .cp-ic.voucher{background:linear-gradient(135deg,#FF9466,var(--coral))}
.vp-tools{display:flex;align-items:center;justify-content:space-between;margin:4px 0 8px}
.vp-all{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink);cursor:pointer;font-weight:600;white-space:nowrap}
.vp-row{display:flex;align-items:center;gap:10px;padding:11px 8px;border-bottom:1px solid var(--line);cursor:pointer;border-radius:8px}
.vp-row:hover{background:var(--surface-2,#FBFAFE)}
.vp-row.on{background:#FFF7ED}
.vp-ck{width:22px;height:22px;flex:0 0 auto;border:1.5px solid var(--line-2,#E1DAF0);border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:900;background:#fff}
.vp-row.on .vp-ck{background:var(--coral);border-color:var(--coral)}
.vp-ic{font-size:18px;flex:0 0 auto}
.vp-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.vp-tt{font-size:13.5px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vp-sub{font-size:11.5px;color:var(--muted)}
.vp-kind{display:inline-block;font-size:10.5px;font-weight:700;color:var(--coral);background:rgba(255,122,69,.12);border-radius:5px;padding:1px 7px;margin-right:5px}
.vp-kind-ticket{color:#7c5cff;background:rgba(124,92,255,.12)}
.vp-kind-coupon{color:#e8820c;background:rgba(232,130,12,.12)}
.vp-kind-booking{color:#0ea5e9;background:rgba(14,165,233,.12)}
.vp-kind-activity{color:#10b981;background:rgba(16,185,129,.12)}
.vp-tabs{display:flex;flex-wrap:wrap;gap:7px;margin:8px 0 10px}
.vp-tab{font-size:12.5px;font-weight:600;color:var(--ink-2,#564E73);background:var(--surface-2,#FBFAFE);border:1.5px solid var(--line);border-radius:var(--r-pill,999px);padding:5px 12px;cursor:pointer;transition:all .12s;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.vp-tab:hover{border-color:var(--coral)}
.vp-tab.on{background:var(--coral);border-color:var(--coral);color:#fff}
.vp-tab i{font-style:normal;font-size:11px;font-weight:700;opacity:.85}
.vp-tab.on i{opacity:.95}
