*{box-sizing:border-box;margin:0;padding:0}
:root{--left:340px;--right:340px;--gap:12px;--radius:22px;--bg:#151a2c;--panel:rgba(255,255,255,.06);--line:rgba(255,255,255,.09);--muted:rgba(255,255,255,.62);--pink:#ff4d6d;--green:#28cf7a}
html,body{width:100%;height:100%}
body{min-height:100vh;background:radial-gradient(circle at top left,#ff4d6d28,transparent 28%),radial-gradient(circle at bottom right,#6b5cff25,transparent 30%),linear-gradient(135deg,#0b1020,#151a2c 55%,#1b1f35);color:#fff;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;overflow:hidden;font-size:14px}
.app{height:100vh;display:grid;grid-template-columns:minmax(260px,var(--left)) minmax(420px,1fr) minmax(280px,var(--right));gap:var(--gap);padding:var(--gap)}
.panel{min-height:0;display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius);background:var(--panel);border:1px solid var(--line);backdrop-filter:blur(16px);box-shadow:0 10px 28px rgba(0,0,0,.24),inset 0 1px 0 rgba(255,255,255,.04)}
.panel-header{min-height:64px;padding:12px 14px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0}.panel-title{font-size:20px;font-weight:950}.logo{font-size:24px;font-weight:950;letter-spacing:.5px}.logo span{color:var(--pink)}
.panel-body{padding:12px;overflow:auto;flex:1}.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.form-group{margin-bottom:10px}.form-label{font-size:13px;color:var(--muted);margin-bottom:6px}.muted-text{color:var(--muted);font-size:13px;margin-top:3px}.api-status{margin-top:10px;color:var(--muted);font-size:13px}.section-gap,.mini-gap{height:8px}
textarea,input,select{width:100%;border:none;outline:none;border-radius:14px;background:rgba(255,255,255,.08);color:white;padding:10px 12px;font-size:14px;border:1px solid rgba(255,255,255,.08);transition:.18s}textarea{min-height:96px;resize:vertical;line-height:1.5}textarea:focus,input:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(255,77,109,.13)}
.btn{border:none;border-radius:14px;background:linear-gradient(135deg,#ff4d6d,#ff6b81);color:white;font-weight:900;cursor:pointer;padding:10px 13px;font-size:14px;transition:.18s;white-space:nowrap}.btn:hover{transform:translateY(-1px)}.btn:active{transform:scale(.98)}.btn-secondary,.btn-gray{background:rgba(255,255,255,.14)}.btn-green{background:linear-gradient(135deg,#20c975,#35d98b)}
.account-tools{margin-top:8px}.account-item,.match-item{background:rgba(255,255,255,.075);border-radius:16px;padding:11px;margin-bottom:9px;cursor:pointer;border:1px solid transparent}.account-item.active,.match-item.active{border-color:var(--pink);background:rgba(255,77,109,.16)}.account-row{align-items:flex-start}.account-check{width:18px!important;height:18px!important;flex:none;margin-top:3px}.account-main{flex:1;min-width:0}.account-name,.match-name,.user-name{font-weight:950;font-size:16px}.account-sub,.match-sub,.user-sub{margin-top:4px;font-size:13px;color:var(--muted);word-break:break-all}.status-dot{display:inline-block;width:8px;height:8px;background:#32d873;border-radius:50%;margin-right:6px}
.header-actions{justify-content:flex-end}.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:9px;margin-bottom:12px}.stat-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:12px;text-align:center}.stat-num{font-size:26px;font-weight:950;color:#ff6375}.stat-label{margin-top:3px;font-size:13px;color:var(--muted)}.swipe-config{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px;margin-bottom:12px}.toolbar{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-bottom:12px}.toolbar .btn{padding:10px 8px}
.card-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px}.user-card{border-radius:18px;background:rgba(255,255,255,.08);overflow:hidden;border:1px solid rgba(255,255,255,.08)}.user-img{height:200px;background:rgba(255,255,255,.1);background-size:cover;background-position:center}.user-content{padding:11px}.user-location{height:auto!important;-webkit-line-clamp:1!important}.user-bio{margin-top:6px;font-size:13px;line-height:1.42;color:rgba(255,255,255,.68);height:38px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}.tag{display:inline-block;margin-top:8px;padding:5px 9px;border-radius:999px;background:rgba(255,255,255,.13);font-size:12px;color:rgba(255,255,255,.75)}.card-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 11px 11px}.empty{text-align:center;color:rgba(255,255,255,.55);padding:30px 8px;font-size:16px;font-weight:800}
.chat-layout{display:flex;gap:10px;flex-direction:column}.chat-box{display:flex;flex-direction:column;min-height:420px;border-radius:18px;background:rgba(255,255,255,.04);overflow:hidden}.chat-head{padding:12px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}.chat-avatar{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.16);background-size:cover;background-position:center}.chat-title{font-weight:950;font-size:17px}.chat-sub{font-size:12px;color:rgba(255,255,255,.55)}.chat-body{flex:1;overflow-y:auto;padding:12px}.msg{display:flex;margin-bottom:8px}.msg.mine{justify-content:flex-end}.bubble{max-width:78%;padding:9px 11px;border-radius:14px;line-height:1.45;font-size:14px;background:rgba(255,255,255,.12)}.mine .bubble{background:var(--pink)}.chat-input{padding:12px;border-top:1px solid rgba(255,255,255,.08)}.ai-box{margin-top:9px;background:rgba(255,255,255,.08);border-radius:14px;padding:10px}.ai-title{font-size:12px;color:rgba(255,255,255,.58);margin-bottom:6px}.ai-text{font-size:14px;line-height:1.45;color:#fff;min-height:20px}.toast{position:fixed;left:50%;bottom:20px;transform:translateX(-50%);background:rgba(0,0,0,.82);color:white;padding:10px 16px;border-radius:999px;opacity:0;pointer-events:none;transition:.2s;z-index:9999;font-size:14px;font-weight:900}.toast.show{opacity:1}
@media(max-width:1500px){:root{--left:300px;--right:300px}.btn{font-size:13px;padding:9px 11px}.panel-title{font-size:18px}.logo{font-size:22px}.card-list{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}.user-img{height:180px}}
@media(max-width:1150px){body{overflow:auto}.app{height:auto;min-height:100vh;grid-template-columns:1fr;padding:10px}.panel{min-height:360px}.task-header{align-items:flex-start;flex-direction:column}.toolbar{grid-template-columns:repeat(2,1fr)}.stat-grid{grid-template-columns:repeat(2,1fr)}.swipe-config{grid-template-columns:1fr}.card-list{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}
@media(max-width:520px){.app{padding:6px;gap:8px}.panel-header,.panel-body{padding:10px}.row{gap:6px}.btn{width:auto;font-size:12px;padding:8px 10px}.card-list{grid-template-columns:1fr}.user-img{height:260px}.toolbar{grid-template-columns:1fr 1fr}.stat-grid{gap:6px}.stat-card{padding:10px}.stat-num{font-size:22px}}

.chat-back{display:none;padding:8px 10px;border-radius:12px}.chat-layout.chat-open>div:first-child{display:none}.chat-layout.chat-open .chat-back{display:inline-block}.chat-layout.chat-open .chat-box{min-height:calc(100vh - 120px)}

/* 单卡模式：附近的人一个账号只显示一个主卡片 */
.card-list{
  display:flex!important;
  justify-content:center;
  align-items:flex-start;
  padding:6px 0 20px;
}
.single-card-wrap{
  width:min(100%,520px);
  margin:0 auto;
}
.single-card-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
  padding:0 4px;
}
.single-card-account{
  font-size:14px;
  color:rgba(255,255,255,.72);
  font-weight:800;
}
.single-card-count{
  margin-top:3px;
  font-size:13px;
  color:rgba(255,255,255,.5);
}
.single-card-check{
  display:flex;
  align-items:center;
  gap:6px;
  color:rgba(255,255,255,.75);
  font-weight:800;
  white-space:nowrap;
}
.single-card-check input{
  width:20px!important;
  height:20px!important;
}
.single-user-card{
  width:100%;
  border-radius:24px;
  background:rgba(255,255,255,.08);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 18px 45px rgba(0,0,0,.22);
}
.single-user-img{
  width:100%;
  height:520px;
  background:rgba(255,255,255,.1);
  background-size:cover;
  background-position:center;
}
.single-user-content{
  padding:18px;
}
.single-user-name{
  font-size:28px;
  font-weight:950;
  line-height:1.2;
}
.single-user-sub{
  margin-top:8px;
  color:rgba(255,255,255,.62);
  font-size:15px;
}
.single-user-bio{
  margin-top:12px;
  color:rgba(255,255,255,.78);
  line-height:1.55;
  font-size:15px;
  word-break:break-word;
  max-height:72px;
  overflow:auto;
}
.single-user-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:16px;
}
.single-user-actions .btn{
  padding:13px 12px;
  border-radius:16px;
  font-size:16px;
}
.single-user-actions.main-actions .btn{
  font-size:18px;
}
@media(max-width:1500px){.single-user-img{height:430px}.single-card-wrap{width:min(100%,460px)}}
@media(max-width:520px){.single-user-img{height:420px}.single-user-name{font-size:24px}.single-user-actions .btn{font-size:14px}}

/* 多账号显示：勾选几个账号就显示几个账号卡片 */
.card-list{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(360px,1fr));
  gap:14px;
  justify-content:stretch;
  align-items:start;
  padding:6px 0 20px;
}
.account-nearby-card{
  width:100%;
  max-width:520px;
  margin:0 auto;
}
.account-nearby-card .single-user-img{
  height:420px;
}
.empty-account-card{
  min-height:280px;
  border-radius:24px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  padding:14px;
}
.account-card-empty{
  padding:40px 10px;
}
@media(max-width:900px){.card-list{grid-template-columns:1fr}.account-nearby-card{max-width:520px}.account-nearby-card .single-user-img{height:420px}}

