/**
 * guoman · 国潮琉璃 — 深紫罗兰 + 鎏金 + 琉璃青的国产动漫沉浸主题
 * 玻璃态卡片(backdrop-blur) + 鎏金描边 + backdrop hero；footer_rich 注入已在 TemplatePresenter SELF_FOOTER_THEMES 跳过，自渲染原生页脚
 * 令牌前缀 --cg- / 类前缀 .cg-（零冲突）
 */
:root {
    /* 夜画布 night */
    --cg-night:    #13101f;
    --cg-night-2:  #1c1830;
    --cg-night-3:  #252038;
    --cg-night-4:  #2e2944;
    /* 鎏金 gold（标题/印章/CTA/描边） */
    --cg-gold:   #d4af37;
    --cg-gold-d: #b8941f;
    --cg-gold-t: rgba(212, 175, 55, .14);
    /* 琉璃青 glaze（链接/徽标/信息） */
    --cg-glaze:   #5b8def;
    --cg-glaze-d: #4673cc;
    /* 桃红 rose（热门/评分） */
    --cg-rose:   #ff5e7e;
    --cg-rose-d: #e64768;
    /* 文字 */
    --cg-ink:  #ece8f5;
    --cg-ink-2:#bfb9d8;
    --cg-mute: #9b95b8;
    /* 线 lines */
    --cg-line:   rgba(212, 175, 55, .22);
    --cg-line-2: rgba(212, 175, 55, .10);
    --cg-line-3: rgba(255, 255, 255, .06);
    /* 玻璃态 */
    --cg-glass:    rgba(28, 24, 48, .72);
    --cg-glass-2:  rgba(36, 31, 60, .78);
    /* 光晕 */
    --cg-glow-gold:    0 8px 30px rgba(212, 175, 55, .20);
    --cg-glow-glaze:   0 8px 30px rgba(91, 141, 239, .22);
    --cg-shadow:       0 6px 22px rgba(0, 0, 0, .42);
    --cg-shadow-sm:    0 3px 12px rgba(0, 0, 0, .38);
    /* 半径 */
    --cg-radius:    10px;
    --cg-radius-lg: 16px;
    --cg-radius-sm: 6px;
    /* 字体 */
    --cg-font:  -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "微软雅黑", system-ui, sans-serif;
    --cg-serif: "Noto Serif SC", "Songti SC", "STSong", "SimSun", "宋体", serif;
    --cg-contain: 1240px;
}

/* ============ base ============ */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
    margin: 0;
    background: var(--cg-night);
    color: var(--cg-ink);
    font-family: var(--cg-font);
    font-size: 15px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}
body::before {
    content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none;
    background:
        radial-gradient(900px 600px at 12% -8%, rgba(212,175,55,.10), transparent 60%),
        radial-gradient(800px 600px at 92% 6%, rgba(91,141,239,.12), transparent 60%),
        radial-gradient(700px 700px at 50% 110%, rgba(255,94,126,.07), transparent 60%);
}
img { max-width: 100%; display: block; }
a { color: var(--cg-glaze); text-decoration: none; transition: color .15s; }
a:hover { color: var(--cg-gold); }
h1, h2, h3, h4 { margin: 0; line-height: 1.32; font-weight: 800; color: var(--cg-ink); }
p { margin: 0 0 .6em; }
ul { margin: 0; padding: 0; list-style: none; }
button { font-family: inherit; cursor: pointer; }
input { font-family: inherit; }
:focus-visible { outline: 2px solid var(--cg-gold); outline-offset: 2px; border-radius: 3px; }

.cg-visually-hidden {
    position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.cg-container { width: 100%; max-width: var(--cg-contain); margin: 0 auto; padding: 0 20px; }

/* ============ 按钮 / 胶囊 / 眉标 ============ */
.cg-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 11px 24px; border-radius: var(--cg-radius);
    font-weight: 700; font-size: 15px; line-height: 1; cursor: pointer;
    transition: transform .15s, box-shadow .15s, background .15s, border-color .15s;
    border: 1.5px solid transparent;
}
.cg-btn svg { width: 18px; height: 18px; }
.cg-btn--primary { background: linear-gradient(135deg, var(--cg-gold), var(--cg-gold-d)); color: var(--cg-night); box-shadow: var(--cg-glow-gold); }
.cg-btn--primary:hover { transform: translateY(-2px); color: var(--cg-night); box-shadow: 0 12px 36px rgba(212,175,55,.32); }
.cg-btn--ghost { background: var(--cg-glass); color: var(--cg-ink); border-color: var(--cg-line); backdrop-filter: blur(8px); }
.cg-btn--ghost:hover { border-color: var(--cg-gold); color: var(--cg-gold); transform: translateY(-2px); }

