@charset "utf-8";

/*--------------------------------------------------------------
    イベントタイトル
  --------------------------------------------------------------*/

#events-titlearea {
  margin: 0;
  padding: 0;

  width: 100%;
  min-height: 100dvh;

  display: flex;
  flex-direction: column;
  justify-content: end;
  align-items: center;
}

#events-titlearea>div:last-child {
  width: 100%;
}

#events-titlearea .textarea {
  width: 100%;

  margin: 0;
  padding: 0;

  display: flex;
  flex-direction: column;
  justify-content: end;
  align-items: center;
  text-align: center;
}

#events-titlearea .textarea>div:first-child {
  width: 100%;
  min-height: 50vh;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

#events-titlearea .textarea>div:first-child img {
  width: 90%;
}


#events-titlearea .textarea>div:first-child p {
  color: #000;
  font-size: clamp(1.6rem, 1.8vw, 2.8rem);
  line-height: 1.4;
  font-weight: 400;
}

#events-titlearea .textarea>div:nth-child(2) {
  width: 100%;
  margin: 0;
  padding: 1rem;

  display: flex;
  justify-content: start;
  align-items: end;
}

#events-titlearea .textarea>div:nth-child(2)>div {
  width: 30vw;
  padding: 1rem;
  background-color: rgba(43, 207, 14, 0.716);
  backdrop-filter: blur(5px);
}

#events-titlearea .textarea>div:nth-child(2) p {
  text-align: start;
}


#events-titlearea .textarea>div:nth-child(3) {
  width: 100%;

  margin: 0;
  padding: 1rem;

  display: flex;
  justify-content: center;
  align-items: end;
}

#events-titlearea .textarea>div:nth-child(4) {
  width: 100%;

  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: end;
}

#events-titlearea h1 {
  color: #fff;
  font-size: 6vw;
  font-weight: 700;
  text-align: center;
}

#events-titlearea h2 {
  color: #000;
  font-size: 3vw;
  font-weight: 700;
  text-align: center;
}

#events-titlearea h3 {
  margin: 1rem 0 1rem 0;
  color: #eaff00;
}

#events-titlearea p {
  color: #fff;
}


@media (max-width: 767.98px) {

  /* sm 以下の画面サイズの場合のスタイル */

  #events-titlearea {
    width: 100%;
    height: unset;
  }

  #events-titlearea {
    background-position-x: 50%;
  }

  #events-titlearea .textarea>div:first-child {
    position: relative;
    width: 100%;
    height: unset;
    min-height: unset;
    margin: 0;
    padding: 120px 0 1rem 0;
    display: flex;
    flex-direction: column;
    justify-content: start;
    align-items: center;
  }


  #events-titlearea .textarea>div:first-child img {
    width: 95%;
  }

  #events-titlearea .textarea>div:first-child h1 {
    margin: 0.5rem 0 1rem 0;
    padding: 0;
    font-size: 7.5vw;
    color: #000;
  }

  #events-titlearea .textarea>div:first-child h2 {
    margin: 0.5rem 0 0 0;
    padding: 0;
    font-size: 4vw;
  }

  #events-titlearea .textarea>div:first-child p {
    color: #000;
    font-size: 1rem;
    line-height: 1.4;
    font-weight: 400;
  }

  #events-titlearea .textarea>div:nth-child(2) {
    margin: 0 0 1rem 0;
    padding: 0;

    width: 100%;
  }

  #events-titlearea .textarea>div:nth-child(2)>div {
    margin: 1rem 1rem 0 1rem;
    width: 100%;
  }

  #events-titlearea .textarea>div:last-child {
    margin: 0;
    padding: 0;
  }
}

@media (min-width: 768px) and (max-width: 991.98px) {

  /* md の画面サイズの場合のスタイル */
  #events-titlearea {
    width: 100%;
    height: unset;
  }

  #events-titlearea {
    background-position-x: 80%;
  }

  #events-titlearea .textarea>div:first-child {
    position: relative;
    width: 100%;
    height: unset;
    min-height: unset;
    margin: 0;
    padding: 120px 0 1rem 0;
    display: flex;
    flex-direction: column;
    justify-content: start;
    align-items: center;
  }


  #events-titlearea .textarea>div:first-child img {
    width: 95%;
  }


  #events-titlearea .textarea>div:first-child h1 {
    margin: 0.5rem 0 1rem 0;
    padding: 0;
    font-size: 7.5vw;
    color: #000;
  }

  #events-titlearea .textarea>div:first-child h2 {
    margin: 0.5rem 0 0 0;
    padding: 0;
    font-size: 4vw;
  }

  #events-titlearea .textarea>div:first-child p {
    color: #000;
    font-size: 1rem;
    line-height: 1.4;
    font-weight: 400;
  }

  #events-titlearea .textarea>div:nth-child(2) {
    margin: 0 0 1rem 0;
    padding: 0;

    width: 100%;
  }

  #events-titlearea .textarea>div:nth-child(2)>div {
    margin: 1rem 1rem 0 1rem;
    width: 100%;
  }

  #events-titlearea .textarea>div:last-child {
    margin: 0;
    padding: 0;
  }
}