/* 无图模式：列表勾选，减少图片资源占用 */
.noimg-account-block{
  width:100%;
  border-radius:18px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  padding:12px;
  overflow:hidden;
}
.noimg-account-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
}
.noimg-mini-actions .btn{padding:7px 10px;font-size:12px;border-radius:10px}
.noimg-user-list{display:flex;flex-direction:column;gap:8px;max-height:calc(100vh - 310px);overflow:auto;padding-right:4px}
.noimg-user-row{
  display:grid;
  grid-template-columns:28px minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  padding:10px;
  border-radius:14px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.07);
}
.noimg-user-row.checked{border-color:var(--pink);background:rgba(255,77,109,.14)}
.noimg-check input{width:20px!important;height:20px!important}
.noimg-user-main{min-width:0;cursor:pointer}
.noimg-user-title{font-size:16px;font-weight:950;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.noimg-user-sub{margin-top:3px;font-size:12px;color:rgba(255,255,255,.55);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.noimg-user-bio{margin-top:4px;font-size:13px;color:rgba(255,255,255,.7);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.noimg-row-actions{display:flex;gap:6px}.noimg-row-actions .btn{padding:7px 10px;font-size:12px;border-radius:10px}
.noimg-empty{padding:24px 8px}
@media(max-width:900px){.noimg-user-row{grid-template-columns:28px minmax(0,1fr)}.noimg-row-actions{grid-column:2;justify-content:flex-start}}

.reply-config{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:8px;font-size:13px;color:rgba(255,255,255,.82)}
.reply-config select{height:34px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:rgba(0,0,0,.25);color:#fff;padding:0 10px;outline:none}
.reply-config input[type=checkbox]{width:16px;height:16px;vertical-align:-3px;margin-right:4px}
.reply-textarea{width:100%;min-height:74px;resize:vertical;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.22);color:#fff;padding:9px 10px;outline:none;box-sizing:border-box;line-height:1.45}
.reply-textarea.is-hidden{display:none}

.match-title-line{display:flex;align-items:center;gap:8px;justify-content:space-between;}
.unread-dot{width:10px;height:10px;border-radius:50%;background:#ff375f;box-shadow:0 0 0 3px rgba(255,55,95,.18);display:inline-block;flex:0 0 auto;}
.match-main{width:100%;}
.match-reply-row{display:flex;align-items:center;gap:10px;margin-top:8px;font-size:12px;color:rgba(255,255,255,.78);}
.match-reply-row label{display:flex;align-items:center;gap:4px;cursor:pointer;}
.match-reply-row input{width:14px;height:14px;accent-color:#2bd47d;}
.reply-state{margin-left:auto;font-size:11px;opacity:.75;}
.match-auto-tools{margin:8px 0 12px;}
.match-auto-tools textarea{width:100%;min-height:68px;resize:vertical;border:1px solid rgba(255,255,255,.12);border-radius:14px;background:rgba(255,255,255,.08);color:#fff;padding:10px 12px;outline:none;}
.match-auto-tools textarea::placeholder{color:rgba(255,255,255,.45);}

.global-ai-tools{margin:8px 0 12px;padding:12px;border-radius:16px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:8px;color:rgba(255,255,255,.9)}
.global-ai-toggle{display:flex;align-items:center;gap:8px;font-weight:800;font-size:15px;cursor:pointer}
.global-ai-toggle input{width:18px;height:18px;accent-color:#2bd47d}
.global-delay-label{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.78)}
.global-delay-label input{width:120px;height:34px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.22);color:#fff;padding:0 10px;outline:none}
.global-ai-tip{font-size:12px;line-height:1.45;color:rgba(255,255,255,.56)}
.profile-modal {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: none;
}

.profile-modal.show {
    display: block;
}

.profile-mask {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(6px);
}

.profile-box {
    position: absolute;
    left: 50%;
    top: 50%;
    width: min(520px, calc(100vw - 28px));
    max-height: 88vh;
    overflow-y: auto;
    transform: translate(-50%, -50%);
    background: #fff;
    border-radius: 24px;
    padding: 18px;
    box-shadow: 0 20px 70px rgba(0,0,0,.28);
}

.profile-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.profile-title {
    font-size: 20px;
    font-weight: 800;
}

.profile-sub {
    font-size: 12px;
    color: #888;
    margin-top: 4px;
}

.profile-close {
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 50%;
    background: #f2f2f2;
    font-size: 24px;
    cursor: pointer;
}

.profile-main {
    display: flex;
    gap: 14px;
    align-items: flex-start;
}

.profile-avatar {
    width: 82px;
    height: 82px;
    border-radius: 20px;
    object-fit: cover;
    background: #eee;
    flex-shrink: 0;
}

.profile-name {
    font-size: 22px;
    font-weight: 800;
    margin-bottom: 6px;
}

.profile-info {
    color: #666;
    font-size: 14px;
    margin-bottom: 8px;
}

.profile-desc {
    font-size: 14px;
    line-height: 1.5;
    color: #333;
    word-break: break-all;
}

.profile-pics {
    margin-top: 16px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
}

.profile-pics img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 14px;
    background: #eee;
}
.account-profile-btn {
    width: 100%;
    margin-bottom: 12px;
}

.profile-extra {
    margin-top: 14px;
    padding: 10px 12px;
    border-radius: 14px;
    background: #f6f7fb;
    color: #555;
    font-size: 13px;
    line-height: 1.7;
    word-break: break-all;
}

.profile-text {
    min-width: 0;
}

.profile-pics img {
    cursor: pointer;
}

.profile-summary-lines {
    margin-bottom: 12px;
    font-weight: 700;
    color: #333;
}

.profile-detail-title {
    margin: 10px 0 8px;
    font-size: 15px;
    font-weight: 800;
    color: #222;
}

.profile-detail-table {
    display: grid;
    gap: 6px;
}

.profile-detail-row {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 8px;
    padding: 7px 8px;
    border-radius: 10px;
    background: #fff;
    border: 1px solid #eceef5;
}

.profile-detail-key {
    color: #777;
    font-weight: 700;
    white-space: nowrap;
}

.profile-detail-val {
    color: #222;
    white-space: pre-wrap;
    word-break: break-all;
}

.profile-raw {
    margin-top: 10px;
    padding: 8px 10px;
    border-radius: 12px;
    background: #fff;
    border: 1px solid #eceef5;
}

.profile-raw summary {
    cursor: pointer;
    font-weight: 800;
    color: #555;
}

.profile-raw pre {
    max-height: 260px;
    overflow: auto;
    margin: 8px 0 0;
    font-size: 12px;
    line-height: 1.45;
    white-space: pre-wrap;
    word-break: break-all;
}

/* v9 紧凑多账号模式：一行尽量显示 6 个账号 */
:root{
  --left:300px;
  --right:300px;
  --gap:10px;
}
.task-panel .panel-body{
  padding:10px;
}
.task-panel .stat-grid{
  gap:7px;
  margin-bottom:8px;
}
.task-panel .stat-card{
  padding:8px 6px;
  border-radius:14px;
}
.task-panel .stat-num{
  font-size:22px;
}
.task-panel .swipe-config{
  gap:7px;
  margin-bottom:8px;
}
.task-panel .toolbar{
  gap:7px;
  margin-bottom:8px;
}
.task-panel .toolbar .btn{
  padding:8px 6px;
  font-size:13px;
}
#nearbyList.card-list{
  grid-template-columns:repeat(auto-fill,minmax(138px,1fr))!important;
  gap:10px!important;
  align-items:start;
}
.account-nearby-card{
  max-width:none!important;
  width:100%!important;
  margin:0!important;
}
.single-card-top{
  margin-bottom:6px!important;
  gap:4px!important;
  padding:0 2px!important;
}
.single-card-account{
  font-size:12px!important;
  line-height:1.2;
  word-break:break-all;
}
.single-card-count{
  font-size:11px!important;
  line-height:1.25;
}
.single-card-check{
  font-size:12px!important;
  gap:3px!important;
}
.single-card-check input{
  width:16px!important;
  height:16px!important;
}
.single-user-card{
  border-radius:16px!important;
  box-shadow:0 10px 24px rgba(0,0,0,.18)!important;
}
.account-nearby-card .single-user-img,
.single-user-img{
  height:155px!important;
}
.single-user-content{
  padding:9px!important;
}
.single-user-name{
  font-size:18px!important;
  line-height:1.18!important;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.single-user-sub{
  margin-top:4px!important;
  font-size:12px!important;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.single-user-bio{
  margin-top:6px!important;
  font-size:12px!important;
  line-height:1.35!important;
  max-height:34px!important;
  overflow:hidden!important;
}
.single-user-content .tag{
  margin-top:6px!important;
  padding:3px 7px!important;
  font-size:11px!important;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
}
.single-user-actions{
  gap:6px!important;
  margin-top:8px!important;
}
.single-user-actions .btn{
  padding:8px 5px!important;
  border-radius:11px!important;
  font-size:12px!important;
}
.single-user-actions.main-actions .btn{
  font-size:13px!important;
  padding:9px 5px!important;
}
.empty-account-card{
  min-height:210px!important;
  padding:10px!important;
  border-radius:16px!important;
}
.account-card-empty{
  padding:26px 6px!important;
  font-size:13px!important;
}
@media(max-width:1500px){
  :root{--left:280px;--right:280px;--gap:8px;}
  #nearbyList.card-list{grid-template-columns:repeat(auto-fill,minmax(132px,1fr))!important;gap:8px!important;}
  .account-nearby-card .single-user-img,.single-user-img{height:145px!important;}
}
@media(max-width:1150px){
  #nearbyList.card-list{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))!important;}
  .account-nearby-card .single-user-img,.single-user-img{height:175px!important;}
}
@media(max-width:520px){
  #nearbyList.card-list{grid-template-columns:1fr!important;}
  .account-nearby-card .single-user-img,.single-user-img{height:360px!important;}
}

/* v10 重新整理：紧凑但不挤，目标一行 6 个账号，功能不删 */
:root{
  --left:260px;
  --right:260px;
  --gap:8px;
  --radius:18px;
}
.app{
  grid-template-columns:minmax(235px,var(--left)) minmax(720px,1fr) minmax(230px,var(--right));
  gap:var(--gap);
  padding:var(--gap);
}
.panel-header{
  min-height:54px;
  padding:10px 12px;
}
.panel-body{
  padding:10px;
}
.logo{font-size:22px;}
.btn{
  border-radius:12px;
  padding:9px 11px;
  font-size:13px;
}
textarea{min-height:78px;}
.account-item,.match-item{
  border-radius:14px;
  padding:9px;
  margin-bottom:7px;
}
.account-name,.match-name,.user-name{font-size:15px;}
.account-sub,.match-sub,.user-sub{font-size:12px;}

.task-panel .panel-header{
  gap:8px;
}
.task-panel .stat-grid{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:7px;
  margin-bottom:8px;
}
.task-panel .stat-card{
  padding:7px 6px;
  border-radius:13px;
}
.task-panel .stat-num{font-size:20px;line-height:1.05;}
.task-panel .stat-label{font-size:12px;}
.task-panel .swipe-config{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:7px;
  margin-bottom:8px;
}
.task-panel .swipe-config input{padding:8px 10px;}
.task-panel .toolbar{
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:7px;
  margin-bottom:10px;
}
.task-panel .toolbar .btn{
  padding:8px 5px;
  font-size:12px;
}

/* 账号卡片：六列小卡，信息浮层，按钮保留 */
#nearbyList.card-list{
  display:grid!important;
  grid-template-columns:repeat(auto-fill,minmax(122px,1fr))!important;
  gap:9px!important;
  justify-content:stretch!important;
  align-items:start!important;
  padding:2px 0 18px!important;
}
.account-nearby-card{
  width:100%!important;
  max-width:none!important;
  margin:0!important;
  min-width:0!important;
}
.single-card-top{
  min-height:34px!important;
  margin-bottom:5px!important;
  padding:0 1px!important;
  gap:4px!important;
  align-items:flex-start!important;
}
.single-card-account{
  font-size:11px!important;
  line-height:1.15!important;
  max-width:94px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.single-card-count{
  margin-top:2px!important;
  font-size:10px!important;
  line-height:1.15!important;
  max-width:96px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.single-card-check{
  font-size:0!important;
  gap:0!important;
  padding-top:1px;
}
.single-card-check::after{
  content:'选';
  font-size:10px;
  color:rgba(255,255,255,.7);
  margin-left:3px;
}
.single-card-check input{
  width:14px!important;
  height:14px!important;
  margin:0!important;
}
.single-user-card{
  position:relative;
  border-radius:14px!important;
  background:rgba(255,255,255,.075)!important;
  border:1px solid rgba(255,255,255,.1)!important;
  box-shadow:0 8px 18px rgba(0,0,0,.18)!important;
  overflow:hidden!important;
}
.account-nearby-card .single-user-img,
.single-user-img{
  height:auto!important;
  aspect-ratio:1/1!important;
  width:100%!important;
  background-size:cover!important;
  background-position:center!important;
}
.single-user-content{
  padding:8px!important;
}
.single-user-name{
  font-size:16px!important;
  line-height:1.12!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.single-user-sub{
  margin-top:3px!important;
  font-size:11px!important;
  line-height:1.2!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.single-user-bio{
  margin-top:5px!important;
  font-size:11px!important;
  line-height:1.28!important;
  height:28px!important;
  max-height:28px!important;
  overflow:hidden!important;
  display:-webkit-box!important;
  -webkit-line-clamp:2!important;
  -webkit-box-orient:vertical!important;
}
.single-user-content .tag{
  margin-top:5px!important;
  padding:2px 6px!important;
  font-size:10px!important;
  max-width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.single-user-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:5px!important;
  margin-top:7px!important;
}
.single-user-actions .btn{
  min-width:0!important;
  padding:7px 3px!important;
  border-radius:10px!important;
  font-size:11px!important;
  line-height:1.1!important;
}
.single-user-actions.main-actions .btn{
  padding:8px 3px!important;
  font-size:12px!important;
}
.empty-account-card{
  min-height:235px!important;
  padding:9px!important;
  border-radius:14px!important;
}
.account-card-empty{
  padding:28px 4px!important;
  font-size:12px!important;
}

/* 右侧聊天保留，但更窄更紧凑 */
.chat-box{min-height:360px;}
.chat-head{padding:9px;}
.chat-avatar{width:38px;height:38px;}
.chat-title{font-size:15px;}
.chat-body{padding:9px;}
.chat-input{padding:9px;}

@media(max-width:1500px){
  :root{--left:248px;--right:248px;--gap:7px;}
  .app{grid-template-columns:minmax(225px,var(--left)) minmax(690px,1fr) minmax(220px,var(--right));}
  #nearbyList.card-list{grid-template-columns:repeat(auto-fill,minmax(116px,1fr))!important;gap:8px!important;}
  .single-user-name{font-size:15px!important;}
  .single-user-actions .btn{font-size:10.5px!important;}
}
@media(max-width:1280px){
  :root{--left:230px;--right:220px;--gap:6px;}
  .app{grid-template-columns:minmax(210px,var(--left)) minmax(660px,1fr) minmax(200px,var(--right));}
  #nearbyList.card-list{grid-template-columns:repeat(auto-fill,minmax(108px,1fr))!important;gap:7px!important;}
}
@media(max-width:1150px){
  body{overflow:auto!important;}
  .app{height:auto;min-height:100vh;grid-template-columns:1fr!important;padding:8px;}
  #nearbyList.card-list{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))!important;}
  .task-panel .toolbar{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:520px){
  #nearbyList.card-list{grid-template-columns:1fr!important;}
  .account-nearby-card .single-user-img,.single-user-img{aspect-ratio:auto!important;height:360px!important;}
  .single-card-account,.single-card-count{max-width:none;}
}

/* v11 自适应卡片布局：卡片放大，宽屏自动多列，窄屏自动少列 */
#nearbyList.card-list{
  display:grid!important;
  grid-template-columns:repeat(auto-fit, minmax(clamp(180px, 15.5vw, 230px), 1fr))!important;
  gap:14px!important;
  align-items:start!important;
  justify-content:stretch!important;
  padding:6px 0 22px!important;
}
.account-nearby-card{
  width:100%!important;
  max-width:none!important;
  min-width:0!important;
  margin:0!important;
}
.single-card-top{
  min-height:42px!important;
  margin-bottom:8px!important;
  padding:0 2px!important;
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:8px!important;
}
.single-card-account{
  font-size:14px!important;
  line-height:1.2!important;
  max-width:150px!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.single-card-count{
  margin-top:3px!important;
  font-size:12px!important;
  line-height:1.2!important;
  max-width:160px!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.single-card-check{
  font-size:12px!important;
  gap:4px!important;
  padding-top:2px!important;
  white-space:nowrap!important;
}
.single-card-check::after{content:none!important;}
.single-card-check input{
  width:17px!important;
  height:17px!important;
}
.single-user-card{
  border-radius:18px!important;
  overflow:hidden!important;
  background:rgba(255,255,255,.08)!important;
  border:1px solid rgba(255,255,255,.11)!important;
  box-shadow:0 12px 26px rgba(0,0,0,.22)!important;
}
.account-nearby-card .single-user-img,
.single-user-img{
  width:100%!important;
  height:auto!important;
  aspect-ratio:4/5!important;
  background-size:cover!important;
  background-position:center!important;
}
.single-user-content{
  padding:12px!important;
}
.single-user-name{
  font-size:22px!important;
  line-height:1.12!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.single-user-sub{
  margin-top:5px!important;
  font-size:13px!important;
  line-height:1.25!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.single-user-bio{
  margin-top:8px!important;
  font-size:13px!important;
  line-height:1.35!important;
  height:36px!important;
  max-height:36px!important;
  overflow:hidden!important;
  display:-webkit-box!important;
  -webkit-line-clamp:2!important;
  -webkit-box-orient:vertical!important;
}
.single-user-content .tag{
  margin-top:8px!important;
  padding:4px 8px!important;
  font-size:12px!important;
  max-width:100%!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.single-user-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  margin-top:10px!important;
}
.single-user-actions .btn{
  min-width:0!important;
  padding:9px 6px!important;
  border-radius:12px!important;
  font-size:13px!important;
  line-height:1.1!important;
}
.single-user-actions.main-actions .btn{
  padding:11px 6px!important;
  font-size:14px!important;
}
.empty-account-card{
  min-height:330px!important;
  padding:12px!important;
  border-radius:18px!important;
}
.account-card-empty{
  padding:70px 10px!important;
  font-size:14px!important;
  line-height:1.45!important;
}
.account-card-empty .btn{
  margin-top:10px!important;
  padding:10px 14px!important;
  font-size:14px!important;
}
@media(max-width:1600px){
  #nearbyList.card-list{grid-template-columns:repeat(auto-fit, minmax(clamp(170px, 16vw, 215px), 1fr))!important;gap:12px!important;}
  .single-user-name{font-size:20px!important;}
  .single-user-actions.main-actions .btn{font-size:13px!important;}
}
@media(max-width:1280px){
  #nearbyList.card-list{grid-template-columns:repeat(auto-fit, minmax(170px, 1fr))!important;gap:12px!important;}
}
@media(max-width:900px){
  #nearbyList.card-list{grid-template-columns:repeat(auto-fit, minmax(210px, 1fr))!important;}
}
@media(max-width:520px){
  #nearbyList.card-list{grid-template-columns:1fr!important;}
  .account-nearby-card .single-user-img,.single-user-img{aspect-ratio:4/5!important;height:auto!important;}
  .single-card-account,.single-card-count{max-width:none!important;}
}

/* v12 自动打招呼 / 自动回复配置 */
.auto-reply-config{gap:10px!important;}
.auto-config-title{font-weight:950;font-size:15px;color:#fff;margin-bottom:2px;}
.auto-mode-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:end;}
.auto-mode-row select{height:34px;min-width:120px;padding:0 10px;border-radius:10px;background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.12);color:#fff;}
.auto-small-label{font-size:12px;color:rgba(255,255,255,.62);font-weight:800;margin-top:2px;}
.auto-textarea{width:100%;min-height:64px!important;max-height:130px;resize:vertical;border-radius:12px!important;background:rgba(0,0,0,.22)!important;border:1px solid rgba(255,255,255,.12)!important;color:#fff!important;padding:9px 10px!important;line-height:1.45!important;font-size:13px!important;}
.auto-textarea::placeholder{color:rgba(255,255,255,.38);}
@media (max-width:900px){.auto-mode-row{grid-template-columns:1fr;}}



/* =========================
   v14 卡片尺寸优化
========================= */

.card-list{
    display:grid !important;
    grid-template-columns:repeat(auto-fill,minmax(260px,1fr)) !important;
    gap:14px !important;
    align-items:start !important;
}

.user-card,
.single-card,
.noimg-account-block{
    width:100% !important;
    max-width:320px !important;
    margin:0 auto !important;
    border-radius:20px !important;
    overflow:hidden !important;
}

.user-card img,
.single-card img{
    width:100% !important;
    height:360px !important;
    object-fit:cover !important;
    display:block !important;
}

.user-card-body,
.single-card-body{
    padding:14px !important;
}

.user-card .row,
.single-card .row{
    gap:8px !important;
}

@media (max-width: 1400px){
    .card-list{
        grid-template-columns:repeat(auto-fill,minmax(240px,1fr)) !important;
    }
}

@media (max-width: 900px){
    .card-list{
        grid-template-columns:repeat(auto-fill,minmax(220px,1fr)) !important;
    }

    .user-card img,
    .single-card img{
        height:300px !important;
    }
}


/* =========================
   v15 重点修复：滑动卡片不要单张铺满
   只针对中间“附近的人/滑动卡片”
========================= */

#nearbyList.card-list{
    display:grid !important;
    grid-template-columns:repeat(auto-fill, minmax(210px, 230px)) !important;
    gap:14px !important;
    justify-content:start !important;
    align-items:start !important;
    padding:8px 4px 24px !important;
}

/* 每个账号的滑动卡片固定在小卡片宽度，不再 100% 撑满 */
#nearbyList .account-nearby-card{
    width:230px !important;
    max-width:230px !important;
    min-width:0 !important;
    margin:0 !important;
}

/* 卡片主体 */
#nearbyList .single-user-card{
    width:100% !important;
    border-radius:16px !important;
    overflow:hidden !important;
}

/* 滑动卡片图片尺寸 */
#nearbyList .account-nearby-card .single-user-img,
#nearbyList .single-user-img{
    width:100% !important;
    height:245px !important;
    aspect-ratio:auto !important;
    background-size:cover !important;
    background-position:center center !important;
}

/* 上方账号文字缩短 */
#nearbyList .single-card-top{
    min-height:36px !important;
    margin-bottom:6px !important;
    gap:6px !important;
}

#nearbyList .single-card-account{
    font-size:13px !important;
    max-width:145px !important;
}

#nearbyList .single-card-count{
    font-size:11px !important;
    max-width:145px !important;
}

/* 内容区压缩 */
#nearbyList .single-user-content{
    padding:10px !important;
}

#nearbyList .single-user-name{
    font-size:20px !important;
    line-height:1.1 !important;
}

#nearbyList .single-user-sub{
    font-size:12px !important;
    margin-top:4px !important;
}

#nearbyList .single-user-bio{
    font-size:12px !important;
    line-height:1.3 !important;
    height:32px !important;
    max-height:32px !important;
    margin-top:6px !important;
}

#nearbyList .single-user-content .tag{
    font-size:11px !important;
    padding:3px 7px !important;
    margin-top:6px !important;
}

/* 按钮也缩小 */
#nearbyList .single-user-actions{
    gap:6px !important;
    margin-top:8px !important;
}

#nearbyList .single-user-actions .btn{
    padding:7px 5px !important;
    font-size:12px !important;
    border-radius:10px !important;
}

#nearbyList .single-user-actions.main-actions .btn{
    padding:9px 5px !important;
    font-size:13px !important;
}

