打开/关闭菜单
打开/关闭外观设置菜单
打开/关闭个人菜单
未登录
未登录用户的IP地址会在进行任意编辑后公开展示。

模板:角色/styles.css:修订间差异

来自国漫宇宙
Rockman留言 | 贡献
创建页面,内容为“=================================================== * 国漫TV · 角色词条专属组件样式 (TemplateStyles 作用域) * ===================================================:​ --- 1. 结构化角色 Infobox 重构 ---:​ .gmtv-char-infobox { float: right; width: 320px; margin: 0 0 24px 30px; background-color: #ffffff; border-radius: 12px; box-shadow: 0 4px 20px rgba(126, 34, 206, 0.08); border: 1px solid #f3e8ff; ov…”
 
Rockman留言 | 贡献
无编辑摘要
 
(未显示同一用户的13个中间版本)
第1行: 第1行:
/* ===================================================
/* ──────────────────────────────────────────
* 国漫TV · 角色词条专属组件样式 (TemplateStyles 作用域)
  1. 最外层容器
* =================================================== */
  限制最大宽度,禁止全屏撑满
────────────────────────────────────────── */
.gmtv-character {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0;
  /*background: var(--c-bg);*/
  font-family: 'PingFang SC', 'Noto Sans SC', 'Microsoft YaHei', sans-serif;
  color: var(--c-text);
  line-height: 1.8;
}
 
 
/* ──────────────────────────────────────────
  2. 顶部英雄标题区
────────────────────────────────────────── */
.gmtv-hero {
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  border-radius: var(--radius-card);
  padding: 22px 24px;
  margin-bottom: 18px;
  display: flex;
  align-items: flex-start;
  gap: 18px;
  color: #fff;
  position: relative;
  overflow: hidden;
}
 
/* 装饰光晕 */
.gmtv-hero::before {
  content: '';
  position: absolute;
  top: -40px;
  right: -40px;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  pointer-events: none;
}
 
.gmtv-hero-avatar {
  width: 72px;
  height: 72px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.25);
  border: 2px solid rgba(255, 255, 255, 0.4);
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
}
 
.gmtv-hero-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
 
.gmtv-hero-info {
  flex: 1;
  min-width: 0;
}
 
.gmtv-hero-name {
  font-size: 26px;
  font-weight: 900;
  letter-spacing: 2px;
  line-height: 1.2;
  margin: 0 0 4px;
}
 
.gmtv-hero-sub {
  font-size: 13px;
  opacity: 0.88;
  margin: 0 0 10px;
}
 
.gmtv-hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
 
.gmtv-hero-tag {
  background: rgba(255, 255, 255, 0.22);
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-radius: 20px;
  padding: 2px 12px;
  font-size: 11px;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
}
 
 
/* ──────────────────────────────────────────
  3. 主体双栏布局
  PC:左侧 Infobox(260px) + 右侧卡片流
  移动端:单栏,Infobox 在上
────────────────────────────────────────── */
.gmtv-body {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}
 
.gmtv-sidebar {
  width: 260px;
  flex-shrink: 0;
  position: sticky;
  top: 72px;
}
 
.gmtv-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
 
 
/* ──────────────────────────────────────────
  4. Infobox
  重置 Citizen 皮肤对 table/infobox 的默认干扰
────────────────────────────────────────── */
.gmtv-character .gmtv-infobox,
.gmtv-character .gmtv-infobox table,
.gmtv-character .gmtv-infobox td,
.gmtv-character .gmtv-infobox th {
  border: none !important;
  background: none !important;
  padding: 0 !important;
  margin: 0 !important;
  float: none !important;
  width: auto !important;
}
 
.gmtv-infobox {
  background: var(--c-card) !important;
  border-radius: var(--radius-card) !important;
  border: 1px solid var(--c-border) !important;
  overflow: hidden;
  box-shadow: var(--shadow-card);
  width: 100% !important;
}
 
.gmtv-infobox-head {
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 10px 14px;
  text-align: center;
}
 
.gmtv-infobox-img {
  width: 100%;
  max-height: 280px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--c-head-bg);
  border-bottom: 1px solid var(--c-border);
}
 
.gmtv-infobox-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
 
.gmtv-infobox-img-placeholder {
  width: 100%;
  height: 180px;
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 56px;
}
 
.gmtv-infobox-group {
  background: var(--c-head-bg);
  color: var(--c-primary);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 7px 14px;
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
}


/* --- 1. 结构化角色 Infobox 重构 --- */
.gmtv-infobox-row {
.gmtv-char-infobox {
  display: flex;
    float: right;
  align-items: flex-start;
    width: 320px;
  padding: 8px 14px;
    margin: 0 0 24px 30px;
  border-bottom: 1px solid var(--c-border);
    background-color: #ffffff;
  gap: 8px;
    border-radius: 12px;
  font-size: 12.5px;
    box-shadow: 0 4px 20px rgba(126, 34, 206, 0.08);
    border: 1px solid #f3e8ff;
    overflow: hidden;
    font-size: 0.95em;
    box-sizing: border-box;
}
}


/* 移动端优先:屏幕宽度不足时自动转换为全宽占位,不再浮动 */
.gmtv-infobox-row:last-child {
@media screen and (max-width: 768px) {
  border-bottom: none;
    .gmtv-char-infobox {
}
        float: none;
 
        width: 100%;
.gmtv-infobox-key {
        margin: 0 0 24px 0;
  color: var(--c-sub);
    }
  min-width: 58px;
  flex-shrink: 0;
  padding-top: 1px;
  font-size: 12px;
}
 
.gmtv-infobox-val {
  color: var(--c-text);
  font-weight: 500;
  flex: 1;
  word-break: break-all;
}
 
.gmtv-infobox-val a,
.gmtv-infobox-val a:visited {
  color: var(--c-primary);
  text-decoration: none;
  font-weight: 600;
}
 
.gmtv-infobox-val a:hover {
  color: var(--c-accent);
  text-decoration: underline;
}
 
 
/* ──────────────────────────────────────────
  5. 通用卡片
────────────────────────────────────────── */
.gmtv-card {
  background: var(--c-card);
  border-radius: var(--radius-card);
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow-card);
  overflow: visible;
  isolation: isolate;
}
 
