/* ===== 基础变量 — 2PT 青绿风格 ===== */
:root {
    --primary:      #e74c3c;
    --primary-dark: #c0392b;
    --secondary:    #f39c12;
    --accent:       #0abf8f;       /* 亮色下稍深的青绿 */
    --accent-dim:   rgba(10,191,143,0.12);
    --accent-glow:  rgba(10,191,143,0.25);
    --success:      #00b25a;
    --bg-dark:      #0a0e14;
    --bg-card:      #111720;
    --bg-hover:     #161d2a;
    --bg-sidebar:   #0d1219;
    --bg-topbar:    #0d1117;
    --text-primary: #e2eaf5;
    --text-secondary: #7a8fa8;
    --text-muted:   #3d5068;
    --border:       #1e2d40;
    --border-bright: #2a4060;
    --shadow:       0 4px 24px rgba(0,0,0,0.5);
    --radius:       6px;
    --radius-sm:    4px;
    --transition:   all 0.18s ease;
    --strength:     #ef4444;
    --agility:      #22c55e;
    --intelligence: #3b82f6;
    --universal:    #a855f7;
    --font-mono:    'Roboto Mono', 'Courier New', monospace;
}

/* ===== 亮色主题覆盖 ===== */
body[data-theme="light"] {
    --accent:         #0abf8f;
    --accent-dim:     rgba(10,191,143,0.1);
    --accent-glow:    rgba(10,191,143,0.2);
    --bg-dark:        #f0f4f8;
    --bg-card:        #ffffff;
    --bg-hover:       #e8edf3;
    --bg-sidebar:     #f5f7fa;
    --bg-topbar:      #ffffff;
    --text-primary:   #1a2332;
    --text-secondary: #4a5e74;
    --text-muted:     #8fa3b8;
    --border:         #d1dce8;
    --border-bright:  #b0c4d8;
    --shadow:         0 4px 24px rgba(0,0,0,0.08);
    --strength:       #dc2626;
    --agility:        #16a34a;
    --intelligence:   #2563eb;
    --universal:      #9333ea;
    --success:        #059669;
    --primary:        #dc2626;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
    font-family: 'Exo 2', 'Noto Sans SC', sans-serif;
    background: var(--bg-dark);
    color: var(--text-primary);
    min-height: 100vh;
    overflow-x: hidden;
    font-size: 14px;
    line-height: 1.5;
}

/* ===== 顶部导航栏（新增） ===== */
.topbar {
    position: fixed;
    top: 0; left: 0; right: 0;
    height: 48px;
    background: var(--bg-topbar);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 0;
    z-index: 200;
    padding: 0 16px;
    overflow: visible;
}

.topbar-logo {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-right: 24px;
    text-decoration: none;
    flex-shrink: 0;
}

.topbar-logo-icon { font-size: 18px; }

.topbar-logo-text {
    font-size: 15px;
    font-weight: 800;
    color: var(--accent);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.topbar-nav {
    display: flex;
    align-items: stretch;
    height: 100%;
    gap: 0;
    flex: 1;
    overflow: visible;
}

.topbar-nav::-webkit-scrollbar { display: none; }

.topbar-nav-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 0 14px;
    height: 100%;
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    white-space: nowrap;
    transition: color 0.15s, border-color 0.15s;
    background: none;
    border-top: none;
    border-left: none;
    border-right: none;
}

.topbar-nav-item:hover { color: var(--text-primary); }

.topbar-nav-item.active {
    color: var(--accent);
    border-bottom-color: var(--accent);
}

.topbar-nav-sep {
    width: 1px;
    height: 24px;
    background: var(--border);
    margin: 0 4px;
    align-self: center;
}

.topbar-search {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 0 10px;
    height: 32px;
    margin: 0 12px;
    flex-shrink: 0;
    min-width: 220px;
    cursor: pointer;
    transition: border-color .15s;
}

.topbar-search:hover { border-color: var(--accent); }
.topbar-search span { font-size: 12px; color: var(--text-muted); flex: 1; }
.topbar-search kbd {
    background: var(--bg-hover);
    border: 1px solid var(--border-bright);
    border-radius: 3px;
    padding: 1px 5px;
    font-size: 10px;
    color: var(--text-muted);
    font-family: var(--font-mono);
}

.topbar-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

/* ===== 布局 ===== */
.app {
    display: flex;
    min-height: 100vh;
    padding-top: 48px; /* 顶部栏高度 */
}

/* ===== topbar 下拉菜单 ===== */
.topbar-dropdown {
    position: relative;
    display: flex;
    align-items: stretch;
    height: 100%;
}

.topbar-dropdown-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 180px;
    background: var(--bg-card);
    border: 1px solid var(--border-bright);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    z-index: 300;
    padding: 4px 0;
    flex-direction: column;
}

.topbar-dropdown:hover .topbar-dropdown-menu,
.topbar-dropdown.open .topbar-dropdown-menu {
    display: flex;
}

.topbar-dd-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.12s, color 0.12s;
    white-space: nowrap;
}

.topbar-dd-item:hover {
    background: var(--bg-hover);
    color: var(--accent);
}

.topbar-dd-item.active {
    color: var(--accent);
    background: var(--accent-dim);
}

/* ===== 主内容区 ===== */
.main-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.search-box input::placeholder {
    color: var(--text-muted);
}

.search-btn {
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: 16px;
    padding: 8px;
    cursor: pointer;
}

.theme-toggle {
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    font-size: 18px;
    padding: 8px 12px;
    border-radius: 8px;
    cursor: pointer;
}

/* 语言切换按钮 */
.lang-toggle {
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    font-size: 13px;
    padding: 6px 12px;
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 2px;
    transition: var(--transition);
    font-family: 'Noto Sans SC', 'Exo 2', sans-serif;
}

.lang-toggle:hover {
    border-color: var(--primary);
    color: var(--text-primary);
}

.lang-zh, .lang-en {
    transition: color 0.2s, font-weight 0.2s;
}

.lang-sep {
    color: var(--border);
    margin: 0 1px;
}

/* ===== 页面容器 ===== */
.page-container {
    flex: 1;
    padding: 24px;
    overflow-y: auto;
}

.page {
    display: none;
    animation: fadeIn 0.3s ease;
}

.page.active {
    display: block;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.page-header {
    margin-bottom: 24px;
}

.page-header h1 {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 8px;
}

.subtitle {
    color: var(--text-secondary);
    font-size: 14px;
}

/* ===== 筛选栏 ===== */
.filter-bar {
    display: flex;
    gap: 8px;
    margin-top: 16px;
    flex-wrap: wrap;
}

.filter-btn, .tab-btn {
    padding: 8px 16px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 20px;
    color: var(--text-secondary);
    font-size: 13px;
    cursor: pointer;
    transition: var(--transition);
}

.filter-btn:hover, .tab-btn:hover {
    border-color: var(--primary);
    color: var(--text-primary);
}

.filter-btn.active, .tab-btn.active {
    background: var(--primary);
    border-color: var(--primary);
    color: white;
}

.tabs {
    display: flex;
    gap: 8px;
    margin-top: 16px;
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

/* ===== 统计卡片 ===== */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 32px;
}

.stat-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 24px;
    text-align: center;
    transition: var(--transition);
}

.stat-card:hover {
    border-color: var(--primary);
    transform: translateY(-2px);
}

.stat-icon {
    font-size: 32px;
    margin-bottom: 8px;
}

.stat-value {
    font-size: 36px;
    font-weight: 700;
    color: var(--primary);
}

.stat-label {
    font-size: 14px;
    color: var(--text-secondary);
    margin-top: 4px;
}

/* ===== 快速入口 ===== */
.quick-access h2 {
    font-size: 20px;
    margin-bottom: 16px;
}

.quick-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 16px;
}

.quick-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 24px;
    cursor: pointer;
    transition: var(--transition);
}

.quick-card:hover {
    border-color: var(--primary);
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}

.quick-icon {
    font-size: 36px;
    margin-bottom: 12px;
}

.quick-card h3 {
    font-size: 16px;
    margin-bottom: 8px;
}

.quick-card p {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.5;
}

/* ===== 英雄网格 ===== */
.heroes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 12px;
}

.hero-card {
    background: var(--bg-card);
    border: 2px solid var(--border);
    border-radius: var(--radius);
    padding: 16px 12px;
    text-align: center;
    cursor: pointer;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}

.hero-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow);
}

.hero-card.strength { border-color: var(--strength); }
.hero-card.agility { border-color: var(--agility); }
.hero-card.intelligence { border-color: var(--intelligence); }
.hero-card.universal { border-color: var(--universal); }

.hero-card.strength:hover { box-shadow: 0 4px 20px rgba(239, 68, 68, 0.3); }
.hero-card.agility:hover { box-shadow: 0 4px 20px rgba(34, 197, 94, 0.3); }
.hero-card.intelligence:hover { box-shadow: 0 4px 20px rgba(59, 130, 246, 0.3); }
.hero-card.universal:hover { box-shadow: 0 4px 20px rgba(168, 85, 247, 0.3); }

.hero-avatar {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    margin: 0 auto 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    background: var(--bg-hover);
}

.hero-avatar-img {
    border-radius: 8px;
    overflow: hidden;
    padding: 0;
    background: var(--bg-hover);
    width: 120px;
    height: 68px;
}

.hero-avatar-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
}

.hero-avatar-fallback {
    font-size: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.hero-name-cn {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 4px;
}

.hero-name-en {
    font-size: 11px;
    color: var(--text-muted);
}

.hero-attr {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.hero-attr.strength { background: var(--strength); }
.hero-attr.agility { background: var(--agility); }
.hero-attr.intelligence { background: var(--intelligence); }
.hero-attr.universal { background: var(--universal); }

/* ===== 物品网格 ===== */
.items-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 12px;
}

.item-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
    cursor: pointer;
    transition: var(--transition);
    display: flex;
    align-items: center;
    gap: 12px;
}

.item-card:hover {
    border-color: var(--secondary);
    transform: translateY(-2px);
}

.item-icon {
    width: 48px;
    height: 48px;
    border-radius: 8px;
    background: var(--bg-hover);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    flex-shrink: 0;
}

.item-icon-img {
    padding: 0;
    overflow: hidden;
}

.item-icon-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 8px;
    display: block;
}

.item-icon-fallback {
    font-size: 24px;
}

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

.item-name {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 4px;
}

.item-price {
    font-size: 12px;
    color: var(--secondary);
    font-weight: 600;
}

.item-desc {
    font-size: 11px;
    color: var(--text-muted);
    margin-top: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ===== 中立物品网格 ===== */
.neutral-items-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 12px;
}

.neutral-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 12px;
    cursor: pointer;
    transition: var(--transition);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.neutral-card:hover {
    border-color: var(--accent);
    transform: translateY(-2px);
}

/* 中立物品图片 */
.neutral-img {
    width: 88px;
    height: 88px;
    border-radius: 6px;
    overflow: hidden;
    margin-bottom: 8px;
    background: var(--bg-hover);
    display: flex;
    align-items: center;
    justify-content: center;
    align-self: center;
}
.neutral-img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.neutral-tier {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
    margin-bottom: 8px;
}

.tier1 { background: #6b7280; color: white; }
.tier2 { background: #22c55e; color: white; }
.tier3 { background: #3b82f6; color: white; }
.tier4 { background: #a855f7; color: white; }
.tier5 { background: #f59e0b; color: black; }
.enchantment { background: #ec4899; color: white; }

.neutral-name {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 4px;
}

.neutral-desc {
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.5;
}

/* ===== 赛事表格 ===== */
.tournament-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 16px;
}

.tournament-table th,
.tournament-table td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid var(--border);
}

.tournament-table th {
    background: var(--bg-card);
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
}

.tournament-table td {
    font-size: 13px;
}

.tournament-table tr:hover td {
    background: var(--bg-hover);
}

.champion {
    color: var(--secondary);
    font-weight: 600;
}

.prize-pool {
    color: var(--success);
    font-weight: 600;
}

/* ===== 机制网格 ===== */
.mechanics-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 16px;
}

.mechanic-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
}

.mechanic-card h3 {
    font-size: 16px;
    margin-bottom: 12px;
    color: var(--accent);
}

.mechanic-card table {
    width: 100%;
    font-size: 13px;
}

.mechanic-card th,
.mechanic-card td {
    padding: 8px 0;
    border-bottom: 1px solid var(--border);
    text-align: left;
}

.mechanic-card th {
    color: var(--text-secondary);
    font-weight: 500;
}

/* ===== 弹窗 ===== */
.modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.8);
    z-index: 1000;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.modal.active {
    display: flex;
}

.modal-content {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    max-width: 800px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    position: relative;
    animation: modalIn 0.3s ease;
}

@keyframes modalIn {
    from { opacity: 0; transform: scale(0.9); }
    to { opacity: 1; transform: scale(1); }
}

.modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: 20px;
    cursor: pointer;
    z-index: 10;
}

.modal-body {
    padding: 32px;
}

/* ===== 详情页样式 ===== */
.detail-header {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--border);
}

.detail-avatar {
    width: 80px;
    height: 80px;
    border-radius: 16px;
    background: var(--bg-hover);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 40px;
}

.hero-detail-avatar {
    width: 200px;
    height: 113px;
    border-radius: 12px;
    overflow: hidden;
    flex-shrink: 0;
}

.hero-detail-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
}

.detail-title h2 {
    font-size: 24px;
    margin-bottom: 4px;
}

.detail-title .subtitle {
    color: var(--text-secondary);
    font-size: 14px;
}

.detail-section {
    margin-bottom: 24px;
}

.detail-section h3 {
    font-size: 16px;
    margin-bottom: 12px;
    color: var(--accent);
}

.detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 12px;
}

.detail-stat {
    background: var(--bg-hover);
    padding: 12px;
    border-radius: 8px;
}

.detail-stat .label {
    font-size: 11px;
    color: var(--text-secondary);
    margin-bottom: 4px;
}

.detail-stat .value {
    font-size: 18px;
    font-weight: 600;
}

/* ===================================================================
   全自适应响应式系统
   断点（基于 viewport 总宽度）：
     桌面   ≥900px  → 完整侧边栏(240px)，4列统计卡片
     平板   640-899px → 侧边栏收缩图标(64px)，2列统计卡片
     手机   ≤639px  → 侧边栏隐藏，底部导航，2列统计卡片
   =================================================================== */

/* 宽屏优化 (≥1440px) */
@media (min-width: 1440px) {
    .page-container     { padding: 32px 48px; }
    .search-box         { width: 520px; }
    .quick-grid         { grid-template-columns: repeat(5, 1fr); }
    .hot-heroes-grid    { grid-template-columns: repeat(3, 1fr); }
    .teams-grid         { grid-template-columns: repeat(2, 1fr); }
}