/* 空账号卡片也别太大 */
#nearbyList .empty-account-card{
    width:230px !important;
    max-width:230px !important;
    min-height:245px !important;
    padding:10px !important;
}

#nearbyList .account-card-empty{
    padding:45px 8px !important;
    font-size:13px !important;
}

/* 中等屏幕稍微再小 */
@media(max-width:1400px){
    #nearbyList.card-list{
        grid-template-columns:repeat(auto-fill, minmax(190px, 210px)) !important;
        gap:12px !important;
    }

    #nearbyList .account-nearby-card,
    #nearbyList .empty-account-card{
        width:210px !important;
        max-width:210px !important;
    }

    #nearbyList .account-nearby-card .single-user-img,
    #nearbyList .single-user-img{
        height:220px !important;
    }
}

/* 小屏幕手机再自适应 */
@media(max-width:700px){
    #nearbyList.card-list{
        grid-template-columns:repeat(auto-fill, minmax(160px, 1fr)) !important;
        justify-content:stretch !important;
    }

    #nearbyList .account-nearby-card,
    #nearbyList .empty-account-card{
        width:100% !important;
        max-width:none !important;
    }

    #nearbyList .account-nearby-card .single-user-img,
    #nearbyList .single-user-img{
        height:220px !important;
    }
}


/* =========================
   v16 修复：右侧匹配 / 聊天 / 自动回复重新整理
   只改右侧区域，不影响滑动卡片功能
========================= */

/* 右侧面板加宽，避免自动回复区域挤在一起 */
:root{
    --right:460px !important;
}

.app{
    grid-template-columns:minmax(280px,var(--left)) minmax(420px,1fr) minmax(420px,var(--right)) !important;
}

/* 右侧整体 */
.chat-panel-wrap{
    min-width:420px !important;
}

.chat-panel-wrap .panel-header{
    min-height:58px !important;
    padding:12px 14px !important;
}

.chat-panel-wrap .panel-body.chat-layout{
    padding:12px !important;
    display:flex !important;
    flex-direction:column !important;
    gap:12px !important;
    overflow:hidden !important;
}

/* 自动回复配置区：更清晰，不占太多高度 */
.chat-panel-wrap .global-ai-tools.auto-reply-config{
    margin:0 0 10px 0 !important;
    padding:12px !important;
    border-radius:18px !important;
    background:rgba(255,255,255,.075) !important;
    border:1px solid rgba(255,255,255,.10) !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.04) !important;
    display:flex !important;
    flex-direction:column !important;
    gap:9px !important;
}

.chat-panel-wrap .auto-config-title{
    font-size:15px !important;
    font-weight:950 !important;
    color:#fff !important;
    line-height:1.2 !important;
    margin:0 0 2px 0 !important;
}

/* 开关行 */
.chat-panel-wrap .global-ai-toggle{
    min-height:28px !important;
    display:flex !important;
    align-items:center !important;
    gap:8px !important;
    font-size:13px !important;
    font-weight:850 !important;
    color:rgba(255,255,255,.90) !important;
    margin:0 !important;
}

