@charset "utf-8";
/* CSS Document */

/* タイトルスタイル（全ページ共通） */
.section__title .title__lang {
  display: block;
}

.section__title .title__lang--en {
  color: #e07f81;
  font-size: 1.2rem;
  font-weight: 700;
  text-transform: uppercase;
}

.section__title .title__lang--jp {
  font-size: 2.3rem;
  font-weight: 500;
}

.section__title .title--center {
  text-align: center;
}

.section__title .title--left .title__lang--en {
  margin-bottom: 10px;
}

html {
  scroll-behavior: smooth;
}

.hero_ {
  background: #FFFFFF;
  position: relative;
}

.hero__container_ {
  aspect-ratio: 529 / 543;
}

.hero__mask_ {
  bottom: 40px;
  position: absolute;
  width: 100%;
}

h1.tittle {
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translateX(-50%);
  color: white;
  font-weight: 500;
  font-size: 2.7rem;
  text-align: center;
  text-shadow: 0 0 4px #3b3b3b,
    0 0 8px #3b3b3b,
    0 0 12px #3b3b3b;
  width: 100%;
}

.section_ {
  padding-bottom: 40px;
}

.section__ {
  padding-bottom: 50px;
}

[data-page=top] .section__title .title__lang--jp {
  font-size: 2.3rem;
}

/* メニューコンテナ：３列グリッド */
.menu-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  font-weight: bold;
  font-size: 90%;
}

/* 各メニューアイテム */
.menu-item {
  background-color: #f7eef1;
  border-radius: 8px;
  padding: 10px 15px 28px;
  text-align: center;
  position: relative;
  cursor: pointer;
  transition: background-color .2s;
  height: 75px;
  display: flex;
  align-items: center;
  justify-content: center;

}

.menu-item:hover {
  background-color: #eedae0;
}

/* タイトル */
.menu-item__title {
  margin: 0;
  color: #191e1f;
  line-height: 1.4;
  font-weight: 500;
  font-size: 1.2rem;
}

/* 矢印（下向き）を背景画像で配置 */
.menu-item::after {
  content: "";
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 8px;
  background: url("../../images/policy/arrow.png") no-repeat center;
  background-size: contain;
}

/* リンク領域を枠全体に拡大 */
.menu-item a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.mb0 {
  margin-bottom: 0 !important;
}