.gmtv-card-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: var(--c-head-bg);
  border-bottom: 1px solid var(--c-border);
  cursor: pointer;
  user-select: none;
}
 
/* 左侧色点装饰 */
.gmtv-card-head::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  flex-shrink: 0;
}
 
.gmtv-card-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--c-text);
  flex: 1;
}
 
.gmtv-card-body {
  padding: 16px;
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--c-text);
}
 
/* 折叠后:隐藏底边框,避免出现空色块 */
.gmtv-card.mw-collapsed .gmtv-card-head {
  border-bottom: none;
  border-radius: calc(var(--radius-card) - 1px);
}
 
/* 折叠后卡片 overflow 改为 visible,圆角不被截断 */
.gmtv-card.mw-collapsed {
  overflow: visible;
}
 
/* 折叠状态下强制隐藏 p 标签防止撑开空白 */
.gmtv-card.mw-collapsed p {
  display: none;
}
 
 
/* ──────────────────────────────────────────
  6. 剧透卡片(默认折叠 + 自动角标)
────────────────────────────────────────── */
.gmtv-card-spoiler .gmtv-card-head {
  background: #FFF0F5;
}
 
/* 折叠状态:显示"含剧透"角标 */
.gmtv-card-spoiler.mw-collapsed .gmtv-card-title::after {
  content: '⚠ 含剧透';
  font-size: 10px;
  font-weight: 600;
  color: #FF6B9D;
  background: #FFE0EC;
  border: 1px solid #FFB3CC;
  border-radius: 8px;
  padding: 1px 7px;
  margin-left: 8px;
  vertical-align: middle;
}
 
/* 展开状态:角标变为"剧透已展开" */
.gmtv-card-spoiler:not(.mw-collapsed) .gmtv-card-title::after {
  content: '▼ 剧透已展开';
  font-size: 10px;
  font-weight: 600;
  color: #FFA94D;
  background: #FFEAE0;
  border: 1px solid #FFD0A0;
  border-radius: 8px;
  padding: 1px 7px;
  margin-left: 8px;
  vertical-align: middle;
}
 
 
/* ──────────────────────────────────────────
  7. 标签 / Badge
────────────────────────────────────────── */
.gmtv-tag {
  display: inline-block;
  background: var(--c-tag-bg);
  color: var(--c-tag-text);
  border-radius: 20px;
  padding: 2px 11px;
  font-size: 11px;
  font-weight: 600;
  margin: 2px 3px 2px 0;
  white-space: nowrap;
}
 
.gmtv-tag-primary {
  background: #FF6B9D;
  color: #fff;
}
 
.gmtv-tag-accent {
  background: #FFA94D;
  color: #fff;
}
 
.gmtv-badge-win {
  display: inline-block;
  background: #E6F9EE;
  color: #1E8A47;
  padding: 1px 10px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
}
 
.gmtv-badge-loss {
  display: inline-block;
  background: #FDEAEA;
  color: #C0392B;
  padding: 1px 10px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
}
 
.gmtv-badge-draw {
  display: inline-block;
  background: #F0F0F0;
  color: #666666;
  padding: 1px 10px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
}
 
 
/* ──────────────────────────────────────────
  8. 数据表格(战绩、技能、装备)
  重置 Citizen wikitable 默认样式
────────────────────────────────────────── */
.gmtv-character .gmtv-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  border: none !important;
  background: none !important;
  margin: 0 !important;
}
 
.gmtv-character .gmtv-table th {
  background: var(--c-head-bg) !important;
  color: var(--c-primary) !important;
  padding: 8px 12px !important;
  text-align: left !important;
  font-weight: 700 !important;
  border-bottom: 2px solid var(--c-border) !important;
  border-right: none !important;
  border-top: none !important;
  border-left: none !important;
  white-space: nowrap;
}
 
.gmtv-character .gmtv-table td {
  padding: 8px 12px !important;
  border-bottom: 1px solid var(--c-border) !important;
  border-right: none !important;
  border-top: none !important;
  border-left: none !important;
  color: var(--c-text) !important;
  vertical-align: top;
}
 
.gmtv-character .gmtv-table tr:last-child td {
  border-bottom: none !important;
}
 
.gmtv-character .gmtv-table a,
.gmtv-character .gmtv-table a:visited {
  color: var(--c-primary);
  text-decoration: none;
}
 
.gmtv-character .gmtv-table a:hover {
  color: var(--c-accent);
}
 
/* wikitable 污染防护 */
.gmtv-character .wikitable.gmtv-table,
.gmtv-character .wikitable.gmtv-table > tbody > tr > th,
.gmtv-character .wikitable.gmtv-table > tbody > tr > td {
  background: none !important;
  border-color: var(--c-border) !important;
}
 
.gmtv-card-body-table {
  padding: 0 16px !important;
  overflow-x: auto;
  overflow-y: visible;
  display: block;
  box-sizing: border-box;
 
}
 
/* 表格本身宽度撑满容器,padding 由容器控制 */
.gmtv-card-body-table .gmtv-table,
.gmtv-card-body-table table {
  width: 100% !important;
  margin: 0 !important;
}
 