.chat-panel-wrap .global-ai-toggle input{
    width:17px !important;
    height:17px !important;
    flex:0 0 auto !important;
}

/* 回复方式 + 延迟一行排开 */
.chat-panel-wrap .auto-mode-row{
    display:grid !important;
    grid-template-columns:1fr 145px !important;
    gap:8px !important;
    align-items:end !important;
}

.chat-panel-wrap .global-delay-label{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:5px !important;
    font-size:12px !important;
    color:rgba(255,255,255,.70) !important;
    font-weight:800 !important;
    margin:0 !important;
}

.chat-panel-wrap .global-delay-label select,
.chat-panel-wrap .global-delay-label input{
    width:100% !important;
    height:34px !important;
    border-radius:11px !important;
    padding:0 10px !important;
    font-size:13px !important;
}

/* 小标题 */
.chat-panel-wrap .auto-small-label{
    font-size:12px !important;
    line-height:1.25 !important;
    color:rgba(255,255,255,.62) !important;
    font-weight:850 !important;
    margin-top:2px !important;
}

/* 文本框压缩但不难用 */
.chat-panel-wrap .auto-textarea,
.chat-panel-wrap .reply-textarea,
.chat-panel-wrap .match-auto-tools textarea{
    width:100% !important;
    min-height:58px !important;
    max-height:118px !important;
    resize:vertical !important;
    border-radius:13px !important;
    padding:9px 10px !important;
    font-size:13px !important;
    line-height:1.42 !important;
    background:rgba(0,0,0,.22) !important;
    border:1px solid rgba(255,255,255,.12) !important;
    color:#fff !important;
    box-sizing:border-box !important;
}

.chat-panel-wrap #greetText{
    min-height:54px !important;
}

.chat-panel-wrap #keywordReplyRules{
    min-height:72px !important;
}

.chat-panel-wrap #fallbackReplyText{
    min-height:58px !important;
}

.chat-panel-wrap .global-ai-tip{
    font-size:11px !important;
    line-height:1.4 !important;
    color:rgba(255,255,255,.50) !important;
}

/* 匹配列表独立滚动，别把聊天框挤下去 */
.chat-panel-wrap #matchList{
    max-height:210px !important;
    overflow-y:auto !important;
    padding-right:3px !important;
    margin-top:8px !important;
}

.chat-panel-wrap .match-item{
    padding:10px !important;
    border-radius:15px !important;
    margin-bottom:8px !important;
}

.chat-panel-wrap .match-name{
    font-size:15px !important;
}

.chat-panel-wrap .match-sub{
    font-size:12px !important;
    line-height:1.35 !important;
}

/* 聊天框保持可用高度 */
.chat-panel-wrap .chat-box{
    flex:1 1 auto !important;
    min-height:330px !important;
    border-radius:18px !important;
}

.chat-panel-wrap .chat-head{
    padding:10px 12px !important;
}

.chat-panel-wrap .chat-avatar{
    width:42px !important;
    height:42px !important;
}

.chat-panel-wrap .chat-title{
    font-size:16px !important;
}

.chat-panel-wrap .chat-sub{
    font-size:12px !important;
}

.chat-panel-wrap .chat-body{
    min-height:180px !important;
    padding:10px !important;
}

.chat-panel-wrap .chat-input{
    padding:10px !important;
}

.chat-panel-wrap .chat-input .row{
    display:grid !important;
    grid-template-columns:1fr auto !important;
    gap:8px !important;
}

.chat-panel-wrap .chat-input input{
    min-width:0 !important;
}

.chat-panel-wrap .chat-input .btn{
    padding:9px 14px !important;
}

/* 大屏幕右侧更舒服 */
@media (min-width:1700px){
    :root{
        --right:500px !important;
    }

    .app{
        grid-template-columns:minmax(300px,var(--left)) minmax(520px,1fr) minmax(460px,var(--right)) !important;
    }

    .chat-panel-wrap{
        min-width:460px !important;
    }
}

/* 中屏不要强行挤爆，右侧变 400 */
@media (max-width:1400px){
    :root{
        --right:400px !important;
        --left:300px !important;
    }

    .app{
        grid-template-columns:minmax(260px,var(--left)) minmax(360px,1fr) minmax(380px,var(--right)) !important;
    }

    .chat-panel-wrap{
        min-width:380px !important;
    }

    .chat-panel-wrap .auto-mode-row{
        grid-template-columns:1fr 130px !important;
    }
}

/* 窄屏自动上下排列 */
@media (max-width:1150px){
    .app{
        grid-template-columns:1fr !important;
        height:auto !important;
        min-height:100vh !important;
        overflow:visible !important;
    }

    body{
        overflow:auto !important;
    }

    .chat-panel-wrap{
        min-width:0 !important;
    }

    .chat-panel-wrap .panel-body.chat-layout{
        overflow:visible !important;
    }

    .chat-panel-wrap #matchList{
        max-height:260px !important;
    }
}

@media (max-width:560px){
    .chat-panel-wrap .auto-mode-row{
        grid-template-columns:1fr !important;
    }

    .chat-panel-wrap .chat-input .row{
        grid-template-columns:1fr !important;
    }
}


/* =========================
   v17 自动回复流程小优化
========================= */
.chat-panel-wrap #noMessageAction{
    width:100% !important;
    height:34px !important;
    border-radius:11px !important;
    padding:0 10px !important;
    font-size:13px !important;
}
/* 回复方式下拉框 */
#noMessageAction,
#autoReplyMode{
    background:#2b3042 !important;

    color:#fff !important;

    border:1px solid rgba(255,255,255,.12) !important;
}

/* 下拉项 */
#noMessageAction option,
#autoReplyMode option{
    background:#2b3042 !important;

    color:#fff !important;
}

/* =========================
   v22 右侧高级选择框：聊天 / 自动回复 / AI回复
========================= */

.right-mode-select{
    margin-bottom:12px !important;
    padding:10px !important;
    border-radius:16px !important;
    background:rgba(255,255,255,.06) !important;
    border:1px solid rgba(255,255,255,.10) !important;
}

#rightPanelMode,
#noMessageAction,
#autoReplyMode,
#aiReplyMaxCount{
    width:100% !important;
    height:38px !important;
    border-radius:12px !important;
    padding:0 12px !important;
    background:#2b3042 !important;
    color:#fff !important;
    border:1px solid rgba(255,255,255,.14) !important;
    outline:none !important;
}

#rightPanelMode option,
#noMessageAction option,
#autoReplyMode option{
    background:#2b3042 !important;
    color:#fff !important;
}

.right-pane{
    display:none !important;
}

.right-pane.active{
    display:block !important;
}

#rightChatPane{
    min-height:160px !important;
}

#rightAutoPane .global-ai-tools,
#rightAiPane .global-ai-tools{
    margin-top:0 !important;
}

#rightAiPane .btn{
    width:100% !important;
    margin-top:10px !important;
}

.chat-panel-wrap .panel-body.chat-layout{
    gap:10px !important;
}

.chat-panel-wrap #matchList{
    max-height:360px !important;
    overflow-y:auto !important;
}


/* =========================
   v23 顶部点击切换 TAB
========================= */

.right-top-tabs{
    display:flex !important;
    gap:10px !important;
    margin-bottom:14px !important;
}

.right-top-tab{
    flex:1 !important;
    height:42px !important;
    border:none !important;
    border-radius:14px !important;
    background:rgba(255,255,255,.07) !important;
    color:rgba(255,255,255,.76) !important;
    font-size:14px !important;
    font-weight:900 !important;
    cursor:pointer !important;
    transition:.18s !important;
}

.right-top-tab:hover{
    transform:translateY(-1px) !important;
}

.right-top-tab.active{
    background:linear-gradient(135deg,#ff5f8f,#ff7ca8) !important;
    color:#fff !important;
    box-shadow:0 8px 24px rgba(255,95,143,.24) !important;
}


/* =========================
   v24 单个账号删除
========================= */
.account-row{
    align-items:center !important;
}

.account-main{
    flex:1 !important;
    min-width:0 !important;
}

.account-del-btn{
    flex:0 0 auto !important;
    border:none !important;
    border-radius:10px !important;
    padding:7px 9px !important;
    background:rgba(255,77,109,.16) !important;
    color:#ff8ba1 !important;
    font-size:12px !important;
    font-weight:900 !important;
    cursor:pointer !important;
}

.account-del-btn:hover{
    background:#ff4d6d !important;
    color:#fff !important;
}


/* =========================
   v28 右侧聊天布局：左匹配，右聊天，防叠层
========================= */

.chat-main-header{
    display:flex !important;
    justify-content:space-between !important;
    align-items:center !important;
}

.chat-panel-wrap .panel-body.chat-layout{
    display:flex !important;
    flex-direction:column !important;
    gap:14px !important;
    overflow:hidden !important;
    min-height:0 !important;
}

.chat-top-tabs{
    display:flex !important;
    gap:12px !important;
    padding-bottom:10px !important;
    border-bottom:1px solid rgba(255,255,255,.08) !important;
}

.chat-top-tab{
    flex:1 !important;
    height:42px !important;
    border:none !important;
    border-radius:14px !important;
    background:rgba(255,255,255,.07) !important;
    color:rgba(255,255,255,.75) !important;
    font-size:14px !important;
    font-weight:950 !important;
    cursor:pointer !important;
}

.chat-top-tab.active{
    background:linear-gradient(135deg,#ff4d75,#ff6f9a) !important;
    color:#fff !important;
    box-shadow:0 10px 26px rgba(255,77,117,.25) !important;
}

.right-pane{
    display:none !important;
    min-height:0 !important;
}

.right-pane.active{
    display:block !important;
    min-height:0 !important;
}

#rightChatPane.active{
    flex:1 1 auto !important;
    min-height:0 !important;
}

.chat-two-col{
    display:grid !important;
    grid-template-columns:310px minmax(420px,1fr) !important;
    gap:14px !important;
    min-height:0 !important;
    height:calc(100vh - 150px) !important;
}

.match-side{
    display:flex !important;
    flex-direction:column !important;
    min-height:0 !important;
    overflow:hidden !important;
    border-radius:20px !important;
    background:rgba(255,255,255,.045) !important;
    border:1px solid rgba(255,255,255,.10) !important;
    padding:12px !important;
}

.match-side-head{
    flex:0 0 auto !important;
    display:flex !important;
    justify-content:space-between !important;
    align-items:center !important;
    padding-bottom:10px !important;
}

.match-side-title{
    font-size:18px !important;
    font-weight:950 !important;
    color:#fff !important;
}

.match-side-sub{
    font-size:12px !important;
    color:rgba(255,255,255,.62) !important;
    margin-top:3px !important;
}

.match-side #matchList{
    flex:1 1 auto !important;
    min-height:0 !important;
    overflow-y:auto !important;
    display:flex !important;
    flex-direction:column !important;
    gap:10px !important;
    padding-right:4px !important;
    max-height:none !important;
}

.match-refresh-btn{
    flex:0 0 auto !important;
    width:100% !important;
    margin-top:12px !important;
}

.match-side .match-item{
    margin:0 !important;
    padding:14px !important;
    border-radius:16px !important;
    background:rgba(255,255,255,.06) !important;
    border:1px solid transparent !important;
}

.match-side .match-item.active{
    border-color:#ff4d75 !important;
    box-shadow:0 0 0 1px rgba(255,77,117,.28) inset !important;
}

.match-side .match-name{
    font-size:18px !important;
    font-weight:950 !important;
    color:#fff !important;
}

.match-side .match-sub{
    margin-top:6px !important;
    font-size:13px !important;
    color:rgba(255,255,255,.68) !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
}

.chat-two-col .chat-box{
    position:relative !important;
    display:flex !important;
    flex-direction:column !important;
    min-height:0 !important;
    height:100% !important;
    border-radius:20px !important;
    background:rgba(255,255,255,.045) !important;
    border:1px solid rgba(255,255,255,.10) !important;
    overflow:hidden !important;
}

.chat-two-col .chat-head{
    flex:0 0 auto !important;
    padding:16px 18px !important;
    border-bottom:1px solid rgba(255,255,255,.08) !important;
    background:rgba(255,255,255,.025) !important;
}

.chat-two-col .chat-avatar{
    width:52px !important;
    height:52px !important;
    border-radius:50% !important;
}