.mb15 {
  margin-bottom: 10px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb40 {
  margin-bottom: 40px;
}

.mb30 {
  margin-bottom: 30px;
}

.mb50 {
  margin-bottom: 50px;
}

.mt50 {
  margin-top: 50px;
}

.mt40 {
  margin-top: 40px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mt20 {
  margin-top: 20px;
}

.mt10 {
  margin-top: 10px;
}

.mt0 {
  margin-top: 0 !important;
}

.mb120 {
  margin-bottom: 120px;
}

.mtb40 {
  margin: 40px auto;
}

.mtb20 {
  margin: 20px auto;
}

.mr5 {
  margin-right: 5px;
}

.pt20 {
  padding-top: 20px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pt60 {
  padding-top: 60px !important;
}

.pb0 {
  padding-bottom: 0 !important;
}

.pb80 {
  padding-bottom: 80px;
}

.pb70 {
  padding-bottom: 70px;
}

.pb60 {
  padding-bottom: 60px;
}

.pb50 {
  padding-bottom: 50px !important;
}

.pb40 {
  padding-bottom: 40px;
}

.pb30 {
  padding-bottom: 30px;
}

.pb80 {
  padding-bottom: 80px;
}

.textb {
  font-weight: 500;
  font-size: 115%;
}

.bg_pink {
  background-color: #f7eff0;
  padding-top: 50px;
}

.bg_pink_ {
  background-color: #f7eff0;
  padding: 20px 20px 40px !important;
}

.bordert {
  border-top: 1px solid #cccccc;
}

.bg_wpink {
  background-image:
    linear-gradient(to bottom,
      #fff 0,
      #fff 6%,
      #f7eff0 6%,
      #f7eff0 100%);
}

.bg_wpink_10 {
  background-image:
    linear-gradient(to bottom,
      #fff 0,
      #fff 10%,
      #f7eff0 0%,
      #f7eff0 100%);
}

.bg_wpink_ {
  background-image:
    linear-gradient(to bottom,
      #fff 0,
      #fff 14%,
      #f7eff0 14%,
      #f7eff0 100%);
}

.bg_wpink__ {
  background-image:
    linear-gradient(to bottom,
      #fff 0,
      #fff 15%,
      #f7eff0 15%,
      #f7eff0 100%);
}

span.pink {
  color: #dd6164;
  font-weight: 500;
  margin-bottom: 10px;
  display: inline-block;
}

span.pinkTT {
  color: #dd6164;
  font-size: 110%;
}

span.font_small {
  font-size: 11px;
  line-height: 22px;
}

.concept__image_ {
  aspect-ratio: 67 / 42;
  border-radius: 10px;
  margin-bottom: 20px;
  overflow: hidden;
}

.p_area {
  background-color: #f7eff0;
  padding: 0 0 80px;
}

.p_area_img {
  position: relative;
  top: -100px;
}

.section-title {
  text-align: left;
  margin: 20px 0;
}

.p_area .section-title {
  margin: -110px 0 0;
}

.p_area .section-title_ {
  margin: 0;
}

.section-title__heading {
  display: flex;
  align-items: flex-start;
  font-size: 1.7rem;
  font-weight: 500;
  color: #333;
  border-bottom: 1px dotted #ccc;
  width: 100%;
  padding-bottom: 10px;
  margin-bottom: 20px;
}

.section-title__icon_ {
  display: inline-block;
  flex: 0 0 0.8em;
  width: 14px;
  height: 14px;
  background-image: url("../../images/policy/tt_icon.png");
  background-repeat: no-repeat;
  background-position: left;
  background-size: contain;
  vertical-align: text-top;
  margin-top: 8px;
  margin-right: 8px;
}

.section-title__icon {
  flex: 0 0 0.8em;
  width: 14px;
  height: 14px;
  background-image: url("../../images/policy/tt_icon.png");
  background-repeat: no-repeat;
  background-position: left;
  background-size: contain;
  vertical-align: text-top;
  margin-top: 10px;
  margin-right: 8px;
}

.section-title__divider {
  margin-top: 8px;
  width: 100%;
  border: 1px dotted #ccc;
  /* background-image: url("../../images/policy/line.png");*/
}

.concept__text p {
  font-size: 110%;
  letter-spacing: 0.08em;
  line-height: 1.8;
}

#concept .spacer01 {
  aspect-ratio: 750/860;
  clip-path: inset(0);
  overflow: hidden;
  position: relative;
}

#concept .spacer01::before {
  background: url("../../images/policy/concept.jpg") no-repeat;
  background-position: calc(50% + 275px) center;
  background-size: 470px auto;
  content: "";
  height: 100%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
}

.concept_tt {
  width: 70%;
  margin: 50px auto;
  display: block;
}

.concept_tt_ {
  margin: 30px auto;
  display: block;
  width: 31%;
}

.divider {
  width: 40px;
  height: 1px;
  background-color: #e07f81;
  margin: 30px auto 0;
}

.heading {
  isplay: inline-flex;
  align-items: baseline;
  font-size: 2.0rem;
  font-weight: normal;
  color: #333;
}

/* 番号部分 */
.heading__number {
  color: #e07f81;
  font-weight: bold;
  font-size: 1.1em;
  margin-right: 0.5em;
  font-family: "Barlow", sans-serif;
}

/* スラッシュ */
.heading__slash {
  color: #999;
  margin-right: 0.5em;
}

/* テキスト */
.heading__text {
  white-space: nowrap;
  font-weight: 500;
}

.director-section {
  margin: 40px auto 40px;
  color: #333;
}

/* 見出し */
.director-section__header {
  background-color: #e07f81;
  color: #fff;
  padding: 4px 15px;
  font-size: 1.85rem;
  font-weight: bold;
}

/* リストリセット */
.director-list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 110%;
  letter-spacing: 0.06em;
  line-height: 1.8;
}

/* 各項目 */
.director-list__item {
  padding: 16px 0;
  position: relative;
}

/* 既存の間の線はそのまま */
.director-list__item:not(:last-child) {
  border-bottom: 1px dotted #ccc;
}

/* さらに最後の要素にも同じ線を追加 */
.director-list__item:last-child {
  border-bottom: 1px dotted #ccc;
}

/* 左端の● */
.director-list__bullet {
  display: inline-block;
  width: 6px;
  height: 6px;
  background-color: #e07f81;
  border-radius: 50%;
  margin-right: 8px;
  vertical-align: middle;
}

/* 氏名＋ふりがな */
.director-list__name {
  font-weight: bold;
}

.director-list__kana {
  margin-left: 4px;
  color: #666;
}

/* 役職 */
.director-list__role {
  display: block;
  margin-top: 4px;
  color: #555;
}

.related {
  max-width: 800px;
  margin: 30px auto 0;
  text-align: center;
}

.related__title {
  color: #e07f81;
  margin-bottom: 24px;
  font-size: 2rem;
  font-weight: 500;
}

/* 2列グリッド */
.related__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  list-style: none;
  padding: 0;
  margin: 0;
}

/* 各アイテム */
.related__item a {
  display: flex;
  align-items: center;
  padding: 20px 10px 20px 20px;
  border: 1px solid #ccc;
  border-radius: 8px;
  text-decoration: none;
  color: #191e1f;
  font-size: 1.3rem;
  position: relative;
  background: #FFFFFF;
  transition: background .2s;
  font-weight: 500;
  text-align: left;
}

.related__item a:hover {
  background: #f7eff0;
}

/* 左の半円アイコン */
.related__item a::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 6px;
  height: 10px;
  background-color: #e57373;
  border-top-right-radius: 16px;
  border-bottom-right-radius: 16px;
}

/* 右の矢印を背景画像で */
.related__item a .arrow-icon {
  margin-left: auto;
  display: inline-block;
  width: 16px;
  /* 矢印画像の幅 */
  height: 16px;
  /* 矢印画像の高さ */
  background: url("../../images/policy/arrow_r.png") no-repeat center center;
  background-size: contain;
}

/* パンくずナビ全体 */
.breadcrumb {
  display: inline-flex;
  align-items: center;
  padding: 20px;
  border-bottom: 1px solid #cccccc;
  /* 下のライン */
  margin-bottom: 24px;
  width: 100%;
}

/* リストリセット */
.breadcrumb ul {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}

.breadcrumb li {
  display: flex;
  align-items: center;
}

/* セパレータ */
.breadcrumb li+li::before {
  content: "―";
  margin: 0 8px;
  color: #bbbbbb;
}

/* リンク */
.breadcrumb a {
  color: #bbbbbb;
  text-decoration: none;
}

.breadcrumb a:hover {
  text-decoration: underline;
}

/* 現在ページ */
.breadcrumb .current {
  color: #e07f81;
  font-weight: bold;
}

.google-map-link {
  display: inline-flex;
  align-items: center;
  color: #e07f81;
  /* テキスト＆線の色 */
  font-size: 1.25rem;
  /* お好みで調整 */
  text-decoration: none;
  border-bottom: 2px solid;
  /* 下線 */
  border-color: currentColor;
  /* テキストと同じ色に */
  padding-bottom: 4px;
  /* 下線との余白 */
}

.google-map-link__icon {
  width: 1em;
  /* テキストサイズに合わせる */
  height: 1em;
  margin-left: 0.5em;
  /* テキストとの隙間 */
  fill: currentColor;
  /* アイコンも同じ色 */
}

.facility-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  /* アイテム間の隙間 */
  list-style: none;
  padding: 0;
  margin: 0;
}

.facility-list {
  margin-bottom: 15px;
}

.facility-item figure {
  margin: 0;
}

.img-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 11;
  overflow: hidden;
  border-radius: 12px;
  /* 角丸 */
}

