/* ============================================================
   pokemon-summary.css  — 全ポケモン評価一覧テーブル
   ============================================================ */

#pokego-pokemon-summary {
    --pks-accent:   #0c6d7d;
    --pks-accent-s: #d9eff2;
    --pks-ink:      #1f2430;
    --pks-soft:     #667085;
    --pks-line:     #d8dde6;
    --pks-paper:    #ffffff;
    --pks-surface:  #f4f6fb;
    --pks-radius:   10px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 16px 12px 48px;
    font-family: 'Helvetica Neue', Arial, 'Hiragino Kaku Gothic ProN',
                 'Hiragino Sans', Meiryo, sans-serif;
    color: var(--pks-ink);
    font-size: 13px;
}

/* ---- コントロールバー ---- */
.pks-controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
}

.pks-search-wrap {
    position: relative;
    flex: 1 1 200px;
    min-width: 140px;
    max-width: 320px;
}

.pks-search-wrap::before {
    content: "🔍";
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 13px;
    pointer-events: none;
}

#pks-search {
    width: 100%;
    padding: 8px 10px 8px 32px;
    border: 1px solid var(--pks-line);
    border-radius: var(--pks-radius);
    font-size: 13px;
    color: var(--pks-ink);
    background: var(--pks-paper);
    box-sizing: border-box;
    outline: none;
}

#pks-search:focus {
    border-color: var(--pks-accent);
    box-shadow: 0 0 0 2px var(--pks-accent-s);
}

/* ---- フィルタートグル ---- */
.pks-filter-group {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}

.pks-filter-label {
    font-size: 12px;
    color: var(--pks-soft);
    font-weight: 600;
}

.pks-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 11px;
    border-radius: 999px;
    border: 1px solid var(--pks-line);
    background: var(--pks-paper);
    color: var(--pks-soft);
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    user-select: none;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.pks-filter-btn::before {
    content: "☑";
    font-size: 12px;
}

.pks-filter-btn.excluded {
    background: #f5f5f5;
    color: #b0b0b0;
    border-color: #ddd;
    text-decoration: line-through;
}

.pks-filter-btn.excluded::before {
    content: "☐";
}

.pks-filter-btn[data-cat="shadow"]   { border-color: rgba(147,112,219,.5); color: #6a35c2; }
.pks-filter-btn[data-cat="mega"],
.pks-filter-btn[data-cat="gmax"]     { border-color: rgba(255,152,0,.5); color: #e65100; }
.pks-filter-btn[data-cat="legendary"]{ border-color: rgba(239,108,0,.5); color: #bf360c; }

.pks-filter-btn[data-cat="shadow"].excluded,
.pks-filter-btn[data-cat="mega"].excluded,
.pks-filter-btn[data-cat="gmax"].excluded,
.pks-filter-btn[data-cat="legendary"].excluded { color: #b0b0b0; border-color: #ddd; }

.pks-count {
    margin-left: auto;
    font-size: 12px;
    color: var(--pks-soft);
    white-space: nowrap;
}

.pks-count strong {
    color: var(--pks-ink);
    font-size: 14px;
}

/* ---- テーブルラッパー ---- */
.pks-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border: 1px solid var(--pks-line);
    border-radius: var(--pks-radius);
    box-shadow: 0 2px 8px rgba(17,24,39,.05);
}

#pks-table {
    width: auto;
    border-collapse: collapse;
    white-space: nowrap;
    table-layout: fixed;
}

/* ---- 列幅固定（colgroup で管理、CSS は補助のみ） ---- */
#pks-table .pks-col-name { overflow: hidden; }

/* ---- ヘッダー ---- */
#pks-table thead th {
    position: sticky;
    top: 0;
    background: var(--pks-surface);
    padding: 9px 10px;
    text-align: left;
    font-size: 11px;
    font-weight: 700;
    color: var(--pks-soft);
    text-transform: uppercase;
    letter-spacing: .05em;
    border-bottom: 2px solid var(--pks-line);
    z-index: 10;
}

#pks-table thead th.sortable {
    cursor: pointer;
    user-select: none;
}

#pks-table thead th.sortable:hover {
    background: #e8ecf0;
}

#pks-table thead th .sort-arrow {
    display: inline-block;
    margin-left: 4px;
    opacity: .35;
    font-size: 10px;
}