@media (min-width: 992px) {
  /* lg 以上の画面サイズの場合のスタイル */
}

/*--------------------------------------------------------------
    イベント概要
  --------------------------------------------------------------*/

#events-adout {
  width: 100%;
  height: 100%;
}

#events-adout .events-adout-grid {
  width: 100%;
  height: 100%;

  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto;
  column-gap: 2rem;
  row-gap: 1rem;
}



#events-adout .icon-grid {
  margin: 0 0 2rem 0;
  position: relative;
  height: 3rem;
  display: grid;
  grid-template-columns: 3rem 1fr;
  column-gap: 0.5rem;
}

#events-adout .events-adout-grid h3 {
  margin: 0 0 0.5rem 0;
  padding: 0;

  font-size: 1.5rem;
  color: rgb(1, 161, 51);
}

#events-adout .icon-grid span {
  width: 3rem;
  height: 3rem;
  display: flex;
  justify-content: center;
  align-items: end;
  font-size: 3rem;
  color: rgb(1, 161, 51);
}

#events-adout .events-adout-grid p>img {
  margin: 0 1rem 0 0;
  padding: 0;
  height: 6rem;
  float: left;
}

#events-adout h2 {
  margin: 0 0 3rem 0;
  padding: 0;
  text-align: center;
  vertical-align: middle;
}

#events-adout h2 img {
  vertical-align: middle;
}

#events-adout h5 {
  margin: 0 0 0.5rem 0;
  padding: 0;
}

#events-adout img.koro-pok-kur {
  width: 4rem;
}

@media (max-width: 767.98px) {

  /* sm 以下の画面サイズの場合のスタイル */
  #events-adout .events-adout-grid {
    grid-template-columns: 1fr
  }
}

@media (min-width: 768px) and (max-width: 991.98px) {

  /* md の画面サイズの場合のスタイル */
  #events-adout .events-adout-grid {
    grid-template-columns: 1fr
  }
}

@media (min-width: 992px) {
  /* lg 以上の画面サイズの場合のスタイル */
}


/* */
#events-adout .events-adout-fivepoints {
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: center;
}

#events-adout .events-adout-fivepoints h3 {
  margin: 3rem 0 3rem 0;
  padding: 0;
}

#events-adout .events-adout-fivepoints ul li {
  margin: 1rem 0 1rem 0;
  padding: 0.8rem 2rem 0.8rem 2rem;
  font-size: clamp(1.125rem, 2.5vw, 1.8rem);
  line-height: 1.25;
  text-align: center;
  list-style-type: none;
  background-color: rgb(27, 200, 186);
  color: #fff;
  border-radius: 2rem;
}

/*--------------------------------------------------------------
    イベント詳細
  --------------------------------------------------------------*/

#events-details {
  width: 100%;
  height: 100%;
}

#events-details .events-details-grid {
  width: 100%;
  height: 100%;

  margin: 1rem 0 1rem 0;

  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto;
  column-gap: 1rem;
  row-gap: 1rem;
}

#events-details .events-details-grid>div {
  height: unset;
  margin: 0;
  padding: 1rem;
  background-color: #2edcb9;
  color: #fff;
  border-radius: 1rem;
}


#events-details .icon-grid-section {
  margin: 0 0 2rem 0;
  position: relative;
  height: 7rem;
  display: grid;
  grid-template-columns: 7rem 1fr;
  column-gap: 0.5rem;
}

#events-details .icon-grid-section>div:first-child {
  display: flex;
  justify-content: center;
  align-items: center;
}

#events-details .icon-grid-section>div:last-child {
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: start;
}

#events-details .icon-grid-section>div:last-child h3 {
  margin: 0;
}