/* th/td 左右 padding 恢复正常,不需要再单独控制首尾列 */
.gmtv-card-body-table .gmtv-table th {
  padding: 8px 12px !important;
}
 
.gmtv-card-body-table .gmtv-table td {
  padding: 8px 12px !important;
}
 
/* 表格顶部加一点间距,不和卡片头部紧贴 */
.gmtv-card-body-table .gmtv-table,
.gmtv-card-body-table table.wikitable {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
 
.gmtv-card-body h2,
.gmtv-card-body h3,
.gmtv-card-body h4 {
  padding-left: 2px !important;
  margin-top: 18px !important;
  margin-bottom: 8px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--c-text) !important;
  border-bottom: 1px solid var(--c-border) !important;
  padding-bottom: 6px !important;
}
 
/* 卡片内第一个标题不需要顶部间距 */
.gmtv-card-body h2:first-child,
.gmtv-card-body h3:first-child,
.gmtv-card-body h4:first-child {
  margin-top: 4px !important;
}
 
/* 卡片内段落间距 */
.gmtv-card-body p {
  margin-top: 0 !important;
  margin-bottom: 10px !important;
}
 
.gmtv-card-body p:last-child {
  margin-bottom: 0 !important;
}
 
 
/* ──────────────────────────────────────────
  9. 境界进度条
  动画:用 transition 替代 @keyframes
  宽度通过内联 style="width:xx%" 控制
────────────────────────────────────────── */
.gmtv-realm-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
 
.gmtv-realm-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
 
.gmtv-realm-name {
  font-size: 12px;
  color: var(--c-text);
  font-weight: 600;
  width: 72px;
  flex-shrink: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
 
.gmtv-realm-track {
  flex: 1;
  height: 8px;
  background: var(--c-border);
  border-radius: 10px;
  overflow: hidden;
  min-width: 0px;
}
 
.gmtv-realm-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  border-radius: 10px;
  transition: width 1s ease;
}
 
.gmtv-realm-label {
  font-size: 11px;
  color: var(--c-sub);
  width: 40px;
  text-align: right;
  flex-shrink: 0;
  white-space: nowrap;
}
 
/* 当前境界行高亮 */
.gmtv-realm-row.current .gmtv-realm-name {
  color: var(--c-primary);
}
 
.gmtv-realm-row.current .gmtv-realm-fill {
  background: #FFA94D;
}
 
.gmtv-realm-row.current .gmtv-realm-label {
  color: var(--c-primary);
  font-weight: 700;
}
 
 
/* ──────────────────────────────────────────
  10. 人物关系网格
────────────────────────────────────────── */
.gmtv-rel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 10px;
}
 
.gmtv-rel-card {
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  padding: 12px 8px;
  text-align: center;
  transition: border-color 0.2s, box-shadow 0.2s;
}
 
.gmtv-rel-card:hover {
  border-color: #FF6B9D;
  box-shadow: 0 2px 10px rgba(255, 107, 157, 0.15);
}
 
.gmtv-rel-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  margin: 0 auto 8px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
}
 
.gmtv-rel-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
 
.gmtv-rel-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--c-text);
  margin-bottom: 3px;
}
}