.cg-pill {
    display: inline-flex; align-items: center; padding: 4px 12px;
    background: var(--cg-glass); color: var(--cg-ink-2);
    border: 1px solid var(--cg-line-2); border-radius: 999px;
    font-size: 12.5px; font-weight: 600;
}
.cg-pill--accent { background: var(--cg-rose-d); color: #fff; border-color: transparent; }
.cg-pill--score { background: var(--cg-gold-t); color: var(--cg-gold); border-color: var(--cg-gold); }

.cg-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    color: var(--cg-gold); font-size: 13px; font-weight: 700;
    letter-spacing: .04em; text-transform: uppercase; margin: 0 0 8px;
}
.cg-eyebrow-stamp {
    display: inline-grid; place-items: center; width: 22px; height: 22px;
    background: var(--cg-gold); color: var(--cg-night);
    font-family: var(--cg-serif); font-weight: 900; font-size: 14px;
    border-radius: 4px;
}

/* ============ 顶栏 header ============ */
.cg-header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(19, 16, 31, .82);
    border-bottom: 1px solid var(--cg-line);
    backdrop-filter: saturate(150%) blur(14px);
    transition: box-shadow .2s, background .2s;
}
.cg-header.is-scrolled {
    background: rgba(19, 16, 31, .95);
    box-shadow: 0 4px 0 var(--cg-gold-t);
}
.cg-header-inner {
    max-width: var(--cg-contain); margin: 0 auto;
    display: flex; align-items: center; gap: 18px;
    padding: 0 20px; height: 66px;
}
.cg-logo { display: inline-flex; align-items: center; gap: 10px; color: var(--cg-ink); flex-shrink: 0; }
.cg-logo:hover { color: var(--cg-ink); }
.cg-logo-stamp {
    display: inline-grid; place-items: center;
    width: 38px; height: 38px;
    background: linear-gradient(135deg, var(--cg-gold), var(--cg-gold-d)); color: var(--cg-night);
    font-family: var(--cg-serif); font-weight: 900; font-size: 21px;
    border-radius: 7px;
    box-shadow: var(--cg-glow-gold);
}
.cg-logo-text { font-size: 21px; font-weight: 800; letter-spacing: .02em; }

.cg-nav { display: flex; align-items: center; gap: 4px; flex: 1; min-width: 0; }
.cg-nav-link {
    position: relative; display: inline-flex; align-items: center; gap: 4px;
    padding: 8px 14px; color: var(--cg-ink-2); font-weight: 600; font-size: 15px;
    border-radius: 8px; transition: color .15s, background .15s; white-space: nowrap;
}
.cg-nav-link:hover, .cg-nav-link.is-active { color: var(--cg-gold); background: var(--cg-gold-t); }
.cg-nav-group { position: relative; }
.cg-nav-group-toggle { border: none; background: none; }
.cg-nav-group-arrow { font-size: 10px; opacity: .7; transition: transform .2s; }
.cg-nav-group-toggle[aria-expanded="true"] .cg-nav-group-arrow { transform: rotate(180deg); }
.cg-nav-submenu {
    position: absolute; top: calc(100% + 8px); left: 0; min-width: 168px;
    background: var(--cg-glass-2); border: 1px solid var(--cg-line);
    border-radius: var(--cg-radius); padding: 6px;
    box-shadow: var(--cg-shadow);
    backdrop-filter: blur(16px);
    opacity: 0; visibility: hidden; transform: translateY(-6px);
    transition: opacity .15s, transform .15s, visibility .15s;
}
.cg-nav-group:hover .cg-nav-submenu, .cg-nav-group.is-open .cg-nav-submenu { opacity: 1; visibility: visible; transform: translateY(0); }
.cg-nav-subitem {
    display: block; padding: 9px 12px; color: var(--cg-ink-2);
    border-radius: 6px; font-weight: 600; font-size: 14px;
}
.cg-nav-subitem:hover, .cg-nav-subitem.is-active { color: var(--cg-gold); background: var(--cg-gold-t); }

.cg-search { display: flex; align-items: center; gap: 0; flex-shrink: 0; }
.cg-search-input {
    width: 200px; padding: 9px 14px;
    background: var(--cg-night-3); color: var(--cg-ink);
    border: 1px solid var(--cg-line-2); border-right: none;
    border-radius: var(--cg-radius-sm) 0 0 var(--cg-radius-sm);
    font-size: 14px; outline: none; transition: border-color .15s;
}
.cg-search-input::placeholder { color: var(--cg-mute); }
.cg-search-input:focus { border-color: var(--cg-gold); }
.cg-search-btn {
    display: inline-grid; place-items: center; width: 40px; height: 37px;
    background: linear-gradient(135deg, var(--cg-gold), var(--cg-gold-d)); color: var(--cg-night);
    border: none; border-radius: 0 var(--cg-radius-sm) var(--cg-radius-sm) 0;
    cursor: pointer;
}
.cg-search--mobile { display: none; }

