/* ============================================
   Beach Page 専用CSS
   プレフィックス: .bp- で他ページへの影響を防止
   ============================================ */

/* --- リセット・ベース --- */
.bp-wrap {font-feature-settings: "palt"; }
.bp-inner {  }

/* --- ヘッダーナビ --- */
.bp-topnav { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 16px 24px; border-bottom: 1px solid #cbd5e1; }
.bp-topnav-logo { font-size: 13px; letter-spacing: 0.28em; color: #64748b; }
.bp-topnav-links { display: flex; gap: 32px; font-size: 14px; color: #475569; }
.bp-topnav-links a { color: inherit; text-decoration: none; transition: color .2s; }
.bp-topnav-links a:hover { color: #1e293b; }

/* --- ヒーローセクション --- */
.bp-hero { display: grid; border-bottom: 1px solid #cbd5e1;margin-top: 9px; }
.bp-hero-main { position: relative; min-height: auto; background: linear-gradient(135deg, #5a9ec7 0%, #7bb8d9 28%, #d8e8f0 28%, #d8e8f0 46%, #6baad0 46%, #2c7eb9 100%); border-bottom: 1px solid #cbd5e1; }
.bp-hero-main.has-photo { background-size: cover; background-position: center; }
.bp-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(255,255,255,0.68), rgba(255,255,255,0.08)); transition: opacity .3s; }
.bp-hero-content { position: relative; display: flex; flex-direction: column; justify-content: center; height: 100%; min-height: auto; padding: 24px; transition: opacity .3s; }
.bp-hero-area { font-size: 12px; letter-spacing: 0.24em; color: #334155; }
.bp-hero-title { font-size: clamp(1.4rem, 3.5vw, 2.2rem); font-weight: bold; letter-spacing: 0.08em; color: #020617; margin: 0; line-height: 1.2; text-shadow: 0 1px 3px rgba(255,255,255,0.8), 0 0 12px rgba(255,255,255,0.5); }
.bp-hero-desc { margin-top: 20px; max-width: 560px; font-size: 14px; line-height: 2; color: #000; text-shadow: 0 1px 2px rgba(255,255,255,0.7), 0 0 8px rgba(255,255,255,0.4); }
.bp-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.bp-badge { border: 1px solid #2c7eb9; padding: 3px 10px; font-size: 10px; letter-spacing: 0.12em; color: #fff; background: #2c7eb9; font-weight: bold; }


/* --- ヒーロー写真サムネイル --- */
.bp-hero-thumbs { position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%); display: flex; gap: 6px; z-index: 2; }
.bp-hero-thumb { width: 56px; height: 40px; border-radius: 4px; overflow: hidden; cursor: pointer; border: 2px solid rgba(255,255,255,0.5); opacity: 0.7; transition: opacity .2s, border-color .2s; }
.bp-hero-thumb.active { border-color: #fff; opacity: 1; }
.bp-hero-thumb:hover { opacity: 1; }
.bp-hero-thumb img { width: 100%; height: 100%; object-fit: cover; }

/* --- ヒーロー右パネル --- */
.bp-hero-side { display: grid; grid-template-rows: auto auto 1fr; }
.bp-quick-summary { padding: 20px 24px 20px; border-bottom: 1px solid #cbd5e1; border-top: 1px solid #cbd5e1; }
.bp-quick-summary-top { display: flex; align-items: center; justify-content: space-between; }
.bp-label-en { font-size: 11px; text-transform: uppercase; letter-spacing: 0.28em; color: #64748b; }
.bp-rating { display: flex; align-items: center; gap: 8px; margin-top: 8px; }
.bp-rating-score { font-size: 14px; font-weight: bold; }
.bp-rating-count { font-size: 14px; color: #64748b; }
.bp-update-tag { border: 1px solid #94a3b8; padding: 8px 12px; font-size: 12px; letter-spacing: 0.14em; color: #334155; }

/* --- シーズン情報 --- */
.bp-season { background: #f0f7fc; padding: 24px; border-bottom: 1px solid #cbd5e1; display: flex; align-items: flex-start; gap: 16px; }
.bp-season-icon { border: 1px solid #cbd5e1; padding: 12px; display: flex; align-items: center; justify-content: center; }
.bp-season-icon svg { width: 20px; height: 20px; color: #334155; }
.bp-season-label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.22em; color: #64748b; }
.bp-season-period { font-size: 1.5rem; font-weight: bold; letter-spacing: 0.05em; color: #1e293b; margin-top: 8px; }
.bp-season-note { font-size: 14px; line-height: 2; color: #475569; margin-top: 8px; }

/* --- 設備グリッド（ヒーロー内） --- */
.bp-facility-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; }
.bp-facility-cell { padding: 12px 16px; border-bottom: 1px solid #cbd5e1; border-right: 1px solid #cbd5e1; text-align: center; }
.bp-facility-cell:nth-child(3n) { border-right: none; }
.bp-facility-cell svg { width: 28px; height: 28px; color: #475569; display: block; margin: 0 auto; }
.bp-facility-label { font-size: 12px; letter-spacing: 0.18em; color: #64748b; margin: 8px 0; }
.bp-facility-value { font-size: 14px; font-weight: bold; color: #1e293b; margin-top: 4px; line-height: 1.2; }

/* --- セクション共通 --- */
.bp-section { padding: 24px; border-bottom: 1px solid #cbd5e1; }
.bp-section-header { display: flex; align-items: end; justify-content: space-between; border-bottom: 3px solid #2c7eb9; padding:0 0 12px 5px; margin-bottom: 20px; }
.bp-section-title { font-size: 20px; font-weight: bold; letter-spacing: 0.08em; margin-top: 4px; }
.bp-section-actions { display: flex; gap: 12px; }

/* --- ボタン --- */
.bp-btn { border: 1px solid #94a3b8; padding: 8px 16px; font-size: 14px; color: #334155; background: transparent; cursor: pointer; transition: all .2s; text-decoration: none; display: inline-block; text-align: center; }
.bp-btn:hover { background: #2c7eb9; color: #fff; }
.bp-btn-block { display: block; width: 100%; padding: 12px 16px; }

/* --- ステータスカード（6列） --- */
.bp-status-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.bp-status-card { border: 1px solid #cbd5e1; background: #f5fafd; padding: 16px; text-align: center; }
.bp-status-card-header { display: flex; align-items: center; justify-content: center; gap: 8px; color: #64748b; }
.bp-status-card-header svg { width: 16px; height: 16px; }
.bp-status-card-header span { font-size: 12px; letter-spacing: 0.16em; }
.bp-status-card-value { font-size: 20px; font-weight: bold; letter-spacing: 0.04em; color: #1e293b; margin-top: 16px; }

/* --- 撮影タイミング --- */
.bp-photo-note { margin-top: 16px; border: 1px solid #cbd5e1; background: #fff; padding: 16px; font-size: 14px; line-height: 2; color: #475569; }

/* --- 2カラムセクション --- */
.bp-split { display: grid; border-bottom: 1px solid #cbd5e1; }
.bp-split-left { padding: 24px; border-bottom: 1px solid #cbd5e1; }
.bp-split-right { padding: 24px; }

/* --- 概要グリッド --- */
.bp-overview-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 32px; }
.bp-overview-item { border: 1px solid #cbd5e1; padding: 16px; }
.bp-overview-item-label { font-size: 12px; letter-spacing: 0.16em; color: #64748b; }
.bp-overview-item-value { font-size: 14px; line-height: 2; color: #1e293b; margin-top: 12px; }
.bp-overview-text { margin-top: 24px; font-size: 14px; line-height: 2.2; color: #334155; }

/* --- ギャラリー --- */
.bp-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: #cbd5e1; }
.bp-gallery-item { min-height: 180px; background: linear-gradient(135deg, #7bb3d4, #d4e4ed, #2c7eb9); display: flex; align-items: flex-end; padding: 20px; color: #fff; position: relative; overflow: hidden; }
.bp-gallery-item img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.bp-gallery-item-inner { position: relative; z-index: 1; }
.bp-gallery-item-en { font-size: 11px; text-transform: uppercase; letter-spacing: 0.22em; color: rgba(255,255,255,0.8); }
.bp-gallery-item-title { font-size: 18px; font-weight: bold; letter-spacing: 0.06em; margin-top: 8px; }

/* --- 設備・楽しみ方 --- */
.bp-facility-list { display: grid; gap: 16px; margin-top: 24px; }
.bp-facility-row { display: flex; gap: 16px; border: 1px solid #cbd5e1; padding: 16px; }
.bp-facility-row svg { width: 20px; height: 20px; color: #475569; flex-shrink: 0; margin-top: 2px; }
.bp-facility-row-title { font-size: 14px; font-weight: bold; letter-spacing: 0.08em; color: #1e293b; }
.bp-facility-row-text { font-size: 14px; line-height: 2; color: #475569; margin-top: 8px; }

.bp-play-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 24px; }
.bp-play-card { border: 1px solid #cbd5e1; background: #f5fafd; padding: 20px; }
.bp-play-card svg { width: 20px; height: 20px; color: #475569; }
.bp-play-card-title { font-size: 18px; font-weight: bold; letter-spacing: 0.05em; color: #1e293b; margin-top: 16px; }
.bp-play-card-text { font-size: 14px; line-height: 2; color: #475569; margin-top: 12px; }

/* --- アクセス --- */
.bp-access-info { margin-top: 24px; }
.bp-access-item { margin-bottom: 20px; }
.bp-access-label { font-size: 12px; letter-spacing: 0.18em; color: #64748b; }
.bp-access-value { font-size: 16px; color: #1e293b; margin-top: 8px; line-height: 2; }
.bp-map-placeholder { min-height: 280px; border: 1px solid #cbd5e1; background: linear-gradient(135deg, #f4f1ea, #d7d2c7, #e8edf0); display: flex; align-items: center; justify-content: center; }
.bp-map-placeholder-inner { text-align: center; color: #475569; }
.bp-map-placeholder-inner svg { width: 32px; height: 32px; margin: 0 auto; }

/* --- 周辺スポット --- */
.bp-nearby-list { display: grid; gap: 0; margin-top: 15px; }
.bp-nearby-item { display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid #cbd5e1; padding: 8px 16px; text-decoration: none; color: inherit; transition: background .2s; }
.bp-nearby-item:first-child { border-top: 1px solid #cbd5e1; }
.bp-nearby-item:hover { background: #f0f7fc; }
.bp-nearby-item-left { display: flex; align-items: center; gap: 16px; }
.bp-nearby-item-left > svg { width: 20px; height: 20px; color: #475569; }
.bp-nearby-item-title { font-size: 14px; font-weight: bold; letter-spacing: 0.06em; color: #1e293b; }
.bp-nearby-item-dist { font-size: 12px; letter-spacing: 0.14em; color: #64748b; margin: 1px 0 3px; }

/* --- FAQ --- */
.bp-faq-list { display: grid; gap: 16px; margin-top: 24px; }
.bp-faq-item { border: 1px solid #cbd5e1; padding: 20px; }
.bp-faq-q { font-size: 14px; font-weight: bold; letter-spacing: 0.06em; color: #1e293b; }
.bp-faq-a { font-size: 14px; line-height: 2; color: #475569; margin-top: 12px; }

/* --- CTA --- */
.bp-cta { padding: 40px 24px; }
.bp-cta-box { border: 1px solid #2c7eb9; background: #f0f7fc; padding: 24px; display: grid; gap: 24px; }
.bp-cta-title { font-size: 1.5rem; font-weight: bold; letter-spacing: 0.08em; color: #1e293b; margin-top: 8px; }
.bp-cta-text { font-size: 14px; line-height: 2; color: #475569; margin-top: 16px; max-width: 640px; }
.bp-cta-actions { display: grid; gap: 12px; }

/* --- 安全情報 --- */
.bp-safety { background: #fef9f0; border: 1px solid #fbbf24; padding: 20px; margin-top: 24px; border-radius: 0; }
.bp-safety-title { font-size: 15px; font-weight: bold; color: #92400e; display: flex; align-items: center; gap: 8px; }
.bp-safety-text { font-size: 14px; line-height: 2; color: #78350f; margin-top: 12px; }

/* --- 水質バッジ --- */
.bp-quality { display: inline-block; padding: 2px 10px; font-size: 13px; font-weight: bold; letter-spacing: 0.08em; }
.bp-quality-aa { background: #e0f0ff; color: #2c7eb9; }
.bp-quality-a { background: #dcfce7; color: #166534; }
.bp-quality-b { background: #fef9c3; color: #854d0e; }

/* --- 星評価 --- */
.bp-stars { display: inline-flex; gap: 2px; font-size: 16px; color: #2c7eb9; }
.bp-stars-empty { color: #e2e8f0; }

/* ============================================
   レスポンシブ
   ============================================ */

/* ============================================
   Beach List Page 専用CSS（追加分）
   ============================================ */

/* --- ヒーロー（一覧版） --- */
.bp-list-hero { display: grid; border-bottom: 1px solid #cbd5e1; }
.bp-list-hero-left { background: #f0f7fc; padding: 24px; border-bottom: 1px solid #cbd5e1; }
.bp-list-hero-title { font-size: clamp(2rem, 5vw, 3.75rem); font-weight: bold; letter-spacing: 0.08em; color: #020617; margin: 20px 0 0; line-height: 1.2; }
.bp-list-hero-desc { margin-top: 20px; max-width: 640px; font-size: 14px; line-height: 2; color: #334155; }
.bp-summary-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 32px; }

/* --- サマリーカード --- */
.bp-summary-card { border: 1px solid #cbd5e1; background: #fff; padding: 16px; }
.bp-summary-card-label { font-size: 12px; letter-spacing: 0.16em; color: #64748b; }
.bp-summary-card-value { font-size: 1.5rem; font-weight: bold; letter-spacing: 0.04em; color: #1e293b; margin-top: 12px; }

/* --- 検索パネル --- */
.bp-search-box { display: flex; align-items: center; gap: 12px; border: 1px solid #cbd5e1; padding: 16px; margin-top: 24px; }
.bp-search-box svg { width: 20px; height: 20px; color: #64748b; flex-shrink: 0; }
.bp-search-box input { width: 100%; background: transparent; border: none; outline: none; font-size: 14px; color: #1e293b; }
.bp-search-box input::placeholder { color: #94a3b8; }

.bp-filter-group { border: 1px solid #cbd5e1; padding: 16px; margin-top: 16px; }
.bp-filter-group-header { display: flex; align-items: center; gap: 8px; color: #475569; margin-bottom: 12px; }
.bp-filter-group-header svg { width: 16px; height: 16px; }
.bp-filter-group-title { font-size: 14px; font-weight: bold; letter-spacing: 0.08em; color: #1e293b; }
.bp-filter-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.bp-filter-tag { border: 1px solid #94a3b8; padding: 8px 12px; font-size: 12px; letter-spacing: 0.12em; color: #334155; background: transparent; cursor: pointer; transition: all .2s; }
.bp-filter-tag:hover, .bp-filter-tag.active { background: #2c7eb9; color: #fff; }

/* --- 統計バー --- */
.bp-stat-bar { display: grid; gap: 16px; }
.bp-stat-bar-map { border: 1px solid #cbd5e1; background: #f0f7fc; padding: 20px; }
.bp-stat-bar-map-title { font-size: 18px; font-weight: bold; letter-spacing: 0.04em; color: #1e293b; margin-top: 12px; }
.bp-stat-bar-map-text { font-size: 14px; line-height: 2; color: #475569; margin-top: 12px; }
.bp-stat-bar-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.bp-stat-card { border: 1px solid #cbd5e1; background: #fff; padding: 16px; }
.bp-stat-card svg { width: 20px; height: 20px; color: #475569; }
.bp-stat-card-label { font-size: 12px; letter-spacing: 0.16em; color: #64748b; margin-top: 12px; }
.bp-stat-card-value { font-size: 20px; font-weight: bold; color: #1e293b; margin-top: 8px; }

/* --- ビーチカード --- */
.bp-beach-card { display: grid; border: 1px solid #cbd5e1; background: #fff; }
.bp-beach-card-visual { border-bottom: 1px solid #cbd5e1; min-height: 200px; display: flex; flex-direction: column; justify-content: space-between; padding: 20px; }
.bp-beach-card-visual.has-photo { background: linear-gradient(135deg, #5a9ec7 0%, #7bb8d9 25%, #d8e8f0 25%, #d8e8f0 42%, #6baad0 42%, #2c7eb9 100%); }
.bp-beach-card-visual.no-photo { background: #f0f7fc; }
.bp-beach-card-visual-top { display: flex; align-items: center; justify-content: space-between; font-size: 12px; letter-spacing: 0.16em; color: #334155; }
.bp-beach-card-visual-top svg { width: 16px; height: 16px; }
.bp-beach-card-visual-en { font-size: 11px; text-transform: uppercase; letter-spacing: 0.24em; color: #334155; }
.bp-beach-card-visual-name { font-size: 1.5rem; font-weight: bold; letter-spacing: 0.06em; color: #020617; margin-top: 8px; }
.bp-beach-card-visual-area { font-size: 14px; color: #334155; margin-top: 8px; }

.bp-beach-card-body { padding: 20px; }
.bp-beach-card-rating { display: flex; align-items: center; gap: 8px; font-size: 14px; color: #475569; }
.bp-beach-card-rating svg { width: 16px; height: 16px; }
.bp-beach-card-rating strong { color: #1e293b; font-weight: bold; }
.bp-beach-card-desc { font-size: 14px; line-height: 2; color: #334155; margin-top: 16px; }

/* --- カード内メタグリッド --- */
.bp-beach-card-meta { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; border: 1px solid #cbd5e1; background: #cbd5e1; margin-top: 16px; }
.bp-beach-card-meta-cell { background: #f5fafd; padding: 16px; }
.bp-beach-card-meta-header { display: flex; align-items: center; gap: 8px; color: #64748b; }
.bp-beach-card-meta-header svg { width: 16px; height: 16px; }
.bp-beach-card-meta-header span { font-size: 12px; letter-spacing: 0.16em; }
.bp-beach-card-meta-value { font-size: 14px; font-weight: bold; color: #1e293b; margin-top: 12px; line-height: 1.6; }

/* --- カード内アクション --- */
.bp-beach-card-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 20px; padding-top: 20px; border-top: 1px solid #cbd5e1; }
.bp-beach-card-actions .bp-btn { display: flex; align-items: center; justify-content: center; gap: 8px; min-width: 140px; padding: 12px 16px; }
.bp-beach-card-actions .bp-btn svg { width: 16px; height: 16px; }

/* --- 結果ヘッダー --- */
.bp-list-header { display: flex; flex-direction: row; align-items: flex-end; justify-content: space-between; gap: 16px; padding-bottom: 16px; border-bottom: 1px solid #cbd5e1; margin-bottom: 24px; }
.bp-list-header-title { font-size: 20px; font-weight: bold; letter-spacing: 0.08em; color: #1e293b; margin-top: 4px; padding: 0 5px; white-space: nowrap; }
.bp-list-header-options { display: flex; flex-wrap: wrap; gap: 8px; font-size: 12px; letter-spacing: 0.12em; color: #475569; }
.bp-list-header-opt { border: 1px solid #94a3b8; padding: 8px 12px; }

/* --- ガイドカード --- */
.bp-guide-grid { display: grid; gap: 16px; }
.bp-guide-card { border: 1px solid #cbd5e1; background: #f0f7fc; padding: 20px; }
.bp-guide-card-en { font-size: 11px; text-transform: uppercase; letter-spacing: 0.22em; color: #64748b; }
.bp-guide-card-title { font-size: 18px; font-weight: bold; letter-spacing: 0.05em; color: #1e293b; margin-top: 8px; }
.bp-guide-card-text { font-size: 14px; line-height: 2; color: #475569; margin-top: 12px; }

/* --- リスト用カード一覧 --- */
.bp-beach-list { display: grid; gap: 24px; }

/* --- レスポンシブ（一覧追加分） --- */

/* マーカーCSS */
.bp-marker{position:relative;width:44px;height:56px;}
.bp-marker-pin{position:absolute;top:0;left:0;width:44px;height:56px;}
.bp-marker-img{position:absolute;top:5px;left:7px;width:30px;height:30px;border-radius:50%;object-fit:cover;}

/* Leaflet divIconのデフォルトスタイルをリセット */
.leaflet-div-icon { background: none !important; border: none !important; }
.bp-marker-img { z-index: 1; }
.bp-marker-pin { z-index: 0; }
.bp-marker-img { z-index: 2; position: absolute; top: 5px; left: 7px; width: 30px; height: 30px; border-radius: 50%; object-fit: cover; }

/* 一覧カードリンク */
.bp-beach-card-link:hover .bp-beach-card { border-color: #2c7eb9; box-shadow: 0 2px 8px rgba(44,126,185,0.15); }

/* ============================================
   グリッドカード（Bタイプ一覧）
   ============================================ */
.bp-grid-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.bp-grid-card { border: 1px solid #cbd5e1; background: #fff; overflow: hidden; text-decoration: none; color: inherit; transition: box-shadow .2s, border-color .2s; display: block; }
.bp-grid-card:hover { box-shadow: 0 4px 12px rgba(44,126,185,0.15); border-color: #2c7eb9; }
.bp-grid-card-img { height: 180px; background-size: cover; background-position: center; background-color: #f0f7fc; position: relative; }
.bp-grid-badges { position: absolute; bottom: 10px; left: 10px; display: flex; gap: 4px; flex-wrap: wrap; }
.bp-grid-badge { background: rgba(255,255,255,0.92); padding: 3px 10px; font-size: 11px; font-weight: bold; color: #1e293b; border-radius: 3px; }
.bp-grid-card-body { padding: 14px; }
.bp-grid-card-name { font-size: 16px; font-weight: bold; color: #1e293b; }
.bp-grid-card-area { font-size: 11px; color: #64748b; margin-top: 4px; }
.bp-grid-card-review { margin-top: 8px; display: flex; align-items: center; gap: 4px; }
.bp-grid-card-desc { font-size: 12px; line-height: 1.7; color: #475569; margin-top: 8px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* ===== Cタイプヒーロー（左マップ+右テキスト） ===== */
.bp-list-hero-c { display: grid; grid-template-columns: 1fr 1fr; border-bottom: 1px solid #cbd5e1; }
.bp-lhc-map { min-height: 350px; }
.bp-lhc-legend { display: flex; gap: 10px; padding: 6px 10px; background: #f8fafc; border-top: 1px solid #e2e8f0; flex-wrap: wrap; }
.bp-lhc-legend span { display: flex; align-items: center; gap: 4px; font-size: 10px; color: #64748b; }
.bp-lhc-body { padding: 32px; display: flex; flex-direction: column; justify-content: center; }
.bp-lhc-sub { font-size: 11px; letter-spacing: 0.2em; color: #2c7eb9; text-transform: uppercase; }
.bp-lhc-title { font-size: 28px; font-weight: bold; color: #1e293b; margin: 8px 0 0; line-height: 1.3; }
.bp-lhc-desc { font-size: 13px; line-height: 1.8; color: #475569; margin-top: 12px; }
.bp-lhc-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-top: 16px; }
.bp-lhc-stat { text-align: center; }
.bp-lhc-stat-num { font-size: 20px; font-weight: bold; color: #1e293b; }
.bp-lhc-stat-label { font-size: 11px; color: #64748b; margin-top: 2px; }
.bp-lhc-search { display: flex; margin-top: 16px; }
.bp-lhc-search input { flex: 1; padding: 9px 12px; font-size: 13px; border: 1px solid #e2e8f0; border-radius: 4px 0 0 4px; outline: none; }
.bp-lhc-search button { padding: 9px 16px; font-size: 13px; background: #2c7eb9; color: #fff; border: none; border-radius: 0 4px 4px 0; cursor: pointer; font-weight: bold; }
.bp-lhc-filters { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 6px; margin-top: 8px; }
.bp-lhc-filters select { padding: 7px 8px; font-size: 12px; border: 1px solid #e2e8f0; color: #475569; }

/* Cタイプヒーロー レスポンシブ */

.bp-nearby-glass { padding: 24px; background: rgba(255,255,255,0.8); backdrop-filter: blur(12px); }

.bp-nearby-tabs { display: grid; grid-template-columns: repeat(6, 1fr); gap: 0; margin-bottom: 16px; }
.bp-nearby-tabs label { display: block; }
.bp-nearby-tabs .bp-filter-tag { display: block; text-align: center; width: 100%; box-sizing: border-box; border-radius: 0; }

/* アクセス PC/SP出し分け */
.bp-access-sp { display: none; }

.bp-access-label svg { color: #2c7eb9; }
.bp-access-label { display: flex; align-items: center; gap: 4px; }

/* About もっと見る（CSSのみ・スマホのみ） */
.bp-about-toggle { display: none; }
.bp-about-more { display: none; }

.bp-about-text { line-height: 1.6; } .bp-about-text p { font-size: 15px; color: #334155; margin: 0; }

/* Hタイプ: 今日の状況（左天気大+右2列グリッド） */
.bp-today-h { display: grid; grid-template-columns: 200px 1fr; border: 1px solid #e2e8f0; }
.bp-today-h-main { padding: 20px; text-align: center; display: flex; flex-direction: column; align-items: center; justify-content: center; border-right: 1px solid #e2e8f0; background: #f5fafd; }
.bp-today-h-name { font-size: 20px; font-weight: bold; color: #1e293b; margin-top: 4px; }
.bp-today-h-temp { font-size: 14px; margin-top: 8px; }
.bp-today-h-rain { font-size: 11px; color: #64748b; margin-top: 6px; }
.bp-today-h-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.bp-today-h-cell { padding: 12px; text-align: center; border-bottom: 1px solid #e2e8f0; border-right: 1px solid #e2e8f0; }
.bp-today-h-cell:nth-child(2n) { border-right: none; }
.bp-today-h-label { font-size: 9px; color: #94a3b8; }
.bp-today-h-value { font-size: 14px; font-weight: bold; color: #1e293b; margin-top: 4px; }

.bp-nearby-item-title { display: flex; align-items: center; flex-wrap: wrap; gap: 4px; }

/* トップページヒーロー レスポンシブ */

/* シーズン早見表 */
.bp-season-chart { border: 1px solid #e2e8f0; }
.bp-sc-row { display: grid; grid-template-columns: 80px repeat(12, 1fr); gap: 0; }
.bp-sc-header { font-size: 11px; color: #64748b; text-align: center; font-weight: bold; }
.bp-sc-header > div { padding: 5px 0; border-bottom: 1px solid #e2e8f0; }
.bp-sc-label { font-size: 11px; font-weight: bold; color: #1e293b; text-align: center; padding: 4px 4px; border-bottom: 1px solid #e2e8f0; line-height: 1.1; }
.bp-sc-cell { border-bottom: 1px solid #e2e8f0; border-right: 1px solid #f0f0f0; padding: 2px; display: flex; align-items: center; justify-content: center; min-height: 28px; }
.bp-sc-cell:last-child { border-right: none; }
.bp-sc-peak { background: #0B3D5E; height: 18px; width: 100%; }
.bp-sc-shoulder { background: #2c7eb9; height: 18px; width: 100%; }
.bp-sc-edge { background: #2c7eb9; opacity: 0.4; height: 18px; width: 100%; }

/* ============================================
   トップページ クラス化CSS
   ============================================ */
/* ヒーロー */
.bp-top-hero { background: url(/img/beach/hero_bg.jpg) center/cover no-repeat; padding: 60px 24px 50px; text-align: center; color: #fff; position: relative; }
.bp-top-hero::before { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: rgba(11, 61, 94, 0.21); }
.bp-top-hero > * { position: relative; z-index: 1; }
.bp-top-title { font-size: 22px; font-weight: bold; margin: 6px 0 8px; color: #fff; }
.bp-top-desc { font-size: 13px; color: rgba(255,255,255,0.8); margin: 0 0 16px; }
/* 統計 */
.bp-top-stats { display: flex; gap: 16px; justify-content: center; margin-bottom: 20px; }
.bp-top-stat-num { font-size: 24px; font-weight: bold; color: #fff; }
.bp-top-stat-label { font-size: 11px; color: rgba(255,255,255,0.7); margin-top: 2px; }
/* 検索 */
.bp-top-search { display: flex; max-width: 420px; margin: 0 auto; }
.bp-top-search input { flex: 1; padding: 10px 14px; font-size: 14px; border: none; border-radius: 4px 0 0 4px; outline: none; }
.bp-top-search button { padding: 10px 20px; font-size: 14px; background: #f59e0b; color: #fff; border: none; border-radius: 0 4px 4px 0; cursor: pointer; font-weight: bold; }
/* 人気カード */
.bp-top-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin: 20px 0; }
.bp-top-card { display: block; border: 1px solid #e2e8f0; text-decoration: none; color: inherit; overflow: hidden; }
.bp-top-card-img { height: 140px; background: #e2e8f0 center/cover no-repeat; }
.bp-top-card-body { padding: 10px 12px; }
.bp-top-card-name { font-size: 14px; font-weight: bold; color: #1e293b; }
.bp-top-card-area { font-size: 12px; color: #64748b; margin-top: 4px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

.bp-top-en { font-size: 10px; letter-spacing: 0.4em; opacity: 0.6; }
.bp-top-search-results { margin-top: 16px; }
.bp-top-no-results { padding: 20px; color: #64748b; }
.bp-top-area-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; margin-top: 16px; }
.bp-top-area-card { border: 1px solid #e2e8f0; padding: 10px; }
.bp-top-area-name { font-size: 13px; font-weight: bold; color: #2c7eb9; margin-bottom: 6px; }
.bp-top-area-link { font-size: 13px; color: #1e293b; text-decoration: none; display: inline-block; margin: 2px 3px; }
.bp-top-area-link:hover { color: #2c7eb9; }
.bp-top-area-count { font-size: 10px; color: #64748b; margin-left: 2px; }
.bp-top-rank-tabs { display: flex; gap: 0; margin-bottom: 16px; }
.bp-top-rank-num { font-size: 16px; font-weight: bold; min-width: 24px; text-align: center; }
.bp-top-rank-area { font-size: 12px; color: #64748b; }
.bp-top-rank-desc { font-size: 11px; color: #64748b; margin-top: 2px; line-height: 1.4; }
.bp-sc-legend { display: flex; gap: 14px; margin: 10px 0 0; align-items: center; flex-wrap: wrap; font-size: 11px; color: #64748b; }
.bp-sc-legend-item { display: flex; align-items: center; gap: 5px; }
.bp-sc-legend-peak { width: 14px; height: 10px; background: #0B3D5E; }
.bp-sc-legend-shoulder { width: 14px; height: 10px; background: #2c7eb9; }
.bp-sc-legend-edge { width: 14px; height: 10px; background: #2c7eb9; opacity: 0.4; }
.bp-sc-temp-guide { margin-top: 12px; padding: 10px; }
.bp-sc-temp-title { font-size: 12px; font-weight: bold; margin: 0; }
.bp-sc-temp-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin-top: 8px; }
.bp-sc-temp-card { text-align: center; padding: 6px; border: 1px solid #e2e8f0; }
.bp-sc-temp-value { font-size: 15px; font-weight: bold; margin: 0; }
.bp-sc-temp-label { font-size: 11px; color: #64748b; margin: 2px 0 0; }
.bp-top-note { font-size: 11px; color: #94a3b8; margin: 8px 0 0; }
.bp-top-sec-desc { font-size: 13px; color: #475569; margin-bottom: 14px; }
.bp-top-wq-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin-bottom: 14px; }
.bp-top-sub-title { font-size: 14px; font-weight: bold; margin: 0 0 6px; }
.bp-top-info-box { background: #f5fafd; padding: 12px; margin-bottom: 12px; }
.bp-top-info-text { font-size: 12px; color: #475569; margin: 0 0 8px; }
.bp-top-trans-bar { height: 32px; background: linear-gradient(to right, #e0f0ff, #fef9c3, #fee2e2); margin-bottom: 4px; }
.bp-top-trans-labels { display: flex; justify-content: space-between; font-size: 11px; color: #64748b; }
.bp-top-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.bp-top-kaisui-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 4px; margin-bottom: 12px; }
.bp-top-three-col { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }

/* ===== トップページ: ランキングタブ ===== */
.bp-rank-tab-btn { display: inline-block; padding: 6px 14px; font-size: 13px; border: 1px solid #e2e8f0; cursor: pointer; background: #fff; color: #64748b; }
.bp-rank-tab-btn.active { background: #2c7eb9; color: #fff; border-color: #2c7eb9; font-weight: bold; }
.bp-list-mt0 { margin-top: 0; }
.bp-sc-label-bold { font-weight: bold; }
.bp-sc-temp-span { font-size: 11px; color: #94a3b8; }

/* ===== トップページ: 水質カード ===== */
.bp-top-wq-card { text-align: center; padding: 10px 6px; }
.bp-top-wq-rank { font-size: 22px; font-weight: bold; margin: 0; }
.bp-top-wq-label { font-size: 11px; margin: 2px 0 0; }
.bp-top-wq-aa { background: #e0f0ff; }
.bp-top-wq-aa .bp-top-wq-rank,
.bp-top-wq-aa .bp-top-wq-label { color: #2c7eb9; }
.bp-top-wq-a { background: #dcfce7; }
.bp-top-wq-a .bp-top-wq-rank,
.bp-top-wq-a .bp-top-wq-label { color: #16a34a; }
.bp-top-wq-b { background: #fef9c3; }
.bp-top-wq-b .bp-top-wq-rank,
.bp-top-wq-b .bp-top-wq-label { color: #ca8a04; }
.bp-top-wq-c { background: #fee2e2; }
.bp-top-wq-c .bp-top-wq-rank,
.bp-top-wq-c .bp-top-wq-label { color: #dc2626; }

/* ===== トップページ: 水質情報カード ===== */
.bp-top-info-card { background: #f5fafd; padding: 10px 12px; border-radius: 6px; }
.bp-top-info-card-title { font-size: 13px; font-weight: bold; margin: 0 0 4px; }
.bp-top-info-card-text { font-size: 12px; color: #475569; margin: 0; line-height: 1.5; }

/* ===== トップページ: 快水浴場百選カード ===== */
.bp-top-kaisui-card { text-align: center; }
.bp-top-kaisui-star { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 18px; margin: 0 auto 4px; }
.bp-top-kaisui-name { font-size: 13px; font-weight: bold; margin: 0; }
.bp-top-kaisui-sub { font-size: 11px; color: #94a3b8; margin: 2px 0 0; }
.bp-top-kaisui-beautiful { background: #e0f0ff; color: #2c7eb9; }
.bp-top-kaisui-clean { background: #dcfce7; color: #16a34a; }
.bp-top-kaisui-peaceful { background: #ccfbf1; color: #0d9488; }
.bp-top-kaisui-gentle { background: #fef3c7; color: #d97706; }
.bp-top-kaisui-rich { background: #ffedd5; color: #ea580c; }

/* ===== トップページ: 安全ガイドカード ===== */
.bp-top-guide-card { background: #f5fafd; padding: 10px 12px; border-radius: 6px; }
.bp-top-guide-title { font-size: 13px; font-weight: bold; margin: 0 0 4px; }
.bp-top-guide-text { font-size: 12px; color: #475569; margin: 0; line-height: 1.5; }

/* ===== トップページ: 特集カード ===== */
.bp-top-special-card { background: #f5fafd; padding: 10px 12px; border-radius: 6px; }
.bp-top-special-title { font-size: 13px; font-weight: bold; margin: 0 0 4px; }
.bp-top-special-text { font-size: 12px; color: #475569; margin: 0; line-height: 1.5; }

/* ===== トップページ: 水温カラー ===== */
.bp-sc-temp-cold { color: #2c7eb9; }
.bp-sc-temp-cool { color: #16a34a; }
.bp-sc-temp-comfortable { color: #ca8a04; }
.bp-sc-temp-warm { color: #dc2626; }

/* ===== 水質ランク色（共通） ===== */
.bp-wq-aa { background: #e0f0ff; color: #2c7eb9; border-color: #2c7eb9; }
.bp-wq-a { background: #dcfce7; color: #16a34a; border-color: #16a34a; }
.bp-wq-b { background: #fef9c3; color: #ca8a04; border-color: #ca8a04; }
.bp-wq-c { background: #fee2e2; color: #dc2626; border-color: #dc2626; }
.bp-wq-other { background: #f1f5f9; color: #64748b; border-color: #94a3b8; }
/* バッジ用（詳細ページ bp-badge） */
.bp-badge.bp-wq-aa,
.bp-badge.bp-wq-a,
.bp-badge.bp-wq-b,
.bp-badge.bp-wq-c,
.bp-badge.bp-wq-other { font-weight: bold; }
/* グリッドバッジ用（一覧ページ bp-grid-badge） */
.bp-grid-badge.bp-wq-aa,
.bp-grid-badge.bp-wq-a,
.bp-grid-badge.bp-wq-b,
.bp-grid-badge.bp-wq-c,
.bp-grid-badge.bp-wq-other { font-weight: bold; }
/* 水質テキスト用（詳細ページ ステータスカード内） */
.bp-wq-text-aa { color: #2c7eb9; }
.bp-wq-text-a { color: #16a34a; }
.bp-wq-text-b { color: #ca8a04; }
.bp-wq-text-c { color: #dc2626; }
.bp-wq-text-other { color: #64748b; }

/* ===== 詳細ページ: 快水浴場百選パターンA ===== */
.bp-kaisui-section-head { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.bp-kaisui-section-title { font-size: 15px; font-weight: bold; margin: 0; }
.bp-kaisui-section-sub { font-size: 11px; color: #94a3b8; }
.bp-kaisui-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; }
.bp-kaisui-card { text-align: center; padding: 12px 4px; }
.bp-kaisui-card-score { font-size: 22px; font-weight: bold; }
.bp-kaisui-card-score span { font-size: 12px; }
.bp-kaisui-card-label { font-size: 11px; font-weight: bold; margin-top: 4px; }
.bp-kaisui-card-sub { font-size: 10px; color: #94a3b8; margin-top: 2px; }
.bp-kaisui-source { text-align: right; margin-top: 8px; }
.bp-kaisui-source a { font-size: 10px; color: #94a3b8; }
/* 詳細ページ快水浴場百選 COLOR 6 */
.bp-kaisui-beautiful { background: #e0f0ff; }
.bp-kaisui-beautiful .bp-kaisui-card-score { color: #1a5a8a; }
.bp-kaisui-beautiful .bp-kaisui-card-label { color: #2c7eb9; }
.bp-kaisui-clean { background: #dcfce7; }
.bp-kaisui-clean .bp-kaisui-card-score { color: #0d7a35; }
.bp-kaisui-clean .bp-kaisui-card-label { color: #16a34a; }
.bp-kaisui-peaceful { background: #ccfbf1; }
.bp-kaisui-peaceful .bp-kaisui-card-score { color: #0f766e; }
.bp-kaisui-peaceful .bp-kaisui-card-label { color: #0d9488; }
.bp-kaisui-gentle { background: #fef3c7; }
.bp-kaisui-gentle .bp-kaisui-card-score { color: #b45309; }
.bp-kaisui-gentle .bp-kaisui-card-label { color: #d97706; }
.bp-kaisui-rich { background: #ffedd5; }
.bp-kaisui-rich .bp-kaisui-card-score { color: #c2410c; }
.bp-kaisui-rich .bp-kaisui-card-label { color: #ea580c; }

/* ===== 詳細ページ: 快水浴場百選 帯型（パターンE） ===== */
.bp-kaisui-band { background: #f5fafd; padding: 10px 16px; border: 1px solid #e2e8f0; border-top: none; margin-bottom: 0; }
.bp-kaisui-band-inner { display: flex; align-items: center; gap: 14px; }
.bp-kaisui-band-badge { font-size: 12px; font-weight: bold; color: #2c7eb9; white-space: nowrap; line-height: 1.4; }
.bp-kaisui-band-badge-sub { display: block; font-size: 10px; color: #333; }
.bp-kaisui-band-items { display: flex; gap: 10px; flex: 1; }
.bp-kaisui-band-item { text-align: center; flex: 1; padding: 3px 0; }
.bp-kaisui-band-score { font-size: 16px; font-weight: bold; }
.bp-kaisui-band-score span { font-size: 10px; }
.bp-kaisui-band-label { font-size: 10px; font-weight: bold; margin-top: 1px; }
/* 帯型の色（COLOR 6） */
.bp-kaisui-band-item.bp-kaisui-beautiful .bp-kaisui-band-score { color: #1a5a8a; }
.bp-kaisui-band-item.bp-kaisui-beautiful .bp-kaisui-band-label { color: #2c7eb9; }
.bp-kaisui-band-item.bp-kaisui-clean .bp-kaisui-band-score { color: #0d7a35; }
.bp-kaisui-band-item.bp-kaisui-clean .bp-kaisui-band-label { color: #16a34a; }
.bp-kaisui-band-item.bp-kaisui-peaceful .bp-kaisui-band-score { color: #0f766e; }
.bp-kaisui-band-item.bp-kaisui-peaceful .bp-kaisui-band-label { color: #0d9488; }
.bp-kaisui-band-item.bp-kaisui-gentle .bp-kaisui-band-score { color: #b45309; }
.bp-kaisui-band-item.bp-kaisui-gentle .bp-kaisui-band-label { color: #d97706; }
.bp-kaisui-band-item.bp-kaisui-rich .bp-kaisui-band-score { color: #c2410c; }
.bp-kaisui-band-item.bp-kaisui-rich .bp-kaisui-band-label { color: #ea580c; }
.bp-kaisui-source { text-align: right; margin: 2px 0 -20px; }

/* ===== 安全・快適ガイド アコーディオン ===== */
.beach-guide { max-width: 100%; margin: 0; padding: 0; }
.beach-guide-sub { font-size: 14px; color: #666; margin: 0 0 20px; }
.beach-guide-item { border-bottom: 1px solid #e0e0e0; }
.beach-guide-item:first-child { border-top: 1px solid #e0e0e0; }
.beach-guide-header { display: flex; align-items: center; gap: 12px; padding: 16px 0 16px 8px; cursor: pointer; user-select: none; background: none; border: none; width: 100%; text-align: left; font-family: inherit; }
.beach-guide-header:hover .beach-guide-title { color: #1a6b9c; }
.beach-guide-icon { width: 40px; height: 40px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.beach-guide-icon svg { width: 20px; height: 20px; }
.beach-guide-title { flex: 1; font-size: 16px; font-weight: bold; color: #1a1a1a; transition: color 0.15s; margin: 0; }
.beach-guide-arrow { width: 20px; height: 20px; flex-shrink: 0; margin-right: 10px; transition: transform 0.25s ease; color: #999; }
.beach-guide-item.is-open .beach-guide-arrow { transform: rotate(180deg); }
.beach-guide-body { overflow: hidden; max-height: 0; transition: max-height 0.35s ease; }
.beach-guide-item.is-open .beach-guide-body { max-height: 3000px; }
.beach-guide-inner { padding: 0 0 24px 52px; }
.beach-guide-inner p { font-size: 15px; color: #444; line-height: 1.8; margin: 0 0 14px; }
.beach-guide-inner p:last-child { margin-bottom: 0; }
.beach-guide-h3 { font-size: 15px; font-weight: bold; color: #0B3D5E; margin: 20px 0 8px; padding: 0; }
.beach-guide-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin: 12px 0; }
.beach-guide-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; margin: 12px 0; }
.beach-guide-card { padding: 12px 14px; background: #f7f7f5; border: none; }
.beach-guide-card-title { font-size: 14px; font-weight: bold; color: #1a1a1a; margin: 0 0 4px; }
.beach-guide-card-desc { font-size: 13px; color: #666; line-height: 1.6; margin: 0; }
.beach-guide-warn { padding: 12px 14px; background: #FEF3F2; border-left: 3px solid #E24B4A; margin: 14px 0; font-size: 14px; color: #791F1F; line-height: 1.7; }
.beach-guide-tip { padding: 12px 14px; background: #EFF8FF; border-left: 3px solid #1a6b9c; margin: 14px 0; font-size: 14px; color: #0C447C; line-height: 1.7; }
.beach-guide-link { display: inline-flex; align-items: center; gap: 4px; color: #1a6b9c; font-size: 14px; text-decoration: none; margin-top: 8px; font-weight: bold; }
.beach-guide-link:hover { text-decoration: underline; }
.beach-guide-checklist { list-style: none; padding: 0; margin: 10px 0; }
.beach-guide-checklist li { font-size: 14px; color: #444; padding: 5px 0 5px 28px; position: relative; line-height: 1.6; }
.beach-guide-checklist li::before { content: ""; position: absolute; left: 0; top: 9px; width: 16px; height: 16px; border: 1.5px solid #ccc; }
.beach-guide-tag { display: inline-block; font-size: 11px; padding: 2px 8px; margin: 4px 4px 0 0; background: #f0f0ee; color: #666; }
.beach-guide-tag--danger { background: #FEF3F2; color: #A32D2D; }

/* ============================================
   レスポンシブ
   ============================================ */

@media screen and (min-width: 1024px) {
  .bp-hero { grid-template-columns: 1.2fr 0.8fr; }
  .bp-hero-main { border-bottom: none; border-right: 1px solid #cbd5e1; }
  .bp-hero-content { padding: 40px; }
  .bp-section { padding: 13px 0px 24px; }
  .bp-split { grid-template-columns: 1fr 1fr; }
  #access.bp-split { grid-template-columns: 0.65fr 1.35fr; }
  .bp-split-left { border-bottom: none; border-right: 1px solid #cbd5e1; padding: 25px; }
  .bp-split-right { padding: 40px; }
  .bp-split.ratio-9-11 { grid-template-columns: 0.9fr 1.1fr; }
  .bp-split.ratio-8-12 { grid-template-columns: 0.8fr 1.2fr; }
  .bp-split.ratio-11-9 { grid-template-columns: 1.1fr 0.9fr; }
  .bp-status-grid { grid-template-columns: repeat(5, 1fr); }
  .bp-cta-box { grid-template-columns: 1fr auto; align-items: center; padding: 32px; }
  .bp-cta-actions { min-width: 220px; }
  .bp-section-actions-mobile { display: none; }
  .bp-list-hero { grid-template-columns: 1.05fr 0.95fr; }
  .bp-list-hero-left { border-bottom: none; border-right: 1px solid #cbd5e1; padding: 40px; }
  .bp-list-hero-right { padding: 40px; }
  .bp-summary-grid { grid-template-columns: repeat(4, 1fr); }
  .bp-stat-bar { grid-template-columns: 0.75fr 1.25fr; }
  .bp-stat-bar-cards { grid-template-columns: repeat(4, 1fr); }
  .bp-beach-card { grid-template-columns: 260px 1fr; }
  .bp-beach-card-visual { border-bottom: none; border-right: 1px solid #cbd5e1; }
  .bp-list-header { flex-direction: row; align-items: flex-end; justify-content: space-between; }
  .bp-guide-grid { grid-template-columns: repeat(3, 1fr); }
}

@media screen and (max-width: 1023px) {
  .bp-hero { grid-template-columns: 1fr; }
  .bp-split { grid-template-columns: 1fr; }
  .bp-gallery { grid-template-columns: repeat(2, 1fr); }
  .bp-play-grid { grid-template-columns: 1fr; }
  .bp-overview-grid { grid-template-columns: 1fr; }
  .bp-section-actions-pc { display: none; }
  .bp-topnav-links { display: none; }
  .bp-hero-content { padding: 24px; }
  .bp-hero-desc { font-size: 13px; }
  .bp-grid-list { grid-template-columns: repeat(2, 1fr); }
}

@media screen and (max-width: 768px) {
  .bp-list-hero-c { grid-template-columns: 1fr; }
  .bp-list-hero-c .bp-lhc-map { min-height: 250px; }
  .bp-lhc-body { padding: 15px 10px; }
  .bp-top-hero { grid-template-columns: 1fr !important; }
  .bp-top-hero #top-map { min-height: 250px !important; }
  .bp-top-cards { grid-template-columns: 1fr; }
  .bp-top-card-img { height: 180px; }
  .bp-top-stats { gap: 12px; }
  .bp-top-stat-num { font-size: 20px; }
}

@media screen and (max-width: 640px) {
  .bp-status-grid { grid-template-columns: repeat(2, 1fr); }
  .bp-gallery { grid-template-columns: 1fr 1fr; }
  .bp-beach-card-meta { grid-template-columns: 1fr; }
  .bp-beach-card-actions { flex-direction: column; }
  .bp-beach-card-actions .bp-btn { width: 100%; }
  .bp-stat-bar-cards { grid-template-columns: 1fr 1fr; }
  .bp-grid-list { grid-template-columns: 1fr; }
  .bp-facility-label { font-size: 10px; }
  .bp-facility-value { font-size: 12px; }
  .bp-facility-cell { padding: 5px 5px; }
  .bp-hero-content { height: 60vw; padding-bottom: 52px; }
  .bp-lhc-br { display: none; }
  .bp-list-header-title { white-space: nowrap; font-size: 16px; }
  .bp-hero-thumbs { bottom: 8px; gap: 4px; }
  .bp-hero-thumb { width: 44px; height: 32px; }
  .bp-quick-summary { padding: 12px 24px; }
  .bp-season { padding: 12px 24px; }
  .bp-season-period { font-size: 18px; }
  .bp-season-note { font-size: 12px; }
  .bp-section { padding: 24px 0px; }
  .bp-split-left { padding: 24px 0px; }
  .bp-nearby-glass { padding: 5px 0px 24px; }
  .bp-nearby-tabs { grid-template-columns: repeat(3, 1fr); }
  .bp-nearby-tabs .bp-filter-tag { font-size: 11px; padding: 11px 4px; font-weight: bold; }
  .bp-access-pc { display: none; }
  .bp-access-sp {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid #e2e8f0;
  border-radius: 0;
  overflow: hidden;
  }
  .bp-access-sp-item {
  padding: 10px 12px;
  border-bottom: 1px solid #e2e8f0;
  display: flex;
  align-items: center;
  gap: 8px;
  }
  .bp-access-sp-item:nth-child(odd) { border-right: 1px solid #e2e8f0; }
  .bp-access-sp-item > svg { width: 16px; height: 16px; color: #2c7eb9; flex-shrink: 0; }
  .bp-access-sp-text { font-size: 12px; }
  .bp-access-sp-label { color: #94a3b8; font-size: 9px; }
  .bp-access-sp-value { color: #1e293b; font-weight: bold; line-height: 1.3; }
  .bp-access-sp-value a { color: #2c7eb9; text-decoration: none; }
  .bp-about-text {
  max-height: calc(1.6em * 5); line-height: 1.6;
  overflow: hidden;
  position: relative;
  transition: max-height .3s ease;
  }
  .bp-about-text::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 40px;
  background: linear-gradient(transparent, #fff);
  transition: opacity .3s;
  }
  .bp-about-more {
  display: block;
  text-align: center;
  padding: 8px;
  font-size: 13px;
  color: #2c7eb9;
  font-weight: bold;
  cursor: pointer;
  border-top: 1px solid #e2e8f0;
  }
  .bp-about-more::after { content: 'もっと見る ▼'; }
  .bp-about-toggle:checked ~ .bp-about-text {
  max-height: 2000px;
  }
  .bp-about-toggle:checked ~ .bp-about-text::after {
  opacity: 0;
  }
  .bp-about-toggle:checked ~ .bp-about-more::after {
  content: '閉じる ▲';
  }
  .bp-about-text p { font-size: 14px; }
  .bp-today-h { grid-template-columns: 1fr; }
  .bp-today-h-main { border-right: none; border-bottom: 1px solid #e2e8f0; padding: 16px; }
  .bp-today-h-main img { width: 40px; height: 40px; }
  .bp-today-h-name { font-size: 16px; }
  .bp-sc-row { grid-template-columns: 60px repeat(12, 1fr); }
  .bp-sc-label { font-size: 10px; padding: 4px 2px; }
  .bp-sc-header { font-size: 9px; }
  .bp-top-two-col { grid-template-columns: 1fr; }
  .bp-top-three-col { grid-template-columns: 1fr; }
  .bp-top-kaisui-grid { grid-template-columns: repeat(3, 1fr); }
  .bp-sc-temp-grid { grid-template-columns: repeat(2, 1fr); }
  .bp-kaisui-grid { grid-template-columns: repeat(3, 1fr); }
  .bp-kaisui-band-inner { flex-direction: column; gap: 8px; align-items: flex-start; }
  .bp-kaisui-band-badge { display: flex; gap: 6px; align-items: baseline; }
  .bp-kaisui-band-badge-sub { display: inline; }
  .bp-kaisui-band-items { width: 100%; }
}

@media (max-width: 600px) {
  .beach-guide-grid, .beach-guide-grid-3 { grid-template-columns: 1fr; }
  .beach-guide-inner { padding: 0 0 24px 0; }
}
