/* ==================  テーマ変数  ================== */
:root {
    --bg: #0b1a12;
    --panel: #16281c;
    --card-bg: #16281c;
    --text: #e5e7eb;
    --muted: #94a3a8;
    --accent: #36d6b5;
    --accent-soft: rgba(54,214,181,.18);
}

/* ==================  ベース  ================== */
html, body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font-family: "Segoe UI",system-ui,sans-serif
}

*, *:before, *:after { box-sizing: border-box }

/* 共通カード */
.card {
    background: var(--card-bg);
    border: 1px solid var(--accent-soft);
    border-radius: 12px;
    box-shadow: 0 1px 6px rgba(0,0,0,.35);
    padding: 12px;
}

/* 固定ヘッダー */
body { padding-left: 2cm }
/* 既存ロゴ分(PC) */
#slotTopBtn {
    position: fixed;
    top: 8px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--panel);
    color: var(--accent);
    padding: 6px 18px;
    border-radius: 8px;
    font-weight: 700;
    border: 1px solid var(--accent-soft);
    z-index: 9999;
    box-shadow: 0 2px 8px rgba(0,0,0,.55);
    text-decoration: none;
}

/* 見出し */
h3 {
    margin: 18px auto 10px;
    max-width: 1280px;
    padding: 0 12px;
    color: #cbd5e1;
    letter-spacing: .2px
}

/* コンテナ */
.summary-wrap, .form-area {
    max-width: 1280px;
    margin: 8px auto 0;
    padding: 0 12px
}

/* フォーム */
.search-container { margin-bottom: 10px }
label { color: var(--muted); margin-right: 6px }
input[type="text"], select {
    background: #0f251b;
    color: var(--text);
    border: 1px solid #173328;
    border-radius: 8px;
    padding: 6px 8px
}
.select-row {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    align-items: center;
    white-space: nowrap
}

/* ==================  summaryData（上カード）  ================== */
#summaryData {
    display: block;
    background: var(--panel);
    border: 1px solid var(--accent-soft);
    border-radius: 12px;
    padding: 10px 14px
}
#summaryData .label {
    color: var(--accent);
    font-weight: 700;
    display: block;
    margin-bottom: 8px
}
#summaryData .summary-grid {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0 10px
}
#summaryData .kv { display: flex; align-items: baseline; gap: 6px }
#summaryData .kv .k { color: var(--muted) }
#summaryData .kv + .kv::before {
    content: "|";
    color: var(--muted);
    margin: 0 10px
}

/* ==================  期間Data（下カード）  ================== */
#filteredSummaryData {
    margin-top: 2px;
    max-width: 1280px;
    margin-inline: auto;
    padding-inline: 14px;
    background: var(--panel);
    border: 1px solid var(--accent-soft);
    border-radius: 12px;
    padding-top: 10px;
    padding-bottom: 10px
}
#filteredSummaryData .label-period { color: #ffd166; font-weight: 700 }
#filteredSummaryData .period-lines { display: grid; gap: 8px; margin-top: 4px }
#filteredSummaryData .line {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 6px
}
#filteredSummaryData .pair { display: inline-flex; align-items: baseline; gap: 4px }
#filteredSummaryData .sep { color: var(--muted); margin: 0 6px }

/* ==================  PC 固定  ================== */
@media (min-width:769px) {
    :root { --slotTopH: 30px }
    body { padding-top: var(--slotTopH) }
    h3 { margin-top: 8px }

    /* 上カードの行表示（PCは横並び） */
    #summaryData .summary-lines {
        display: flex !important;
        flex-wrap: wrap;
        align-items: baseline;
        gap: 0 8px
    }
    #summaryData .kvline { display: flex; align-items: baseline; gap: 0 8px }
    #summaryData .kvline + .kvline::before {
        content: "|";
        color: var(--muted);
        margin: 0 8px
    }
    #summaryData .pair { display: flex; align-items: baseline; gap: 6px }
    #summaryData .pair + .pair::before {
        content: "|";
        color: var(--muted);
        margin: 0 8px
    }

    /* ▼ 期間DataをPCで「上カード」と同じ1行インラインに */
    #filteredSummaryData .period-lines {
        display: flex !important;
        flex-wrap: wrap;
        align-items: baseline;
        gap: 0 8px;
    }
    #filteredSummaryData .line { display: flex; align-items: baseline; gap: 6px; }
    #filteredSummaryData .line + .line::before {
        content: "|";
        color: var(--muted);
        margin: 0 8px;
    }
    #filteredSummaryData .sep { margin: 0 8px; }
}