/* 平板 640px–899px */
@media (max-width: 899px) and (min-width: 640px) {
    .page-container          { padding: 16px; }
    .stats-grid              { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .hot-heroes-grid         { grid-template-columns: repeat(2, 1fr); }
    .hero-spotlight          { flex-direction: column; }
    .hero-spotlight-img      { width: 100%; height: 150px; }
    .teams-grid              { grid-template-columns: 1fr; }
    .filter-btn              { padding: 6px 10px; font-size: 12px; }
    .topbar-nav-item         { padding: 0 10px; font-size: 12px; }
    .topbar-search           { min-width: 160px; }
}

/* 手机端 ≤639px */
@media (max-width: 639px) {
    /* 移动端 topbar：隐藏下拉导航，只保留Logo+搜索+操作 */
    .topbar-nav              { display: none; }
    .topbar-search           { flex: 1; min-width: 0; margin: 0 8px; }
    .main-content            { margin-left: 0 !important; }
    .top-bar {
        height: 52px;
        padding: 0 10px;
        gap: 8px;
    }
    .lang-toggle             { padding: 5px 8px; font-size: 11px; }
    .theme-toggle            { padding: 6px 8px; font-size: 14px; }
    .page-container          { padding: 12px 12px 70px; }
    .page-header             { margin-bottom: 14px; }
    .page-header h1          { font-size: 20px; }
    .stats-grid              { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .stat-card               { padding: 16px 10px; }
    .stat-value              { font-size: 26px !important; }
    .stat-icon               { font-size: 22px; margin-bottom: 6px; }
    .quick-grid              { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .quick-card              { padding: 14px 10px; }
    .quick-card h3           { font-size: 13px; }
    .quick-card p            { display: none; }
    .quick-icon              { font-size: 22px; }
    .heroes-grid             { grid-template-columns: repeat(auto-fill, minmax(86px, 1fr)); gap: 8px; }
    .hero-card               { padding: 8px 4px; }
    .hero-avatar-img         { width: 80px; height: 45px; margin-bottom: 6px; }
    .hero-name-cn            { font-size: 11px; }
    .hero-name-en            { font-size: 9px; }
    .items-grid              { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 8px; }
    .item-card               { padding: 10px 8px; gap: 8px; }
    .item-name               { font-size: 12px; }
    .item-desc               { display: none; }
    .item-icon               { width: 40px; height: 40px; }
    .neutral-items-grid      { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 8px; }
    .filter-bar              { gap: 4px; flex-wrap: wrap; }
    .filter-btn              { padding: 5px 10px; font-size: 11px; }
    .tab-content             { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .tournament-table        { min-width: 500px; font-size: 12px; }
    .tournament-table th,
    .tournament-table td     { padding: 7px 8px; }
    .hot-heroes-grid         { grid-template-columns: 1fr; }
    .hero-tier-img           { width: 52px; height: 30px; }
    .modal-content           { margin: 6px; border-radius: 12px; max-height: calc(100vh - 12px); }
    .hero-detail-avatar      { width: 140px; height: 79px; }
    .detail-header           { flex-wrap: wrap; gap: 12px; }
    .counter-grid            { grid-template-columns: 1fr; }
    .detail-grid             { grid-template-columns: repeat(2, 1fr); }
    .teams-grid              { grid-template-columns: 1fr; }
    .player-heroes           { gap: 3px; }
    .hero-spotlight          { flex-direction: column; min-height: auto; }
    .hero-spotlight-img      { width: 100%; height: 110px; }
    .hero-spotlight-info     { padding: 12px 14px; }
    .spotlight-hero-name     { font-size: 18px; }
    .patch-changes li        { font-size: 12px; }
    .patch-log               { padding: 14px; }
    .tabs                    { overflow-x: auto; -webkit-overflow-scrolling: touch; gap: 4px; padding-bottom: 4px; }
    .tab-btn                 { white-space: nowrap; padding: 7px 12px; font-size: 12px; }
    .bottom-nav {
        display: flex !important;
        position: fixed;
        bottom: 0; left: 0; right: 0;
        height: 54px;
        background: var(--bg-sidebar);
        border-top: 1px solid var(--border);
        z-index: 100;
        justify-content: space-around;
        align-items: center;
        padding: 0 2px;
    }
    .bottom-nav-item {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 1px;
        padding: 5px 2px;
        border-radius: 8px;
        color: var(--text-muted);
        text-decoration: none;
        font-size: 9px;
        cursor: pointer;
        transition: var(--transition);
        flex: 1;
        min-width: 0;
    }
    .bottom-nav-item .bnav-icon  { font-size: 18px; line-height: 1; }
    .bottom-nav-item.active,
    .bottom-nav-item:hover {
        color: var(--primary);
        background: rgba(231,76,60,0.1);
    }
}

/* 超小屏 ≤380px */
@media (max-width: 380px) {
    .stats-grid              { grid-template-columns: repeat(2, 1fr); gap: 8px; }
    .heroes-grid             { grid-template-columns: repeat(3, 1fr); }
    .bottom-nav-item .bnav-label { display: none; }
    .bottom-nav-item         { padding: 8px 2px; }
    .bottom-nav-item .bnav-icon  { font-size: 20px; }
    .quick-grid              { grid-template-columns: repeat(2, 1fr); }
}

/* 默认隐藏仅移动端元素 */
.mobile-menu-btn  { display: none; }
.bottom-nav       { display: none; }


/* ===== 滚动条 ===== */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: var(--bg-dark);
}

::-webkit-scrollbar-thumb {
    background: var(--border);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--text-muted);
}

/* ===== 热门/推荐区块 ===== */
.section-title {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.hot-heroes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 10px;
    margin-bottom: 24px;
}

.hero-tier-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    background: var(--bg-card);
    border-radius: 8px;
    border: 1px solid var(--border);
    transition: var(--transition);
    cursor: pointer;
}

.hero-tier-row:hover {
    border-color: var(--primary);
    background: var(--bg-hover);
}

.hero-tier-rank {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--bg-hover);
    border: 2px solid var(--border);
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
    flex-shrink: 0;
}

