﻿    :root {
      /* Design system: calm wiki analytics, neutral surfaces, game color used for data. */
      --color-bg: #F5F7F6;
      --color-surface: #FFFFFF;
      --color-surface-muted: #F8FAF8;
      --color-surface-raised: #FFFFFF;
      --color-border: #DCE5DF;
      --color-border-strong: #C6D4CC;
      --color-text: #1F2D26;
      --color-text-subtle: #5D6F65;
      --color-text-muted: #87968E;
      --color-accent: #3F7D64;
      --color-accent-hover: #315F4D;
      --color-accent-soft: rgba(63, 125, 100, 0.11);
      --color-accent-softer: rgba(63, 125, 100, 0.06);
      --color-danger: #B86464;
      --color-danger-hover: #985050;
      --color-danger-soft: rgba(184, 100, 100, 0.10);
      --color-warning: #C58B36;
      --color-warning-soft: rgba(197, 139, 54, 0.14);

      --font-sans: 'Noto Sans SC', 'Microsoft YaHei', 'PingFang SC', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
      --font-size-xs: 12px;
      --font-size-sm: 13px;
      --font-size-md: 14px;
      --font-size-lg: 16px;
      --font-size-xl: 20px;
      --font-size-2xl: 24px;
      --font-weight-regular: 400;
      --font-weight-medium: 500;
      --font-weight-semibold: 600;
      --font-weight-bold: 700;

      --space-1: 4px;
      --space-2: 8px;
      --space-3: 12px;
      --space-4: 16px;
      --space-5: 20px;
      --space-6: 24px;
      --radius-sm: 6px;
      --radius-md: 8px;
      --radius-lg: 12px;
      --radius-xl: 16px;
      --radius-pill: 999px;
      --shadow-soft: 0 8px 24px rgba(31, 45, 38, 0.07);
      --shadow-raised: 0 14px 38px rgba(31, 45, 38, 0.12);
      --shadow-focus: 0 0 0 3px rgba(63, 125, 100, 0.18);
      --transition-fast: 150ms ease;
      --transition-base: 220ms ease;

      --bg-color: var(--color-bg);
      --panel-bg: var(--color-surface-muted);
      --element-bg: var(--color-surface);
      --border-color: var(--color-border);
      --text-main: var(--color-text);
      --text-sub: var(--color-text-subtle);
      --accent: var(--color-accent);
      --accent-hover: var(--color-accent-hover);
      --shadow-color: rgba(31, 45, 38, 0.08);
      --btn-danger: var(--color-danger);
      --btn-danger-hover: var(--color-danger-hover);
      --warning-color: var(--color-warning);
      --card-header-bg: var(--color-accent);

      --team-base-font-size: 13px;
      --team-card-title-font-size: 15px;
      --type-tag-font-size: 14px;
    }

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

    *:focus-visible {
      outline: none;
      box-shadow: var(--shadow-focus);
    }
    
    body {
      background-color: var(--bg-color); 
      color: var(--text-main);
      font-family: var(--font-sans);
      font-size: var(--font-size-md);
      font-weight: var(--font-weight-regular);
      letter-spacing: 0;
      height: 100vh; 
      display: flex; flex-direction: row; 
      overflow: hidden; 
    }

    /* 侧边栏导航 */
    .sidebar {
      width: 8px;
      background: var(--accent);
      transition: width var(--transition-base), background var(--transition-base), box-shadow var(--transition-base);
      display: flex; flex-direction: column; justify-content: flex-start; padding-top: 30px; 
      overflow: hidden; z-index: 100;
      flex-shrink: 0;
      box-shadow: none;
      border-right: none;
    }
    .sidebar:hover { 
      width: 180px;
      background: var(--element-bg);
      box-shadow: var(--shadow-soft);
      border-right: 1px solid var(--border-color);
    }
    
    .nav-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
    .nav-item {
      display: flex; align-items: center; height: 50px; cursor: pointer;
      color: var(--text-sub); font-weight: var(--font-weight-semibold); transition: background var(--transition-fast), color var(--transition-fast);
      white-space: nowrap; padding-left: 20px; position: relative;
    }
    .nav-item:hover { background: var(--color-accent-softer); color: var(--text-main); }
    .nav-item.active { color: var(--accent); background: var(--color-accent-soft); }
    .nav-item.active::before {
      content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--accent);
    }
    .nav-icon { opacity: 0; font-size: 18px; margin-right: 12px; width: 24px; text-align: center; transition: opacity 0.2s; }
    .nav-text { opacity: 0; transition: opacity var(--transition-fast); font-size: var(--font-size-md); }
    .sidebar:hover .nav-icon,
    .sidebar:hover .nav-text { opacity: 1; transition-delay: 0.1s; } 

    /* 主内容与视图容器 */
    .main-wrapper {
      flex: 1; display: flex; flex-direction: column;
      overflow: hidden; position: relative; min-width: 0;
    }
    .view-section {
      display: none; flex-direction: column; flex: 1; height: 100%; width: 100%; overflow: hidden;
    }
    .view-section.active { display: flex; }

    /* 加载动画 */
    #global-loading {
      position: fixed; top: 0; left: 0; right: 0; bottom: 0;
      background: rgba(245, 247, 246, 0.92); z-index: 9999;
      display: flex; flex-direction: column; justify-content: center; align-items: center;
    }
    .loader {
      border: 4px solid var(--border-color); border-top: 4px solid var(--accent);
      border-radius: 50%; width: 40px; height: 40px; animation: spin 1s linear infinite;
    }
    @keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
    .loading-text { margin-top: 15px; font-weight: var(--font-weight-semibold); color: var(--accent); letter-spacing: 0; }

    header {
      height: 60px; min-height: 60px; display: flex; justify-content: space-between; align-items: center;
      padding: 0 30px; background: var(--element-bg); box-shadow: 0 1px 0 var(--border-color); z-index: 10;
    }
    .title { font-size: var(--font-size-xl); font-weight: var(--font-weight-bold); color: var(--accent); letter-spacing: 0; display: flex; align-items: center; gap: 8px; }
    .header-controls { display: flex; gap: 12px; align-items: center; }

    .btn-global {
      background: var(--element-bg); border: 1px solid var(--border-color); padding: 7px 14px; cursor: pointer; font-size: var(--font-size-md); 
      border-radius: var(--radius-md); transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast); font-family: inherit; font-weight: var(--font-weight-semibold); color: var(--text-sub);
    }
    .btn-global:hover {
      border-color: var(--accent); color: var(--accent);
    }
    .btn-global.primary { color: #FFF; border-color: var(--accent); background: var(--accent); }
    .btn-global.primary:hover { background: var(--accent-hover); color: #FFF; box-shadow: var(--shadow-focus); }
    .btn-global.danger { color: var(--btn-danger); border-color: var(--btn-danger); }
    .btn-global.danger:hover { background: var(--btn-danger); color: #FFF; box-shadow: 0 0 0 3px var(--color-danger-soft); }

    .btn-mini {
      background: var(--element-bg); border: 1px solid; padding: 4px 10px; cursor: pointer; font-size: var(--font-size-xs); 
      border-radius: var(--radius-md); transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast); font-family: inherit; font-weight: var(--font-weight-semibold); width: auto; min-width: 50px; text-align: center; flex-shrink: 0;
    }
    .btn-mini.primary { color: var(--accent); border-color: var(--color-border-strong); }
    .btn-mini.primary:hover { background: var(--accent); color: #FFF; }
    .btn-mini.danger { color: var(--btn-danger); border-color: var(--btn-danger); }
    .btn-mini.danger:hover { background: var(--btn-danger); color: #FFF; }
    .btn-mini:disabled { opacity: 0.5; cursor: not-allowed; }

    .toggle-wrapper { display: flex; align-items: center; gap: 6px; cursor: pointer; font-size: var(--font-size-sm); color: var(--text-sub); font-weight: var(--font-weight-semibold); white-space: nowrap; }
    .toggle-wrapper input[type="checkbox"] { accent-color: var(--accent); width: 16px; height: 16px; cursor: pointer; }

    .top-slicer {
      padding: 12px 30px; display: flex; flex-direction: column; gap: 12px;
      background: var(--color-surface-muted); border-bottom: 1px solid var(--border-color);
      flex-shrink: 0;
    }
    .slicer-row {
      display: flex; flex-direction: row; align-items: center; gap: 15px; flex-wrap: wrap; 
    }
    .filter-header { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
    
    .filter-label { color: var(--text-main); font-size: var(--font-size-md); font-weight: var(--font-weight-semibold); white-space: nowrap; }
    .filter-desc { color: var(--color-text-muted); font-size: var(--font-size-sm); font-weight: var(--font-weight-regular); margin-left: 10px; white-space: nowrap;}
    .filter-list { display: flex; flex-wrap: nowrap; gap: 8px; align-items: center; }

    .filter-list-scroll { flex: 0 1 auto; display: flex; gap: 8px; overflow-x: auto; padding-bottom: 2px; }
    .filter-list-scroll::-webkit-scrollbar { height: 4px; }
    .filter-list-scroll::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 2px; }

    .attr-checkbox, .type-attr-checkbox { display: none; }
    .attr-label {
      padding: 5px 11px; border: 1px solid var(--border-color); border-radius: var(--radius-pill); font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold);
      cursor: pointer; transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast); color: var(--text-sub); display: inline-block; white-space: nowrap; background: var(--element-bg); user-select: none;
    }
    .attr-checkbox:checked + .attr-label, .type-attr-checkbox:checked + .attr-label { 
      background: var(--accent); color: #FFF; border-color: var(--accent); 
    }
    .type-attr-checkbox:disabled + .attr-label {
      opacity: 0.58; cursor: not-allowed; background: var(--color-surface-muted); border-color: var(--border-color);
    }
    .type-attr-checkbox:disabled:checked + .attr-label {
      background: var(--accent); opacity: 0.7; color: #FFF; border-color: var(--accent);
    }
    
    @keyframes flash-warning {
      0%, 100% { border-color: var(--border-color); background: var(--element-bg); }
      50% { border-color: var(--warning-color); background: var(--color-warning-soft); }
    }
    .limit-reached { animation: flash-warning 0.5s ease-in-out; }

    .stat-checkbox { display: none; }
    .stat-checkbox:checked + .stat-label { background: var(--stat-color); color: #FFF; border-color: var(--stat-color); }

    .main-container { display: flex; flex: 1; padding: 20px; gap: 20px; position: relative; overflow: hidden; background: var(--bg-color); } 
    
    .panel { background: var(--element-bg); border: 1px solid var(--border-color); box-shadow: var(--shadow-soft); border-radius: var(--radius-lg); position: relative; }

    .left-panel { flex: 5.5; display: flex; flex-direction: column; padding: 20px; height: 100%; min-width: 0; } 
    .left-controls { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 15px; width: 100%; position: relative; z-index: 10; }
    .stat-group { display: flex; align-items: center; gap: 10px; flex-wrap: nowrap; white-space: nowrap; flex: 1; overflow-x: auto; }
    .stat-checkboxes { display: flex; gap: 8px; flex-wrap: nowrap; align-items: center; }
    .view-controls { display: flex; flex-direction: column; align-items: center; gap: 8px; flex-shrink: 0; padding-left: 15px; border-left: 2px dashed var(--border-color); width: 130px; }
    
    .top-n-input { width: 50px; background: var(--element-bg); border: 1px solid var(--border-color); color: var(--text-main); padding: 3px 4px; text-align: center; border-radius: var(--radius-md); font-family: var(--font-sans); font-weight: var(--font-weight-semibold); outline: none; transition: border-color var(--transition-fast), box-shadow var(--transition-fast); margin: 0; }
    .top-n-input:focus { border-color: var(--accent); }
    .top-n-input:disabled { opacity: 0.55; cursor: not-allowed; background: var(--color-surface-muted);}
    
    .chart-wrapper { position: relative; flex: 1; width: 100%; min-height: 0; display: flex; flex-direction: column; }
    #bar-chart { flex: 1; width: 100%; height: 100%; }

    #empty-state { position: absolute; top: 0; left: 0; right: 0; bottom: 0; display: none; flex-direction: column; justify-content: center; align-items: center; background: transparent; z-index: 5; pointer-events: none; }
    .empty-icon { font-size: 60px; color: var(--border-color); margin-bottom: 20px; }
    .empty-text { font-size: var(--font-size-lg); color: var(--text-sub); font-weight: var(--font-weight-semibold); text-align: center; }

    .right-panel { flex: 4.5; display: flex; flex-direction: column; gap: 15px; padding: 20px; height: 100%; min-width: 0; }
    #right-content-wrap { display: flex; flex-direction: column; gap: 15px; flex: 1; }
    .sprite-header-name { text-align: center; font-size: var(--font-size-2xl); font-weight: var(--font-weight-bold); color: var(--accent); letter-spacing: 0; margin-bottom: 5px; flex-shrink: 0; }
    .right-top-split { flex: 5.5; display: flex; flex-direction: row; gap: 15px; min-height: 0; }
    
    .img-container { flex: 1; background: var(--color-surface-muted); border-radius: var(--radius-lg); display: flex; justify-content: center; align-items: center; border: 1px solid var(--border-color); overflow: hidden; padding: 10px; }
    .img-container img { width: 100%; height: 100%; object-fit: contain; display: block; filter: drop-shadow(0 10px 15px rgba(0,0,0,0.08)); transition: opacity 0.2s ease-in-out; }
    #radar-chart { flex: 1.2; height: 100%; min-height: 0; background: var(--color-surface-muted); border-radius: var(--radius-lg); border: 1px solid var(--border-color);}

    .info-container { flex: 4; display: flex; flex-direction: column; gap: 12px; overflow-y: auto; background: var(--color-surface-muted); padding: 18px; border-radius: var(--radius-lg); border: 1px solid var(--border-color); }
    .info-row { display: flex; align-items: baseline; gap: 10px;}
    .info-title { width: 75px; color: #FFF; background: var(--accent); font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold); flex-shrink: 0; padding: 4px 8px; border-radius: var(--radius-md); text-align: center; }
    .info-value { flex: 1; color: var(--text-main); font-size: var(--font-size-md); font-weight: var(--font-weight-medium); background: var(--element-bg); padding: 8px 12px; border-radius: var(--radius-md); border: 1px solid var(--border-color); min-height: 38px; }

    #system-alert { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: rgba(245,247,246,0.95); z-index: 999; display: flex; flex-direction: column; justify-content: center; align-items: center; color: var(--text-main); display: none; }
    .footer { text-align: center; padding: 10px 15px; font-size: var(--font-size-xs); color: var(--text-sub); background: var(--element-bg); border-top: 1px solid var(--border-color); flex-shrink: 0; font-weight: var(--font-weight-medium); }
    .footer a { color: var(--accent); text-decoration: none; }

    /* 全局 tooltip 样式 */
    .global-tooltip {
      position: fixed;
      background: rgba(42, 58, 49, 0.95);
      color: #FFF;
      padding: 6px 10px;
      border-radius: 8px;
      font-size: 12px;
      white-space: nowrap;
      z-index: 999999;
      box-shadow: 0 4px 10px rgba(0,0,0,0.2);
      pointer-events: none;
      display: none;
    }

    /* 属性克制查询样式 */
    .type-grid-container {
      display: flex; flex-direction: row; gap: 20px; padding: 20px; height: 100%; overflow: hidden; background: var(--bg-color);
    }
    .type-panel {
      background: var(--element-bg); border-radius: var(--radius-lg); box-shadow: var(--shadow-soft);
      border: 1px solid var(--border-color); display: flex; flex-direction: column;
      overflow: hidden; position: relative;
    }
    #card-panel { width: 340px; flex-shrink: 0; }
    #scatter-panel { flex: 1; min-width: 0; }
    
    .type-panel-header {
      background: var(--color-surface-muted); padding: 12px 15px; font-weight: var(--font-weight-bold); font-size: var(--font-size-lg); color: var(--accent);
      border-bottom: 1px solid var(--border-color); text-align: center; letter-spacing: 0; flex-shrink: 0;
    }
    .type-chart-box { flex: 1; width: 100%; height: 100%; min-height: 0; position: relative; }

    .tc-container { display: flex; flex-direction: column; height: 100%; padding: 12px 15px; background: var(--color-surface-muted); }
    .tc-badge-header { 
      font-size: var(--font-size-lg); font-weight: var(--font-weight-bold); color: #FFF; text-align: center;
      padding: 10px; border-radius: var(--radius-lg); margin-bottom: 10px;
      box-shadow: 0 6px 16px rgba(31,45,38,0.12); transition: background var(--transition-base);
      display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 6px; flex-shrink: 0;
    }
    .tc-badge-title { font-size: var(--font-size-xs); opacity: 0.9; font-weight: var(--font-weight-semibold); }
    .tc-badge-content { display: flex; gap: 6px; flex-wrap: wrap; justify-content: center;}
    
    .tc-body { flex: 1; display: flex; flex-direction: column; gap: 8px; overflow-y: auto; padding-right: 2px; }
    .tc-body::-webkit-scrollbar { width: 4px; }
    .tc-body::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 2px; }

    .tc-section { display: flex; flex-direction: column; gap: 6px; margin-bottom: 6px; }
    .tc-section:last-child { margin-bottom: 0; }
    .tc-section-title { 
      font-size: var(--font-size-md); font-weight: var(--font-weight-bold); color: var(--text-main); margin-bottom: 2px; 
      padding-left: 8px; border-left: 4px solid var(--accent); line-height: 1.2; display: flex; align-items: center;
    }
    .tc-separator {
      border-bottom: 1px dashed rgba(63, 125, 100, 0.32); 
      margin: 6px 0;
    }

    .tc-row { background: var(--element-bg); border: 1px solid var(--border-color); border-radius: var(--radius-md); padding: 8px 10px; }
    .tc-label { font-size: var(--font-size-sm); font-weight: var(--font-weight-bold); color: var(--text-main); margin-bottom: 6px; display: flex; align-items: center; gap: 6px; }
    .tc-tags { display: flex; flex-wrap: wrap; gap: 6px; }
    
    .type-tag {
      width: calc((100% - 12px) / 3); 
      max-width: 96px;
      justify-content: center; 
      border-radius: var(--radius-md); font-weight: var(--font-weight-bold);
      color: #FFF; box-shadow: 0 2px 6px rgba(31,45,38,0.10); display: inline-flex; align-items: center; gap: 4px;
      box-sizing: border-box;
      position: relative;
      font-size: var(--type-tag-font-size);
    }
    .tc-empty { font-size: var(--font-size-sm); color: var(--text-sub); font-style: normal; font-weight: var(--font-weight-semibold); }
    .type-instruction { position: absolute; top: 12px; right: 15px; font-size: var(--font-size-sm); color: var(--text-sub); font-weight: var(--font-weight-semibold); background: rgba(255,255,255,0.94); padding: 6px 10px; border-radius: var(--radius-md); z-index: 5; border: 1px solid var(--border-color); display: flex; align-items: center; gap: 8px; box-shadow: var(--shadow-soft); }
    .type-instruction label { cursor: pointer; display: flex; align-items: center; gap: 4px; user-select: none; }
    .type-instruction input[type="checkbox"] { accent-color: var(--accent); width: 14px; height: 14px; cursor: pointer; margin: 0; }

    /* 面板选项卡样式 */
    .panel-tabs {
      display: flex;
      background: var(--color-surface-muted);
      border-bottom: 1px solid var(--border-color);
      flex-shrink: 0;
    }
    .panel-tab {
      flex: 1;
      text-align: center;
      padding: 12px 15px;
      font-weight: var(--font-weight-semibold);
      font-size: var(--font-size-md);
      color: var(--text-sub);
      cursor: pointer;
      transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
      letter-spacing: 0;
    }
    .panel-tab.active {
      color: var(--accent);
      background: var(--element-bg);
      border-bottom: 2px solid var(--accent);
    }
    .panel-tab:hover:not(.active) {
      background: var(--color-accent-softer);
    }

    /* 选项卡内容区 */
    .tab-content {
      display: none;
      flex: 1;
      width: 100%;
      height: 100%;
      min-height: 0;
      position: relative;
      flex-direction: column;
    }
    .tab-content.active {
      display: flex;
    }

    /* 战术轮转内容样式 */
    #tab-tactics {
      background: var(--color-surface-muted);
      overflow: hidden;
    }
    
    .tactics-list {
      flex: 1;
      overflow-y: auto;
      padding: 15px;
      display: grid;
      gap: 15px;
      align-content: start; 
    }
    .tactics-list.cols-1 { grid-template-columns: minmax(0, 1fr); }
    .tactics-list.cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .tactics-list.cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

    .tactics-list::-webkit-scrollbar { width: 4px; }
    .tactics-list::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 2px; }

    .tactic-card {
      background: var(--element-bg);
      border: 1px solid var(--border-color);
      border-radius: var(--radius-lg);
      box-shadow: 0 4px 12px rgba(31,45,38,0.04);
      overflow: hidden;
      display: flex;
      flex-direction: column; 
    }
    .tactic-header {
      background: var(--color-surface-muted);
      padding: 10px 15px;
      font-weight: var(--font-weight-bold);
      color: var(--text-main);
      border-bottom: 1px dashed var(--border-color);
      display: flex;
      align-items: center;
      flex-wrap: wrap; 
      gap: 4px;
    }
    .tactic-body {
      padding: 12px 15px;
      display: flex;
      flex-direction: column;
      gap: 12px;
      flex: 1; 
    }
    .tactic-tier {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }
    .tier-title {
      font-size: var(--font-size-md); 
      font-weight: var(--font-weight-bold);
      color: var(--text-main);
      display: flex;
      align-items: center;
      white-space: nowrap; 
    }
    .tier-desc {
      font-size: var(--font-size-sm); 
      color: var(--text-sub);
      font-weight: var(--font-weight-regular);
      margin-left: 6px;
    }
    .tier-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
    }

    /* 队伍阵容分析特有样式 */
    .team-builder-container {
      display: flex; flex-direction: column; height: 100%; padding: 15px; gap: 15px; overflow: hidden; background: var(--bg-color);
    }
    .team-roster {
      display: flex; flex-direction: column; gap: 12px; flex-shrink: 0; background: var(--element-bg); padding: 12px; border-radius: var(--radius-lg); border: 1px solid var(--border-color); box-shadow: var(--shadow-soft);
    }
    
    .roster-slots {
      display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 10px; overflow-x: auto; padding: 6px 6px 12px 6px;
    }
    .roster-slots::-webkit-scrollbar { height: 4px; }
    .roster-slots::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 2px; }
    
    .roster-slot {
      background: var(--color-surface-muted); border: 1px solid var(--border-color); border-radius: var(--radius-lg); padding: 6px; 
      cursor: pointer; transition: transform var(--transition-fast), background var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast); display: flex; flex-direction: row; align-items: center; gap: 8px; user-select: none;
      height: 70px; 
      overflow: hidden;
    }
    .roster-slot.active {
      border-color: var(--accent); box-shadow: var(--shadow-focus); background: var(--color-accent-softer); transform: translateY(-1px);
    }
    .roster-slot img {
      width: 50px; height: 50px; object-fit: contain; border-radius: var(--radius-sm); background: var(--element-bg); flex-shrink: 0; border: 1px solid var(--border-color);
    }
    .slot-info {
      display: flex; flex-direction: column; justify-content: center; gap: 3px; flex: 1; min-width: 0; height: 100%;
    }
    .slot-name { 
      font-weight: var(--font-weight-bold); color: var(--text-main); font-size: var(--font-size-sm); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; 
    }
    .slot-types-row {
      display: flex; gap: 3px; align-items: center; white-space: nowrap; overflow: hidden;
    }
    .slot-label {
      font-size: 11px; color: var(--text-sub); font-weight: var(--font-weight-semibold); flex-shrink: 0;
    }
    .slot-types-row .type-tag {
      font-size: 10px; padding: 0.1em 0.5em; width: auto; box-shadow: none; margin: 0; flex-shrink: 0; border-radius: 6px;
    }

    .roster-editor {
      display: flex; flex-direction: column; background: var(--color-surface-muted); padding: 12px; border-radius: var(--radius-lg); border: 1px solid var(--border-color);
    }
    .editor-header { 
      display: flex; justify-content: space-between; align-items: center; font-weight: var(--font-weight-bold); color: var(--accent); font-size: var(--font-size-md); 
    }
    #editor-rows-container {
      display: flex; flex-direction: column; gap: 10px; margin-top: 10px; padding-top: 10px; border-top: 1px dashed var(--border-color); transition: all 0.3s;
    }
    .editor-row { display: flex; align-items: center; gap: 15px; }
    .editor-row .filter-label { width: 140px; text-align: right; font-size: 13px; flex-shrink: 0;}
    .editor-row .filter-list-scroll { flex: 1; }

    /* 核心：8宫格全屏展示布局 (无内部滚动条，左1右2，等分铺满空间) */
    .team-analysis-main {
      display: flex;
      flex-direction: row;
      gap: 15px;
      flex: 1;
      min-height: 0;
    }
    .macro-card-wrapper {
      flex: 1; /* 左边宏观区域占 1 份 */
      background: var(--element-bg); 
      border: 1px solid var(--border-color); 
      border-radius: var(--radius-lg); 
      display: flex; 
      flex-direction: column; 
      overflow: hidden; 
      box-shadow: 0 4px 12px rgba(31,45,38,0.04);
    }
    .micro-panel-grid {
      flex: 2; /* 右侧微观区域占 2 份，内部继续切割 */
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      grid-template-rows: repeat(3, minmax(0, 1fr));
      gap: 12px;
      min-height: 0;
    }
    .micro-card-wrapper {
      background: var(--element-bg); 
      border: 1px solid var(--border-color); 
      border-radius: var(--radius-lg); 
      display: flex; 
      flex-direction: column; 
      overflow: hidden; 
      box-shadow: 0 4px 12px rgba(31,45,38,0.04);
      transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base), opacity var(--transition-base), filter var(--transition-base);
      position: relative;
    }
    
    /* 悬停高亮与变暗联动 */
    .micro-card-wrapper.highlight-card {
      transform: translateY(-4px);
      box-shadow: var(--shadow-raised);
      border-color: var(--accent);
      z-index: 10;
    }
    .micro-card-wrapper.dimmed-card {
      opacity: 0.3; filter: grayscale(80%);
    }
    
    .team-macro-tag {
      cursor: pointer; transition: 0.2s;
      border: 2px solid transparent; /* 提前占位防止抖动 */
      box-sizing: border-box;
      white-space: nowrap; /* 强制不换行 */
      width: auto !important; /* 解除原有宽度的限制 */
      max-width: none !important;
    }
    .team-macro-tag.active-macro-tag {
      border-color: var(--accent);
      box-shadow: var(--shadow-focus);
      z-index: 5;
      transform: translateY(-2px);
    }
    
    .grid-card-header {
      padding: 6px 12px; border-bottom: 1px dashed var(--border-color); 
      font-weight: var(--font-weight-bold); color: var(--text-main); font-size: var(--font-size-sm); display: flex; align-items: center; justify-content: space-between; gap: 6px; flex-shrink: 0;
    }
    
    .micro-chart-box {
      flex: 1; width: 100%; min-height: 0; position: relative;
    }

    /* 弹窗样式 */
    .modal-overlay {
      display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(31, 45, 38, 0.52); z-index: 1000; justify-content: center; align-items: center; backdrop-filter: blur(4px);
    }
    .modal-overlay.active { display: flex; }
    .modal-content {
      background: var(--element-bg); width: 90%; max-width: 800px; height: 85%; border-radius: var(--radius-xl); display: flex; flex-direction: column; overflow: hidden; box-shadow: var(--shadow-raised); border: 1px solid var(--border-color);
    }
    .modal-header {
      padding: 15px 20px; background: var(--color-surface-muted); border-bottom: 1px solid var(--border-color); display: flex; justify-content: space-between; align-items: center; flex-shrink: 0;
    }
    .modal-header input {
      padding: 8px 14px; border: 1px solid var(--border-color); border-radius: var(--radius-pill); outline: none; flex: 1; margin: 0 20px; font-family: inherit; font-weight: var(--font-weight-medium); font-size: var(--font-size-md); transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    }
    .modal-header input:focus { border-color: var(--accent); }
    .modal-close {
      cursor: pointer; font-size: 28px; color: var(--text-sub); font-weight: var(--font-weight-semibold); line-height: 1; transition: color var(--transition-fast);
    }
    .modal-close:hover { color: var(--btn-danger); }
    .modal-body {
      flex: 1; padding: 20px; overflow-y: auto; display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 15px; align-content: start; background: var(--color-surface-muted);
    }
    .modal-body::-webkit-scrollbar { width: 6px; }
    .modal-body::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 3px; }
    .poke-select-card {
      background: var(--element-bg); border: 1px solid var(--border-color); border-radius: var(--radius-lg); padding: 12px 10px; display: flex; flex-direction: column; align-items: center; cursor: pointer; transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast); gap: 8px;
    }
    .poke-select-card:hover {
      border-color: var(--accent); transform: translateY(-2px); box-shadow: var(--shadow-soft);
    }
    .poke-select-card img { width: 60px; height: 60px; object-fit: contain; }
    .poke-select-card .name { font-size: var(--font-size-sm); font-weight: var(--font-weight-bold); text-align: center; color: var(--text-main); line-height: 1.3; }

    /* 中屏与移动端响应式布局 */
    @media (max-width: 1200px) {
      .tactics-list.cols-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    }

    @media (max-width: 900px) {
      .team-analysis-main { flex-direction: column; overflow-y: auto; }
      .macro-card-wrapper { flex: none; min-height: 400px; }
      .micro-panel-grid { flex: none; min-height: 800px; }
    }

    @media (max-width: 768px) {
      body { flex-direction: column; height: 100vh; overflow: hidden; } 
      .sidebar {
        width: 100%; height: 50px; border-right: none; border-bottom: 1px solid var(--border-color);
        background: var(--panel-bg); flex-direction: row; transition: none; z-index: 100; padding-top: 0;
      }
      .sidebar:hover { width: 100%; background: var(--panel-bg); } 
      .nav-list { flex-direction: row; width: 100%; justify-content: space-around; padding: 0; align-items: center; gap: 0;}
      .nav-item { height: 50px; padding: 0; flex: 1; justify-content: center; }
      .nav-item.active::before { width: 100%; height: 4px; top: auto; left: 0; bottom: 0; }
      .nav-icon { width: auto; margin-right: 6px; font-size: 16px; }
      .nav-text { opacity: 1; font-size: 14px; margin: 0; transition: none; }
      .main-wrapper { overflow: auto; flex: 1; }
      .view-section { overflow: visible; height: auto; min-height: 100%; }
      header { padding: 0 15px; height: 60px; min-height: 60px; }
      .title { font-size: 18px; }
      .header-controls { gap: 6px; }
      .btn-global { padding: 4px 10px; font-size: 12px; }
      
      .main-container { flex-direction: column; overflow: visible; padding: 10px; gap: 15px; }
      .panel { min-height: unset; height: auto; overflow: visible; }
      .left-panel { flex: none; height: 500px; padding: 15px; } 
      .right-panel { flex: none; height: auto; padding: 15px; }
      .left-controls { flex-direction: column; align-items: flex-start; gap: 15px; }
      .view-controls { padding-left: 0; border-left: none; width: 100%; flex-direction: row; justify-content: space-between; border-top: 1px dashed var(--border-color); padding-top: 10px; }
      .right-top-split { flex-direction: column; }
      #radar-chart { min-height: 250px; }
      .img-container { height: 200px; flex: none; }

      .top-slicer { padding: 10px; gap: 8px; }
      .slicer-row { gap: 10px; }
      .filter-header { flex-direction: column; align-items: flex-start; gap: 4px;}
      .filter-desc { display: none; } 

      .type-grid-container { flex-direction: column; overflow: visible; padding: 10px; }
      .type-panel { flex: none; min-height: 400px; }
      #card-panel { width: 100%; min-height: auto; order: -1; }
      
      .team-builder-container { padding: 10px; gap: 10px; flex-direction: column; overflow: visible;}
      .team-roster { padding: 10px; flex: none; }
      .editor-row { flex-direction: column; align-items: flex-start; gap: 6px; }
      .editor-row .filter-label { width: 100%; text-align: left; }
      
      .roster-slots { grid-template-columns: repeat(3, minmax(0, 1fr)); }
      
      .micro-panel-grid { grid-template-columns: 1fr; }
    }