.img-wrap_ {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 16;
  overflow: hidden;
  margin-bottom: 15px;
}

.facility-list p {
  margin-bottom: 20px;
  text-align: center;
}

.img-wrap img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* 枠に合わせて切り抜き */
  display: block;
}

.facility-item figcaption {
  margin-top: 0.5rem;
  text-align: center;
  font-size: 1.25em;
}

.pdf-label {
  display: inline-flex;
  align-items: center;
  /* テキストとアイコンをセンター揃え */
  color: #e89fa1;
  /* テキスト＆線の色 */
  font-size: 1.25rem;
  /* お好みで調整 */
  text-decoration: none;
  /* デフォルトの下線解除 */
}

.pdf-label__text {
  border-bottom: 1px solid #e07f81;
  padding-bottom: 5px;
}

.pdf-label__icon {
  display: inline-block;
  width: 1.25em;
  /* テキストサイズに合わせる */
  height: 1.25em;
  margin-left: 0.5em;
  /* テキストとの余白 */
  background-image: url("../../images/policy/information/pdf.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  vertical-align: middle;
}

.pdf-label__icon--blank {
  background-image: url("../../images/top/ico_blank.png");
}

/* ハンドブックへのテキストリンク用（下線を border で表現） */
.pdf-link {
  color: #e07f81;
  font-weight: 500;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  position: relative;
  padding-bottom: 2px;
}

.pdf-link:hover {
  opacity: 1;
}

/* テキスト部分のみに下線を引く（PDFアイコンの下には伸ばさない） */
.pdf-link::before {
  content: "";
  position: absolute;
  left: -1.2em;
  right: 1.2em;
  /* アイコン幅＋余白ぶんを確保して下線を手前で止める */
  bottom: 0;
  border-bottom: 1px solid currentColor;
}

.pdf-link:hover::before {
  border-bottom: none;
}

/* pdf-link の後ろに PDF アイコンを表示 */
.pdf-link::after {
  content: "";
  display: inline-block;
  width: 10px;
  height: 12px;
  margin-left: 0.4em;
  background-image: url("../../images/admission/icon-pdf.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.maplink_icon {
  display: inline-block;
  width: 1.25em;
  height: 1.25em;
  margin-left: 0.5em;
  background-image: url("../../images/policy/link.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  vertical-align: middle;
}

/* ===== ギャラリー 2列 ===== */
.gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  max-width: 960px;
  margin: 0px auto 40px;
}

.gallery img {
  width: 100%;
  aspect-ratio: 4 / 2.7;
  object-fit: cover;
  border-radius: 14px;
  display: block;
  transition: transform .18s ease;
}

.gallery img:hover {
  transform: scale(1.02);
  cursor: pointer;
}

.lb-item p {
  text-align: center;
  font-size: 120%;
  margin: 5px auto 10px;
  color: #191e1f;
}

/* ===== ライトボックス ===== */
.lb-overlay[hidden] {
  display: none;
}

.lb-overlay {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.9);
  z-index: 9999;
  padding: 20px;
}

.lb-figure {
  margin: 0;
  text-align: center;
}

#lb-image {
  max-width: 90vw;
  max-height: 90vh;
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4);
}

