@import url('../../theme.css');

/* ============================================================
   施設カード（テキストリスト型）
   ============================================================ */
.facility-card {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
}
.facility-card:hover { background: rgba(123,163,204,.06); }

.facility-card__link {
  display: block;
  text-decoration: none;
  color: inherit;
  padding: var(--space-5) var(--space-6);
}

.facility-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.facility-card__location {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 4px;
  letter-spacing: .02em;
}
.facility-card__sep { opacity: .4; }

.facility-card__title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: var(--color-text);
  margin: 0;
  transition: color var(--transition-fast);
}
.facility-card:hover .facility-card__title { color: var(--color-primary); }

.facility-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.facility-card__tag {
  display: inline-block;
  padding: 3px 12px;
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  border: 1px solid rgba(14,47,86,.2);
  background: rgba(123,163,204,.1);
  color: var(--color-primary);
}
.facility-card__tag--onsen {
  border-color: rgba(192,98,42,.25);
  background: rgba(192,98,42,.05);
  color: #b85020;
}

.facility-card__footer {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-top: var(--space-1);
}

.facility-card__badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 11px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: 11px;
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
}
.facility-card__badge--stay {
  border-color: rgba(80,60,120,.25);
  color: #5a4080;
  background: rgba(80,60,120,.04);
}

.facility-card__price {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
}

/* ============================================================
   施設グリッド（リスト）
   ============================================================ */
.facility-grid {
  display: flex;
  flex-direction: column;
  margin: 0;
}

/* /facility/ アーカイブページのみカード間に余白を追加 */
.post-type-archive-facility .facility-grid {
  gap: var(--space-3);
}
.post-type-archive-facility .facility-card {
  border-bottom: none;
  box-shadow: var(--shadow-sm);
}

/* 施設詳細ページ「関連コラム」セクション */
.facility-related-articles {
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border);
}
.facility-related-articles__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-6);
}
.facility-related-articles__card {
  text-decoration: none;
  color: inherit;
}

/* 施設詳細ページ「近くの温泉施設」のカード間余白 */
.facility-nearby .facility-grid {
  gap: var(--space-3);
}
.facility-nearby .facility-card {
  border-bottom: none;
  box-shadow: var(--shadow-sm);
}

/* ============================================================
   アーカイブツールバー（件数 + ソート）
   ============================================================ */
.archive-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.archive-total { margin: 0; font-size: var(--font-size-sm); color: var(--color-text-muted); }

.facility-sort {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.facility-sort__label {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  white-space: nowrap;
}

.facility-sort__btns {
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
}

.facility-sort__btn {
  display: inline-block;
  padding: 4px var(--space-3);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--transition-fast), background var(--transition-fast), border-color var(--transition-fast);
}