/* ==================  モバイル（〜768px）  ================== */
@media (max-width:768px) {
    /* 全幅化と横スクロール抑止 */
    body { padding-left: 0 }
    html, body { overflow-x: hidden }

    /* SLOT TOP 調整 */
    #slotTopBtn { font-size: 13px; padding: 3px 14px; top: 6px }

    /* タイトル余白 */
    h3 {
        margin-top: 48px;
        text-align: center;
        padding: 0 8px;
        line-height: 1.35;
        font-size: 17px
    }

    /* フォームを2列グリッドに */
    .search-container {
        display: grid;
        grid-template-columns: 120px 1fr;
        gap: 8px;
        align-items: center
    }
    .select-row {
        display: grid !important;
        grid-template-columns: 120px 1fr;
        gap: 8px;
        align-items: center;
        white-space: normal
    }
    .select-row label, .select-row select { width: 100%; max-width: 100% }

    /* 上カード：ガター圧縮＋自動縮小 */
    .summary-wrap, #summaryData { padding-inline: 6px }
    #summaryData { font-size: clamp(12px,3.2vw,14px); line-height: 1.35 }
    #summaryData .summary-lines {
        display: grid !important;
        grid-template-columns: 1fr;
        gap: 8px;
        margin-top: 4px
    }
    #summaryData .kvline { display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px }
    #summaryData .pair { display: flex; align-items: baseline; gap: 4px }
    #summaryData .kv + .kv::before, #summaryData .pair + .pair::before { margin: 0 4px }
    #summaryData .kv + .kv::before { content: "" } /* 1列なのでパイプ非表示 */

    /* 下カード：同じ縮小＆ガター */
    #filteredSummaryData {
        padding-inline: 6px;
        font-size: clamp(12px,3.2vw,14px);
        line-height: 1.35
    }
}

/* より狭い端末（〜520px）微調整 */
@media (max-width:520px) {
    #summaryData { font-size: clamp(12px,3.6vw,13.5px) }
    #filteredSummaryData { font-size: clamp(11.5px,3.5vw,13px) }
    #filteredSummaryData .line { gap: 6px }
}

/* ==================  Best/Worst ランキング  ================== */
/* === Best/Worst（左右ガター極小・はみ出し無し・自動縮小フォント） === */
#g5BestWorstWrapper {
    max-width: 1280px;
    margin: 20px auto;
    padding-inline: 2px;
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
    gap: 10px;
    box-sizing: border-box;
}
#g5BestWorstWrapper .card { min-width: 0; padding: 10px; }
#g5BestWorstWrapper table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
    font-size: clamp(12px, 1.35vw, 14px);
}
/* 列幅調整 */
#g5BestWorstWrapper colgroup col:first-child { width: 48px !important; }
#g5BestWorstWrapper colgroup col:nth-child(2) { width: 120px !important; }
#g5BestWorstWrapper colgroup col:nth-child(3) { width: 90px !important; }
#g5BestWorstWrapper colgroup col:nth-child(4) { width: 90px !important; }
#g5BestWorstWrapper colgroup col:nth-child(5) { width: 70px !important; }
#g5BestWorstWrapper th, #g5BestWorstWrapper td {
    padding: 6px 8px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
#g5BestWorstWrapper h4 { margin: 4px 0 8px; }

/* === モバイル時（768px以下） === */
@media (max-width: 768px) {
    #g5BestWorstWrapper { padding-inline: 4px; gap: 10px; }
    #g5BestWorstWrapper colgroup col:nth-child(2) { width: 100px !important; }
    #g5BestWorstWrapper colgroup col:nth-child(3),
    #g5BestWorstWrapper colgroup col:nth-child(4) { width: 84px !important; }
    #g5BestWorstWrapper colgroup col:nth-child(5) { width: 60px !important; }

    /* 横幅と中央揃えを上カードと統一 */
    #filteredSummaryData {
        width: 100%;
        max-width: 1280px;
        margin-inline: auto;
        padding-inline: 6px;
        font-size: clamp(12px, 3.2vw, 14px);
        line-height: 1.35;
    }
    #filteredSummaryData .period-lines {
        display: grid !important;
        grid-template-columns: 1fr;
        gap: 8px;
        margin-top: 4px;
    }
    #filteredSummaryData .line { display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px; }
    #filteredSummaryData .pair { display: flex; align-items: baseline; gap: 4px; }
    #filteredSummaryData .sep { color: var(--muted); margin: 0 6px; }
}