.cg-menu-toggle { display: none; flex-direction: column; gap: 5px; width: 30px; padding: 6px 4px; background: none; border: none; }
.cg-menu-toggle span { height: 2px; width: 100%; background: var(--cg-ink); border-radius: 2px; transition: transform .2s, opacity .2s; }
.cg-menu-toggle.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.cg-menu-toggle.is-open span:nth-child(2) { opacity: 0; }
.cg-menu-toggle.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.cg-scrim { position: fixed; inset: 0; z-index: 90; background: rgba(0,0,0,.6); backdrop-filter: blur(2px); }
.cg-scrim[hidden] { display: none; }

.cg-main { min-height: 60vh; }

/* ============ section / band ============ */
.cg-section { padding: 36px 0; }
.cg-band {
    display: inline-flex; align-items: center;
    background: var(--cg-glass); border: 1px solid var(--cg-line-2);
    border-radius: 999px; padding: 6px 8px 6px 18px; margin-bottom: 18px;
    backdrop-filter: blur(8px);
}
.cg-section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.cg-section-title { font-size: 24px; }
.cg-section-more { color: var(--cg-glaze); font-weight: 700; font-size: 14px; white-space: nowrap; }
.cg-section-more:hover { color: var(--cg-gold); }
.cg-eyebrow--onband { color: var(--cg-gold); margin: 0 14px 0 0; }

/* ============ 横滑行 cg-row ============ */
.cg-row { margin: 0 -20px; padding: 0 20px; overflow-x: auto; scrollbar-width: thin; scrollbar-color: var(--cg-line) transparent; -webkit-overflow-scrolling: touch; }
.cg-row::-webkit-scrollbar { height: 6px; }
.cg-row::-webkit-scrollbar-thumb { background: var(--cg-line); border-radius: 3px; }
.cg-row-track { display: grid; grid-auto-flow: column; grid-auto-columns: 168px; gap: 16px; padding-bottom: 6px; }

/* ============ 卡片 cg-card（玻璃态） ============ */
.cg-card { }
.cg-card-link { display: block; }
.cg-card-poster {
    position: relative; aspect-ratio: 2/3; overflow: hidden;
    border-radius: var(--cg-radius); border: 1px solid var(--cg-line-2);
    background: var(--cg-night-3);
    box-shadow: var(--cg-shadow-sm);
}
.cg-card-poster img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.cg-card-link:hover .cg-card-poster { border-color: var(--cg-gold); box-shadow: var(--cg-glow-gold); transform: translateY(-4px); }
.cg-card-link:hover .cg-card-poster img { transform: scale(1.06); }
.cg-card-badge {
    position: absolute; top: 8px; right: 8px;
    padding: 3px 9px; background: var(--cg-rose-d); color: #fff;
    border-radius: 6px; font-size: 11.5px; font-weight: 700;
    box-shadow: 0 2px 8px rgba(0,0,0,.4); max-width: 80%; text-overflow: ellipsis; overflow: hidden; white-space: nowrap;
}
.cg-card-score {
    position: absolute; bottom: 8px; left: 8px;
    padding: 2px 8px; background: rgba(19,16,31,.78); color: var(--cg-gold);
    border: 1px solid var(--cg-gold); border-radius: 5px;
    font-size: 12px; font-weight: 700; backdrop-filter: blur(4px);
}
.cg-card-play {
    position: absolute; inset: 0; display: grid; place-items: center;
    color: var(--cg-gold); opacity: 0; transition: opacity .2s;
    background: radial-gradient(circle at center, rgba(19,16,31,.5), transparent 70%);
}
.cg-card-link:hover .cg-card-play { opacity: 1; }
.cg-card-play svg { filter: drop-shadow(0 2px 8px rgba(0,0,0,.6)); }
.cg-card-body { padding: 9px 2px 0; }
.cg-card-title {
    font-size: 14.5px; font-weight: 700; line-height: 1.4;
    overflow: hidden; text-overflow: ellipsis; display: -webkit-box;
    -webkit-line-clamp: 1; -webkit-box-orient: vertical;
}
.cg-card-meta { display: flex; gap: 8px; margin-top: 3px; color: var(--cg-mute); font-size: 12px; }

/* ============ 网格 cg-grid ============ */
.cg-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 20px 14px; }
.cg-grid--rel { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }

