@charset "UTF-8";
:root {
  --mainColor: #F29424;
  --pointColor: #ffb300;
  --textColor: #000;
  --sidePadding: 64px;
}
@media (max-width: 999px) {
  :root {
    --sidePadding: 40px;
  }
}
@media (max-width: 767px) {
  :root {
    --sidePadding: 20px;
  }
}

.hide-pc {
  display: none !important;
}

.show-pc,
.show-tab,
.show-sp {
  display: none !important;
}

@media (min-width: 1000px) {
  .show-pc {
    display: block !important;
  }
}
@media (max-width: 999px) {
  .show-tab {
    display: block !important;
  }
}
@media (max-width: 767px) {
  .hide-pc {
    display: block !important;
  }
  .hide-sp {
    display: none !important;
  }
  .show-sp {
    display: block !important;
  }
}
.inline-block {
  display: inline-block;
}

/* Typography */
.ff-en {
  font-family: "Akshar", sans-serif;
}

.fw-medium {
  font-weight: 500;
}

.fw-bold {
  font-weight: bold;
}

.sectionTitle {
  text-align: center;
  line-height: 1.15;
}
.sectionTitle_caption {
  font-size: 80px;
}
@media (max-width: 999px) {
  .sectionTitle_caption {
    font-size: 56px;
  }
}
@media (max-width: 767px) {
  .sectionTitle_caption {
    font-size: 10.6666666667vw;
  }
}
.sectionTitle_sub {
  color: var(--mainColor);
}
@media (max-width: 767px) {
  .sectionTitle_sub {
    padding-top: 1.0666666667vw;
    font-size: 3.2vw;
  }
}

.l-contents p a, .l-contents li a {
  text-decoration: underline;
}

/* button */
.btn {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  max-width: 640px;
  height: 120px;
  font-size: 20px;
  font-weight: 700;
  text-decoration: none;
}
@media (max-width: 999px) {
  .btn {
    max-width: 450px;
    height: 90px;
  }
}
@media (max-width: 767px) {
  .btn {
    width: 78.6666666667vw;
    height: 21.3333333333vw;
    font-size: 4.2666666667vw;
  }
}
.btn.-primary {
  background: var(--mainColor);
  color: #fff;
}
@media (hover: hover) and (pointer: fine) {
  .btn.-primary:hover {
    background: #f09c00;
  }
}
.btn.-border {
  border: solid 1px var(--textColor);
}
@media (hover: hover) and (pointer: fine) {
  .btn.-border:hover {
    background: var(--textColor);
    color: #fff;
  }
}

/**
 * wp admin only
 */
.wp-admin .wp-block {
  max-width: 1200px;
}
.wp-admin .about_price dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.wp-admin .about_price dl dt, .wp-admin .about_price dl dd {
  margin: 5px;
}

/**
 * section title
 */
.c-sectionTitle {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
  margin-bottom: 56px;
}
.c-sectionTitle::before {
  content: "";
  display: block;
  width: 40px;
  height: 39px;
  background: url(images/icon-title.png) no-repeat center;
  background-size: contain;
}
.c-sectionTitle .en {
  font-family: "Akshar", sans-serif;
  font-size: 40px;
  font-weight: 500;
  text-transform: uppercase;
}
.c-sectionTitle .ja {
  position: relative;
  text-align: right;
  padding-bottom: 15px;
  margin-left: auto;
  width: 120px;
  border-bottom: solid 1px #fff;
  font-size: 12px;
  line-height: 1;
}
.c-sectionTitle .ja::after {
  position: absolute;
  right: 0;
  bottom: -1px;
  content: "";
  display: block;
  width: 16px;
  height: 1px;
  background: var(--mainColor);
}
@media (max-width: 767px) {
  .c-sectionTitle {
    margin-bottom: 30px;
  }
  .c-sectionTitle::before {
    width: 28px;
    height: 28px;
  }
  .c-sectionTitle .en {
    font-size: 32px;
  }
  .c-sectionTitle .ja {
    width: 88px;
    padding-bottom: 12px;
  }
  .c-sectionTitle .ja::after {
    width: 14px;
  }
}

/**
 * スケジュール
 */
.schedule_table + .schedule_table {
  margin-top: 64px;
}
@media (max-width: 767px) {
  .schedule_table + .schedule_table {
    margin-top: 40px;
  }
}
.schedule_table .title {
  padding-bottom: 16px;
  color: var(--mainColor);
  font-size: 24px;
  font-weight: 500;
}
.schedule_table .list {
  border: solid 1px #fff;
}
@media (max-width: 767px) {
  .schedule_table .list {
    border: none;
  }
}
.schedule_table .item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.schedule_table .item + .item {
  border-top: solid 1px #fff;
}
@media (max-width: 767px) {
  .schedule_table .item {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    border: solid 1px #fff;
  }
  .schedule_table .item + .item {
    margin-top: 12px;
  }
}
.schedule_table .item p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-top: 0.8em;
  padding-bottom: 0.8em;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.5;
}
.schedule_table .item_date {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 158px;
}
@media (max-width: 767px) {
  .schedule_table .item_date {
    width: 58%;
  }
}
.schedule_table .item_time {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 134px;
  border-left: solid 1px #fff;
}
@media (max-width: 767px) {
  .schedule_table .item_time {
    width: 42%;
  }
}
.schedule_table .item_title {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
  padding-left: 20px;
  padding-right: 12px;
  border-left: solid 1px #fff;
}
.schedule_table .item_title span {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.schedule_table .item_title a {
  display: block;
}
.schedule_table .item_title a img {
  width: 20px;
}
@media (hover: hover) and (pointer: fine) {
  .schedule_table .item_title a:hover {
    opacity: 0.75;
  }
}
@media (max-width: 767px) {
  .schedule_table .item_title {
    width: 100%;
    padding-left: 16px;
    padding-right: 16px;
    border-left: 0;
    border-top: solid 1px #fff;
  }
}