/* === Android 360px級(～420px)での右はみ出し対策 === */
@media (max-width: 420px) {
    #g5BestWorstWrapper { padding-inline: 4px; }
    #g5BestWorstWrapper .card { padding: 8px; overflow-x: clip; }
    #g5BestWorstWrapper table { font-size: clamp(11px, 3.2vw, 13px); }
    #g5BestWorstWrapper colgroup col:first-child { width: 42px !important; }
    #g5BestWorstWrapper colgroup col:nth-child(2) { width: 92px !important; }
    #g5BestWorstWrapper colgroup col:nth-child(3) { width: 82px !important; }
    #g5BestWorstWrapper colgroup col:nth-child(4) { width: 72px !important; }
    #g5BestWorstWrapper colgroup col:nth-child(5) { width: 58px !important; }
    #g5BestWorstWrapper th, #g5BestWorstWrapper td { padding: 5px 6px; }
}

/* ==================  ウォーターフォール保険  ================== */
#3WaterfallWrapper > .card, #_3WaterfallWrapper > .card, #waterfallChartArea, #waterfallChartArea * { box-sizing: border-box }
#3WaterfallWrapper > .card, #_3WaterfallWrapper > .card { min-width: 0 !important }
#waterfallChartArea { width: 100% !important; height: 240px }

/* ===== summary 2カードの“流体タイポ + 余白” ===== */
:is(#summaryData, #filteredSummaryData) {
    font-size: clamp(14px, 0.95vw, 16px);
    line-height: 1.35;
    padding-block: clamp(8px, 1vw, 14px);
    padding-inline: clamp(10px, 1.2vw, 18px);
}
:is(#summaryData, #filteredSummaryData) .kvline,
:is(#summaryData, #filteredSummaryData) .line {
    gap: clamp(4px, 0.8vw, 10px);
}
:is(#summaryData, #filteredSummaryData) .pair {
    gap: clamp(3px, 0.6vw, 8px);
}
:is(#summaryData, #filteredSummaryData) .kv + .kv::before,
:is(#summaryData, #filteredSummaryData) .pair + .pair::before {
    margin: 0 clamp(3px, 0.7vw, 8px);
}

/* ===== スマホ（〜768px）：より積極的に拡縮 ===== */
@media (max-width: 768px) {
    :is(#summaryData, #filteredSummaryData) {
        font-size: clamp(12.5px, 3.6vw, 15.5px);
        padding-inline: clamp(6px, 3vw, 14px);
        padding-block: clamp(8px, 2.6vw, 12px);
    }
    :is(#summaryData, #filteredSummaryData) .kvline,
    :is(#summaryData, #filteredSummaryData) .line {
        gap: clamp(4px, 1.6vw, 9px);
    }
    :is(#summaryData, #filteredSummaryData) .pair {
        gap: clamp(3px, 1.2vw, 7px);
    }
    :is(#summaryData, #filteredSummaryData) .kv + .kv::before,
    :is(#summaryData, #filteredSummaryData) .pair + .pair::before {
        margin: 0 clamp(3px, 1.6vw, 7px);
    }
}

/* ===== 超狭幅（〜420px）：読みやすさ維持の微調整 ===== */
@media (max-width: 420px) {
    :is(#summaryData, #filteredSummaryData) {
        font-size: clamp(12px, 3.9vw, 15px);
        padding-inline: clamp(6px, 3.4vw, 12px);
    }
}

/* ===== 機種Dataカード：幅・色・余白の統一 ===== */
#machineMetaCard {
    width: 100%;
    max-width: 1280px;
    margin: 6px auto 0;
    padding: 10px 14px;
    box-sizing: border-box;
}
#machineMetaCard .label-machine {
    color: #58c0e8; /* 青と水色の中間 */
    font-weight: 700;
    display: block;
    margin-bottom: 8px;
}

/* PCは1行インラインだが、“|” は出さない */
@media (min-width:769px) {
    #machineMetaCard .machine-lines {
        display: flex !important;
        flex-wrap: wrap;
        align-items: baseline;
        gap: 0 8px;
    }
    #machineMetaCard .kvline { display: flex; align-items: baseline; gap: 6px; }
    #machineMetaCard .pair   { display: flex; align-items: baseline; gap: 6px; }
    #machineMetaCard .pair + .pair::before,
    #machineMetaCard .kvline + .kvline::before {
        content: "";
        margin: 0;
    }
}