/* ============ 全部分类 CTA ============ */
.cg-allcat-cta {
    display: flex; align-items: center; gap: 16px; padding: 22px 26px;
    background: var(--cg-glass); border: 1px solid var(--cg-line); border-radius: var(--cg-radius-lg);
    color: var(--cg-ink); transition: border-color .15s, transform .15s;
    backdrop-filter: blur(8px);
}
.cg-allcat-cta:hover { border-color: var(--cg-gold); transform: translateY(-2px); color: var(--cg-ink); }
.cg-allcat-stamp {
    display: inline-grid; place-items: center; width: 48px; height: 48px;
    background: linear-gradient(135deg, var(--cg-gold), var(--cg-gold-d)); color: var(--cg-night);
    font-family: var(--cg-serif); font-weight: 900; font-size: 24px; border-radius: 9px; flex-shrink: 0;
}
.cg-allcat-text { display: flex; flex-direction: column; gap: 3px; }
.cg-allcat-text strong { font-size: 17px; }
.cg-allcat-text em { font-style: normal; color: var(--cg-mute); font-size: 13px; }
.cg-allcat-arrow { margin-left: auto; font-size: 22px; color: var(--cg-gold); }

/* ============ Hero（首页 / 详情） ============ */
.cg-hero {
    position: relative; min-height: 440px; display: flex; align-items: flex-end;
    padding: 0 0 44px; overflow: hidden;
}
.cg-hero-bg {
    position: absolute; inset: 0; background-size: cover; background-position: center;
    filter: blur(2px) brightness(.5); transform: scale(1.06);
}
.cg-hero-screen { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(19,16,31,.4), rgba(19,16,31,.9)); }
.cg-hero-veil { position: absolute; inset: 0; background: radial-gradient(80% 70% at 18% 80%, rgba(212,175,55,.22), transparent 70%); }
.cg-hero-inner { position: relative; width: 100%; max-width: var(--cg-contain); margin: 0 auto; padding: 0 20px; }
.cg-hero-eyebrow { color: var(--cg-gold); }
.cg-hero-title { font-size: 40px; line-height: 1.15; margin: 4px 0 14px; max-width: 760px; text-shadow: 0 2px 16px rgba(0,0,0,.6); }
.cg-hero-meta { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.cg-hero-desc { max-width: 680px; color: var(--cg-ink-2); font-size: 15px; margin: 0 0 18px; }
.cg-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* ============ 详情 hero ============ */
.cg-detail-hero { position: relative; padding: 28px 0 32px; overflow: hidden; }
.cg-detail-hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center; filter: blur(8px) brightness(.32); transform: scale(1.1); }
.cg-detail-hero-screen { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(19,16,31,.6), var(--cg-night)); }
.cg-detail-hero-veil { position: absolute; inset: 0; background: radial-gradient(60% 70% at 12% 30%, rgba(212,175,55,.18), transparent 70%); }
.cg-detail-hero-inner { position: relative; }
.cg-detail-title { font-size: 32px; line-height: 1.2; margin: 10px 0 6px; }
.cg-detail-sub { color: var(--cg-ink-2); margin: 0 0 14px; }
.cg-detail-hook { max-width: 760px; color: var(--cg-ink-2); margin: 14px 0 18px; }

/* detail 双栏 */
.cg-detail-grid { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 28px; padding: 24px 0 40px; }
.cg-detail-main { min-width: 0; }
.cg-detail-aside { display: grid; gap: 18px; align-content: start; }
.cg-aside-poster { border-radius: var(--cg-radius); overflow: hidden; border: 1px solid var(--cg-line); box-shadow: var(--cg-shadow); }
.cg-aside-poster img { width: 100%; aspect-ratio: 2/3; object-fit: cover; }
.cg-aside-play { width: 100%; }

.cg-block { margin: 0 0 30px; }
.cg-panel { background: var(--cg-glass); border: 1px solid var(--cg-line-2); border-radius: var(--cg-radius-lg); padding: 22px; backdrop-filter: blur(8px); }
.cg-block-title { font-size: 19px; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--cg-line-2); }
.cg-block-title--band { display: inline-flex; align-items: center; gap: 8px; border-bottom: none; padding-bottom: 0; }
.cg-block-title--band::before { content: ""; width: 4px; height: 20px; background: linear-gradient(180deg, var(--cg-gold), var(--cg-gold-d)); border-radius: 2px; }

.cg-synopsis { color: var(--cg-ink-2); line-height: 1.85; font-size: 15px; }
.cg-synopsis--short { color: var(--cg-mute); }
.cg-more-link { color: var(--cg-glaze); font-weight: 600; }