.facility-sort__btn:hover {
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.facility-sort__btn.is-active {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}

@media (max-width: 600px) {
  .archive-toolbar { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   施設詳細 ヒーロー
   ============================================================ */
.facility-hero {
  position: relative;
  min-height: 480px;
  display: flex;
  align-items: flex-end;
  background: linear-gradient(160deg, #071a19 0%, #0f3532 60%, #1a5250 100%);
}
.facility-hero__bg {
  position: absolute; inset: 0; overflow: hidden;
}
.facility-hero__img {
  width: 100%; height: 100%; object-fit: cover; opacity: .75;
}
.facility-hero__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,.08) 0%,
    rgba(4,16,15,.45) 35%,
    rgba(6,20,18,.88) 100%
  );
}
.facility-hero__content {
  position: relative;
  z-index: 1;
  color: #fff;
  padding-top: var(--space-20);
  padding-bottom: var(--space-12);
  width: 100%;
}
.facility-hero__breadcrumb {
  display: flex; align-items: center; flex-wrap: wrap; gap: 6px;
  font-size: 12px;
  color: rgba(255,255,255,.45);
  margin-bottom: var(--space-4);
}
.facility-hero__breadcrumb a {
  color: rgba(255,255,255,.55); text-decoration: none;
  transition: color var(--transition-fast);
}
.facility-hero__breadcrumb a:hover { color: #fff; }
.facility-hero__location {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,.55);
  margin-bottom: var(--space-3);
  letter-spacing: .04em;
}
.facility-hero__title {
  font-family: var(--font-heading);
  font-size: clamp(1.9rem, 4.5vw, 3.2rem);
  line-height: 1.18;
  letter-spacing: -.02em;
  margin-bottom: var(--space-8);
}
.facility-hero__tags {
  display: flex; flex-wrap: wrap; gap: var(--space-2);
  margin-bottom: var(--space-6);
}
.facility-hero__tag {
  display: inline-block;
  padding: 6px 16px;
  border: 1.5px solid rgba(255,255,255,.4);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: rgba(255,255,255,.9);
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(6px);
  text-decoration: none;
  transition: background var(--transition-fast), border-color var(--transition-fast);
}
.facility-hero__tag:hover {
  background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.7); color: #fff;
}
.facility-hero__tag--onsen {
  border-color: rgba(255,180,120,.5);
  background: rgba(255,150,80,.1);
  color: rgba(255,200,160,.95);
}
.facility-hero__tag--onsen:hover {
  background: rgba(255,150,80,.22); border-color: rgba(255,180,120,.8); color: #fff;
}
.facility-hero__tag--quality {
  border-color: rgba(232,220,200,.5);
  background: rgba(232,220,200,.08);
  color: rgba(232,220,200,.9);
}
.facility-hero__actions { display: flex; align-items: center; gap: var(--space-3); }

/* ヒーロー内お気に入りボタン */
.favorite-btn--hero {
  background: rgba(255,255,255,.08);
  border: 1.5px solid rgba(255,255,255,.38);
  color: rgba(255,255,255,.8);
  backdrop-filter: blur(6px);
  border-radius: var(--radius-full);
  padding: 9px var(--space-6);
  font-size: var(--font-size-sm);
}
.favorite-btn--hero:hover {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.65);
  color: #fff;
}
.favorite-btn--hero.favorite-btn--active {
  background: rgba(224,92,139,.2);
  border-color: rgba(224,92,139,.65);
  color: #ffb3cf;
}

/* ============================================================
   施設詳細ページ フルワイドレイアウト
   ============================================================ */
.facility-page {
  padding-top: var(--space-10);
  padding-bottom: var(--space-20);
}

/* ============================================================
   特徴タグセクション
   ============================================================ */
.facility-tags-section {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-12);
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}

.facility-tags-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-5);
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--color-border);
}
.facility-tags-row:last-child { border-bottom: none; }

.facility-tags-row__label {
  flex-shrink: 0;
  width: 5.5rem;
  padding-top: 4px;
  font-size: 14px;
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  letter-spacing: .06em;
}
.facility-tags-row__label--onsen  { color: #c0622a; }
.facility-tags-row__label--quality { color: #7a6040; }

.facility-tags-row__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

/* タグチップ */
.ftag {
  display: inline-block;
  padding: 4px 14px;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  border: 1px solid transparent;
  transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}
.ftag:hover { transform: translateY(-1px); }

.ftag--facility {
  background: rgba(123,163,204,.15);
  color: var(--color-primary);
  border-color: rgba(14,47,86,.15);
}
.ftag--facility:hover {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}

.ftag--onsen {
  background: rgba(192,98,42,.07);
  color: #b85020;
  border-color: rgba(192,98,42,.2);
}
.ftag--onsen:hover {
  background: #c0622a;
  color: #fff;
  border-color: #c0622a;
}

.ftag--quality {
  background: rgba(122,96,64,.07);
  color: #6a5030;
  border-color: rgba(122,96,64,.2);
  font-size: var(--font-size-sm);
}
.ftag--quality:hover {
  background: #7a6040;
  color: #fff;
  border-color: #7a6040;
}
.facility-content {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-relaxed);
  color: var(--color-text);
  margin-bottom: var(--space-12);
  padding-bottom: var(--space-12);
  border-bottom: 1px solid var(--color-border);
}

/* ============================================================
   サイドバーカード
   ============================================================ */
.facility-sidebar-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: var(--space-6);
  box-shadow: var(--shadow-sm);
}
.facility-sidebar-card__header {
  padding: var(--space-4) var(--space-6);
  background: linear-gradient(90deg, #f0f8f7, #f8fcfb);
  border-bottom: 1px solid var(--color-border);
}
.facility-sidebar-card__title {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  letter-spacing: .1em;
  text-transform: uppercase;
}

/* ============================================================
   セクション見出し共通
   ============================================================ */
.facility-section-title {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  color: var(--color-text);
  position: relative;
  padding-bottom: var(--space-4);
  margin-bottom: var(--space-8);
}
.facility-section-title::after {
  content: '';
  position: absolute; bottom: 0; left: 0;
  width: 2.5rem; height: 3px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-light));
  border-radius: 2px;
}