.lb-caption {
  margin-top: 12px;
  color: #fff;
  letter-spacing: .08em;
  text-shadow: 0 2px 6px rgba(0, 0, 0, .4);
}

/* ===== ボタン ===== */
.lb-btn {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border: none;
  border-radius: 999px;
  background: rgba(0, 0, 0, .55);
  color: #fff;
  font-size: 28px;
  line-height: 44px;
  cursor: pointer;
}

.lb-prev {
  left: max(16px, 4vw);
}

.lb-next {
  right: max(16px, 4vw);
}

.lb-close {
  top: clamp(12px, 4vh, 24px);
  right: clamp(12px, 4vw, 24px);
  transform: none;
  width: 40px;
  height: 40px;
  font-size: 24px;
}

.lb-btn:focus-visible {
  outline: 2px solid #fff;
}

.schedule-card {
  --pink: #de8f97;
  /* 枠と文字色（お好みで調整） */
  max-width: 680px;
  /* 幅の上限 */
  margin: 24px auto;
  /* 中央配置 */
  padding: 18px 24px;
  /* 余白 */
  border: 2px solid var(--pink);
  /* ピンク枠 */
  border-radius: 14px;
  /* 角丸 */
  color: var(--pink);
  /* 文字色 */
  text-align: center;
  /* 中央揃え */
  font-weight: 500;
  letter-spacing: .08em;
  font-size: 140%;
  line-height: 1.9;
}