/* 详情元信息卡 dl（兼容 _shared/detail_meta_bar 的 pill 风格 + 自有 dl） */
.cg-info-card { background: var(--cg-glass); border: 1px solid var(--cg-line-2); border-radius: var(--cg-radius); padding: 16px; backdrop-filter: blur(8px); }
.cg-info-dl { margin: 0; display: grid; gap: 10px; }
.cg-info-dl > div { display: grid; grid-template-columns: 56px minmax(0, 1fr); gap: 10px; align-items: start; font-size: 14px; }
.cg-info-dl dt { color: var(--cg-mute); font-weight: 600; }
.cg-info-dl dd { margin: 0; color: var(--cg-ink-2); word-break: break-word; }
.cg-info-dl dd a { color: var(--cg-glaze); }
.cg-info-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.cg-info-tags a { padding: 2px 10px; background: var(--cg-night-3); border: 1px solid var(--cg-line-2); border-radius: 999px; font-size: 12.5px; color: var(--cg-ink-2); }
.cg-info-tags a:hover { border-color: var(--cg-gold); color: var(--cg-gold); }

/* ============ 列表页 ============ */
.cg-list-pad { padding: 26px 0 44px; }
.cg-list-head { margin-bottom: 18px; }
.cg-list-title { font-size: 28px; margin: 4px 0 4px; }
.cg-list-sub { color: var(--cg-mute); font-size: 14px; margin: 0; }
.cg-list-sub strong { color: var(--cg-gold); }

.cg-filter { background: var(--cg-glass); border: 1px solid var(--cg-line-2); border-radius: var(--cg-radius); padding: 14px 18px; margin-bottom: 22px; backdrop-filter: blur(8px); }
.cg-filter-row { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; padding: 5px 0; }
.cg-filter-row + .cg-filter-row { border-top: 1px solid var(--cg-line-3); }
.cg-filter-label { width: 44px; color: var(--cg-mute); font-weight: 700; font-size: 13px; flex-shrink: 0; }
.cg-filter-item {
    padding: 5px 13px; border-radius: 999px; color: var(--cg-ink-2);
    font-size: 13.5px; font-weight: 600; border: 1px solid transparent;
}
.cg-filter-item:hover { color: var(--cg-gold); background: var(--cg-gold-t); }
.cg-filter-item.is-active { background: linear-gradient(135deg, var(--cg-gold), var(--cg-gold-d)); color: var(--cg-night); }

.cg-empty { text-align: center; padding: 60px 20px; color: var(--cg-mute); }
.cg-empty p { margin-bottom: 14px; }

/* ============ 分页 ============ */
.cg-pagination { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-top: 28px; }
.cg-page-btn, .cg-page-num {
    display: inline-grid; place-items: center; min-width: 38px; height: 38px; padding: 0 12px;
    background: var(--cg-glass); color: var(--cg-ink-2);
    border: 1px solid var(--cg-line-2); border-radius: 8px;
    font-weight: 700; font-size: 14px; transition: all .15s;
}
.cg-page-btn:hover, .cg-page-num:hover { border-color: var(--cg-gold); color: var(--cg-gold); transform: translateY(-1px); }
.cg-page-num.is-active { background: linear-gradient(135deg, var(--cg-gold), var(--cg-gold-d)); color: var(--cg-night); border-color: transparent; }

/* ============ 播放器 / 选集 ============ */
.cg-play-container { padding-top: 18px; }
.cg-play-back { display: inline-flex; align-items: center; gap: 6px; color: var(--cg-glaze); font-weight: 600; font-size: 14px; }
.cg-play-back:hover { color: var(--cg-gold); }
.cg-play-title { font-size: 26px; margin: 12px 0 4px; }
.cg-play-sub { color: var(--cg-mute); margin: 0 0 16px; font-size: 14px; }
.cg-player-wrap {
    position: relative; width: 100%; aspect-ratio: 16/9; max-height: 72vh;
    background: #000; border-radius: var(--cg-radius); overflow: hidden;
    border: 1px solid var(--cg-line); box-shadow: var(--cg-shadow);
}
.cg-player-wrap--page { aspect-ratio: 16/9; }
.cg-play-empty { color: var(--cg-mute); text-align: center; padding: 40px; }
.cg-nextbar {
    display: flex; align-items: center; justify-content: space-between; gap: 14px;
    margin-top: 16px; padding: 14px 18px;
    background: var(--cg-glass); border: 1px solid var(--cg-line-2); border-radius: var(--cg-radius);
    backdrop-filter: blur(8px); flex-wrap: wrap;
}
.cg-nextbar-info { color: var(--cg-ink-2); font-size: 14px; }
.cg-nextbar-info strong { color: var(--cg-gold); }