.chat-user-meta{
    min-width:0 !important;
}

.chat-two-col .chat-title{
    font-size:22px !important;
    font-weight:950 !important;
}

.chat-two-col .chat-sub{
    font-size:13px !important;
    color:rgba(255,255,255,.60) !important;
}

.chat-two-col .chat-body{
    flex:1 1 auto !important;
    min-height:0 !important;
    overflow-y:auto !important;
    padding:20px !important;
    background:rgba(0,0,0,.08) !important;
}

.chat-two-col .chat-input{
    flex:0 0 auto !important;
    padding:14px 16px !important;
    border-top:1px solid rgba(255,255,255,.08) !important;
    background:rgba(255,255,255,.025) !important;
}

.chat-two-col .chat-input .row{
    display:grid !important;
    grid-template-columns:1fr auto !important;
    gap:10px !important;
}

.chat-two-col .chat-input input{
    min-width:0 !important;
    height:46px !important;
    border-radius:15px !important;
}

.chat-two-col .chat-input .btn{
    height:46px !important;
    min-width:78px !important;
    border-radius:15px !important;
}

.chat-two-col .msg{
    margin:12px 0 !important;
    display:flex !important;
}

.chat-two-col .msg.mine{
    justify-content:flex-end !important;
}

.chat-two-col .bubble{
    max-width:72% !important;
    padding:12px 16px !important;
    border-radius:18px !important;
    font-size:15px !important;
    line-height:1.55 !important;
}

.chat-two-col .msg.mine .bubble{
    background:#ff4d75 !important;
    color:#fff !important;
    border-bottom-right-radius:8px !important;
}

.chat-two-col .msg:not(.mine) .bubble{
    background:rgba(255,255,255,.10) !important;
    color:#fff !important;
    border-bottom-left-radius:8px !important;
}

#rightAutoPane.active,
#rightAiPane.active{
    display:block !important;
    overflow-y:auto !important;
    max-height:calc(100vh - 150px) !important;
}

#rightAutoPane .global-ai-tools,
#rightAiPane .global-ai-tools{
    max-width:720px !important;
    margin:0 auto !important;
}

#noMessageAction,
#autoReplyMode,
#aiReplyMaxCount{
    background:#2b3042 !important;
    color:#fff !important;
    border:1px solid rgba(255,255,255,.14) !important;
}

#noMessageAction option,
#autoReplyMode option{
    background:#2b3042 !important;
    color:#fff !important;
}

@media(max-width:1400px){
    .chat-two-col{
        grid-template-columns:280px minmax(360px,1fr) !important;
    }
}

@media(max-width:1100px){
    .chat-two-col{
        grid-template-columns:1fr !important;
        height:auto !important;
    }

    .match-side{
        max-height:360px !important;
    }

    .chat-two-col .chat-box{
        height:620px !important;
    }
}


/* =========================
   v29 点击聊天后匹配列表自动收起，避免挡住聊天
========================= */

#rightChatPane{
    min-width:0 !important;
}

.chat-two-col{
    position:relative !important;
    overflow:hidden !important;
}

/* 默认：左边列表 + 右边聊天 */
#rightChatPane:not(.chat-focus) .chat-two-col{
    grid-template-columns:310px minmax(520px,1fr) !important;
}

/* 点击某个聊天后：列表往左收起，聊天占满 */
#rightChatPane.chat-focus .chat-two-col{
    grid-template-columns:0 minmax(0,1fr) !important;
    gap:0 !important;
}

#rightChatPane.chat-focus .match-side{
    width:0 !important;
    min-width:0 !important;
    padding:0 !important;
    margin:0 !important;
    border:none !important;
    opacity:0 !important;
    pointer-events:none !important;
    transform:translateX(-110%) !important;
}

#rightChatPane.chat-focus .chat-box{
    width:100% !important;
    max-width:none !important;
}

/* 返回按钮在聊天打开时显示明显一点 */
#rightChatPane.chat-focus .chat-back{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-width:58px !important;
}

/* 未选聊天时，返回按钮弱化 */
#rightChatPane:not(.chat-focus) .chat-back{
    opacity:.65 !important;
}

/* 防止聊天头像和标题被挤出屏幕 */
.chat-two-col .chat-head{
    min-width:0 !important;
}

.chat-two-col .chat-user-meta{
    min-width:0 !important;
    overflow:hidden !important;
}

.chat-two-col .chat-title,
.chat-two-col .chat-sub{
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
}

/* 中等宽度时默认列表变窄，避免一开始就挡住 */
@media(max-width:1500px){
    #rightChatPane:not(.chat-focus) .chat-two-col{
        grid-template-columns:260px minmax(420px,1fr) !important;
    }

    .match-side .match-name{
        font-size:16px !important;
    }

    .match-side .match-item{
        padding:12px !important;
    }
}

@media(max-width:1180px){
    #rightChatPane:not(.chat-focus) .chat-two-col{
        grid-template-columns:1fr !important;
    }

    #rightChatPane:not(.chat-focus) .chat-box{
        display:none !important;
    }

    #rightChatPane.chat-focus .chat-two-col{
        grid-template-columns:1fr !important;
    }

    #rightChatPane.chat-focus .match-side{
        display:none !important;
    }

    #rightChatPane.chat-focus .chat-box{
        display:flex !important;
        height:calc(100vh - 150px) !important;
    }
}


/* =========================
   v31 wlyz 卡密登录
========================= */
.login-mask{
    position:fixed;
    inset:0;
    z-index:9999999;
    display:none;
    align-items:center;
    justify-content:center;
    background:rgba(8,10,20,.82);
    backdrop-filter:blur(14px);
}

.login-mask.show{
    display:flex;
}

.login-box{
    width:min(430px,calc(100vw - 36px));
    padding:28px;
    border-radius:26px;
    background:linear-gradient(145deg,rgba(255,255,255,.13),rgba(255,255,255,.06));
    border:1px solid rgba(255,255,255,.14);
    box-shadow:0 24px 80px rgba(0,0,0,.42);
}

.login-logo{
    font-size:30px;
    font-weight:1000;
    letter-spacing:.5px;
    margin-bottom:18px;
}

.login-logo span{
    color:#ff4d75;
}

.login-title{
    font-size:24px;
    font-weight:950;
    margin-bottom:8px;
}

.login-sub{
    color:rgba(255,255,255,.68);
    line-height:1.5;
    margin-bottom:18px;
}

.login-input{
    width:100%;
    height:48px;
    border-radius:15px;
    border:1px solid rgba(255,255,255,.14);
    background:#2b3042;
    color:#fff;
    padding:0 14px;
    font-size:15px;
    outline:none;
    margin-bottom:14px;
}

.login-btn{
    width:100%;
    height:48px;
    border-radius:15px;
}

.login-tip{
    margin-top:12px;
    color:rgba(255,255,255,.48);
    font-size:12px;
    line-height:1.5;
}


/* =========================
   v32 卡密错误提示
========================= */
.login-error{
    display:none;
    margin:-4px 0 12px;
    padding:10px 12px;
    border-radius:12px;
    background:rgba(255,77,109,.15);
    border:1px solid rgba(255,77,109,.38);
    color:#ff9aad;
    font-size:13px;
    font-weight:800;
    line-height:1.45;
}

.toast{
    z-index:10000000 !important;
}


/* v33 卡密状态 */
.card-expire-info{
    margin-top:10px;
}

.card-expire-row{
    display:flex;
    flex-direction:column;
    gap:6px;
    padding:12px;
    border-radius:16px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.08);
    font-size:13px;
    color:#fff;
}

.card-state{
    display:inline-flex;
    width:max-content;
    padding:4px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:900;
}

.card-state.ok{
    background:rgba(0,255,140,.18);
    color:#54ffaf;
}

.card-state.warn{
    background:rgba(255,196,0,.16);
    color:#ffd85a;
}

.card-state.danger{
    background:rgba(255,77,109,.18);
    color:#ff8ca3;
}


/* =========================
   v34 卡密状态位置 + 聊天切换隐藏
========================= */

/* 卡密状态放到查看资料上面，减少占下面账号列表空间 */
.card-expire-top{
    margin:0 0 12px 0 !important;
}

.card-expire-top .card-expire-row{
    padding:10px 12px !important;
    gap:5px !important;
}

/* 默认只显示匹配列表，不显示右边未选择聊天的大框 */
#rightChatPane:not(.chat-focus) .chat-two-col{
    grid-template-columns:1fr !important;
    height:calc(100vh - 150px) !important;
}

#rightChatPane:not(.chat-focus) .match-side{
    width:100% !important;
    max-width:none !important;
    opacity:1 !important;
    pointer-events:auto !important;
    transform:none !important;
}

#rightChatPane:not(.chat-focus) .chat-box{
    display:none !important;
}

/* 点击匹配后：隐藏匹配列表，只显示聊天窗口 */
#rightChatPane.chat-focus .chat-two-col{
    grid-template-columns:1fr !important;
    gap:0 !important;
    height:calc(100vh - 150px) !important;
}

#rightChatPane.chat-focus .match-side{
    display:none !important;
}

#rightChatPane.chat-focus .chat-box{
    display:flex !important;
    width:100% !important;
    height:100% !important;
    max-width:none !important;
}

/* 匹配列表占满当前右侧区域 */
#rightChatPane:not(.chat-focus) #matchList{
    max-height:none !important;
}

/* 返回按钮醒目一点 */
#rightChatPane.chat-focus .chat-back{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-width:58px !important;
}


/* v37 卡密到期时间显示 */
.card-expire-info{
    margin:0 0 12px 0;
}

.card-expire-row{
    display:flex;
    flex-direction:column;
    gap:6px;
    padding:12px;
    border-radius:16px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.08);
    font-size:13px;
    color:#fff;
}

.card-state{
    display:inline-flex;
    width:max-content;
    padding:4px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:900;
}

.card-state.ok{
    background:rgba(0,255,140,.18);
    color:#54ffaf;
}

.card-state.warn{
    background:rgba(255,196,0,.16);
    color:#ffd85a;
}

.card-state.danger{
    background:rgba(255,77,109,.18);
    color:#ff8ca3;
}


/* v38 机器码显示 */
.card-expire-row span:last-child{
    word-break:break-all;
    color:rgba(255,255,255,.65);
    font-size:12px;
}


/* v40 验证服务器在线状态 */
.auth-server-status{
    margin:0 0 10px 0;
    padding:9px 11px;
    border-radius:13px;
    font-size:13px;
    font-weight:900;
    line-height:1.35;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.06);
    color:rgba(255,255,255,.78);
}

.login-box .auth-server-status{
    margin:0 0 14px 0;
}

.auth-server-status.online{
    color:#54ffaf;
    background:rgba(0,255,140,.12);
    border-color:rgba(0,255,140,.26);
}

.auth-server-status.offline{
    color:#ff9aad;
    background:rgba(255,77,109,.14);
    border-color:rgba(255,77,109,.34);
}

.auth-server-status.checking{
    color:#ffd85a;
    background:rgba(255,196,0,.12);
    border-color:rgba(255,196,0,.22);
}


/* v43 单卡单端提示 */
.login-error{
    white-space:pre-wrap;
}


