/**
 * gazlog Hub — 追加スタイル
 *
 * 基本デザインは pcparts-charts.css / group-charts.css を継承。
 * ここには gazlog 固有の追加スタイルのみ記述。
 *
 * @since 3.0.0
 */

/* ================================================================
   共通カードコンテナ — 非グラフ系ショートコードの横幅統一
   デスクトップ: 記事幅の70%, スマホ: 100%
   ================================================================ */

.gazlog-card-container {
    width: 100%;
    max-width: var(--gazlog-card-max-width, 70%);
    margin-left: 0;
    margin-right: auto;
    margin-bottom: var(--gazlog-gap-lg, 16px);
}

@media (max-width: 768px) {
    .gazlog-card-container {
        max-width: 100%;
    }
}

/* ランキングテーブル（用途別スコア・購入アドバイザー用） */
.gazlog-ranking-table {
    width: 100%;
    border-collapse: collapse;
    font-family: var(--gazlog-font-family, sans-serif);
    font-size: 13px;
    margin-top: 16px;
}

.gazlog-ranking-table thead th {
    background: #f8fafc;
    color: #6b7280;
    font-weight: 600;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .3px;
    padding: 8px 10px;
    border-bottom: 2px solid #e2e8f0;
    text-align: left;
}

.gazlog-ranking-table tbody tr {
    border-bottom: 1px solid #f1f5f9;
    transition: background .15s;
}

.gazlog-ranking-table tbody tr:hover {
    background: #f8fafc;
}

.gazlog-ranking-table td {
    padding: 8px 10px;
    vertical-align: middle;
}