.cg-ep-groups { margin-top: 16px; display: grid; gap: 16px; }
.cg-ep-group-title { font-size: 15px; color: var(--cg-ink-2); margin-bottom: 10px; font-weight: 700; }
.cg-ep-list { display: flex; flex-wrap: wrap; gap: 8px; }
.cg-ep {
    padding: 7px 14px; background: var(--cg-night-3); color: var(--cg-ink-2);
    border: 1px solid var(--cg-line-2); border-radius: 7px;
    font-size: 13.5px; font-weight: 600; transition: all .15s;
}
.cg-ep:hover { border-color: var(--cg-gold); color: var(--cg-gold); transform: translateY(-1px); }
.cg-ep.is-active { background: linear-gradient(135deg, var(--cg-gold), var(--cg-gold-d)); color: var(--cg-night); border-color: transparent; }
.cg-play-eps { background: var(--cg-glass); border: 1px solid var(--cg-line-2); border-radius: var(--cg-radius-lg); padding: 20px; backdrop-filter: blur(8px); }

/* ============ 人物页 ============ */
.cg-person-head { padding: 26px 0 8px; }
.cg-person-name { font-size: 30px; margin: 4px 0 4px; }
.cg-person-sub { color: var(--cg-mute); font-size: 14px; margin: 0; }
.cg-person-sub strong { color: var(--cg-gold); }
.cg-person-body { padding: 22px 20px 40px; }

.cg-media-list { display: grid; gap: 14px; }
.cg-media {
    display: grid; grid-template-columns: 120px minmax(0, 1fr); gap: 16px;
    padding: 14px; background: var(--cg-glass); border: 1px solid var(--cg-line-2);
    border-radius: var(--cg-radius); backdrop-filter: blur(8px); transition: border-color .15s;
}
.cg-media:hover { border-color: var(--cg-line); }
.cg-media-poster { position: relative; border-radius: 7px; overflow: hidden; aspect-ratio: 2/3; }
.cg-media-poster img { width: 100%; height: 100%; object-fit: cover; }
.cg-media-badge { position: absolute; bottom: 6px; left: 6px; padding: 2px 7px; background: var(--cg-rose-d); color: #fff; border-radius: 4px; font-size: 11px; font-weight: 700; }
.cg-media-body h3 { font-size: 17px; margin-bottom: 6px; }
.cg-media-body h3 a { color: var(--cg-ink); }
.cg-media-body h3 a:hover { color: var(--cg-gold); }
.cg-media-meta { display: flex; gap: 10px; flex-wrap: wrap; color: var(--cg-mute); font-size: 13px; margin-bottom: 6px; }
.cg-media-score { color: var(--cg-gold); font-weight: 700; }
.cg-media-blurb { color: var(--cg-ink-2); font-size: 14px; margin: 0 0 8px; }
.cg-media-link { color: var(--cg-glaze); font-size: 13px; font-weight: 600; }
.cg-media-link:hover { color: var(--cg-gold); }

.cg-person-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }
.cg-person-card { }
.cg-person-card-link {
    display: grid; grid-template-columns: 44px minmax(0, 1fr); gap: 12px; align-items: center;
    padding: 14px; background: var(--cg-glass); border: 1px solid var(--cg-line-2);
    border-radius: var(--cg-radius); backdrop-filter: blur(8px); transition: border-color .15s, transform .15s;
}
.cg-person-card-link:hover { border-color: var(--cg-gold); transform: translateY(-2px); }
.cg-person-avatar {
    display: grid; place-items: center; width: 44px; height: 44px;
    background: linear-gradient(135deg, var(--cg-gold), var(--cg-gold-d)); color: var(--cg-night);
    font-family: var(--cg-serif); font-weight: 900; font-size: 22px; border-radius: 10px;
}
.cg-person-card-name { font-weight: 700; color: var(--cg-ink); font-size: 15px; }
.cg-person-card-count { display: block; color: var(--cg-mute); font-size: 12.5px; margin-top: 2px; }