/* ============================================================
   本文エリア
   ============================================================ */
.facility-content {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-relaxed);
  color: var(--color-text);
  padding-bottom: var(--space-10);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-10);
}

/* ============================================================
   基本情報（サイドバー内）
   ============================================================ */
.facility-info { margin: 0; }
.facility-info__list { margin: 0; }

.facility-info__row {
  display: flex;
  align-items: flex-start;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  gap: var(--space-4);
  transition: background var(--transition-fast);
}
.facility-info__row:last-child { border-bottom: none; }
.facility-info__row:hover { background: #f8fcfb; }

.facility-info__dt {
  flex-shrink: 0;
  width: 5.5rem;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-muted);
  line-height: 1.6;
  padding-top: 1px;
}

.facility-info__dd {
  flex: 1;
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--color-text);
  line-height: 1.65;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}
.facility-info__dd a {
  color: var(--color-primary);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
}
.facility-info__dd a:hover { text-decoration: underline; }

/* 利用可 / 不可バッジ */
.info-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 10px;
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: .02em;
  white-space: nowrap;
}
.info-badge--ok {
  background: #e8f6f4;
  color: #1a6b68;
  border: 1px solid #b2deda;
}
.info-badge--no {
  background: #f3f3f3;
  color: #aaa;
  border: 1px solid #e2e2e2;
}
.info-price {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  font-weight: var(--font-weight-medium);
}

/* ============================================================
   訪問記録セクション
   ============================================================ */
.visit-section {
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-6) var(--space-8);
  margin-bottom: var(--space-12);
  box-shadow: var(--shadow-sm);
}
.visit-section__summary {
  display: flex; align-items: center; gap: var(--space-4);
}
.visit-section__icon {
  font-size: 1.75rem; line-height: 1; color: var(--color-primary);
}
.visit-section__count {
  font-size: var(--font-size-base);
  color: var(--color-text-muted);
  flex: 1;
}
.visit-section__add-btn {
  padding: 9px var(--space-6);
  background: var(--color-primary);
  color: #fff; border: none;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  cursor: pointer;
  letter-spacing: .02em;
  transition: background var(--transition-fast);
  white-space: nowrap;
}
.visit-section__add-btn:hover { background: var(--color-primary-dark); }
.visit-section__login-link {
  font-size: var(--font-size-sm); color: var(--color-primary); text-decoration: underline;
}
.visit-panel {
  margin-top: var(--space-5); padding-top: var(--space-5);
  border-top: 1px solid var(--color-border);
}
.visit-panel__type-group {
  display: flex; gap: var(--space-2); margin-bottom: var(--space-5);
}
.visit-panel__type-label { cursor: pointer; }
.visit-panel__type-label input { display: none; }
.visit-panel__type-btn {
  display: inline-block;
  padding: 7px var(--space-5);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: all var(--transition-fast);
}
.visit-panel__type-label input:checked + .visit-panel__type-btn {
  background: var(--color-primary); border-color: var(--color-primary); color: #fff;
}
.visit-panel__date-group { margin-bottom: var(--space-5); }
.visit-panel__date-label {
  display: block;
  font-size: var(--font-size-sm); font-weight: var(--font-weight-bold);
  color: var(--color-text-muted); margin-bottom: var(--space-2);
}
.visit-panel__date-input {
  padding: 10px var(--space-4);
  border: 1.5px solid var(--color-border); border-radius: var(--radius-md);
  font-size: var(--font-size-base); width: 100%; max-width: 240px;
  transition: border-color var(--transition-fast);
}
.visit-panel__date-input:focus {
  outline: none; border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(14,47,86,.12);
}
.visit-panel__actions { display: flex; gap: var(--space-3); }
.visit-panel__error { font-size: var(--font-size-sm); color: var(--color-error); margin-top: var(--space-2); }
.visit-history { list-style: none; margin-top: var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); }

