@charset "utf-8";

html {
  scroll-padding-top: 110px;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  line-height: 1.5em;
  font-size: 16px;
  max-width: 1920px;
  margin: 0 auto;
  background-image: url(../images/bg.jpg);
  background-size: cover;
  background-position: top center;
}

.jpFont {
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
}

.jpFontBold {
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
}

.enFont {
  font-family: "Lato";
  font-weight: 700;
}

.w1140 {
  width: 100%;
  max-width: 1140px;
  margin-left: auto;
  margin-right: auto;
}

/* header */
header {

}

.brandLogo {
  padding: 25px 0;
}

.brandLogo img {
  width: 240px;
}


/* contents */
main {

}


/* event */
.eventText1 {
  margin-left: 100px;
  margin-top: 60px;
  margin-bottom: 40px;
}

.eventText1 img {
  height: 70px;
}

.eventText2 {
  text-align: center;
}

.eventText2 img  {
  width: 800px;
}

.eventText3 {
  text-align: center;
  font-weight: 600;
  color: #fff;
  font-size: 16px;
  line-height: 2.5em;
  margin-top: 30px;
}


/* info */
.infoBox {
  margin-top: 75px;
  background-color: rgba(0, 0, 0, 0.5);
  background-image: url(../images/info_bg.png);
  background-repeat: no-repeat;
  border-radius: 50px;
  padding: 50px;
}

.infoLogo {
  text-align: center;
}

.infoLogo img {
  height: 85px;
}

.infoText {
  text-align: center;
  color: #fff;
  margin: 30px 0;
}

.infoDateBox {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 35px;
  color: #fff;
}

.infoDate {
  font-size: 32px;
}

.infoDate span {
  font-size: 66px;
}

.infoTimeBox {
  width: 80px;
}

.infoTimeTitle {
  text-align: center;
  padding: 0 0 10px 0;
  border-bottom: 2px solid #fff;
}

.infoTime {
  text-align: center;
  padding: 10px 0;
  font-size: 30px;
}

.infoPlaceBox {
  border: 2px solid #fff;
  padding: 10px 20px;
  position: relative;
  width: 570px;
  margin: 10px auto 20px auto;
}

.infoPlace {
  text-align: center;
  color: #fff;
  font-size: 18px;
  padding-bottom: 10px;
  border-bottom: 2px solid #fff;
}

.infoPlaceEtc {
  text-align: center;
  color: #fff;
  font-size: 14px;
  padding-top: 10px;
}

.infoFree {
  position: absolute;
  right: -15px;
  bottom: -60px;
}

.infoFree img {
  width: 115px;
}

.infoCapacity {
  color: #fff;
  width: 570px;
  margin: 0 auto;
  font-size: 12px;
  display: flex;
  align-items: baseline;
}

.infoCapacity span {
  font-size: 18px;
}

.infoDeadline {
  text-align: center;
  margin: 30px 0 20px 0;
}

.infoDeadline span {
  background-color: #DC000C;
  padding: 5px 60px 10px 60px;
  border-radius: 30px;
  text-align: center;
  color: #fff;
}


/* common title */
.contentsTitleBox {
  color: #fff;
  position: relative;
  margin-left: 100px;
  padding-left: 50px;
}

.contentsTitleBox:before {
  content: "";
  background-image: url(../images/contents_title_logo.svg);
  background-repeat: no-repeat;
  width: 30px;
  height: 30px;
  position: absolute;
  left: 0;
}

.contentsTitleBox p {
  font-size: 32px;
  margin-bottom: 5px;
}

.contentsTitleBox h2 {
  font-size: 14px;
  font-weight: 600;
}


/* course */
.courseContents {
  margin-top: 80px;
  margin-bottom: 80px;
}

.courseBox {
  display: flex;
  justify-content: space-between;
  gap: 50px;
  align-items: flex-start;
  margin: 40px 0;
}

.courseInTitleBox {
  border-left: 20px solid #fff;
  margin-bottom: 20px;
}

.courseInTitleBox h3 {
  padding-left: 15px;
  padding-top: 10px;
  font-size: 28px;
  color: #fff;
  margin-bottom: 10px;
}

.courseInTitleBox p {
  margin-left: 15px;
  color: #003a74;
  background-color: #ffbe00;
  display: inline-block;
  padding: 2px 25px;
}

.courseRight {
  margin-left: 100px;
}

.courseLeft {
  margin-right: 100px;
}

.courseTitle {
  font-size: 24px;
  line-height: 1.7em;
  color: #fff;
  font-weight: 700;
}

.courseSubTitle {
  color: #ffbe00;
  line-height: 2em;
  font-weight: 700;
  margin-top: 10px;
}

.courseSubTitle span {
  border: 1px solid #ffbe00;
  padding: 1px 10px 2px 10px;
  margin-right: 15px;
  font-size: 14px;
}

.courseName {
  line-height: 2em;
  color: #fff;
  font-weight: 700;
  margin: 1em 0;
}