/* 设置弹窗：把所有配置集中到这里 */
.settings-modal{position:fixed;inset:0;z-index:999998;display:none;color:#fff;}
.settings-modal.show{display:block;}
.settings-mask{position:absolute;inset:0;background:rgba(0,0,0,.58);backdrop-filter:blur(8px);}
.settings-box{position:absolute;right:18px;top:18px;bottom:18px;width:min(560px,calc(100vw - 36px));overflow-y:auto;background:linear-gradient(180deg,rgba(30,35,54,.98),rgba(16,18,30,.98));border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:18px;box-shadow:0 24px 80px rgba(0,0,0,.38);box-sizing:border-box;}
.settings-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;}
.settings-title{font-size:22px;font-weight:950;}
.settings-sub{font-size:12px;color:rgba(255,255,255,.56);margin-top:3px;}
.settings-close{width:38px;height:38px;border:0;border-radius:14px;background:rgba(255,255,255,.12);color:#fff;font-size:28px;line-height:34px;cursor:pointer;}
.settings-section{padding:13px;margin-top:12px;border-radius:18px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.09);}
.settings-section-title{font-size:15px;font-weight:900;margin-bottom:10px;}
.settings-tip{font-size:12px;line-height:1.45;color:rgba(255,255,255,.55);margin-top:8px;}
.proxy-grid{display:grid;grid-template-columns:140px minmax(0,1fr);gap:10px;align-items:end;}
.proxy-grid label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:rgba(255,255,255,.76);}
.proxy-grid input,.proxy-grid select{height:40px;border:1px solid rgba(255,255,255,.14);border-radius:12px;background:rgba(0,0,0,.22);color:#fff;padding:0 11px;outline:none;box-sizing:border-box;}
.proxy-grid select option{color:#111;}
.settings-box .swipe-config{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:0;}
.settings-box .swipe-config input{width:100%;}
.settings-box .global-ai-tools{margin:0;background:transparent;border:0;padding:0;}
.chat-top-tabs{display:none!important;}
@media(max-width:620px){.settings-box{left:10px;right:10px;top:10px;bottom:10px;width:auto;border-radius:20px}.proxy-grid{grid-template-columns:1fr}}

/* 设置弹窗分类 */
.settings-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:10px 0 14px;position:sticky;top:-18px;z-index:3;padding:12px 0 8px;background:linear-gradient(180deg,rgba(30,35,54,.98),rgba(30,35,54,.92));backdrop-filter:blur(8px);}
.settings-tab{height:38px;border:1px solid rgba(255,255,255,.12);border-radius:14px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.78);font-weight:900;cursor:pointer;}
.settings-tab.active{background:linear-gradient(135deg,rgba(255,77,109,.92),rgba(255,130,90,.92));border-color:rgba(255,255,255,.22);color:#fff;box-shadow:0 10px 24px rgba(255,77,109,.18);}
.settings-section[data-settings-section]{display:none;}
.settings-section[data-settings-section].active{display:block;}
.settings-tip-top{margin:-2px 0 10px;}
.settings-section .swipe-config{display:grid;grid-template-columns:1fr;gap:12px;margin:0;}
.settings-section .auto-reply-config{margin:0;}
@media (max-width:520px){.settings-tabs{grid-template-columns:repeat(2,1fr);}.settings-box{right:10px;left:10px;width:auto;}.proxy-grid{grid-template-columns:1fr!important;}}

/* settings category cards */
.settings-inner-card{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.045);
  border-radius:18px;
  padding:14px;
  margin:12px 0;
}
.settings-inner-title{
  font-size:15px;
  font-weight:800;
  color:#fff;
  margin-bottom:10px;
}
#fallbackSettingsCard:focus-within{
  border-color:rgba(255,255,255,.25);
  background:rgba(255,255,255,.07);
}

/* AI 人设设置 */
.ai-persona-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.ai-persona-grid label,
.chat-type-grid label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 12px;
  color: #64748b;
}
.ai-persona-grid input,
.global-delay-label input,
.global-delay-label textarea {
  width: 100%;
}
.ai-small-textarea {
  min-height: 64px;
}
.chat-type-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 12px;
}
.chat-type-grid label {
  flex-direction: row;
  align-items: center;
  color: #334155;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 8px 10px;
}
.chat-type-grid input {
  width: auto;
}
@media (max-width: 720px) {
  .ai-persona-grid,
  .chat-type-grid {
    grid-template-columns: 1fr;
  }
}


/* AI 平台选择 + 聊天类型深色修复 */
.ai-platform-card .ai-persona-grid label,
.ai-check-label{
  color: rgba(255,255,255,.72) !important;
}
.ai-platform-card select,
.ai-platform-card input,
.ai-persona-grid select{
  width: 100%;
  background: rgba(255,255,255,.08) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 16px;
  padding: 12px 14px;
  outline: none;
}
.ai-platform-card select option,
.ai-persona-grid select option{
  background: #2b2e3f !important;
  color: #fff !important;
}
.ai-key-link-btn{
  height: 44px;
  width: 100%;
  border-radius: 16px !important;
}
#aiBaseUrlWrap.ai-hide{
  display: none !important;
}
.chat-type-grid .chat-type-item{
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  color: #fff !important;
  border-radius: 18px !important;
  padding: 12px 14px !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px !important;
  cursor: pointer;
}
.chat-type-grid .chat-type-item:hover{
  background: rgba(255,255,255,.10) !important;
}
.chat-type-grid .chat-type-item input[type="radio"]{
  width: 16px !important;
  height: 16px !important;
  accent-color: #c86bff;
  transform: scale(.9);
}
.chat-type-grid .chat-type-item span{
  color: #fff !important;
  font-size: 15px;
}


/* =========================
   独立卡密登录页
========================= */
.login-page-body{
    min-height:100vh;
    margin:0;
    background:
        radial-gradient(circle at 20% 20%, rgba(255,77,117,.22), transparent 34%),
        radial-gradient(circle at 80% 10%, rgba(104,94,255,.20), transparent 34%),
        #080a14;
    color:#fff;
}
.login-page-wrap{
    min-height:100vh;
    display:grid;
    grid-template-columns:minmax(320px,460px) minmax(320px,520px);
    gap:24px;
    align-items:center;
    justify-content:center;
    padding:34px;
}
.login-page-left,
.notice-card{
    border-radius:28px;
    background:linear-gradient(145deg,rgba(255,255,255,.13),rgba(255,255,255,.06));
    border:1px solid rgba(255,255,255,.14);
    box-shadow:0 24px 80px rgba(0,0,0,.36);
}
.login-page-left{ padding:30px; }
.login-page-left h1{ margin:4px 0 10px; font-size:34px; }
.login-page-desc{ margin:0 0 18px; color:rgba(255,255,255,.68); line-height:1.65; }
.login-mini-info{ margin-top:14px; color:rgba(255,255,255,.48); font-size:12px; word-break:break-all; }
.login-page-right{ display:flex; flex-direction:column; gap:18px; }
.notice-card{ padding:24px; }
.notice-title{ font-size:20px; font-weight:950; margin-bottom:14px; }
.notice-list{ margin:0; padding-left:18px; color:rgba(255,255,255,.72); line-height:1.9; }
.telegram-line{ font-size:24px; font-weight:950; margin:10px 0 16px; }
.contact-card .btn{ width:100%; }
@media (max-width: 860px){
    .login-page-wrap{ grid-template-columns:1fr; padding:18px; align-items:start; }
    .login-page-left{ margin-top:28px; }
}

/* =========================
   登录页优化：左右不分散，合并成一张主卡
========================= */
.login-page-wrap.login-page-single{
    grid-template-columns:minmax(760px,1180px);
    padding:48px 28px;
}
.login-panel{
    width:100%;
    display:grid;
    grid-template-columns:minmax(320px,440px) 1fr;
    gap:0;
    overflow:hidden;
    border-radius:34px;
    background:linear-gradient(145deg,rgba(255,255,255,.14),rgba(255,255,255,.055));
    border:1px solid rgba(255,255,255,.15);
    box-shadow:0 34px 100px rgba(0,0,0,.46);
}
.login-panel .login-page-left,
.login-panel .notice-card{
    border:0;
    border-radius:0;
    background:transparent;
    box-shadow:none;
}
.login-panel .login-page-left{
    padding:42px;
    border-right:1px solid rgba(255,255,255,.12);
    background:linear-gradient(155deg,rgba(255,77,117,.14),rgba(255,255,255,.03));
}
.login-panel .login-page-right{
    padding:42px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    gap:26px;
}
.notice-topline{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:18px;
}
.notice-subtitle{
    margin:6px 0 0;
    color:rgba(255,255,255,.58);
    line-height:1.6;
}
.notice-badge{
    flex:0 0 auto;
    padding:8px 12px;
    border-radius:999px;
    font-size:12px;
    font-weight:900;
    color:#ff4d75;
    background:rgba(255,77,117,.13);
    border:1px solid rgba(255,77,117,.22);
}
.login-panel .notice-list{
    padding:18px 22px;
    border-radius:22px;
    background:rgba(255,255,255,.055);
    border:1px solid rgba(255,255,255,.08);
}
.contact-inline{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    padding:20px;
    border-radius:24px;
    background:rgba(255,255,255,.075);
    border:1px solid rgba(255,255,255,.10);
}
.contact-label{
    color:rgba(255,255,255,.62);
    font-weight:800;
    margin-bottom:5px;
}
.contact-inline .telegram-line{
    margin:0;
}
.contact-inline .btn{
    width:auto;
    min-width:150px;
}
@media (max-width: 860px){
    .login-page-wrap.login-page-single{
        grid-template-columns:1fr;
        padding:18px;
    }
    .login-panel{
        grid-template-columns:1fr;
    }
    .login-panel .login-page-left{
        border-right:0;
        border-bottom:1px solid rgba(255,255,255,.12);
        padding:30px;
    }
    .login-panel .login-page-right{
        padding:30px;
    }
    .contact-inline{
        align-items:stretch;
        flex-direction:column;
    }
    .contact-inline .btn{
        width:100%;
    }
}


