@charset "utf-8";
/*------------------------------------------------------------
 common Style
------------------------------------------------------------*/
#gHeader {
  background-color: #fff;
  position: fixed;
  width: 100%;
  z-index: 100;
}
#pagePath {
  margin-bottom: 0px;
  /*background: #000;*/
  padding-top: 75px;
}

.bold {font-weight: bold;}

.colorBlack {color: #333 !important;}

.colorWhite {color: #fff !important;}

.colorBlue01 {color: #36B0C9 !important;}

.serif {font-family: YuMincho, Yu Mincho, "游明朝", serif;}

.times {font-family: "Times New Roman", Times, serif;}

.wrap {
  margin: auto;
  width: 94%;
  max-width: 1000px;
}

.inlineBlock {display: inline-block;}

main {
  margin-bottom: 0 !important;
  font-feature-settings: "palt";
  letter-spacing: 3px;
}

main img {
  max-width: 100%;
  height: auto;
}

main .image,
main figure {
  position: relative;
}

main figure {
  margin: auto;
}

main .text {
  display: inline-block;
  text-align: justify;
  letter-spacing: .5px;
  line-height: 1.9;
  font-size: 13px;
}

main .image .text,
main figure .text {
  position: absolute;
}

main .commonLinkButton01 {
  margin: auto;
  padding-top: 50px;
  max-width: 290px;
}

@media (min-width:1025px){
  main .button a:hover {
    opacity: .7;
  }
}


/*------------------------------------------------------------
 pc - tablet Style
------------------------------------------------------------*/

main sup {
  vertical-align: top;
  font-size: 10px;
}

main .annotation {
  display: block;
  padding-top: 15px;
  line-height: 1.5;
  font-size: 10px;
}

main .mainVisual {padding-bottom: 150px;}

main .section01 {
  padding-bottom: 260px;
  max-width: 1200px;
}

main .section01 h3 {
  margin: auto;
  padding-bottom: 100px;
  width: 90%;
  max-width: 410px;
}

main .section01 .wrapper {
  display: flex;
  flex-flow: row-reverse;
  align-items: flex-end;
  /*padding-left: 200px;*/
}

main .section01 .wrapper .image {
  flex: 0 0 722px;
}

main .section01 .wrapper dl {
  position: relative;
      margin-left: -100px;
    margin-right: 20px;
}

main .section01 .wrapper dt {
  position: relative;
  margin-bottom: 20px;
  padding-bottom: 15px;
  line-height: 1.7;
  font-size: 24px;
}

main .section01 .wrapper dt:after {
  content: '';
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 90px;
  height: 1px;
  background: #808080;
}

main .section01 .wrapper dt .en {
  display: block;
  padding-bottom: 10px;
  font-size: 12px;
}

main .section01 .wrapper dd {
  line-height: 2;
  font-size: 14px;
  letter-spacing: 0;
}

main .section02 {
  margin-bottom: 130px;
  padding: 150px 0 190px;
  background: url('../img/section02-bg.png') no-repeat center center;
  background-size: cover;
}

main .section02 h3 {
  margin: auto;
  padding-bottom: 30px;
  width: 80%;
  max-width: 325px;
}

main .section02 > header {
  padding-bottom: 90px;
}

main .section02 > header .lead {
  text-align: center;
  line-height: 2;
  font-size: 13px;
}

main .section02 .inSections {
  display: flex;
  align-items: flex-start;
  gap: 0 50px;
  padding-left: 100px;
}

main .section02 .inSections:not(:last-of-type) {
  padding-bottom: 100px;
}

main .section02 .inSections .textArea {
  flex: 0 0 335px;
}

main .section02 .inSections h4 {
  padding-bottom: 25px;
  line-height: 1;
  font-size: 12px;
  color: #4C4948;
  font-weight: normal;
}

main .section02 .inSections .text01 {
  padding-bottom: 5px;
  letter-spacing: 1px;
  line-height: 1.5;
  font-size: 15px;
}

main .section02 .inSections .text02 {
  padding-bottom: 10px;
  line-height: 1.7;
  font-size: 24px;
}

main .section02 .inSections .text03 {
  line-height: 2;
  letter-spacing: 0;
  font-size: 14px;
}

main .section02 .inSec02 {
  flex-flow: row-reverse;
  padding-right: 100px;
  padding-left: 0;
}

main .section02 .inSec03 {
  align-items: center;
  max-width: 920px;
}

main .section03 h3 {
  margin: auto;
  padding-bottom: 40px;
  width: 70%;
  max-width: 572px;
}

main .section03 > header {
  padding-bottom: 150px;
}

main .section03 > header .flexArea {
  display: flex;
  align-items: center;
  gap: 0 30px;
}

main .section03 > header .inners {
  flex: 0 0 570px;
}

main .section03 > header .inners .innerTitle {
  padding-bottom: 15px;
}

main .section03 > header .inners .innerTitle img {
  width: auto;
  height: 14px;
}

main .section03 > header .howTo {
  flex: 0 0 570px;
}

main .section03 > header .howTo .steps {
  display: flex;
  justifi-content: space-between;
  gap: 0 20px;
}

main .section03 > header .howTo .steps figcaption {
  display: block;
  padding-top: 10px;
  line-height: 2;
  letter-spacing: 0;
  font-size: 13px;
}

main .section03 > header .point .points li > span {
  display: inline-block;
  padding-bottom: 6px;
  border-bottom: 1px solid #4C4948;
  line-height: 1;
}

main .section03 > header .point .points li:not(:last-child) {
  margin-bottom: 15px;
}

main .section03 .bgArea {
  padding: 110px 0 150px;
  background: url('../img/section03-bg.png') no-repeat center center;
  background-size: cover;
}

main .section03 .inSections {
  box-sizing: border-box;
  position: relative;
  padding: 90px 60px 80px;
  max-width: 800px;
  border-radius: 40px;
  text-align: center;
  background: #E4F2F6;
}

main .section03 .inSections:not(:last-of-type) {
  margin-bottom: 30px;
}

main .section03 .inSections h4 {
  margin: auto;
  padding-bottom: 30px;
  max-width: 400px;
}

main .section03 .inSec01 .pointIcon {
  position: absolute;
  top: -40px;
  left: -60px;
  width: 214px;
}

main .section03 .inSec01 .image {
  margin: auto;
  padding-bottom: 30px;
  max-width: 380px;
}

main .section03 .inSec01 .spots {
  text-align: left;
  font-size: 13px;
}

main .section03 .inSec01 .spots li {
  padding-bottom: 20px;
  border-bottom: 1px solid #ccc;
  letter-spacing: 1px;
  line-height: 1;
}

main .section03 .inSec01 .spots li:not(:last-child) {
  margin-bottom: 20px;
}

main .section03 .inSec01 .spots .emphasis {
  display: inline-block;
  font-size: 22px;
  min-width: 240px;
}

main .section03 .inSec02 h4 {
  width: 90%;
  max-width: 317px;
}

main .section03 .inSec02 .wrapper:not(:last-of-type) {
  padding-bottom: 30px;
}

main .section03 .inSec02 .wrapper dl {
  display: flex;
  margin-bottom: 30px;
  padding: 10px 0;
  border-radius: 100px;
  align-items: center;
  text-align: left;
  background: #AEDAE5;
}

main .section03 .inSec02 .wrapper dt {
  margin-right: 20px;
  padding: 6px 30px 6px 40px;
  border-right: 1px solid #6CAEC6;
  line-height: 1;
  font-size: 26px;
}

main .section03 .inSec02 .wrapper dd {
  line-height: 2;
  letter-spacing: 1px;
  font-size: 13px;
}

main .section03 .inSec02 .wrapper .steps {
  display: flex;
  justify-content: center;
  gap: 0 22px;
}

main .section03 .inSec02 .wrapper .steps li {
  flex: 0 0 212px;
}

main .section03 .inSec02 .wrapper .steps li .text {
  padding-top: 10px;
  line-height: 2;
  letter-spacing: 0;
  font-size: 14px;
}

main .section04 {
  position: relative;
  padding: 160px 0;
  z-index: 1;
}

main .section04:after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 934px;
  background: url('../img/section04-img.png') no-repeat right center;
  background-size: auto 100%;
  z-index: -1;
}

main .section04 h3 {
  padding-bottom: 20px;
  line-height: 1.7;
  font-size: 24px;
  font-weight: normal;
}

main .section04 h3 img {
  display: block;
  padding-bottom: 25px;
  width: auto;
  height: 12px;
}

main .section04 .lead {
  line-height: 2;
  font-size: 14px;
}

main .mainImageArea {
  position: relative;
}

main .mainImageArea .button {
  position: absolute;
  bottom: 10%;
  left: 49%;
  padding: 0;
  width: 25%;
  max-width: none;
  transform: translateX(-50%);
}



@media all and (max-width: 1024px) {
}


/*------------------------------------------------------------
 sp Style
------------------------------------------------------------*/

@media all and (max-width: 767px) {
#pagePath {
  margin-bottom: 0;
  padding-top: 65px;
}

main {
    margin-bottom: 50px !important;
}

main sup {
  font-size: 1.5vw;
}

main .annotation {
  padding-top: 2vw;
  font-size: 1.5vw;
}

main .mainVisual {padding-bottom: 20vw;}

main .section01 {
  padding-bottom: 20vw;
  width: auto;
}

main .section01 h3 {
  padding-bottom: 8vw;
}

main .section01 .wrapper {
  flex-flow: column;
  align-items: center;
  gap: 15vw 0;
  padding-left: 0;
}

main .section01 .wrapper .image {
  flex: 0 0 auto;
}

main .section01 .wrapper dl {
  margin: auto;
  width: 90%;
}

main .section01 .wrapper dt {
  margin-bottom: 4vw;
  padding-bottom: 4vw;
  font-size: 6.5vw;
}

main .section01 .wrapper dt:after {
  width: 30vw;
}

main .section01 .wrapper dt .en {
  padding-bottom: 1vw;
  font-size: 3.5vw;
}

main .section01 .wrapper dd {
  font-size: 4vw;
  letter-spacing: 1px;
}

main .section02 {
  margin-bottom: 20vw;
  padding: 20vw 0 20vw;
  background-image: url('../img/sp/section02-bg.png');
}

main .section02 h3 {
  padding-bottom: 8vw;
}

main .section02 > header {
  padding-bottom: 15vw;
}

main .section02 > header .lead {
  font-size: 4vw;
  letter-spacing: 1px;
}

main .section02 .inSections {
  flex-flow: column;
  align-items: center;
  gap: 10vw 0;
  padding: 0 10vw !important;
  width: auto;
}

main .section02 .inSections:not(:last-of-type) {
  padding-bottom: 15vw !important;
}

main .section02 .inSections .textArea {
  flex: 0 0 auto;
}

main .section02 .inSections h4 {
  padding-bottom: 25px;
  font-size: 3vw;
}

main .section02 .inSections .text01 {
  padding-bottom: 5px;
  letter-spacing: 1px;
  line-height: 1.5;
  font-size: 5.5vw;
}

main .section02 .inSections .text02 {
  padding-bottom: 2vw;
  font-size: 6.5vw;
}

main .section02 .inSections .text03 {
  font-size: 4vw;
  letter-spacing: 1px;
}

main .section02 .inSections .text03 img {
  display: block;
  padding: 7vw 0 5vw;
}

main .section02 .inSections .image {
  order: -1;
}

main .section02 .inSec01 .image {
  margin-right: -10vw;
}

main .section02 .inSec02 {
  flex-flow: column;
}

main .section02 .inSec02 .image {
  margin-left: -10vw;
}

main .section02 .inSec03 {
  max-width: 920px;
}

main .section03 {
  margin-bottom: 20vw;
}

main .section03 h3 {
  padding-bottom: 10vw;
}

main .section03 > header {
  padding-bottom: 15vw;
}

main .section03 > header .flexArea {
  flex-flow: column;
  gap: 15vw 0;
}

main .section03 > header .inners {
  flex: 0 0 auto;
}

main .section03 > header .inners .innerTitle {
  padding-bottom: 5vw;
}

main .section03 > header .inners .innerTitle img {
  height: 4vw;
}

main .section03 > header .howTo {
  flex: 0 0 auto;
}

main .section03 > header .howTo .steps {
  flex-flow: column;
  gap: 8vw 0;
  margin: auto;
  width: 60%;
}

main .section03 > header .howTo .steps figcaption {
  padding-top: 3vw;
  font-size: 4vw;
}

main .section03 > header .point .points li > span {
  padding-bottom: 2vw;
}

main .section03 > header .point .points li:not(:last-child) {
  margin-bottom: 4vw;
}

main .section03 .bgArea {
  padding: 18vw 0 20vw;
  background-image: url('../img/sp/section03-bg.png');
}

main .section03 .inSections {
  padding: 15vw 8vw 12vw;
  border-radius: 8vw;
}

main .section03 .inSections:not(:last-of-type) {
  margin-bottom: 10vw;
}

main .section03 .inSections h4 {
  padding-bottom: 8vw;
}

main .section03 .inSec01 .pointIcon {
  top: -18vw;
  left: -1vw;
  width: 30vw;
}

main .section03 .inSec01 .image {
  padding-bottom: 5vw;
  width: 60%;
}

main .section03 .inSec01 .spots {
  font-size: 4vw;
}

main .section03 .inSec01 .spots li {
  padding-bottom: 5vw;
  line-height: 2;
}

main .section03 .inSec01 .spots li:not(:last-child) {
  margin-bottom: 5vw;
}

main .section03 .inSec01 .spots li:last-child {
  padding: 0;
  border: none;
}

main .section03 .inSec01 .spots .emphasis {
  display: block;
  font-size: 5.5vw;
  min-width: 0;
}

main .section03 .inSec02 .wrapper:not(:last-of-type) {
  padding-bottom: 15vw;
}

main .section03 .inSec02 .wrapper dl {
  flex-flow: column;
  margin-bottom: 7vw;
  padding: 0;
  border-radius: 0;
  text-align: center;
  background: none;
}

main .section03 .inSec02 .wrapper dt {
  margin: 0 0 5vw;
  padding: 3vw 0;
  width: 100%;
  border-radius: 30vw;
  border-right: none;
  font-size: 5vw;
  background: #AEDAE5;
}

main .section03 .inSec02 .wrapper dd {
  letter-spacing: 1px;
  font-size: 4vw;
}

main .section03 .inSec02 .wrapper .steps {
  flex-flow: column;
  gap: 10vw 0;
  margin: auto;
  width: 80%;
}

main .section03 .inSec02 .wrapper .steps li {
  flex: 0 0 auto;
}

main .section03 .inSec02 .wrapper .steps li .text {
  padding-top: 3vw;
  font-size: 4vw;
}

main .section04 {
  display: flex;
  flex-flow: column;
  gap: 10vw 0;
  padding: 0 0 20vw 10vw;
  z-index: 1;
}

main .section04:after {
  display: none;
}

main .section04 .image {
  order: -1;
}

main .section04 h3 {
  padding-bottom: 4vw;
  font-size: 6vw;
}

main .section04 h3 img {
  padding-bottom: 6vw;
  height: 3.5vw;
}

main .section04 .lead {
  font-size: 3.6vw;
  letter-spacing: 1px;
}

main .mainImageArea .button {
  position: static;
  width: 90%;
  transform: none;
}
}