.courseName span {
  font-size: 24px;
  padding: 0 15px;
}

.courseInImage {
  width: 450px;
}

.courseInImage img {
  width: 100%;
}


/* group strengths*/
.strengthsBox {
  background: rgba(0, 0, 0, 0.5);
  box-shadow: 10px 10px 10px rgba(0, 0, 0, 0.5);
  border-radius: 40px;
  padding: 40px 100px;
  margin: 35px 0;
}

.strengthsEachBox {

}

.strengthsEachLogoBox {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}

.strengthsEachLogo {
  position: absolute;
  left: 0;
}

.strengthsEachListChester .strengthsEachLogo img {
  height: 60px;
}

.strengthsEachListAoyama .strengthsEachLogo img {
  height: 85px;
}

.strengthsEachTitle {
  font-size: 16px;
  color: #fff;
  line-height: 2em;
  text-align: center;
}

.strengthsEachTitle span {
  font-size: 32px;
}

.strengthsEachList {
  display: flex;
  justify-content: space-between;
  gap: 40px;
  margin: 40px 0;
}

.strengthsEachListChester {

}

.strengthsEachListAoyama {

}

.strengthsEachList li {
  background-color: #003A74;
  color: #fff;
  width: 286px;
  padding: 40px 20px 10px 20px;
  border-radius: 25px;
}

.strengthsEachListChester .strengthsEachList li {
  background-image: url(../images/group_strengths_1.svg);
  background-size: 25%;
  background-repeat: no-repeat;
}

.strengthsEachListAoyama .strengthsEachList li {
  background-image: url(../images/group_strengths_2.svg);
  background-size: 25%;
  background-repeat: no-repeat;
}

.strengthsEachListTitle {
  text-align: center;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.5em;
  margin-bottom: 30px;
}

.strengthsEachListText {
  font-weight: 600;
  font-size: 16px;
  line-height: 1.6em;
  margin: 20px 0;
}

.strengthsEachListText.mini {
  font-size: 12px;
  line-height: 1.75em;
}


/* form */
.form {
  margin-top: 75px;
}

.formBox {
  background: rgb(73 67 67 / 50%);
  box-shadow: 10px 10px 10px rgba(0, 0, 0, 0.5);
  border-radius: 40px;
  padding: 40px 100px;
  margin: 35px 0;
}

.formEachBox {

}

.formEachTitle {
  color: #fff;
  font-weight: 600;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  line-height: 1em;
  margin-bottom: 10px;
}

.formRequired {
  background-color: #dc000c;
  color: #fff;
  font-size: 12px;
  margin-left: 20px;
  padding: 2px 10px 5px 15px;
  line-height: 1.4em;
  border-radius: 12px;
  letter-spacing: 5px;
  font-weight: normal;
  position: relative;
  top: 1px;
}

.formEachSubTitle {
  color: #ffbe00;
  font-size: 14px;
  margin-left: 20px;
  line-height: 1.4em;
  border-radius: 12px;
  font-weight: normal;
  position: relative;
  top: 1px;
}

.inputBox {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 33px;
  gap: 5px;
}

.textBox {
  padding: 5px;
  border: 2px solid #979797;
  background-color: #fff;
  border-radius: 10px;
  color: #1e1e1e;
  font-size: 16px;
  caret-color: #ffbe00;
  width: 200px;
}

.textBox100p {
  width: 100%;
  padding: 10px;
  font-size: 18px;
}

.inputBox input[type="email"]:focus, .inputBox input[type="text"]:focus, .inputBox input[type="tel"]:focus {
  outline: 2px solid #ffbe00;
}

.inputBox input[type="radio"] {
  appearance: none;
  position: relative;
  width: 20px;
  height: 20px;
  border: 2px solid #ffffff;
  border-radius: 9999px;
  cursor: pointer;
  margin-left: 0;
}

textarea {
  line-height: 1.5em;
  font-size: 14px !important;
}

.inputBox input[type="radio"]:checked::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 10px;
  height: 10px;
  margin: auto;
  border-radius: 9999px;
  background-color: #ffbe00;
}

.inputBox input[type="image"] {
  text-align: center;
  margin: 0 auto;
  width: 380px;
  transition: 0.5s;
}

.inputBox input[type="image"]:hover {
  filter: brightness(1.2);
}

.inputBox label {
  color: #fff;
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 2px;
  margin-right: 15px;
}


/* send */
.formSendTitle {
  text-align: center;
  color: #fff;
  font-size: 24px;
  margin: 30px 0;
}

.formSendText {
  text-align: center;
  color: #fff;
  font-size: 16px;
  margin: 30px 0;
}

.formSendText a {
  text-decoration: underline;
}

/* footer */
footer {

}


