/* ═══════════════════════════════════════════════════════════════
   成员风采 — 全屏沉浸式展示
   左侧名字列表 + 右侧立绘滑动出场 + 信息显现
   ═══════════════════════════════════════════════════════════════ */

/* 桌面端锁定滚动 */
.members-page{overflow:hidden;height:100vh}

/* ── 舞台布局 ── */
.m-stage{
  display:flex;height:100vh;width:100vw;
  position:relative;overflow:hidden;
  background:var(--bg);
}

/* ═══ 左侧边栏 ═══ */
.m-sidebar{
  width:220px;flex-shrink:0;
  display:flex;flex-direction:column;
  padding:100px 0 40px;
  background:rgba(5,5,16,.6);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-right:1px solid var(--border);
  position:relative;z-index:10;
}

.m-sidebar-head{padding:0 28px;margin-bottom:32px}

.m-label{
  font-size:13px;font-weight:700;letter-spacing:3px;
  text-transform:uppercase;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}

.m-list{list-style:none;display:flex;flex-direction:column;gap:2px;padding:0 12px}

.m-item{
  padding:14px 20px;border-radius:12px;
  font-size:16px;font-weight:600;
  color:var(--text-3);cursor:pointer;
  transition:all .35s var(--ease);
  position:relative;overflow:hidden;
}

.m-item::before{
  content:'';position:absolute;left:0;top:50%;
  width:3px;height:0;border-radius:2px;
  background:var(--grad);
  transform:translateY(-50%);
  transition:height .35s var(--ease);
}

.m-item:hover{
  color:var(--text-2);
  background:rgba(108,92,231,.06);
}

.m-item.active{
  color:#fff;
  background:rgba(108,92,231,.1);
}

.m-item.active::before{height:24px}

/* ═══ 主展示区 ═══ */
.m-main{
  flex:1;position:relative;overflow:hidden;
}

/* 背景光效 */
.m-bg-glow{
  position:absolute;inset:0;z-index:0;
  background:radial-gradient(ellipse 60% 50% at 65% 50%,rgba(108,92,231,.08),transparent 70%);
  transition:opacity .8s var(--ease);
}

/* ═══ 歌手面板 ═══ */
.m-panel{
  position:absolute;inset:0;z-index:1;
  display:flex;align-items:center;
  padding:0 60px;
  opacity:0;
  pointer-events:none;
  transition:opacity .6s var(--ease);
}

.m-panel.active{
  opacity:1;
  pointer-events:auto;
}

/* ── 立绘 ── */
.m-portrait{
  flex-shrink:0;
  width:45%;max-width:520px;
  height:90vh;
  display:flex;align-items:flex-end;justify-content:center;
  position:relative;
  overflow:hidden;
}

.m-portrait img{
  display:block;
  height:100%;width:auto;max-width:100%;
  object-fit:contain;object-position:bottom center;
  filter:drop-shadow(0 0 60px rgba(108,92,231,.2));
  transform:translateY(80px) scale(.95);
  opacity:0;
  transition:transform .9s cubic-bezier(.16,1,.3,1),
             opacity .6s var(--ease);
}

.m-panel.active .m-portrait img{
  transform:translateY(0) scale(1);
  opacity:1;
}

/* 立绘离场动画 */
.m-panel.exit-left .m-portrait img{
  transform:translateX(-120px) scale(.9);
  opacity:0;
  transition:transform .5s var(--ease),opacity .4s var(--ease);
}

.m-panel.exit-right .m-portrait img{
  transform:translateX(120px) scale(.9);
  opacity:0;
  transition:transform .5s var(--ease),opacity .4s var(--ease);
}

/* ── 信息区 ── */
.m-info{
  flex:1;padding:0 0 0 60px;
  max-width:500px;
  transform:translateY(40px);
  opacity:0;
  transition:transform .8s cubic-bezier(.16,1,.3,1) .15s,
             opacity .6s var(--ease) .15s;
}

.m-panel.active .m-info{
  transform:translateY(0);
  opacity:1;
}

.m-panel.exit-left .m-info,
.m-panel.exit-right .m-info{
  transform:translateY(30px);
  opacity:0;
  transition:transform .4s var(--ease),opacity .3s var(--ease);
}