/* =========================
   登录页动态效果版
========================= */
.login-page-body{
    position:relative;
    overflow:hidden;
    background:#070b18;
}
.login-page-body::before{
    content:"";
    position:fixed;
    inset:-20%;
    pointer-events:none;
    background:
      radial-gradient(circle at 18% 18%, rgba(255,77,109,.35), transparent 26%),
      radial-gradient(circle at 78% 18%, rgba(108,92,255,.28), transparent 28%),
      radial-gradient(circle at 70% 84%, rgba(36,217,139,.16), transparent 24%),
      linear-gradient(135deg,#080b17,#11162a 58%,#171a34);
    animation:loginBgBreath 9s ease-in-out infinite alternate;
    z-index:-3;
}
.login-bg-anim{
    position:fixed;
    inset:0;
    pointer-events:none;
    overflow:hidden;
    z-index:-2;
}
.login-bg-anim .orb{
    position:absolute;
    width:280px;
    height:280px;
    border-radius:50%;
    filter:blur(10px);
    opacity:.55;
    background:radial-gradient(circle, rgba(255,77,109,.42), rgba(255,77,109,0) 68%);
    animation:floatOrb 12s ease-in-out infinite;
}
.orb-1{left:4%;top:9%;animation-duration:13s!important;}
.orb-2{right:9%;top:13%;background:radial-gradient(circle, rgba(108,92,255,.44), rgba(108,92,255,0) 68%)!important;animation-delay:-3s!important;animation-duration:15s!important;}
.orb-3{left:34%;bottom:-8%;background:radial-gradient(circle, rgba(35,213,124,.22), rgba(35,213,124,0) 68%)!important;animation-delay:-6s!important;animation-duration:17s!important;}
.orb-4{right:24%;bottom:12%;width:180px!important;height:180px!important;background:radial-gradient(circle, rgba(255,196,87,.20), rgba(255,196,87,0) 70%)!important;animation-delay:-9s!important;animation-duration:11s!important;}
.grid-glow{
    position:absolute;
    inset:0;
    background-image:
      linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
    background-size:54px 54px;
    mask-image:radial-gradient(circle at 50% 35%, black, transparent 72%);
    animation:gridMove 18s linear infinite;
    opacity:.5;
}
.login-panel{
    position:relative;
    animation:panelIn .55s cubic-bezier(.2,.9,.25,1) both, panelFloat 6s ease-in-out .8s infinite;
}
.login-panel::before{
    content:"";
    position:absolute;
    inset:-2px;
    border-radius:inherit;
    padding:1px;
    background:linear-gradient(120deg, rgba(255,77,109,.75), rgba(255,255,255,.12), rgba(108,92,255,.75), rgba(255,77,109,.75));
    background-size:300% 300%;
    animation:borderFlow 6s linear infinite;
    -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
    -webkit-mask-composite:xor;
            mask-composite:exclude;
    pointer-events:none;
}
.login-panel .login-page-left,
.login-panel .login-page-right{position:relative;z-index:1;}
.animated-logo{
    display:inline-block;
    animation:logoPulse 2.8s ease-in-out infinite;
    text-shadow:0 0 24px rgba(255,77,109,.22);
}
.login-panel .login-page-left h1,
.notice-title,
.contact-inline{
    animation:softRise .6s ease both;
}
.login-panel .login-page-left h1{animation-delay:.08s;}
.notice-title{animation-delay:.16s;}
.contact-inline{animation-delay:.24s;}
.auth-server-status.online{
    animation:onlineGlow 2s ease-in-out infinite;
}
.login-input:focus{
    animation:inputGlow 1.6s ease-in-out infinite;
}
.dynamic-btn{
    position:relative;
    overflow:hidden;
    box-shadow:0 14px 32px rgba(255,77,109,.26);
}
.dynamic-btn::before{
    content:"";
    position:absolute;
    top:-60%;
    left:-40%;
    width:38%;
    height:220%;
    background:linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
    transform:rotate(25deg);
    animation:btnShine 2.8s ease-in-out infinite;
}
.dynamic-btn span{position:relative;z-index:1;}
.dynamic-notice .notice-list li{
    transform:translateX(0);
    transition:.22s ease;
}
.dynamic-notice .notice-list li:hover{
    transform:translateX(6px);
    color:#fff;
}
.contact-inline:hover{
    transform:translateY(-2px);
    border-color:rgba(255,77,109,.28);
    box-shadow:0 18px 38px rgba(0,0,0,.20);
}
.telegram-line{
    animation:telegramFloat 2.6s ease-in-out infinite;
}
.toast.show{
    animation:toastPop .22s ease both;
}
@keyframes loginBgBreath{from{transform:scale(1);filter:saturate(1)}to{transform:scale(1.04);filter:saturate(1.22)}}
@keyframes floatOrb{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(42px,-36px,0) scale(1.12)}}
@keyframes gridMove{from{background-position:0 0,0 0}to{background-position:54px 54px,54px 54px}}
@keyframes panelIn{from{opacity:0;transform:translateY(22px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes panelFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes borderFlow{0%{background-position:0% 50%}100%{background-position:300% 50%}}
@keyframes logoPulse{0%,100%{transform:translateY(0);filter:brightness(1)}50%{transform:translateY(-2px);filter:brightness(1.18)}}
@keyframes softRise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes onlineGlow{0%,100%{box-shadow:0 0 0 rgba(40,207,122,0)}50%{box-shadow:0 0 24px rgba(40,207,122,.22)}}
@keyframes inputGlow{0%,100%{box-shadow:0 0 0 3px rgba(255,77,109,.13)}50%{box-shadow:0 0 0 5px rgba(255,77,109,.22)}}
@keyframes btnShine{0%{left:-55%;opacity:0}25%{opacity:1}55%{left:115%;opacity:0}100%{left:115%;opacity:0}}
@keyframes telegramFloat{0%,100%{transform:translateX(0)}50%{transform:translateX(4px)}}
@keyframes toastPop{from{transform:translateX(-50%) translateY(8px) scale(.96)}to{transform:translateX(-50%) translateY(0) scale(1)}}
@media (prefers-reduced-motion: reduce){
    .login-page-body::before,.login-bg-anim .orb,.grid-glow,.login-panel,.login-panel::before,.animated-logo,.auth-server-status.online,.login-input:focus,.dynamic-btn::before,.telegram-line{animation:none!important;}
}
.status-dot.offline{background:#8b8b95!important}.status-dot.online{background:#32d873!important}.status-dot.warning{background:#ffbd4a!important}.status-dot.error{background:#ff4d6d!important}.ws-status-line{font-weight:800;color:#8affc1!important}


/* ================= 项目化后台 / 发布动态 ================= */
.app-dashboard{display:flex;gap:18px;align-items:stretch;padding:18px;min-height:100vh;background:radial-gradient(circle at top left,rgba(117,80,255,.18),transparent 34%),#0b0e19;}
.project-sidebar{width:230px;flex:0 0 230px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(28,32,55,.96),rgba(15,18,32,.96));border-radius:24px;padding:18px;box-shadow:0 18px 50px rgba(0,0,0,.28);position:sticky;top:18px;height:calc(100vh - 36px);box-sizing:border-box;}
.project-logo{font-size:28px;font-weight:900;letter-spacing:1px;color:#fff;margin-bottom:4px}.project-logo span{color:#ff4f8b}.project-subtitle{font-size:12px;color:rgba(255,255,255,.48);margin-bottom:18px}
.project-nav{width:100%;border:0;background:transparent;color:rgba(255,255,255,.72);text-align:left;padding:13px 14px;margin:6px 0;border-radius:15px;cursor:pointer;font-size:14px;transition:.18s}.project-nav:hover{background:rgba(255,255,255,.07);color:#fff}.project-nav.active{background:linear-gradient(135deg,#ff4f8b,#7357ff);color:#fff;box-shadow:0 10px 28px rgba(255,79,139,.22)}
.project-main{flex:1;min-width:0;display:grid;grid-template-columns:1fr;gap:18px}.project-page{min-width:0}.project-page[style*="display: none"]{display:none!important}
.moment-layout{display:grid;grid-template-columns:minmax(420px,1.1fr) minmax(360px,.9fr);gap:18px}.moment-left,.moment-right{display:flex;flex-direction:column;gap:16px}.moment-card{border:1px solid rgba(255,255,255,.08);background:rgba(20,24,42,.86);border-radius:22px;padding:18px;box-shadow:0 14px 35px rgba(0,0,0,.2)}
.moment-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}.moment-form-grid label,.moment-card label{display:flex;flex-direction:column;gap:8px;color:rgba(255,255,255,.72);font-size:13px}.moment-form-grid input,.moment-card input,.moment-card select,.moment-card textarea{border:1px solid rgba(255,255,255,.1);background:rgba(8,11,22,.78);color:#fff;border-radius:14px;padding:12px;outline:none}.moment-content{min-height:130px;resize:vertical}.moment-toolbar{margin-top:12px}.moment-search-row input{flex:1}.moment-topic-list,.my-moment-list{display:flex;flex-direction:column;gap:10px;max-height:360px;overflow:auto;padding-right:4px}.moment-topic-item,.my-moment-item{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.045);border-radius:16px;padding:13px}.moment-topic-name,.my-moment-value{font-weight:700;color:#fff;margin-bottom:6px}.moment-topic-desc,.my-moment-meta{font-size:12px;color:rgba(255,255,255,.55);line-height:1.5}.moment-topic-actions,.my-moment-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.moment-mini-btn{border:0;border-radius:10px;background:rgba(255,255,255,.1);color:#fff;padding:7px 10px;cursor:pointer}.moment-mini-btn:hover{background:rgba(255,79,139,.25)}.moment-log{height:180px;overflow:auto;font-size:12px;color:rgba(255,255,255,.68);line-height:1.8}.moment-log-line{border-bottom:1px dashed rgba(255,255,255,.08);padding:4px 0}.moment-log-line.ok{color:#8ff0b5}.moment-log-line.err{color:#ff8ca8}
@media(max-width:1100px){.app-dashboard{flex-direction:column}.project-sidebar{width:100%;height:auto;position:relative;top:auto;display:flex;overflow:auto;gap:8px;align-items:center}.project-logo,.project-subtitle{display:none}.project-nav{white-space:nowrap;width:auto}.moment-layout{grid-template-columns:1fr}.moment-form-grid{grid-template-columns:1fr}}

/* =========================
   v38 匹配 + 聊天同屏显示
   说明：之前点击匹配后会隐藏左侧匹配列表，只显示聊天。
   这里强制改成左边匹配、右边聊天一直同时显示。
========================= */
#rightChatPane .chat-two-col,
#rightChatPane:not(.chat-focus) .chat-two-col,
#rightChatPane.chat-focus .chat-two-col{
    display:grid !important;
    grid-template-columns:320px minmax(420px,1fr) !important;
    gap:14px !important;
    height:calc(100vh - 150px) !important;
    overflow:hidden !important;
}

#rightChatPane .match-side,
#rightChatPane:not(.chat-focus) .match-side,
#rightChatPane.chat-focus .match-side{
    display:flex !important;
    width:auto !important;
    max-width:none !important;
    min-width:0 !important;
    padding:12px !important;
    margin:0 !important;
    border:1px solid rgba(255,255,255,.10) !important;
    opacity:1 !important;
    pointer-events:auto !important;
    transform:none !important;
}

#rightChatPane .chat-box,
#rightChatPane:not(.chat-focus) .chat-box,
#rightChatPane.chat-focus .chat-box{
    display:flex !important;
    width:100% !important;
    height:100% !important;
    max-width:none !important;
}

#rightChatPane .chat-back,
#rightChatPane.chat-focus .chat-back,
#rightChatPane:not(.chat-focus) .chat-back{
    display:none !important;
}

#rightChatPane #matchList{
    max-height:none !important;
}

@media(max-width:1180px){
    #rightChatPane .chat-two-col,
    #rightChatPane:not(.chat-focus) .chat-two-col,
    #rightChatPane.chat-focus .chat-two-col{
        grid-template-columns:280px minmax(0,1fr) !important;
        height:calc(100vh - 150px) !important;
    }
}

@media(max-width:860px){
    #rightChatPane .chat-two-col,
    #rightChatPane:not(.chat-focus) .chat-two-col,
    #rightChatPane.chat-focus .chat-two-col{
        grid-template-columns:1fr !important;
        height:auto !important;
        overflow:visible !important;
    }

    #rightChatPane .match-side,
    #rightChatPane:not(.chat-focus) .match-side,
    #rightChatPane.chat-focus .match-side{
        max-height:260px !important;
    }

    #rightChatPane .chat-box,
    #rightChatPane:not(.chat-focus) .chat-box,
    #rightChatPane.chat-focus .chat-box{
        height:560px !important;
    }
}

/* =========================
   v39 滑动任务 + 好友列表同屏显示
   左边执行滑动任务，右边固定显示当前账号好友列表。
========================= */
.swipe-friend-layout{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) 330px !important;
    gap:14px !important;
    overflow:hidden !important;
    min-height:0 !important;
}
.swipe-work-area{
    min-width:0 !important;
    min-height:0 !important;
    overflow:auto !important;
    padding-right:2px !important;
}
.swipe-friend-side{
    min-height:0 !important;
    height:100% !important;
    max-height:calc(100vh - 150px) !important;
    position:sticky !important;
    top:0 !important;
}
.match-list-box,
.match-side #matchList,
.match-side #matchListSwipe{
    flex:1 1 auto !important;
    min-height:0 !important;
    overflow-y:auto !important;
    display:flex !important;
    flex-direction:column !important;
    gap:10px !important;
    padding-right:4px !important;
    max-height:none !important;
}
.swipe-friend-side .match-item{
    margin:0 !important;
    padding:14px !important;
    border-radius:16px !important;
    background:rgba(255,255,255,.06) !important;
    border:1px solid transparent !important;
    cursor:pointer !important;
}
.swipe-friend-side .match-item.active{
    border-color:#ff4d75 !important;
    box-shadow:0 0 0 1px rgba(255,77,117,.28) inset !important;
}
.swipe-friend-side .match-name{
    font-size:17px !important;
    font-weight:950 !important;
    color:#fff !important;
}
.swipe-friend-side .match-sub{
    margin-top:6px !important;
    font-size:13px !important;
    color:rgba(255,255,255,.68) !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
}
@media(max-width:1180px){
    .swipe-friend-layout{
        grid-template-columns:minmax(0,1fr) 280px !important;
    }
}
@media(max-width:860px){
    .swipe-friend-layout{
        grid-template-columns:1fr !important;
        overflow:auto !important;
    }
    .swipe-friend-side{
        max-height:320px !important;
        position:relative !important;
    }
}

.moment-mini-btn-danger{
    background:rgba(255,59,48,.14)!important;
    color:#ff6b6b!important;
    border-color:rgba(255,59,48,.35)!important;
}

.moment-mini-btn-danger:hover{
    background:rgba(255,59,48,.24)!important;
}