.hero-tier-rank.rank-1 { background: #f5c518; border-color: #f5c518; color: #000; }
.hero-tier-rank.rank-2 { background: #c0c0c0; border-color: #c0c0c0; color: #000; }
.hero-tier-rank.rank-3 { background: #cd7f32; border-color: #cd7f32; color: #fff; }

.hero-tier-img {
    width: 64px;
    height: 36px;
    border-radius: 6px;
    overflow: hidden;
    flex-shrink: 0;
    background: var(--bg-card);
}

.hero-tier-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
}

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

.hero-tier-name {
    font-size: 14px;
    font-weight: 600;
}

.hero-tier-meta {
    font-size: 11px;
    color: var(--text-muted);
    margin-top: 2px;
}

.hero-tier-winrate {
    font-size: 15px;
    font-weight: 700;
    color: var(--success);
    flex-shrink: 0;
}

.hero-tier-winrate.bad { color: var(--primary); }

/* ===== 版本更新日志 ===== */
.patch-log {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    margin-bottom: 16px;
}

.patch-log-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.patch-badge {
    background: var(--primary);
    color: #fff;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 700;
}

.patch-date {
    font-size: 12px;
    color: var(--text-muted);
}

.patch-changes {
    list-style: none;
    padding: 0;
}

.patch-changes li {
    padding: 6px 0;
    border-bottom: 1px solid var(--border);
    font-size: 13px;
    color: var(--text-secondary);
    display: flex;
    align-items: flex-start;
    gap: 8px;
    line-height: 1.5;
}

.patch-changes li:last-child { border-bottom: none; }

.patch-change-tag {
    padding: 1px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 700;
    flex-shrink: 0;
    margin-top: 2px;
}

.tag-buff { background: rgba(46, 204, 113, 0.2); color: var(--success); }
.tag-nerf { background: rgba(231, 76, 60, 0.2); color: var(--primary); }
.tag-rework { background: rgba(52, 152, 219, 0.2); color: var(--accent); }
.tag-new { background: rgba(243, 156, 18, 0.2); color: var(--secondary); }

/* ===== 技能区块 ===== */
.skills-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.skill-item {
    background: var(--bg-hover);
    border-radius: 8px;
    padding: 12px 14px;
    display: flex;
    gap: 12px;
    align-items: flex-start;
}

.skill-icon-wrap {
    flex-shrink: 0;
}

.skill-icon {
    width: 52px;
    height: 52px;
    border-radius: 8px;
    object-fit: cover;
    display: block;
}

.skill-icon-placeholder {
    width: 52px;
    height: 52px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    background: var(--bg-card);
    flex-shrink: 0;
}

.skill-header {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 5px;
}

.skill-name {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-primary);
}

.skill-en {
    font-size: 11px;
    color: var(--text-muted);
}

.skill-badge {
    display: inline-block;
    padding: 1px 7px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 600;
}

.skill-badge-behavior {
    background: rgba(52,152,219,0.18);
    border: 1px solid rgba(52,152,219,0.35);
    color: #60c8f0;
}

.skill-badge-dmg      { background: #c0392b; color: #fff; border: 1px solid #e74c3c; }
.skill-badge-magical  { background: #6c3483; color: #fff; border: 1px solid #9b59b6; }
.skill-badge-physical { background: #c0392b; color: #fff; border: 1px solid #e74c3c; }
.skill-badge-pure     { background: #b7770d; color: #fff; border: 1px solid #f39c12; }

.skill-info h4 {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 4px;
}

.skill-type-badge {
    display: inline-block;
    padding: 1px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 600;
    background: rgba(52, 152, 219, 0.2);
    color: var(--accent);
    margin-bottom: 4px;
}

.skill-desc {
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.6;
    margin: 0;
}

.skill-attribs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 6px;
}

.skill-attrib {
    font-size: 11px;
    background: var(--bg-card);
    border-radius: 4px;
    padding: 2px 8px;
    color: var(--text-secondary);
}

.skill-attrib b {
    color: var(--secondary);
    font-weight: 600;
}

.skill-mccd {
    font-size: 11px;
    color: var(--text-muted);
    margin-top: 5px;
    font-family: monospace;
}

/* ===== 神杖 / 魔晶 ===== */
.aghs-grid {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.aghs-block {
    border-radius: 10px;
    padding: 14px 16px;
    border: 1px solid var(--border);
}

.aghs-scepter {
    background: linear-gradient(135deg, rgba(26,10,46,0.8), rgba(88,28,135,0.15));
    border-color: rgba(168,85,247,0.4);
}

.aghs-shard {
    background: linear-gradient(135deg, rgba(10,30,46,0.8), rgba(6,182,212,0.15));
    border-color: rgba(6,182,212,0.4);
}

.aghs-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.aghs-icon {
    width: 40px;
    height: 32px;
    border-radius: 6px;
    object-fit: cover;
    flex-shrink: 0;
}

.aghs-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-primary);
}

.aghs-skill {
    font-size: 11px;
    color: var(--text-muted);
    margin-top: 2px;
}

.aghs-skill b {
    color: var(--secondary);
}

.aghs-new-badge {
    background: #f59e0b;
    color: #000;
    border-radius: 3px;
    padding: 0 5px;
    font-size: 10px;
    font-weight: 700;
    margin-left: 4px;
}

.aghs-desc {
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.65;
    margin: 0;
}

/* ===== 克制提示 ===== */
.counter-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.counter-block {
    background: var(--bg-hover);
    border-radius: 8px;
    padding: 12px;
}

.counter-block h4 {
    font-size: 12px;
    color: var(--text-muted);
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.counter-heroes {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.counter-hero-chip {
    display: flex;
    align-items: center;
    gap: 4px;
    background: var(--bg-card);
    border-radius: 6px;
    padding: 4px 8px;
    font-size: 11px;
    cursor: pointer;
    transition: var(--transition);
    border: 1px solid var(--border);
}

.counter-hero-chip:hover {
    border-color: var(--primary);
}

.counter-hero-chip img {
    width: 28px;
    height: 16px;
    border-radius: 3px;
    object-fit: cover;
    object-position: center top;
}

/* ===== 主页英雄聚焦 ===== */
.hero-spotlight {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    margin-bottom: 24px;
    display: flex;
    align-items: stretch;
    min-height: 140px;
    cursor: pointer;
    transition: var(--transition);
}

.hero-spotlight:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 20px rgba(231,76,60,0.2);
}

.hero-spotlight-img {
    width: 240px;
    flex-shrink: 0;
    overflow: hidden;
    position: relative;
    background: var(--bg-hover);
}

.hero-spotlight-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
}

.hero-spotlight-info {
    flex: 1;
    padding: 20px 24px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.spotlight-label {
    font-size: 11px;
    color: var(--primary);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 8px;
    font-weight: 700;
}

.spotlight-hero-name {
    font-size: 26px;
    font-weight: 700;
    margin-bottom: 2px;
}

.spotlight-hero-en {
    font-size: 12px;
    color: var(--text-muted);
    margin-bottom: 10px;
}

.spotlight-roles {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.role-tag {
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    background: var(--bg-hover);
    border: 1px solid var(--border);
    color: var(--text-secondary);
}

/* ===== 版本说明提示 ===== */
.info-banner {
    background: rgba(52,152,219,0.1);
    border: 1px solid rgba(52,152,219,0.3);
    border-radius: 8px;
    padding: 12px 16px;
    font-size: 13px;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
}

/* ===== 赛事下一场横幅 ===== */
.next-event-banner {
    background: linear-gradient(135deg, rgba(231,76,60,0.1) 0%, rgba(243,156,18,0.08) 100%);
    border: 1px solid rgba(231,76,60,0.25);
    border-radius: var(--radius);
    padding: 16px 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 20px;
}

.next-event-icon { font-size: 28px; flex-shrink: 0; }

.next-event-label {
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 4px;
}

.next-event-name {
    font-size: 17px;
    font-weight: 700;
    color: var(--secondary);
}

.next-event-meta {
    font-size: 12px;
    color: var(--text-secondary);
    margin-top: 2px;
}

/* ===== 职业战队页面 ===== */
.teams-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(520px, 1fr));
    gap: 20px;
}

.team-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    transition: var(--transition);
}

.team-card:hover {
    border-color: var(--primary);
    box-shadow: var(--shadow);
}

.team-header {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 18px;
    background: var(--bg-hover);
}

.team-logo {
    font-size: 32px;
    flex-shrink: 0;
}

.team-info { flex: 1; }

.team-name {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 4px;
}

.team-meta {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 4px;
}

.region-tag {
    font-size: 11px;
    padding: 2px 8px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 4px;
    color: var(--text-secondary);
}

.team-rank {
    font-size: 12px;
    color: var(--text-muted);
}

.team-ti {
    font-size: 12px;
    color: var(--secondary);
    font-weight: 600;
}

.team-earnings {
    font-size: 20px;
    font-weight: 700;
    color: var(--success);
    flex-shrink: 0;
}

.team-note {
    padding: 8px 18px;
    font-size: 12px;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border);
    background: rgba(52,152,219,0.05);
}

.players-list {
    padding: 0;
}

.player-row {
    display: flex;
    gap: 12px;
    padding: 12px 18px;
    border-bottom: 1px solid var(--border);
    align-items: flex-start;
    transition: var(--transition);
}

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

.player-row:hover {
    background: var(--bg-hover);
}

.player-pos {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 800;
    flex-shrink: 0;
    margin-top: 2px;
}

.pos-1 { background: rgba(231,76,60,0.2); color: #ef4444; border: 1px solid rgba(231,76,60,0.4); }
.pos-2 { background: rgba(52,152,219,0.2); color: #3b82f6; border: 1px solid rgba(52,152,219,0.4); }
.pos-3 { background: rgba(243,156,18,0.2); color: #f39c12; border: 1px solid rgba(243,156,18,0.4); }
.pos-4 { background: rgba(46,204,113,0.2); color: #2ecc71; border: 1px solid rgba(46,204,113,0.4); }
.pos-5 { background: rgba(168,85,247,0.2); color: #a855f7; border: 1px solid rgba(168,85,247,0.4); }

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

.player-id {
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 2px;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.player-realname {
    font-size: 12px;
    font-weight: 400;
    color: var(--text-secondary);
}

.player-nat {
    font-size: 12px;
    font-weight: 400;
}

.player-poslabel {
    font-size: 11px;
    color: var(--text-muted);
    margin-bottom: 6px;
}

.player-heroes {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 4px;
}

.hero-chip {
    padding: 2px 8px;
    background: var(--bg-hover);
    border: 1px solid var(--border);
    border-radius: 12px;
    font-size: 11px;
    color: var(--text-secondary);
    cursor: default;
    transition: var(--transition);
}

.hero-chip:hover {
    border-color: var(--primary);
    color: var(--text-primary);
}

.player-note {
    font-size: 11px;
    color: var(--text-muted);
    line-height: 1.5;
    margin-top: 4px;
    padding: 4px 8px;
    background: rgba(0,0,0,0.2);
    border-radius: 4px;
    border-left: 2px solid var(--primary);
}

/* 赛事表格状态行 */
.live-row {
    background: rgba(231,76,60,0.05);
    animation: pulse-row 2s infinite;
}

.ti-row {
    background: rgba(243,156,18,0.06);
    border-bottom: 2px solid var(--secondary);
}

.upcoming-row {
    opacity: 0.75;
}

@keyframes pulse-row {
    0%, 100% { background: rgba(231,76,60,0.05); }
    50% { background: rgba(231,76,60,0.12); }
}

/* ===== 响应式补充（合并到多断点系统）===== */
@media (max-width: 767px) {
    .hero-spotlight { flex-direction: column; }
    .hero-spotlight-img { width: 100%; height: 120px; }
    .counter-grid { grid-template-columns: 1fr; }
    .hot-heroes-grid { grid-template-columns: 1fr; }
    .teams-grid { grid-template-columns: 1fr; }
    .team-header { flex-wrap: wrap; }
    .player-row { flex-wrap: wrap; }
}

/* ===================================================================
   新增功能样式：天赋树 / 出装推荐 / 英雄属性 / 计时器 / 详情Tab
   =================================================================== */

/* ── 详情弹窗 Tab 切换 ── */
.detail-tabs {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
    margin: 12px 0 16px;
    border-bottom: 1px solid var(--border);
    padding-bottom: 10px;
}
.detail-tab-btn {
    padding: 7px 14px;
    background: var(--bg-hover);
    border: 1px solid var(--border);
    border-radius: 20px;
    color: var(--text-secondary);
    font-size: 12px;
    cursor: pointer;
    transition: var(--transition);
    white-space: nowrap;
}
.detail-tab-btn:hover { border-color: var(--primary); color: var(--text-primary); }
.detail-tab-btn.active {
    background: var(--primary);
    border-color: var(--primary);
    color: #fff;
    font-weight: 600;
}
.detail-tab-content { display: none; }
.detail-tab-content.active { display: block; }

.hero-roles-inline {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: 6px;
}

/* ── 英雄属性表格 ── */
.stats-bar-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 8px;
}
.stat-bar-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-hover);
    padding: 8px 12px;
    border-radius: 8px;
    font-size: 13px;
}
.stat-bar-label { color: var(--text-secondary); font-size: 12px; }
.stat-bar-val   { font-weight: 600; color: var(--text-primary); }

/* ── 天赋树 ── */
.talent-tree {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.talent-row {
    display: grid;
    grid-template-columns: 1fr 44px 1fr;
    gap: 10px;
    align-items: stretch;
}
.talent-opt {
    background: var(--bg-hover);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 11px 14px;
    font-size: 12.5px;
    color: var(--text-secondary);
    transition: var(--transition);
    line-height: 1.5;
    cursor: default;
    position: relative;
}
.talent-opt:hover {
    border-color: var(--secondary);
    color: var(--text-primary);
    background: rgba(243,156,18,0.1);
    z-index: 1;
    transform: scale(1.01);
}
.talent-left  { text-align: right; }
.talent-right { text-align: left;  }
.talent-level {
    width: 44px;
    height: 44px;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 800;
    flex-shrink: 0;
    margin: 0 auto;
    align-self: center;
    letter-spacing: -0.5px;
}
.talent-note {
    margin-top: 10px;
    padding: 8px 12px;
    background: rgba(52,152,219,0.06);
    border: 1px solid rgba(52,152,219,0.2);
    border-radius: 6px;
}
.talent-note-tip {
    font-size: 11px;
    color: var(--text-muted);
}

/* ── 出装推荐 ── */
.build-role-badge {
    font-size: 11px;
    background: rgba(52,152,219,0.15);
    color: var(--accent);
    padding: 2px 8px;
    border-radius: 10px;
    margin-left: 8px;
    font-weight: 500;
    vertical-align: middle;
}
.build-phase { margin-bottom: 14px; }
.build-phase-label {
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.8px;
    margin-bottom: 8px;
    font-weight: 600;
}
.build-items-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.build-item-chip {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    transition: var(--transition);
}
.build-item-chip:hover { transform: translateY(-2px); }
.build-item-img {
    width: 48px;
    height: 36px;
    background: var(--bg-hover);
    border-radius: 6px;
    overflow: hidden;
    border: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
}
.build-item-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 5px;
}
.build-item-name {
    font-size: 9px;
    color: var(--text-muted);
    text-align: center;
    max-width: 52px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.build-tips {
    background: rgba(52,152,219,0.08);
    border: 1px solid rgba(52,152,219,0.2);
    border-left: 3px solid var(--accent);
    border-radius: 6px;
    padding: 10px 14px;
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.6;
    margin-top: 4px;
}

/* ── 计时器页面 ── */
.timer-clock-card {
    background: linear-gradient(135deg, var(--bg-card) 0%, rgba(231,76,60,0.08) 100%);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 28px;
    text-align: center;
    margin-bottom: 24px;
}
.timer-clock-label {
    font-size: 12px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 8px;
}
.timer-clock {
    font-size: 72px;
    font-weight: 800;
    color: var(--text-primary);
    font-family: 'Exo 2', monospace;
    letter-spacing: 4px;
    line-height: 1;
    margin-bottom: 16px;
    transition: color 0.3s;
}
.timer-clock.timer-pulsing {
    color: var(--primary);
    animation: timer-pulse 0.8s ease infinite alternate;
}
@keyframes timer-pulse {
    from { opacity: 0.7; }
    to   { opacity: 1;   }
}
.timer-clock-controls {
    display: flex;
    gap: 12px;
    justify-content: center;
    margin-bottom: 12px;
}
.timer-btn {
    padding: 10px 28px;
    border-radius: 24px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
    border: none;
}
.timer-btn-start {
    background: var(--primary);
    color: #fff;
}
.timer-btn-start:hover { background: var(--primary-dark); transform: scale(1.04); }
.timer-btn-reset {
    background: var(--bg-hover);
    color: var(--text-secondary);
    border: 1px solid var(--border);
}
.timer-btn-reset:hover { border-color: var(--primary); color: var(--text-primary); }
.timer-phase { font-size: 13px; color: var(--text-muted); }

.timer-events-title {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 12px;
}
.timer-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 12px;
    margin-bottom: 8px;
}
.timer-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-left: 3px solid var(--tcolor, var(--primary));
    border-radius: 10px;
    padding: 14px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    transition: var(--transition);
}
.timer-card-due {
    border-color: var(--tcolor);
    background: rgba(231,76,60,0.06);
    animation: pulse-row 1s infinite;
}
.timer-card-icon { font-size: 28px; flex-shrink: 0; }
.timer-card-info { flex: 1; }
.timer-card-name { font-size: 14px; font-weight: 700; margin-bottom: 2px; }
.timer-card-desc { font-size: 11px; color: var(--text-muted); margin-bottom: 4px; }
.timer-card-next { font-size: 13px; color: var(--text-secondary); font-weight: 600; }
.timer-due-text  { color: var(--primary) !important; }
.timer-btn-kill {
    padding: 6px 14px;
    background: rgba(231,76,60,0.15);
    color: var(--primary);
    border: 1px solid rgba(231,76,60,0.3);
    border-radius: 16px;
    font-size: 12px;
    cursor: pointer;
    transition: var(--transition);
    flex-shrink: 0;
}
.timer-btn-kill:hover { background: var(--primary); color: #fff; }

.bounty-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 14px;
    background: var(--bg-card);
    border-radius: var(--radius);
    border: 1px solid var(--border);
}
.bounty-mark {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    opacity: 0.45;
    transition: var(--transition);
}
.bounty-mark.bounty-past  { opacity: 0.2; }
.bounty-mark.bounty-soon  { opacity: 1; transform: scale(1.2); }
.bounty-dot  { font-size: 14px; }
.bounty-time { font-size: 9px; color: var(--text-muted); }

.timeline-list {
    display: flex;
    flex-direction: column;
    background: var(--bg-card);
    border-radius: var(--radius);
    border: 1px solid var(--border);
    overflow: hidden;
}
.timeline-item {
    display: grid;
    grid-template-columns: 56px 32px 1fr;
    gap: 12px;
    align-items: center;
    padding: 10px 16px;
    border-bottom: 1px solid var(--border);
    transition: var(--transition);
}
.timeline-item:last-child { border-bottom: none; }
.timeline-item.timeline-past { opacity: 0.35; }
.timeline-item.timeline-current {
    background: rgba(231,76,60,0.08);
    border-left: 3px solid var(--primary);
}
.timeline-time  { font-size: 12px; color: var(--text-muted); font-family: monospace; font-weight: 600; }
.timeline-dot   { font-size: 18px; text-align: center; }
.timeline-label { font-size: 13px; font-weight: 600; }
.timeline-desc  { font-size: 11px; color: var(--text-muted); margin-top: 1px; }

.timer-toast {
    position: fixed;
    top: 70px;
    left: 50%;
    transform: translateX(-50%) translateY(-20px);
    background: var(--primary);
    color: #fff;
    padding: 10px 20px;
    border-radius: 24px;
    font-size: 14px;
    font-weight: 600;
    z-index: 9999;
    opacity: 0;
    transition: all 0.3s ease;
    pointer-events: none;
    white-space: nowrap;
    box-shadow: 0 4px 20px rgba(0,0,0,0.3);
}
.timer-toast.show {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

@media (max-width: 639px) {
    .timer-clock       { font-size: 52px; }
    .timer-cards-grid  { grid-template-columns: 1fr; }
    .talent-row        { grid-template-columns: 1fr 36px 1fr; }
    .talent-opt        { padding: 8px; font-size: 11px; }
    .stats-bar-grid    { grid-template-columns: repeat(2, 1fr); }
    .build-items-row   { gap: 6px; }
    .build-item-img    { width: 42px; height: 32px; }
    .timeline-item     { grid-template-columns: 46px 28px 1fr; gap: 8px; padding: 8px 12px; }
}

/* =============================================
   收藏夹 / 我的英雄池
   ============================================= */

/* 英雄卡片收藏按钮 */
.hero-fav-btn {
    position: absolute;
    top: 6px;
    right: 6px;
    background: rgba(0,0,0,0.6);
    border: none;
    border-radius: 50%;
    width: 26px;
    height: 26px;
    font-size: 13px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.2s, transform 0.15s;
    z-index: 2;
    filter: grayscale(1);
}
.hero-card { position: relative; }
.hero-card:hover .hero-fav-btn { opacity: 1; }
.hero-fav-btn.faved { opacity: 1; filter: grayscale(0); }
.hero-fav-btn:hover { transform: scale(1.2); }

/* 弹窗内收藏按钮 */
.hero-fav-btn-lg {
    background: none;
    border: none;
    font-size: 22px;
    cursor: pointer;
    vertical-align: middle;
    margin-left: 8px;
    filter: grayscale(1);
    transition: filter 0.2s, transform 0.15s;
    line-height: 1;
}
.hero-fav-btn-lg.faved { filter: grayscale(0); }
.hero-fav-btn-lg:hover { transform: scale(1.2); filter: grayscale(0); }

/* 收藏空状态 */
.fav-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 80px 24px;
    color: var(--text-secondary);
}
.fav-empty-icon { font-size: 56px; filter: grayscale(0.5); }
.fav-empty-title { font-size: 20px; font-weight: 600; color: var(--text-primary); }
.fav-empty-hint  { font-size: 14px; color: var(--text-muted); }
.btn-primary {
    background: var(--primary);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 10px 24px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
    margin-top: 8px;
}
.btn-primary:hover { background: var(--primary-dark); transform: translateY(-1px); }

/* 收藏英雄网格 */
.fav-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
}

.fav-hero-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    transition: var(--transition);
}
.fav-hero-card:hover { border-color: var(--primary); box-shadow: 0 4px 16px rgba(231,76,60,0.15); }

.fav-hero-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px;
    cursor: pointer;
    position: relative;
}

.fav-hero-img {
    width: 80px;
    height: 45px;
    border-radius: 6px;
    overflow: hidden;
    flex-shrink: 0;
}
.fav-hero-img img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }

.fav-hero-name { font-size: 15px; font-weight: 700; color: var(--text-primary); }
.fav-hero-sub  { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.fav-hero-roles { display: flex; gap: 4px; margin-top: 4px; flex-wrap: wrap; }

.fav-remove-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 14px;
    cursor: pointer;
    padding: 4px 6px;
    border-radius: 4px;
    transition: var(--transition);
}
.fav-remove-btn:hover { color: var(--primary); background: rgba(231,76,60,0.1); }

.fav-core-items {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px 12px;
    border-top: 1px solid var(--border);
    background: var(--bg-hover);
}
.fav-items-label { font-size: 11px; color: var(--text-muted); flex-shrink: 0; }
.fav-item-chip {
    width: 38px;
    height: 28px;
    border-radius: 4px;
    overflow: hidden;
    background: var(--bg-card);
}
.fav-item-chip img { width: 100%; height: 100%; object-fit: cover; }

/* =============================================
   Tier List
   ============================================= */
.tier-row {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 12px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 12px;
    transition: var(--transition);
}

