/* ============================================================
   P-FINDER — LIGHT THEME OVERRIDE LAYER
   ============================================================
   目的: 既存テンプレ/CSS は色をダークでハードコードしている
   (#17161B, #1E1B2A, rgba(167,139,250,*) 等)。トークン化前の
   それらを「白基調×オレンジ」へ最小差分で上書きする。
   - style.css / pf-design.css の後に読み込む (詳細度+後勝ちで上書き)。
   - JS フック/ID/構造には一切触れない。見た目のみ。
   - パチンコ慣習の出玉色 (プラス=赤 / マイナス=青) は不変。
   ============================================================ */

/* === ページ地・本文 ============================================ */
html { background: var(--pf-bg-base); }
body {
  background: var(--pf-bg-base);
  color: var(--pf-text-1);
}
/* FOUC 用の先行背景もライトへ (base.html の #pf-anti-fouc を上書き) */
html.pf-loading { background: var(--pf-bg-base); }

/* ============================================================
   HEADER (白・上部固定)
   ============================================================ */
.pf-header {
  background: rgba(255,255,255,0.92) !important;
  border-bottom: 1px solid var(--pf-border-subtle) !important;
  box-shadow: var(--pf-shadow-2);
}
.pf-logo { color: var(--pf-text-1); }
/* ロゴ文字: デザイン案準拠でダーク単色 */
.pf-logo-title {
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  color: var(--pf-text-1) !important;
}
.pf-logo-sub { color: var(--pf-text-3); }
.pf-nav-link { color: var(--pf-text-2); }
.pf-nav-link:hover { background: var(--pf-brand-soft); color: var(--pf-brand); }
/* ハンバーガー(≡): 設計SPヘッダ準拠 = オレンジの線のみ・箱なし。
   線をオレンジ #FD6710、地は透明。フォーカス時の大きなオレンジ枠
   (global :focus-visible の outline2px + glow4px) が「箱」に見える問題を抑制し、
   タップ/フォーカス後も控えめな丸い淡オレンジ地のみにする。 */