/* Mobile：幅・余白・文字サイズを上カードに合わせる（2行構成） */
@media (max-width:768px) {
    #machineMetaCard {
        padding-inline: 6px;
        font-size: clamp(12.5px, 3.6vw, 15.5px);
        line-height: 1.35;
    }
    #machineMetaCard .machine-lines {
        display: grid !important;
        grid-template-columns: 1fr;
        gap: 8px;
        margin-top: 4px;
    }
    #machineMetaCard .kvline { display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px; }
    #machineMetaCard .pair   { display: flex; align-items: baseline; gap: 4px; }
    #machineMetaCard .pair + .pair::before,
    #machineMetaCard .kvline + .kvline::before {
        content: "";
        margin: 0;
    }

    /* ===== 3枚のKPIカード統一 ===== */
    .summary-wrap {
        max-width: 1280px;
        margin: 0 auto;
        padding-inline: 12px;
        box-sizing: border-box;
    }
    @media (max-width:768px) {
        .summary-wrap { padding-inline: 6px; }
    }
    :root { --kpi-gap: 4px; }
    #summaryData, #filteredSummaryData, #machineMetaCard {
        display: block;
        width: 100%;
        margin: var(--kpi-gap) 0 !important;
        padding: 10px 14px !important;
        box-sizing: border-box;
    }
    #filteredSummaryData, #machineMetaCard {
        max-width: none !important;
        margin-inline: 0 !important;
        padding-inline: 14px !important;
    }
    @media (max-width:768px) {
        #summaryData, #filteredSummaryData, #machineMetaCard {
            margin: var(--kpi-gap) 0 !important;
            padding: 10px 14px !important;
        }
    }
}

/* ==== KPI 3カード統一（PC） ==== */
@media (min-width:769px) {
    .summary-wrap {
        max-width: 1280px;
        margin: 0 auto;
        padding: 0 12px;
        box-sizing: border-box;
    }
    .kpi-card {
        width: 100% !important;
        max-width: 1280px !important;
        margin: 4px 0 !important;
        padding: 10px 14px !important;
        box-sizing: border-box;
    }
    #filteredSummaryData, #machineMetaCard {
        max-width: none !important;
        margin-inline: 0 !important;
        padding-inline: 14px !important;
    }
}
/* ===== モバイル：カード間の余白を 4px に統一 ===== */
@media (max-width: 768px) {

    /* まず、各セクションの外側マージンを殺す（カードの間隔はカード側で管理） */
    .summary-wrap,
    .form-area,
    #g1PieWrapper,
    #g2PieWrapper,
    #g3WaterfallWrapper,
    #g4PriceWrapper,
    #g5BestWorstWrapper,
    section.container-1280 {
        margin-top: 0 !important;
        margin-bottom: 0 !important;
    }

    /* 実際のカード同士の上下だけ 4px にする */
    .card,
    #summaryData,
    #filteredSummaryData,
    #machineMetaCard {
        margin-top: 4px !important;
        margin-bottom: 4px !important;
    }

    /* 2枚並べてるグラフ類の gap 30px を 4px に潰す */
    #g1PieWrapper,
    #g2PieWrapper,
    #g3WaterfallWrapper,
    #g4PriceWrapper,
    #g5BestWorstWrapper {
        gap: 4px !important;
    }

    /* タイトルと最初のカードの間も 4px くらいに */
    h3 {
        margin-bottom: 4px !important;
    }
}
/* ===== モバイル：カード間を完全に 4px に揃える最終調整 ===== */
@media (max-width: 768px) {

    /* カードの上マージンは 0、下だけ 4px にする */
    .card,
    #summaryData,
    #filteredSummaryData,
    #machineMetaCard {
        margin-top: 0 !important;
        margin-bottom: 4px !important;
    }
}