.tier-badge {
    flex-shrink: 0;
    width: 100px;
    min-height: 60px;
    border: 2px solid;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    padding: 8px;
}
.tier-letter { font-size: 28px; font-weight: 900; line-height: 1; }
.tier-desc   { font-size: 9px; text-align: center; line-height: 1.3; opacity: 0.8; }

.tier-heroes {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-content: flex-start;
}

.tier-hero-chip {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: var(--bg-hover);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 6px 10px 6px 6px;
    cursor: pointer;
    transition: var(--transition);
    width: 200px;
}
.tier-hero-chip:hover { border-color: var(--primary); background: rgba(231,76,60,0.08); }
.tier-hero-chip img { width: 48px; height: 28px; border-radius: 4px; object-fit: cover; object-position: center top; flex-shrink: 0; }
.tier-hero-info { flex: 1; min-width: 0; }
.tier-hero-name { font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tier-hero-meta { display: flex; align-items: center; gap: 6px; margin-top: 2px; }
.tier-role-tag  { font-size: 10px; color: var(--text-muted); background: var(--bg-card); padding: 1px 5px; border-radius: 3px; }
.tier-wr        { font-size: 11px; font-weight: 700; font-family: monospace; }
.tier-hero-note { font-size: 10px; color: var(--text-muted); margin-top: 2px; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

@media (max-width: 639px) {
    .tier-row { flex-direction: column; }
    .tier-badge { width: 100%; flex-direction: row; min-height: auto; padding: 8px 12px; }
    .tier-letter { font-size: 22px; }
    .tier-hero-chip { width: calc(50% - 4px); }
}

/* =============================================
   英雄对比
   ============================================= */
.compare-selector {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
}
.compare-slot { flex: 1; }
.compare-slot-inner { background: var(--bg-card); border: 2px dashed var(--border); border-radius: var(--radius); min-height: 120px; display: flex; align-items: center; justify-content: center; transition: var(--transition); }
.compare-slot-inner:hover { border-color: var(--primary); }

.compare-slot-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    color: var(--text-muted);
    cursor: pointer;
    padding: 24px;
    width: 100%;
    justify-content: center;
    font-size: 13px;
}
.compare-plus { font-size: 36px; color: var(--primary); line-height: 1; }

.compare-slot-selected {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 16px;
    width: 100%;
}
.compare-slot-selected img {
    width: 160px;
    height: 90px;
    object-fit: cover;
    object-position: center top;
    border-radius: 8px;
    border: 2px solid var(--primary);
}
.compare-slot-name { font-size: 16px; font-weight: 700; }
.compare-slot-en   { font-size: 12px; color: var(--text-muted); }
.compare-clear-btn {
    background: var(--bg-hover);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    border-radius: 6px;
    padding: 4px 12px;
    font-size: 12px;
    cursor: pointer;
    transition: var(--transition);
    margin-top: 4px;
}
.compare-clear-btn:hover { border-color: var(--primary); color: var(--primary); }

.compare-vs {
    font-size: 28px;
    font-weight: 900;
    color: var(--secondary);
    flex-shrink: 0;
    text-shadow: 0 0 20px rgba(243,156,18,0.4);
}

/* 对比搜索覆盖层 */
.compare-search-overlay {
    display: none;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(480px, 90vw);
    max-height: 70vh;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
    z-index: 200;
    overflow: hidden;
    flex-direction: column;
}
.compare-search-overlay.active { display: flex; }

.compare-search-box {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    gap: 8px;
}
.compare-search-box input {
    flex: 1;
    background: var(--bg-hover);
    border: 1px solid var(--border);
    color: var(--text-primary);
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 14px;
    outline: none;
}
.compare-search-box button {
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: 18px;
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 4px;
}
.compare-search-box button:hover { color: var(--primary); }

.compare-search-results {
    overflow-y: auto;
    flex: 1;
}
.csearch-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    cursor: pointer;
    border-bottom: 1px solid var(--border);
    transition: var(--transition);
}
.csearch-item:hover { background: var(--bg-hover); }
.csearch-item img { width: 48px; height: 28px; border-radius: 4px; object-fit: cover; object-position: center top; }
.csearch-item span { font-size: 13px; font-weight: 500; }
.csearch-en { color: var(--text-muted); font-size: 11px; margin-left: auto; }

/* 对比结果 */
.compare-result { display: flex; flex-direction: column; gap: 16px; }
.cmp-section-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 4px 0;
    border-bottom: 1px solid var(--border);
    margin-top: 8px;
}
.cmp-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--bg-card);
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--border);
}
.cmp-table thead th {
    padding: 10px 16px;
    font-size: 13px;
    font-weight: 600;
    text-align: center;
    background: var(--bg-hover);
    border-bottom: 1px solid var(--border);
}
.cmp-table thead th:nth-child(1) { text-align: right; }
.cmp-table thead th:nth-child(3) { text-align: left; }
.cmp-table tbody tr:hover { background: var(--bg-hover); }
.cmp-val   { text-align: center; padding: 8px 16px; font-family: monospace; font-size: 14px; }
.cmp-val:nth-child(1) { text-align: right; }
.cmp-val:nth-child(3) { text-align: left; }
.cmp-label { text-align: center; padding: 8px; font-size: 12px; color: var(--text-muted); white-space: nowrap; }
.cmp-win   { color: var(--success); font-weight: 700; }

.cmp-builds {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
}
.cmp-build-col   { flex: 1; display: flex; flex-direction: column; gap: 8px; }
.cmp-build-role  { font-size: 12px; color: var(--secondary); font-weight: 600; }
.cmp-items-row   { display: flex; gap: 6px; flex-wrap: wrap; }
.cmp-item-chip   { width: 44px; height: 32px; border-radius: 4px; overflow: hidden; background: var(--bg-hover); }
.cmp-item-chip img { width: 100%; height: 100%; object-fit: cover; }
.cmp-build-tips  { font-size: 11px; color: var(--text-muted); line-height: 1.5; }
.cmp-vs-mini     { font-size: 16px; font-weight: 900; color: var(--secondary); flex-shrink: 0; align-self: center; }

.cmp-talents {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.cmp-talent-col {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.cmp-talent-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    color: var(--text-secondary);
    background: var(--bg-hover);
    border-radius: 4px;
    padding: 4px 8px;
}
.cmp-tlvl {
    font-size: 11px;
    font-weight: 700;
    color: var(--secondary);
    width: 22px;
    flex-shrink: 0;
    text-align: center;
}

@media (max-width: 639px) {
    .compare-selector { flex-direction: column; }
    .compare-vs { transform: rotate(90deg); }
    .cmp-talents { grid-template-columns: 1fr; }
    .cmp-table, .cmp-builds { font-size: 12px; }
}

/* =============================================
   物品合成路径
   ============================================= */
.recipe-badge {
    display: inline-block;
    background: rgba(52,152,219,0.15);
    color: var(--accent);
    font-size: 9px;
    padding: 1px 5px;
    border-radius: 3px;
    border: 1px solid rgba(52,152,219,0.3);
    font-weight: 500;
    vertical-align: middle;
    margin-left: 4px;
}

.recipe-tree {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 16px 0;
}
.recipe-final {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--bg-hover);
    border: 2px solid var(--secondary);
    border-radius: 10px;
    padding: 12px 20px;
    width: 100%;
}
.recipe-item-img { width: 52px; height: 38px; border-radius: 6px; overflow: hidden; background: var(--bg-card); }
.recipe-item-img img { width: 100%; height: 100%; object-fit: cover; }
.recipe-item-name { font-size: 15px; font-weight: 700; }
.recipe-total-cost { font-size: 13px; color: var(--secondary); margin-top: 2px; }

.recipe-arrow { font-size: 22px; color: var(--text-muted); }

.recipe-components {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    width: 100%;
}
.recipe-comp-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 10px 14px;
    min-width: 100px;
    transition: var(--transition);
}
.recipe-comp-item:hover { border-color: var(--accent); }
.recipe-comp-img { width: 48px; height: 36px; border-radius: 4px; overflow: hidden; }
.recipe-comp-img img { width: 100%; height: 100%; object-fit: cover; }
.recipe-comp-name { font-size: 11px; text-align: center; font-weight: 500; color: var(--text-secondary); }
.recipe-comp-cost { font-size: 11px; color: var(--secondary); font-weight: 600; font-family: monospace; }

/* =============================================
   局内备忘
   ============================================= */
.match-notes-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}
.match-notes-textarea {
    width: 100%;
    min-height: 160px;
    background: transparent;
    border: none;
    color: var(--text-primary);
    padding: 16px;
    font-size: 14px;
    font-family: 'Noto Sans SC', sans-serif;
    line-height: 1.6;
    resize: vertical;
    outline: none;
    display: block;
}
.match-notes-textarea::placeholder { color: var(--text-muted); }
.match-notes-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    padding: 8px 12px;
    border-top: 1px solid var(--border);
    background: var(--bg-hover);
}
.notes-saved-hint { font-size: 12px; color: var(--success); margin-right: auto; }

/* =============================================
   Ban/Pick 助手
   ============================================= */
.bp-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 20px;
    align-items: start;
}
.bp-panel {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.bp-panel-title { font-size: 13px; font-weight: 700; color: var(--text-secondary); margin-bottom: 4px; }
.bp-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    padding: 4px 0;
}
.bp-filter-btn {
    padding: 3px 8px;
    font-size: 11px;
    border-radius: 12px;
    border: 1px solid var(--border);
    background: var(--bg-hover);
    color: var(--text-muted);
    cursor: pointer;
    transition: var(--transition);
    white-space: nowrap;
}
.bp-filter-btn:hover { border-color: var(--accent); color: var(--accent); }
.bp-filter-btn.active { background: var(--accent); border-color: var(--accent); color: #fff; }
.bp-input {
    width: 100%;
    background: var(--bg-hover);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text-primary);
    padding: 8px 10px;
    font-size: 13px;
    outline: none;
    transition: var(--transition);
}
.bp-input:focus { border-color: var(--primary); }
.bp-enemy-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4px;
    max-height: 300px;
    overflow-y: auto;
}
.bp-hero-chip {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
    padding: 6px 4px;
    background: var(--bg-hover);
    border: 1px solid var(--border);
    border-radius: 6px;
    cursor: pointer;
    font-size: 10px;
    text-align: center;
    transition: var(--transition);
}
.bp-hero-chip:hover { border-color: var(--accent); }
.bp-hero-chip.bp-selected { border-color: var(--primary); background: rgba(231,76,60,0.15); }
.bp-hero-chip img { width: 44px; height: 24px; object-fit: cover; border-radius: 3px; }

.bp-selected-title { font-size: 12px; color: var(--text-muted); margin-top: 8px; }
.bp-selected-heroes { display: flex; flex-wrap: wrap; gap: 6px; min-height: 32px; }
.bp-tag {
    display: flex;
    align-items: center;
    gap: 4px;
    background: var(--bg-hover);
    border: 1px solid var(--primary);
    border-radius: 20px;
    padding: 3px 8px;
    font-size: 11px;
    color: var(--text-primary);
}
.bp-tag img { width: 28px; height: 16px; border-radius: 2px; object-fit: cover; }
.bp-clear-btn {
    background: none;
    border: 1px solid var(--border);
    color: var(--text-muted);
    border-radius: 6px;
    padding: 6px;
    font-size: 12px;
    cursor: pointer;
    margin-top: 4px;
    transition: var(--transition);
}
.bp-clear-btn:hover { border-color: var(--primary); color: var(--primary); }

/* 分析结果 */
.bp-result-panel { min-height: 300px; }
.bp-empty-hint { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 60px 24px; color: var(--text-muted); }

.bp-analysis { display: flex; flex-direction: column; gap: 16px; }
.bp-section {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
}
.bp-section-title { font-size: 13px; font-weight: 700; color: var(--text-secondary); margin-bottom: 12px; text-transform: uppercase; letter-spacing: 0.5px; }
.bp-heroes-row { display: flex; gap: 10px; flex-wrap: wrap; }
.bp-hero-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    background: var(--bg-hover);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 10px 12px;
    cursor: pointer;
    transition: var(--transition);
    font-size: 12px;
    min-width: 72px;
    text-align: center;
}
.bp-hero-card:hover { border-color: var(--accent); }
.bp-hero-card img { width: 56px; height: 32px; object-fit: cover; border-radius: 4px; }
.bp-ban-card { border-color: rgba(231,76,60,0.3); }
.bp-ban-card:hover { border-color: var(--primary); }
.bp-score { font-size: 11px; font-weight: 700; }

.bp-pick-grid { display: flex; flex-direction: column; gap: 6px; }
.bp-pick-row {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--bg-hover);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 8px 12px;
    cursor: pointer;
    transition: var(--transition);
}
.bp-pick-row:hover { border-color: var(--success); }
.bp-pick-row img { width: 48px; height: 28px; object-fit: cover; border-radius: 4px; flex-shrink: 0; }
.bp-pick-info { flex: 1; min-width: 0; }
.bp-pick-name { font-size: 13px; font-weight: 600; }
.bp-pick-meta { display: flex; gap: 4px; margin-top: 3px; flex-wrap: wrap; }
.bp-pick-stats { display: flex; flex-direction: column; align-items: flex-end; gap: 3px; }
.bp-counter-badge {
    font-size: 10px;
    background: rgba(46,204,113,0.15);
    color: var(--success);
    border: 1px solid rgba(46,204,113,0.3);
    border-radius: 4px;
    padding: 2px 6px;
    white-space: nowrap;
}
.bp-tip {
    background: rgba(52,152,219,0.08);
    border: 1px solid rgba(52,152,219,0.2);
    border-radius: 6px;
    padding: 8px 12px;
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.5;
}

@media (max-width: 900px) {
    .bp-layout { grid-template-columns: 1fr; }
    .bp-enemy-grid { grid-template-columns: repeat(4, 1fr); }
}

/* =============================================
   出门规划器
   ============================================= */
.sb-layout {
    display: grid;
    grid-template-columns: 220px 200px 1fr;
    gap: 16px;
    align-items: start;
}
.sb-label { font-size: 12px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 6px; }
.sb-hero-select, .sb-gold-panel, .sb-result {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
}
.sb-hero-scroll {
    max-height: 280px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 3px;
    margin-bottom: 8px;
}
.sb-hero-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 8px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    transition: var(--transition);
}
.sb-hero-item:hover { background: var(--bg-hover); }
.sb-hero-item.sb-hero-selected { background: rgba(231,76,60,0.15); color: var(--primary); }
.sb-hero-item img { width: 36px; height: 20px; object-fit: cover; border-radius: 3px; }
.sb-selected-hero {
    display: flex;
    align-items: center;
    padding: 8px;
    background: var(--bg-hover);
    border-radius: 6px;
    min-height: 40px;
}

.sb-gold-presets { display: flex; flex-direction: column; gap: 4px; }
.sb-preset {
    background: var(--bg-hover);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    border-radius: 6px;
    padding: 6px 10px;
    font-size: 12px;
    cursor: pointer;
    text-align: left;
    transition: var(--transition);
}
.sb-preset:hover, .sb-preset.active { border-color: var(--secondary); color: var(--secondary); background: rgba(243,156,18,0.08); }

