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

-------------------------------------------------------------- */

/* common */
main {
  padding-bottom: 0;
}

.section_type21_body {
  background: #fff;
}

a {
  color: #57a3e5;
  transition: 0.3s;
  text-decoration: none;
}

a:hover {
  opacity: 0.7;
}

.heading_type21 .font-small {
  font-size: 20px;
  letter-spacing: 0.075em;
}

@media screen and (max-width: 768px) {
  .heading_type21 .font-small {
    font-size: 18px;
    letter-spacing: 0;
  }
}

.section_type01a {
  margin-bottom: 0;
  background: none;
}

.section_type01a+.section_type01a {
  margin-top: 0;
}

.section_type01a h3 {
  font-size: 18px;
  font-weight: normal;
  line-height: 1.5;
}

.section_type01a p {
  font-size: 18px;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .section_type01a p {
    font-size: 16px;
  }
}

.heading_type01a {
  color: #003686;
  padding-top: 60px;
  background: #fff;
  margin-bottom: 0;
  border-bottom-width: 3px;
  border-bottom-style: solid;
  border-color: rgba(0, 54, 134, .2);
}

.heading_type01a span {
  border-bottom: 3px solid #003686;
}

.heading_type01a span.font-small {
  font-size: 20px;
  border-bottom: none;
}

@media screen and (max-width: 768px) {
  .heading_type01a span.font-small {
    font-size: 18px;
  }
}

.section_type01a .contents {
  padding: 40px 2em;
  background: rgba(73, 102, 175, 0.1);
}

.section_type01a .contents p+p {
  margin-top: 1em;
}

.section_type01a .contents .content+.content {
  margin-top: 1em;
}

.btn_type01 {
  padding: .8em 1em;
}

figure figcaption {
  margin-top: 1em;
  font-size: 12px;
  line-height: 1.5;
  text-align: center;
  word-break: break-all;
}

.sec_01 .heading_type01a {
  padding-top: 15px;
}

.sec_01 .row_01 {
  text-align: center;
  margin: 30px auto 60px;
}

.sec_01 .row_01 figcaption a {
  color: #222;
}

.sec_01 .row_02 {
  display: flex;
  justify-content: center;
  gap: 70px;
  margin-bottom: 60px;
}

.sec_01 .row_03 .movie {
  width: 435px;
  aspect-ratio: 435 / 245;
  margin: 0 auto;
  position: relative;
}

.sec_01 .row_03 .movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.sec_01 .row_03 .movie_caption {
  margin-top: 1em;
  font-size: 12px;
  line-height: 1.5;
  text-align: center;
}

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

  .sec_01 .row_01 figcaption {
    text-align: left;
  }

  .sec_01 .row_02 {
    flex-direction: column;
    gap: 30px;
    margin-bottom: 60px;
  }

  .sec_01 .row_03 .movie {
    width: 100%;
  }

  .sec_01 .row_03 .movie_caption {
    text-align: left;
  }
}

.sec_02 .content {
  width: 737px;
  margin: 30px auto 0;
  padding: 20px;
  background: #fff;
}

.sec_02 .row {
  display: flex;
  justify-content: flex-start;
  gap: 30px;
}

.sec_02 .row .col_01 {
  display: flex;
  margin: 25px 0 0 0;
}

.sec_02 .row .col_01 h3 {
  font-size: 18px;
  margin-right: 1.5em;
}

.sec_02 .row .col_01 figcaption {
  font-size: 15px;
}

.sec_02 .row .col_02 figure+figure {
  margin-top: 30px;
}

.sec_02 .row .col_02 figcaption {
  margin-top: 0;
  margin-bottom: 0.5em;
}

.sec_02 .caution {
  margin-top: 15px;
  font-size: 12px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .sec_02 .content {
    width: 100%;
    padding: 10px;
  }

  .sec_02 .row {
    flex-direction: column;
    gap: 30px;
  }

  .sec_02 .row .col_01 {
    display: block;
    margin: 25px 0 0 0;
  }

  .sec_02 .row .col_01 h3 {
    text-align: center;
    margin-bottom: 0.5em;
  }
}

.sec_03 .content {
  width: 500px;
  margin: 30px auto 0;
  background: #fff;
  padding: 20px;
}

@media screen and (max-width: 768px) {
  .sec_03 .content {
    width: 100%;
    margin: 30px auto 0;
    background: #fff;
    padding: 20px;
  }
}

.sec_05 .box {
  margin: 2em 2em 0;
  padding: 30px 2em;
  border: #293580 solid 1px;
}

.sec_05 .box h2 {
  color: #003686;
  font-size: 25px;
  font-weight: bold;
  text-align: center;
  line-height: 1.2;
  margin-bottom: 0.5em;
}

.sec_05 .box p {
  text-align: center;
}

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

  .sec_05 .box {
    margin: 1em 1em 0;
    padding: 30px 1em;
    border: #293580 solid 1px;
  }

  .sec_05 .box h2 {
    font-size: 20px;
  }

  .sec_05 .box p {
    text-align: left;
  }
}