.target {
  max-width: 500px;
  /* 親要素の幅は必要に応じて */
}

.target_tt {
  display: flex;
  align-items: center;
  gap: 10px;
  /* テキストと線の間隔 */
  margin-top: 20px;
}

.target_tt span {
  font-weight: bold;
  white-space: nowrap;
  /* 折り返さない */
  font-size: 1.2em;
}

.target_tt hr {
  flex: 1;
  border: none;
  /* デフォルトを消す */
  height: 1px;
  /* 線の太さ */
  border: 1px #ccc solid;
}

.btn-wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  /* 3列均等 */
  gap: 12px;
  /* ボタンの間隔 */
  margin: 10px 0 50px;
}

.b_label {
  background: #d97b7b;
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 6px 0;
  font-size: 1.3rem;
  cursor: pointer;
  width: 100%;
  /* グリッドのセル幅いっぱい */
  text-align: center;
}

/* トラック（横スクロール領域） */
.hscroll__track {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  position: relative;
  margin-left: 20px;
}

/* 表 */
.hscroll__table {
  border-collapse: separate;
  border-spacing: 0;
  min-width: 1010px;
  /* 幅を増やすとスクロール量が増える */
  font-size: 16px;
  line-height: 1.6;
  border-top: 1px solid #e6e6e6;
  border-left: 1px solid #e6e6e6;
}

.hscroll__table thead th {
  padding: 7px 18px;
}

.hscroll__table th,
.hscroll__table td {
  padding: 10px 18px;
  border-right: 1px solid #e6e6e6;
  border-bottom: 1px solid #e6e6e6;
  background: #fff;
  vertical-align: middle;
  text-align: center;
  font-size: 1.4rem;
  line-height: 2rem;
}

.hscroll__table thead th {
  background: #d97b7b;
  color: #fff;
  font-weight: 400;
  font-size: 1.4rem;
}

.hscroll__table tbody th.sticky {
  position: sticky;
  left: 0;
  z-index: 2;
  background: #f8eded;
  /* 見出し列の背景 */
  text-align: left;
  white-space: nowrap;
  font-weight: 400;
  border-right: 1px solid #f7eff0;
  text-align: center;
}

.hscroll__table tbody th.sticky.sticky-col-1 {
  left: 0;
}

.hscroll__table tbody th.sticky.sticky-col-2 {
  left: 72px;
  /* 1列目の幅に合わせて必要なら微調整 */
}

/* 「該当認定」セル（rowspan=3）の右側に境界線を付ける */
.hscroll__table tbody th.sticky.sticky-col-1[rowspan="3"] {
  border-right: 1px solid #e6e6e6;
}

.hscroll__table tbody tr:nth-child(odd) td {
  background: #fff;
}

/* スクロールヒント */
.hscroll {
  position: relative;
}

.hscroll__hint {
  position: absolute;
  inset: auto 0 40% 0;
  margin: auto;
  width: 50%;
  padding: 20px;
  height: 180px;
  background: rgba(0, 0, 0, .72);
  color: #fff;
  border-radius: 12px;
  display: grid;
  place-items: center;
  gap: 8px;
  z-index: 3;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
}

.hscroll__hint .hint__icon {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 22px;
}

.hscroll__hint .hand {
  font-size: 28px;
  line-height: 1;
}

.hscroll__hint.hide {
  opacity: 0;
  transform: translateY(6px);
}

