/* ==========================================================================
 * 贡献BD 系统 样式 (community.css) v20260511-0020
 * 复用整站暗色+金紫色调
 * ========================================================================== */

/* ===== 主页：toolbar / 二级 tab / 列表 ===== */
.contrib-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:18px;gap:12px;flex-wrap:wrap;
}
.contrib-subtabs{
  display:flex;background:#1a1a26;border:1px solid #2a2538;
  border-radius:10px;padding:4px;gap:2px;
}
.contrib-subtab{
  padding:7px 16px;border:none;background:transparent;color:#9a9080;
  font-size:13px;cursor:pointer;border-radius:7px;font-weight:500;
  transition:all .15s ease;letter-spacing:.3px;
}
.contrib-subtab:hover{color:#d8d0e0;}
.contrib-subtab.active{
  background:linear-gradient(135deg,rgba(245,245,245,.12),rgba(180,140,255,.1));
  color:#f5f5f5;box-shadow:inset 0 0 0 1px rgba(245,245,245,.3);
}
.contrib-new-btn{
  padding:9px 18px;
  background:linear-gradient(135deg,#3a2d5c 0%,#5a4080 50%,#6b3d70 100%);
  color:#f5f5f5;border:1px solid rgba(245,245,245,.45);
  border-radius:10px;font-size:13.5px;font-weight:600;cursor:pointer;
  letter-spacing:.5px;transition:all .2s ease;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 4px 14px rgba(90,64,128,.25);
}
.contrib-new-btn:hover{
  filter:brightness(1.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 6px 18px rgba(90,64,128,.4);
}

.contrib-list{display:flex;flex-direction:column;gap:10px;}
.contrib-loading,.contrib-empty{
  text-align:center;padding:50px 20px;color:#7a7060;font-size:13px;
  border:1px dashed #2a2538;border-radius:12px;background:rgba(255,255,255,.01);
}
.contrib-empty-btn{
  margin-top:14px;padding:10px 22px;
  background:linear-gradient(135deg,#3a2d5c,#6b3d70);color:#f5f5f5;
  border:1px solid rgba(245,245,245,.4);border-radius:10px;
  font-size:13px;cursor:pointer;font-weight:600;
}
.contrib-empty-btn:hover{filter:brightness(1.12);}

.contrib-card{
  background:linear-gradient(135deg,rgba(255,255,255,.02),rgba(180,140,255,.03));
  border:1px solid #2a2538;border-radius:12px;padding:14px 16px;
  transition:all .2s ease;
}
.contrib-card:hover{border-color:rgba(180,140,255,.3);}
.contrib-card.draft{border-style:dashed;}
.contrib-card-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.contrib-card-title{flex:1;font-size:15px;font-weight:600;color:#f5f5f5;line-height:1.4;}
.contrib-card-status{
  flex-shrink:0;font-size:11px;padding:3px 9px;border-radius:9px;
  border:1px solid;letter-spacing:.5px;
}
.contrib-card-status.published{background:rgba(74,200,140,.1);color:#5fc899;border-color:rgba(74,200,140,.3);}
.contrib-card-status.hidden{background:rgba(180,180,180,.06);color:#888;border-color:#444;}
.contrib-card-status.draft{background:rgba(245,245,245,.08);color:#f5f5f5;border-color:rgba(245,245,245,.3);}
.contrib-card-meta{
  display:flex;flex-wrap:wrap;align-items:center;gap:8px;
  font-size:12px;color:#8a8090;margin-bottom:10px;
}
.contrib-sep{width:3px;height:3px;border-radius:50%;background:#3a3548;}
.contrib-card-actions{display:flex;gap:8px;justify-content:flex-end;}
.contrib-mini-btn{
  padding:6px 14px;font-size:12px;font-weight:500;cursor:pointer;
  background:rgba(255,255,255,.02);color:#a89e88;
  border:1px solid #2a2538;border-radius:8px;transition:all .15s ease;
}
.contrib-mini-btn:hover{border-color:rgba(180,140,255,.4);color:#d8d0e0;}
.contrib-mini-btn.primary{
  background:rgba(245,245,245,.08);color:#f5f5f5;border-color:rgba(245,245,245,.35);
}
.contrib-mini-btn.primary:hover{background:rgba(245,245,245,.15);}

/* ===== 编辑器：进度条 ===== */
.editor-progress{margin:6px 0 22px;}
.editor-progress-bar{
  display:flex;align-items:center;gap:0;
  background:rgba(255,255,255,.01);border:1px solid #2a2538;
  border-radius:12px;padding:14px 12px;
}
.editor-progress-step{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  flex:0 0 auto;cursor:pointer;opacity:.45;transition:opacity .2s ease;
  min-width:60px;
}
.editor-progress-step.active,.editor-progress-step.done{opacity:1;}
.editor-progress-step.active{cursor:default;}
.editor-progress-dot{
  width:28px;height:28px;border-radius:50%;
  background:#1a1a26;border:1.5px solid #2a2538;color:#7a7060;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:600;transition:all .25s ease;
}
.editor-progress-step.done .editor-progress-dot{
  background:rgba(180,140,255,.15);color:#b48cff;border-color:rgba(180,140,255,.5);
}
.editor-progress-step.active .editor-progress-dot{
  background:linear-gradient(135deg,#f5f5f5,#b48cff);color:#1a1408;
  border-color:rgba(245,245,245,.6);
  box-shadow:0 0 12px rgba(245,245,245,.35);
}
.editor-progress-name{font-size:11.5px;color:#8a8090;letter-spacing:.3px;}
.editor-progress-step.active .editor-progress-name{color:#f5f5f5;font-weight:600;}
.editor-progress-sep{flex:1;height:1px;background:#2a2538;margin:0 4px;align-self:center;margin-top:14px;}

/* ===== 编辑器：表单字段 ===== */
.ed-field{margin-bottom:18px;}
.ed-label{
  display:block;font-size:12.5px;font-weight:500;color:#a89e88;
  margin-bottom:8px;letter-spacing:.4px;
}
.ed-label .req{color:#c47a4a;font-size:11px;margin-left:2px;}
.ed-hint{font-size:11px;color:#5a5060;font-weight:400;margin-left:6px;}
.ed-input,.ed-textarea{
  width:100%;padding:10px 13px;
  background:rgba(255,255,255,.02);border:1px solid #2a2538;
  border-radius:9px;color:#cfc6b3;font-size:13.5px;font-family:inherit;
  transition:all .15s ease;
}
.ed-input:focus,.ed-textarea:focus{
  outline:none;border-color:rgba(245,245,245,.5);background:rgba(255,255,255,.03);
}
.ed-textarea{resize:vertical;min-height:60px;line-height:1.55;}
.ed-warn{font-size:12px;margin-top:6px;color:#c47a4a;display:none;}
.ed-warn.show{display:block;}

.ed-chips{display:flex;flex-wrap:wrap;gap:7px;}
.ed-chip{
  padding:7px 14px;border:1px solid #2a2538;border-radius:18px;
  background:rgba(255,255,255,.015);color:#9a9080;font-size:13px;
  cursor:pointer;transition:all .18s ease;user-select:none;
}
.ed-chip:hover{border-color:rgba(180,140,255,.35);color:#d8d0e0;background:rgba(180,140,255,.06);}
.ed-chip.active{
  background:linear-gradient(135deg,rgba(245,245,245,.14),rgba(180,140,255,.1));
  border-color:rgba(245,245,245,.5);color:#f5f5f5;font-weight:500;
}

.editor-actions{
  display:flex;gap:10px;margin-top:24px;padding-top:18px;
  border-top:1px solid rgba(255,255,255,.04);justify-content:flex-end;
  flex-wrap:wrap;
}
.ed-btn{
  padding:11px 22px;border:none;border-radius:10px;
  font-size:13.5px;font-weight:600;cursor:pointer;
  transition:all .2s ease;letter-spacing:.4px;
}
.ed-btn.full{width:100%;}
.ed-btn.primary{
  background:linear-gradient(135deg,#3a2d5c,#5a4080,#6b3d70);
  color:#f5f5f5;border:1px solid rgba(245,245,245,.45);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 4px 12px rgba(90,64,128,.25);
}
.ed-btn.primary:hover{filter:brightness(1.12);}
.ed-btn.ghost{
  background:transparent;color:#a89e88;border:1px solid #2a2538;
}
.ed-btn.ghost:hover{border-color:rgba(180,140,255,.4);color:#d8d0e0;}
.ed-btn.secondary{
  background:rgba(255,255,255,.02);color:#7a7060;border:1px solid #2a2538;
}
.ed-btn.secondary:hover{color:#a89e88;}

/* ===== 装备列表 ===== */
.equip-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px;}
.equip-empty{
  padding:20px;text-align:center;color:#5a5060;font-size:12.5px;
  border:1px dashed #2a2538;border-radius:10px;
}
.equip-item{
  display:flex;gap:12px;padding:12px;
  background:rgba(255,255,255,.02);border:1px solid #2a2538;
  border-radius:10px;align-items:flex-start;
}
.equip-item-icon{
  width:40px;height:40px;flex-shrink:0;
  background:#1a1a26;border:1px solid #2a2538;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:#5a5060;font-size:18px;overflow:hidden;
}
.equip-item-icon img{width:100%;height:100%;object-fit:contain;}
.equip-item-body{flex:1;min-width:0;}
.equip-item-title{font-size:14px;color:#f5f5f5;font-weight:600;margin-bottom:5px;}
.equip-tag-fb{
  font-size:10px;padding:1px 6px;border-radius:4px;font-weight:400;
  background:rgba(245,245,245,.08);color:#f5f5f5;border:1px solid rgba(245,245,245,.3);
  margin-left:6px;
}
.equip-item-stats{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:4px;}
.equip-stat-tag{
  font-size:11.5px;padding:2px 8px;
  background:rgba(180,140,255,.06);border:1px solid rgba(180,140,255,.2);
  border-radius:5px;color:#b8ad95;
}
.equip-item-note{font-size:12px;color:#8a8090;font-style:italic;line-height:1.4;}
.equip-item-actions{display:flex;flex-direction:column;gap:5px;flex-shrink:0;}
.equip-mini{
  padding:4px 10px;font-size:11px;cursor:pointer;
  background:transparent;color:#7a7060;border:1px solid #2a2538;border-radius:6px;
  transition:all .15s ease;
}
.equip-mini:hover{color:#d8d0e0;border-color:rgba(180,140,255,.4);}

/* ===== 装备添加器 弹窗 ===== */
.equip-modal{
  display:none;position:fixed;inset:0;z-index:9998;
  background:rgba(6,5,12,.82);backdrop-filter:blur(6px);
  align-items:center;justify-content:center;padding:20px;
}
.equip-modal.show{display:flex;}
.equip-panel{
  width:100%;max-width:560px;max-height:90vh;
  background:radial-gradient(ellipse at top,rgba(120,80,180,.1),transparent 50%),linear-gradient(180deg,#15131e,#0f0d18);
  border:1px solid #2a2538;border-radius:18px;
  display:flex;flex-direction:column;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
  animation:advSlide .25s cubic-bezier(.2,.8,.2,1);
}
.equip-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.04);
}
.equip-title{color:#f5f5f5;font-size:15.5px;font-weight:600;letter-spacing:.6px;}
.equip-close{
  background:transparent;border:none;color:#6a6070;font-size:24px;cursor:pointer;
  width:30px;height:30px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;line-height:1;
}
.equip-close:hover{background:rgba(255,255,255,.05);color:#f5f5f5;}
.equip-body{padding:18px 20px;overflow-y:auto;color:#cfc6b3;}

/* ===== 模糊搜索 ===== */
.search-box{position:relative;}
.search-dropdown{
  display:none;position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:20;
  background:linear-gradient(180deg,#1a1726,#15131e);
  border:1px solid #2a2538;border-radius:10px;max-height:280px;overflow-y:auto;
  box-shadow:0 12px 32px rgba(0,0,0,.5);padding:4px;
}
.search-dropdown.show{display:block;animation:advDdShow .15s ease;}
.search-dropdown::-webkit-scrollbar{width:6px;}
.search-dropdown::-webkit-scrollbar-thumb{background:rgba(245,245,245,.15);border-radius:3px;}

.search-item{
  display:flex;gap:10px;align-items:center;
  padding:8px 10px;border-radius:7px;cursor:pointer;
  transition:background .15s ease;
}
.search-item:hover{background:rgba(180,140,255,.08);}
.search-item.small{padding:7px 10px;}
.search-item-icon{
  width:30px;height:30px;flex-shrink:0;border-radius:6px;
  background:#1a1a26;border:1px solid #2a2538;
  display:flex;align-items:center;justify-content:center;color:#5a5060;
  overflow:hidden;
}
.search-item-icon img{width:100%;height:100%;object-fit:contain;}
.search-item-text{flex:1;min-width:0;}
.search-item-name{font-size:13px;color:#f5f5f5;font-weight:500;line-height:1.3;}
.search-item-cat{font-size:11px;color:#7a7060;margin-top:2px;}

.search-preview{
  display:flex;align-items:center;gap:8px;
  margin-top:8px;padding:8px 10px;
  background:rgba(245,245,245,.05);border:1px solid rgba(245,245,245,.25);
  border-radius:8px;font-size:12.5px;color:#f5f5f5;
}
.search-preview img{width:28px;height:28px;object-fit:contain;border-radius:5px;}

/* 词缀行 */
.stat-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px;}
.stat-empty{
  padding:14px;text-align:center;color:#5a5060;font-size:12px;
  border:1px dashed #2a2538;border-radius:8px;
}
.stat-row{
  display:flex;gap:8px;align-items:center;
  padding:8px 10px;
  background:rgba(180,140,255,.04);border:1px solid rgba(180,140,255,.15);
  border-radius:8px;
}
.stat-row-text{flex:1;font-size:12.5px;color:#cfc6b3;line-height:1.4;}
.stat-row-min{
  width:90px;padding:5px 8px;
  background:rgba(255,255,255,.02);border:1px solid #2a2538;
  border-radius:6px;color:#cfc6b3;font-size:12px;
}
.stat-row-min:focus{outline:none;border-color:rgba(245,245,245,.5);}
.stat-row-del{
  width:24px;height:24px;font-size:16px;cursor:pointer;
  background:transparent;color:#7a7060;border:1px solid #2a2538;
  border-radius:6px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;line-height:1;
}
.stat-row-del:hover{color:#c47a4a;border-color:#c47a4a;}
.stat-search-row{display:flex;gap:8px;align-items:flex-start;}
.stat-search-row .search-box{flex:1;}

/* ===== 天赋树截图 ===== */
.talent-img-row{display:flex;flex-wrap:wrap;gap:10px;}
.talent-img-cell{
  position:relative;width:140px;height:96px;border-radius:10px;overflow:hidden;
  border:1px solid #2a2538;background:#1a1a26;
}
.talent-img-cell img{width:100%;height:100%;object-fit:cover;}
.talent-img-del{
  position:absolute;top:4px;right:4px;width:22px;height:22px;font-size:14px;
  background:rgba(0,0,0,.7);color:#fff;border:none;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;line-height:1;
}
.talent-img-add{
  width:140px;height:96px;
  background:rgba(255,255,255,.02);border:1.5px dashed #2a2538;
  color:#7a7060;font-size:13px;cursor:pointer;border-radius:10px;
  transition:all .15s ease;
}
.talent-img-add:hover{border-color:rgba(245,245,245,.5);color:#f5f5f5;}

/* ===== 预览 ===== */
.preview-tip{
  font-size:12.5px;color:#8a8090;margin-bottom:12px;padding:10px 14px;
  background:rgba(245,245,245,.05);border:1px solid rgba(245,245,245,.2);
  border-radius:9px;text-align:center;
}
.preview-frame{
  background:#0f0d18;border:1px solid #2a2538;border-radius:14px;
  padding:20px 22px;margin-bottom:18px;
}
.preview-card .preview-author{
  display:inline-block;font-size:11.5px;color:#f5f5f5;
  background:rgba(245,245,245,.08);border:1px solid rgba(245,245,245,.3);
  border-radius:9px;padding:3px 10px;margin-bottom:10px;letter-spacing:.4px;
}
.preview-title{
  margin:0 0 10px;font-size:20px;color:#f5f5f5;font-weight:700;line-height:1.3;
}
.preview-meta{
  display:flex;flex-wrap:wrap;align-items:center;gap:8px;
  font-size:12.5px;color:#9a9080;margin-bottom:18px;padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.04);
}
.preview-sep{width:3px;height:3px;border-radius:50%;background:#3a3548;}
.preview-price{color:#f5f5f5;font-weight:600;}
.preview-section{
  margin:18px 0 8px;font-size:13px;color:#f5f5f5;font-weight:600;
  letter-spacing:.6px;border-left:2px solid rgba(245,245,245,.5);padding-left:10px;
}
.preview-text{font-size:13.5px;color:#cfc6b3;line-height:1.7;}
.preview-eq-list{display:flex;flex-direction:column;gap:8px;}
.preview-eq{
  display:flex;gap:12px;padding:11px;
  background:rgba(255,255,255,.02);border:1px solid #2a2538;border-radius:9px;
}
.preview-eq-icon{
  width:38px;height:38px;flex-shrink:0;border-radius:7px;background:#1a1a26;
  border:1px solid #2a2538;display:flex;align-items:center;justify-content:center;
  color:#5a5060;overflow:hidden;
}
.preview-eq-icon img{width:100%;height:100%;object-fit:contain;}
.preview-eq-body{flex:1;min-width:0;}
.preview-eq-title{font-size:13.5px;color:#f5f5f5;font-weight:600;margin-bottom:5px;}
.preview-eq-stats{display:flex;flex-wrap:wrap;gap:5px;}
.preview-eq-note{font-size:12px;color:#8a8090;font-style:italic;margin-top:4px;line-height:1.4;}
.preview-imgs{display:flex;flex-wrap:wrap;gap:10px;}
.preview-imgs img{max-width:100%;max-height:300px;border-radius:8px;border:1px solid #2a2538;}

/* ===== 详情页：社区 banner ===== */
.community-detail-banner{
  display:flex;align-items:center;flex-wrap:wrap;gap:12px;
  padding:11px 14px;margin:0 0 16px;
  background:linear-gradient(135deg,rgba(245,245,245,.06),rgba(180,140,255,.06));
  border:1px solid rgba(245,245,245,.25);border-radius:10px;
}
.community-badge{
  font-size:11px;font-weight:600;letter-spacing:.5px;
  padding:3px 9px;border-radius:9px;
  background:rgba(245,245,245,.15);color:#f5f5f5;border:1px solid rgba(245,245,245,.4);
}
.community-author{font-size:13px;color:#f5f5f5;font-weight:500;}
.community-time{font-size:11.5px;color:#7a7060;}
.community-likes{
  margin-left:auto;font-size:13px;color:#a89e88;cursor:pointer;
  display:flex;align-items:center;gap:4px;
  padding:4px 12px;background:rgba(255,255,255,.02);border:1px solid #2a2538;
  border-radius:18px;transition:all .15s ease;user-select:none;
}
.community-likes:hover{border-color:rgba(245,245,245,.4);color:#f5f5f5;}
.community-likes.liked{background:rgba(245,245,245,.1);color:#f5f5f5;border-color:rgba(245,245,245,.4);}
.community-likes .like-icon{font-size:14px;}

/* ===== Toast ===== */
.contrib-toast{
  position:fixed;left:50%;bottom:30px;transform:translate(-50%,12px);
  padding:10px 18px;background:#1a1a26;color:#f5f5f5;
  border:1px solid rgba(245,245,245,.4);border-radius:10px;
  font-size:13px;font-weight:500;
  box-shadow:0 6px 24px rgba(0,0,0,.5);
  opacity:0;pointer-events:none;transition:all .2s ease;z-index:10000;
}
.contrib-toast.show{opacity:1;transform:translate(-50%,0);}
.contrib-toast.error{border-color:rgba(196,122,74,.6);color:#ffb38c;}

/* 移动端 */
@media (max-width:480px){
  .contrib-toolbar{flex-direction:column;align-items:stretch;}
  .contrib-new-btn{width:100%;}
  .editor-progress-bar{padding:10px 8px;overflow-x:auto;}
  .editor-progress-step{min-width:54px;}
  .editor-progress-name{font-size:10.5px;}
  .editor-progress-sep{min-width:6px;}
  .editor-actions{flex-direction:column;}
  .editor-actions .ed-btn{width:100%;}
  .equip-modal{padding:0;align-items:flex-end;}
  .equip-panel{max-width:100%;max-height:95vh;border-radius:16px 16px 0 0;}
}

/* ===== 大厅卡片：社区角标（独立行，不与标题挤）===== */
.bd-card-community{position:relative;}
.bd-community-badge{
  display:inline-flex;align-items:center;
  font-size:10.5px;padding:3px 9px;margin-bottom:8px;
  background:linear-gradient(135deg,rgba(245,245,245,.12),rgba(180,140,255,.18));
  color:#f5f5f5;border:1px solid rgba(245,245,245,.3);border-radius:9px;
  letter-spacing:.4px;font-weight:500;
  width:fit-content;
}

/* ===== 装备内联编辑卡 ===== */
.equip-item-editing{
  flex-direction:column;align-items:stretch;gap:0;
  background:linear-gradient(180deg,rgba(180,140,255,.06),rgba(245,245,245,.03));
  border:1px solid rgba(180,140,255,.35);
  padding:16px;
}
.equip-inline-title{
  font-size:12.5px;color:#b48cff;font-weight:600;letter-spacing:.5px;
  margin-bottom:14px;text-transform:uppercase;
}
.ed-subfield{margin-bottom:14px;}
.ed-subfield:last-of-type{margin-bottom:10px;}
.ed-sublabel{
  display:block;font-size:12px;color:#a89e88;margin-bottom:6px;letter-spacing:.3px;
}
.ed-btn.small{padding:8px 14px;font-size:12.5px;}
.equip-inline-actions{
  display:flex;gap:8px;justify-content:flex-end;
  margin-top:10px;padding-top:12px;
  border-top:1px solid rgba(255,255,255,.04);
}

/* ===== 职业选择网格（带图标）===== */
.class-picker{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:12px;
}
.class-pick-cell{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  cursor:pointer;background:transparent;border:none;
  transition:all .25s ease;position:relative;
}
.class-pick-cell .class-pick-img-wrap{
  width:60px;height:60px;
  background:#1a1a26;
  border:1.5px solid #2a2538;
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  transition:all .25s cubic-bezier(.2,.8,.2,1);
}
.class-pick-cell img{
  width:48px;height:48px;object-fit:contain;
  filter:grayscale(.5) brightness(.85);
  transition:filter .25s ease;
}
.class-pick-cell:hover .class-pick-img-wrap{
  border-color:rgba(180,140,255,.5);
  transform:translateY(-2px);
}
.class-pick-cell:hover img{filter:grayscale(0) brightness(1);}
.class-pick-cell.active .class-pick-img-wrap{
  border-color:#f5f5f5;
  background:linear-gradient(135deg,rgba(245,245,245,.06),rgba(180,140,255,.1));
  box-shadow:
    0 0 0 2px rgba(245,245,245,.18),
    0 0 22px rgba(245,245,245,.35),
    0 0 40px rgba(180,140,255,.25);
}
.class-pick-cell.active img{
  filter:grayscale(0) brightness(1.15) drop-shadow(0 0 6px rgba(245,245,245,.4));
}
.class-pick-name{
  font-size:11.5px;color:#a89e88;letter-spacing:.6px;font-weight:500;
  text-align:center;
}
.class-pick-cell.active .class-pick-name{color:#f5f5f5;font-weight:600;text-shadow:0 0 8px rgba(245,245,245,.4);}

/* ===== 贡献BD 主页的英雄 banner（生动版）===== */
.contrib-hero{
  position:relative;overflow:hidden;border-radius:14px;
  padding:32px 28px 28px;margin-bottom:18px;min-height:140px;
  background:
    radial-gradient(ellipse at 0% 0%,rgba(180,80,80,.2) 0%,transparent 50%),
    radial-gradient(ellipse at 100% 50%,rgba(80,80,200,.18) 0%,transparent 55%),
    radial-gradient(ellipse at 50% 120%,rgba(180,140,255,.22) 0%,transparent 60%),
    linear-gradient(180deg,#1a1428 0%,#0f0d18 100%);
  border:1px solid #2a2538;
}
/* 装饰：暗黑奇幻几何线条 */
.contrib-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;opacity:.18;
  background-image:
    radial-gradient(circle at 12% 50%,rgba(255,160,80,.6) 0,transparent 2px),
    radial-gradient(circle at 26% 30%,rgba(180,140,255,.5) 0,transparent 1.5px),
    radial-gradient(circle at 38% 75%,rgba(255,255,255,.5) 0,transparent 1px),
    radial-gradient(circle at 55% 25%,rgba(255,160,80,.4) 0,transparent 1.5px),
    radial-gradient(circle at 70% 65%,rgba(180,140,255,.4) 0,transparent 2px),
    radial-gradient(circle at 85% 45%,rgba(255,255,255,.5) 0,transparent 1px),
    radial-gradient(circle at 92% 80%,rgba(255,160,80,.4) 0,transparent 1.5px);
  background-size:100% 100%;
}
/* 右下角职业图标剪影群 */
.contrib-hero::after{
  content:'';position:absolute;right:-20px;bottom:-30px;width:280px;height:200px;
  background-image:
    url('assets/class-icons/战士.png'),
    url('assets/class-icons/女巫.png'),
    url('assets/class-icons/游侠.png'),
    url('assets/class-icons/德鲁伊.png');
  background-repeat:no-repeat;
  background-size:78px,72px,70px,76px;
  background-position:
    0 70%,
    34% 25%,
    65% 78%,
    100% 32%;
  filter:grayscale(1) brightness(1.4) blur(.3px);
  opacity:.13;
  pointer-events:none;
  mask-image:linear-gradient(135deg,transparent 0%,black 60%);
  -webkit-mask-image:linear-gradient(135deg,transparent 0%,black 60%);
}
.contrib-hero-title{
  position:relative;font-size:23px;color:#f5f5f5;font-weight:700;
  margin-bottom:8px;letter-spacing:1.5px;
  text-shadow:0 2px 12px rgba(0,0,0,.5);
}
.contrib-hero-title::before{
  content:'';display:inline-block;width:3px;height:18px;
  background:linear-gradient(180deg,#b48cff,rgba(180,140,255,.3));
  vertical-align:middle;margin-right:10px;border-radius:2px;
}
.contrib-hero-sub{
  position:relative;font-size:13px;color:#bbb4a8;line-height:1.7;
  max-width:560px;
}

/* ==========================================================================
 * 编辑器字色统一变白（2026-05-11 修复）
 * 覆写先前灰棕色标签 / chip / 输入框，使"新建BD"页文字清晰
 * ========================================================================== */
#page-contrib-editor .ed-label,
#page-contrib-editor .ed-sublabel,
#page-contrib-editor .ed-hint,
#page-contrib-editor .ed-input,
#page-contrib-editor .ed-textarea,
#page-contrib-editor .ed-chip,
#page-contrib-editor .ed-btn.ghost,
#page-contrib-editor .ed-btn.secondary,
#page-contrib-editor .editor-progress-name,
#page-contrib-editor .class-pick-name,
#page-contrib-editor .equip-empty,
#page-contrib-editor .stat-row-text,
#page-contrib-editor .stat-row-min,
#page-contrib-editor .stat-empty,
#page-contrib-editor .search-item-name,
#page-contrib-editor .search-item-cat,
#page-contrib-editor .preview-meta,
#page-contrib-editor .preview-text,
#page-contrib-editor .preview-sep + span,
#page-contrib-editor .equip-add-btn,
#page-contrib-editor .equip-body,
#page-contrib-editor .equip-mini,
#page-contrib-editor .equip-item-name,
#page-contrib-editor .equip-item-type,
#page-contrib-editor .equip-item-note,
#page-contrib-editor .eq-stats-list li,
#page-contrib-editor input,
#page-contrib-editor textarea,
#page-contrib-editor select{
  color:#ffffff !important;
}
#page-contrib-editor .ed-input::placeholder,
#page-contrib-editor .ed-textarea::placeholder,
#page-contrib-editor input::placeholder,
#page-contrib-editor textarea::placeholder{
  color:rgba(255,255,255,.42) !important;
}
/* chip / 输入框的 hover / focus 也保持白 */
#page-contrib-editor .ed-chip:hover,
#page-contrib-editor .ed-chip.active,
#page-contrib-editor .ed-btn.ghost:hover,
#page-contrib-editor .ed-btn.secondary:hover{
  color:#ffffff !important;
}
/* 次级（可选/辅助）信息稍微降透明度但底色还是白 */
#page-contrib-editor .ed-hint,
#page-contrib-editor .ed-sublabel,
#page-contrib-editor .equip-item-type,
#page-contrib-editor .search-item-cat{
  color:rgba(255,255,255,.62) !important;
}
#page-contrib-editor .ed-label .req{ color:#ff9a6b !important; }
/* 进度条：未激活状态稍暗，但还是白系 */
#page-contrib-editor .editor-progress-step:not(.active):not(.done) .editor-progress-name{
  color:rgba(255,255,255,.5) !important;
}

/* ==========================================================================
 * 编辑器：移动端响应式（2026-05-11）
 * 断点：768px 平板以下；480px 手机
 * ========================================================================== */
@media (max-width:768px){
  #page-contrib-editor{
    padding:12px !important;
  }
  #page-contrib-editor .editor-progress-bar{
    padding:10px 8px;gap:2px;overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  #page-contrib-editor .editor-progress-step{min-width:52px;}
  #page-contrib-editor .editor-progress-dot{width:24px;height:24px;font-size:12px;}
  #page-contrib-editor .editor-progress-name{font-size:10.5px;}
  #page-contrib-editor .editor-progress-sep{min-width:6px;margin:0 2px;}

  #page-contrib-editor .ed-field{margin-bottom:16px;}
  #page-contrib-editor .ed-input,
  #page-contrib-editor .ed-textarea{
    font-size:16px;padding:11px 13px; /* iOS 聚焦不自动放大需 >=16px */
  }
  #page-contrib-editor .ed-chip{
    padding:8px 14px;font-size:13px;
  }
  #page-contrib-editor .class-picker{
    grid-template-columns:repeat(4,1fr);
    gap:10px;
  }
  #page-contrib-editor .class-pick-cell .class-pick-img-wrap{
    width:52px;height:52px;border-radius:12px;
  }
  #page-contrib-editor .class-pick-cell img{width:40px;height:40px;}
  #page-contrib-editor .class-pick-name{font-size:11px;}

  #page-contrib-editor .editor-actions{
    gap:8px;margin-top:18px;padding-top:14px;
  }
  #page-contrib-editor .ed-btn{
    padding:11px 18px;font-size:13.5px;
  }

  /* 装备内联卡 */
  #page-contrib-editor .equip-item-editing{padding:14px 12px;}
  #page-contrib-editor .equip-inline-title{font-size:12px;margin-bottom:12px;}
  #page-contrib-editor .equip-inline-actions{
    flex-direction:column-reverse;gap:8px;
  }
  #page-contrib-editor .equip-inline-actions .ed-btn{width:100%;}

  /* 装备搜索弹出 & 词缀搜索下拉 */
  #page-contrib-editor .stat-row{flex-wrap:wrap;}
  #page-contrib-editor .stat-row-text{flex-basis:100%;margin-bottom:6px;}
  #page-contrib-editor .stat-row-min{width:100px;}

  /* 预览卡片 */
  #page-contrib-editor .preview-card{padding:14px !important;}
  #page-contrib-editor .preview-title{font-size:17px !important;}
  #page-contrib-editor .preview-meta{font-size:12px;flex-wrap:wrap;}
  #page-contrib-editor .preview-eq-thumb{width:46px;height:46px;}
}

@media (max-width:480px){
  #page-contrib-editor{padding:10px !important;}
  #page-contrib-editor .class-picker{
    grid-template-columns:repeat(4,1fr);
    gap:8px;
  }
  #page-contrib-editor .class-pick-cell .class-pick-img-wrap{
    width:48px;height:48px;
  }
  #page-contrib-editor .class-pick-cell img{width:36px;height:36px;}
  #page-contrib-editor .class-pick-name{font-size:10.5px;}
  #page-contrib-editor .editor-actions{flex-direction:column-reverse;}
  #page-contrib-editor .editor-actions .ed-btn{width:100%;}
  #page-contrib-editor .ed-chips{gap:6px;}
  #page-contrib-editor .ed-chip{padding:7px 12px;font-size:12.5px;}
  #page-contrib-editor .editor-progress-step{min-width:46px;}
  #page-contrib-editor .editor-progress-name{font-size:10px;}
}