/* 顶栏:角色名与一句话身份定位 */
.gmtv-rel-name a,
.gmtv-char-infobox-header {
.gmtv-rel-name a:visited {
    background: linear-gradient(135deg, #7e22ce 0%, #a855f7 100%);
  color: var(--c-text);
    color: #ffffff;
  text-decoration: none;
    padding: 20px;
    text-align: center;
}
}
.gmtv-char-infobox-title {
 
    font-size: 1.5em;
.gmtv-rel-name a:hover {
    font-weight: 800;
  color: var(--c-primary);
    margin-bottom: 4px;
    letter-spacing: 1px;
}
}
.gmtv-char-infobox-quote {
 
    font-size: 0.85em;
.gmtv-rel-type {
    opacity: 0.85;
  font-size: 10px;
    font-style: italic;
  color: var(--c-primary);
  font-weight: 600;
}
}


/* Infobox 数据行布局 */
 
.gmtv-char-infobox-section {
/* ──────────────────────────────────────────
    padding: 12px 20px;
  11. 台词引用块
    background-color: #faf5ff;
────────────────────────────────────────── */
    color: #7e22ce;
.gmtv-quote {
    font-weight: bold;
  border-left: 3px solid var(--c-primary);
    font-size: 1.05em;
  background: var(--c-head-bg);
    border-top: 1px solid #f3e8ff;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    border-bottom: 1px solid #f3e8ff;
  padding: 12px 16px;
  margin: 10px 0;
  position: relative;
}
}
.gmtv-char-infobox-row {
 
    display: flex;
.gmtv-quote-text {
    padding: 10px 20px;
  font-size: 13.5px;
    border-bottom: 1px dashed #f0f0f0;
  color: var(--c-text);
  font-style: italic;
  line-height: 1.8;
  margin: 0 0 6px;
}
}
.gmtv-char-infobox-row:last-child {
 
    border-bottom: none;
.gmtv-quote-source {
  font-size: 11px;
  color: var(--c-sub);
  text-align: right;
}
}
.gmtv-char-infobox-label {
 
    flex: 0 0 85px;
 
    color: #666666;
/* ──────────────────────────────────────────
    font-weight: 500;
  12. 原著 vs 动漫对比
────────────────────────────────────────── */
.gmtv-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 4px;
}
}
.gmtv-char-infobox-data {
 
    flex: 1;
.gmtv-compare-col {
    color: #2c3e50;
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
}


/* 词条内专属链接交互(双圆弧线动态特效) */
.gmtv-compare-head {
.gmtv-char-infobox-data a,
  padding: 7px 12px;
.relation-name a,
  font-size: 12px;
.gmtv-data-table a {
  font-weight: 700;
    position: relative;
  text-align: center;
    transition: color 0.3s ease;
    overflow: visible;
    text-decoration: none;
    color: #7e22ce;
    font-weight: 500;
}
}
.gmtv-char-infobox-data a::before, .gmtv-char-infobox-data a::after,
 
.relation-name a::before, .relation-name a::after,
.gmtv-compare-head-novel {
.gmtv-data-table a::before, .gmtv-data-table a::after {
  background: var(--c-tag-bg);
    content: "";
  color: var(--c-tag-text);
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 14px;
    height: 80%;
    border: 2px solid transparent;
    border-radius: 50%;
    opacity: 0;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    pointer-events: none;
}
}
.gmtv-char-infobox-data a::before, .relation-name a::before, .gmtv-data-table a::before {  
 
    left: 0; border-left-color: #7e22ce;  
.gmtv-compare-head-anime {
  background: #FFEAE0;
  color: #FF6B9D;
}
}
.gmtv-char-infobox-data a::after, .relation-name a::after, .gmtv-data-table a::after {
 
    right: 0; border-right-color: #7e22ce;  
.gmtv-compare-body {
  padding: 10px 12px;
  font-size: 12.5px;
  color: var(--c-text);
  line-height: 1.7;
}
}
.gmtv-char-infobox-data a:hover::before, .relation-name a:hover::before, .gmtv-data-table a:hover::before {
 
    left: -6px; opacity: 1;  
 
/* ──────────────────────────────────────────
  13. Navbox 底部导航
────────────────────────────────────────── */
.gmtv-navbox {
  background: var(--c-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  margin-top: 14px;
  font-size: 12.5px;
}
}
.gmtv-char-infobox-data a:hover::after, .relation-name a:hover::after, .gmtv-data-table a:hover::after {
 
    right: -6px; opacity: 1;  
.gmtv-navbox-title {
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  padding: 10px 16px;
  text-align: center;
}
}


/* --- 2. 可视化境界进度条 (Pure CSS) --- */
.gmtv-navbox-row {
.gmtv-realm-container {
  display: flex;
    margin: 20px 0;
  align-items: flex-start;
    padding: 16px;
  padding: 8px 14px;
    background-color: #faf5ff;
  border-bottom: 1px solid var(--c-border);
    border-radius: 8px;
  gap: 12px;
    border: 1px solid #f3e8ff;
}
}
.gmtv-realm-header {
 
    display: flex;
.gmtv-navbox-row:last-child {
    justify-content: space-between;
  border-bottom: none;
    margin-bottom: 8px;
    font-size: 0.9em;
    font-weight: bold;
    color: #4527a0;
}
}
.gmtv-progress-track {
 
    width: 100%;
.gmtv-navbox-group {
    height: 12px;
  color: var(--c-primary);
    background-color: #e5e5e5;
  font-weight: 700;
    border-radius: 6px;
  min-width: 56px;
    overflow: hidden;
  flex-shrink: 0;
    box-shadow: inset 0 1px 3px rgba(0,0,0,0.1);
  padding-top: 1px;
}
}
.gmtv-progress-fill {
 
    height: 100%;
.gmtv-navbox-links {
    background: linear-gradient(90deg, #7e22ce, #d946ef);
  flex: 1;
    border-radius: 6px;
  color: var(--c-text);
    transition: width 1s cubic-bezier(0.4, 0, 0.2, 1);
  line-height: 1.8;
    /* 配合 style="width: XX%" 实现动态填满效果 */
}
}


/* --- 3. 战绩与技能数据表格重构 --- */
.gmtv-navbox-links a,
.gmtv-data-table {
.gmtv-navbox-links a:visited {
    width: 100%;
  color: var(--c-primary);
    border-collapse: collapse;
  text-decoration: none;
    margin: 20px 0;
  margin-right: 2px;
    background-color: #ffffff;
    box-shadow: 0 2px 12px rgba(126, 34, 206, 0.05);
    border-radius: 8px;
    overflow: hidden; /* 配合圆角生效 */
}
}
.gmtv-data-table th {
 
    background-color: #f3e8ff;
.gmtv-navbox-links a:hover {
    color: #7e22ce;
  color: var(--c-accent);
    padding: 14px 16px;
  text-decoration: underline;
    text-align: left;
    font-weight: bold;
    border-bottom: 2px solid #e9d5ff;
}
}
.gmtv-data-table td {
 
    padding: 12px 16px;
 
    border-bottom: 1px solid #f0f0f0;
/* ──────────────────────────────────────────
    color: #2c3e50;
  14. 正文内链
    font-size: 0.95em;
────────────────────────────────────────── */
    vertical-align: middle;
.gmtv-card-body a,
.gmtv-card-body a:visited {
  color: var(--c-primary);
  text-decoration: none;
  border-bottom: 1px solid #FFD0E0;
  transition: color 0.15s, border-color 0.15s;
}
}
.gmtv-data-table tr:last-child td {
 
    border-bottom: none;
.gmtv-card-body a:hover {
  color: var(--c-accent);
  border-bottom-color: var(--c-accent);
}
}
.gmtv-data-table tbody tr {
 
    transition: background-color 0.2s ease;
 
/* ──────────────────────────────────────────
  15. mw-collapsible 按钮样式
────────────────────────────────────────── */
/* 追加到 styles.css 末尾 */
 
.gmtv-card {
  position: relative;
}
}
.gmtv-data-table tbody tr:hover {
 
    background-color: #faf5ff; /* 悬浮整行高亮指示 */
.gmtv-character .mw-collapsible-toggle,
.gmtv-character button.mw-collapsible-toggle {
  position: absolute;
  top: 10px;
  right: 14px;
  float: none;
  margin: 0;
  z-index: 1;
  background: rgba(255, 107, 157, 0.1) !important;
  color: #FF6B9D !important;
  border: 1px solid rgba(255, 107, 157, 0.3) !important;
  border-radius: 20px !important;
  padding: 3px 12px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  cursor: pointer;
  white-space: nowrap;
  line-height: 1.4;
}
}


/* 战果特殊标记 */
.gmtv-character .mw-collapsible-toggle:hover,
.gmtv-result-win {
.gmtv-character button.mw-collapsible-toggle:hover {
    color: #16a34a;
  background: rgba(255, 107, 157, 0.2) !important;
    font-weight: bold;
  border-color: #FF6B9D !important;
    background: #dcfce7;
    padding: 2px 8px;
    border-radius: 4px;
}
}
.gmtv-result-loss {
 
    color: #dc2626;
.gmtv-card:not(.mw-collapsed) .mw-collapsible-toggle,
    font-weight: bold;
.gmtv-card:not(.mw-collapsed) button.mw-collapsible-toggle {
    background: #fee2e2;
  background: rgba(255, 169, 77, 0.1) !important;
    padding: 2px 8px;
  color: #FFA94D !important;
    border-radius: 4px;
  border-color: rgba(255, 169, 77, 0.3) !important;
}
}
.gmtv-result-draw {
 
    color: #d97706;
.gmtv-card:not(.mw-collapsed) .mw-collapsible-toggle:hover,
    font-weight: bold;
.gmtv-card:not(.mw-collapsed) button.mw-collapsible-toggle:hover {
    background: #fef3c7;
  background: rgba(255, 169, 77, 0.2) !important;
    padding: 2px 8px;
  border-color: #FFA94D !important;
    border-radius: 4px;
}
}


/* --- 4. 人物关系网络图谱 (CSS Grid 卡片流) --- */
.gmtv-character .mw-collapsible-toggle:focus,
.gmtv-relation-grid {
.gmtv-character button.mw-collapsible-toggle:focus {
    display: grid;
  outline: none;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 16px;
    margin: 20px 0;
}
}
.gmtv-relation-card {
 
    background-color: #ffffff;
 
    border: 1px solid #f3e8ff;
 
    border-radius: 8px;
 
    padding: 16px 12px;
/* ──────────────────────────────────────────
    text-align: center;
  16. Citizen 皮肤冲突覆盖
    box-shadow: 0 2px 8px rgba(0,0,0,0.02);
────────────────────────────────────────── */
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
.gmtv-character .floatright {
  float: none !important;
  margin: 0 !important;
  clear: none !important;
}
}
.gmtv-relation-card:hover {
 
    transform: translateY(-4px);
.gmtv-character table.gmtv-table {
    border-color: #a855f7;
  border: none !important;
    box-shadow: 0 8px 16px rgba(126, 34, 206, 0.08);
  border-collapse: collapse !important;
}
}
.relation-label {
 
     font-size: 0.8em;
 
     color: #888888;
/* ──────────────────────────────────────────
     margin-bottom: 6px;
  17. 响应式:移动端
     text-transform: uppercase;
────────────────────────────────────────── */
     letter-spacing: 1px;
@media screen and (max-width: 768px) {
 
  .gmtv-body {
    flex-direction: column;
  }
 
  .gmtv-sidebar {
    width: 100%;
    position: static;
  }
 
  .gmtv-hero {
    padding: 16px;
    gap: 12px;
  }
 
  .gmtv-hero-avatar {
    width: 54px;
    height: 54px;
     font-size: 26px;
  }
 
  .gmtv-hero-name {
     font-size: 20px;
  }
 
  .gmtv-compare {
     grid-template-columns: 1fr;
  }
 
  .gmtv-rel-grid {
     grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
     gap: 8px;
  }
}
}
.relation-name {
 
     font-size: 1.1em;
@media screen and (max-width: 480px) {
     font-weight: bold;
 
  .gmtv-hero {
    flex-direction: column;
    align-items: flex-start;
  }
 
  .gmtv-card-body {
    padding: 12px;
  }
 
  .gmtv-infobox-row {
     flex-direction: column;
    gap: 2px;
  }
 
  .gmtv-infobox-key {
    min-width: 0;
     font-size: 11px;
  }
}
}

2026年6月4日 (四) 00:51的最新版本

/* ──────────────────────────────────────────
   1. 最外层容器
   限制最大宽度,禁止全屏撑满
────────────────────────────────────────── */
.gmtv-character {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0;
  /*background: var(--c-bg);*/
  font-family: 'PingFang SC', 'Noto Sans SC', 'Microsoft YaHei', sans-serif;
  color: var(--c-text);
  line-height: 1.8;
}


/* ──────────────────────────────────────────
   2. 顶部英雄标题区
────────────────────────────────────────── */
.gmtv-hero {
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  border-radius: var(--radius-card);
  padding: 22px 24px;
  margin-bottom: 18px;
  display: flex;
  align-items: flex-start;
  gap: 18px;
  color: #fff;
  position: relative;
  overflow: hidden;
}

/* 装饰光晕 */
.gmtv-hero::before {
  content: '';
  position: absolute;
  top: -40px;
  right: -40px;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  pointer-events: none;
}

.gmtv-hero-avatar {
  width: 72px;
  height: 72px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.25);
  border: 2px solid rgba(255, 255, 255, 0.4);
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
}

.gmtv-hero-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.gmtv-hero-info {
  flex: 1;
  min-width: 0;
}

.gmtv-hero-name {
  font-size: 26px;
  font-weight: 900;
  letter-spacing: 2px;
  line-height: 1.2;
  margin: 0 0 4px;
}

.gmtv-hero-sub {
  font-size: 13px;
  opacity: 0.88;
  margin: 0 0 10px;
}

.gmtv-hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.gmtv-hero-tag {
  background: rgba(255, 255, 255, 0.22);
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-radius: 20px;
  padding: 2px 12px;
  font-size: 11px;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
}


/* ──────────────────────────────────────────
   3. 主体双栏布局
   PC:左侧 Infobox(260px) + 右侧卡片流
   移动端:单栏,Infobox 在上
────────────────────────────────────────── */
.gmtv-body {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.gmtv-sidebar {
  width: 260px;
  flex-shrink: 0;
  position: sticky;
  top: 72px;
}

.gmtv-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}


/* ──────────────────────────────────────────
   4. Infobox
   重置 Citizen 皮肤对 table/infobox 的默认干扰
────────────────────────────────────────── */
.gmtv-character .gmtv-infobox,
.gmtv-character .gmtv-infobox table,
.gmtv-character .gmtv-infobox td,
.gmtv-character .gmtv-infobox th {
  border: none !important;
  background: none !important;
  padding: 0 !important;
  margin: 0 !important;
  float: none !important;
  width: auto !important;
}

.gmtv-infobox {
  background: var(--c-card) !important;
  border-radius: var(--radius-card) !important;
  border: 1px solid var(--c-border) !important;
  overflow: hidden;
  box-shadow: var(--shadow-card);
  width: 100% !important;
}

.gmtv-infobox-head {
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 10px 14px;
  text-align: center;
}

.gmtv-infobox-img {
  width: 100%;
  max-height: 280px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--c-head-bg);
  border-bottom: 1px solid var(--c-border);
}

.gmtv-infobox-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.gmtv-infobox-img-placeholder {
  width: 100%;
  height: 180px;
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 56px;
}

.gmtv-infobox-group {
  background: var(--c-head-bg);
  color: var(--c-primary);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 7px 14px;
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
}

.gmtv-infobox-row {
  display: flex;
  align-items: flex-start;
  padding: 8px 14px;
  border-bottom: 1px solid var(--c-border);
  gap: 8px;
  font-size: 12.5px;
}

.gmtv-infobox-row:last-child {
  border-bottom: none;
}

.gmtv-infobox-key {
  color: var(--c-sub);
  min-width: 58px;
  flex-shrink: 0;
  padding-top: 1px;
  font-size: 12px;
}

.gmtv-infobox-val {
  color: var(--c-text);
  font-weight: 500;
  flex: 1;
  word-break: break-all;
}

.gmtv-infobox-val a,
.gmtv-infobox-val a:visited {
  color: var(--c-primary);
  text-decoration: none;
  font-weight: 600;
}

.gmtv-infobox-val a:hover {
  color: var(--c-accent);
  text-decoration: underline;
}


/* ──────────────────────────────────────────
   5. 通用卡片
────────────────────────────────────────── */
.gmtv-card {
  background: var(--c-card);
  border-radius: var(--radius-card);
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow-card);
  overflow: visible;
  isolation: isolate;
}