.sb-style-btns { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.sb-style {
    background: var(--bg-hover);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    border-radius: 6px;
    padding: 7px;
    font-size: 12px;
    cursor: pointer;
    transition: var(--transition);
}
.sb-style:hover, .sb-style.active { border-color: var(--accent); color: var(--accent); background: rgba(52,152,219,0.08); }

.sb-result-header { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.sb-items-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); gap: 10px; }
.sb-item-card {
    background: var(--bg-hover);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 10px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}
.sb-item-img { width: 52px; height: 38px; border-radius: 4px; overflow: hidden; background: var(--bg-card); }
.sb-item-img img { width: 100%; height: 100%; object-fit: cover; }
.sb-item-name { font-size: 11px; font-weight: 600; line-height: 1.3; }
.sb-item-cost { font-size: 11px; color: var(--secondary); font-family: monospace; }
.sb-item-desc { font-size: 10px; color: var(--text-muted); line-height: 1.3; }

@media (max-width: 900px) {
    .sb-layout { grid-template-columns: 1fr; }
}

/* =============================================
   伤害计算器
   ============================================= */
.calc-layout {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
.calc-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
}
.calc-card-wide { grid-column: 1 / -1; }
.calc-card-title { font-size: 15px; font-weight: 700; margin-bottom: 16px; }
.calc-row { display: flex; flex-direction: column; gap: 4px; margin-bottom: 12px; }
.calc-row label { font-size: 12px; color: var(--text-muted); }
.calc-input {
    background: var(--bg-hover);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text-primary);
    padding: 8px 10px;
    font-size: 14px;
    font-family: monospace;
    outline: none;
    transition: var(--transition);
    width: 100%;
}
.calc-input:focus { border-color: var(--accent); }
.calc-formula {
    font-size: 11px;
    color: var(--text-muted);
    background: var(--bg-hover);
    border-radius: 4px;
    padding: 6px 10px;
    font-family: monospace;
    margin-bottom: 12px;
    line-height: 1.4;
}
.calc-result {
    font-size: 28px;
    font-weight: 900;
    color: var(--secondary);
    font-family: monospace;
    margin: 8px 0;
}
.calc-note { font-size: 11px; color: var(--text-muted); line-height: 1.5; }
.calc-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.calc-table th { padding: 8px 12px; background: var(--bg-hover); text-align: center; font-size: 12px; color: var(--text-muted); border-bottom: 1px solid var(--border); }
.calc-table td { padding: 7px 12px; text-align: center; border-bottom: 1px solid var(--border); font-family: monospace; }
.calc-table tr:hover td { background: var(--bg-hover); }

@media (max-width: 900px) {
    .calc-layout { grid-template-columns: 1fr; }
}

/* =============================================
   版本日志
   ============================================= */
.pn-header {
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 16px;
    padding: 16px 20px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
}
.pn-version { font-size: 28px; font-weight: 900; color: var(--secondary); }
.pn-date { font-size: 14px; color: var(--text-muted); }

.pn-filter-bar { display: flex; gap: 8px; margin-bottom: 20px; flex-wrap: wrap; }
.pn-filter {
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    border-radius: 20px;
    padding: 6px 16px;
    font-size: 13px;
    cursor: pointer;
    transition: var(--transition);
}
.pn-filter:hover, .pn-filter.active { border-color: var(--primary); color: var(--primary); background: rgba(231,76,60,0.08); }

.pn-section {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    margin-bottom: 16px;
}
.pn-section-title { font-size: 15px; font-weight: 700; margin-bottom: 14px; }
.pn-changes { display: flex; flex-direction: column; gap: 8px; }
.pn-change {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 8px 12px;
    background: var(--bg-hover);
    border-radius: 6px;
    font-size: 13px;
    line-height: 1.5;
}
.pn-tag {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 3px;
    border: 1px solid;
    white-space: nowrap;
    flex-shrink: 0;
    margin-top: 1px;
}
.pn-hero-name {
    font-weight: 700;
    color: var(--accent);
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
}
.pn-hero-name:hover { text-decoration: underline; }
.pn-change-text { color: var(--text-secondary); }

/* ===== 术语词典 ===== */
.glossary-group { margin-bottom: 28px; }
.glossary-group-title {
    font-size: 13px; font-weight: 700; color: var(--accent);
    text-transform: uppercase; letter-spacing: 0.05em;
    margin-bottom: 10px; padding-bottom: 6px;
    border-bottom: 1px solid var(--border);
}
.glossary-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 10px;
}
.glossary-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 12px 14px; transition: var(--transition);
}
.glossary-card:hover { border-color: var(--accent); transform: translateY(-1px); }
.glossary-term { font-size: 15px; font-weight: 700; color: var(--text-primary); margin-bottom: 4px; }
.glossary-en { font-size: 12px; color: var(--text-muted); font-weight: 400; }
.glossary-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.6; }
.glossary-example {
    font-size: 11px; color: var(--text-muted); margin-top: 6px;
    font-style: italic; padding-left: 8px; border-left: 2px solid var(--border);
}

/* ===== 指南公共布局 ===== */
.guide-layout { display: grid; grid-template-columns: 180px 1fr; gap: 24px; align-items: start; }
.guide-toc {
    position: sticky; top: 80px; background: var(--bg-card);
    border: 1px solid var(--border); border-radius: var(--radius); padding: 14px;
}
.guide-toc-title { font-size: 12px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; margin-bottom: 10px; }
.guide-toc-item { display: block; font-size: 12px; color: var(--text-secondary); padding: 5px 8px; border-radius: 6px; cursor: pointer; transition: var(--transition); margin-bottom: 2px; }
.guide-toc-item:hover { background: var(--bg-hover); color: var(--accent); }
.guide-content { min-width: 0; }
.guide-section { margin-bottom: 40px; scroll-margin-top: 80px; }
.guide-section h2 { font-size: 18px; font-weight: 700; color: var(--text-primary); margin-bottom: 16px; padding-bottom: 8px; border-bottom: 2px solid var(--accent); }
.guide-section p { color: var(--text-secondary); line-height: 1.7; margin-bottom: 12px; }
.guide-info-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; margin-top: 16px; }
.guide-info-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; text-align: center; }
.guide-info-icon { font-size: 28px; margin-bottom: 8px; }
.guide-info-title { font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 4px; }
.guide-info-desc { font-size: 12px; color: var(--text-muted); line-height: 1.5; }
.guide-map-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 10px; }
.guide-res-card { display: flex; gap: 12px; align-items: flex-start; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px; }
.guide-res-icon { font-size: 22px; flex-shrink: 0; margin-top: 2px; }
.guide-res-name { font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 3px; }
.guide-res-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.5; }
.guide-roles-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 14px; }
.role-detail-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; }
.role-detail-header { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.role-pos-badge { padding: 2px 10px; border-radius: 12px; font-size: 11px; font-weight: 700; }
.role-detail-icon { font-size: 20px; }
.role-detail-name { font-size: 16px; font-weight: 700; color: var(--text-primary); }
.role-detail-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.6; margin-bottom: 10px; }
.role-detail-keys { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.role-key-tag { font-size: 11px; background: var(--bg-hover); border: 1px solid var(--border); border-radius: 4px; padding: 2px 8px; color: var(--text-secondary); }
.role-detail-heroes { margin-bottom: 8px; }
.role-heroes-label { font-size: 11px; color: var(--text-muted); margin-right: 4px; }
.role-newbie-tip { font-size: 11px; color: var(--success); background: rgba(46,204,113,0.08); border-radius: 6px; padding: 6px 10px; border: 1px solid rgba(46,204,113,0.2); }
.guide-basics-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px; }
.guide-basic-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; }
.guide-basic-icon { font-size: 24px; margin-bottom: 8px; }
.guide-basic-title { font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 6px; }
.guide-basic-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.6; }
.guide-hero-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 12px; }
.guide-hero-card { display: flex; gap: 12px; align-items: flex-start; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px; cursor: pointer; transition: var(--transition); }
.guide-hero-card:hover { border-color: var(--accent); transform: translateY(-1px); }
.guide-hero-card img { width: 72px; height: 40px; border-radius: 6px; object-fit: cover; flex-shrink: 0; }
.guide-hero-name { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.guide-hero-pos { font-size: 11px; color: var(--accent); margin-bottom: 4px; }
.guide-hero-why { font-size: 12px; color: var(--text-secondary); line-height: 1.5; margin-bottom: 6px; }
.guide-hero-stars { font-size: 11px; color: var(--secondary); }
.guide-tips-list { display: flex; flex-direction: column; gap: 10px; }
.guide-tip-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0; background: var(--bg-card); border-radius: var(--radius); overflow: hidden; border: 1px solid var(--border); }
.guide-tip-wrong { padding: 10px 14px; font-size: 12px; background: rgba(231,76,60,0.08); color: var(--text-secondary); border-right: 1px solid var(--border); }
.guide-tip-right { padding: 10px 14px; font-size: 12px; background: rgba(46,204,113,0.06); color: var(--text-secondary); }
.pro-timing-grid { display: flex; flex-direction: column; gap: 6px; }
.pro-timing-row { display: flex; align-items: center; gap: 12px; background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px; padding: 10px 14px; }
.pro-timing-time { font-family: monospace; font-size: 13px; font-weight: 700; color: var(--secondary); min-width: 54px; flex-shrink: 0; }
.pro-timing-icon { font-size: 18px; flex-shrink: 0; }
.pro-timing-label { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.pro-timing-detail { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.pro-micro-list { display: flex; flex-direction: column; gap: 10px; }
.pro-micro-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; }
.pro-micro-header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.pro-micro-title { font-size: 14px; font-weight: 700; color: var(--text-primary); flex: 1; }
.pro-micro-level { font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 4px; }
.level-中级 { background: rgba(59,130,246,0.2); color: #3b82f6; }
.level-高级 { background: rgba(239,68,68,0.2); color: #ef4444; }
.pro-micro-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.6; }
.pro-meta-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; }
.guide-meta-card { display: flex; gap: 12px; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; }
.guide-meta-icon { font-size: 24px; flex-shrink: 0; }
.guide-meta-title { font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 5px; }
.guide-meta-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.6; }

@media (max-width: 768px) {
    .guide-layout { grid-template-columns: 1fr; }
    .guide-toc { display: none; }
    .guide-tip-row { grid-template-columns: 1fr; }
    .guide-tip-wrong { border-right: none; border-bottom: 1px solid var(--border); }
    .pro-timing-time { min-width: 44px; font-size: 11px; }
    .glossary-cards { grid-template-columns: 1fr; }
}

/* ===== 术语词典 ===== */
.glossary-group { margin-bottom: 28px; }
.glossary-group-title {
    font-size: 13px; font-weight: 700; color: var(--accent);
    text-transform: uppercase; letter-spacing: 0.05em;
    margin-bottom: 10px; padding-bottom: 6px;
    border-bottom: 1px solid var(--border);
}
.glossary-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 10px;
}
.glossary-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 12px 14px; transition: var(--transition);
}
.glossary-card:hover { border-color: var(--accent); transform: translateY(-1px); }
.glossary-term { font-size: 15px; font-weight: 700; color: var(--text-primary); margin-bottom: 4px; }
.glossary-en { font-size: 12px; color: var(--text-muted); font-weight: 400; }
.glossary-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.6; }
.glossary-example {
    font-size: 11px; color: var(--text-muted); margin-top: 6px;
    font-style: italic; padding-left: 8px; border-left: 2px solid var(--border);
}

/* ===== 指南公共布局 ===== */
.guide-layout { display: grid; grid-template-columns: 180px 1fr; gap: 24px; align-items: start; }
.guide-toc {
    position: sticky; top: 80px; background: var(--bg-card);
    border: 1px solid var(--border); border-radius: var(--radius); padding: 14px;
}
.guide-toc-title { font-size: 12px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; margin-bottom: 10px; }
.guide-toc-item { display: block; font-size: 12px; color: var(--text-secondary); padding: 5px 8px; border-radius: 6px; cursor: pointer; transition: var(--transition); margin-bottom: 2px; }
.guide-toc-item:hover { background: var(--bg-hover); color: var(--accent); }
.guide-content { min-width: 0; }
.guide-section { margin-bottom: 40px; scroll-margin-top: 80px; }
.guide-section h2 { font-size: 18px; font-weight: 700; color: var(--text-primary); margin-bottom: 16px; padding-bottom: 8px; border-bottom: 2px solid var(--accent); }
.guide-section p { color: var(--text-secondary); line-height: 1.7; margin-bottom: 12px; }
.guide-info-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; margin-top: 16px; }
.guide-info-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; text-align: center; }
.guide-info-icon { font-size: 28px; margin-bottom: 8px; }
.guide-info-title { font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 4px; }
.guide-info-desc { font-size: 12px; color: var(--text-muted); line-height: 1.5; }
.guide-map-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 10px; }
.guide-res-card { display: flex; gap: 12px; align-items: flex-start; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px; }
.guide-res-icon { font-size: 22px; flex-shrink: 0; margin-top: 2px; }
.guide-res-name { font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 3px; }
.guide-res-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.5; }
.guide-roles-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 14px; }
.role-detail-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; }
.role-detail-header { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.role-pos-badge { padding: 2px 10px; border-radius: 12px; font-size: 11px; font-weight: 700; }
.role-detail-icon { font-size: 20px; }
.role-detail-name { font-size: 16px; font-weight: 700; color: var(--text-primary); }
.role-detail-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.6; margin-bottom: 10px; }
.role-detail-keys { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.role-key-tag { font-size: 11px; background: var(--bg-hover); border: 1px solid var(--border); border-radius: 4px; padding: 2px 8px; color: var(--text-secondary); }
.role-detail-heroes { margin-bottom: 8px; }
.role-heroes-label { font-size: 11px; color: var(--text-muted); margin-right: 4px; }
.role-newbie-tip { font-size: 11px; color: var(--success); background: rgba(46,204,113,0.08); border-radius: 6px; padding: 6px 10px; border: 1px solid rgba(46,204,113,0.2); }
.guide-basics-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px; }
.guide-basic-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; }
.guide-basic-icon { font-size: 24px; margin-bottom: 8px; }
.guide-basic-title { font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 6px; }
.guide-basic-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.6; }
.guide-hero-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 12px; }
.guide-hero-card { display: flex; gap: 12px; align-items: flex-start; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px; cursor: pointer; transition: var(--transition); }
.guide-hero-card:hover { border-color: var(--accent); transform: translateY(-1px); }
.guide-hero-card img { width: 72px; height: 40px; border-radius: 6px; object-fit: cover; flex-shrink: 0; }
.guide-hero-name { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.guide-hero-pos { font-size: 11px; color: var(--accent); margin-bottom: 4px; }
.guide-hero-why { font-size: 12px; color: var(--text-secondary); line-height: 1.5; margin-bottom: 6px; }
.guide-hero-stars { font-size: 11px; color: var(--secondary); }
.guide-tips-list { display: flex; flex-direction: column; gap: 10px; }
.guide-tip-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0; background: var(--bg-card); border-radius: var(--radius); overflow: hidden; border: 1px solid var(--border); }
.guide-tip-wrong { padding: 10px 14px; font-size: 12px; background: rgba(231,76,60,0.08); color: var(--text-secondary); border-right: 1px solid var(--border); }
.guide-tip-right { padding: 10px 14px; font-size: 12px; background: rgba(46,204,113,0.06); color: var(--text-secondary); }
.pro-timing-grid { display: flex; flex-direction: column; gap: 6px; }
.pro-timing-row { display: flex; align-items: center; gap: 12px; background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px; padding: 10px 14px; }
.pro-timing-time { font-family: monospace; font-size: 13px; font-weight: 700; color: var(--secondary); min-width: 54px; flex-shrink: 0; }
.pro-timing-icon { font-size: 18px; flex-shrink: 0; }
.pro-timing-label { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.pro-timing-detail { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.pro-micro-list { display: flex; flex-direction: column; gap: 10px; }
.pro-micro-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; }
.pro-micro-header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.pro-micro-title { font-size: 14px; font-weight: 700; color: var(--text-primary); flex: 1; }
.pro-micro-level { font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 4px; }
.level-中级 { background: rgba(59,130,246,0.2); color: #3b82f6; }
.level-高级 { background: rgba(239,68,68,0.2); color: #ef4444; }
.pro-micro-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.6; }
.pro-meta-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; }
.guide-meta-card { display: flex; gap: 12px; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; }
.guide-meta-icon { font-size: 24px; flex-shrink: 0; }
.guide-meta-title { font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 5px; }
.guide-meta-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.6; }