/* 1-3位の強調 */
.gazlog-ranking-table tbody tr:nth-child(1) td:first-child { color: #f59e0b; font-weight: 700; font-size: 1.1em; }
.gazlog-ranking-table tbody tr:nth-child(2) td:first-child { color: #94a3b8; font-weight: 700; }
.gazlog-ranking-table tbody tr:nth-child(3) td:first-child { color: #b45309; font-weight: 700; }

/* レスポンシブ */
@media (max-width: 768px) {
    .gazlog-ranking-table { font-size: 12px; }
    .gazlog-ranking-table td,
    .gazlog-ranking-table th { padding: 6px 6px; }
}

@media (max-width: 480px) {
    .gazlog-ranking-table { font-size: 11px; }
}

/* ================================================================
   [gazlog_used_price] — 中古・買取価格チャート
   ================================================================ */

.gazlog-used-price-wrap {
    font-family: var(--gazlog-font-family, sans-serif);
}

/* タブボタン */
.gazlog-up-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin: 10px 0 0;
    border-bottom: 2px solid #e2e8f0;
    padding-bottom: 0;
}

.gazlog-up-tab-btn {
    padding: 7px 16px;
    font-size: 13px;
    font-weight: 600;
    font-family: inherit;
    color: #6b7280;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    cursor: pointer;
    border-radius: 4px 4px 0 0;
    transition: color .15s, border-color .15s, background .15s;
}

.gazlog-up-tab-btn:hover {
    color: #374151;
    background: #f1f5f9;
}

.gazlog-up-tab-btn.active {
    color: #1a56db;
    border-bottom-color: #1a56db;
    background: transparent;
}

/* パネル */
.gazlog-up-panel {
    padding-top: 10px;
}

/* メトリクス選択行 */
.gazlog-up-metric-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
    font-size: 13px;
}

.gazlog-up-metric-label {
    color: #6b7280;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .3px;
}

.gazlog-up-metric-check {
    display: flex;
    align-items: center;
    gap: 4px;
    color: #374151;
    cursor: pointer;
    user-select: none;
}

.gazlog-up-metric-check input[type="checkbox"] {
    accent-color: #1a56db;
    width: 14px;
    height: 14px;
    cursor: pointer;
}

/* サマリーテーブル */
.gazlog-up-summary {
    margin-top: 14px;
    overflow-x: auto;
}

.gazlog-up-summary-table {
    width: 100%;
    border-collapse: collapse;
    font-family: var(--gazlog-font-family, sans-serif);
    font-size: 13px;
}

.gazlog-up-summary-table thead th {
    background: #f8fafc;
    color: #6b7280;
    font-weight: 600;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .3px;
    padding: 7px 10px;
    border-bottom: 2px solid #e2e8f0;
    text-align: left;
    white-space: nowrap;
}

.gazlog-up-summary-table tbody tr {
    border-bottom: 1px solid #f1f5f9;
    transition: background .12s;
}

.gazlog-up-summary-table tbody tr:hover {
    background: #f8fafc;
}

.gazlog-up-summary-table td {
    padding: 7px 10px;
    vertical-align: middle;
    white-space: nowrap;
}

.gazlog-up-summary-all td {
    font-weight: 600;
    background: #fafbff;
}

.gazlog-up-summary-table tfoot td {
    padding: 4px 10px;
}

/* レスポンシブ */
@media (max-width: 768px) {
    .gazlog-up-tab-btn    { padding: 6px 12px; font-size: 12px; }
    .gazlog-up-metric-row { gap: 8px; font-size: 12px; }
    .gazlog-up-summary-table { font-size: 12px; }
    .gazlog-up-summary-table td,
    .gazlog-up-summary-table th { padding: 5px 6px; }
}

@media (max-width: 480px) {
    .gazlog-up-tab-btn    { padding: 5px 10px; font-size: 11px; }
    .gazlog-up-summary-table { font-size: 11px; }
}

/* ================================================================
   [gazlog_price_summary] — 複数ソース現在価格比較カード
   ================================================================ */

.gazlog-price-summary {
    font-family: var(--gazlog-font-family, sans-serif);
}

.gazlog-ps-header {
    padding: 14px 18px 10px;
    border-bottom: 1px solid var(--gazlog-bg-light, #f9fafb);
}

.gazlog-ps-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--gazlog-text, #333);
}

.gazlog-ps-subtitle {
    font-size: 11px;
    color: var(--gazlog-text-muted, #9ca3af);
}

.gazlog-ps-diff-up {
    color: var(--gazlog-error, #c62828);
    font-weight: 600;
}

.gazlog-ps-diff-down {
    color: var(--gazlog-success, #2e7d32);
    font-weight: 600;
}

.gazlog-ps-body {
    padding: 4px 0;
}

.gazlog-ps-row {
    display: flex;
    align-items: center;
    padding: 10px 18px;
}

.gazlog-ps-row + .gazlog-ps-row {
    border-top: 1px solid var(--gazlog-bg-light, #f9fafb);
}

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

.gazlog-ps-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--gazlog-text, #333);
}

.gazlog-ps-sub {
    font-size: 11px;
    color: var(--gazlog-text-muted, #9ca3af);
}

.gazlog-ps-price-col {
    text-align: right;
}

.gazlog-ps-price {
    font-size: 18px;
    font-weight: 700;
}

.gazlog-ps-change-up {
    font-size: 11px;
    color: var(--gazlog-error, #c62828);
    margin-left: 6px;
}

.gazlog-ps-change-down {
    font-size: 11px;
    color: var(--gazlog-success, #2e7d32);
    margin-left: 6px;
}

.gazlog-ps-date {
    font-size: 10px;
    color: var(--gazlog-text-muted, #9ca3af);
}

.gazlog-ps-icon {
    font-size: 14px;
    margin-right: 6px;
}

.gazlog-ps-icon-sm {
    font-size: 13px;
    margin-right: 6px;
}

.gazlog-ps-level-low {
    display: inline-block;
    font-size: 10px;
    background: var(--gazlog-success-bg, #e8f5e9);
    color: var(--gazlog-success, #2e7d32);
    padding: 1px 6px;
    border-radius: var(--gazlog-radius-sm, 4px);
    margin-left: 4px;
}

.gazlog-ps-level-high {
    display: inline-block;
    font-size: 10px;
    background: var(--gazlog-error-bg, #fce4ec);
    color: var(--gazlog-error, #c62828);
    padding: 1px 6px;
    border-radius: var(--gazlog-radius-sm, 4px);
    margin-left: 4px;
}

/* レスポンシブ */
@media (max-width: 480px) {
    .gazlog-ps-header { padding: 12px 14px 8px; }
    .gazlog-ps-row    { padding: 8px 14px; }
    .gazlog-ps-price  { font-size: 16px; }
    .gazlog-ps-title  { font-size: 15px; }
}

/* ================================================================
   [gazlog_current_price format="card"] — 単一価格カード
   ================================================================ */

.gazlog-cp-card {
    display: inline-block;
    border: 1px solid var(--gazlog-border, #e5e7eb);
    border-left-width: 4px;
    border-radius: var(--gazlog-radius-md, 8px);
    padding: 12px 18px;
    background: var(--gazlog-bg, #fff);
    font-family: var(--gazlog-font-family, sans-serif);
    min-width: 160px;
}

.gazlog-cp-card-label {
    font-size: 12px;
    color: var(--gazlog-text-secondary, #6b7280);
    margin-bottom: 4px;
}

.gazlog-cp-card-price {
    font-size: 24px;
    font-weight: 700;
    color: var(--gazlog-text, #333);
}

.gazlog-cp-card-date {
    font-size: 11px;
    color: var(--gazlog-text-muted, #9ca3af);
    margin-top: 2px;
}

/* [gazlog_current_price format="badge"] */
.gazlog-cp-badge {
    display: inline-block;
    color: #fff;
    padding: 4px 10px;
    border-radius: var(--gazlog-radius-sm, 4px);
    font-size: 13px;
    font-weight: 600;
    font-family: var(--gazlog-font-family, sans-serif);
}

/* [gazlog_stock] バッジ */
.gazlog-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: var(--gazlog-radius-sm, 4px);
    font-size: 12px;
    font-weight: 600;
    font-family: var(--gazlog-font-family, sans-serif);
}

/* ===== モバイル外部ツールチップ (gazlog-hub.css でも定義: 両ファイルが独立ロードされる場合の保険) ===== */
.gazlog-mobile-tooltip {
    display: none;
    margin-top: 6px;
    padding: 8px 12px 10px;
    background: rgba(33, 47, 153, 0.95);
    border-radius: 4px;
    color: #fff;
    font-size: 11px;
    line-height: 1.6;
    font-family: 'Yu Gothic', 'Meiryo', sans-serif;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.gazlog-mtt-date {
    font-weight: 600;
    font-size: 12px;
    padding-bottom: 4px;
    margin-bottom: 4px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

.gazlog-mtt-row {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 2px 0;
}

.gazlog-mtt-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.gazlog-mtt-text {
    color: rgba(255, 255, 255, 0.9);
}

/* ============================================================
   Buy Advisor Card
   ============================================================ */
.gazlog-advisor-card {
    background: var(--gazlog-bg, #fff);
    border: 1px solid var(--gazlog-border, #e5e7eb);
    border-radius: var(--gazlog-radius-md, 8px);
    padding: var(--gazlog-gap-lg, 16px);
    margin-bottom: var(--gazlog-gap-lg, 16px);
    box-shadow: var(--gazlog-shadow-sm, 0 1px 3px rgba(0,0,0,.06));
    font-family: var(--gazlog-font-family, sans-serif);
    font-size: 14px;
    line-height: 1.6;
}

.gazlog-advisor-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--gazlog-gap-md, 12px);
}

.gazlog-advisor-name {
    font-size: 18px;
    font-weight: 700;
    color: var(--gazlog-text, #333);
}

.gazlog-advisor-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: var(--gazlog-radius-sm, 4px);
    font-weight: 700;
    font-size: 13px;
    white-space: nowrap;
}

.gazlog-advisor-score-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    margin-bottom: 4px;
}

.gazlog-advisor-score-label { color: var(--gazlog-text-secondary, #6b7280); }
.gazlog-advisor-score-value { font-weight: 700; }

.gazlog-deal-score-bar {
    height: 6px;
    border-radius: 3px;
    background: var(--gazlog-bg-subtle, #f3f4f6);
    overflow: hidden;
    margin-bottom: var(--gazlog-gap-md, 12px);
}

.gazlog-deal-score-fill {
    height: 100%;
    border-radius: 3px;
    transition: width .3s ease;
}

.gazlog-advisor-section { margin-bottom: 4px; }

.gazlog-advisor-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 3px 0;
    border-bottom: 1px solid var(--gazlog-bg-light, #f9fafb);
}

.gazlog-advisor-row:last-child { border-bottom: none; }
.gazlog-advisor-label { color: var(--gazlog-text-secondary, #6b7280); font-size: 13px; }
.gazlog-advisor-value { font-weight: 600; text-align: right; }

.gazlog-advisor-chart-wrap {
    margin: var(--gazlog-gap-sm, 8px) 0;
    border: 1px solid var(--gazlog-bg-light, #f9fafb);
    border-radius: var(--gazlog-radius-sm, 4px);
    padding: 8px 4px 4px;
    position: relative;
}

.gazlog-advisor-chart-title {
    font-size: 11px;
    font-weight: 600;
    color: var(--gazlog-text-secondary, #6b7280);
    margin-bottom: 4px;
    padding-left: 4px;
}

.gazlog-advisor-chart-area {
    position: relative;
    height: 120px;
}

.gazlog-advisor-sparkline {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
}

/* ── Cheapest product link ── */
.gazlog-advisor-cheapest {
    margin-top: var(--gazlog-gap-sm, 8px);
}
.gazlog-advisor-cheapest a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    background: linear-gradient(135deg, #eff6ff 0%, #f0fdf4 100%);
    border: 1px solid #bfdbfe;
    border-radius: var(--gazlog-radius-sm, 4px);
    text-decoration: none;
    color: inherit;
    transition: border-color .15s, box-shadow .15s;
}
.gazlog-advisor-cheapest a:hover {
    border-color: #60a5fa;
    box-shadow: 0 1px 4px rgba(59,130,246,.15);
}
.gazlog-cheapest-price {
    font-size: 16px;
    font-weight: 800;
    color: #1e40af;
    white-space: nowrap;
}
.gazlog-cheapest-detail {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
}
.gazlog-cheapest-product {
    font-size: 11px;
    color: #475569;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.gazlog-cheapest-shop {
    font-size: 10px;
    color: #94a3b8;
}
.gazlog-cheapest-arrow {
    font-size: 18px;
    color: #94a3b8;
    flex-shrink: 0;
}

/* ── Successor model block ── */
.gazlog-advisor-successor {
    margin-top: var(--gazlog-gap-sm, 8px);
    border: 1px solid #e2e8f0;
    border-radius: var(--gazlog-radius-sm, 4px);
    overflow: hidden;
    border-bottom: none;
}
.gazlog-successor-header {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 5px 10px;
    background: #f1f5f9;
    border-bottom: 1px solid #e2e8f0;
}
.gazlog-successor-title {
    font-size: 11px;
    font-weight: 700;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: .03em;
}
.gazlog-successor-conf {
    font-size: 10px;
    font-weight: 600;
    padding: 1px 6px;
    border-radius: 3px;
    line-height: 1.5;
}
.gazlog-conf-rumor   { background: #fef3c7; color: #92400e; }
.gazlog-conf-leak    { background: #fce7f3; color: #9d174d; }
.gazlog-conf-official{ background: #dcfce7; color: #166534; }

.gazlog-successor-body {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 10px;
}
.gazlog-successor-name {
    font-size: 13px;
    font-weight: 700;
    color: #1e293b;
}
.gazlog-successor-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #64748b;
    flex-shrink: 0;
}
.gazlog-successor-date {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 3px;
    padding: 1px 6px;
}
.gazlog-successor-countdown {
    white-space: nowrap;
}
.gazlog-successor-countdown strong {
    color: #1e293b;
    font-size: 14px;
}
.gazlog-successor-sources {
    display: flex;
    gap: 6px;
    padding: 4px 10px 6px;
    border-top: 1px solid #f1f5f9;
}
.gazlog-successor-sources a {
    font-size: 10px;
    color: #64748b;
    text-decoration: none;
    border: 1px solid #e2e8f0;
    border-radius: 3px;
    padding: 1px 5px;
    transition: all .15s;
}
.gazlog-successor-sources a:hover {
    color: #3b82f6;
    border-color: #93c5fd;
    background: #eff6ff;
}

.gazlog-advisor-reasons {
    margin-top: var(--gazlog-gap-sm, 8px);
    display: flex;
    flex-wrap: wrap;
    gap: var(--gazlog-gap-xs, 4px);
}

.gazlog-advisor-reason-pill {
    display: inline-block;
    background: var(--gazlog-bg-subtle, #f3f4f6);
    color: var(--gazlog-text-secondary, #6b7280);
    font-size: 11px;
    padding: 2px 8px;
    border-radius: var(--gazlog-radius-pill, 80px);
}

.gazlog-text-good { color: var(--gazlog-success, #2e7d32); }
.gazlog-text-warn { color: var(--gazlog-warning, #e65100); }
.gazlog-text-bad  { color: var(--gazlog-error, #c62828); }

/* Advisor table */
.gazlog-advisor-table-scroll {
    position: relative;
}

.gazlog-advisor-scroll-hint {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    margin-bottom: 4px;
    padding: 1px 6px;
    color: var(--gazlog-text-muted, #94a3b8);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.02em;
}

.gazlog-advisor-scroll-hint svg {
    opacity: 0.7;
}

@media (min-width: 900px) {
    /* デスクトップでは基本見えなくて良いので非表示 */
    .gazlog-advisor-scroll-hint { display: none; }
}

.gazlog-advisor-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    /* 端のスクロール影 (overflow 時のみ出現) */
    background:
        linear-gradient(to right, #ffffff 30%, rgba(255,255,255,0)) 0 0 / 20px 100% no-repeat local,
        linear-gradient(to left,  #ffffff 30%, rgba(255,255,255,0)) 100% 0 / 20px 100% no-repeat local,
        radial-gradient(farthest-side at 0   50%, rgba(0,0,0,0.10), rgba(0,0,0,0)) 0   0 / 10px 100% no-repeat scroll,
        radial-gradient(farthest-side at 100% 50%, rgba(0,0,0,0.10), rgba(0,0,0,0)) 100% 0 / 10px 100% no-repeat scroll,
        #ffffff;
}

/* スクロールバー: 控えめなグレー */
.gazlog-advisor-table-wrap::-webkit-scrollbar { height: 8px; }
.gazlog-advisor-table-wrap::-webkit-scrollbar-track {
    background: transparent;
}
.gazlog-advisor-table-wrap::-webkit-scrollbar-thumb {
    background: var(--gazlog-border, #cbd5e1);
    border-radius: 4px;
}
.gazlog-advisor-table-wrap::-webkit-scrollbar-thumb:hover {
    background: var(--gazlog-text-muted, #94a3b8);
}

.gazlog-advisor-table {
    width: 100%;
    border-collapse: collapse;
}

.gazlog-advisor-table th {
    white-space: nowrap;
    font-size: 12px;
}

.gazlog-advisor-table td {
    white-space: nowrap;
    font-size: 13px;
    vertical-align: middle;
}

/* 最安製品セル → リンクボタン
   方針: 「クリックできる」のは一目でわかるが、
   他のセルの視線を奪いすぎないよう、縦積みで控えめに。 */
.gazlog-advisor-buy-btn {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1px;
    padding: 3px 6px 3px 8px;
    background: #ffffff;
    color: var(--gazlog-primary, #2563eb) !important;
    border: 1px solid var(--gazlog-border, #cbd5e1);
    border-left: 3px solid var(--gazlog-primary, #2563eb);
    border-radius: 4px;
    text-decoration: none !important;
    line-height: 1.25;
    white-space: nowrap;
    transition: background 0.12s, border-color 0.12s;
}

.gazlog-advisor-buy-btn:hover,
.gazlog-advisor-buy-btn:focus {
    background: #eff6ff;
    border-color: var(--gazlog-primary, #2563eb);
    text-decoration: none !important;
    color: var(--gazlog-primary, #2563eb) !important;
}

.gazlog-advisor-buy-main {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.gazlog-advisor-buy-price {
    font-size: 13px;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.01em;
}

.gazlog-advisor-buy-icon {
    width: 10px;
    height: 10px;
    fill: currentColor;
    opacity: 0.55;
    flex-shrink: 0;
    transition: opacity 0.12s;
}

.gazlog-advisor-buy-btn:hover .gazlog-advisor-buy-icon {
    opacity: 1;
}

.gazlog-advisor-buy-shop {
    font-size: 10px;
    font-weight: 500;
    color: var(--gazlog-text-muted, #64748b);
    letter-spacing: 0;
}

/* Responsive */
@media (max-width: 640px) {
    .gazlog-advisor-card { padding: var(--gazlog-gap-md, 12px); font-size: 13px; }
    .gazlog-advisor-name { font-size: 16px; }
    .gazlog-advisor-badge { font-size: 12px; padding: 2px 8px; }
}

/* ============================================================
   Resale Value Simulator (.grv-*)
   ============================================================ */
.grv-root {
    border: 1px solid var(--gazlog-border, #e5e7eb);
    border-radius: var(--gazlog-radius-md, 8px);
    overflow: hidden;
    font-family: var(--gazlog-font-family, sans-serif);
    background: var(--gazlog-bg, #fff);
    box-shadow: var(--gazlog-shadow-sm, 0 1px 3px rgba(0,0,0,.06));
    margin: var(--gazlog-gap-lg, 16px) 0;
}

.grv-hdr {
    padding: 14px 16px;
    cursor: pointer;
    user-select: none;
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--gazlog-primary, #212f99);
    color: #fff;
}
.grv-hdr:active { filter: brightness(0.9); }

.grv-t1 { flex: 1; min-width: 0; }
.grv-t1 b { font-size: 15px; display: block; }
.grv-t1 small { font-size: 11px; opacity: .7; }

.grv-pk { display: flex; gap: 8px; flex-shrink: 0; }
.grv-pk-i { text-align: center; min-width: 44px; }
.grv-pk-r { font-size: 18px; font-weight: 800; line-height: 1; }
.grv-pk-l { font-size: 9px; opacity: .7; margin-top: 1px; }

.grv-cv { font-size: 16px; transition: transform .3s; flex-shrink: 0; }
.grv-cv.open { transform: rotate(180deg); }

.grv-bd { max-height: 0; overflow: hidden; transition: max-height .4s ease; }
.grv-bd.open { max-height: 3000px; }

.grv-s { padding: 14px 16px; border-top: 1px solid var(--gazlog-bg-light, #f9fafb); }

.grv-sh {
    font-size: 13px;
    font-weight: 700;
    color: var(--gazlog-text, #333);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    user-select: none;
    padding: 10px 16px;
    border-top: 1px solid var(--gazlog-bg-light, #f9fafb);
    background: var(--gazlog-bg-light, #f9fafb);
}
.grv-sh:active { background: var(--gazlog-bg-subtle, #f3f4f6); }
.grv-sh .c2 { font-size: 12px; transition: transform .3s; margin-left: auto; }
.grv-sh .c2.open { transform: rotate(180deg); }

.grv-sb { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.grv-sb.open { max-height: 1200px; }

.grv-ir { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 8px; }

.grv-pi {
    font-size: 16px;
    font-weight: 700;
    padding: 8px 12px;
    border: 2px solid var(--gazlog-primary, #212f99);
    border-radius: var(--gazlog-radius-md, 8px);
    width: 150px;
    outline: none;
    text-align: right;
    -moz-appearance: textfield;
}
.grv-pi::-webkit-inner-spin-button { -webkit-appearance: none; }
.grv-pi:focus { border-color: var(--gazlog-primary-hover, #1a2570); box-shadow: 0 0 0 3px rgba(33,47,153,.15); }

.grv-ps { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
.grv-pb {
    font-size: 11px;
    padding: 4px 10px;
    border: 1px solid var(--gazlog-border-dark, #d1d5db);
    border-radius: var(--gazlog-radius-sm, 4px);
    background: var(--gazlog-bg, #fff);
    cursor: pointer;
    white-space: nowrap;
    color: var(--gazlog-text-secondary, #6b7280);
}
.grv-pb:hover { border-color: var(--gazlog-primary, #212f99); color: var(--gazlog-primary, #212f99); background: var(--gazlog-primary-light, #e8ecf9); }
.grv-pb:active { background: var(--gazlog-bg-subtle, #f3f4f6); }

.grv-gr { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.grv-gi { font-size: 16px; flex-shrink: 0; }
.grv-gd { flex: 1; min-width: 0; }
.grv-gt { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 3px; }
.grv-gl { font-size: 12px; font-weight: 600; color: var(--gazlog-text, #333); }
.grv-gv { font-size: 11px; color: var(--gazlog-text-secondary, #6b7280); }
.grv-gb { height: 22px; background: var(--gazlog-bg-subtle, #f3f4f6); border-radius: var(--gazlog-radius-sm, 4px); overflow: hidden; }
.grv-gf { height: 100%; border-radius: var(--gazlog-radius-sm, 4px); transition: width .4s ease; display: flex; align-items: center; justify-content: flex-end; padding-right: 8px; min-width: 36px; }
.grv-gp { font-size: 12px; font-weight: 800; color: #fff; text-shadow: 0 1px 2px rgba(0,0,0,.3); }

.grv-fr {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 6px;
    padding: 10px 12px;
    background: var(--gazlog-warning-bg, #fff3e0);
    border-radius: var(--gazlog-radius-md, 8px);
    font-size: 12px;
    color: var(--gazlog-warning, #e65100);
    line-height: 1.6;
}
.grv-fi { width: 52px; padding: 3px 6px; border: 1px solid var(--gazlog-border-dark, #d1d5db); border-radius: var(--gazlog-radius-sm, 4px); font-size: 12px; text-align: right; }
.grv-fn { font-weight: 700; }

.grv-cw { padding: 8px 16px 14px; }

.grv-tb { width: 100%; font-size: 12px; border-collapse: collapse; }
.grv-tb th { text-align: left; padding: 6px 8px; color: var(--gazlog-text-secondary, #6b7280); font-weight: 600; border-bottom: 2px solid var(--gazlog-border, #e5e7eb); font-size: 11px; white-space: nowrap; }
.grv-tb td { padding: 6px 8px; border-bottom: 1px solid var(--gazlog-bg-light, #f9fafb); }
.grv-tb .r { text-align: right; font-variant-numeric: tabular-nums; }
.g-g { color: var(--gazlog-success, #2e7d32); font-weight: 700; }
.g-m { color: var(--gazlog-warning, #e65100); font-weight: 700; }
.g-l { color: var(--gazlog-error, #c62828); font-weight: 700; }

@media (max-width: 480px) {
    .grv-hdr { padding: 12px 14px; gap: 8px; }
    .grv-pk-r { font-size: 16px; }
    .grv-pi { width: 120px; font-size: 14px; padding: 6px 8px; }
    .grv-fr { font-size: 11px; gap: 5px; }
    .grv-tb { font-size: 11px; }
    .grv-tb th, .grv-tb td { padding: 4px 5px; }
    .grv-s, .grv-cw { padding: 10px 12px; }
}

/* ── Advisor Badge (standalone) ── */
.gazlog-abadge-wrap {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    flex-wrap: wrap;
    font-size: 12px;
    line-height: 1;
    vertical-align: middle;
}
.gazlog-abadge-inline { gap: 4px; }
.gazlog-abadge-rec {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 4px;
    border: 1px solid;
}
.gazlog-abadge-score {
    font-weight: 700;
    color: #1e293b;
}
.gazlog-abadge-score small {
    font-weight: 400;
    color: #94a3b8;
    font-size: 10px;
}
.gazlog-abadge-reason {
    display: inline-block;
    background: #f1f5f9;
    color: #475569;
    font-size: 10px;
    padding: 2px 6px;
    border-radius: 80px;
}


/* ============================================================
   AIB 比較テーブル v2 ([gazlog_aib_compare])
   フィルタ + ソート + 列固定 + ボタン型アフィ + モバイルカード
   ============================================================ */
.gazlog-aib-v2 {
    --g-border: #e5e7eb;
    --g-text: #1e293b;
    --g-muted: #64748b;
    --g-primary: #2563eb;
    --g-accent: #dc2626;
    --g-success: #16a34a;
    --g-warn: #f59e0b;
    --g-bg-alt: #f8fafc;
    --g-bg-soft: #f1f5f9;
    --g-shadow: 0 1px 3px rgba(0,0,0,.06);
    --g-radius: 10px;

    background: #fff;
    border: 1px solid var(--g-border);
    border-radius: var(--g-radius);
    padding: 16px;
    margin: 24px 0;
    color: var(--g-text);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans JP", sans-serif;
    box-shadow: var(--g-shadow);
}
.gazlog-aib-v2 *, .gazlog-aib-v2 *::before, .gazlog-aib-v2 *::after { box-sizing: border-box; }

.gazlog-aib-title {
    font-size: 20px;
    font-weight: 700;
    margin: 0 0 14px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--g-bg-soft);
}

.gazlog-aib-empty {
    padding: 32px;
    text-align: center;
    color: var(--g-muted);
    background: var(--g-bg-alt);
    border: 1px dashed var(--g-border);
    border-radius: var(--g-radius);
    margin: 24px 0;
}

/* ============ TOP3 ============ */
.gazlog-aib-top3 { margin: 4px 0 18px; }
.gazlog-aib-top3-label {
    font-size: 13px;
    font-weight: 700;
    color: var(--g-muted);
    margin-bottom: 10px;
    display: flex; align-items: center; gap: 6px;
}
.gazlog-aib-top3-label .bi-trophy-fill { color: var(--g-warn); }
.gazlog-aib-top3-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
}
.gazlog-aib-top3-card {
    display: flex; flex-direction: column; gap: 4px;
    padding: 14px 14px 14px 18px;
    background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
    border: 1px solid var(--g-border);
    border-radius: var(--g-radius);
    text-decoration: none;
    color: inherit;
    transition: transform .15s, box-shadow .15s, border-color .15s;
    position: relative;
}
.gazlog-aib-top3-card::before {
    content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
    border-radius: var(--g-radius) 0 0 var(--g-radius);
}
.gazlog-aib-top3-card.rank-1::before { background: var(--g-warn); }
.gazlog-aib-top3-card.rank-2::before { background: #94a3b8; }
.gazlog-aib-top3-card.rank-3::before { background: #b45309; }
.gazlog-aib-top3-card:hover {
    transform: translateY(-2px);
    border-color: var(--g-primary);
    box-shadow: 0 8px 18px rgba(37,99,235,.12);
}
.gazlog-aib-top3-rank {
    font-size: 11px;
    font-weight: 800;
    color: #94a3b8;
    letter-spacing: .5px;
}
.gazlog-aib-top3-name {
    font-size: 14px;
    font-weight: 700;
    line-height: 1.3;
    color: var(--g-text);
}
.gazlog-aib-top3-price {
    font-size: 22px;
    font-weight: 800;
    color: var(--g-accent);
    line-height: 1;
    margin: 2px 0 4px;
    font-variant-numeric: tabular-nums;
}
.gazlog-aib-top3-shop {
    font-size: 12px; color: var(--g-muted);
    display: flex; align-items: center; gap: 4px;
}
.gazlog-aib-top3-cta {
    margin-top: auto;
    padding-top: 8px;
    font-size: 12px;
    font-weight: 700;
    color: var(--g-primary);
}

/* ============ ツールバー ============ */
.gazlog-aib-toolbar {
    display: flex; flex-wrap: wrap; gap: 10px;
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px solid var(--g-border);
    margin-bottom: 10px;
}
.gazlog-aib-search-wrap {
    position: relative;
    flex: 1 1 220px;
    max-width: 320px;
}
.gazlog-aib-search-wrap .bi-search {
    position: absolute;
    left: 10px; top: 50%; transform: translateY(-50%);
    color: var(--g-muted);
    pointer-events: none;
}
.gazlog-aib-search {
    width: 100%;
    padding: 8px 10px 8px 32px;
    border: 1px solid var(--g-border);
    border-radius: 6px;
    font-size: 13px;
    background: #fff;
    transition: border-color .15s, box-shadow .15s;
}
.gazlog-aib-search:focus {
    outline: none;
    border-color: var(--g-primary);
    box-shadow: 0 0 0 3px rgba(37,99,235,.12);
}
.gazlog-aib-toolbar-right {
    display: flex; flex-wrap: wrap; gap: 8px;
    align-items: center;
    margin-left: auto;
}
.gazlog-aib-checklabel {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 13px;
    color: var(--g-muted);
    cursor: pointer;
    user-select: none;
}
.gazlog-aib-checklabel input { cursor: pointer; }
.gazlog-aib-btn-toggle {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 6px 10px;
    background: #fff;
    border: 1px solid var(--g-border);
    border-radius: 6px;
    color: var(--g-text);
    font-size: 12px;
    cursor: pointer;
    transition: background .15s, border-color .15s;
}
.gazlog-aib-btn-toggle:hover {
    background: var(--g-bg-alt);
    border-color: var(--g-primary);
    color: var(--g-primary);
}
.gazlog-aib-btn-toggle.is-active {
    background: var(--g-primary);
    border-color: var(--g-primary);
    color: #fff;
}
.gazlog-aib-stats {
    font-size: 12px;
    color: var(--g-muted);
    padding: 0 4px;
    font-variant-numeric: tabular-nums;
}
.gazlog-aib-stats .gazlog-aib-count {
    font-weight: 700;
    color: var(--g-text);
}

/* ============ フィルタパネル / 列パネル ============ */
.gazlog-aib-filters,
.gazlog-aib-columns {
    padding: 12px;
    background: var(--g-bg-alt);
    border: 1px solid var(--g-border);
    border-radius: 8px;
    margin-bottom: 10px;
}
.gazlog-aib-filter-group + .gazlog-aib-filter-group { margin-top: 12px; }
.gazlog-aib-filter-label {
    font-size: 12px; font-weight: 700;
    color: var(--g-muted);
    margin-bottom: 6px;
    display: flex; gap: 8px; align-items: center;
}
.gazlog-aib-range-current {
    font-weight: 600;
    color: var(--g-text);
    font-variant-numeric: tabular-nums;
}

.gazlog-aib-chip-group {
    display: flex; flex-wrap: wrap; gap: 6px;
}
.gazlog-aib-chip {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 4px 10px;
    background: #fff;
    border: 1px solid var(--g-border);
    border-radius: 999px;
    font-size: 12px;
    cursor: pointer;
    user-select: none;
    transition: all .12s;
}
.gazlog-aib-chip input { display: none; }
.gazlog-aib-chip:has(input:checked) {
    background: var(--g-primary);
    border-color: var(--g-primary);
    color: #fff;
}
.gazlog-aib-chip-count {
    font-size: 10px;
    background: rgba(0,0,0,.08);
    padding: 1px 5px;
    border-radius: 999px;
}
.gazlog-aib-chip:has(input:checked) .gazlog-aib-chip-count {
    background: rgba(255,255,255,.25);
}
.gazlog-aib-chip .bi-pin-angle-fill { color: var(--g-warn); font-size: 11px; }
.gazlog-aib-chip:has(input:checked) .bi-pin-angle-fill { color: #fde68a; }

.gazlog-aib-range {
    position: relative; height: 28px;
}
.gazlog-aib-range input[type=range] {
    position: absolute; left: 0; right: 0; width: 100%;
    pointer-events: none;
    -webkit-appearance: none; appearance: none;
    background: transparent;
}
.gazlog-aib-range input[type=range]::-webkit-slider-runnable-track {
    height: 4px; background: var(--g-bg-soft); border-radius: 2px;
}
.gazlog-aib-range input[type=range]::-moz-range-track {
    height: 4px; background: var(--g-bg-soft); border-radius: 2px;
}
.gazlog-aib-range input[type=range]::-webkit-slider-thumb {
    -webkit-appearance: none; pointer-events: auto;
    width: 16px; height: 16px; border-radius: 50%;
    background: var(--g-primary); border: 2px solid #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,.3); cursor: pointer;
    margin-top: -6px;
}
.gazlog-aib-range input[type=range]::-moz-range-thumb {
    pointer-events: auto;
    width: 16px; height: 16px; border-radius: 50%;
    background: var(--g-primary); border: 2px solid #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,.3); cursor: pointer;
}

.gazlog-aib-filter-actions {
    margin-top: 12px;
    padding-top: 10px;
    border-top: 1px dashed var(--g-border);
    text-align: right;
}
.gazlog-aib-btn-reset {
    padding: 6px 12px;
    background: #fff;
    border: 1px solid var(--g-border);
    border-radius: 6px;
    font-size: 12px;
    cursor: pointer;
    color: var(--g-muted);
}
.gazlog-aib-btn-reset:hover { color: var(--g-accent); border-color: var(--g-accent); }

/* ============ テーブル ============ */
.gazlog-aib-scroll {
    overflow-x: auto;
    overflow-y: visible;
    border: 1px solid var(--g-border);
    border-radius: 8px;
    background: #fff;
    position: relative;
    /* 横スクロールバーを常時可視に (visible affordance) */
    scrollbar-color: var(--g-primary) #e5e7eb;
    scrollbar-width: thin;
}
/* WebKit 系: スクロールバー強調 */
.gazlog-aib-scroll::-webkit-scrollbar {
    height: 10px;
}
.gazlog-aib-scroll::-webkit-scrollbar-track {
    background: #e5e7eb;
    border-radius: 5px;
}
.gazlog-aib-scroll::-webkit-scrollbar-thumb {
    background: var(--g-primary);
    border-radius: 5px;
    border: 2px solid #e5e7eb;
}
.gazlog-aib-scroll::-webkit-scrollbar-thumb:hover {
    background: #1d4ed8;
}

/* スクロール可能エッジ: グラデーション影 (隠れたコンテンツがある側を示唆) */
.gazlog-aib-scroll-wrap {
    position: relative;
}
.gazlog-aib-scroll-wrap::before,
.gazlog-aib-scroll-wrap::after {
    content: "";
    position: absolute;
    top: 0; bottom: 12px;  /* スクロールバー領域は除外 */
    width: 24px;
    pointer-events: none;
    z-index: 5;
    opacity: 0;
    transition: opacity .2s;
}
.gazlog-aib-scroll-wrap::before {
    left: 0;
    background: linear-gradient(90deg, rgba(15,23,42,0.18) 0%, rgba(15,23,42,0) 100%);
    border-radius: 8px 0 0 8px;
}
.gazlog-aib-scroll-wrap::after {
    right: 0;
    background: linear-gradient(-90deg, rgba(15,23,42,0.18) 0%, rgba(15,23,42,0) 100%);
    border-radius: 0 8px 8px 0;
}
.gazlog-aib-scroll-wrap[data-can-scroll-left="1"]::before { opacity: 1; }
.gazlog-aib-scroll-wrap[data-can-scroll-right="1"]::after { opacity: 1; }

/* スクロールヒントバナー (テーブル直上) */
.gazlog-aib-scroll-hint {
    display: flex; align-items: center; justify-content: center;
    gap: 8px;
    padding: 6px 10px;
    margin-bottom: 8px;
    background: linear-gradient(90deg, transparent 0%, rgba(37,99,235,0.08) 50%, transparent 100%);
    border-radius: 6px;
    font-size: 11px;
    color: var(--g-primary);
    font-weight: 600;
    transition: opacity .3s;
}
.gazlog-aib-scroll-hint[hidden] { display: none; }
.gazlog-aib-scroll-hint .arrow {
    display: inline-block;
    animation: gazlog-aib-scroll-hint-bounce 1.4s ease-in-out infinite;
}
.gazlog-aib-scroll-hint .arrow.right { animation-delay: .7s; }
@keyframes gazlog-aib-scroll-hint-bounce {
    0%, 100% { transform: translateX(0); opacity: .6; }
    50%      { transform: translateX(4px); opacity: 1; }
}
.gazlog-aib-scroll-hint .arrow.left {
    animation-name: gazlog-aib-scroll-hint-bounce-left;
}
@keyframes gazlog-aib-scroll-hint-bounce-left {
    0%, 100% { transform: translateX(0); opacity: .6; }
    50%      { transform: translateX(-4px); opacity: 1; }
}
.gazlog-aib-scroll-hint.is-faded { opacity: 0.35; }
.gazlog-aib-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 13px;
    table-layout: auto;
}
.gazlog-aib-table thead th {
    background: var(--g-bg-soft);
    color: var(--g-muted);
    font-weight: 700;
    padding: 10px 12px;
    text-align: left;
    white-space: nowrap;
    border-bottom: 2px solid #cbd5e1;
    position: sticky;
    top: 0;
    z-index: 3;
    cursor: pointer;
    user-select: none;
    transition: background .12s;
}
.gazlog-aib-table thead th { cursor: default; } /* ヘッダー全体では cursor 反映しない */
.gazlog-aib-table thead th:hover { background: #e2e8f0; }
.gazlog-aib-sort-icon {
    font-size: 10px;
    color: #cbd5e1;
    margin-left: 2px;
    vertical-align: middle;
}
.gazlog-aib-table thead th.is-sorted-asc,
.gazlog-aib-table thead th.is-sorted-desc {
    background: #dbeafe; color: var(--g-primary);
}
.gazlog-aib-table thead th.is-sorted-asc .gazlog-aib-sort-icon,
.gazlog-aib-table thead th.is-sorted-desc .gazlog-aib-sort-icon {
    color: var(--g-primary);
}

/* ============ ヘッダー内ボタン / ソート ▲▼ / 列フィルタ popover ============ */
.gazlog-aib-th-inner {
    display: inline-flex; align-items: center; gap: 4px;
    position: relative;
    width: 100%;
}
.gazlog-aib-th-sort {
    background: transparent; border: 0; padding: 0;
    display: inline-flex; align-items: center; gap: 4px;
    color: inherit;
    font-weight: 700; font-size: inherit;
    cursor: pointer;
    text-align: left;
    flex: 1 1 auto; min-width: 0;
    white-space: nowrap;
}
.gazlog-aib-th-sort:hover { color: var(--g-primary); }
.gazlog-aib-th-sort:focus-visible {
    outline: 2px solid var(--g-primary); outline-offset: 2px; border-radius: 4px;
}
/* ソート方向インジケータ ▲/▼ */
.gazlog-aib-sort-ind {
    display: inline-block;
    width: 14px; height: 14px; line-height: 14px;
    text-align: center;
    font-size: 10px;
    color: #94a3b8;
    transition: color .12s, transform .12s;
}
.gazlog-aib-sort-ind::before { content: "⇅"; font-size: 11px; }
.gazlog-aib-table thead th.is-sorted-asc .gazlog-aib-sort-ind {
    color: var(--g-primary);
    font-weight: 900;
}
.gazlog-aib-table thead th.is-sorted-asc .gazlog-aib-sort-ind::before { content: "▲"; }
.gazlog-aib-table thead th.is-sorted-desc .gazlog-aib-sort-ind {
    color: var(--g-primary);
    font-weight: 900;
}
.gazlog-aib-table thead th.is-sorted-desc .gazlog-aib-sort-ind::before { content: "▼"; }

.gazlog-aib-th-filter {
    background: transparent;
    border: 1px solid transparent;
    padding: 2px 4px;
    border-radius: 4px;
    font-size: 11px;
    color: #94a3b8;
    cursor: pointer;
    position: relative;
    display: inline-flex; align-items: center; justify-content: center;
    line-height: 1;
    flex: 0 0 auto;
}
.gazlog-aib-th-filter:hover {
    background: #fff;
    border-color: var(--g-border);
    color: var(--g-primary);
}
.gazlog-aib-th-filter[aria-expanded="true"] {
    background: var(--g-primary);
    color: #fff;
    border-color: var(--g-primary);
}
.gazlog-aib-th-filter.has-active {
    color: var(--g-primary);
}
.gazlog-aib-th-filter-dot {
    position: absolute;
    top: -2px; right: -2px;
    width: 7px; height: 7px;
    background: var(--g-accent, #f97316);
    border-radius: 50%;
    box-shadow: 0 0 0 1.5px #fff;
}

/* 列 popover (JS で position: fixed 座標を付与) */
.gazlog-aib-col-popover {
    position: fixed;
    z-index: 9999;
    min-width: 220px;
    max-width: 300px;
    background: #fff;
    border: 1px solid var(--g-border);
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(15,23,42,.15);
    padding: 10px 12px;
    white-space: normal;
    font-weight: 400;
    color: var(--g-text);
    cursor: default;
}
.gazlog-aib-col-popover[hidden] { display: none; }
.gazlog-aib-popover-title {
    font-size: 11px; font-weight: 700; color: var(--g-muted);
    margin-bottom: 8px;
    text-transform: none; letter-spacing: 0;
}
.gazlog-aib-popover-actions {
    display: flex; justify-content: space-between;
    gap: 8px;
    margin-top: 10px;
    padding-top: 8px;
    border-top: 1px dashed var(--g-border);
}
.gazlog-aib-popover-actions button {
    background: #fff;
    border: 1px solid var(--g-border);
    border-radius: 6px;
    padding: 4px 10px;
    font-size: 11px;
    cursor: pointer;
    color: var(--g-muted);
}
.gazlog-aib-popover-actions button:hover {
    color: var(--g-primary); border-color: var(--g-primary);
}
.gazlog-aib-range-row {
    display: flex; flex-direction: column; gap: 6px;
}
.gazlog-aib-range-row .gazlog-aib-range-current {
    font-size: 12px; color: var(--g-text);
}

/* モバイル: popover をシート風にする (JS の座標指定を上書き) */
@media (max-width: 640px) {
    .gazlog-aib-col-popover {
        top: auto !important; left: 10px !important; right: 10px !important; bottom: 10px !important;
        max-width: none;
        max-height: 60vh;
        overflow: auto;
    }
}

/* ============ 条件バッジ (モデル名の下) ============ */
.gazlog-aib-badges {
    display: flex; flex-wrap: wrap; gap: 4px;
    margin-top: 4px;
}
.gazlog-aib-badge {
    display: inline-flex; align-items: center; gap: 3px;
    padding: 1px 7px;
    font-size: 10px;
    font-weight: 700;
    border-radius: 999px;
    border: 1px solid transparent;
    white-space: nowrap;
    line-height: 1.5;
}
.gazlog-aib-badge .bi { font-size: 10px; }
.gazlog-aib-badge.tone-info {
    background: #dbeafe; color: #1d4ed8; border-color: #93c5fd;
}
.gazlog-aib-badge.tone-success {
    background: #dcfce7; color: #15803d; border-color: #86efac;
}
.gazlog-aib-badge.tone-warn {
    background: #fef3c7; color: #b45309; border-color: #fcd34d;
}
.gazlog-aib-badge.tone-accent {
    background: #fae8ff; color: #a21caf; border-color: #f0abfc;
}
.gazlog-aib-badge.tone-neutral {
    background: #e2e8f0; color: #334155; border-color: #cbd5e1;
}
.gazlog-aib-badge.tone-danger {
    background: #fee2e2; color: #b91c1c; border-color: #fca5a5;
}

/* バッジフィルタチップ (フィルタパネル) */
.gazlog-aib-badge-chip .bi { font-size: 11px; }
.gazlog-aib-badge-chip.tone-info   { border-color: #93c5fd; }
.gazlog-aib-badge-chip.tone-success{ border-color: #86efac; }
.gazlog-aib-badge-chip.tone-warn   { border-color: #fcd34d; }
.gazlog-aib-badge-chip.tone-accent { border-color: #f0abfc; }
.gazlog-aib-badge-chip.tone-danger { border-color: #fca5a5; }
.gazlog-aib-filter-hint {
    margin-top: 6px;
    font-size: 11px;
    color: var(--g-muted);
}
.gazlog-aib-filter-hint .bi { margin-right: 2px; }

/* ツールバーの active フィルタ件数バッジ */
.gazlog-aib-active-count {
    display: inline-block;
    min-width: 18px;
    padding: 0 5px;
    background: var(--g-accent, #f97316);
    color: #fff;
    border-radius: 999px;
    font-size: 10px; font-weight: 700;
    line-height: 16px;
    text-align: center;
}
.gazlog-aib-active-count[hidden] { display: none; }

.gazlog-aib-btn-reset-inline {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 6px 10px;
    background: #fff;
    border: 1px solid var(--g-accent, #f97316);
    color: var(--g-accent, #f97316);
    border-radius: 6px;
    font-size: 12px;
    cursor: pointer;
}
.gazlog-aib-btn-reset-inline:hover {
    background: var(--g-accent, #f97316);
    color: #fff;
}
.gazlog-aib-btn-reset-inline[hidden] { display: none; }

.gazlog-aib-table tbody tr {
    border-bottom: 1px solid var(--g-border);
    transition: background .1s;
}
.gazlog-aib-table tbody tr:hover td { background: #eff6ff !important; }
.gazlog-aib-table td {
    padding: 10px 12px;
    vertical-align: middle;
    background: #fff;
    border-bottom: 1px solid var(--g-border);
}

.gazlog-aib-col-label small {
    display: block; font-weight: 400; font-size: 10px; color: #94a3b8;
    margin-top: 1px;
}

.gazlog-aib-name {
    min-width: 150px;
    max-width: 220px;
}
.gazlog-aib-mfr {
    font-size: 10px;
    color: var(--g-muted);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .3px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.gazlog-aib-model {
    font-weight: 600;
    line-height: 1.3;
    margin-top: 2px;
    /* スペースでのみ改行 (単語途中で切れない) */
    white-space: normal;
    word-break: keep-all;     /* CJK 文字列は切らない */
    overflow-wrap: normal;    /* 単語の途中では折り返さない */
    hyphens: none;
}
.gazlog-aib-spec {
    text-align: right;
    color: var(--g-text);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}
.gazlog-aib-price {
    text-align: right;
    white-space: nowrap;
    min-width: 100px;
    padding: 8px 10px;
}
.gazlog-aib-price .gazlog-aib-price-value { line-height: 1.1; }
.gazlog-aib-price .gazlog-aib-stock-in,
.gazlog-aib-price .gazlog-aib-stock-out { margin-top: 3px; }
.gazlog-aib-price-value {
    font-size: 14px; font-weight: 800;
    color: var(--g-accent);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.5px;  /* ¥カンマ込みの数字をやや詰める */
}
.gazlog-aib-stock-in,
.gazlog-aib-stock-out {
    display: inline-flex; align-items: center; gap: 2px;
    font-size: 9px;
    padding: 1px 5px;
    border-radius: 4px;
    margin-top: 2px;
    font-style: normal;
    line-height: 1.3;
}
.gazlog-aib-stock-in .bi,
.gazlog-aib-stock-out .bi { font-size: 9px; }
.gazlog-aib-stock-in { background: #dcfce7; color: var(--g-success); }
.gazlog-aib-stock-out { background: #fee2e2; color: var(--g-accent); }
.gazlog-aib-no-price { color: #cbd5e1; font-style: italic; font-size: 12px; }

/* ============ Sticky 列 ============ */
.gazlog-aib-sticky-left {
    position: sticky;
    left: 0;
    background: #fdfdff !important;   /* わずかに tint して固定列であることを示唆 */
    z-index: 2;
    /* 固定境界: 2px 濃い線 + 4px 柔らかい影 (境界が常に見える) */
    box-shadow:
        inset -1px 0 0 rgba(37,99,235,0.18),  /* 内側右端のアクセント線 */
        2px 0 0 #cbd5e1;                       /* 外側の濃い境界線 */
    transition: box-shadow .15s;
}
.gazlog-aib-table thead th.gazlog-aib-sticky-left {
    background: #e0e7ff !important;   /* ヘッダの固定列はさらに濃く (アクセント) */
    z-index: 4;
    box-shadow:
        inset -1px 0 0 rgba(37,99,235,0.3),
        2px 0 0 #cbd5e1;
}
.gazlog-aib-sticky-right {
    position: sticky;
    right: 0;
    background: #fdfdff !important;
    z-index: 2;
    box-shadow:
        inset 1px 0 0 rgba(37,99,235,0.18),
        -2px 0 0 #cbd5e1;
    transition: box-shadow .15s;
}
.gazlog-aib-table thead th.gazlog-aib-sticky-right {
    background: #e0e7ff !important;
    z-index: 4;
    box-shadow:
        inset 1px 0 0 rgba(37,99,235,0.3),
        -2px 0 0 #cbd5e1;
}
.gazlog-aib-table tbody tr:hover .gazlog-aib-sticky-left,
.gazlog-aib-table tbody tr:hover .gazlog-aib-sticky-right {
    background: #eff6ff !important;
}

/* スクロール位置に応じて固定列境界の影を強調 */
.gazlog-aib-scroll-wrap[data-can-scroll-right="1"] .gazlog-aib-sticky-left {
    box-shadow:
        inset -1px 0 0 rgba(37,99,235,0.25),
        6px 0 12px -2px rgba(15,23,42,0.25);
}
.gazlog-aib-scroll-wrap[data-can-scroll-right="1"] thead th.gazlog-aib-sticky-left {
    box-shadow:
        inset -1px 0 0 rgba(37,99,235,0.4),
        6px 0 12px -2px rgba(15,23,42,0.25);
}
.gazlog-aib-scroll-wrap[data-can-scroll-left="1"] .gazlog-aib-sticky-right {
    box-shadow:
        inset 1px 0 0 rgba(37,99,235,0.25),
        -6px 0 12px -2px rgba(15,23,42,0.25);
}
.gazlog-aib-scroll-wrap[data-can-scroll-left="1"] thead th.gazlog-aib-sticky-right {
    box-shadow:
        inset 1px 0 0 rgba(37,99,235,0.4),
        -6px 0 12px -2px rgba(15,23,42,0.25);
}

/* ============ 展開トグル (最安値セル内) ============ */
.gazlog-aib-expand-toggle {
    display: inline-flex; align-items: center; gap: 3px;
    margin-top: 5px;
    padding: 3px 8px;
    background: #fff;
    border: 1px solid var(--g-primary);
    border-radius: 999px;
    color: var(--g-primary);
    font-size: 11px;
    font-weight: 700;
    cursor: pointer;
    transition: all .12s;
    line-height: 1.1;
    white-space: nowrap;
}
.gazlog-aib-expand-toggle:hover {
    background: var(--g-primary);
    color: #fff;
}
.gazlog-aib-expand-toggle .gazlog-aib-chevron {
    transition: transform .15s;
    font-size: 10px;
}
.gazlog-aib-expand-toggle[aria-expanded="true"] {
    background: var(--g-primary);
    color: #fff;
}
.gazlog-aib-expand-toggle[aria-expanded="true"] .gazlog-aib-chevron {
    transform: rotate(180deg);
}

/* 展開行: 全幅でショップ TOP3 を表示 */
.gazlog-aib-expand-row > td {
    background: #f8fafc !important;
    padding: 0 !important;
    border-bottom: 1px solid var(--g-border);
}
.gazlog-aib-expand-inner {
    padding: 12px 14px;
    display: flex; flex-direction: column; gap: 8px;
    /* 展開行の td は colspan 全幅、その内側を sticky 配置で viewport に追従させる */
    position: sticky;
    left: 0;
    /* width は JS で viewport 幅にセット */
}
.gazlog-aib-expand-label {
    font-size: 12px;
    color: var(--g-muted);
    font-weight: 700;
    display: flex; align-items: center; gap: 6px;
}
.gazlog-aib-expand-label .bi-shop { color: var(--g-primary); }
.gazlog-aib-shops-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 8px;
}
.gazlog-aib-buy-rank {
    font-size: 10px;
    font-weight: 800;
    color: #94a3b8;
    min-width: 22px;
    letter-spacing: .3px;
    white-space: nowrap;
}
.gazlog-aib-buy.rank-1 .gazlog-aib-buy-rank { color: var(--g-warn); }
.gazlog-aib-buy.rank-2 .gazlog-aib-buy-rank { color: #94a3b8; }
.gazlog-aib-buy.rank-3 .gazlog-aib-buy-rank { color: #b45309; }
/* 同率時はランクサイズを若干小さく + 文字色維持 */
.gazlog-aib-buy.is-tied .gazlog-aib-buy-rank,
.gazlog-aib-top3-card.is-tied .gazlog-aib-top3-rank {
    font-size: 9px;
    letter-spacing: 0;
}

/* ============ 購入ボタン ============ */
.gazlog-aib-buy {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 10px;
    margin-bottom: 0;
    background: #fff;
    border: 1px solid var(--g-border);
    border-radius: 6px;
    text-decoration: none;
    font-size: 12px;
    font-weight: 600;
    color: var(--g-text);
    transition: all .12s;
    position: relative;
}
.gazlog-aib-buy:hover {
    border-color: var(--g-primary);
    background: #eff6ff;
    color: var(--g-primary);
    transform: translateX(2px);
}
.gazlog-aib-buy.rank-1 {
    background: linear-gradient(90deg, #fef3c7 0%, #fff 60%);
    border-color: var(--g-warn);
}
.gazlog-aib-buy.rank-1:hover {
    background: linear-gradient(90deg, #fde68a 0%, #fef3c7 60%);
    border-color: var(--g-warn);
    color: var(--g-text);
}
.gazlog-aib-buy-shop {
    flex: 1;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    font-weight: 600;
}
.gazlog-aib-buy-price {
    color: var(--g-accent);
    font-weight: 800;
    font-variant-numeric: tabular-nums;
}
.gazlog-aib-buy .bi { font-size: 11px; color: #94a3b8; }
.gazlog-aib-buy:hover .bi { color: var(--g-primary); }

.gazlog-aib-empty-filter {
    padding: 28px;
    text-align: center;
    color: var(--g-muted);
    background: var(--g-bg-alt);
}

/* ============ カードビュー (モバイル) ============ */
.gazlog-aib-cards { display: none; gap: 12px; flex-direction: column; }
.gazlog-aib-card {
    background: #fff;
    border: 1px solid var(--g-border);
    border-radius: var(--g-radius);
    padding: 14px;
    box-shadow: var(--g-shadow);
}
.gazlog-aib-card-header { margin-bottom: 8px; }
.gazlog-aib-card-mfr {
    font-size: 10px; color: var(--g-muted); font-weight: 700;
    text-transform: uppercase; letter-spacing: .3px;
}
.gazlog-aib-card-name { font-size: 15px; font-weight: 700; line-height: 1.3; margin-top: 2px; }
.gazlog-aib-card-price {
    display: flex; align-items: baseline; gap: 10px;
    margin-bottom: 10px; padding-bottom: 8px;
    border-bottom: 1px dashed var(--g-border);
}
.gazlog-aib-card-price span {
    font-size: 22px; font-weight: 800; color: var(--g-accent);
    font-variant-numeric: tabular-nums;
}
.gazlog-aib-card-specs {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6px 12px;
    margin: 0 0 10px;
    padding: 0;
    font-size: 12px;
}
.gazlog-aib-card-specs > div { display: flex; justify-content: space-between; gap: 4px; }
.gazlog-aib-card-specs dt { color: var(--g-muted); font-weight: 500; margin: 0; }
.gazlog-aib-card-specs dd {
    color: var(--g-text); font-weight: 600; margin: 0;
    font-variant-numeric: tabular-nums; text-align: right;
}
.gazlog-aib-card-buttons { display: flex; flex-direction: column; gap: 6px; }
.gazlog-aib-card-buttons .gazlog-aib-buy { margin: 0; padding: 10px 12px; font-size: 13px; }

.gazlog-aib-footer {
    margin-top: 10px;
    text-align: right;
    color: #94a3b8;
    font-size: 11px;
    padding-top: 6px;
    border-top: 1px solid var(--g-bg-soft);
}

/* ============ ブレイクポイント ============ */
@media (max-width: 768px) {
    .gazlog-aib-v2[data-mobile-mode="auto"] .gazlog-aib-scroll,
    .gazlog-aib-v2[data-mobile-mode="card"] .gazlog-aib-scroll { display: none; }
    .gazlog-aib-v2[data-mobile-mode="auto"] .gazlog-aib-cards,
    .gazlog-aib-v2[data-mobile-mode="card"] .gazlog-aib-cards { display: flex; }
    .gazlog-aib-top3-grid { grid-template-columns: 1fr; }
    .gazlog-aib-toolbar { padding: 8px 0; }
    .gazlog-aib-search-wrap { max-width: none; }
    .gazlog-aib-v2 { padding: 12px; }
    .gazlog-aib-title { font-size: 17px; }
}
@media (min-width: 769px) {
    .gazlog-aib-v2 .gazlog-aib-cards { display: none !important; }
    .gazlog-aib-v2[data-mobile-mode="card"] .gazlog-aib-cards { display: flex !important; }
    .gazlog-aib-v2[data-mobile-mode="card"] .gazlog-aib-scroll { display: none; }
}