@media all and (max-width: 859px) {
  /* SP */
  .pconly {
    display: none !important;
  }

  /* common */
  .contentsTitleBox p {
    font-size: 26px;
  }

  /* header */
  .brandLogo {
    padding: 20px 15px;
  }

  .brandLogo img {
    width: auto;
    height: 50px;
  }


  /* main */
  .eventBox {
    padding-left: 35px;
    padding-right: 35px;
  }

  .eventText1 {
    margin-left: 0;
    margin-top: 40px;
    margin-bottom: 40px;
  }

  .eventText1 img {
    width: 100%;
    height: auto;
  }

  .eventText2 img {
    width: 100%;
  }

  .eventText3 {
    font-size: 16px;
    line-height: 2.25em;
  }

  .infoBox {
    margin-left: 15px;
    margin-right: 15px;
    padding: 30px 15px;
    border-radius: 30px;
    width: calc(100% - 30px) !important;
  }

  .infoLogo img {
    height: auto;
    width: 100%;
  }

  .infoText {
    text-shadow: 0 0 5px #222, 0 0 5px #222;
    margin: 25px 0;
  }

  .infoDateBox {
    gap: 25px;
    text-shadow: 0 0 5px #222, 0 0 5px #222;
  }

  .infoDate {
    width: 100%;
    text-align: center;
  }

  .infoTimeBox {
    width: auto;
  }

  .infoPlaceBox {
    width: 100%;
    text-shadow: 0 0 5px #222, 0 0 5px #222;
    padding: 10px 15px;
  }

  .infoFree {
    right: -10px;
    bottom: -90px;
  }

  .infoFree img {
    width: 100px;
  }

  .infoCapacity {
    width: calc(100% - 90px);
    margin: 0;
    align-items: center;
    flex-wrap: wrap;
    gap: 5px;
    line-height: 1.5em;
    text-shadow: 0 0 5px #222, 0 0 5px #222;
  }

  .infoDeadline {
    margin-top: 50px;
    margin-bottom: 0;
  }

  .infoDeadline span {
    width: 100%;
    display: block;
    padding: 5px 0 10px 0;
  }

  .contentsTitleBox {
    margin-left: 0;
  }

  .courseContents {
    padding-left: 15px;
    padding-right: 15px;
  }

  .courseBox {
    margin: 20px 0 50px 0;
    gap: 30px;
  }

  .courseRight {
    margin-left: 0;
    flex-wrap: wrap;
    gap: 20px;
  }

  .courseLeft {
    margin-right: 0;
    flex-wrap: wrap;
    flex-direction: column-reverse;
  }

  .courseInTitleBox {
    border-left: 15px solid #fff;
  }

  .courseInTitleBox h3 {
    font-size: 26px;
  }

  .courseInTitleBox p {
    /*font-size: 14px;*/
    padding-left: 20px;
    padding-right: 20px;
  }

  .courseTitle {
    font-size: 18px;
    font-weight: 600;
  }

  .courseSubTitle {
    line-height: 1.7em;
    font-weight: 600;
  }

  .courseSubTitle span {

  }

  .courseName {
    font-size: 14px;
    font-weight: 600;
  }

  .courseName span {
    font-size: 20px;
    font-weight: 600;
  }

  .courseInImage {
    width: 100%;
    text-align: center;
  }

  .courseInImage img {
    width: 75%;
  }

  .groupStrengths {
    padding-left: 15px;
    padding-right: 15px;
  }

  .strengthsBox {
    padding: 40px 10px 5px 10px;
    border-radius: 20px;
    margin-top: 20px;
  }

  .strengthsEachBox {
    padding-left: 15px;
    padding-right: 15px;
  }

  .strengthsEachLogoBox {
    flex-wrap: wrap;
    gap: 20px;
  }

  .strengthsEachLogo {
    position: relative;
    left: auto;
  }

  .strengthsEachTitle {
    font-size: 16px;
    line-height: 1.75em;
  }

  .strengthsEachTitle span {
    font-size: 26px;
    display: block;
    margin-top: 5px;
    line-height: 1.5em;
  }

  .strengthsEachList {
    gap: 20px;
    flex-wrap: wrap;
    margin-top: 20px;
  }

  .strengthsEachList li {
    width: 100%;
    padding: 20px 15px 10px 15px;
  }

  .strengthsEachListTitle {
    margin-bottom: 20px;
    font-size: 18px;
  }

  .strengthsEachListText {
    font-size: 14px;
  }

  .form {
    padding-left: 15px;
    padding-right: 15px;
  }

  .formBox {
    margin-top: 20px;
    border-radius: 20px;
    padding: 30px 20px 5px 20px;
  }

  .inputBox {
    font-size: 14px;
  }

  .inputBox label {
    width: 100%;
  }

  .formEachTitle {
    font-size: 16px;
    line-height: 1.5em;
  }

  .formRequired {
    white-space: nowrap;
    letter-spacing: 0;
    padding-right: 15px;
  }

  .formEachSubTitle {
    font-size: 12px;
  }

  .etc {
    white-space: nowrap;
  }

  .inputBox input[type="image"] {
    width: 100%;
  }
}

@media all and (min-width: 960px) {
  /* PC */
  .sponly {
    display: none !important;
  }
}