/* ============ 排行榜 ============ */
.cg-rank-list { display: grid; gap: 12px; }
.cg-rank-item {
    display: grid; grid-template-columns: 38px 80px minmax(0, 1fr); gap: 14px; align-items: center;
    padding: 14px; background: var(--cg-glass); border: 1px solid var(--cg-line-2);
    border-radius: var(--cg-radius); backdrop-filter: blur(8px); transition: border-color .15s, transform .15s;
}
.cg-rank-item:hover { border-color: var(--cg-line); transform: translateY(-2px); }
.cg-rank-item.is-top { border-color: var(--cg-gold); box-shadow: var(--cg-glow-gold); }
.cg-rank-num {
    display: grid; place-items: center; width: 34px; height: 34px;
    background: var(--cg-night-3); color: var(--cg-ink-2);
    border: 1px solid var(--cg-line-2); border-radius: 8px;
    font-weight: 900; font-size: 16px; font-family: var(--cg-serif);
}
.cg-rank-item.is-top .cg-rank-num { background: linear-gradient(135deg, var(--cg-gold), var(--cg-gold-d)); color: var(--cg-night); border-color: transparent; }
.cg-rank-poster { border-radius: 7px; overflow: hidden; aspect-ratio: 2/3; }
.cg-rank-poster img { width: 100%; height: 100%; object-fit: cover; }
.cg-rank-body h2 { font-size: 16px; margin-bottom: 5px; }
.cg-rank-body h2 a { color: var(--cg-ink); }
.cg-rank-body h2 a:hover { color: var(--cg-gold); }
.cg-rank-body .cg-media-blurb { margin-top: 6px; }

/* ============ 页脚 footer（自渲染） ============ */
.cg-footer { margin-top: 40px; border-top: 1px solid var(--cg-line); background: rgba(19,16,31,.6); backdrop-filter: blur(10px); }
.cg-footer-grid { max-width: var(--cg-contain); margin: 0 auto; display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 32px; padding: 40px 20px 20px; }
.cg-foot-brand { }
.cg-foot-desc { color: var(--cg-mute); font-size: 13.5px; margin-top: 12px; max-width: 320px; }
.cg-foot-col h3 { color: var(--cg-ink); font-size: 15px; margin-bottom: 12px; }
.cg-foot-links { display: grid; gap: 8px; }
.cg-foot-links a { color: var(--cg-mute); font-size: 13.5px; }
.cg-foot-links a:hover { color: var(--cg-gold); }
.cg-foot-link-row { padding-top: 0; grid-template-columns: 1fr; }
.cg-friend { display: flex; flex-wrap: wrap; gap: 10px; }
.cg-friend a { padding: 4px 12px; background: var(--cg-glass); border: 1px solid var(--cg-line-2); border-radius: 999px; color: var(--cg-ink-2); font-size: 13px; }
.cg-friend a:hover { border-color: var(--cg-gold); color: var(--cg-gold); }
.cg-foot-social-row { max-width: var(--cg-contain); margin: 0 auto; display: flex; align-items: center; gap: 16px; padding: 18px 20px; border-top: 1px solid var(--cg-line-3); }
.cg-foot-social-label { color: var(--cg-mute); font-size: 14px; font-weight: 600; }
.cg-foot-social { display: flex; gap: 10px; }
.cg-soc-btn {
    display: inline-grid; place-items: center; width: 38px; height: 38px;
    background: var(--soc, var(--cg-glaze)); color: #fff; border-radius: 9px;
    font-family: var(--cg-serif); font-weight: 900; font-size: 18px;
    transition: transform .15s, box-shadow .15s;
}
.cg-soc-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 18px var(--soc, var(--cg-glaze)); }
.cg-footer-bottom { max-width: var(--cg-contain); margin: 0 auto; padding: 20px; border-top: 1px solid var(--cg-line-3); text-align: center; color: var(--cg-mute); font-size: 13px; }
.cg-footer-bottom p { margin: 0 0 4px; }
.cg-footer-bottom a { color: var(--cg-mute); }
.cg-footer-bottom a:hover { color: var(--cg-gold); }
.cg-sep { margin: 0 6px; opacity: .5; }
.cg-disclaim { color: var(--cg-mute); font-size: 12px; opacity: .8; max-width: 820px; margin: 6px auto 0; }
.cg-foot-custom { margin-top: 8px; }

/* 返回顶部 */
.cg-totop {
    position: fixed; right: 22px; bottom: 22px; z-index: 80;
    display: grid; place-items: center; width: 46px; height: 46px;
    background: linear-gradient(135deg, var(--cg-gold), var(--cg-gold-d)); color: var(--cg-night);
    border: none; border-radius: 50%; cursor: pointer;
    box-shadow: var(--cg-glow-gold); transition: transform .15s, opacity .2s;
}
.cg-totop:hover { transform: translateY(-3px); }
.cg-totop[hidden] { display: none; }

/* 兜底：若某站点未把 guoman 加进 SELF_FOOTER_THEMES，隐藏重复注入的 footer_rich */
body .xc-footer-rich { display: none !important; }
/* user_panel FAB 在深底下的可见性 */
body .xc-up-fab { box-shadow: 0 6px 20px rgba(0,0,0,.5) !important; }