@media (max-width: 768px) {
    .guide-layout { grid-template-columns: 1fr; }
    .guide-toc { display: none; }
    .guide-tip-row { grid-template-columns: 1fr; }
    .guide-tip-wrong { border-right: none; border-bottom: 1px solid var(--border); }
    .pro-timing-time { min-width: 44px; font-size: 11px; }
    .glossary-cards { grid-template-columns: 1fr; }
}

/* ===== 阵容评分器 ===== */
.lu-layout{display:flex;flex-direction:column;gap:16px}
.lu-team{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.lu-radiant{border-top:3px solid #2ecc71}.lu-dire{border-top:3px solid #e74c3c}
.lu-team-title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:12px}
.lu-radiant,.lu-dire{display:grid;grid-template-columns:120px repeat(5,1fr);gap:8px;align-items:center}
.lu-slot{height:80px;background:var(--bg-hover);border:1px dashed var(--border);border-radius:8px;overflow:hidden}
.lu-slot-inner{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;gap:4px;transition:var(--transition)}
.lu-slot-inner:hover{background:rgba(52,152,219,0.2)}
.lu-plus{font-size:20px;color:var(--text-muted)}.lu-pos-label{font-size:11px;color:var(--text-muted)}
.lu-slot-hero{position:relative;height:100%;cursor:pointer}
.lu-slot-hero img{width:100%;height:100%;object-fit:cover;display:block}
.lu-hero-name{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.7);font-size:10px;text-align:center;padding:2px;color:#fff}
.lu-remove{position:absolute;top:2px;right:2px;background:rgba(231,76,60,.8);border:none;border-radius:50%;width:18px;height:18px;color:#fff;cursor:pointer;font-size:10px;line-height:18px;text-align:center;padding:0}
.lu-actions{display:flex;gap:12px;justify-content:center;margin:8px 0}
.lu-result{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;min-height:100px}
.lu-result-verdict{font-size:16px;font-weight:700;text-align:center;color:var(--text-primary);margin-bottom:12px;padding:10px;background:var(--bg-hover);border-radius:8px}
.lu-score-legend{text-align:center;font-size:12px;color:var(--text-muted);margin-bottom:12px}
.lu-dims{display:flex;flex-direction:column;gap:8px}
.lu-dim-row{display:grid;grid-template-columns:90px 1fr 60px;align-items:center;gap:8px}
.lu-dim-label{font-size:12px;color:var(--text-secondary)}
.lu-bars{display:flex;align-items:center;gap:4px;flex:1}
.lu-bar{height:24px;border-radius:4px;display:flex;align-items:center;padding:0 6px;font-size:11px;font-weight:700;color:#fff;min-width:30px;justify-content:center;transition:width .4s}
.lu-bar-sep{font-size:11px;color:var(--text-muted);flex-shrink:0}
.lu-dim-winner{font-size:11px;font-weight:600;text-align:right}
.lu-tips-section{margin-top:14px}
.lu-tips-title{font-size:13px;font-weight:700;color:var(--text-secondary);margin-bottom:8px}
.lu-tip{font-size:12px;color:var(--text-secondary);padding:8px 12px;border-radius:6px;margin-bottom:6px}
.lu-tip-r{background:rgba(46,204,113,.08);border-left:3px solid #2ecc71}
.lu-tip-d{background:rgba(231,76,60,.08);border-left:3px solid #e74c3c}
.csearch-picked{opacity:.5}

/* ===== 英雄风格测试 ===== */
.ht-container{max-width:600px;margin:0 auto}
.ht-progress-bar{height:6px;background:var(--bg-hover);border-radius:3px;margin-bottom:12px;overflow:hidden}
.ht-progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s}
.ht-step-label{font-size:12px;color:var(--text-muted);margin-bottom:12px}
.ht-question{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:20px;line-height:1.5}
.ht-options{display:flex;flex-direction:column;gap:10px}
.ht-option{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;text-align:left;font-size:14px;color:var(--text-primary);cursor:pointer;transition:var(--transition)}
.ht-option:hover{border-color:var(--accent);background:var(--bg-hover);transform:translateX(4px)}
.ht-back{background:none;border:1px solid var(--border);border-radius:6px;padding:6px 14px;color:var(--text-muted);cursor:pointer;margin-top:14px;font-size:13px;transition:var(--transition)}
.ht-back:hover{border-color:var(--accent);color:var(--accent)}
.ht-result{max-width:600px;margin:0 auto}
.ht-result-pos{border:2px solid;border-radius:12px;padding:20px;text-align:center;margin-bottom:24px}
.ht-result-label{font-size:13px;color:var(--text-muted);margin-bottom:8px}
.ht-result-pos-name{font-size:22px;font-weight:800}
.ht-rec-title{font-size:14px;font-weight:700;color:var(--text-secondary);margin-bottom:12px}
.ht-rec-heroes{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.ht-rec-hero{display:flex;align-items:center;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;cursor:pointer;transition:var(--transition)}
.ht-rec-hero:hover{border-color:var(--accent);transform:translateX(4px)}
.ht-rec-hero img{width:64px;height:36px;border-radius:6px;object-fit:cover;flex-shrink:0}
.ht-rec-hero-name{font-size:14px;font-weight:700;color:var(--text-primary)}
.ht-rec-hero-reason{font-size:12px;color:var(--text-muted);margin-top:3px}
.ht-pos-all{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:16px}
.ht-pos-all-title{font-size:13px;font-weight:700;color:var(--text-secondary);margin-bottom:12px}
.ht-pos-row{display:grid;grid-template-columns:150px 1fr 40px;align-items:center;gap:8px;margin-bottom:8px}
.ht-pos-label{font-size:12px;font-weight:600}
.ht-pos-bar-wrap{height:12px;background:var(--bg-hover);border-radius:6px;overflow:hidden}
.ht-pos-bar{height:100%;border-radius:6px;transition:width .4s}
.ht-pos-score{font-size:12px;color:var(--text-muted);text-align:right}

/* ===== 局内决策助手 ===== */
.dc-layout{display:grid;grid-template-columns:340px 1fr;gap:20px;align-items:start}
.dc-input-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.dc-section-title{font-size:13px;font-weight:700;color:var(--text-secondary);margin-bottom:10px}
.dc-time-presets{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.dc-preset{padding:4px 12px;border:1px solid var(--border);border-radius:12px;background:var(--bg-hover);color:var(--text-muted);cursor:pointer;font-size:12px;transition:var(--transition)}
.dc-preset.active,.dc-preset:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.dc-status-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dc-status-label{font-size:11px;color:var(--text-muted);margin-bottom:4px}
.dc-select{width:100%;background:var(--bg-hover);border:1px solid var(--border);border-radius:6px;padding:6px 8px;color:var(--text-primary);font-size:12px}
.dc-result{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;min-height:200px}
.dc-result-header{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.dc-time-badge{background:var(--accent);color:#fff;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:700}
.dc-badge{font-size:11px;padding:3px 10px;border-radius:10px;background:var(--bg-hover);border:1px solid var(--border)}
.dc-badge-ahead{background:rgba(46,204,113,.15);border-color:#2ecc71;color:#2ecc71}
.dc-badge-behind{background:rgba(231,76,60,.15);border-color:#e74c3c;color:#e74c3c}
.dc-block-title{font-size:13px;font-weight:700;color:var(--text-secondary);margin-bottom:10px;margin-top:14px}
.dc-priority-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;background:var(--bg-hover);border-radius:8px;padding:8px 12px}
.dc-priority-num{background:var(--accent);color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.dc-priority-icon{font-size:16px;flex-shrink:0}
.dc-priority-text{font-size:13px;color:var(--text-secondary);line-height:1.5}
.dc-action-row{display:flex;gap:8px;font-size:13px;color:var(--text-secondary);padding:6px 0;border-bottom:1px solid var(--border)}
.dc-warnings{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.3);border-radius:8px;padding:12px;margin-top:12px}
.dc-warning-row{font-size:12px;color:#f59e0b;margin-bottom:6px}

/* ===== 战绩查询 ===== */
.pf-layout{max-width:700px}
.pf-search-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}
.pf-search-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:10px}
.pf-search-hint{font-size:12px;color:var(--text-muted);margin-bottom:14px;line-height:1.6}
.pf-search-hint code{background:var(--bg-hover);padding:1px 5px;border-radius:4px}
.pf-search-hint kbd{background:var(--bg-hover);border:1px solid var(--border);padding:1px 6px;border-radius:4px}
.pf-input-row{display:flex;gap:8px}.pf-input-row .bp-input{flex:1}
.pf-loading{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}
.pf-error{text-align:center;padding:40px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}
.pf-result-wrap{display:flex;flex-direction:column;gap:16px}
.pf-profile-card{display:flex;align-items:center;gap:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.pf-avatar{width:72px;height:72px;border-radius:8px;flex-shrink:0}
.pf-name{font-size:18px;font-weight:700;color:var(--text-primary)}
.pf-rank{font-size:13px;color:var(--text-muted);margin-top:4px}
.pf-plus-badge{display:inline-block;background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;font-size:10px;padding:2px 8px;border-radius:10px;margin-top:4px;font-weight:700}
.pf-stats-section,.pf-heroes-section,.pf-matches-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.pf-section-title{font-size:13px;font-weight:700;color:var(--text-secondary);margin-bottom:12px}
.pf-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pf-stat{text-align:center}
.pf-stat-val{font-size:22px;font-weight:700;color:var(--text-primary)}
.pf-stat-label{font-size:11px;color:var(--text-muted);margin-top:2px}
.pf-hero-list{display:flex;flex-direction:column;gap:8px}
.pf-hero-row{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;transition:var(--transition)}
.pf-hero-row:hover{background:var(--bg-hover)}
.pf-hero-row img{width:52px;height:30px;border-radius:4px;object-fit:cover}
.pf-hero-row-name{font-size:13px;font-weight:600;color:var(--text-primary)}
.pf-hero-row-stats{font-size:12px;color:var(--text-muted);margin-top:2px}
.pf-matches-list{display:flex;flex-direction:column;gap:6px}
.pf-match-row{display:grid;grid-template-columns:24px 42px 80px 50px 60px;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;font-size:12px}
.pf-win{background:rgba(46,204,113,.08);border-left:3px solid #2ecc71}
.pf-loss{background:rgba(231,76,60,.08);border-left:3px solid #e74c3c}
.pf-match-hero-img{width:42px;height:24px;border-radius:3px;object-fit:cover}
.pf-match-kda{font-weight:600;color:var(--text-primary);font-family:monospace}
.pf-match-dur{color:var(--text-muted)}

/* ===== 装备合成助手 ===== */
.ch-layout{display:grid;grid-template-columns:360px 1fr;gap:20px;align-items:start}
.ch-left{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.ch-title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:10px}
.ch-items-grid{display:flex;flex-wrap:wrap;gap:6px;max-height:280px;overflow-y:auto;padding:4px;border:1px solid var(--border);border-radius:8px;margin-bottom:10px}
.ch-item-chip{display:flex;align-items:center;gap:4px;padding:3px 8px 3px 4px;border:1px solid var(--border);border-radius:6px;cursor:pointer;background:var(--bg-hover);transition:var(--transition);font-size:11px;color:var(--text-secondary)}
.ch-item-chip img{width:28px;height:20px;border-radius:3px;object-fit:cover}
.ch-item-chip:hover{border-color:var(--accent)}
.ch-item-selected{background:rgba(52,152,219,.15);border-color:var(--accent);color:var(--accent)}
.ch-selected-wrap{border-top:1px solid var(--border);padding-top:10px}
.ch-selected-title{font-size:12px;font-weight:700;color:var(--text-secondary);margin-bottom:6px}
.ch-selected-list{display:flex;flex-wrap:wrap;gap:4px;min-height:28px;margin-bottom:8px}
.ch-result{min-height:200px}
.ch-result-header{font-size:13px;color:var(--text-muted);margin-bottom:12px}
.ch-recipe-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-bottom:10px}
.ch-affordable{border-color:var(--secondary)}
.ch-complete{border-color:var(--success);background:rgba(46,204,113,.05)}
.ch-recipe-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.ch-recipe-icon img{width:42px;height:32px;border-radius:6px;object-fit:cover}
.ch-recipe-info{flex:1}
.ch-recipe-name{font-size:14px;font-weight:700;color:var(--text-primary)}
.ch-recipe-cost{font-size:12px;color:var(--secondary)}
.ch-completion-pct{font-size:18px;font-weight:800}
.ch-components{display:flex;flex-wrap:wrap;gap:6px}
.ch-comp{display:flex;align-items:center;gap:4px;padding:3px 8px 3px 4px;border-radius:6px;border:1px solid var(--border);font-size:11px}
.ch-comp img{width:24px;height:18px;border-radius:3px;object-fit:cover}
.ch-comp-have{background:rgba(46,204,113,.1);border-color:rgba(46,204,113,.4)}
.ch-comp-need{background:var(--bg-hover);color:var(--text-muted)}

@media(max-width:768px){
    .lu-radiant,.lu-dire{grid-template-columns:80px repeat(5,1fr)}
    .dc-layout,.ch-layout{grid-template-columns:1fr}
    .ht-pos-row{grid-template-columns:120px 1fr 36px}
    .pf-match-row{grid-template-columns:20px 36px 70px 44px 50px}
}

/* ===== 局内快查 ===== */
.quicksearch-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding-top:80px;opacity:0;pointer-events:none;transition:opacity .2s}
.quicksearch-overlay.active{opacity:1;pointer-events:all}
.quicksearch-box{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:100%;max-width:600px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.quicksearch-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg-hover)}
.quicksearch-hint{font-size:13px;font-weight:700;color:var(--accent)}
.quicksearch-esc{background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:2px 8px;font-size:11px;color:var(--text-muted)}
.quicksearch-input{width:100%;background:transparent;border:none;padding:14px 16px;font-size:16px;color:var(--text-primary);outline:none}
.quicksearch-results{max-height:400px;overflow-y:auto}
.qs-hint,.qs-empty{padding:20px 16px;font-size:13px;color:var(--text-muted);text-align:center;line-height:1.8}
.qs-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;transition:var(--transition)}
.qs-item:hover{background:var(--bg-hover)}
.qs-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.qs-icon img{width:100%;height:100%;object-fit:cover;border-radius:6px}
.qs-info{flex:1;min-width:0}
.qs-label{font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qs-en{font-size:11px;color:var(--text-muted)}
.qs-sub{font-size:11px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qs-tag{font-size:10px;background:var(--bg-hover);border:1px solid var(--border);border-radius:10px;padding:2px 8px;color:var(--text-muted);flex-shrink:0}

/* ===== 公共英雄选择器组件（HeroPicker）===== */
.hpicker { display:flex; flex-direction:column; gap:8px; }
.hpicker-search-row { display:flex; gap:8px; }
.hpicker-input { flex:1; }

.hpicker-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
}
.hpicker-filter {
    padding: 3px 10px;
    border-radius: 12px;
    border: 1px solid var(--border);
    background: var(--bg-card);
    color: var(--text-muted);
    font-size: 11px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
    line-height: 1.6;
}
.hpicker-filter:hover { border-color: var(--accent); color: var(--accent); }
.hpicker-filter.active { background: var(--accent-dim); color: var(--accent); border-color: var(--accent); }
.hpicker-sep { width:1px; height:16px; background:var(--border); margin: 0 2px; }

/* 英雄网格 */
.hpicker-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    padding: 4px 0;
    scrollbar-width: thin;
    scrollbar-color: var(--border) transparent;
}
.hpicker-grid::-webkit-scrollbar { width: 4px; }
.hpicker-grid::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

/* normal 模式：图片+名字 */
.hpicker-grid-normal .hpicker-chip {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
    padding: 5px 4px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    background: var(--bg-card);
    cursor: pointer;
    transition: var(--transition);
    width: 64px;
    text-align: center;
}
.hpicker-grid-normal .hpicker-chip:hover { border-color: var(--accent); background: var(--accent-dim); }
.hpicker-grid-normal .hpicker-chip-active { border-color: var(--accent) !important; background: var(--accent-dim) !important; box-shadow: 0 0 8px var(--accent-glow); }
.hpicker-grid-normal .hpicker-chip-img { width: 54px; height: 30px; border-radius: 3px; object-fit: cover; }
.hpicker-grid-normal .hpicker-chip-name { font-size: 10px; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 58px; line-height: 1.2; }

/* compact 模式：只显示图片 */
.hpicker-grid-compact .hpicker-chip {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    background: var(--bg-card);
    cursor: pointer;
    transition: var(--transition);
    overflow: hidden;
}
.hpicker-grid-compact .hpicker-chip:hover { border-color: var(--accent); }
.hpicker-grid-compact .hpicker-chip-active { border-color: var(--accent) !important; box-shadow: 0 0 8px var(--accent-glow); }
.hpicker-grid-compact .hpicker-chip-img { width: 48px; height: 27px; object-fit: cover; display: block; }
.hpicker-grid-compact .hpicker-chip-name { display: none; }

/* ===== 克制图谱 ===== */
.cv-layout{display:grid;grid-template-columns:300px 1fr;gap:20px;align-items:start}
.cv-controls{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:10px}
.cv-picker-label{font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.cv-action-row{display:flex;gap:8px;flex-wrap:wrap}
.cv-search-wrap{position:relative;margin-bottom:10px}
.cv-hero-list{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;z-index:10;max-height:200px;overflow-y:auto}
.cv-suggest{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;font-size:13px;transition:var(--transition)}
.cv-suggest:hover{background:var(--bg-hover)}
.cv-suggest img{width:36px;height:20px;border-radius:3px;object-fit:cover}
.cv-selected{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;min-height:32px}
.cv-tag{display:flex;align-items:center;gap:4px;background:var(--bg-hover);border:1px solid var(--border);border-radius:6px;padding:3px 8px;font-size:12px}
.cv-tag img{width:28px;height:16px;border-radius:3px;object-fit:cover}
.cv-tag button{background:none;border:none;color:var(--primary);cursor:pointer;font-size:11px;padding:0 2px}
.cv-canvas-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.cv-svg{width:100%;height:auto;min-height:300px;display:block}
.cv-legend{display:flex;gap:16px;margin-top:8px;font-size:12px;color:var(--text-muted)}
.cv-legend-item{display:flex;align-items:center;gap:4px}

/* ===== 版本对比 ===== */
.pd-controls{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.pd-filter{padding:5px 14px;border:1px solid var(--border);border-radius:12px;background:var(--bg-hover);color:var(--text-muted);cursor:pointer;font-size:12px;transition:var(--transition)}
.pd-filter.active,.pd-filter:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.pd-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.pd-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;cursor:pointer;transition:var(--transition)}
.pd-card:hover{transform:translateY(-2px);border-color:var(--accent)}
.pd-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.pd-card-header img{width:56px;height:32px;border-radius:6px;object-fit:cover;flex-shrink:0}
.pd-card-info{flex:1}
.pd-hero-name{font-size:14px;font-weight:700;color:var(--text-primary)}
.pd-hero-en{font-size:11px;color:var(--text-muted)}
.pd-change{font-size:16px;font-weight:700;flex-shrink:0}
.pd-reason{font-size:12px;color:var(--text-secondary);line-height:1.5}

/* ===== 技能连招 ===== */
.cb-layout{display:grid;grid-template-columns:160px 1fr;gap:20px;align-items:start}
.cb-hero-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.cb-hero-item{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;transition:var(--transition);border-bottom:1px solid var(--border)}
.cb-hero-item:last-child{border-bottom:none}
.cb-hero-item:hover,.cb-hero-item.cb-active{background:var(--bg-hover);color:var(--accent)}
.cb-hero-item.cb-active{border-left:3px solid var(--accent)}
.cb-hero-item img{width:44px;height:25px;border-radius:4px;object-fit:cover;flex-shrink:0}
.cb-hero-name{font-size:13px;font-weight:600}
.cb-detail{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.cb-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.cb-header img{width:72px;height:40px;border-radius:8px;object-fit:cover}
.cb-title{font-size:18px;font-weight:700;color:var(--text-primary)}
.cb-en{font-size:12px;color:var(--text-muted);font-weight:400}
.cb-combo-block{background:var(--bg-hover);border-radius:10px;padding:14px;margin-bottom:14px}
.cb-combo-name{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:12px}
.cb-difficulty{font-size:12px;color:var(--text-muted);font-weight:400;margin-left:8px}
.cb-timeline{display:flex;flex-direction:column;gap:0}
.cb-step{display:flex;flex-direction:column;align-items:flex-start}
.cb-step-num{display:none}
.cb-step-body{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:10px 14px;width:100%}
.cb-step-header{display:flex;align-items:center;justify-content:space-between;gap:8px}
.cb-step-skill{font-size:14px;font-weight:700;color:var(--text-primary)}
.cb-step-timing{font-size:11px;color:var(--secondary);background:rgba(243,156,18,.1);padding:2px 8px;border-radius:8px;font-family:monospace;flex-shrink:0}
.cb-step-note{font-size:12px;color:var(--text-muted);margin-top:5px;line-height:1.5}
.cb-step-arrow{font-size:18px;color:var(--text-muted);padding:2px 0 2px 14px}
.cb-tips{font-size:12px;color:var(--text-secondary);background:rgba(52,152,219,.08);border-left:3px solid var(--accent);padding:8px 12px;border-radius:0 6px 6px 0;margin-top:10px;line-height:1.6}

/* ===== 数据导出 ===== */
.ex-layout{max-width:600px;display:flex;flex-direction:column;gap:20px}
.ex-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.ex-section h3{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:8px}
.ex-hero-preview{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}
.ex-hero-chip{display:flex;align-items:center;gap:6px;background:var(--bg-hover);border:1px solid var(--border);border-radius:8px;padding:5px 10px;font-size:13px}
.ex-hero-chip img{width:36px;height:20px;border-radius:4px;object-fit:cover}
.ex-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}

/* ===== FAQ ===== */
.faq-group{margin-bottom:24px}
.faq-cat-title{font-size:14px;font-weight:800;margin-bottom:10px;padding-bottom:6px;border-bottom:2px solid currentColor}
.faq-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;overflow:hidden}
.faq-q{padding:14px 16px;cursor:pointer;font-size:14px;font-weight:600;color:var(--text-primary);display:flex;align-items:flex-start;gap:10px;transition:var(--transition);user-select:none}
.faq-q:hover{background:var(--bg-hover)}
.faq-q-icon{color:var(--accent);transition:transform .2s;flex-shrink:0;margin-top:1px}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s;padding:0 16px;font-size:13px;color:var(--text-secondary);line-height:1.7}
.faq-open .faq-q-icon{transform:rotate(90deg)}
.faq-open .faq-a{max-height:300px;padding:0 16px 14px}

@media(max-width:768px){
    .cv-layout,.cb-layout{grid-template-columns:1fr}
    .cv-hero-list{position:static;max-height:none}
}

/* ===== 战绩查询升级样式 ===== */
.pf-total-wr{text-align:center;flex-shrink:0}
.pf-wr-val{font-size:28px;font-weight:800}
.pf-wr-label{font-size:11px;color:var(--text-muted);margin-top:2px}
.pf-analysis-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.pf-analysis-row{display:flex;align-items:flex-start;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--text-secondary)}
.pf-analysis-row:last-child{border-bottom:none}
.pf-analysis-icon{font-size:16px;flex-shrink:0}
.pf-stats-grid2{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.pf-stat2{text-align:center;background:var(--bg-hover);border-radius:8px;padding:10px}
.pf-stat2-val{font-size:18px;font-weight:700;color:var(--text-primary)}
.pf-stat2-label{font-size:11px;color:var(--text-muted);margin-top:3px}
.pf-stat2-sub{font-size:10px;color:var(--text-muted);margin-top:2px}
.pf-hero-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
.pf-hero-card2{background:var(--bg-hover);border:1px solid var(--border);border-radius:8px;overflow:hidden}
.pf-hero-clickable{cursor:pointer;transition:var(--transition)}
.pf-hero-clickable:hover{border-color:var(--accent);transform:translateY(-2px)}
.pf-hero-card2 img{width:100%;height:60px;object-fit:cover;display:block}
.pf-hero-card2-info{padding:6px 8px}
.pf-hero-card2-name{font-size:12px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pf-hero-card2-stats{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted);margin-top:3px}
.pf-match-row2{display:grid;grid-template-columns:70px 1fr 100px 130px;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;margin-bottom:6px;font-size:13px}
.pf-match-result2{font-size:12px;font-weight:700}
.pf-match-hero2{display:flex;align-items:center;gap:6px;min-width:0}
.pf-match-hero2 img{width:42px;height:24px;border-radius:4px;object-fit:cover;flex-shrink:0}
.pf-match-hero2 span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pf-match-kda2{font-family:monospace;font-weight:700;text-align:center}
.pf-match-meta{display:flex;align-items:center;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.pf-match-gpm{color:var(--secondary);font-size:11px}
@media(max-width:768px){
    .pf-stats-grid2{grid-template-columns:repeat(2,1fr)}
    .pf-match-row2{grid-template-columns:60px 1fr 80px}
    .pf-match-meta{display:none}
    .pf-hero-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}
}

/* ===== 分组导航 ===== */
.nav-group{margin-bottom:2px}
.nav-group-header{display:flex;align-items:center;gap:10px;padding:8px 16px;cursor:pointer;border-radius:8px;margin:0 8px;transition:var(--transition);user-select:none}
.nav-group-header:hover{background:var(--bg-hover)}
.nav-group-header.active{background:rgba(52,152,219,.12)}
.nav-group-icon{font-size:16px;flex-shrink:0}
.nav-group-label{flex:1;font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}
.nav-group-arrow{font-size:11px;color:var(--text-muted);flex-shrink:0}
.nav-group-items{max-height:0;overflow:hidden;transition:max-height .25s ease}
.nav-group-items.open{max-height:600px}
.nav-group-items .nav-item{padding-left:38px;font-size:13px}

/* ================================================================
   2PT 风格覆盖层 — 全局组件重设计
   放在文件末尾，优先级高于之前的样式
================================================================ */

/* ── 搜索框 ── */
.search-box {
    background: var(--bg-card) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    height: 34px !important;
}
.search-box input { font-size: 13px !important; color: var(--text-primary) !important; }
.search-box input::placeholder { color: var(--text-muted) !important; }
.search-box:focus-within { border-color: var(--accent) !important; }

/* ── 主按钮 ── */
.btn-primary {
    background: transparent !important;
    color: var(--accent) !important;
    border: 1px solid var(--accent) !important;
    border-radius: var(--radius-sm) !important;
    padding: 7px 18px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    cursor: pointer;
    transition: var(--transition) !important;
}
.btn-primary:hover {
    background: var(--accent-dim) !important;
    box-shadow: 0 0 12px var(--accent-glow) !important;
}

/* ── 统计卡片 ── */
.stat-card {
    background: var(--bg-card) !important;
    border: 1px solid var(--border) !important;
    border-top: 2px solid var(--accent) !important;
    border-radius: var(--radius-sm) !important;
    padding: 16px !important;
}
.stat-icon { font-size: 20px !important; margin-bottom: 6px !important; }
.stat-value { font-size: 28px !important; font-weight: 800 !important; color: var(--accent) !important; font-family: var(--font-mono) !important; }
.stat-label { font-size: 11px !important; color: var(--text-muted) !important; text-transform: uppercase !important; letter-spacing: 0.06em !important; }

/* ── 英雄卡片 ── */
.hero-card {
    background: var(--bg-card) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    padding: 0 0 8px !important;
    overflow: hidden !important;
}
.hero-card:hover {
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 1px var(--accent-dim) !important;
    transform: translateY(-2px) !important;
}
.hero-avatar-img {
    border-radius: 0 !important;
    width: 100% !important;
    height: 56px !important;
    object-fit: cover !important;
    display: block !important;
}
.hero-name-cn { font-size: 11px !important; font-weight: 700 !important; color: var(--text-primary) !important; }
.hero-name-en { font-size: 9px !important; color: var(--text-muted) !important; }
.attr-badge {
    font-size: 9px !important;
    padding: 1px 5px !important;
    border-radius: 2px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
}

/* ── 快速入口卡片 ── */
.quick-card {
    background: var(--bg-card) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    padding: 16px !important;
    transition: var(--transition) !important;
}
.quick-card:hover {
    border-color: var(--accent) !important;
    background: var(--accent-dim) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 16px var(--accent-glow) !important;
}
.quick-icon { font-size: 20px !important; margin-bottom: 8px !important; }
.quick-card h3 { font-size: 13px !important; font-weight: 700 !important; color: var(--text-primary) !important; }
.quick-card p { font-size: 11px !important; color: var(--text-muted) !important; }

/* ── 物品卡片 ── */
.item-card {
    background: var(--bg-card) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
}
.item-card:hover { border-color: var(--accent) !important; transform: translateY(-1px) !important; }
.item-price { color: var(--secondary) !important; font-family: var(--font-mono) !important; font-size: 11px !important; font-weight: 700 !important; }

/* ── 页面标题 ── */
.page-header h1 {
    font-size: 20px !important;
    font-weight: 800 !important;
    color: var(--text-primary) !important;
    letter-spacing: 0.02em !important;
}
.page-header .subtitle { font-size: 12px !important; color: var(--text-secondary) !important; }

/* ── 筛选按钮 ── */
.filter-btn {
    background: transparent !important;
    border: 1px solid var(--border) !important;
    border-radius: 3px !important;
    color: var(--text-secondary) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    padding: 4px 12px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    transition: var(--transition) !important;
}
.filter-btn:hover { border-color: var(--accent) !important; color: var(--accent) !important; }
.filter-btn.active {
    background: var(--accent-dim) !important;
    border-color: var(--accent) !important;
    color: var(--accent) !important;
}

/* ── bp-filter-btn (英雄筛选) ── */
.bp-filter-btn {
    background: transparent !important;
    border: 1px solid var(--border) !important;
    border-radius: 3px !important;
    color: var(--text-muted) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    padding: 3px 9px !important;
    cursor: pointer;
    transition: var(--transition) !important;
}
.bp-filter-btn:hover { border-color: var(--accent) !important; color: var(--accent) !important; }
.bp-filter-btn.active {
    background: var(--accent-dim) !important;
    border-color: var(--accent) !important;
    color: var(--accent) !important;
}

/* ── 赛事表格 ── */
.tournament-table th {
    background: var(--bg-hover) !important;
    color: var(--text-muted) !important;
    font-size: 10px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    font-family: var(--font-mono) !important;
    border-bottom: 1px solid var(--border) !important;
    padding: 8px 12px !important;
}
.tournament-table td { padding: 7px 12px !important; font-size: 12px !important; }
.tournament-table tr:hover td { background: var(--bg-hover) !important; }
.champion { color: var(--accent) !important; font-weight: 700 !important; }
.prize-pool { color: var(--secondary) !important; font-family: var(--font-mono) !important; font-weight: 700 !important; }

/* ── 弹窗 ── */
.modal-content {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-bright) !important;
    border-radius: var(--radius-sm) !important;
    box-shadow: 0 0 40px rgba(29,233,182,.08), 0 20px 60px rgba(0,0,0,.7) !important;
}
.modal-close {
    background: var(--bg-hover) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--text-secondary) !important;
}
.modal-close:hover { background: var(--bg-card) !important; color: var(--text-primary) !important; border-color: var(--border-bright) !important; }

/* ── 天赋树 ── */
.talent-opt {
    background: var(--bg-hover) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    font-size: 11px !important;
}
.talent-opt:hover { border-color: var(--accent) !important; color: var(--accent) !important; background: var(--accent-dim) !important; }

/* ── 详情弹窗 tab ── */
.detail-tab-btn {
    background: transparent !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--text-secondary) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    padding: 5px 12px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
}
.detail-tab-btn.active {
    background: var(--accent-dim) !important;
    border-color: var(--accent) !important;
    color: var(--accent) !important;
}

/* ── 语言切换 & 主题 ── */
.lang-toggle, .theme-toggle {
    background: transparent !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--text-secondary) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
}
.lang-toggle:hover, .theme-toggle:hover {
    border-color: var(--accent) !important;
    color: var(--accent) !important;
}

/* ── Tier Badge ── */
.tier-s-badge { background: rgba(29,233,182,.15) !important; color: var(--accent) !important; border: 1px solid var(--accent) !important; }
.tier-a-badge { background: rgba(0,230,118,.12) !important; color: var(--success) !important; border: 1px solid var(--success) !important; }

/* ── 版本变更标签 ── */
.change-tag.buff   { background: rgba(0,230,118,.12) !important; color: var(--success) !important; border-color: var(--success) !important; }
.change-tag.nerf   { background: rgba(231,76,60,.12) !important; color: var(--primary) !important; border-color: var(--primary) !important; }
.change-tag.rework { background: rgba(243,156,18,.12) !important; color: var(--secondary) !important; border-color: var(--secondary) !important; }

/* ── 分组导航重设计 ── */
.nav-group-header {
    margin: 2px 4px !important;
    padding: 6px 10px !important;
    border-radius: var(--radius-sm) !important;
}
.nav-group-label { font-size: 10px !important; letter-spacing: 0.1em !important; }
.nav-group-header.active { background: var(--accent-dim) !important; }
.nav-group-header.active .nav-group-label { color: var(--accent) !important; }
.nav-group-header.active .nav-group-icon { filter: none !important; }

/* ── 页面容器 ── */
.page-container { padding: 20px 24px !important; }

/* ── 快查浮层 ── */
.quicksearch-box {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-bright) !important;
    border-radius: var(--radius-sm) !important;
    box-shadow: 0 0 0 1px var(--accent-glow), 0 20px 60px rgba(0,0,0,.6) !important;
}
.quicksearch-input { font-size: 15px !important; }
.qs-item:hover { background: var(--accent-dim) !important; }
.qs-tag {
    background: transparent !important;
    border-color: var(--accent) !important;
    color: var(--accent) !important;
}

/* ── 战绩查询 ── */
.pf-profile-card { border-top: 2px solid var(--accent) !important; border-radius: var(--radius-sm) !important; }
.pf-wr-val { color: var(--accent) !important; font-family: var(--font-mono) !important; }

/* ── 信息横幅 ── */
.info-banner {
    background: rgba(29,233,182,.06) !important;
    border-left: 3px solid var(--accent) !important;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0 !important;
    color: var(--text-secondary) !important;
    font-size: 12px !important;
}

/* ── 滚动条全局 ── */
* { scrollbar-width: thin; scrollbar-color: var(--border-bright) transparent; }
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-thumb { background: var(--border-bright); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent); }