#events-details .icon-grid-section>div img {
  width: 6rem;
}


#events-details h2 {
  margin: 3rem 0 3rem 0;
  padding: 0;
  text-align: center;
}

#events-details h3 {
  margin: 0 0 0.5rem 0;
  padding: 0;

  font-size: 1.5rem;
  text-align: start;
}



@media (max-width: 767.98px) {

  /* sm 以下の画面サイズの場合のスタイル */
  #events-details .events-details-grid {
    grid-template-columns: 1fr
  }
}

@media (min-width: 768px) and (max-width: 991.98px) {

  /* md の画面サイズの場合のスタイル */
  #events-details .events-details-grid {
    grid-template-columns: 1fr
  }
}

@media (min-width: 992px) {
  /* lg 以上の画面サイズの場合のスタイル */
}

/**/

#events-details .events-details-area {
  margin: 3rem 0 3rem 0;
  padding: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: start;
}

#events-details .events-schedule-area {
  margin: 3rem 0 3rem 0;
  padding: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: start;
}

#events-details .events-details-grid-sub {
  width: 100%;
  height: 100%;

  display: grid;
  grid-template-columns: 12rem 1fr;
  grid-template-rows: auto;
  column-gap: 2rem;
  row-gap: 0.2rem;
}

#events-details .events-details-grid-sub>span {
  margin: 0;
  padding: 0;

  font-size: clamp(1rem, 1.5vw, 1.4rem);
  line-height: 1.25;
}

#events-details .events-details-grid-sub>span:nth-child(2n+1) {
  text-align-last: justify;
  font-weight: 600;
}



@media (max-width: 767.98px) {

  /* sm 以下の画面サイズの場合のスタイル */

}

@media (min-width: 768px) and (max-width: 991.98px) {

  /* md の画面サイズの場合のスタイル */

}

@media (min-width: 992px) {
  /* lg 以上の画面サイズの場合のスタイル */
}


/* 修正: スケジュール時間表示グリッド */
#events-details .events-details-grid-time {
  margin: 1rem 0 0 0;
  display: flex;
  /* 行を縦に並べる */
  flex-direction: column;
  /* 縦並びの指定 */
  row-gap: 0.5rem;
  /* 行間のスペース */
}

/* 各行のコンテナ */
#events-details .event-row {
  display: flex;
  /* 列を横に並べる */
  column-gap: 1.0rem;
  /* 列間のスペース */
  align-items: baseline;
  /* テキストのベースラインを揃えるときれいです */
}

/* 各列の共通スタイル */
#events-details .events-details-grid-time span {
  margin: 0;
  padding: 0;
  font-size: clamp(1rem, 1.5vw, 1.4rem);
  line-height: 1.25;
  font-weight: 400;
  white-space: nowrap;
  /* すべての列で改行を防ぐ */
}

/* 1列目: 右揃え、幅6rem */
#events-details .first-block {
  width: 6rem;
  text-align: right;
  flex-shrink: 0;
  /* 幅が縮まないようにする */
}

/* 2列目: 中央揃え、幅10rem */
#events-details .second-block {
  text-align: center;
  flex-shrink: 0;
  /* 幅が縮まないようにする */
}

/* 3列目: 左揃え、成り行きの幅 */
#events-details .third-block {
  flex: 1;
  /* 残りのスペースをすべて使う */
  text-align: left;
  /* white-space: nowrap; は必要に応じて設定 */
}

/* スケジュールブロック */
#events-details .events-details-grid-schedule {
  margin: 0;
  width: 100%;
  height: unset;
  display: grid;
  grid-template-columns: 1fr;
  column-gap: 2rem;
  row-gap: 2rem;
}

/* 注意書きテキストとの間隔確保 */
#events-details .events-schedule-area>div:last-child {
  margin-top: 1.5rem;
  /* 注意書きテキストの上マージンを追加 */
}

/* スマートフォン向けの追加調整 */
@media (max-width: 767.98px) {
  #events-details .events-details-grid-schedule {
    grid-template-columns: 1fr;
  }
}

/* タブレット向けの調整 */
@media (min-width: 768px) and (max-width: 991.98px) {
  #events-details .events-details-grid-schedule {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 992px) {
  /* lg 以上の画面サイズの場合のスタイル */
}



/*--------------------------------------------------------------
    FAQ
  --------------------------------------------------------------*/

#event-faq {
  margin: 0;
  padding: 0;
}