.gmtv-card-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: var(--c-head-bg);
  border-bottom: 1px solid var(--c-border);
  cursor: pointer;
  user-select: none;
}

/* 左侧色点装饰 */
.gmtv-card-head::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  flex-shrink: 0;
}

.gmtv-card-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--c-text);
  flex: 1;
}

.gmtv-card-body {
  padding: 16px;
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--c-text);
}

/* 折叠后:隐藏底边框,避免出现空色块 */
.gmtv-card.mw-collapsed .gmtv-card-head {
  border-bottom: none;
  border-radius: calc(var(--radius-card) - 1px);
}

/* 折叠后卡片 overflow 改为 visible,圆角不被截断 */
.gmtv-card.mw-collapsed {
  overflow: visible;
}

/* 折叠状态下强制隐藏 p 标签防止撑开空白 */
.gmtv-card.mw-collapsed p {
  display: none;
}


/* ──────────────────────────────────────────
   6. 剧透卡片(默认折叠 + 自动角标)
────────────────────────────────────────── */
.gmtv-card-spoiler .gmtv-card-head {
  background: #FFF0F5;
}

/* 折叠状态:显示"含剧透"角标 */
.gmtv-card-spoiler.mw-collapsed .gmtv-card-title::after {
  content: '⚠ 含剧透';
  font-size: 10px;
  font-weight: 600;
  color: #FF6B9D;
  background: #FFE0EC;
  border: 1px solid #FFB3CC;
  border-radius: 8px;
  padding: 1px 7px;
  margin-left: 8px;
  vertical-align: middle;
}

