/* =============================================================
 * pages/rank_access.css
 * 週間アクセスランキング ページ (/rank/access/)
 * legacy: pc_rank.css (.rank_access_title) + 二段組レイアウト互換
 * ============================================================= */

/* ===== Page Heading ===== */
.page-heading--ranking {
  --page-heading-accent: #2d9fda;
  --page-heading-accent-rgb: 45, 159, 218;
  --page-heading-accent-d: #1c79b8;
  --page-heading-accent-l: #e6f8ff;
  --page-heading-ink: #163b56;
  --page-heading-line: rgba(45, 159, 218, .46);
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .50) 0%, rgba(255, 255, 255, .86) 42%, rgba(232, 248, 255, .72) 100%),
    url('/images/bg/ranking.png') repeat center top,
    #f5fcff;
  border-top: 8px solid #3296da;
  border-bottom-color: rgba(45, 159, 218, .36);
}
.page-heading--ranking .page-heading__title {
  color: #1c79b8;
  font-size: 2rem;
  font-weight: 900;
}
.page-heading--ranking .page-heading__period {
  margin: 0;
  color: var(--sc-text-2);
  font-size: var(--fs-base);
  font-weight: 800;
  line-height: 1.45;
}
.page-heading--ranking .page-heading__lead {
  color: var(--sc-text);
}
.page-heading--ranking .page-heading__badge {
  color: #1c79b8;
  background: rgba(255, 255, 255, .82);
  border-color: rgba(45, 159, 218, .30);
}
.page-heading--ranking .page-heading__badge::before {
  background: linear-gradient(90deg, #2d9fda 0%, #00afd5 58%, #7ed8ef 100%);
}
.page-heading--ranking::before {
  background: linear-gradient(90deg, #2d9fda 0%, #00afd5 66%, #7ed8ef 100%);
}
@media (max-width: 767px) {
  .page-heading--ranking .page-heading__title {
    font-size: 1.38rem;
  }
  .page-heading--ranking .page-heading__period {
    font-size: var(--fs-sm);
  }
}

/* ===== SP 限定: おすすめスライダー (見えてる 1 枚) ===== */
.rank-access-sp-recommend { margin-bottom: var(--sp-4); }
.rank-access-sp-recommend__title {
  margin: 0 0 var(--sp-2);
  font-size: var(--fs-base);
  font-weight: 800;
  color: var(--sc-accent-d);
  padding-bottom: var(--sp-1);
  border-bottom: 2px solid var(--sc-primary);
}
.rank-access-sp-recommend__swiper {
  border-radius: var(--r-md);
  overflow: hidden;
}
.rank-access-mini-card {
  display: flex;
  align-items: stretch;
  gap: var(--sp-3);
  padding: var(--sp-2);
  background: #fff;
  border: 1px solid var(--sc-border);
  border-radius: var(--r-md);
  color: var(--sc-text);
  text-decoration: none;
  box-shadow: var(--sh-1);
}
.rank-access-mini-card__thumb {
  flex: 0 0 96px;
  width: 96px;
  aspect-ratio: 1 / 1;
  border-radius: var(--r-sm);
  overflow: hidden;
  background: var(--sc-bg-alt);
}
.rank-access-mini-card__thumb img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.rank-access-mini-card__thumb .no-image {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%; color: var(--sc-text-3);
}
.rank-access-mini-card__body {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
  justify-content: center;
}
.rank-access-mini-card__name {
  font-size: var(--fs-sm);
  font-weight: 700;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.rank-access-mini-card__loc,
.rank-access-mini-card__access {
  font-size: var(--fs-xs);
  color: var(--sc-text-2);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* メイン: ランキング一覧 (一覧 .bld-card を流用)
   .bld-card-grid 自体は search.blade.php 内の <style> スコープでしか定義されていないため、
   ここで同等の grid 定義を再宣言。
   ─ SP 1 列
   ─ PC (≥768px) 2 列。サイドバーが横並びになっても main 内で 2 列を維持。 */
.rank-access-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  column-gap: var(--sp-3);
  row-gap: var(--sp-6);
}
@media (min-width: 768px) {
  .rank-access-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
.rank-access-grid__cell { min-width: 0; display: flex; }
.rank-access-grid__cell > .bld-card { flex: 1 1 auto; width: 100%; }

/* 2 列レイアウト + サイドバーありで main 幅が狭くなる ranking ページでは、
   料金行 (例: "20,000円〜50,000円") が改行されがちなので、
   フォントを少しだけ小さく + 料金は nowrap で強制 1 行に。
   写真サイズは元の 180px のまま (一覧と統一)。 */
.rank-access-grid .bld-card__price-block  { font-size: var(--fs-xs); }
.rank-access-grid .bld-card__price-line   { white-space: nowrap; }
.rank-access-grid .bld-card__price-amount { font-size: var(--fs-xs); }
.rank-access-grid .bld-card__rooms        { font-size: var(--fs-xs); }

/* ===== このページだけ「ランクバッジ」を画像の左上にはみ出させて配置 =====
   一覧 (.bld-card) のデフォルトより少し大きめだが、極端に大きくはせず、
   写真フレームの外側に少し飛び出させて存在感を出す。
   スコープを .rank-access-grid 直下に限定し、検索一覧 (.bld-card-grid) には影響させない。
   ─ overflow: visible で写真コンテナをはみ出し許可
   ─ 画像自体はもともと object-fit:cover で枠いっぱいなので border-radius は写真コンテナ側に依存
     (はみ出しの代わりに drop-shadow を強めて切れ目を演出) */
.rank-access-grid .bld-card__photo { overflow: visible; }
.rank-access-grid .bld-card__photo > a {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: var(--r-sm);
  overflow: hidden;
}
.rank-access-grid .bld-card__rank {
  top: -6px;
  left: -6px;
  padding: 4px 11px 4px 10px;
  gap: 5px;
  box-shadow:
    0 6px 14px rgba(0, 0, 0, .4),
    inset 0 -2px 4px rgba(0, 0, 0, .25),
    inset 0 2px 4px rgba(255, 255, 255, .35);
}
.rank-access-grid .bld-card__rank-icon  { font-size: 14px; }
.rank-access-grid .bld-card__rank-label { font-size: 10px; }
.rank-access-grid .bld-card__rank-num   { font-size: 16px; }
/* メダル (1〜3 位) はやや大きく + より強い影で立体感 */
.rank-access-grid .bld-card__rank--medal {
  padding: 5px 13px 5px 12px;
}
.rank-access-grid .bld-card__rank--medal .bld-card__rank-num  { font-size: 20px; }
.rank-access-grid .bld-card__rank--medal .bld-card__rank-icon { font-size: 16px; }

/* サイドバー / ボディ / バナーのレイアウトは page-sidebar-layout.css に集約 */