/* 角色徽章 */
.m-badge{
  display:inline-block;padding:6px 18px;border-radius:50px;
  font-size:12px;font-weight:700;letter-spacing:1px;
  margin-bottom:16px;margin-right:8px;
}
.m-badge-leader{background:rgba(255,215,0,.12);color:#ffd700;border:1px solid rgba(255,215,0,.25)}
.m-badge-admin{background:rgba(168,85,247,.12);color:#a855f7;border:1px solid rgba(168,85,247,.25)}
.m-badge-singer{background:rgba(58,139,255,.12);color:#3a8bff;border:1px solid rgba(58,139,255,.25)}
.m-badge-host{background:rgba(74,222,128,.12);color:#4ade80;border:1px solid rgba(74,222,128,.25)}

/* 歌手名 */
.m-name{
  font-size:clamp(48px,7vw,72px);
  font-weight:900;line-height:1.1;
  margin-bottom:16px;letter-spacing:-1px;
}

/* 元信息 */
.m-meta{
  display:flex;align-items:center;flex-wrap:wrap;gap:8px;
  margin-bottom:24px;font-size:14px;color:var(--text-2);
}
.m-voice{
  padding:4px 14px;border-radius:50px;
  background:rgba(108,92,231,.08);border:1px solid var(--border);
  font-weight:600;
}
.m-divider{color:var(--text-3);font-size:10px}
.m-douyin{color:var(--text-3)}

/* 描述 */
.m-desc{
  font-size:16px;color:var(--text-2);line-height:1.9;
  margin-bottom:32px;
}

/* 荣誉区 */
.m-honors{
  border-top:1px solid var(--border);
  padding-top:24px;
}
.m-honors h4{
  font-size:14px;font-weight:700;color:var(--text-3);
  letter-spacing:2px;text-transform:uppercase;
  margin-bottom:14px;
}
.m-honor-list{
  display:flex;flex-wrap:wrap;gap:10px;
}
.m-honor-placeholder{
  font-size:14px;color:var(--text-3);font-style:italic;
}
.m-honor-tag{
  padding:6px 16px;border-radius:50px;font-size:13px;font-weight:500;
  background:rgba(255,215,0,.06);border:1px solid rgba(255,215,0,.15);
  color:var(--gold);
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — 平板
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .m-sidebar{width:180px;padding-top:80px}
  .m-item{padding:12px 16px;font-size:15px}
  .m-portrait{width:40%}
  .m-info{padding-left:36px}
  .m-panel{padding:0 36px}
  .m-name{font-size:44px}
  .m-desc{font-size:15px;margin-bottom:24px}
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — 手机
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:768px){
  /* 手机端允许滚动 */
  .members-page{overflow:auto;height:auto;min-height:100vh}
  .m-stage{
    flex-direction:column;
    height:100vh;height:100dvh; /* dvh 适配手机动态视口 */
  }

  /* 侧边栏变顶部横向标签栏 */
  .m-sidebar{
    width:100%;height:auto;flex-shrink:0;
    padding:72px 12px 12px;
    border-right:none;border-bottom:1px solid var(--border);
    overflow:visible;
  }
  .m-sidebar-head{padding:0 8px;margin-bottom:10px}
  .m-label{font-size:11px;letter-spacing:2px}

  .m-list{
    flex-direction:row;gap:6px;padding:0 4px;
    overflow-x:auto;overflow-y:hidden;
    flex-wrap:nowrap;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none; /* Firefox */
  }
  .m-list::-webkit-scrollbar{display:none} /* Chrome/Safari */

  .m-item{
    padding:10px 18px;font-size:13px;white-space:nowrap;
    border-radius:50px;flex-shrink:0;
  }
  .m-item::before{display:none}
  .m-item.active{background:rgba(108,92,231,.18)}

  /* 主区域 */
  .m-main{flex:1;min-height:0}

  .m-panel{
    flex-direction:column;
    padding:16px 20px;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    align-items:center;
  }

  /* 立绘 — 适配手机，不要占太多高度 */
  .m-portrait{
    width:100%;max-width:280px;
    height:auto;max-height:38vh;
    flex-shrink:0;
    align-items:center;
  }
  .m-portrait img{
    height:auto;max-height:38vh;width:auto;max-width:100%;
    filter:drop-shadow(0 0 30px rgba(108,92,231,.15));
  }

  /* 离场动画缩小距离 */
  .m-panel.exit-left .m-portrait img{transform:translateX(-60px) scale(.92)}
  .m-panel.exit-right .m-portrait img{transform:translateX(60px) scale(.92)}

  /* 信息区 — 紧凑排布 */
  .m-info{
    padding:16px 0 0;
    max-width:none;width:100%;
    text-align:center;
  }
  .m-name{font-size:32px;letter-spacing:0}
  .m-meta{justify-content:center;font-size:13px;gap:6px;margin-bottom:16px}
  .m-desc{font-size:14px;line-height:1.7;margin-bottom:20px;text-align:left}
  .m-badge{font-size:11px;padding:5px 14px;margin-bottom:12px}
  .m-honors{padding-top:16px}
  .m-honors h4{font-size:12px;margin-bottom:10px}
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — 小手机 (iPhone SE 等)
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:400px){
  .m-sidebar{padding-top:64px;padding-left:8px;padding-right:8px;padding-bottom:8px}
  .m-item{padding:8px 14px;font-size:12px}
  .m-portrait{max-height:32vh;max-width:220px}
  .m-portrait img{max-height:32vh}
  .m-panel{padding:12px 16px}
  .m-name{font-size:28px}
  .m-desc{font-size:13px}
  .m-meta{font-size:12px}
}