/* ===== モバイル最終調整：縦方向のスキマを全部 4px にそろえる ===== */
@media (max-width: 768px) {

    /* h3 とその下のKPI帯の間も 4px に */
    h3 {
        margin-bottom: 4px !important;
    }

    /* KPI 3カードを含むブロック自体の上下 */
    .summary-wrap {
        margin-top: 0 !important;
        margin-bottom: 4px !important;
    }

        /* KPI 3枚のカード同士の間隔を 4px に */
        .summary-wrap .card,
        #summaryData,
        #filteredSummaryData,
        #machineMetaCard {
            margin-top: 0 !important;
            margin-bottom: 4px !important;
        }

    /* フィルタ（検索＋セレクト）と 1段目グラフの間を 4px に */
    .form-area {
        margin-top: 0 !important;
        margin-bottom: 4px !important;
    }

    /* 各グラフ段（1〜5段目）の上下のスキマを 4px に */
    #g1PieWrapper,
    #g2PieWrapper,
    #g3WaterfallWrapper,
    #g4PriceWrapper,
    #g5BestWorstWrapper,
    section.container-1280 {
        margin-top: 0 !important;
        margin-bottom: 4px !important;
    }

    /* 段の中で横並びになっているカード同士は gap=4px に統一 */
    #g1PieWrapper,
    #g2PieWrapper,
    #g3WaterfallWrapper,
    #g4PriceWrapper,
    #g5BestWorstWrapper {
        gap: 4px !important;
    }

        /* 段の中の .card 自体は縦マージンを 0 にして、二重で空かないようにする */
        #g1PieWrapper .card,
        #g2PieWrapper .card,
        #g3WaterfallWrapper .card,
        #g4PriceWrapper .card,
        #g5BestWorstWrapper .card {
            margin-top: 0 !important;
            margin-bottom: 0 !important;
        }
}

/* ================== 機種タイトル用オブジェ ================== */

/* ベースは既存 h3 を引き継ぎつつ、アイコン＋テキストを横並びに */
h3.machine-title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* タイトルアイコンの外側（筐体アイコンの枠） */
.machine-title-icon {
    width: 1.8em;
    height: 1.8em;
    border-radius: 0.6em;
    padding: 2px;
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    background: radial-gradient(circle at 30% 0, #38bdf8 0, #36d6b5 40%, #0f172a 100%);
    box-shadow: 0 0 0 1px rgba(15, 23, 42, .7), 0 8px 18px rgba(0, 0, 0, .7);
}

.machine-title-icon-svg {
    width: 100%;
    height: 100%;
}

/* SVG パーツの色（d-analysis テーマ寄せ） */
.mt-body {
    fill: #020617; /* 本体 */
}

.mt-reel {
    fill: #e5e7eb; /* リール */
}

.mt-foot {
    fill: #111827; /* 足元 */
}

.mt-lever {
    fill: #fbbf24; /* レバー先端 */
}

.mt-lever-stick {
    fill: #e5e7eb; /* レバー棒 */
}

/* タイトル文字側の微調整（既存 h3 を少し強調） */
.machine-title-text {
    font-weight: 600;
    letter-spacing: 0.03em;
}

/* モバイルではセンター揃え（既存 h3 の text-align と合わせる） */
@media (max-width: 768px) {
    h3.machine-title {
        justify-content: center;
    }
}


/* ================== サマリー3枚用オブジェ ================== */

/* 共通アイコンベース */
.summary-icon {
    width: 1.4em;
    height: 1.4em;
    border-radius: 999px;
    padding: 1.5px;
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    background: radial-gradient(circle at 30% 0, #22c55e 0, #36d6b5 40%, #0f172a 100%);
    box-shadow: 0 0 0 1px rgba(15, 23, 42, .7), 0 6px 14px rgba(0, 0, 0, .65);
}

.summary-icon-svg {
    width: 100%;
    height: 100%;
}

/* ラベル部分をアイコン＋テキスト横並びに */
#summaryData .label.label-summary,
#filteredSummaryData .label-period,
#machineMetaCard .label-machine {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* ラベル内テキストだけを分離して調整したいとき用 */
.label-text {
    display: inline-block;
}

/* --- 全店舗 全期間 Data 用（棒グラフカード） --- */
.summary-icon-global .sg-card {
    fill: #020617;
}

.summary-icon-global .sg-bar {
    fill: var(--accent);
}

.summary-icon-global .sg-bar-1 {
    opacity: 1;
}

.summary-icon-global .sg-bar-2 {
    opacity: .8;
}

.summary-icon-global .sg-bar-3 {
    opacity: .6;
}

/* --- 期間 Data 用（折れ線グラフ） --- */
.summary-icon-period .sp-line {
    fill: none;
    stroke: var(--accent);
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.summary-icon-period .sp-axis {
    stroke: #64748b;
    stroke-width: 1.4;
    stroke-linecap: round;
}

/* --- 機種 Info 用（簡易スロット筐体） --- */
.summary-icon-machine .sm-body {
    fill: #020617;
}

.summary-icon-machine .sm-reel {
    fill: #e5e7eb;
}

.summary-icon-machine .sm-info {
    fill: #36d6b5;
}

/* モバイルではアイコンを少し小さめに */
@media (max-width: 768px) {
    .summary-icon {
        width: 1.3em;
        height: 1.3em;
        padding: 1px;
    }
}