#event-faq h2 {
  margin: 3rem 0 3rem 0;
  padding: 0;
}

#event-faq h4 {
  margin: 0 0 1rem 0;
  padding: 0;
}

#event-faq .events-details-grid-faq>div {
  margin: 0 0 1rem 0;
  padding: 0;
}

#event-faq .events-details-grid-faq>div h5 {
  color: rgb(var(--main-color) / 1)
}

#event-faq .event-faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: auto;
  column-gap: 2rem;
  row-gap: 1rem;
}




/*--------------------------------------------------------------
    申し込み
  --------------------------------------------------------------*/


#application {
  margin: 0;
  padding: 0;
}

#application h2 {
  margin: 3rem 0 3rem 0;
  padding: 0;
}


/*--------------------------------------------------------------
    内側のリストマーカー
  --------------------------------------------------------------*/

/* ul要素全体に適用する場合 */
ul.custom-list-marker-arrow {
  margin: 0.5rem 0 2rem 2rem;
  padding: 0;
  list-style-type: none;
  padding-left: 0;
  list-style-position: outside;
  font-size: 1.2rem;
  line-height: 1.5;
}

ul.custom-list-marker-arrow li::marker {
  content: '⇒ ';
  color: #000;
  font-weight: bold;
}



/*--------------------------------------------------------------
    イベントマージンエリア
  --------------------------------------------------------------*/
#margin-area {
  position: relative;
  margin: 0;
  padding: 0;

  height: 50vh;
}


#margin-area>div>div {
  width: 100vw;
  height: 50vh;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between
}

#margin-area div.illustarea {
  width: 100vw;
  height: 50vh;
}

#margin-area div.illustarea>div:first-child {
  width: 100%;
  display: flex;
  justify-content: start;
  align-items: start;
}

#margin-area div.illustarea>div:nth-child(2) {
  width: 100%;
  display: flex;
  justify-content: end;
  align-items: end;
}

img.ookinakabu {
  z-index: 100;
  width: 30vw;
  position: absolute;
  left: 20%;
}




/*--------------------------------------------------------------
    スケジュール
  --------------------------------------------------------------*/
#events-details {
  width: 100%;
  height: 100%;
}

#events-details h3 {
  margin: 3rem 0 3rem 0;
  padding: 0;
}

#events-details h5 {
  text-align: center;
}

#events-details h5>span {
  display: block;
  font-size: 1rem;
  line-height: 1;
  font-weight: 400;
}


#events-details .schedule-grid-first {
  width: 100%;
  height: 100%;

  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: auto;
  column-gap: 2rem;
  row-gap: 2rem;
}

#events-details .schedule-grid-first>div div:first-child {
  margin: 0;
  padding: 0.5rem 0 0.5rem 0;
  background-color: rgb(var(--main-color) / 0.3);

  border-radius: 1rem 1rem 0 0;
}

#events-details .schedule-grid-first>div div:last-child {
  margin: 0;
  padding: 1rem;
  background-color: rgb(var(--main-color) / 0.1);

  border-radius: 0 0 1rem 1rem;
}

#events-details div.schedule-inner-grid {
  width: 100%;
  display: grid;
  grid-template-columns: 5rem 1fr 7rem 5rem;
  column-gap: 0;
  row-gap: 0;
}

#events-details div.schedule-inner-grid>span {
  border-bottom: 1px solid #ccc;
}

#events-details div.schedule-inner-grid>span:nth-child(4n+2) {
  padding: 0 1rem 0 1rem;
}

#events-details div.schedule-inner-grid>span:nth-child(4n+1),
#events-details div.schedule-inner-grid>span:nth-child(4n+4) {
  text-align: end;
  text-wrap: nowrap;
}

#events-details div.schedule-inner-grid>span:nth-child(4n+1) {
  font-weight: 600;
}

#events-details div.schedule-inner-grid span.center {
  font-weight: 600;
  text-align: center;
}

@media (max-width: 767.98px) {

  /* sm 以下の画面サイズの場合のスタイル */
  #events-details .schedule-grid-first {
    display: grid;
    grid-template-columns: 1fr;
  }
}

@media (min-width: 768px) and (max-width: 991.98px) {

  /* md の画面サイズの場合のスタイル */
  #events-details .schedule-grid-first {
    display: grid;
    grid-template-columns: 1fr;
  }
}

@media (min-width: 992px) {
  /* lg 以上の画面サイズの場合のスタイル */
}