.hall-renta-wrap {
  color: #666;
}

.content-header {
  padding-top: 3.75em;
  margin-bottom: 3.75em;
}

.slider-wrap {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.slider-common-style img {
  max-width: 500px;
  margin: auto;
}

/*
 * Slickスライダーの矢印を画像の上に表示するためのスタイル（修正版）
 */

/* スライダーのコンテナを基準位置に設定します。
   Slickが初期化時に付与する .slick-slider クラスを追加してセレクタの優先度を上げます。 */
.variable-width.slick-slider {
  position: relative;
}

/* 矢印ボタンの共通スタイル */
.variable-width.slick-slider .slick-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  /* アクティブなスライドのz-index(999)より大きい値を設定 */
  z-index: 1000;
  cursor: pointer;
}

/* 前へ戻る矢印の位置 */
.variable-width.slick-slider .slick-prev {
    left: 1.5625em;
  /* コンテナの左端からの距離 */
}

/* 次へ進む矢印の位置 */
.variable-width.slick-slider .slick-next {
  right: 1.5625em;
  /* コンテナの右端からの距離 */
}


/* --- 以下は矢印の見た目を整えるための追加スタイルです（お好みで調整してください） --- */

/* 矢印ボタンの背景やサイズを調整 */
.variable-width.slick-slider .slick-arrow {
  background: rgba(0, 0, 0, 0.4);
  border: none;
  width: 2.8125em;
  height: 2.8125em;
  border-radius: 50%;
  /* 円形にする */
}

/* ホバー時に背景を少し濃くする */
.variable-width.slick-slider .slick-arrow:hover {
  background: rgba(0, 0, 0, 0.7);
}

/* ボタン内のテキスト「Previous」「Next」を非表示にする */
.variable-width.slick-slider .slick-arrow {
  font-size: 0;
  line-height: 0;
}

/* 矢印のアイコン（Slick標準のフォントを利用） */
.variable-width.slick-slider .slick-arrow::before {
  font-family: 'slick';
  /* slick-theme.cssで定義されているフォント */
  font-size: 1.25em;
  line-height: 1;
  color: white;
  display: block;
}

/*  */

.title-gold {
  color: #a8925d;
  font-size: 1.5em;
}

.title-black {
  color: #000;
  font-size: 1.5em;
}

.table-container {
  overflow-x: auto;
  /* 横方向のスクロールを有効にする */
  margin-bottom: 1.875em;
  width: 100%;
  box-sizing: border-box;
  min-width: 0;
}

.price-table {
  border-collapse: collapse;
  width: 100%;
  border: 1px solid #b0c4de;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  margin-bottom: 0;
}

.price-table th,
.price-table td {
  border: 1px solid #b0c4de;
  padding: .75em .9375em;
  text-align: center;
  font-size: 1em;
  white-space: normal;
}

.price-table thead th {
  background-color: #e0efff;
  color: #333;
  font-weight: bold;
}

.price-table tbody tr:nth-child(odd) {
  background-color: #ffffff;
}

.price-table tbody tr:nth-child(even) {
  background-color: #f9f9f9;
}

.price-table tbody td:first-child {
  background-color: #f0f8ff;
  font-weight: bold;
}

.price-table tbody th {
  background-color: #f0f8ff;
  font-weight: bold;
}

.price-table .price {
  font-weight: bold;
  color: #000;
  font-size: 1.125em;
}

.price-table .row-header-label {
  font-weight: normal;
  text-align: left;
}

.conditions-header {
  background-color: #e0efff;
  color: #333;
  font-weight: bold;
  padding: .75em .9375em;
  border-bottom: 1px solid #b0c4de;
}

.conditions-list {
  list-style-type: none;
  padding: .9375em 1.25em;
  margin: 0;
}

.conditions-list li {
  padding: .5em 0;
  text-indent: -1em;
  /* ビュレットを左に少し出す */
  padding-left: 1em;
}

.conditions-list li::before {
  content: '\f111';
  font-family: fontawesome;
  font-size: .875em;
  color: inherit;
  margin-right: .5em;
  vertical-align: text-bottom;
}

.container {
  width: 100%;
  max-width: 1100px;
  background-color: #ffffff;
}

.specs-header {
  display: flex;
  justify-content: space-around;
  padding: .75em .625em;
  border: 1px solid #ccc;
  border-bottom: none;
  background-color: #f9f9f9;
  font-size: .9375em;
}

.specs-header span {
  font-weight: bold;
}

.main-table {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  border: 1px solid #ccc;
}

.main-table th,
.main-table td {
  border: 1px solid #ccc;
  padding: .625em;
  text-align: center;
  vertical-align: middle;
  font-size: .875em;
}

.main-table td.text-left {
  text-align: left;
}

.main-table td.vertical-top {
  vertical-align: top;
}

.main-table .row-header {
  background-color: #f2f2f2;
  font-weight: bold;
  width: 5em;
}

/* フロア案内 */
.floor-header th {
  font-weight: bold;
  font-size: 1em;
  background-color: #f9f9f9;
}

.floor-content th {
  font-weight: bold;
  font-size: 1em;
  background-color: #f9f9f9;
}

.floor-content td {
  text-align: center;
  vertical-align: top;
  line-height: 1.8;
}

.floor-content p {
  margin-top: 0;
  margin-bottom: 0;
}

