/* _content/MvpAnalize.Web/Components/Charts/AxisChart.razor.rz.scp.css */
/* T033: AxisChart の外観 (Blazor scoped CSS) — Azure-inspired モダンデザイン。
   各 .axis-chart__bucket に CSS カスタムプロパティ --bar-pct / --bar-color で棒幅と色を渡す。 */

.axis-chart[b-irh9zg9y95] {
    margin: 0;
    padding: 1.25rem 1.5rem 1.375rem;
    background: var(--ds-surface, #fff);
    border: 1px solid var(--ds-border, #D8E0EA);
    border-radius: 12px;
    box-shadow: 0 1px 4px rgba(0,0,0,.05), 0 2px 10px rgba(0,0,0,.04);
    transition: box-shadow .2s, border-color .2s;
}

    .axis-chart:hover[b-irh9zg9y95] {
        box-shadow: 0 4px 20px rgba(15, 108, 189, .09), 0 1px 4px rgba(0,0,0,.06);
        border-color: rgba(15, 108, 189, .25);
    }

.axis-chart__title[b-irh9zg9y95] {
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ds-muted, #64748B);
    margin: 0 0 .875rem 0;
}

.axis-chart__legend[b-irh9zg9y95] {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.axis-chart__legend-item[b-irh9zg9y95] {
    display: block;
}

/* インライン棒グラフ: button の ::before 疑似要素で棒を描く */
.axis-chart__bucket[b-irh9zg9y95] {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    width: 100%;
    background: transparent;
    border: none;
    border-radius: 7px;
    padding: .45rem .55rem;
    cursor: pointer;
    text-align: left;
    font: inherit;
    gap: 0;
    transition: background .13s;
}

    .axis-chart__bucket[b-irh9zg9y95]::before {
        content: '';
        position: absolute;
        left: 0;
        top: 0;
        height: 100%;
        width: var(--bar-pct, 0%);
        background: var(--bar-color, #ccc);
        opacity: .10;
        border-radius: 7px;
        transition: width .4s cubic-bezier(.4,0,.2,1), opacity .18s;
        pointer-events: none;
    }

    .axis-chart__bucket:hover[b-irh9zg9y95] {
        background: var(--ds-primary-soft, #E5F1FB);
    }

    .axis-chart__bucket:hover[b-irh9zg9y95]::before {
        opacity: .20;
    }

    .axis-chart__bucket:focus-visible[b-irh9zg9y95] {
        outline: 2px solid var(--ds-primary, #0F6CBD);
        outline-offset: 1px;
    }

/* 選択状態 */
.axis-chart__bucket--selected[b-irh9zg9y95] {
    background: var(--ds-primary-soft, #E5F1FB);
    box-shadow: inset 2.5px 0 0 var(--ds-primary, #0F6CBD);
}

    .axis-chart__bucket--selected[b-irh9zg9y95]::before {
        opacity: .20;
    }

    .axis-chart__bucket--selected .axis-chart__name[b-irh9zg9y95] {
        color: var(--ds-primary, #0F6CBD);
        font-weight: 600;
    }

    .axis-chart__bucket--selected .axis-chart__count[b-irh9zg9y95] {
        color: var(--ds-primary-dark, #0B4F8A);
    }

/* 無効状態 */
    .axis-chart__bucket--disabled[b-irh9zg9y95] {
        cursor: default;
        opacity: .55;
    }

        .axis-chart__bucket--disabled:hover[b-irh9zg9y95] {
            background: transparent;
        }

        .axis-chart__bucket--disabled[b-irh9zg9y95]::before {
            opacity: .06;
        }

.axis-chart__swatch[b-irh9zg9y95] {
    display: inline-block;
    flex-shrink: 0;
    width: 9px;
    height: 9px;
    border-radius: 3px;
    margin-right: .5rem;
}

.axis-chart__name[b-irh9zg9y95] {
    flex: 1;
    font-size: .82rem;
    color: var(--ds-text, #0F172A);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-right: .5rem;
}

.axis-chart__count[b-irh9zg9y95] {
    font-size: .82rem;
    font-variant-numeric: tabular-nums;
    font-weight: 700;
    color: var(--ds-primary, #0F6CBD);
    flex-shrink: 0;
}

/* スクリーンリーダ向けテーブルは視覚的に非表示 */
.axis-chart__table-wrap[b-irh9zg9y95] {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0,0,0,0);
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
}

.axis-chart__table[b-irh9zg9y95] {
    white-space: normal;
}

.axis-chart__empty[b-irh9zg9y95] {
    color: var(--ds-muted, #64748B);
    font-style: italic;
    font-size: .875rem;
    margin: .5rem 0;
}

/* モバイル対応 (6.1インチ基準: max-width: 390px) */
@media (max-width: 390px) {
    .axis-chart[b-irh9zg9y95] {
        overflow-x: auto;
    }

    .axis-chart__legend[b-irh9zg9y95] {
        min-width: 260px;
    }
}
/* _content/MvpAnalize.Web/Components/Charts/BubbleMapComponent.razor.rz.scp.css */
/* BubbleMapComponent.razor.css
   スコープ付き CSS: バブルマップ専用スタイル */

/* ── セクション ──────────────────────────────────────────────────────────── */
.bubble-map-section[b-x9ucf8x8r6] {
    margin-top: 2rem;
    padding: 1rem 0;
}

.bubble-map-section__title[b-x9ucf8x8r6] {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 0.75rem;
    color: var(--mud-palette-text-primary, #1a1a1a);
}

/* ── SVG ─────────────────────────────────────────────────────────────────── */
.bubble-map__svg[b-x9ucf8x8r6] {
    display: block;
    max-width: 100%;
    width: 100%;
    border: 1px solid var(--mud-palette-divider, #e0e0e0);
    border-radius: 8px;
    background-color: #cce0f0;
    user-select: none; /* ドラッグ中にテキスト選択されないようにする */
}

/* ── SVG コンテナ（相対位置: ズームボタン配置用） ──────────────────────── */
.bubble-map__container[b-x9ucf8x8r6] {
    position: relative;
}

/* ── ズームコントロール ───────────────────────────────────────────────────── */
.bubble-map__zoom-controls[b-x9ucf8x8r6] {
    position: absolute;
    top: 8px;
    right: 12px;
    z-index: 10;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.bubble-map__zoom-btn[b-x9ucf8x8r6] {
    width: 32px;
    height: 32px;
    border: 1px solid rgba(0,0,0,0.2);
    border-radius: 4px;
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(4px);
    font-size: 1.1rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 1px 3px rgba(0,0,0,0.15);
    transition: background-color 0.12s;
    color: #333;
    padding: 0;
}

    .bubble-map__zoom-btn:hover[b-x9ucf8x8r6] {
        background: rgba(255,255,255,1);
        border-color: rgba(0,0,0,0.35);
    }

    .bubble-map__zoom-btn--reset[b-x9ucf8x8r6] {
        font-size: 0.95rem;
        margin-top: 4px;
    }

/* ── 世界地図アウトライン ─────────────────────────────────────────────────── */
.bubble-map__world-outline path[b-x9ucf8x8r6] {
    fill: #e8f4e8;
    stroke: #a0bfa0;
    stroke-width: 0.4;
}

/* ── バブル ──────────────────────────────────────────────────────────────── */
.bubble-map__bubble[b-x9ucf8x8r6] {
    opacity: 0.78;
    cursor: pointer;
    transition: opacity 0.15s ease, r 0.15s ease;
}

.bubble-map__bubble:hover[b-x9ucf8x8r6] {
    opacity: 1.0;
}

/* ── ツールチップ ─────────────────────────────────────────────────────────── */
.bubble-map__tooltip-bg[b-x9ucf8x8r6] {
    fill: rgba(0, 0, 0, 0.82);
}

.bubble-map__tooltip-title[b-x9ucf8x8r6] {
    fill: #ffffff;
    font-size: 13px;
    font-weight: 600;
}

.bubble-map__tooltip-body[b-x9ucf8x8r6] {
    fill: #e0e0e0;
    font-size: 11px;
}

/* ── 凡例 ────────────────────────────────────────────────────────────────── */
.bubble-map__legend[b-x9ucf8x8r6] {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    margin-top: 0.75rem;
    flex-wrap: wrap;
}

.bubble-map__legend-desc[b-x9ucf8x8r6] {
    width: 100%;
    margin: 0 0 0.25rem;
    font-size: 0.8rem;
    color: var(--mud-palette-text-secondary, #555);
}

.bubble-map__legend-color[b-x9ucf8x8r6] {
    display: flex;
    align-items: center;
    gap: 2px;
}

.bubble-map__legend-label[b-x9ucf8x8r6] {
    font-size: 0.75rem;
    color: var(--mud-palette-text-secondary, #666);
    padding: 0 4px;
}

.bubble-map__legend-swatch[b-x9ucf8x8r6] {
    display: inline-block;
    width: 20px;
    height: 14px;
    border-radius: 2px;
}

.bubble-map__legend-size[b-x9ucf8x8r6] {
    display: flex;
    align-items: center;
}

.bubble-map__legend-size-label[b-x9ucf8x8r6] {
    font-size: 10px;
    fill: #555;
}

/* ── モバイル対応 ─────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
    .bubble-map__legend[b-x9ucf8x8r6] {
        flex-direction: column;
        align-items: flex-start;
    }
}
/* _content/MvpAnalize.Web/Components/Charts/FilterChips.razor.rz.scp.css */
/* T053: FilterChips のスコープ CSS — モダンピルデザイン。 */

.filter-chips[b-7ls9cp43go] {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
    min-height: 2rem;
}

/* aria-live 通知専用: 視覚的に非表示 */
.filter-chips__sr-only[b-7ls9cp43go] {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

/* チップ本体 */
.filter-chips__chip[b-7ls9cp43go] {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .3rem .75rem .3rem .65rem;
    background: var(--ds-primary-soft, #E5F1FB);
    border: 1.5px solid rgba(15, 108, 189, .3);
    border-radius: 999px;
    font-size: .8rem;
    font-weight: 600;
    color: var(--ds-primary-dark, #0B4F8A);
    animation: chip-in-b-7ls9cp43go .2s cubic-bezier(.4,0,.2,1);
}

@keyframes chip-in-b-7ls9cp43go {
    from { opacity: 0; transform: scale(.85); }
    to   { opacity: 1; transform: scale(1); }
}

.filter-chips__label[b-7ls9cp43go] {
    line-height: 1;
}

/* ✕ 解除ボタン */
.filter-chips__remove[b-7ls9cp43go] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.1rem;
    height: 1.1rem;
    border: none;
    border-radius: 50%;
    background: rgba(15, 108, 189, .15);
    color: var(--ds-primary, #0F6CBD);
    font-size: .7rem;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    transition: background .15s, color .15s;
}

    .filter-chips__remove:hover[b-7ls9cp43go] {
        background: var(--ds-primary, #0F6CBD);
        color: #fff;
    }

    .filter-chips__remove:focus-visible[b-7ls9cp43go] {
        outline: 2px solid var(--ds-primary, #0F6CBD);
        outline-offset: 2px;
    }

/* 全解除ボタン */
.filter-chips__clear-all[b-7ls9cp43go] {
    padding: .3rem .8rem;
    border: 1.5px solid #e5e7eb;
    border-radius: 999px;
    background: #fff;
    color: #6b7280;
    font-size: .78rem;
    font-weight: 600;
    cursor: pointer;
    transition: border-color .15s, color .15s, background .15s;
}

    .filter-chips__clear-all:hover[b-7ls9cp43go] {
        border-color: #dc2626;
        color: #dc2626;
        background: #fef2f2;
    }

    .filter-chips__clear-all:focus-visible[b-7ls9cp43go] {
        outline: 2px solid #dc2626;
        outline-offset: 2px;
    }

/* ── モバイル対応 (6.1インチ基準: max-width: 390px) ── */
@media (max-width: 390px) {
    .filter-chips__chip[b-7ls9cp43go] {
        min-height: 44px;
    }

    .filter-chips__remove[b-7ls9cp43go] {
        min-width: 44px;
        min-height: 44px;
    }
}
/* _content/MvpAnalize.Web/Components/Charts/HistoryChart.razor.rz.scp.css */
/* HistoryChart コンポーネントスタイル（ApexCharts 版） */

.history-chart[b-og3kpgyzx3] {
    width: 100%;
    background: var(--ds-surface, #fff);
    border: 1px solid var(--ds-border, #D8E0EA);
    border-radius: 12px;
    padding: 1.5rem;
    margin-top: 2rem;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
}

.history-chart :deep(.apexcharts-canvas)[b-og3kpgyzx3] {
    height: 300px !important;
}

.history-chart__title[b-og3kpgyzx3] {
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ds-muted, #64748B);
    margin: 0 0 1rem;
}

/* タブ */
.history-chart__tabs[b-og3kpgyzx3] {
    display: flex;
    gap: 0.25rem;
    margin-bottom: 1rem;
}

.history-chart__tab[b-og3kpgyzx3] {
    padding: 0.25rem 0.75rem;
    border: 1px solid var(--ds-border, #D8E0EA);
    border-radius: 6px;
    background: transparent;
    color: var(--ds-muted, #64748B);
    font-size: 0.8125rem;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

.history-chart__tab:hover:not(:disabled)[b-og3kpgyzx3] {
    background: var(--ds-primary-soft, #E5F1FB);
    color: var(--ds-primary, #0F6CBD);
}

.history-chart__tab--active[b-og3kpgyzx3] {
    background: var(--ds-primary, #0F6CBD);
    color: #fff;
    border-color: var(--ds-primary, #0F6CBD);
}

.history-chart__tab:disabled[b-og3kpgyzx3] {
    opacity: 0.5;
    cursor: not-allowed;
}

/* ローディング・空状態 */
.history-chart__loading[b-og3kpgyzx3],
.history-chart__empty[b-og3kpgyzx3] {
    text-align: center;
    color: #6b7280;
    font-size: 0.875rem;
    padding: 2rem 0;
    margin: 0;
}

/* レスポンシブ */
@media (max-width: 640px) {
    .history-chart[b-og3kpgyzx3] {
        padding: 1rem;
    }
}

/* _content/MvpAnalize.Web/Components/Layout/MainLayout.razor.rz.scp.css */
/* Main content: コンテンツ領域をフッタと分離するための flex 設定 */
.mvp-main[b-c7bo6uyxy2] {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}
/* _content/MvpAnalize.Web/Components/Pages/Dashboard.razor.rz.scp.css */
/* T034: Dashboard.razor 用のスコープ CSS — Azure-inspired executive design. */

.dashboard[b-bgrw6fx90s] {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.dashboard__title[b-bgrw6fx90s] {
    margin: 0 0 .25rem 0;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--ds-text, #0F172A);
    letter-spacing: -.015em;
    border: none;
    background: none;
    padding: 0;
}

/* ── KPI サマリカード ───────────────────────────────────────── */
.dashboard__summary[b-bgrw6fx90s] {
    background: linear-gradient(135deg, #0B4F8A 0%, #0F6CBD 55%, #1E86D4 100%);
    border-radius: 16px;
    padding: 1.75rem 2rem;
    color: #fff;
    box-shadow: 0 4px 24px rgba(15, 108, 189, .28), 0 1px 4px rgba(0,0,0,.08);
    display: flex;
    flex-direction: column;
    gap: .35rem;
    position: relative;
    overflow: hidden;
}

/* 装飾サークル */
.dashboard__summary[b-bgrw6fx90s]::before {
    content: '';
    position: absolute;
    top: -50px;
    right: -50px;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .06);
    pointer-events: none;
}

.dashboard__summary[b-bgrw6fx90s]::after {
    content: '';
    position: absolute;
    bottom: -70px;
    right: 80px;
    width: 240px;
    height: 240px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .04);
    pointer-events: none;
}

.dashboard__metric-label[b-bgrw6fx90s] {
    margin: 0;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .09em;
    text-transform: uppercase;
    opacity: .75;
}

.dashboard__metric-value[b-bgrw6fx90s] {
    margin: 0;
    font-size: 3.5rem;
    font-weight: 800;
    line-height: 1;
    font-variant-numeric: tabular-nums;
    letter-spacing: -.025em;
}

.dashboard__updated[b-bgrw6fx90s] {
    margin: .4rem 0 0 0;
    font-size: .78rem;
    opacity: .7;
}

/* ── 注記バー ──────────────────────────────────────────────── */
.dashboard__note[b-bgrw6fx90s] {
    margin: 0;
    padding: .65rem 1rem;
    background: var(--ds-surface, #fff);
    border-left: 3px solid var(--ds-primary, #0F6CBD);
    border-radius: 0 8px 8px 0;
    font-size: .82rem;
    color: var(--ds-muted, #64748B);
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
}

/* 注記 + 地域別リンクのグループ */
.dashboard__info-group[b-bgrw6fx90s] {
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

/* 地域別ダッシュボードへの誘導リンク */
.dashboard__geo-link[b-bgrw6fx90s] {
    margin: 0;
    padding: .55rem .9rem;
    background: var(--ds-surface, #fff);
    border-left: 3px solid var(--ds-green, #16A34A);
    border-radius: 0 8px 8px 0;
    font-size: .875rem;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
}

.dashboard__geo-link__anchor[b-bgrw6fx90s] {
    color: var(--ds-green, #16A34A);
    text-decoration: none;
    font-weight: 600;
}

.dashboard__geo-link__anchor:hover[b-bgrw6fx90s] {
    text-decoration: underline;
}

/* ── 3 列グリッド ──────────────────────────────────────────── */
.dashboard__charts[b-bgrw6fx90s] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.25rem;
    align-items: start;
}

/* HistoryChart wrapper */
.dashboard__history-wrapper[b-bgrw6fx90s] {
    margin-top: .25rem;
}

/* ── ステータスカード ────────────────────────────────────────── */
.dashboard__notice[b-bgrw6fx90s] {
    background: var(--ds-surface, #fff);
    border-left: 4px solid var(--ds-primary, #0F6CBD);
    padding: 1.25rem 1.5rem;
    border-radius: 0 12px 12px 0;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
}

.dashboard__notice--error[b-bgrw6fx90s] {
    border-left-color: var(--ds-red, #DC2626);
}

.dashboard__loading[b-bgrw6fx90s] {
    color: var(--ds-muted, #64748B);
    font-style: italic;
    font-size: .9rem;
}

/* ── モバイル対応 ── */
@media (max-width: 390px) {
    .dashboard__charts[b-bgrw6fx90s] {
        grid-template-columns: 1fr;
    }

    .dashboard__metric-value[b-bgrw6fx90s] {
        font-size: 2.5rem;
    }

    .dashboard__summary[b-bgrw6fx90s] {
        padding: 1.25rem 1.5rem;
    }
}
/* _content/MvpAnalize.Web/Components/Pages/GeoDistributionDashboard.razor.rz.scp.css */
/* 003: GeoDistributionDashboard.razor 用スコープ CSS — Azure-inspired design */

/* ── 全体レイアウト ─────────────────────────────────────────── */
.geo-dash[b-a8l1ndumpv] {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

/* ── タイトルエリア ──────────────────────────────────────────── */
.geo-dash__header[b-a8l1ndumpv] {
    display: flex;
    align-items: center;
    gap: .6rem;
}

.geo-dash__header-icon[b-a8l1ndumpv] {
    font-size: 1.75rem;
    line-height: 1;
}

.geo-dash__title[b-a8l1ndumpv] {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--ds-text, #0F172A);
    letter-spacing: -.015em;
}

/* ── サマリーカード ───────────────────────────────────────────── */
.geo-dash__summary[b-a8l1ndumpv] {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.geo-dash__kpi[b-a8l1ndumpv] {
    flex: 1 1 160px;
    background: var(--ds-surface, #fff);
    border: 1px solid var(--ds-border, #D8E0EA);
    border-radius: 14px;
    padding: 1.25rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: .3rem;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    position: relative;
    overflow: hidden;
}

/* カラーアクセントバー（上端） */
.geo-dash__kpi[b-a8l1ndumpv]::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--ds-primary-dark, #0B4F8A), var(--ds-primary, #0F6CBD));
    border-radius: 14px 14px 0 0;
}

.geo-dash__kpi-label[b-a8l1ndumpv] {
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--ds-muted, #64748B);
    margin-top: .2rem;
}

.geo-dash__kpi-value[b-a8l1ndumpv] {
    font-size: 2.2rem;
    font-weight: 800;
    line-height: 1;
    font-variant-numeric: tabular-nums;
    color: var(--ds-text, #0F172A);
    letter-spacing: -.02em;
}

/* ── メインコンテンツグリッド ─────────────────────────────────── */
.geo-dash__grid[b-a8l1ndumpv] {
    display: grid;
    grid-template-columns: minmax(280px, 2fr) minmax(220px, 1.5fr) minmax(200px, 1fr);
    gap: 1.25rem;
    align-items: start;
}

/* ── セクション共通 ───────────────────────────────────────────── */
.geo-dash__section[b-a8l1ndumpv] {
    background: var(--ds-surface, #fff);
    border: 1px solid var(--ds-border, #D8E0EA);
    border-radius: 12px;
    padding: 1.25rem 1.4rem;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
}

.geo-dash__section-title[b-a8l1ndumpv] {
    margin: 0 0 .9rem 0;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ds-muted, #64748B);
    border-bottom: 1px solid var(--ds-border, #D8E0EA);
    padding-bottom: .5rem;
}

.geo-dash__section-title--sub[b-a8l1ndumpv] {
    margin-top: 1.25rem;
}

.geo-dash__section-header[b-a8l1ndumpv] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: .9rem;
    border-bottom: 1px solid var(--ds-border, #D8E0EA);
    padding-bottom: .5rem;
}

    .geo-dash__section-header .geo-dash__section-title[b-a8l1ndumpv] {
        margin-bottom: 0;
        border-bottom: none;
        padding-bottom: 0;
    }

.geo-dash__map-link[b-a8l1ndumpv] {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-size: .75rem;
    font-weight: 600;
    color: var(--mud-palette-primary, #0078d4);
    text-decoration: none;
    padding: .25rem .625rem;
    border: 1px solid var(--mud-palette-primary, #0078d4);
    border-radius: 4px;
    white-space: nowrap;
    transition: background-color .15s, color .15s;
}

    .geo-dash__map-link:hover[b-a8l1ndumpv] {
        background-color: var(--mud-palette-primary, #0078d4);
        color: #fff;
        text-decoration: none;
    }

/* ── テーブル共通 ─────────────────────────────────────────────── */
.geo-dash__table[b-a8l1ndumpv] {
    border-collapse: collapse;
    width: 100%;
    font-size: .845rem;
}

.geo-dash__th[b-a8l1ndumpv] {
    background: var(--ds-primary-dark, #0B4F8A);
    color: #fff;
    padding: .5rem .65rem;
    text-align: left;
    font-weight: 600;
    font-size: .78rem;
    letter-spacing: .02em;
    white-space: nowrap;
}

.geo-dash__th--rank[b-a8l1ndumpv],
.geo-dash__th--num[b-a8l1ndumpv] {
    text-align: right;
}

.geo-dash__th--bar[b-a8l1ndumpv] {
    width: 100px;
}

.geo-dash__tr--alt td[b-a8l1ndumpv],
.geo-dash__tr--alt th[b-a8l1ndumpv] {
    background: #F8FAFD;
}

.geo-dash__tr-total td[b-a8l1ndumpv],
.geo-dash__tr-total th[b-a8l1ndumpv] {
    background: var(--ds-primary-soft, #E5F1FB);
    font-weight: 700;
    color: var(--ds-primary-dark, #0B4F8A);
}

.geo-dash__td[b-a8l1ndumpv] {
    padding: .42rem .65rem;
    border-bottom: 1px solid var(--ds-border, #D8E0EA);
    vertical-align: middle;
    color: var(--ds-text, #0F172A);
}

.geo-dash__td--rank[b-a8l1ndumpv] {
    text-align: right;
    width: 3rem;
    color: var(--ds-muted, #64748B);
    font-variant-numeric: tabular-nums;
}

.geo-dash__td--num[b-a8l1ndumpv] {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.geo-dash__td--bar[b-a8l1ndumpv] {
    padding: .3rem .65rem;
}

.geo-dash__medal[b-a8l1ndumpv] {
    font-size: 1.1rem;
}

/* データバー */
.geo-dash__bar-wrap[b-a8l1ndumpv] {
    background: var(--ds-border, #D8E0EA);
    border-radius: 4px;
    height: 12px;
    overflow: hidden;
}

.geo-dash__bar[b-a8l1ndumpv] {
    height: 100%;
    background: linear-gradient(90deg, var(--ds-primary, #0F6CBD), #3B82F6);
    border-radius: 4px;
    transition: width .3s ease;
    min-width: 2px;
}

.geo-dash__bar--company[b-a8l1ndumpv] {
    background: linear-gradient(90deg, var(--ds-green, #16A34A), #22C55E);
}

.geo-dash__bar--gender[b-a8l1ndumpv] {
    background: linear-gradient(90deg, var(--ds-purple, #7C3AED), #A855F7);
}

/* 地域ドット */
.geo-dash__region-dot[b-a8l1ndumpv] {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    margin-right: .35rem;
    vertical-align: middle;
}

/* ── 円グラフ ─────────────────────────────────────────────────── */
.geo-dash__pie-figure[b-a8l1ndumpv] {
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .75rem;
}

.geo-dash__pie[b-a8l1ndumpv] {
    width: 100%;
    max-width: 220px;
}

.geo-dash__pie-label[b-a8l1ndumpv] {
    font-size: 11px;
    font-weight: 700;
    fill: #fff;
}

.geo-dash__pie-legend[b-a8l1ndumpv] {
    display: flex;
    flex-direction: column;
    gap: .3rem;
    width: 100%;
    font-size: .8rem;
}

.geo-dash__pie-legend-item[b-a8l1ndumpv] {
    display: flex;
    align-items: center;
    gap: .4rem;
}

.geo-dash__pie-legend-dot[b-a8l1ndumpv] {
    display: inline-block;
    width: 11px;
    height: 11px;
    border-radius: 3px;
    flex-shrink: 0;
}

/* ── キーインサイト ───────────────────────────────────────────── */
.geo-dash__insight-box[b-a8l1ndumpv] {
    background: #FEFCE8;
    border: 1px solid #FDE68A;
    border-radius: 10px;
    padding: 1rem 1.2rem;
}

.geo-dash__insight-list[b-a8l1ndumpv] {
    margin: 0;
    padding: 0 0 0 1.1em;
    list-style: disc;
}

.geo-dash__insight-item[b-a8l1ndumpv] {
    padding: .25rem 0;
    font-size: .87rem;
    color: var(--ds-text, #0F172A);
    line-height: 1.55;
}

/* ── 下段レイアウト ───────────────────────────────────────────── */
.geo-dash__bottom[b-a8l1ndumpv] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
    align-items: start;
}

/* スクロールテーブル */
.geo-dash__scroll-table[b-a8l1ndumpv] {
    max-height: 400px;
    overflow-y: auto;
    border-radius: 0 0 8px 8px;
}

.geo-dash__table--full thead th[b-a8l1ndumpv] {
    position: sticky;
    top: 0;
    z-index: 1;
}

/* ── ConcentrationChart ─────────────────────────────────────── */
.concentration-chart[b-a8l1ndumpv] {
    width: 100%;
}

.concentration-chart__caption[b-a8l1ndumpv] {
    font-size: .72rem;
    color: var(--ds-muted, #64748B);
    margin-top: .4rem;
    text-align: center;
}

/* ── ステータス / ローディング ────────────────────────────────── */
.geo-dash__loading[b-a8l1ndumpv] {
    color: var(--ds-muted, #64748B);
    font-style: italic;
    font-size: .9rem;
}

.geo-dash__insight-fallback[b-a8l1ndumpv] {
    color: var(--ds-muted, #64748B);
    font-size: .87rem;
    font-style: italic;
}

/* ── レスポンシブ ─────────────────────────────────────────────── */
@media (max-width: 900px) {
    .geo-dash__grid[b-a8l1ndumpv] {
        grid-template-columns: 1fr 1fr;
    }

    .geo-dash__insights[b-a8l1ndumpv] {
        grid-column: 1 / -1;
    }
}

@media (max-width: 600px) {
    .geo-dash__grid[b-a8l1ndumpv] {
        grid-template-columns: 1fr;
    }

    .geo-dash__bottom[b-a8l1ndumpv] {
        grid-template-columns: 1fr;
    }

    .geo-dash__kpi-value[b-a8l1ndumpv] {
        font-size: 1.9rem;
    }
}

/* ── 会社別ドリルダウン ───────────────────────────────── */
.geo-dash__hint[b-a8l1ndumpv] {
    font-size: .78rem;
    color: var(--ds-muted, #64748B);
    margin: -.4rem 0 .6rem;
    font-style: italic;
}

.geo-dash__drill-icon[b-a8l1ndumpv] {
    font-size: .7rem;
    color: var(--ds-muted, #64748B);
    vertical-align: middle;
}

.geo-dash__tr--selected td[b-a8l1ndumpv] {
    background: var(--ds-primary-soft, #E5F1FB) !important;
    font-weight: 600;
}

.geo-dash__drill-panel[b-a8l1ndumpv] {
    margin-top: .75rem;
    border: 1px solid var(--ds-primary, #0F6CBD);
    border-radius: 10px;
    padding: 1rem 1.2rem;
    background: var(--ds-primary-soft, #E5F1FB);
    animation: drill-in-b-a8l1ndumpv .2s ease;
}

@keyframes drill-in-b-a8l1ndumpv {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.geo-dash__drill-header[b-a8l1ndumpv] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-weight: 700;
    font-size: .88rem;
    color: var(--ds-primary-dark, #0B4F8A);
    margin-bottom: .75rem;
}

.geo-dash__drill-close[b-a8l1ndumpv] {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    color: var(--ds-muted, #64748B);
    padding: 0 .25rem;
    line-height: 1;
}

.geo-dash__drill-close:hover[b-a8l1ndumpv] {
    color: var(--ds-text, #0F172A);
}

.geo-dash__drill-table[b-a8l1ndumpv] {
    margin-top: .6rem;
}

/* 010: バブルマップセクション用スペーシング */
.geo-dash__all-countries[b-a8l1ndumpv] +  .bubble-map-section {
    margin-top: 2rem;
}

/* _content/MvpAnalize.Web/Components/Pages/GeoMap.razor.rz.scp.css */
.geo-map-page[b-38jdxtjq4s] {
    display: flex;
    flex-direction: column;
    padding: 0 1rem 1rem;
    box-sizing: border-box;
}

.geo-map-page__header[b-38jdxtjq4s] {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem 0;
    flex-shrink: 0;
    flex-wrap: wrap;
}

.geo-map-page__back[b-38jdxtjq4s] {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    color: var(--mud-palette-primary);
    text-decoration: none;
    font-size: 0.875rem;
    white-space: nowrap;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    transition: background-color 0.15s;
}

    .geo-map-page__back:hover[b-38jdxtjq4s] {
        background-color: rgba(0, 120, 212, 0.08);
        text-decoration: none;
    }

.geo-map-page__title[b-38jdxtjq4s] {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 600;
    flex: 1;
}

.geo-map-page__meta[b-38jdxtjq4s] {
    font-size: 0.8125rem;
    color: var(--mud-palette-text-secondary);
    white-space: nowrap;
}

.geo-map-page__loading[b-38jdxtjq4s] {
    display: flex;
    justify-content: center;
    align-items: center;
    flex: 1;
}

.geo-map-page__map-wrap[b-38jdxtjq4s] {
    display: flex;
    flex-direction: column;
}

    /* BubbleMapComponent 内のタイトル（ページ h1 と重複するため非表示） */
    .geo-map-page__map-wrap[b-38jdxtjq4s]  .bubble-map-section__title {
        display: none;
    }

    /* Leaflet マップ: フッター・ヘッダー・凡例分を差し引いた高さ */
    .geo-map-page__map-wrap[b-38jdxtjq4s]  .bubble-map__leaflet {
        width: 100%;
        height: clamp(360px, calc(100vh - 250px), 820px);
    }
/* _content/MvpAnalize.Web/Components/Pages/MvpList.razor.rz.scp.css */
/* MVP 一覧ページ — モダンプロフェッショナルデザイン */

.mvp-list[b-dvpl1sktu3] {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

/* ヘッダ */
.mvp-list__header[b-dvpl1sktu3] {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .5rem;
}

.mvp-list__title[b-dvpl1sktu3] {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--ds-text, #0F172A);
    letter-spacing: -.015em;
}

.mvp-list__back-link[b-dvpl1sktu3] {
    font-size: .875rem;
    color: var(--ds-primary, #0F6CBD);
    text-decoration: none;
    font-weight: 500;
}

.mvp-list__back-link:hover[b-dvpl1sktu3] {
    text-decoration: underline;
}

/* フィルタ領域 */
.mvp-list__filters[b-dvpl1sktu3] {
    background: var(--ds-surface, #fff);
    border: 1px solid var(--ds-border, #D8E0EA);
    border-radius: 12px;
    padding: 1rem 1.25rem;
    display: flex;
    flex-direction: column;
    gap: .75rem;
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

.mvp-list__search-wrap[b-dvpl1sktu3] {
    position: relative;
}

.mvp-list__search[b-dvpl1sktu3] {
    width: 100%;
    box-sizing: border-box;
    padding: .6rem 1rem .6rem 2.5rem;
    border: 1.5px solid #cbd5e1;
    border-radius: 8px;
    font-size: .9375rem;
    background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") .75rem center / 1rem no-repeat;
    transition: border-color .15s, box-shadow .15s;
}

.mvp-list__search:focus[b-dvpl1sktu3] {
    outline: none;
    border-color: var(--ds-primary, #0F6CBD);
    box-shadow: 0 0 0 3px rgba(15, 108, 189, .15);
}

.mvp-list__filter-row[b-dvpl1sktu3] {
    display: flex;
    flex-wrap: wrap;
    gap: .625rem;
    align-items: center;
}

.mvp-list__select[b-dvpl1sktu3] {
    padding: .5rem .875rem;
    border: 1.5px solid #cbd5e1;
    border-radius: 8px;
    font-size: .875rem;
    background: #fff;
    color: #374151;
    cursor: pointer;
    transition: border-color .15s;
    flex: 1 1 160px;
    max-width: 260px;
}

.mvp-list__select:focus[b-dvpl1sktu3] {
    outline: none;
    border-color: var(--ds-primary, #0F6CBD);
    box-shadow: 0 0 0 3px rgba(15, 108, 189, .15);
}

.mvp-list__clear-btn[b-dvpl1sktu3] {
    padding: .5rem .875rem;
    border: 1.5px solid #e2e8f0;
    border-radius: 8px;
    background: #fff;
    color: #6b7280;
    font-size: .875rem;
    cursor: pointer;
    transition: background .15s, color .15s;
    white-space: nowrap;
}

.mvp-list__clear-btn:hover[b-dvpl1sktu3] {
    background: #f1f5f9;
    color: #374151;
}

/* サマリ */
.mvp-list__summary[b-dvpl1sktu3] {
    font-size: .875rem;
    color: #6b7280;
}

.mvp-list__count[b-dvpl1sktu3] {
    font-weight: 600;
    color: #374151;
}

/* ステータス */
.mvp-list__status[b-dvpl1sktu3] {
    text-align: center;
    padding: 2rem;
    color: #6b7280;
    font-size: .9375rem;
}

.mvp-list__status--error[b-dvpl1sktu3] {
    color: #dc2626;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 8px;
    padding: 1rem;
    text-align: left;
}

/* カードグリッド */
.mvp-list__grid[b-dvpl1sktu3] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1rem;
}

/* MVP カード */
.mvp-card[b-dvpl1sktu3] {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1.25rem 1rem 1rem;
    background: #fff;
    border: 1.5px solid #e5e7eb;
    border-radius: 14px;
    text-decoration: none;
    color: inherit;
    transition: transform .15s, box-shadow .15s, border-color .15s;
    cursor: pointer;
    gap: .75rem;
}

.mvp-card:hover[b-dvpl1sktu3] {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0,0,0,.1);
    border-color: var(--ds-primary, #0F6CBD);
}

/* アバター */
.mvp-card__avatar-wrap[b-dvpl1sktu3] {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    background: #dbeafe;
}

.mvp-card__avatar[b-dvpl1sktu3] {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mvp-card__avatar-fallback[b-dvpl1sktu3] {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--ds-primary, #0F6CBD) 0%, var(--ds-primary-dark, #0B4F8A) 100%);
    color: #fff;
    font-size: 1.25rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: .02em;
    flex-shrink: 0;
}

/* カード本文 */
.mvp-card__body[b-dvpl1sktu3] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .25rem;
    width: 100%;
    text-align: center;
}

.mvp-card__name[b-dvpl1sktu3] {
    margin: 0;
    font-size: .9375rem;
    font-weight: 600;
    color: #111827;
    line-height: 1.3;
    word-break: break-word;
}

.mvp-card__country[b-dvpl1sktu3] {
    margin: 0;
    font-size: .8125rem;
    color: #6b7280;
}

.mvp-card__years[b-dvpl1sktu3] {
    margin: 0;
    font-size: .75rem;
    color: #0078d4;
    font-weight: 600;
}

.mvp-card__tags[b-dvpl1sktu3] {
    display: flex;
    flex-wrap: wrap;
    gap: .25rem;
    justify-content: center;
}

.mvp-card__tag[b-dvpl1sktu3] {
    font-size: .6875rem;
    font-weight: 600;
    padding: .1875rem .5rem;
    border-radius: 99px;
    white-space: nowrap;
}

.mvp-card__tag--category[b-dvpl1sktu3] {
    background: #eff6ff;
    color: #1d4ed8;
    border: 1px solid #bfdbfe;
    white-space: normal;
    word-break: break-word;
    font-size: .625rem;
    text-align: center;
    line-height: 1.4;
}

/* ページネーション */
.mvp-pager[b-dvpl1sktu3] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .25rem;
    padding: .75rem 0;
    flex-wrap: wrap;
}

.mvp-pager__nav[b-dvpl1sktu3] {
    display: inline-flex;
    align-items: center;
    gap: .375rem;
    padding: .4375rem .875rem;
    border: 1.5px solid #e2e8f0;
    border-radius: 9999px;
    background: #fff;
    color: #374151;
    font-size: .8125rem;
    font-weight: 500;
    cursor: pointer;
    transition: background .15s, border-color .15s, color .15s, box-shadow .15s;
    white-space: nowrap;
    line-height: 1;
}

.mvp-pager__nav:hover:not(:disabled)[b-dvpl1sktu3] {
    background: #f0f9ff;
    border-color: #0078d4;
    color: #0078d4;
    box-shadow: 0 2px 8px rgba(0,120,212,.12);
}

.mvp-pager__nav:disabled[b-dvpl1sktu3] {
    opacity: .35;
    cursor: not-allowed;
}

.mvp-pager__page[b-dvpl1sktu3] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.125rem;
    height: 2.125rem;
    border: 1.5px solid transparent;
    border-radius: 8px;
    background: transparent;
    color: #374151;
    font-size: .875rem;
    font-weight: 500;
    cursor: pointer;
    transition: background .15s, border-color .15s, color .15s;
    padding: 0;
    line-height: 1;
}

.mvp-pager__page:hover:not(.mvp-pager__page--active)[b-dvpl1sktu3] {
    background: #f1f5f9;
    border-color: #e2e8f0;
    color: #0078d4;
}

.mvp-pager__page--active[b-dvpl1sktu3] {
    background: var(--ds-primary, #0F6CBD);
    border-color: var(--ds-primary, #0F6CBD);
    color: #fff;
    font-weight: 700;
    box-shadow: 0 2px 8px rgba(15, 108, 189, .28);
    cursor: default;
}

.mvp-pager__ellipsis[b-dvpl1sktu3] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.125rem;
    height: 2.125rem;
    color: #9ca3af;
    font-size: .875rem;
    user-select: none;
    pointer-events: none;
}

/* ── モバイル対応 (6.1インチ基準: max-width: 390px) ── */
@media (max-width: 390px) {
    .mvp-list__grid[b-dvpl1sktu3] {
        grid-template-columns: 1fr;
    }

    .mvp-list__filter-row[b-dvpl1sktu3] {
        flex-direction: column;
        align-items: stretch;
    }

    .mvp-list__select[b-dvpl1sktu3] {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }

    .mvp-pager__page:not(.mvp-pager__page--active)[b-dvpl1sktu3],
    .mvp-pager__ellipsis[b-dvpl1sktu3] {
        display: none;
    }
}