/* 展开状态:角标变为"剧透已展开" */
.gmtv-card-spoiler:not(.mw-collapsed) .gmtv-card-title::after {
  content: '▼ 剧透已展开';
  font-size: 10px;
  font-weight: 600;
  color: #FFA94D;
  background: #FFEAE0;
  border: 1px solid #FFD0A0;
  border-radius: 8px;
  padding: 1px 7px;
  margin-left: 8px;
  vertical-align: middle;
}


/* ──────────────────────────────────────────
   7. 标签 / Badge
────────────────────────────────────────── */
.gmtv-tag {
  display: inline-block;
  background: var(--c-tag-bg);
  color: var(--c-tag-text);
  border-radius: 20px;
  padding: 2px 11px;
  font-size: 11px;
  font-weight: 600;
  margin: 2px 3px 2px 0;
  white-space: nowrap;
}

.gmtv-tag-primary {
  background: #FF6B9D;
  color: #fff;
}

.gmtv-tag-accent {
  background: #FFA94D;
  color: #fff;
}

.gmtv-badge-win {
  display: inline-block;
  background: #E6F9EE;
  color: #1E8A47;
  padding: 1px 10px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
}

.gmtv-badge-loss {
  display: inline-block;
  background: #FDEAEA;
  color: #C0392B;
  padding: 1px 10px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
}

