/*--------------------------------
	　Font
--------------------------------*/

@font-face {
  font-family: "NotoSansJP-Bold";
  src: url("../font/NotoSansJP-Bold.woff");
  font-style: normal;
  font-weight: 700;
}

@font-face {
  font-family: "NotoSansJP-Medium";
  src: url("../font/NotoSansJP-Medium.woff");
  font-style: normal;
  font-weight: 500;
}

@font-face {
  font-family: "NotoSansJP-Regular";
  src: url("../font/NotoSansJP-Regular.woff");
  font-style: normal;
  font-weight: 400;
}

@font-face {
  font-family: "NotoSansJP-Light";
  src: url("../font/NotoSansJP-Light.woff");
  font-style: normal;
  font-weight: 300;
}


@font-face {
  font-family: "NotoSerifJP-Light";
  src: url("../font/NotoSerifJP-Light.woff");
  font-style: normal;
  font-weight: 300;
}

@font-face {
  font-family: "NotoSerifJP-Regular";
  src: url("../font/NotoSerifJP-Regular.woff");
  font-style: normal;
  font-weight: 400;
}

@font-face {
  font-family: "NotoSerifJP-Medium";
  src: url("../font/NotoSerifJP-Medium.woff");
  font-style: normal;
  font-weight: 500;
}

@font-face {
  font-family: "NotoSerifJP-SemiBold";
  src: url("../font/NotoSerifJP-SemiBold.woff");
  font-style: normal;
  font-weight: 600;
}

@font-face {
  font-family: "NotoSerifJP-Bold";
  src: url("../font/NotoSerifJP-Bold.woff");
  font-style: normal;
  font-weight: 700;
}

html {
  scroll-behavior: smooth !important;
}




/*--------------------------------
	　Common
--------------------------------*/

.sp-only {
  display: none !important;
}

.inner {
  max-width: 1120px;
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}

a:hover {
  opacity: 0.7;
}



/*--------------------------------
	　Header
--------------------------------*/

.header {
  padding: 24px 40px;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
}

.header__menu {
  width: 100%;
}

.header__buttons {
  width: 100%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 24px;
}

.header__entry a {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 24px 48px;
  border-radius: 4px;
  background: #003078;
  color: white;
  font-size: 18px;
  font-family: "NotoSerifJP-Medium";
  letter-spacing: 0.113em;
  text-decoration: none;
}

.header__contact a {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 24px 28px;
  border-radius: 0.4rem;
  border: 2px solid rgba(0, 0, 0, 0.12);
  background: #FFF;
  color: #000;
  text-align: center;
  font-family: "NotoSerifJP-Regular";
  font-size: 16px;
  letter-spacing: 0.1em;
  text-decoration: none;
}





/*--------------------------------
	　Main View
--------------------------------*/