/* ============================================================
   泉質・効能
   ============================================================ */
.facility-spring {
  background: linear-gradient(135deg, #eef7f6 0%, #e4f3f1 100%);
  border: 1px solid #c2e0dd;
  border-radius: var(--radius-md);
  padding: var(--space-8) var(--space-10);
  margin-bottom: var(--space-12);
}
.facility-spring__title {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  color: var(--color-text);
  position: relative;
  padding-bottom: var(--space-4); margin-bottom: var(--space-6);
}
.facility-spring__title::after {
  content: '';
  position: absolute; bottom: 0; left: 0;
  width: 2.5rem; height: 3px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-light));
  border-radius: 2px;
}
.facility-spring__quality-tags {
  display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-5);
}
.facility-spring__quality-tag {
  background: var(--color-primary); color: #fff;
  font-size: var(--font-size-sm); font-weight: var(--font-weight-medium);
  padding: 5px 14px; border-radius: var(--radius-full);
}
.facility-spring__meta {
  display: flex; gap: var(--space-8); margin-bottom: var(--space-5);
  font-size: var(--font-size-base); color: var(--color-text-muted);
}
.facility-spring__meta strong { color: var(--color-text); font-weight: var(--font-weight-bold); }
.facility-spring__desc {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text);
}
.facility-spring__source {
  padding: var(--space-6) 0;
  border-top: 1px solid rgba(14,47,86,.12);
}
.facility-spring__source:first-of-type { border-top: none; padding-top: 0; }
.facility-spring__source-name {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-4);
  color: var(--color-primary);
}

/* ============================================================
   基本情報セクション（写真 + 地図 + テーブル 2カラム）
   ============================================================ */
.info-section {
  margin-bottom: var(--space-16);
  padding-top: var(--space-10);
  border-top: 1px solid var(--color-border);
}
.info-section__title {
  font-family: var(--font-heading);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  margin-bottom: var(--space-8);
  padding-top: var(--space-4);
  position: relative;
}
.info-section__title::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 2rem; height: 3px;
  background: var(--color-primary);
  border-radius: 2px;
}
.info-section__grid {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--space-12);
  align-items: start;
}
.info-section__media {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.info-section__photo {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: var(--radius-md);
  display: block;
}

/* ギャラリービューワー */
.facility-gallery {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.facility-gallery__main {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: var(--radius-md);
  display: block;
  transition: opacity 0.15s;
}
.facility-gallery__thumbs {
  display: flex;
  gap: 6px;
}
.facility-gallery__thumb {
  flex: 1;
  min-width: 0;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 4px;
  cursor: pointer;
  opacity: 0.55;
  border: 2px solid transparent;
  transition: opacity 0.15s, border-color 0.15s;
}
.facility-gallery__thumb:hover { opacity: 0.85; }
.facility-gallery__thumb--active {
  opacity: 1;
  border-color: var(--color-primary);
}
.info-section__map {
  width: 100%;
  height: 200px;
  border: none;
  border-radius: var(--radius-md);
  display: block;
}
.info-section__map-link {
  font-size: var(--font-size-xs);
  color: var(--color-primary);
  text-decoration: none;
}
.info-section__map-link:hover { text-decoration: underline; }
.info-section__map-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 160px;
  background: #f4f8f7;
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-primary);
  font-size: var(--font-size-sm);
  text-decoration: none;
}

.info-section__data { min-width: 0; }