.gmtv-badge-draw {
  display: inline-block;
  background: #F0F0F0;
  color: #666666;
  padding: 1px 10px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
}


/* ──────────────────────────────────────────
   8. 数据表格(战绩、技能、装备)
   重置 Citizen wikitable 默认样式
────────────────────────────────────────── */
.gmtv-character .gmtv-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  border: none !important;
  background: none !important;
  margin: 0 !important;
}

.gmtv-character .gmtv-table th {
  background: var(--c-head-bg) !important;
  color: var(--c-primary) !important;
  padding: 8px 12px !important;
  text-align: left !important;
  font-weight: 700 !important;
  border-bottom: 2px solid var(--c-border) !important;
  border-right: none !important;
  border-top: none !important;
  border-left: none !important;
  white-space: nowrap;
}

.gmtv-character .gmtv-table td {
  padding: 8px 12px !important;
  border-bottom: 1px solid var(--c-border) !important;
  border-right: none !important;
  border-top: none !important;
  border-left: none !important;
  color: var(--c-text) !important;
  vertical-align: top;
}

.gmtv-character .gmtv-table tr:last-child td {
  border-bottom: none !important;
}

.gmtv-character .gmtv-table a,
.gmtv-character .gmtv-table a:visited {
  color: var(--c-primary);
  text-decoration: none;
}

.gmtv-character .gmtv-table a:hover {
  color: var(--c-accent);
}

/* wikitable 污染防护 */
.gmtv-character .wikitable.gmtv-table,
.gmtv-character .wikitable.gmtv-table > tbody > tr > th,
.gmtv-character .wikitable.gmtv-table > tbody > tr > td {
  background: none !important;
  border-color: var(--c-border) !important;
}

.gmtv-card-body-table {
  padding: 0 16px !important;
  overflow-x: auto;
  overflow-y: visible;
  display: block;
  box-sizing: border-box;
  
}

/* 表格本身宽度撑满容器,padding 由容器控制 */
.gmtv-card-body-table .gmtv-table,
.gmtv-card-body-table table {
  width: 100% !important;
  margin: 0 !important;
}

/* th/td 左右 padding 恢复正常,不需要再单独控制首尾列 */
.gmtv-card-body-table .gmtv-table th {
  padding: 8px 12px !important;
}

.gmtv-card-body-table .gmtv-table td {
  padding: 8px 12px !important;
}

/* 表格顶部加一点间距,不和卡片头部紧贴 */
.gmtv-card-body-table .gmtv-table,
.gmtv-card-body-table table.wikitable {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.gmtv-card-body h2,
.gmtv-card-body h3,
.gmtv-card-body h4 {
  padding-left: 2px !important;
  margin-top: 18px !important;
  margin-bottom: 8px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--c-text) !important;
  border-bottom: 1px solid var(--c-border) !important;
  padding-bottom: 6px !important;
}

/* 卡片内第一个标题不需要顶部间距 */
.gmtv-card-body h2:first-child,
.gmtv-card-body h3:first-child,
.gmtv-card-body h4:first-child {
  margin-top: 4px !important;
}

/* 卡片内段落间距 */
.gmtv-card-body p {
  margin-top: 0 !important;
  margin-bottom: 10px !important;
}

.gmtv-card-body p:last-child {
  margin-bottom: 0 !important;
}


/* ──────────────────────────────────────────
   9. 境界进度条
   动画:用 transition 替代 @keyframes
   宽度通过内联 style="width:xx%" 控制
────────────────────────────────────────── */
.gmtv-realm-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.gmtv-realm-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.gmtv-realm-name {
  font-size: 12px;
  color: var(--c-text);
  font-weight: 600;
  width: 72px;
  flex-shrink: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gmtv-realm-track {
  flex: 1;
  height: 8px;
  background: var(--c-border);
  border-radius: 10px;
  overflow: hidden;
  min-width: 0px;
}

.gmtv-realm-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  border-radius: 10px;
  transition: width 1s ease;
}

.gmtv-realm-label {
  font-size: 11px;
  color: var(--c-sub);
  width: 40px;
  text-align: right;
  flex-shrink: 0;
  white-space: nowrap;
}

/* 当前境界行高亮 */
.gmtv-realm-row.current .gmtv-realm-name {
  color: var(--c-primary);
}

.gmtv-realm-row.current .gmtv-realm-fill {
  background: #FFA94D;
}

.gmtv-realm-row.current .gmtv-realm-label {
  color: var(--c-primary);
  font-weight: 700;
}


/* ──────────────────────────────────────────
   10. 人物关系网格
────────────────────────────────────────── */
.gmtv-rel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 10px;
}

.gmtv-rel-card {
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  padding: 12px 8px;
  text-align: center;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.gmtv-rel-card:hover {
  border-color: #FF6B9D;
  box-shadow: 0 2px 10px rgba(255, 107, 157, 0.15);
}

.gmtv-rel-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  margin: 0 auto 8px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
}

.gmtv-rel-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.gmtv-rel-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--c-text);
  margin-bottom: 3px;
}

.gmtv-rel-name a,
.gmtv-rel-name a:visited {
  color: var(--c-text);
  text-decoration: none;
}

.gmtv-rel-name a:hover {
  color: var(--c-primary);
}

.gmtv-rel-type {
  font-size: 10px;
  color: var(--c-primary);
  font-weight: 600;
}


/* ──────────────────────────────────────────
   11. 台词引用块
────────────────────────────────────────── */
.gmtv-quote {
  border-left: 3px solid var(--c-primary);
  background: var(--c-head-bg);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: 12px 16px;
  margin: 10px 0;
  position: relative;
}