.mv {
  background-image: url(../images/mv-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  height: 740px;
}

.mv__inner {
  padding-top: 70px;

  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.mv__box > img {
  width: 338px;
  height: auto;
  padding-bottom: 30px;
}

.mv__text {
  color: #E4CF91;
  font-family: "NotoSerifJP-Regular";
  font-size: 26px;
  letter-spacing: 0.244em;
}

.mv__text--small {
  font-size: 21px;
}

.mv__title {
  width: 705px;
  height: 150px;
  margin-top: 38px;
  margin-bottom: 60px;
}

.mv__title img {
  width: 100%;
  height: 100%;
}

.mv__logo {
  width: 512px;
  height: auto;
  margin-bottom: 28px;
}

.mv__logo img {
  width: 100%;
  height: 100%;
}

.mv__sub-text {
  color: #E4CF91;
  font-family: "NotoSerifJP-Medium";
  font-size: 24px;
  line-height: 180%;
  letter-spacing: 0.31em;

  display: inline-block;
  text-align: center;
  padding: 5px 15px;
  border-top: 1px solid #E4CF91;
  border-bottom: 1px solid #E4CF91;
  background: rgba(0, 0, 0, 0.31);
}

.mv__img {
  width: 387px;
  height: 194px;
}

.mv__img img {
  width: 100%;
  height: 100%;
}







/*--------------------------------
	　About
--------------------------------*/

.about {
  background-image: url(../images/about-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
}

.about__inner {
  padding-top: 60px;
  padding-bottom: 92px;

  display: flex;
  justify-content: space-between;
}

.about__content {
  display: flex;
  flex-direction: column;
  gap: 48px;
  margin-top: 169px;
  margin-right: -110px;
  z-index: 100;
}

.about__title {
  width: 602px;
  height: 167px;
}

.about__title img {
  width: 100%;
  height: 100%;
}

.about__text {
  color: #000;
  font-size: 28px;
  line-height: 220%;
  letter-spacing: 0.14em;
  font-family: "NotoSerifJP-Regular";
  width: 620px;
  margin-left: 34px;
}

.about__img {
  width: 640px;
  height: 400px;
}

.about__img img {
  width: 100%;
  height: 100%;
}







/*--------------------------------
	　Features
--------------------------------*/

.features {
  width: 100%;
  background: #001535;
}

.features__inner {
  padding-top: 100px;
  padding-bottom: 120px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  row-gap: 56px;
}

.features__tit {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 24px;
}

.features__tit>img {
  width: 155px;
  height: auto;
}

.features__tit>h3 {
  font-size: 30px;
  color: #fff;
  font-family: "NotoSerifJP-Medium";
  letter-spacing: 0.281em;
}

.features__contents {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
}

.features__content {
  width: 346px;
  height: 454px;
  position: relative;
}

.feature__img {
  width: 100%;
  height: 100%;
}

.feature__img img {
  width: 100%;
  height: 100%;
}

.feature__box {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  z-index: 100;

  display: flex;
  align-items: center;
  flex-direction: column;
  box-sizing: border-box;
  width: 100%;
  padding: 48px 32px;
}

.features__content:nth-child(1) .feature__box {
  gap: 121px;
}

.features__content:nth-child(2) .feature__box {
  gap: 43px;
}

.features__content:nth-child(3) .feature__box {
  gap: 95px;
}

.feature__number {
  width: 44px;
  height: 30px;
}

.feature__number img {
  width: 100%;
  height: 100%;
}

.feature__text {
  color: #FFF;
  text-align: center;
  font-size: 28px;
  line-height: 187%;
  letter-spacing: 0.1em;
  font-family: "NotoSerifJP-Medium";
}









/*--------------------------------
  　Speaker
--------------------------------*/

.speaker {
  background: #000;
}

.speaker__inner {
  padding-top: 100px;
  padding-bottom: 120px;

  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;

  display: flex;
  flex-direction: column;
  align-items: center;
}

.speaker__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 24px;
}

.speaker__title>img {
  width: 135px;
  height: auto;
}

.speaker__title>h3 {
  font-size: 30px;
  color: #fff;
  font-family: "NotoSerifJP-Medium";
  letter-spacing: 0.281em;
}

.speaker__text {
  color: #FFF;
  text-align: center;
  font-family: "NotoSerifJP-Light";
  font-size: 16px;
  line-height: 221%;
  letter-spacing: 0.016em;
  margin-top: 44px;
  margin-bottom: 64px;
}


/*--------------------------------
  　登壇者スライダー
--------------------------------*/

/* slider */

.slider {
  width: 100%;
}

.slider-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  width: 100%;
  max-width: 257px;
  margin-right: 40px;
}

.slider-item__img {
  width: 257px;
  height: 257px;
  border-radius: 100%;
  object-fit: cover;
  margin: 0 auto;
}

.slider-item__body {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.slider-item__name {
  color: white;
  text-align: center;
  font-family: "NotoSerifJP-Regular";
  font-size: 24px;
  line-height: 180%;
  letter-spacing: 0.016em;
}

.slider-item__position-1 {
  color: #AC8A11;
  text-align: center;
  font-family: "NotoSerifJP-Regular";
  font-size: 16px;
  line-height: 180%;
  letter-spacing: 0.016em;
  width: 100%;
}

.slider-item__position-2 {
  color: white;
  text-align: center;
  font-family: "NotoSerifJP-Regular";
  font-size: 16px;
  line-height: 180%;
  letter-spacing: 0.016em;
  margin-top: 10px;
  width: 100%;
}







/*--------------------------------
	　Curriculum
--------------------------------*/
.curriculum {
  background-image: url(../images/curriculum-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
}

.curriculum__inner {
  padding-top: 100px;
  padding-bottom: 120px;
  display: flex;
  flex-direction: column;
  row-gap: 56px;
  box-sizing: border-box;
}

.curriculum__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 24px;
}

.curriculum__title>img {
  width: 207px;
  height: auto;
}

.curriculum__title>h3 {
  font-size: 30px;
  color: #fff;
  font-family: "NotoSerifJP-Medium";
  letter-spacing: 0.094em;
}

.curriculum__box {
  width: 100%;
}

.curriculum__items {
  display: flex;
  justify-content: center;
  align-items: stretch;
  width: 100%;
}

.curriculum__item {
  width: 280px;
  background-color: white;
  padding: 32px 24px;
  box-sizing: border-box;

  display: flex;
  flex-direction: column;
  gap: 24px;
}

.curriculum__item:nth-child(even) {
  background: rgba(255, 255, 255, 0.93);
}

.curriculum__item--odd {
  background: rgba(255, 255, 255, 0.93);
}

.curriculum__item--odd:nth-child(even) {
  background-color: white;
}

.curriculum__item-title {
  width: 100%;
  display: block;
  color: #C39000;
  text-align: center;
  font-family: "NotoSerifJP-SemiBold";
  font-size: 22px;
  line-height: 150%;
  letter-spacing: 0.138em;
  padding-bottom: 12px;
  border-bottom: 1px solid #C39000;
}

.curriculum__contents {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.curriculum__content {
  width: 100%;
  padding-left: 1em;
  text-indent: -1em;
  color: #000;
  font-family: "NotoSansJP-Regular";
  font-size: 14px;
  line-height: 133%;
  box-sizing: border-box;
}

.curriculum__content::before {
  content: '・';
}







/*--------------------------------
	　Schedule
--------------------------------*/
.schedule {
  background-image: url(../images/schedule-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
}

.schedule__inner {
  padding-top: 100px;
  padding-bottom: 120px;
  display: flex;
  flex-direction: column;
  row-gap: 56px;
  box-sizing: border-box;
}

.schedule__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 24px;
}

.schedule__title>img {
  width: 163px;
  height: auto;
}

.schedule__title>h3 {
  font-size: 30px;
  color: #000;
  font-family: "NotoSerifJP-Medium";
  letter-spacing: 0.281em;
}

.schedule__container {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.schedule__wrapper {
  display: flex;
  justify-content: space-between;
  gap: 56px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  background: #FFF;
  padding: 56px;
}

.schedule__left {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.schedule__year {
  font-size: 20px;
  color: #000;
  letter-spacing: 0.125em;
  font-family: "NotoSerifJP-Regular";
}

.schedule__box {
  display: flex;
  justify-content: flex-start;
  align-items: flex-end;
  gap: 8px;
}

.schedule__date {
  font-size: 45px;
  color: #000;
  font-family: "NotoSerifJP-Regular";
}

.schedule__week {
  font-size: 20px;
  color: #000;
  letter-spacing: 0.18em;
  font-family: "NotoSerifJP-Regular";
}

.schedule__right {
  width: 774px;
}

.schedule__items {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.schedule__item {
  padding-top: 32px;
  border-top: 1px solid #444;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.schedule__item:first-child {
  padding-top: 0;
  border-top: none;
}


.schedule__time {
  color: #D1B871;
  font-size: 18px;
  font-family: "NotoSerifJP-Regular";
  line-height: 180%;
  letter-spacing: 0.016em;
}

.schedule__seminer-title {
  color: #000;
  font-size: 26px;
  font-family: "NotoSerifJP-Medium";
  line-height: 150%;
  letter-spacing: 0.016em;
  text-align: left;
  width: 100%;
}

.schedule__flex {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
}

.schedule__speaker {
  background: #EEE;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 3px 20px;
  color: #000;
  font-size: 16px;
  font-family: "NotoSerifJP-Regular";
  line-height: 180%;
  letter-spacing: 0.016em;
}

.schedule__name {
  color: #000;
  font-size: 18px;
  font-family: "NotoSerifJP-Regular";
  line-height: 180%;
  letter-spacing: 0.016em;
}

.schedule__text {
  color: #000;
  font-size: 14px;
  font-family: "NotoSerifJP-Regular";
  line-height: 180%;
  letter-spacing: 0.016em;
  text-align: left;
  width: 100%;
}

.schedule__more {
  width: 100%;
  border-radius: 4px;
  border: 1px solid #001D4A;
  background: #FFF;
  padding: 16px 48px;
  box-sizing: border-box;
  cursor: pointer;
}

.schedule__btn-inner {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
}

.schedule__btn-text {
  color: #001D4A;
  font-family: "NotoSerifJP-Medium";
  font-size: 18px;
  letter-spacing: 0.113em;
}

.schedule__icon {
  width: 22px;
  height: 22px;
}

.schedule__icon img {
  width: 100%;
  height: 100%;
}

.js-btn-close {
  display: none;
}






/*--------------------------------
	　Step
--------------------------------*/

.step {
  background: #001535;
  width: 100%;
}

.step__inner {
  padding-top: 100px;
  padding-bottom: 120px;
  display: flex;
  flex-direction: column;
  row-gap: 80px;
  max-width: 1120px;
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}

.step__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 24px;
}

.step__title>img {
  width: 260px;
  height: auto;
}

.step__title>h3 {
  font-size: 30px;
  color: #fff;
  font-family: "NotoSerifJP-Medium";
  letter-spacing: 0.281em;
}

.step__items {
  display: flex;
  justify-content: space-between;
  width: 100%
}

.step__item {
  width: 30.893%;
}

.step__img {
  width: 100%;
  height: 221px;
}

.step__img img {
  width: 100%;
  height: 100%;
}

.step__number {
  margin-top: 24px;
  width: 74px;
  height: 20px;
}

.step__number img {
  width: 100%;
  height: 100%;
}

.step__item-title {
  color: #FFF;
  font-family: "NotoSerifJP-SemiBold";
  font-size: 24px;
  line-height: 150%;
  letter-spacing: 0.3em;

  display: block;
  width: 100%;
  padding-bottom: 16px;
  margin-top: 12px;
  border-bottom: 1px solid #D1B871;
}

.step__text {
  margin-top: 16px;
  color: #FFF;
  font-family: "NotoSerifJP-Light";
  font-size: 16px;
  line-height: 221%;
  letter-spacing: 0.25px;
}







/*--------------------------------
	　Price
--------------------------------*/

.price {
  background-image: url(../images/price-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
}

.price__inner {
  padding-top: 100px;
  padding-bottom: 120px;
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 56px;
  box-sizing: border-box;
}

.price__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 24px;
}

.price__title>img {
  width: 88px;
  height: auto;
}

.price__title>h3 {
  font-size: 30px;
  color: #000;
  font-family: "NotoSerifJP-Medium";
  letter-spacing: 0.281em;
}

.price__content {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  gap: 8px;
  width: 100%;
}

.price__left {
  max-width: 556px;
  width: 100%;
  height: 434px;
  background: #FFF;
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  padding: 40px;
  box-sizing: border-box;
}

.price__fee {
  width: 350px;
  height: 69px;
}

.price__fee img {
  width: 100%;
  height: 100%;
}

.price__detail {
  margin-top: 28px;
  color: #000;
  text-align: center;
  font-size: 12px;
  line-height: 180%;
  letter-spacing: 0.016em;
  font-family: "NotoSansJP-Light";
  width: 100%;
  max-width: 452px;
}


.price__right {
  max-width: 556px;
  width: 100%;
  height: 434px;
  background: #FFF;
  display: flex;
  flex-direction: column;
  padding: 48px;
  box-sizing: border-box;
}

.price__items {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
}

.price__item {
  display: flex;
  align-items: center;
  gap: 15px;
}

.price__icon {
  width: 36px;
  height: 36px;
}

.price__icon img {
  width: 100%;
  height: 100%;
}

.price__text {
  color: #000;
  font-size: 16px;
  line-height: 180%;
  letter-spacing: 0.016em;
  font-family: "NotoSerifJP-Light";
  width: 100%;
  max-width: 404px;
}





/*--------------------------------
	　Contact
--------------------------------*/

.contact {
  background-image: url(../images/contact-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
}

.contct__inner {
  padding-top: 120px;
  padding-bottom: 120px;
  display: flex;
  justify-content: space-between;
  row-gap: 56px;
  box-sizing: border-box;
}

.contact__left {
  display: flex;
  flex-direction: column;
  width: 500px;
  box-sizing: border-box;
}

.contact__title {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.contact__title>img {
  width: 139px;
  height: auto;
}

.contact__title>h3 {
  font-size: 30px;
  color: #fff;
  font-family: "NotoSerifJP-Medium";
  letter-spacing: 0.281em;
}

.contact__text {
  color: #fff;
  font-size: 16px;
  line-height: 180%;
  font-family: "NotoSerifJP-Light";
  margin-top: 32px;
  margin-bottom: 32px;
}

.contact__tel {
  border-top: 1px solid rgba(255, 255, 255, 0.26);
  padding: 24px 0px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.contact__tel a {
  width: 435px;
  height: 40px;
}

.contact__tel>a>img {
  width: 100%;
  height: 100%;
}

.contact__tel-title {
  color: #FFF;
  font-family: "NotoSerifJP-Regular";
  font-size: 18px;
  line-height: 150%;
  letter-spacing: 0.225em;
}

.contact__tel-time {
  color: #FFF;
  font-family: "NotoSerifJP-Regular";
  font-size: 18px;
  line-height: 150%;
  letter-spacing: 0.225em;
}

.contact__right {
  width: 563px;
  padding: 40px;
  border-radius: 6px;
  background: #FFF;
  box-shadow: 0px 4px 45px 0px rgba(7, 51, 86, 0.15);
  box-sizing: border-box;
}



/*--------------------------------
	　Form
--------------------------------*/

.form__wrap {
  width: 100%;
}

.wpcf7 .template01 {
  color: #000;
  font-size: 18px;
  line-height: 150%;
  letter-spacing: 0.016em;
  font-family: "NotoSerifJP-Medium";
}

.wpcf7 .template01 a {
  margin: 0;
  padding: 0;
  text-decoration: none;
  color: #0078DC;
  transition: opacity .25s;
}

.wpcf7 .template01 a:hover {
  opacity: .5;
  transition: opacity .25s;
}

.form__flex {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}

.wpcf7 .template01 div.form__row {
  margin: 0;
  padding: 0;
  margin-top: 16px;
}

.wpcf7 .template01 div.form__row.row-privacy {
  margin-top: 24px;
  text-align: center;
}

.wpcf7 .template01 div.form__row.row-submit {
  margin-top: 24px;
  text-align: center;
}

.wpcf7 .template01 p.form__label,
.wpcf7 .template01 p.form__body {
  margin: 0;
  margin-bottom: 16px;
  padding: 0;
  box-sizing: border-box;
}

.wpcf7 .template01 p.form__label label {
  position: relative;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

.wpcf7 .template01 p.form__label.is-required label {
  padding-right: 40px;
}

/* 
.wpcf7 .template01 p.form__label.is-required label::after {
  content: "必須";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 36px;
  padding: 0 5px;
  background-color: rgba(179, 0, 36);
  color: #fff;
  font-size: 11px;
  text-align: center;
  box-sizing: border-box;
} */

/* テキストフィールド */
.wpcf7 .template01 input[type=text],
.wpcf7 .template01 input[type=tel],
.wpcf7 .template01 input[type=email],
.wpcf7 .template01 input[type=url],
.wpcf7 .template01 input[type=date],
.wpcf7 .template01 input[type=number],
.wpcf7 .template01 textarea {
  width: 100%;
  margin: 0;
  height: 56px;
  padding: 8px 12px;
  border-radius: 4px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  box-shadow: none;
  background-color: #fff;
  box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  color: inherit;
  font-family: inherit;
  font-weight: inherit;
  font-size: inherit;
}

.wpcf7 .template01 textarea {
  height: 146px;
  resize: none;
}

/* テキストフィールド placeholder */
.wpcf7 .template01 input[type=text]::placeholder,
.wpcf7 .template01 input[type=tel]::placeholder,
.wpcf7 .template01 input[type=email]::placeholder,
.wpcf7 .template01 input[type=url]::placeholder,
.wpcf7 .template01 input[type=date]::placeholder,
.wpcf7 .template01 input[type=number]::placeholder,
.wpcf7 .template01 textarea::placeholder {
  color: rgba(0, 0, 0, 0.38);
  font-size: 18px;
  font-family: "NotoSansJP-Light";
  line-height: 180%;
  letter-spacing: 0.031em;
}

.wpcf7 .template01 input[type=text]:-ms-input-placeholder,
.wpcf7 .template01 input[type=tel]:-ms-input-placeholder,
.wpcf7 .template01 input[type=email]:-ms-input-placeholder,
.wpcf7 .template01 input[type=url]:-ms-input-placeholder,
.wpcf7 .template01 input[type=date]:-ms-input-placeholder,
.wpcf7 .template01 input[type=number]:-ms-input-placeholder,
.wpcf7 .template01 textarea:-ms-input-placeholder {
  color: rgba(0, 0, 0, 0.38);
  font-size: 18px;
  font-family: "NotoSansJP-Light";
  line-height: 180%;
  letter-spacing: 0.031em;
}

.wpcf7 .template01 input[type=text]::-ms-input-placeholder,
.wpcf7 .template01 input[type=tel]::-ms-input-placeholder,
.wpcf7 .template01 input[type=email]::-ms-input-placeholder,
.wpcf7 .template01 input[type=url]::-ms-input-placeholder,
.wpcf7 .template01 input[type=date]::-ms-input-placeholder,
.wpcf7 .template01 input[type=number]::-ms-input-placeholder,
.wpcf7 .template01 textarea::-ms-input-placeholder {
  color: rgba(0, 0, 0, 0.38);
  font-size: 18px;
  font-family: "NotoSansJP-Light";
  line-height: 180%;
  letter-spacing: 0.031em;
}

/* テキストフィールド フォーカス時 */
.wpcf7 .template01 input[type=text]:focus,
.wpcf7 .template01 input[type=tel]:focus,
.wpcf7 .template01 input[type=email]:focus,
.wpcf7 .template01 input[type=url]:focus,
.wpcf7 .template01 input[type=date]:focus,
.wpcf7 .template01 input[type=number]:focus,
.wpcf7 .template01 textarea:focus {
  outline: 0;
  border: 1px #080808 solid;
}

/* チェックボックス */

.wpcf7-acceptance .wpcf7-list-item-label {
  display: inline-block;
}

.wpcf7 .template01 input[type=checkbox] {
  display: none;
}

.wpcf7 .template01 input[type=checkbox]+span {
  cursor: pointer;
  position: relative;
  margin: 0;
  padding: 0;
  padding-left: 32px;
  font-size: inherit;
  box-sizing: border-box;
  transition: opacity .25s ease;
  text-align: left;
}

.wpcf7 .template01 input[type=checkbox]+span::before {
  content: "";
  opacity: 1;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  border: 2px solid #ccc;
  border-radius: 4px;
  background-color: #fff;
  box-sizing: border-box;
  transition: opacity .25s ease;
  z-index: 1;
  margin-top: 2px;
}

.wpcf7 .template01 input[type=checkbox]+span::after {
  content: "";
  opacity: 0;
  display: block;
  position: absolute;
  top: 3px;
  left: 6px;
  width: 6px;
  height: 12px;
  border-bottom: 3px solid #000;
  border-right: 3px solid #000;
  box-sizing: border-box;
  transform: rotate(40deg);
  transition: opacity .25s ease;
  z-index: 10;
}

.wpcf7 .template01 input[type=checkbox]:checked+span {
  color: #306ad4;
  transition: all .25s ease;
}

.wpcf7 .template01 input[type=checkbox]:checked+span::before {
  opacity: 1;
  transition: opacity .25s ease;
}

.wpcf7 .template01 input[type=checkbox]:checked+span::after {
  opacity: 1;
  border-bottom: 2px solid #306ad4;
  border-right: 2px solid #306ad4;
  transition: opacity .25s ease;
}

.form__body--index>span{
  color: #000;
  font-size: 14px;
  line-height: 150%;
  letter-spacing: 0.016em;
}

.form__body--index {
  margin-top: 4px;
}


/* ラジオボタン */

.radio-custum .wpcf7-list-item-label {
  border-radius: 4px;
  border: 2px solid rgba(0, 0, 0, 0.12);
  padding: 16px 8px;
  font-family: "NotoSansJP-Light";
}

input[type="radio"]:checked+.wpcf7-list-item-label {
  border-radius: 4px;
  border: 2px solid #0078DC;
  background: rgba(25, 118, 210, 0.06);
}


.wpcf7 .template01 input[type=radio] {
  display: none;
}

.wpcf7-form-control.wpcf7-radio {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}

.wpcf7-list-item.first {
  margin: 0;
}

.wpcf7-list-item-label {
  cursor: pointer;
  display: flex;
}

/* デフォルトのボタン */
input[type="radio"] {
  opacity: 0;
  /* デフォルトのボタンを非表示 */
  position: absolute;
}

/* チェック前のボタン */
.wpcf7-list-item-label::before {
  background: #fff;
  border: 1px solid #333;
  border-radius: 100%;
  /* ラジオボタンっぽく丸くする */
  content: "";
  height: 20px;
  margin-bottom: auto;
  margin-right: 8px;
  margin-top: auto;
  transition: background-color .5s;
  /* 色をじんわり変化させる */
  width: 20px;
}

/* チェック後のボタン */
input[type="radio"]:checked+.wpcf7-list-item-label::before {
  background-color: #0078DC;
  /* チェック後の中心の色 */
  box-shadow: inset 0 0 0 3px #fff;
  /* 中心の色のスタイル */
  border: 1px solid #0078DC;
}


/* 送信ボタン */
.wpcf7 .template01 .submit-btn {
  position: relative;
  width: 100%;
  height: 75px;
  max-width: 100%;
  margin: 0;
  padding: 0;
  margin-left: auto;
  margin-right: auto;
}

.wpcf7 .template01 input[type="submit"] {
  cursor: pointer;
  width: 100%;
  max-width: 100%;
  padding: 24px;
  border-radius: 0;
  box-shadow: none;
  background: #001D4A;
  color: #fff;
  font-size: 18px;
  text-align: center;
  box-sizing: border-box;
  transition: opacity .25s;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  font-family: "NotoSerifJP-Medium";
}

.wpcf7 .template01 input[type="submit"]:disabled {
  cursor: not-allowed;
  box-shadow: none !important;
  border: 1px solid #f8f8f8 !important;
  background-color: #f8f8f8 !important;
  color: #999 !important;
}

.wpcf7 .template01 input[type="submit"]:hover {
  border: 1px solid #000;
  background-color: #fff;
  color: #000;
  transition: opacity .25s, background-color .25s;
}

.wpcf7 .template01 input[type="submit"]:focus {
  outline: 1px #eee solid;
  border: 1px #080808 solid;
}

.wpcf7 .template01 span.wpcf7-list-item {
  margin: 0;
  width: 100%;
}

.wpcf7 .template01 .ajax-loader {
  display: block;
}

@media only screen and (max-width: 768px) {
  .wpcf7 .template01 span.wpcf7-list-item {
    display: block;
  }
}

/*--------------------------------
	　利用規約
--------------------------------*/

.terms-of-service {
  width: 100vw;
}

.terms-of-service__kv {
  width: 100%;
  background-image: url(../images/terms-of-service_kv.png);
  background-repeat: no-repeat;
  background-size: cover;
  height: 413px;
}

.terms-of-service__tit {
  padding: 215px 0 0;
  margin: 0 auto;
  width: fit-content;
  display: flex;
  flex-direction: column;
  row-gap: 30px;
}

.terms-of-service__tit > img {
  width: 294px;
  height: auto;
  margin: 0 auto;
}

.terms-of-service__tit > h1 {
  color: #FFF;
  font-size: 40px;
  text-align: center;
  font-family: "NotoSerifJP-Regular";
  font-weight: 300;
  letter-spacing: 0.1em;
}

.terms-of-service__content {
  width: 100%;
  padding: 60px 0 100px;
  background: #F3F3F3;
}

.terms-of-service__content > div {
  width: 1120px;
  margin: 0 auto;
  padding: 64px;
  box-sizing: border-box;
  border: 1px solid rgba(0, 0, 0, 0.12);
  background: #FFF;
}

.terms-of-service__content-list {
  width: 100%;
  display: flex;
  flex-direction: column;
  row-gap: 48px;
}

.terms-of-service__content-list li {
  color: rgba(0, 0, 0, 0.87);
  font-size: 16px;
  line-height: 28px;
  letter-spacing: 0.05em;
  font-family: "NotoSerifJP-Regular";
  font-weight: 400;
}

.terms-of-service__content-list > li > ul {
  display: flex;
  flex-direction: column;
  row-gap: 10px;
}

.terms-of-service__content-list > li > ul > li:first-of-type {
  color: #000;
  font-size: 20px;
  line-height: 30px;
  letter-spacing: 0.05em;
  font-weight: 700;
}

.terms-of-service__content-list_subtitle {
  padding: 10px 0;
}

.terms-of-service__content-list_detail {
  margin-left: 20px;
  display: flex;
  flex-direction: column;
  row-gap: 10px;
}

.terms-of-service__breadcrumbs {
  background: #F3F3F3;
}

.terms-of-service__breadcrumbs > div {
  width: 1120px;
  margin: 0 auto;
}

.terms-of-service__breadcrumbs ul {
  padding: 20px 0;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  align-items: center;
  gap: 40px;
}

.terms-of-service__breadcrumbs ul li {
  display: block;
  font-size: 15px;
  line-height: 20px;
  position: relative;
  font-family: "NotoSerifJP-Regular";
  letter-spacing: 0.05em;
}

.terms-of-service__breadcrumbs ul li a {
  color: #003078;
  text-decoration: none;
}

.terms-of-service__breadcrumbs ul li:not(:last-of-type)::after {
  display: block;
  content: '';
  width: 11px;
  height: 10px;
  background: url(../images/breadcrumb-arrow-icon.svg) no-repeat 50% 50%;
  background-size: contain;
  position: absolute;
  top: 3px;
  bottom: 0;
  right: -25px;
  margin: auto;
}

/*--------------------------------
	　footer
--------------------------------*/

.footer {
  background: #011026;
  width: 100%;
}

.footer__inner {
  padding: 64px 80px;

  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
}

.footer__left {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 100%;
  max-width: 332px;
}

.footer__logo {
  width: 328px;
  height: auto;
}

.footer__logo img {
  width: 100%;
  height: 100%;
}

.footer__sub-text {
  width: 100%;
  display: block;
  text-align: center;
  padding: 3px 0;
  color: #E4CF91;
  font-size: 16px;
  font-family: "NotoSerifJP-Medium";
  line-height: 180%;
  letter-spacing: 0.198em;
  border-top: 0.6px solid #E4CF91;
  border-bottom: 0.6px solid #E4CF91;
}

.footer__right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 40px;
}

.footer__items {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 24px;
}

.footer__item a {
  text-decoration: none;
  color: #FFF;
  font-family: "NotoSerifJP-Medium";
  font-size: 14px;
  line-height: 100%;
  letter-spacing: 0.019em;
}

.footer__copyright {
  color: #FFF;
  font-size: 10px;
  font-family: "NotoSansJP-Light";
  line-height: 100%;
  letter-spacing: 0.025em;
}