.hint__icon img {
  width: 50%;
  margin: 0 auto;
}

/* 好みで：スクロールバーを細く */
.hscroll__track::-webkit-scrollbar {
  height: 10px;
}

.hscroll__track::-webkit-scrollbar-thumb {
  background: #d97b7b33;
  border-radius: 6px;
}

/* 募集要項テーブルではスクロールバー自体を非表示にする */
.hscroll__track {
  scrollbar-width: none;
  /* Firefox */
}

.hscroll__track::-webkit-scrollbar {
  display: none;
  /* Chrome, Safari等 */
}

/* pink枠 */
.cert-list {
  display: grid;
  margin-top: 30px;
}

/* カード */
.cert-card {
  background: #fff;
  border-radius: 0 0 10px 10px;
  padding: 20px 20px 16px;
  position: relative;
  margin-bottom: 30px;
}

/* 上部のピンク帯（角丸） */
.cert-card__badge {
  display: inline-block;
  padding: 5px 20px;
  background: #e07f81;
  color: #fff;
  font-size: 1.7rem;
  width: 100%;
  border-radius: 10px 10px 0 0;
}

/* 赤みのある強調行 */
.cert-card__lead {
  margin: 0 0 8px;
  color: #e07f81;
  line-height: 1.6;
}

/* 本文 */
.cert-card__text {
  margin: 0;
  line-height: 1.8;
  font-size: 14px;
}

/*/// flow ///*/

/* セクション枠 */
.flow {
  background: white;
  border-radius: 12px;
  padding: 0 0 16px;
  margin: auto;
}

/* 見出し：上左右だけ角丸 */
.flow__head {
  background: #e07f81;
  color: #fff;
  padding: 10px 20px;
  margin: 0 0 12px;
  border-radius: 8px 8px 0 0;
  /* 上左右だけ角丸 */
  font-size: 1.3em;
}

/* タイムライン本体 */
.flow__list {
  list-style: none;
  margin: 0;
  padding: 8px 0 0 0;
  position: relative;
}

/* 縦ライン（中央寄り左に表示） */
.flow__list::before {
  content: "";
  position: absolute;
  left: 56px;
  /* バッジの右端に合わせる */
  top: 20px;
  height: calc(100% - 90px);
  /* STEP5を少し超えない程度の長さに調整 */
  width: 2px;
  background: #e07f81;
}

/* 各行 */
.flow__item {
  display: grid;
  grid-template-columns: 78px 1fr;
  /* バッジ幅 / 本文 */
  position: relative;
  padding: 12px 20px;
}

/* ステップ丸角バッジ */
.flow__step {
  width: 78px;
  height: 38px;
  display: inline-grid;
  place-items: center;
  border-radius: 10px;
  background: #e07f81;
  color: #fff;
  font-size: 1.4rem;
  padding: 1px;
  align-self: start;
  position: relative;
  z-index: 1;
  font-weight: 500;
  font-family: "Barlow", sans-serif;
  border: 5px solid #fff;
}

/* 各項目の内容 */
.flow__body {
  background: #fff;
  border-radius: 10px;
  padding: 2px 10px 0;
}

.flow__title {
  margin: 0 0 6px;
  color: #e07f81;
  font-weight: 700;
  font-size: 1.7rem;
}

.gallery_admission {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  max-width: 960px;
  margin: 0px auto 40px;
}

.gallery_admission img {
  width: 100%;
  height: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 14px;
  display: block;
  transition: transform .18s ease;
}

.section__divider {
  margin: 40px auto 20px;
}

.gallery_admission__text p {
  font-size: 1.4rem;
}

.gallery_admission__caution p {
  font-size: 1.4rem;
  display: block;
  padding-left: 1em;
  /* 2行目以降を1文字分下げる */
  text-indent: -1em;
  /* 1行目だけ左に戻して揃える（ぶら下がりインデント） */
}

.gallery_admission__caution p::before {
  content: "※";
  margin-right: 0.25em;
  color: #191e1f;
  font-weight: 500;
}

.display_block {
  display: block;
}