/* ── 响应式覆盖 ── */
@media(max-width:1024px){
    .main-content { margin-left: 48px !important; }
}
@media(max-width:639px){
    .main-content { margin-left: 0 !important; }
    .topbar { padding: 0 10px; }
    .topbar-logo-text { display: none; }
    .topbar-search { display: none; }
}

/* ===== TierList 实时升级样式 ===== */
.tl-header { display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-bottom:16px; }
.tl-rank-tabs { display:flex; gap:6px; flex-wrap:wrap; }
.tl-rank-tab {
    padding:5px 14px; border-radius:20px; font-size:12px; font-weight:600; cursor:pointer;
    border:1px solid var(--border); background:var(--bg-card); color:var(--text-secondary);
    transition:var(--transition);
}
.tl-rank-tab.active { background:var(--accent-dim); color:var(--accent); border-color:var(--accent); }
.tl-live-badge { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--success); }
.tl-live-dot { width:8px; height:8px; border-radius:50%; background:var(--success); animation:pulse 1.5s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.4} }

/* ===== 协同矩阵样式 ===== */
.synergy-layout { display:flex; flex-direction:column; gap:16px; }
.synergy-hint { color:var(--text-muted); font-size:13px; margin-bottom:8px; }
.synergy-hero-list { display:flex; flex-wrap:wrap; gap:8px; max-height:260px; overflow-y:auto; }
.syn-hero-chip {
    display:flex; align-items:center; gap:6px; padding:5px 10px;
    border-radius:var(--radius-sm); border:1px solid var(--border);
    background:var(--bg-card); cursor:pointer; font-size:12px;
    transition:var(--transition);
}
.syn-hero-chip:hover { border-color:var(--accent); color:var(--accent); }
.syn-hero-chip img { width:32px; height:18px; border-radius:3px; }
.syn-selected-hero { display:flex; align-items:center; gap:10px; margin-bottom:16px; padding:10px; background:var(--bg-card); border-radius:var(--radius); border:1px solid var(--border); }
.syn-two-col { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.syn-col { background:var(--bg-card); border-radius:var(--radius); padding:16px; border:1px solid var(--border); }
.syn-chips { display:flex; flex-direction:column; gap:6px; }
.syn-result-chip { display:flex; align-items:center; gap:8px; padding:6px 8px; border-radius:var(--radius-sm); cursor:pointer; transition:var(--transition); }
.syn-result-chip:hover { background:var(--bg-hover); }
.syn-result-chip img { width:36px; height:20px; border-radius:3px; }
.syn-chip-name { flex:1; font-size:13px; }
.syn-chip-wr { font-weight:700; font-size:13px; font-family:var(--font-mono); }
@media(max-width:639px) { .syn-two-col { grid-template-columns:1fr; } }

/* ===== 职业Ban/Pick样式 ===== */
.probp-header { display:flex; align-items:center; gap:8px; margin-bottom:12px; font-size:12px; color:var(--text-muted); }
.probp-tabs-wrap { display:flex; gap:8px; margin-bottom:16px; }
.probp-tab {
    padding:6px 16px; border-radius:20px; font-size:12px; font-weight:600; cursor:pointer;
    border:1px solid var(--border); background:var(--bg-card); color:var(--text-secondary);
    transition:var(--transition);
}
.probp-tab.active { background:var(--accent-dim); color:var(--accent); border-color:var(--accent); }
.probp-table { width:100%; border-collapse:collapse; font-size:13px; }
.probp-table th { padding:8px 12px; text-align:left; color:var(--text-muted); font-size:11px; text-transform:uppercase; border-bottom:1px solid var(--border); }
.probp-table td { padding:8px 12px; border-bottom:1px solid var(--border); }
.probp-table tr:hover { background:var(--bg-hover); }

/* ===== 英雄卡片生成器样式 ===== */
.herocard-layout { display:grid; grid-template-columns:280px 1fr; gap:20px; }
.herocard-select h3 { margin-bottom:10px; font-size:14px; }
.herocard-hero-grid { display:flex; flex-wrap:wrap; gap:6px; max-height:400px; overflow-y:auto; }
.hc-hero-chip {
    display:flex; align-items:center; gap:6px; padding:4px 8px;
    border-radius:var(--radius-sm); border:1px solid var(--border);
    background:var(--bg-card); cursor:pointer; font-size:11px;
    transition:var(--transition);
}
.hc-hero-chip:hover { border-color:var(--accent); color:var(--accent); }
.hc-hero-chip img { width:28px; height:16px; border-radius:2px; }
@media(max-width:768px) { .herocard-layout { grid-template-columns:1fr; } }

/* ===== 版本周刊样式 ===== */
.weekly-header { margin-bottom:20px; }
.weekly-title { font-size:20px; font-weight:800; color:var(--text-primary); margin-bottom:4px; }
.weekly-version { font-size:12px; color:var(--text-muted); }
.weekly-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.weekly-section { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:16px; }
.weekly-section h3 { font-size:14px; margin-bottom:12px; }
.weekly-hero-row { display:flex; flex-wrap:wrap; gap:8px; }
.weekly-hero-chip { display:flex; align-items:center; gap:6px; padding:5px 10px; border-radius:var(--radius-sm); background:var(--bg-hover); cursor:pointer; font-size:12px; transition:var(--transition); }
.weekly-hero-chip:hover { background:var(--accent-dim); color:var(--accent); }
.weekly-hero-chip img { width:32px; height:18px; border-radius:3px; }
.weekly-changes { display:flex; flex-direction:column; gap:8px; }
.weekly-change { font-size:13px; padding:6px 0; border-bottom:1px solid var(--border); }
.weekly-recommend { display:flex; gap:12px; flex-wrap:wrap; }
.weekly-rec-card { display:flex; align-items:center; gap:10px; padding:12px; background:var(--bg-hover); border-radius:var(--radius); cursor:pointer; flex:1; min-width:180px; transition:var(--transition); }
.weekly-rec-card:hover { background:var(--accent-dim); }
.weekly-rec-card img { width:48px; height:27px; border-radius:4px; }
@media(max-width:639px) { .weekly-grid { grid-template-columns:1fr; } .weekly-recommend { flex-direction:column; } }

/* ===== PWA 离线提示 ===== */
.pwa-offline-banner {
    position:fixed; bottom:70px; left:50%; transform:translateX(-50%);
    background:#333; color:#fff; padding:8px 20px; border-radius:20px;
    font-size:12px; z-index:9999; display:none;
}
.pwa-offline-banner.show { display:block; }

/* ===== 支持作者页面 ===== */
.support-layout {
    max-width: 640px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.support-intro {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px 24px;
    line-height: 2;
    color: var(--text-secondary);
    font-size: 14px;
}

.support-intro b { color: var(--accent); }

.support-qr-row {
    display: flex;
    gap: 24px;
    justify-content: center;
    flex-wrap: wrap;
}

.support-qr-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    text-align: center;
    flex: 1;
    min-width: 260px;
    max-width: 300px;
    transition: var(--transition);
}

.support-qr-card:hover {
    border-color: var(--accent);
    box-shadow: 0 0 20px var(--accent-glow);
    transform: translateY(-2px);
}

.support-qr-title {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 14px;
    letter-spacing: 0.04em;
}

.support-qr-img-wrap {
    width: 240px;
    height: 240px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    border-radius: var(--radius-sm);
    padding: 8px;
}

.support-qr-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.support-qr-placeholder {
    color: var(--text-muted);
    font-size: 12px;
    line-height: 1.8;
    text-align: center;
    padding: 20px;
}

.support-footer {
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 20px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
}

.support-thanks {
    font-size: 15px;
    font-weight: 700;
    color: var(--text-primary);
}

.support-thanks-note {
    font-size: 12px;
    color: var(--text-muted);
}

.support-links {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 8px;
}

.support-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 18px;
    border-radius: 20px;
    border: 1px solid var(--border);
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    transition: var(--transition);
}

.support-link:hover {
    border-color: var(--accent);
    color: var(--accent);
    background: var(--accent-dim);
}

/* 顶部支持按钮高亮 */
.topbar-nav-support {
    color: #e91e63 !important;
}
.topbar-nav-support:hover, .topbar-nav-support.active {
    color: #e91e63 !important;
    border-bottom-color: #e91e63 !important;
}