/* v40：好友列表按未读/已读分组；WS 来消息只重绘当前 userid 的分组 */
.match-group{margin-bottom:12px;}
.match-group-title{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;margin:4px 0 8px;border-radius:12px;background:rgba(255,255,255,.06);font-size:12px;font-weight:700;color:rgba(255,255,255,.78);}
.match-group-title span{min-width:22px;height:22px;line-height:22px;text-align:center;border-radius:999px;background:rgba(255,255,255,.10);font-size:12px;color:#fff;}
.match-group-empty{padding:10px 12px;margin-bottom:8px;border-radius:12px;background:rgba(255,255,255,.035);font-size:12px;color:rgba(255,255,255,.45);}


/* ================= UI move: 账号管理左侧 + 顶部任务导航 ================= */
.app-dashboard{
  display:flex!important;
  grid-template-columns:none!important;
  gap:14px!important;
  align-items:stretch!important;
  padding:14px!important;
  overflow:hidden;
}
.project-sidebar.account-manager-sidebar{
  width:380px!important;
  flex:0 0 380px!important;
  padding:14px!important;
  display:flex!important;
  flex-direction:column!important;
  gap:10px!important;
  overflow:hidden!important;
}
.account-left-panel{
  flex:1!important;
  min-height:0!important;
  border-radius:20px!important;
}
.account-left-panel .panel-header{
  align-items:flex-start!important;
  flex-direction:column!important;
}
.account-left-panel .logo{display:none!important;}
.account-left-panel textarea{min-height:88px!important;}
.project-main{
  flex:1!important;
  min-width:0!important;
  display:flex!important;
  flex-direction:column!important;
  gap:12px!important;
}
.project-topbar{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(18,22,39,.82);
  border-radius:20px;
  box-shadow:0 12px 32px rgba(0,0,0,.2);
}
.project-topbar .project-nav{
  width:auto!important;
  min-width:132px;
  text-align:center!important;
  margin:0!important;
}
.project-main>.project-page{
  flex:1!important;
  min-height:0!important;
}
.project-main>.project-page[style*="display: none"]{display:none!important;}
.project-sidebar.account-manager-sidebar>.project-nav{display:none!important;}
.task-panel .header-actions{gap:7px!important;}
@media(max-width:1200px){
  .app-dashboard{flex-direction:column!important;overflow:auto!important;}
  .project-sidebar.account-manager-sidebar{width:100%!important;flex:0 0 auto!important;position:relative!important;height:auto!important;max-height:none!important;}
  .project-topbar{position:sticky;top:0;z-index:20;overflow:auto;}
  .project-topbar .project-nav{white-space:nowrap;}
}

/* ================= v41：鼠标悬停动态效果（只改 UI，不改功能） ================= */
:root{
  --hover-glow: 0 16px 42px rgba(255, 70, 110, .22), 0 0 0 1px rgba(255,255,255,.10) inset;
  --hover-border: rgba(255, 93, 132, .38);
  --hover-bg: rgba(255,255,255,.075);
}

/* 所有可点击区域：鼠标移上去有手感 */
button,
.btn,
.project-nav,
.settings-tab,
.chat-top-tab,
.chat-type-item,
.ai-platform-card,
.account-profile-btn,
.match-refresh-btn,
.moment-mini-btn,
.moment-mini-btn-danger,
.account-tools button,
.header-actions button,
.toolbar button,
.card-list .card,
.match-list-box .match-item,
.account-panel,
.stat-card,
.moment-card,
.settings-inner-card{
  position:relative;
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease,
    background .18s ease,
    filter .18s ease,
    opacity .18s ease!important;
}

button:hover,
.btn:hover,
.project-nav:hover,
.settings-tab:hover,
.chat-top-tab:hover,
.chat-type-item:hover,
.ai-platform-card:hover,
.account-profile-btn:hover,
.match-refresh-btn:hover,
.moment-mini-btn:hover,
.account-tools button:hover,
.header-actions button:hover,
.toolbar button:hover{
  transform:translateY(-2px) scale(1.015);
  box-shadow:var(--hover-glow)!important;
  border-color:var(--hover-border)!important;
  filter:brightness(1.08);
}

/* 账号卡片、好友项、动态卡片：鼠标到哪里哪里浮起来 */
.account-panel:hover,
.card-list .card:hover,
.match-list-box .match-item:hover,
.stat-card:hover,
.moment-card:hover,
.settings-inner-card:hover,
.ai-platform-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--hover-glow)!important;
  border-color:var(--hover-border)!important;
  background:linear-gradient(135deg, rgba(255,255,255,.095), rgba(255,70,110,.075))!important;
}

/* 顶部滑块任务/发布任务按钮更明显 */
.project-topbar .project-nav:hover{
  background:linear-gradient(135deg, rgba(255,75,120,.28), rgba(130,90,255,.22))!important;
}
.project-topbar .project-nav.active{
  box-shadow:0 12px 34px rgba(255,70,110,.20)!important;
}

/* 输入框也有轻微动态 */
input:hover,
textarea:hover,
select:hover{
  border-color:rgba(255,255,255,.20)!important;
  background:rgba(255,255,255,.075)!important;
}
input:focus,
textarea:focus,
select:focus{
  outline:none!important;
  border-color:rgba(255,90,135,.55)!important;
  box-shadow:0 0 0 3px rgba(255,90,135,.12)!important;
}

/* 鼠标悬停时加一层扫光感，不挡点击 */
.project-nav::after,
.btn::after,
.account-panel::after,
.moment-card::after,
.stat-card::after,
.settings-inner-card::after,
.ai-platform-card::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  opacity:0;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.16) 45%, transparent 70%);
  transform:translateX(-35%);
  transition:opacity .18s ease, transform .45s ease;
}
.project-nav:hover::after,
.btn:hover::after,
.account-panel:hover::after,
.moment-card:hover::after,
.stat-card:hover::after,
.settings-inner-card:hover::after,
.ai-platform-card:hover::after{
  opacity:1;
  transform:translateX(35%);
}

/* 点击瞬间别太飘 */
button:active,
.btn:active,
.project-nav:active,
.settings-tab:active,
.chat-top-tab:active,
.chat-type-item:active,
.account-profile-btn:active,
.match-refresh-btn:active{
  transform:translateY(0) scale(.985)!important;
}

/* 弹窗里的关闭/设置项也统一动态 */
.settings-close:hover,
.profile-close:hover,
.chat-back:hover{
  transform:rotate(4deg) scale(1.06)!important;
  box-shadow:var(--hover-glow)!important;
}

/* =========================
   v31 修复聊天底部输入栏超出界面
   只调整高度/滚动，不改功能逻辑
========================= */
.chat-panel-wrap{
    height:100% !important;
    min-height:0 !important;
}

.chat-panel-wrap .panel-body.chat-layout{
    height:100% !important;
    min-height:0 !important;
    overflow:hidden !important;
}

#rightChatPane.active{
    display:flex !important;
    flex-direction:column !important;
    flex:1 1 auto !important;
    min-height:0 !important;
    overflow:hidden !important;
}

.chat-two-col{
    flex:1 1 auto !important;
    height:auto !important;
    min-height:0 !important;
    max-height:100% !important;
    overflow:hidden !important;
}

.chat-two-col .chat-box,
#rightChatPane.chat-focus .chat-box{
    height:100% !important;
    min-height:0 !important;
    max-height:100% !important;
    overflow:hidden !important;
}

.chat-two-col .chat-head{
    flex:0 0 auto !important;
}

.chat-two-col .chat-body{
    flex:1 1 auto !important;
    min-height:0 !important;
    overflow-y:auto !important;
    padding-bottom:14px !important;
}

.chat-two-col .chat-input{
    flex:0 0 auto !important;
    position:relative !important;
    bottom:auto !important;
    z-index:3 !important;
}

.chat-two-col .chat-input .row{
    flex-wrap:nowrap !important;
}

.chat-two-col .chat-input input{
    min-width:0 !important;
}

@media(max-width:1100px){
    #rightChatPane.active{
        overflow:visible !important;
    }
    .chat-two-col{
        height:auto !important;
        max-height:none !important;
        overflow:visible !important;
    }
    .chat-two-col .chat-box{
        height:620px !important;
    }
}


.role-voice-test-card{
  margin-top:14px;
  padding:14px;
  border-radius:18px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 12px 28px rgba(0,0,0,.16);
}
.role-voice-test-title{
  font-weight:800;
  margin-bottom:10px;
  color:#fff;
}
.role-voice-test-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.role-voice-test-grid label{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.role-voice-test-grid select,
.role-voice-test-grid textarea{
  width:100%;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(10,10,20,.42);
  color:#fff;
  padding:10px 12px;
  outline:none;
}
.role-voice-test-text{grid-column:1 / -1;}
.role-voice-test-actions{
  display:flex;
  gap:10px;
  align-items:center;
  margin-top:12px;
  flex-wrap:wrap;
}
.role-voice-test-result{
  margin-top:10px;
  font-size:13px;
  color:rgba(255,255,255,.72);
}
.role-voice-test-result audio{
  width:100%;
  margin-top:8px;
}
.voice-ok{color:#75f0b2;margin-bottom:6px;}
@media (max-width:900px){.role-voice-test-grid{grid-template-columns:1fr;}}


/* =========================
   v32 上传图片 + 深色下拉框统一修复
========================= */
select,
select:hover,
select:focus,
.moment-card select,
.ai-platform-card select,
.ai-persona-grid select,
.role-voice-test-grid select,
.reply-config select,
.proxy-grid select{
  background:#171a2a !important;
  color:#ffffff !important;
  border:1px solid rgba(255,255,255,.14) !important;
  color-scheme:dark !important;
}
select option,
select optgroup,
.moment-card select option,
.ai-platform-card select option,
.ai-persona-grid select option,
.role-voice-test-grid select option,
.proxy-grid select option{
  background:#171a2a !important;
  color:#ffffff !important;
}
select option:checked{
  background:#2b2440 !important;
  color:#ffffff !important;
}
.moment-upload-field{
  grid-column:span 1;
}
.moment-upload-box{
  min-height:96px;
  border:1px dashed rgba(255,255,255,.18);
  background:linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,70,120,.055));
  border-radius:18px;
  padding:14px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:8px;
  cursor:pointer;
  transition:.18s ease;
  outline:none;
}
.moment-upload-box:hover,
.moment-upload-box:focus,
.moment-upload-box.dragover{
  border-color:rgba(255,90,135,.55);
  background:linear-gradient(135deg, rgba(255,90,135,.16), rgba(130,90,255,.13));
  box-shadow:0 0 0 3px rgba(255,90,135,.10);
}
.moment-upload-box.has-file{
  border-style:solid;
  border-color:rgba(110,231,183,.42);
  background:linear-gradient(135deg, rgba(110,231,183,.12), rgba(255,255,255,.055));
}
.moment-upload-btn{
  width:max-content;
  border:0;
  border-radius:14px;
  background:linear-gradient(135deg,#ff4f8b,#8b5cf6);
  color:#fff;
  padding:10px 16px;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 12px 26px rgba(255,79,139,.18);
}
.moment-upload-tips{
  color:rgba(255,255,255,.62);
  font-size:12px;
  line-height:1.45;
}
.moment-upload-name{
  color:rgba(255,255,255,.86);
  font-size:13px;
  word-break:break-all;
}
@media(max-width:1100px){
  .moment-upload-field{grid-column:1 / -1;}
}


/* 默认无图模式：彻底隐藏图片和背景图，避免浏览器请求图片 CDN，节省流量 */
body.no-image-mode img{display:none!important;}
body.no-image-mode .user-img,
body.no-image-mode .single-user-img,
body.no-image-mode .chat-avatar,
body.no-image-mode .profile-avatar,
body.no-image-mode .match-avatar{
  background-image:none!important;
  background:rgba(255,255,255,.08)!important;
}
body.no-image-mode .single-user-img::after{
  content:"无图模式";
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%;
  color:rgba(255,255,255,.55);
  font-weight:900;
}


/* v2 无图模式：不切换成紧凑列表，只是不读取图片链接 */
.single-user-noimg{
  min-height:96px;
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(255,255,255,.55);
  background:rgba(255,255,255,.06);
  border:1px dashed rgba(255,255,255,.16);
  font-weight:900;
  margin-bottom:12px;
}
body.no-image-mode .single-user-img{display:none!important;}


/* 账号提取 */
.account-extract-page .panel-body{
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding-top:42px;
}
.extract-card{
  width:min(760px, 96%);
  background:rgba(20,24,36,.92);
  border:1px solid rgba(255,255,255,.08);
  border-radius:22px;
  padding:24px;
  box-shadow:0 18px 60px rgba(0,0,0,.28);
}
.extract-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.extract-actions{
  gap:12px;
  margin:8px 0 18px;
  flex-wrap:wrap;
}
.extract-result{
  width:100%;
  min-height:220px;
  background:#111722;
  color:#fff;
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;
  padding:14px;
  resize:vertical;
  outline:none;
}
@media(max-width:760px){
  .extract-grid{grid-template-columns:1fr;}
}