/* 予約リンク（基本情報セクション内） */
.info-section__booking {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border);
}
.info-section__booking-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-muted);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}
.info-section__booking-label small {
  font-weight: var(--font-weight-normal);
  opacity: .7;
  letter-spacing: 0;
  text-transform: none;
}
.info-section__booking-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.info-section__booking-btn {
  display: block;
  padding: var(--space-3) var(--space-5);
  background: var(--color-primary);
  color: #fff;
  border-radius: var(--radius-md);
  text-decoration: none;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-sm);
  text-align: center;
  transition: background var(--transition-fast), transform var(--transition-fast);
}
.info-section__booking-btn:hover {
  background: var(--color-primary-dark);
  color: #fff;
  transform: translateY(-1px);
}

/* 施設補足情報 */
.info-section__notes {
  margin-top: var(--space-8);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border);
}
.info-section__notes-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-muted);
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}
.info-section__notes-body {
  font-size: var(--font-size-sm);
  color: var(--color-text);
  line-height: 1.7;
  background: #f8faf9;
  border-left: 3px solid var(--color-primary);
  padding: var(--space-4) var(--space-5);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

/* ============================================================
   Googleマップ（単体セクション — 現在は info-section 内に統合）
   ============================================================ */
.facility-map { margin-bottom: var(--space-12); }
.facility-map__title {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  color: var(--color-text);
  position: relative;
  padding-bottom: var(--space-4); margin-bottom: var(--space-6);
}
.facility-map__title::after {
  content: '';
  position: absolute; bottom: 0; left: 0;
  width: 2.5rem; height: 3px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-light));
  border-radius: 2px;
}
.facility-map__embed {
  width: 100%; height: 400px; border: none;
  border-radius: var(--radius-md); box-shadow: var(--shadow-sm);
}

/* ============================================================
   予約リンク（サイドバー内）
   ============================================================ */
.facility-booking { margin: 0; padding: 0; border: none; }
.facility-booking__title { display: none; }
.facility-booking__links {
  display: flex; flex-direction: column; gap: var(--space-3);
  padding: var(--space-5) var(--space-5);
}
.facility-booking__btn {
  display: block;
  padding: var(--space-3) var(--space-4);
  background: var(--color-primary); color: #fff;
  border-radius: var(--radius-md); text-decoration: none;
  font-weight: var(--font-weight-bold); font-size: var(--font-size-sm);
  text-align: center;
  transition: background var(--transition-fast);
}
.facility-booking__btn:hover { background: var(--color-primary-dark); color: #fff; }

/* ============================================================
   近くの温泉施設
   ============================================================ */
.facility-nearby {
  padding-top: var(--space-12);
  margin-top: var(--space-8);
  margin-bottom: var(--space-12);
  border-top: 1px solid var(--color-border);
}
.facility-nearby__title {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  color: var(--color-text);
  position: relative;
  padding-bottom: var(--space-4); margin-bottom: var(--space-8);
}
.facility-nearby__title::after {
  content: '';
  position: absolute; bottom: 0; left: 0;
  width: 2.5rem; height: 3px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-light));
  border-radius: 2px;
}

/* ============================================================
   タグバッジ（モディファイア）
   ============================================================ */
.tag-badge--small { font-size: 11px; padding: 3px 9px; }

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (max-width: 900px) {
  .info-section__grid { grid-template-columns: 1fr; }
  .info-section__photo { aspect-ratio: 16 / 9; }
}
@media (max-width: 768px) {
  .facility-hero { min-height: 360px; }
  .facility-hero__title { font-size: var(--font-size-2xl); }
  .facility-card__link { padding: var(--space-4) var(--space-4); }
  .facility-card__title { font-size: var(--font-size-lg); }
  .facility-spring { padding: var(--space-6); }
  .facility-page { padding-top: var(--space-8); }
  .facility-tags-row {
    flex-direction: column;
    gap: var(--space-2);
    padding: var(--space-4) var(--space-4);
  }
  .facility-tags-row__label { width: auto; }
}
@media (max-width: 480px) {
  .facility-card__link { padding: var(--space-4) var(--space-3); }
  .facility-card__title { font-size: var(--font-size-base); }
}