.pf-nav-menu { color: #FD6710; background: transparent; }
.pf-nav-menu svg { stroke: #FD6710; color: #FD6710; }
.pf-nav-menu:hover { background: rgba(253,103,16,0.10); }
.pf-nav-menu:focus,
.pf-nav-menu:focus-visible {
  outline: none;
  box-shadow: none;
  background: rgba(253,103,16,0.10);
}
@media (max-width: 900px) {
  .pf-nav-menu { background: transparent; }
  .pf-nav-menu:hover,
  .pf-nav-menu:focus,
  .pf-nav-menu:focus-visible { background: rgba(253,103,16,0.10); }
}

/* 戻るボタン (_header.html 内の固定色) */
.pf-back-btn {
  background: var(--pf-brand-soft) !important;
  border: 1px solid var(--pf-brand-line) !important;
  color: var(--pf-brand) !important;
}
.pf-back-btn:hover {
  background: rgba(249,115,22,0.16) !important;
  border-color: var(--pf-brand) !important;
  color: var(--pf-brand-deep) !important;
}

/* ============================================================
   AUTH SLOT (ヘッダ右の認証 UI)
   ============================================================ */
.pf-auth-skeleton {
  background: linear-gradient(90deg, #ECECEF 25%, #F6F6F7 50%, #ECECEF 75%) !important;
  background-size: 200% 100% !important;
}
.pf-auth-btn-mini.is-login {
  background: transparent;
  color: var(--pf-brand);
  border: 1px solid var(--pf-brand-line);
}
.pf-auth-btn-mini.is-login:hover { background: var(--pf-brand-soft); color: var(--pf-brand-deep); }
.pf-auth-btn-mini.is-signup {
  background: linear-gradient(135deg, var(--pf-brand-strong), var(--pf-brand));
  color: #fff;
}
.pf-auth-user {
  background: var(--pf-bg-elev);
  border: 1px solid var(--pf-border-default);
  color: var(--pf-text-1);
}
.pf-auth-user:hover { border-color: var(--pf-brand); background: var(--pf-brand-soft); }
.pf-auth-user-avatar {
  background: linear-gradient(135deg, var(--pf-brand-strong), var(--pf-brand)) !important;
  color: #fff !important;
}

/* ============================================================
   DRAWER (ハンバーガーメニュー)
   ============================================================ */
.pf-drawer { background: var(--pf-bg-card) !important; box-shadow: -4px 0 24px rgba(0,0,0,0.10) !important; }
.pf-drawer-overlay { background: rgba(0,0,0,0.35) !important; }
.pf-drawer-head { color: var(--pf-text-3); border-bottom: 1px solid var(--pf-border-subtle); }
.pf-drawer a { color: var(--pf-text-1); }
.pf-drawer a:hover { background: var(--pf-brand-soft); color: var(--pf-brand); }
.pf-drawer a.is-active {
  background: var(--pf-brand-soft);
  color: var(--pf-brand);
  border: 1px solid var(--pf-brand-line);
}
/* drawer 認証ボックス */
.pf-drawer-auth {
  background: var(--pf-brand-soft) !important;
  border: 1px solid var(--pf-brand-line) !important;
}
.pf-da-guest-title { color: var(--pf-brand-deep); }
.pf-da-guest-msg, .pf-da-user-email { color: var(--pf-text-3); }
.pf-da-user-avatar { background: linear-gradient(135deg, var(--pf-brand-strong), var(--pf-brand)); color: #fff; }
.pf-da-user-name { color: var(--pf-text-1); }
.pf-da-user-actions a, .pf-da-user-actions button {
  background: var(--pf-bg-elev); border: 1px solid var(--pf-border-default); color: var(--pf-brand);
}
.pf-da-user-actions a:hover { background: var(--pf-brand-soft); color: var(--pf-brand-deep); }

/* ============================================================
   HERO / 検索 (index トップ — 今回主対象外だが崩れ防止)
   ============================================================ */
.pf-hero, .pf-hero-v2 {
  background:
    radial-gradient(ellipse at 20% 50%, rgba(249,115,22,0.08), transparent 60%),
    radial-gradient(ellipse at 80% 50%, rgba(249,115,22,0.05), transparent 60%),
    var(--pf-bg-card) !important;
  border-bottom: 1px solid var(--pf-border-subtle) !important;
}
.pf-hero-title, .pf-hero-title-v2 { color: var(--pf-text-1) !important; }
.pf-hero-sub { color: var(--pf-text-3) !important; }

/* ============================================================
   FOOTER
   ============================================================ */
.pf-footer {
  background: var(--pf-bg-card) !important;
  border-top: 1px solid var(--pf-border-subtle) !important;
  color: var(--pf-text-3);
}
.pf-footer-head { color: var(--pf-text-2); }
.pf-footer-col a, .pf-keyword-chips a { color: var(--pf-text-3); }
.pf-footer-col a:hover, .pf-keyword-chips a:hover { color: var(--pf-brand); }
.pf-footer-copy { color: var(--pf-text-3); }
.pf-data-freshness {
  background: var(--pf-brand-soft); border: 1px solid var(--pf-border-default); color: var(--pf-text-3);
}

/* ============================================================
   汎用: ダーク固定の "面" を白系へ寄せる安全網
   (個別テンプレ <style> の主要クラスを横断上書き)
   ============================================================ */
.pf-section-title { color: var(--pf-text-1); }
.pf-section-more, .pf-c-section-action { color: var(--pf-brand); }
.pf-loading, .pf-empty { color: var(--pf-text-3); }
.pf-empty-state-title { color: var(--pf-text-2); }
.pf-empty-state-desc { color: var(--pf-text-3); }

/* back-to-top フローティング */
.pf-back-to-top {
  background: rgba(255,255,255,0.92) !important;
  border: 1px solid var(--pf-border-default) !important;
  color: var(--pf-brand) !important;
  box-shadow: var(--pf-shadow-3) !important;
}
.pf-back-to-top:hover { background: #fff !important; border-color: var(--pf-brand) !important; }

/* タグ (pf-tag) — ダーク前提の淡色地をライトへ */
.pf-tag { background: var(--pf-bg-elev); color: var(--pf-text-2); border: 1px solid var(--pf-border-subtle); }
.pf-tag.is-warning { background: var(--pf-warn-soft); color: #B26A00; }
.pf-tag.is-success { background: var(--pf-success-soft); color: #15803D; }
.pf-tag.is-muted   { background: var(--pf-bg-elev); color: var(--pf-text-3); }
.pf-tag.is-p { background: var(--pf-ps-p-soft); color: #A16207; }
.pf-tag.is-s { background: var(--pf-ps-s-soft); color: #1D4ED8; }

/* 出玉プラス/マイナス (慣習: 赤/青) — 念のため固定 */
.positive, .pf-hall-delta.positive { color: var(--pf-positive) !important; }
.negative, .pf-hall-delta.negative { color: var(--pf-negative) !important; }

/* ============================================================
   COMMON SHELL — モバイルファースト共通シェル
   上部タブ「AIナビ｜ホーム」 + 下部固定タブバー (5等分)
   .pf-shell-page を付けたページ (収支/AIナビ) で
   中央寄せ max-width 430px + 下部タブ分の余白を有効化。
   ============================================================ */

/* --- 上部タブ「AIナビ｜ホーム」 --- */
.pf-toptabs {
  background: var(--pf-bg-card);
  border-bottom: 1px solid var(--pf-border-subtle);
}
.pf-toptabs-inner {
  max-width: 430px;
  margin: 0 auto;
  display: flex;
}
.pf-toptab {
  flex: 1;
  text-align: center;
  padding: 13px 8px 11px;
  font-size: 14px;
  font-weight: 800;
  color: var(--pf-text-3);
  text-decoration: none;
  position: relative;
  transition: color var(--pf-dur-1) var(--pf-ease);
}
.pf-toptab::after {
  content: "";
  position: absolute;
  left: 50%; bottom: -1px;
  width: 0; height: 3px;
  background: var(--pf-brand);
  border-radius: 3px 3px 0 0;
  transform: translateX(-50%);
  transition: width var(--pf-dur-2) var(--pf-ease-out);
}
.pf-toptab:hover { color: var(--pf-text-1); }
.pf-toptab.is-active { color: var(--pf-brand); }
.pf-toptab.is-active::after { width: 56px; }

/* --- ページ本体を中央寄せ (430px) --- */
.pf-shell-page .pf-main,
.pf-shell-page .nearby-shell {
  max-width: 430px;
  margin-left: auto;
  margin-right: auto;
}
.pf-shell-page .pf-container { max-width: 430px; }
/* AIナビ (/ai_mode) は body.ai-mode-noscroll / simple モードで
   旧 max-width(1100px/760px) が当たり、フル幅化していた。
   共通シェルとして 430px の中央カラムを最優先で強制する。 */
html .pf-shell-page .nearby-shell,
html[data-pf-mode="simple"] .pf-shell-page .nearby-shell,
body.ai-mode-noscroll .pf-shell-page .nearby-shell {
  max-width: 430px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
/* 下部タブバー (固定高 ~62px) と被らない余白 */
.pf-shell-page { padding-bottom: calc(64px + env(safe-area-inset-bottom, 0px)); }

/* --- 下部固定タブバー (白・5等分) --- */
.pf-bottom-nav {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 120;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-top: 1px solid var(--pf-border-subtle);
  box-shadow: 0 -1px 3px rgba(0,0,0,0.06);
  padding-bottom: env(safe-area-inset-bottom, 0px);
}
/* 中身は 430px 幅に収め、両脇は白で埋める (PCでも中央寄せ表示) */
.pf-bottom-nav {
  padding-left: max(0px, calc((100% - 430px) / 2));
  padding-right: max(0px, calc((100% - 430px) / 2));
}
.pf-bn-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 8px 2px 7px;
  color: var(--pf-text-3);
  text-decoration: none;
  font-weight: 700;
  transition: color var(--pf-dur-1) var(--pf-ease);
  min-height: 56px;
}
.pf-bn-ico { display: block; fill: var(--pf-brand); }
.pf-bn-label { font-size: 10px; line-height: 1; letter-spacing: -0.01em; }
.pf-bn-item:hover { color: var(--pf-text-1); }
.pf-bn-item.is-active { color: var(--pf-brand); }
.pf-bn-item.is-active .pf-bn-ico { fill: var(--pf-brand); }

/* simple モードでは下部タブを隠す (AI 専用最小表示と整合) */
html[data-pf-mode="simple"] .pf-bottom-nav,
html[data-pf-mode="simple"] .pf-toptabs { display: none !important; }

/* 注: 901-1099px でヘッダー横ナビとボトムナビが同時表示される崩れの修正は、
   外部CSS(asset_v依存=デプロイ反映が遅い)ではなく _pf_bottomnav.html のインライン
   <style>(テンプレ=即時反映)に置いた。重複を避けるためここには置かない。 */