/* ============ 响应式 ============ */
@media (max-width: 1024px) {
    .cg-detail-grid { grid-template-columns: 1fr; }
    .cg-detail-aside { grid-template-columns: 200px 1fr; }
    .cg-foot-col:nth-child(4) { display: none; }
    .cg-footer-grid { grid-template-columns: 1.4fr 1fr 1fr; }
}

@media (max-width: 860px) {
    .cg-search--desktop { display: none; }
    .cg-search--mobile { display: flex; width: 100%; margin: 8px 0; }
    .cg-search--mobile .cg-search-input { width: 100%; }
    .cg-menu-toggle { display: flex; }
    .cg-nav {
        position: fixed; top: 0; right: -86%; width: 86%; max-width: 340px; height: 100vh;
        flex-direction: column; align-items: stretch; gap: 4px;
        background: var(--cg-night-2); padding: 80px 16px 24px;
        overflow-y: auto; z-index: 95; transition: right .25s;
        border-left: 1px solid var(--cg-line);
    }
    .cg-nav.is-open { right: 0; }
    .cg-nav-link { padding: 13px 14px; font-size: 16px; }
    .cg-nav-group, .cg-nav-submenu { width: 100%; position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; background: none; border: none; padding: 0 0 0 12px; backdrop-filter: none; }
    .cg-nav-submenu { display: none; }
    .cg-nav-group.is-open .cg-nav-submenu { display: block; }
    .cg-hero { min-height: 380px; }
    .cg-hero-title { font-size: 30px; }
    .cg-detail-title { font-size: 26px; }
    .cg-section-title { font-size: 21px; }
}

@media (max-width: 768px) {
    .cg-detail-aside { grid-template-columns: 1fr; }
    .cg-aside-poster { max-width: 200px; margin: 0 auto; }
    .cg-footer-grid { grid-template-columns: 1fr 1fr; gap: 24px; padding: 30px 16px 16px; }
    .cg-foot-brand { grid-column: 1 / -1; }
    .cg-foot-social-row { justify-content: center; flex-wrap: wrap; }
}

@media (max-width: 520px) {
    .cg-header-inner { height: 56px; gap: 10px; padding: 0 14px; }
    .cg-logo-text { font-size: 18px; }
    .cg-logo-stamp { width: 34px; height: 34px; font-size: 19px; }
    .cg-hero-inner { padding: 0 14px 36px; }
    .cg-hero-title { font-size: 25px; }
    .cg-container { padding: 0 14px; }
    .cg-row { margin: 0 -14px; padding: 0 14px; }
    .cg-row-track { grid-auto-columns: 132px; gap: 12px; }
    .cg-grid { grid-template-columns: repeat(auto-fill, minmax(108px, 1fr)); gap: 16px 10px; }
    .cg-card-title { font-size: 13px; }
    .cg-section { padding: 28px 0; }
    .cg-media { grid-template-columns: 96px 1fr; gap: 12px; padding: 12px; }
    .cg-rank-list { gap: 10px; }
    .cg-rank-item { grid-template-columns: 34px 64px minmax(0, 1fr); gap: 10px; padding: 10px; }
    .cg-rank-num { width: 30px; height: 30px; font-size: 15px; }
    .cg-rank-poster { width: 64px; }
    .cg-rank-body .cg-media-meta { gap: 6px; margin-bottom: 4px; font-size: 12px; }
    .cg-rank-body .cg-media-blurb { display: none; }
    .cg-person-grid { grid-template-columns: 1fr 1fr; }
    .cg-person-card-link { grid-template-columns: 36px minmax(0, 1fr); padding: 10px; gap: 8px; }
    .cg-person-avatar { width: 36px; height: 36px; font-size: 18px; }
    .cg-person-card-name { font-size: 13.5px; }
    .cg-footer-grid { grid-template-columns: 1fr; gap: 20px; padding: 26px 14px 14px; }
    .cg-totop { right: 16px; bottom: 16px; width: 42px; height: 42px; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
    .cg-card-link:hover .cg-card-poster, .cg-btn:hover, .cg-ep:hover, .cg-page-btn:hover, .cg-page-num:hover { transform: none; }
}
/* vodplay rank sidebar grid */
.cg-play-grid { display: grid; grid-template-columns: minmax(0, 1fr) 300px; gap: 28px; align-items: start; }
.cg-play-main { min-width: 0; }
.cg-play-aside { display: flex; flex-direction: column; gap: 18px; position: sticky; top: 80px; }
.cg-side-rank { margin: 0; }
@media (max-width: 900px) {
    .cg-play-grid { grid-template-columns: 1fr; }
    .cg-play-aside { position: static; }
}
