@charset "UTF-8";

/* --------------------------------------------------
 Common Block
-------------------------------------------------- */

.max-comm-blc {
  max-width: 1920px;
  margin: 0 auto;
  position: relative;
  box-sizing: border-box;
}

.middle-comm-blc {
  max-width: 1366px;
  padding: 0 4%;
  margin: 0 auto;
  position: relative;
  box-sizing: border-box;
}

.comm-blc {
  max-width: 1200px;
  padding: 0 4%;
  margin: 0 auto;
  position: relative;
  box-sizing: border-box;
}

.min-comm-blc {
  max-width: 922px;
  padding: 0 4%;
  margin: 0 auto;
  position: relative;
  box-sizing: border-box;
}

.narrow-comm-blc {
  max-width: 800px;
  padding: 0 4%;
  margin: 0 auto;
  position: relative;
  box-sizing: border-box;
}

.margin-comm {
  margin-top: 4rem;
  margin-bottom: 4rem;
}

.padding-comm {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

@media screen and (max-width:640px) {
  .padding-comm {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }
}

/* --------------------------------------------------
 Title Text
-------------------------------------------------- */

.txt-big {
  font-size: 120% !important;
}

.txt-small {
  font-size: 80% !important;
}

.ttl-stroke .stroke {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  z-index: -1;
  font-weight: bold;
  color: #fff;
  -webkit-text-fill-color: #fff;
  -webkit-text-stroke-width: 5px;
  -webkit-text-stroke-color: #fff;
  text-shadow: 4px 4px 10px rgba(0, 0, 0, 0.5);
}

.txt-normal-desc {
  text-align: center;
  font-size: 120%;
}

@media screen and (max-width:640px) {
  .txt-normal-desc {
    font-size: 100%;
  }
}

/* --------------------------------------------------
 ttl-blc-bg
-------------------------------------------------- */

.ttl-blc-bg {
  background-color: #0158a2;
  padding: 2rem 0;
  display: block;
  box-sizing: border-box;
}

.ttl-blc-bg .inner {
  max-width: 1360px;
  padding: 0 4%;
}

.ttl-blc-bg .ttl-heading-01 {
  font-size: 200%;
  color: #fff;
  line-height: 1.3;
  text-align: center;
  font-weight: bold;
}

.ttl-blc-bg .txt-heading-desc {
  text-align: center;
  font-size: 120%;
  color: #fff;
  line-height: 1.5;
}

.ttl-blc-bg .ttl-heading-01+.txt-heading-desc {
  margin-top: 1rem;
}

@media screen and (max-width:640px) {
  .ttl-blc-bg .ttl-heading-01+.txt-heading-desc {
    margin-top: 10px;
  }

  .ttl-blc-bg .ttl-heading-01 {
    font-size: 180%;
  }
}

@media screen and (max-width:480px) {
  .ttl-blc-bg {
    padding: 1.5rem 0;
  }

  .ttl-blc-bg .txt-heading-desc {
    font-size: 100%;
  }

  .ttl-blc-bg .ttl-heading-01 {
    font-size: 150%;
  }
}

/* --------------------------------------------------
 ttl-heading-02
-------------------------------------------------- */

.ttl-heading-02 {
  font-size: 150%;
  font-weight: bold;
  color: #0158a2;
  display: block;
  text-align: center;
}

.ttl-heading-02 span {
  position: relative;
  padding-left: 30px;
  display: inline-block;
  box-sizing: border-box;
}

.ttl-heading-02 span::before {
  content: "";
  background-image: url(../img/top/icon_key_blue.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  left: 0;
  top: 12px;
  width: 24px;
  height: 24px;
}

@media screen and (max-width:767px) {
  .ttl-heading-02 span::before {
    top: 5px;
  }
}

@media screen and (max-width:480px) {
  .ttl-heading-02 {
    font-size: 130%;
  }

  .ttl-heading-02 span {
    padding-left: 25px;
  }

  .ttl-heading-02 span::before {
    top: 4px;
    width: 20px;
    height: 20px;
  }
}

/* --------------------------------------------------
 key-visual-blc
-------------------------------------------------- */

.key-visual-blc {
  position: relative;
  display: flex;
  width: 100%;
  box-sizing: border-box;
}

.key-visual-blc .bg {
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
}

.key-visual-blc .key-height-blc {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 4rem 0;
  min-height: 683px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  align-content: center;
  box-sizing: border-box;
}

.key-visual-blc .key-height-blc .width-blc {
  width: 100%;
  position: relative;
  max-width: 1360px;
  padding: 0 4%;
  box-sizing: border-box;
  margin: auto;
}

.key-visual-blc .key-height-blc .group-blc {
  width: 100%;
  padding-right: 550px;
  display: block;
  box-sizing: border-box;
}

/* group-blc01 ------------------------- */

.key-visual-blc .key-height-blc .group-blc.group-blc01 {
  position: relative;
  z-index: 2;
}

.key-visual-blc .key-height-blc .group-blc.group-blc01::before {
  content: "";
  background-image: url(../img/top/key_visual_img_02.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  right: 180px;
  top: 30px;
  bottom: 0;
  width: 435px;
  height: 564px;
  z-index: 1;
}

.key-visual-blc .key-height-blc .group-blc.group-blc01 .txt01 {
  color: #0bab7c;
  font-size: 350%;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  display: block;
  position: relative;
  z-index: 1;
}

.key-visual-blc .key-height-blc .group-blc.group-blc01 .txt02 {
  color: #0a6b4e;
  font-size: 200%;
  font-weight: bold;
  text-align: center;
  margin-top: 2rem;
  line-height: 1.5;
  display: block;
  position: relative;
  z-index: 1;
}

/* group-blc02 ------------------------- */

.key-visual-blc .key-height-blc .group-blc.group-blc02 {
  margin: 4rem auto auto;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc {
  position: relative;
  z-index: 3;
  animation-delay: 0.4s;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .txt01 {
  color: #fb3c3c;
  font-size: 180%;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  display: block;
  position: relative;
  z-index: 1;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list {
  display: flex;
  flex-wrap: wrap;
  margin-top: 1rem;
  padding: 0 50px;
  box-sizing: border-box;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li {
  position: relative;
  width: calc(100% / 2);
  z-index: 1;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .txt {
  color: #fb3c3c;
  font-size: 120%;
  font-weight: bold;
  line-height: 1.5;
  display: inline-block;
  position: relative;
  z-index: 1;
  box-sizing: border-box;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .txt::before {
  content: "";
  background-image: url(../img/top/icon_key_red.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 25px;
  height: 35px;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .stroke {
  display: inline-block;
  font-size: 120%;
  line-height: 1.5;
  box-sizing: border-box;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .txt, .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .stroke {
  padding-left: 30px;
  padding-left: 30px;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc {
  width: 720px;
  height: 590px;
  position: absolute;
  right: 0;
  top: 0;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li {
  position: absolute;
  right: 0;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(1) {
  left: 50px;
  z-index: 0;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(2) {
  right: 140px;
  top: -40px;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(3) {
  bottom: 100px;
  right: 50px;
}

.key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(4) {
  left: 0;
  bottom: 0px;
  z-index: 2;
}

@media screen and (max-width:1440px) {
  .key-visual-blc .key-height-blc .width-blc {
    font-size: 90%;
  }
}

@media screen and (max-width:1366px) {

  .key-visual-blc .key-height-blc .group-blc {
    padding-right: 41vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc01::before {
    top: 0;
    right: 12vw;
    width: 30vw;
    height: 38vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc {
    width: 53vw;
    height: 45vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(2) {
    right: 6vw;
    width: 19vw;
    top: -5vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(1) {
    left: 5vw;
    width: 14vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(3) {
    bottom: 5vw;
    right: 2vw;
    width: 21vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(4) {
    width: 19vw;
    bottom: 6vw;
    left: 3vw;
  }

  .key-visual-blc .key-height-blc {
    min-height: 45vw;
  }
}

@media screen and (max-width:1200px) {
  .key-visual-blc .key-height-blc .group-blc {
    padding-right: 35vw;
    font-size: 1.2vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 {
    margin-top: 2rem;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .txt::before {
    width: 2vw;
    height: 3vw;
    top: -0.2vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .txt, .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .stroke {
    padding-left: 2.5vw;
  }
}

@media screen and (max-width:1000px) {
  .key-visual-blc .key-height-blc .group-blc {
    padding-right: 30vw;
    font-size: 1.4vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc01::before {
    right: 8vw;
    width: 40vw;
    height: 50vw;
    top: -2vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(4) {
    bottom: 0vw;
    left: 0vw;
    width: 21vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(3) {
    width: 20vw;
    right: 0vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(2) {
    top: -3vw;
  }
}

@media screen and (max-width:767px) {
  .key-visual-blc .key-height-blc .group-blc.group-blc01::before {
    content: none;
  }

  .key-visual-blc .key-height-blc .group-blc {
    padding-right: 0;
    font-size: 100%;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc {
    width: 100%;
    height: 100%;
    z-index: 0;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .txt::before {
    width: 25px;
    height: 25px;
    top: 2px;
    left: 0;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .txt, .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .stroke {
    padding-left: 30px;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(1) {
    left: 40px;
    top: 0px;
    width: 140px;
    height: 140px;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(2) {
    top: -30px;
    width: 150px;
    height: 150px;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(3) {
    width: 150px;
    height: 150px;
    right: 50px;
    bottom: -20px;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(3) img {
    transform: rotate(50deg);
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(4) {
    width: 150px;
    height: 150px;
    bottom: -50px;
    left: 10px;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc01 .txt02 {
    margin-top: 1rem;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list {
    max-width: 570px;
    margin: 1rem auto auto;
  }
}

@media screen and (max-width:640px) {
  .key-visual-blc .key-height-blc {
    min-height: 400px;
    padding: 2rem 0;
    display: flex;
    align-items: center;
    align-content: center;
  }

  .key-visual-blc .key-height-blc .group-blc {
    font-size: 2vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list {
    padding: 0 30px;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .txt::before {
    top: -0.3vw;
    width: 4vw;
    height: 5vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .txt, .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .stroke {
    padding-left: 4vw;
  }
}

@media screen and (max-width:480px) {
  .key-visual-blc .key-height-blc .group-blc.group-blc02 {
    margin-top: 5vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list {
    margin-top: 1vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc01 .txt02 {
    margin-top: 1.5vw;
  }

  .key-visual-blc .key-height-blc .width-blc {
    font-size: 100%;
  }

  .key-visual-blc .key-height-blc {
    min-height: 350px;
  }

  .key-visual-blc .key-height-blc .group-blc {
    font-size: 2.3vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list {
    padding: 0;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .ttl-stroke .stroke {
    -webkit-text-stroke-width: 3px;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .txt-blc .list li .txt::before {
    top: 1px;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(1) {
    left: 7vw;
    top: -3vw;
    width: 23vw;
    height: auto;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(2) {
    top: -10vw;
    width: 33vw;
    height: auto;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(3) {
    width: 30vw;
    height: auto;
    right: 10vw;
    bottom: 0vw;
  }

  .key-visual-blc .key-height-blc .group-blc.group-blc02 .img-blc ul>li:nth-child(4) {
    width: 30vw;
    height: auto;
    bottom: -5vw;
    left: 0;
  }
}

/* --------------------------------------------------
 key-visual-img-blc
-------------------------------------------------- */

.key-visual-blc.key-visual-img-blc .key-height-blc {
  min-height: 300px;
  align-items: center;
  align-content: center;
}

.key-visual-blc.key-visual-img-blc .key-height-blc .txt01 {
  width: 100%;
  color: #0bab7c;
  font-size: 350%;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  display: block;
  position: relative;
  z-index: 1;
}

@media screen and (max-width:1000px) {
  .key-visual-blc.key-visual-img-blc .key-height-blc {
    min-height: 200px;
  }

  .key-visual-blc.key-visual-img-blc .key-height-blc .txt01 {
    font-size: 300%;
  }
}

@media screen and (max-width:640px) {
  .key-visual-blc.key-visual-img-blc .key-height-blc .txt01 {
    font-size: 250%;
  }
}

@media screen and (max-width:480px) {
  .key-visual-blc.key-visual-img-blc .key-height-blc {
    min-height: 150px;
  }

  .key-visual-blc.key-visual-img-blc .key-height-blc .txt01 {
    font-size: 200%;
  }
}

/* --------------------------------------------------
 inner-padding
-------------------------------------------------- */

.inner-padding {
  padding: 4rem;
  background-color: #fff;
  display: block;
  box-sizing: border-box;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.2);
}

@media screen and (max-width:1000px) {
  .inner-padding {
    padding: 4rem 4%;
  }
}

@media screen and (max-width:767px) {
  .inner-padding {
    padding: 2rem 4%;
  }
}

/* --------------------------------------------------
 tbl-form
-------------------------------------------------- */

.tbl-form th, .tbl-form td {
  border-bottom: 1px dashed #d4d4d4;
  padding: 2rem 2rem;
  box-sizing: border-box;
}

.tbl-form tr:first-child th, .tbl-form tr:first-child td {
  padding-top: 0;
}

.tbl-form th {
  width: 30%;
}

.tbl-form td {
  width: 70%;
}

.tbl-form td select {
  border: 1px solid #7d7d7d;
  padding: 10px 10px;
  outline: 0;
  transition: all ease-in 0.3s;
  box-sizing: border-box;
  margin-bottom: 10px;
  color: #303f5a;
}

.tbl-form td select:focus {
  border: 1px solid rgba(1, 88, 162, 0.7);
  box-shadow: 0 0 5px rgba(1, 88, 162, 0.5), 0 0 10px rgba(1, 88, 162, 0.5);
  outline: medium none;
}

@media screen and (max-width:1000px) {
  .tbl-form th, .tbl-form td {
    padding: 2rem 1rem;
  }
}

@media screen and (max-width:640px) {
  .tbl-form th, .tbl-form td {
    width: 100%;
    display: block;
    padding: 1rem 0;
  }

  .tbl-form tr:first-child td {
    padding-top: 10px;
  }

  .tbl-form th {
    border-bottom: 0;
    padding-bottom: 0;
  }

  .tbl-form td {
    padding-top: 10px;
  }

  .required-txt {
    margin-bottom: 1rem;
  }
}

/* --------------------------------------------------
 btn-style
-------------------------------------------------- */

@media screen and (min-width:1001px) {
  .btn-style .btn:hover {
    transform: translate(0, 4px);
    box-shadow: none;
  }
}

.btn-style {
  margin-top: 2rem;
  text-align: center;
  display: flex;
  justify-content: center;
}

.btn-style .btn {
  font-size: 120%;
  font-weight: bold;
  line-height: 2;
  border: 0;
  max-width: 300px;
  width: 100%;
  display: inline-block;
  text-decoration: none;
  text-align: center;
  background-color: #fb3c3c;
  color: #fff;
  border-radius: 50px;
  padding: 10px 2rem;
  box-sizing: border-box;
  box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.4);
  transition: all 400ms;
  cursor: pointer;
}

.btn-style .btn-back+.btn-next {
  margin-left: 20px;
}

.btn-style .btn.btn-back {
  background-color: #888888;
}

@media screen and (max-width:1000px) {
  .btn-style .btn {
    max-width: 300px;
    padding: 10px 20px;
  }
}

@media screen and (max-width:767px) {
  .btn-style .btn {
    max-width: 250px;
    padding: 6px 20px;
  }
}

@media screen and (max-width:640px) {
  .btn-style {
    margin-top: 1rem;
  }

  .btn-style .btn-back+.btn-next {
    margin-left: 10px;
  }
}

/* --------------------------------------------------
 text align
-------------------------------------------------- */

.align-center {
  text-align: center !important;
}

.align-left {
  text-align: left !important;
}

.align-right {
  text-align: right !important;
}

/* --------------------------------------------------
 background color
-------------------------------------------------- */
.bg-white {
  background-color: #fff !important;
}

/* --------------------------------------------------
 spacing
-------------------------------------------------- */

/* margin --------------------------------*/

.mt-3rem {
  margin-top: 3rem;
}

.mt-2rem {
  margin-top: 2rem;
}

.mt-1rem {
  margin-top: 1rem;
}

/* padding --------------------------------*/

.pt-3rem {
  padding-top: 3rem;
}

.pt-2rem {
  padding-top: 2rem;
}

.pt-1rem {
  padding-top: 1rem;
}

/* --------------------------------------------------
 br
-------------------------------------------------- */

@media screen and (min-width:481px) {
  .br-sp480 {
    display: none;
  }
}

@media screen and (min-width:375px) {
  .br-sp375 {
    display: none;
  }
}

/* --------------------------------------------------
 Hide
-------------------------------------------------- */

.hidden {
  opacity: 0;
}

.visible {
  opacity: 1;
}

.disnon {
  display: none;
}

.hide {
  opacity: 0;
}