.gmtv-quote-text {
  font-size: 13.5px;
  color: var(--c-text);
  font-style: italic;
  line-height: 1.8;
  margin: 0 0 6px;
}

.gmtv-quote-source {
  font-size: 11px;
  color: var(--c-sub);
  text-align: right;
}


/* ──────────────────────────────────────────
   12. 原著 vs 动漫对比
────────────────────────────────────────── */
.gmtv-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 4px;
}

.gmtv-compare-col {
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.gmtv-compare-head {
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 700;
  text-align: center;
}

.gmtv-compare-head-novel {
  background: var(--c-tag-bg);
  color: var(--c-tag-text);
}

.gmtv-compare-head-anime {
  background: #FFEAE0;
  color: #FF6B9D;
}

.gmtv-compare-body {
  padding: 10px 12px;
  font-size: 12.5px;
  color: var(--c-text);
  line-height: 1.7;
}


/* ──────────────────────────────────────────
   13. Navbox 底部导航
────────────────────────────────────────── */
.gmtv-navbox {
  background: var(--c-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  margin-top: 14px;
  font-size: 12.5px;
}

.gmtv-navbox-title {
  background: linear-gradient(135deg, var(--c-gradient-start) 0%, var(--c-gradient-end) 100%);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  padding: 10px 16px;
  text-align: center;
}

.gmtv-navbox-row {
  display: flex;
  align-items: flex-start;
  padding: 8px 14px;
  border-bottom: 1px solid var(--c-border);
  gap: 12px;
}

.gmtv-navbox-row:last-child {
  border-bottom: none;
}

.gmtv-navbox-group {
  color: var(--c-primary);
  font-weight: 700;
  min-width: 56px;
  flex-shrink: 0;
  padding-top: 1px;
}

.gmtv-navbox-links {
  flex: 1;
  color: var(--c-text);
  line-height: 1.8;
}

.gmtv-navbox-links a,
.gmtv-navbox-links a:visited {
  color: var(--c-primary);
  text-decoration: none;
  margin-right: 2px;
}

.gmtv-navbox-links a:hover {
  color: var(--c-accent);
  text-decoration: underline;
}


/* ──────────────────────────────────────────
   14. 正文内链
────────────────────────────────────────── */
.gmtv-card-body a,
.gmtv-card-body a:visited {
  color: var(--c-primary);
  text-decoration: none;
  border-bottom: 1px solid #FFD0E0;
  transition: color 0.15s, border-color 0.15s;
}

.gmtv-card-body a:hover {
  color: var(--c-accent);
  border-bottom-color: var(--c-accent);
}


/* ──────────────────────────────────────────
   15. mw-collapsible 按钮样式
────────────────────────────────────────── */
/* 追加到 styles.css 末尾 */

.gmtv-card {
  position: relative;
}

.gmtv-character .mw-collapsible-toggle,
.gmtv-character button.mw-collapsible-toggle {
  position: absolute;
  top: 10px;
  right: 14px;
  float: none;
  margin: 0;
  z-index: 1;
  background: rgba(255, 107, 157, 0.1) !important;
  color: #FF6B9D !important;
  border: 1px solid rgba(255, 107, 157, 0.3) !important;
  border-radius: 20px !important;
  padding: 3px 12px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  cursor: pointer;
  white-space: nowrap;
  line-height: 1.4;
}

.gmtv-character .mw-collapsible-toggle:hover,
.gmtv-character button.mw-collapsible-toggle:hover {
  background: rgba(255, 107, 157, 0.2) !important;
  border-color: #FF6B9D !important;
}

.gmtv-card:not(.mw-collapsed) .mw-collapsible-toggle,
.gmtv-card:not(.mw-collapsed) button.mw-collapsible-toggle {
  background: rgba(255, 169, 77, 0.1) !important;
  color: #FFA94D !important;
  border-color: rgba(255, 169, 77, 0.3) !important;
}

.gmtv-card:not(.mw-collapsed) .mw-collapsible-toggle:hover,
.gmtv-card:not(.mw-collapsed) button.mw-collapsible-toggle:hover {
  background: rgba(255, 169, 77, 0.2) !important;
  border-color: #FFA94D !important;
}

.gmtv-character .mw-collapsible-toggle:focus,
.gmtv-character button.mw-collapsible-toggle:focus {
  outline: none;
}




/* ──────────────────────────────────────────
   16. Citizen 皮肤冲突覆盖
────────────────────────────────────────── */
.gmtv-character .floatright {
  float: none !important;
  margin: 0 !important;
  clear: none !important;
}

.gmtv-character table.gmtv-table {
  border: none !important;
  border-collapse: collapse !important;
}


/* ──────────────────────────────────────────
   17. 响应式:移动端
────────────────────────────────────────── */
@media screen and (max-width: 768px) {

  .gmtv-body {
    flex-direction: column;
  }

  .gmtv-sidebar {
    width: 100%;
    position: static;
  }

  .gmtv-hero {
    padding: 16px;
    gap: 12px;
  }

  .gmtv-hero-avatar {
    width: 54px;
    height: 54px;
    font-size: 26px;
  }

  .gmtv-hero-name {
    font-size: 20px;
  }

  .gmtv-compare {
    grid-template-columns: 1fr;
  }

  .gmtv-rel-grid {
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: 8px;
  }
}

@media screen and (max-width: 480px) {

  .gmtv-hero {
    flex-direction: column;
    align-items: flex-start;
  }

  .gmtv-card-body {
    padding: 12px;
  }

  .gmtv-infobox-row {
    flex-direction: column;
    gap: 2px;
  }

  .gmtv-infobox-key {
    min-width: 0;
    font-size: 11px;
  }
}