#pks-table thead th.sort-asc .sort-arrow { opacity: 1; }
#pks-table thead th.sort-asc .sort-arrow::after  { content: "▲"; }
#pks-table thead th.sort-desc .sort-arrow { opacity: 1; }
#pks-table thead th.sort-desc .sort-arrow::after { content: "▼"; }
#pks-table thead th:not(.sort-asc):not(.sort-desc) .sort-arrow::after { content: "⇅"; }

/* ---- 行 ---- */
#pks-table tbody tr {
    border-bottom: 1px solid var(--pks-line);
    transition: background 0.1s;
}

#pks-table tbody tr:last-child { border-bottom: none; }

#pks-table tbody tr:hover { background: #f0f9fb; }

#pks-table tbody td {
    padding: 6px 8px;
    vertical-align: middle;
    height: 52px;  /* 全行の高さを統一（画像44px+上下padding8px） */
    overflow: hidden;
}

/* 画像セル */
.pks-img-cell {
    width: 56px;
    padding: 4px !important;
    line-height: 0;  /* inline要素の余白を除去 */
}

.pks-pokemon-img {
    width: 44px;
    height: 44px;
    object-fit: contain;
    display: block;
}

.pks-img-placeholder {
    width: 44px;
    height: 44px;
    background: var(--pks-surface);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    color: var(--pks-soft);
}

/* 図鑑番号 */
.pks-dex {
    color: var(--pks-soft);
    font-size: 11px;
    font-weight: 600;
    min-width: 36px;
    text-align: right;
}