/* 座席数・面積 */
.dark-row {
  background-color: #000000;
  color: #ffffff;
  font-weight: bold;
}

.detail-row {
  text-align: left;
  padding-left: 1.25em;
}

.capacity-row {
  text-align: left;
  padding-left: 1.25em;
}

.notes {
  font-size: .75em;
  text-align: left;
  padding: .9375em;
  line-height: 1.6;
  background-color: #f9f9f9;
}

.seat-header th {
  font-weight: bold;
  font-size: 1em;
  background-color: #f9f9f9;
}

.seat-content th {
  font-weight: bold;
  font-size: 1em;
  text-align: left;
  background-color: #f9f9f9;
}

.seat-content td {
  text-align: center;
  vertical-align: top;
  line-height: 1.8;
}

.seat-content p {
  margin-top: 0;
  margin-bottom: 0;
}

.main-table .seat-header .col-spec {
  width: 20%;
}

.facility-header th {
  font-weight: bold;
  font-size: 1em;
  background-color: #f9f9f9;
}

.facility-content th {
  font-weight: bold;
  font-size: 1em;
  text-align: left;
  background-color: #f9f9f9;
}

.facility-content td {
  text-align: center;
  vertical-align: top;
  line-height: 1.8;
}

.main-table th:nth-child(1) {
  width: 20%;
}

/* ダウンロードセクション */

:root {
  --main-blue: #1e7eac;
  --light-gray: #f0f2f5;
  --text-color: #333;
  --border-radius: 8px;
}

.download-section {
  margin-bottom: 2.5em;
}

.download-section:last-child {
  margin-bottom: 0;
}

/* リンクボタン共通スタイル */
.btn-link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .75em 1.25em;
  background-color: var(--main-blue);
  color: #fff !important;
  font-size: 1.1em;
  font-weight: bold;
  text-decoration: none;
  border-radius: var(--border-radius);
  transition: background-color 0.2s ease;
}

.btn-link:hover {
  background-color: #227094;
}

.btn-link .icon {
  width: 1.5em;
  height: 1.5em;
}

.section-subtitle {
  text-align: right;
  font-size: .9em;
  color: #555;
  margin: .5em .3125em 1.5625em 0;
}

/* カラムレイアウト */
.columns-wrapper {
  display: flex;
  gap: 1.875em;
}

.column {
  flex: 1;
  min-width: 0;
}

.column .btn-link {
  font-size: 1em;
  padding: .625em .9375em;
}

/* ファイルリスト */
.file-list {
  list-style: none;
  padding: .9375em 0 0 .3125em;
  margin: 0;
}

.file-list li {
  position: relative;
  padding-left: 1.2em;
  margin-bottom: .75em;
  font-size: .95em;
  line-height: 1.6;
}

.file-list li::before {
  content: '\f111';
  font-family: fontawesome;
  position: absolute;
  font-weight: bold;
  font-size: .4em;
  left: 0;
  top: 1.5em;
}

/* スマートフォン用のレスポンシブ設定 */
@media (max-width: 768px) {
  body {
    padding: .625em;
  }

  .container {
    padding: .9375em;
  }

  .columns-wrapper {
    flex-direction: column;
    /* 横並びを縦並びに変更 */
    gap: 1.5625em;
  }

  .section-subtitle {
    text-align: left;
    margin-left: 0;
  }
}

.contact-form-button {
  background-color: #bc8d00;
  font-size: 1.5em;
  font-weight: bold;
  color: #fff !important;
  text-decoration: none;
  padding: .625em .9375em;
  border-radius: 10px;
}

.syu-sound-button {
  font-size: 1.5em;
  font-weight: bold;
}

.youtube-wrap {
  margin: 0 auto;
}

.youtube-wrap {
  display: flex;
  align-items: center;
  /* 中央揃え（垂直方向） */
  gap: 1.5em;
  /* 動画とテキストの間隔 */
}

.youtube-iframe {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border: none;
}

.text {}

.youtube-iframe {}

.youtube-iframe iframe {
  width: 100%;
  height: 100%;
  border: none;
}


/* スマホ表示 (画面幅が768px以下の場合) */
@media (max-width: 768px) {

  /* Flexboxの方向を縦に変更します */
  .youtube-wrap {
    flex-direction: column;
  }
}

.photos-wrap {
  display: flex;
  gap: .75em;
  list-style: none;
  margin: 1.25em 0 0 0;
  padding-left: 0;
  text-align: center;
}

.photos-wrap li {
  padding-bottom: 0;
}

.photos-wrap li p {
  margin: 0;
}

@media (max-width: 768px) {
  .photos-wrap {
    /* Gridレイアウトに変更して2カラムを作成 */
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    /* 2つの均等なカラム */
  }
}


/*お知らせ2*/
.information-wrap {
  margin-top: 3.75em;
  margin-bottom: 3.75em;
}

.news_list {
  display: flex;
  gap: .625em;
  margin-bottom: 1.25em;
}

.news_list figure {
  width: 50%;
  display: block;
  flex-shrink: 0;
}

.news_list img {
  width: 100%;
}

p.date {
	margin-bottom: 0;
}
h4.news_title {
	margin-block-start: 0em;
	margin-block-end: 0em;
}

@media screen and (max-width: 768px) {
  .news_list {
    display: block;
    gap: 0;
  }

  .news_list figure {
    max-width: auto;
    width: 100%;
  }

  .price-table {
    font-size: .8em;
  }
}