/* ポケモン名 */
.pks-name-inner {
    max-width: 216px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pks-name-link {
    color: var(--pks-accent);
    text-decoration: none;
    font-weight: 700;
    font-size: 13px;
}

.pks-name-link:hover { text-decoration: underline; }

/* フォルム */
.pks-form {
    font-size: 11px;
    color: var(--pks-soft);
    min-width: 60px;
}

/* カテゴリバッジ */
.pks-badge {
    display: inline-block;
    padding: 2px 7px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    white-space: nowrap;
}

.pks-badge--shadow   { background: rgba(147,112,219,.18); color: #6a35c2; }
.pks-badge--mega     { background: rgba(255,152,0,.18); color: #e65100; }
.pks-badge--gmax     { background: rgba(255,87,34,.18); color: #c62828; }
.pks-badge--legendary{ background: rgba(239,108,0,.12); color: #bf360c; }
.pks-badge--normal   { display: none; }

/* タイプチップ */
.pks-type-chips {
    display: flex;
    gap: 2px;
    overflow: hidden;
}

.pks-type-chip {
    display: inline-block;
    padding: 2px 7px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    color: #fff;
}

.pks-type--ノーマル  { background: #9fa19f; }
.pks-type--ほのお    { background: #e62829; }
.pks-type--みず      { background: #2980ef; }
.pks-type--でんき    { background: #fac000; color: #3a2e00; }
.pks-type--くさ      { background: #3fa129; }
.pks-type--こおり    { background: #3dcef3; color: #003a48; }
.pks-type--かくとう  { background: #ff8000; }
.pks-type--どく      { background: #9141cb; }
.pks-type--じめん    { background: #915121; }
.pks-type--ひこう    { background: #81b9ef; color: #1a3055; }
.pks-type--エスパー  { background: #ef4179; }
.pks-type--むし      { background: #91a119; }
.pks-type--いわ      { background: #b0ab82; color: #2e2a16; }
.pks-type--ゴースト  { background: #704170; }
.pks-type--ドラゴン  { background: #5060e1; }
.pks-type--あく      { background: #4f3f3d; }
.pks-type--はがね    { background: #60a1b8; color: #fff; }
.pks-type--フェアリー{ background: #ef70ef; }

/* 数値セル */
.pks-num {
    text-align: right;
    font-variant-numeric: tabular-nums;
    min-width: 50px;
    font-size: 12px;
}

/* 10段階評価セル */
.pks-step10-cell {
    text-align: center;
    min-width: 60px;
}

.pks-step10-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 800;
    color: #fff;
}

.pks-step10-null {
    color: #ccc;
    font-size: 11px;
}

/* ---- ローディング ---- */
.pks-loading {
    text-align: center;
    padding: 40px;
    color: var(--pks-soft);
    font-size: 14px;
}

/* ---- エラー ---- */
.pks-error {
    text-align: center;
    padding: 24px;
    color: #c62828;
    font-size: 13px;
    background: #ffebee;
    border-radius: var(--pks-radius);
    margin: 12px 0;
}

/* ---- 件数0 ---- */
.pks-empty {
    text-align: center;
    padding: 40px;
    color: var(--pks-soft);
    font-size: 13px;
}

/* ============================================================
   静的SEOブロック（クローラ向け常時HTML出力 / JSロード後は静的テーブルを非表示）
   ============================================================ */

.pks-static-block {
    max-width: 1200px;
    margin: 0 auto;
    padding: 8px 12px 0;
    font-family: 'Helvetica Neue', Arial, 'Hiragino Kaku Gothic ProN',
                 'Hiragino Sans', Meiryo, sans-serif;
    color: #1f2430;
    font-size: 13px;
}

/* 静的テーブルはデフォルト非表示（JSレンダリング優先。クローラーは読める）*/
.pks-static-table-wrap { display: none; }
/* JS無効環境では <noscript> 経由で表示 */

/* ---- 「このページの見方」 ---- */
.pks-intro-wrap {
    background: #f4f6fb;
    border: 1px solid #d8dde6;
    border-radius: 10px;
    padding: 14px 18px;
    margin-bottom: 18px;
}

.pks-intro-heading {
    font-size: 14px;
    font-weight: 700;
    margin: 0 0 10px;
    color: #0c6d7d;
}

.pks-intro-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
}

.pks-intro-table th {
    padding: 5px 14px 5px 0;
    text-align: left;
    white-space: nowrap;
    color: #667085;
    font-weight: 600;
    width: 110px;
    vertical-align: top;
}

.pks-intro-table td {
    padding: 5px 0;
    color: #1f2430;
    line-height: 1.5;
}

/* ---- 静的一覧テーブル ---- */
.pks-static-note {
    font-size: 12px;
    color: #667085;
    margin: 0 0 8px;
}

.pks-static-tbl {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
    border: 1px solid #d8dde6;
    border-radius: 10px;
    overflow: hidden;
}

.pks-static-tbl th {
    background: #f4f6fb;
    padding: 7px 10px;
    text-align: left;
    font-size: 11px;
    font-weight: 700;
    color: #667085;
    border-bottom: 2px solid #d8dde6;
    white-space: nowrap;
}

.pks-static-tbl td {
    padding: 5px 10px;
    border-bottom: 1px solid #d8dde6;
    vertical-align: middle;
}

.pks-static-tbl tr:last-child td { border-bottom: none; }

.pks-static-tbl td:first-child a {
    color: #0c6d7d;
    text-decoration: none;
    font-weight: 600;
}

.pks-static-tbl td:first-child a:hover { text-decoration: underline; }

/* ---- 左固定列（画像列を sticky で固定） ---- */
#pks-table .pks-col-img {
    position: sticky;
    left: 0;
    z-index: 2;
    min-width: 44px;  /* sticky 時に列幅が縮まないよう保護 */
    box-shadow: 2px 0 4px rgba(0,0,0,.06);
}
#pks-table thead th.pks-col-img {
    z-index: 12;
}
#pks-table tbody td.pks-col-img {
    background: var(--pks-paper);
}
#pks-table tbody tr:hover td.pks-col-img {
    background: #f0f9fb;
}

/* テーマの max-width:100% / height:auto がポケモン画像を変形させないよう上書き */
.pks-pokemon-img {
    max-width: none !important;
    width: 44px !important;
    height: 44px !important;
}

/* ---- デスクトップ: 幅いっぱいに展開 ---- */
/* Affingerのコンテンツ幅制約はWPページ側で上書き済み。こちらは100%で収める。 */
@media (min-width: 960px) {
    #pokego-pokemon-summary {
        max-width: none;
        width: 100%;
        box-sizing: border-box;
    }
    /* セルの左右パディングを詰めて全カラムを画面内に収める */
    #pks-table thead th,
    #pks-table tbody td {
        padding-left: 7px;
        padding-right: 7px;
    }
}

/* ---- レスポンシブ ---- */
@media (max-width: 640px) {
    #pokego-pokemon-summary {
        padding: 10px 8px 32px;
    }
    .pks-controls {
        gap: 8px;
    }
    .pks-count {
        margin-left: 0;
        width: 100%;
    }
    /* モバイルでは一部列を非表示 */
    #pks-table .pks-col-durability,
    #pks-table .pks-col-gl,
    #pks-table .pks-col-ul,
    #pks-table .pks-col-ml {
        display: none;
    }
}
