@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@600&display=swap');

/* ---------------------------------------------
Reset
--------------------------------------------- */

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

img, video {
  vertical-align: bottom;
}

figure {
  margin: 0;
}

ul, ol, li {
  margin: 0;
  padding: 0;
  list-style: none;
}


/* ---------------------------------------------
font
--------------------------------------------- */

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}

@font-face {
  font-family: "Helvetica Neue";
  src: local("Helvetica Neue Regular");
  font-weight: 100;
}

@font-face {
  font-family: "Helvetica Neue";
  src: local("Helvetica Neue Regular");
  font-weight: 200;
}

html {
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
}

_:-ms-lang(x)::-ms-backdrop, html {
  font-family: Verdana, Meiryo, sans-serif;
}

html body {
  -moz-font-feature-settings: "palt";
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  font-variant-ligatures: no-common-ligatures;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: unset;
  -webkit-text-size-adjust: 100%;
  @media only screen and(-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
}


/* ---------------------------------------------
Base
--------------------------------------------- */

html {
  font-size: 100%;
}

html body {
  line-height: 1.6;
  color: #000;
  font-size: 16px;
}

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

.brPc {
  display: block;
}

.brSp {
  display: none;
}

@media screen and (max-width:750px) {
  html body {
    font-size: 1.6vw;
  }
  img {
    width: 100%;
  }
  .brPc {
    display: none;
  }
  .brSp {
    display: block;
  }
}


/* ---------------------------------------------
width
--------------------------------------------- */

.wrapper {
  width: 100%;
  min-width: 1100px;
}

.contentsInner {
  width: 100%;
  margin: 0 auto;
}

@media screen and (max-width:750px) {
  .wrapper {
    width: 100%;
    min-width: 100%;
  }
  .contentsInner {
    width: 100%;
    margin: 0;
  }
}


/* ---------------------------------------------
#header
--------------------------------------------- */

#pageHeader {
  margin: 0;
  padding: 0;
  position: relative;
  z-index: 1;
}

#pageHeader .inner {
  width: 1100px;
  height: 60px;
  margin: 0 auto;
  padding: 0;
}

#pageHeader .logo {
  margin: 0;
}

@media screen and (max-width:750px) {
  #pageHeader .inner {
    width: 100%;
    height: 10vw;
  }
  #pageHeader .logo {
    width: 60%;
  }
}


/* ---------------------------------------------
MV
--------------------------------------------- */

#mainContents #mv {
  background-image: url(../images/pc_mv_bg.jpg);
  background-repeat: no-repeat;
  width: 1100px;
  height: 852px;
  margin: auto;
  position: relative;
}

#mainContents #mv h1 {
  position: absolute;
  top: 20px;
  right: 85px;
}

#mainContents #mv .mv_sub {
  position: absolute;
  top: 294px;
  left: 60px;
}

@media screen and (max-width:750px) {
  #mainContents #mv {
    background-image: url(../images/sp_mv_bg.jpg);
    background-size: contain;
    width: 100%;
    height: 112vw;
  }
  #mainContents #mv h1 {
    position: absolute;
    top: 3vw;
    right: 6vw;
    width: 31%;
  }
  #mainContents #mv .mv_sub {
    position: absolute;
    top: 50vw;
    left: 5vw;
    width: 26%;
  }
}


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

#mainContents .sec {
  margin: 0;
}

#mainContents .sec h2, #mainContents .sec h3 {
  margin: 0;
}

#mainContents .sec .m_title {
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho Pro', serif;
  font-size: 4em;
  text-align: center;
  color: #0064a9;
  margin: 1em auto 0.2em auto;
}

#mainContents .sec .yellow_line {
  border-top: 0.5em solid #dcc600;
  border-right: none;
  border-bottom: none;
  border-left: none;
  width: 20%;
  margin: 0 auto;
}

#mainContents .sec .text_area {
  text-align: center;
  color: #0064a9;
  font-size: 2.4em;
  font-weight: 500;
}

#mainContents .sec .img_area {
  width: 50em;
  margin: auto;
  padding-bottom: 2em;
  background-color: #fff;
  border-radius: 20px;
}

#mainContents .sec .img_area figure img {
  width: 70%;
  margin: auto;
  padding: 2em;
  display: block;
}

#mainContents .sec .img_area .arrow1 {
  width: 0;
  height: 0;
  border-right: solid 3em transparent;
  border-bottom: solid 2em #0064a9;
  border-left: solid 0em transparent;
  margin: -1em auto 0 auto;
}

#mainContents .sec .img_area .i_area_attention {
  width: 26.6em;
  margin: auto;
  background-color: #0064a8;
  border-radius: 20px;
  color: #fff;
  font-size: 1.7em;
  text-align: center;
  font-weight: bold;
  padding: 0.5em;
}

#mainContents .sec .img_area .i_area_attention p {
  margin: 0;
}

#mainContents .sec .anno_left {
  margin-top: 2em;
  font-size: 0.8em;
  color: #0064a8;
  padding-left: 5.4em;
}

#mainContents .sec .anno_right {
  margin-top: 2em;
  font-size: 0.8em;
  text-align: right;
  color: #0064a8;
  padding-right: 11.6em;
}

#mainContents .sec .anno_right_wid {
  margin-top: 2em;
  font-size: 0.8em;
  text-align: right;
  color: #0064a8;
  padding-right: 5.4em;
}

#mainContents .marker {
  background: linear-gradient(transparent 70%, #edda00 70%);
  font-weight: bold;
}

#mainContents .t_bold {
  font-weight: bold;
}

#mainContents .fs70p {
  font-size: 70%;
}

#mainContents .fs200p {
  font-size: 200%;
}

#mainContents .supText {
  font-size: 45.5%;
  vertical-align: top;
  position: relative;
  top: -0.1em;
}

@media screen and (max-width:750px) {
  #mainContents .sec .anno_left {
    margin-top: 4vw;
    font-size: 3vw;
    padding-left: 6vw;
  }
  #mainContents .sec .anno_right {
    margin-top: 5vw;
    font-size: 3vw;
    padding-right: 6vw;
  }
  #mainContents .sec .anno_right_wid {
    margin-top: 5vw;
    font-size: 3vw;
    text-align: right;
    padding-right: 5vw;
  }
  #mainContents .sec .m_title {
    font-size: 9vw;
    margin: 8vw auto 7vw auto;
    line-height: 1.2;
    font-family: 'Noto Serif JP', serif;
  }
  #mainContents .sec .text_area {
    font-size: 6vw;
  }
  #mainContents .sec .img_area {
    width: 88%;
    padding-bottom: 4vw;
  }
  #mainContents .sec .img_area figure img {
    width: 90%;
    padding: 5vw 3vw 3vw 3vw;
  }
  #mainContents .sec .img_area .i_area_attention {
    width: 88%;
    border-radius: 10px;
    font-size: 5.5vw;
    padding: 3vw;
  }
  #mainContents .sec .yellow_line {
    border-top: 1vw solid #dcc600;
    width: 30%;
  }
}


/* ---------------------------------------------
#mainContents
--------------------------------------------- */

#mainContents #sec_resume .sec_resume_text {
  position: relative;
}

#mainContents #sec_resume .sec_resume_text p {
  position: absolute;
  top: 0;
  right: 78px;
  color: #3864a5;
  background: rgba(240, 242, 242, 0.5);
  border-radius: 20px;
  padding: 2em;
  width: 63%;
  font-size: 1.5em;
  font-weight: 500;
}
#mainContents .crown_anno {
  width: 100%;
  height: 440px;
  background: no-repeat url(../images/sec_crown02.jpg);
  display: flex;
  align-items: flex-end;
}
#mainContents .crown_anno p {
  color: #0064a9;
  font-size: 0.8em;
  padding: 0 5.3em 5.3em;
  margin-bottom: 0;
}

#mainContents {
  width: 1100px;
  min-width: 1100px;
  margin: 0 auto;
}

#mainContents #sec1 {
  margin: 3em 0 0 0;
  padding: 0;
}

#mainContents #sec1 .sec1_inner {
  margin: 0 auto;
  padding: 0 0 2em 0;
  background-color: #f0f2f2;
}

#mainContents #sec1 .sec1_inner .sec1_voice01,
#mainContents #sec1 .sec1_inner .sec1_voice02,
#mainContents #sec1 .sec1_inner .sec1_voice03,
#mainContents #sec1 .sec1_inner .sec1_voice04 {
  position: relative;
}

#mainContents #sec1 .sec1_inner .sec1_voice01 p,
#mainContents #sec1 .sec1_inner .sec1_voice03 p {
  position: absolute;
  top: 230px;
  right: 123px;
  width: 55%;
  font-size: 1.5em;
  line-height: 1.4;
  font-weight: 500;
}

#mainContents #sec1 .sec1_inner .sec1_voice02 p,
#mainContents #sec1 .sec1_inner .sec1_voice04 p {
  position: absolute;
  top: 230px;
  left: 122px;
  width: 55%;
  font-size: 1.5em;
  line-height: 1.4;
  font-weight: 500;
}

#mainContents #sec1 .sec1_inner p {
  color: #0064a9;
}

#mainContents #sec3 .sec3_inner {
  background-color: #f0f2f2;
  padding-bottom: 1em;
}

#mainContents #sec3 .sec3_inner h2 img {
  margin: auto;
  padding-top: 1em;
  display: block;
}

#mainContents #sec3 .sec3_inner .trouble {
  background-color: #f0f2f2;
  background-image: url(../images/sec3_trouble_bg.jpg);
  background-repeat: no-repeat;
  width: 1100px;
  height: 1014px;
  position: relative;
}

#mainContents #sec3 .sec3_inner .trouble p {
  color: #0064a9;
  font-size: 1.6em;
  margin: 0;
  font-weight: 500;
  width: 24%;
  letter-spacing: 2px;
}

#mainContents #sec3 .sec3_inner .trouble .touble_text01 {
  position: absolute;
  top: 5.5em;
  left: 14em;
}

#mainContents #sec3 .sec3_inner .trouble .touble_text02 {
  position: absolute;
  top: 11.9em;
  left: 19.3em;
}

#mainContents #sec3 .sec3_inner .trouble .touble_text03 {
  position: absolute;
  top: 18.8em;
  left: 14em;
}

#mainContents #sec3 .sec3_inner .trouble .touble_text04 {
  position: absolute;
  top: 25.1em;
  left: 19.3em;
}

#mainContents #sec3 .sec3_inner .trouble .touble_text05 {
  position: absolute;
  top: 32em;
  left: 14em;
}

#mainContents .dott_textbox {
  width: 50em;
  margin: auto;
  border: dotted 0.3em #0064a9;
  border-radius: 30px;
  background-color: #fff;
}

#mainContents .dott_textbox .navytitle {
  display: block;
  width: 260px;
  margin: -0.2em auto auto auto;
  padding: 0.5em;
  font-size: 1.5em;
  font-weight: bold;
  color: #fff;
  background-color: #0064a9;
  text-align: center;
  border-radius: 0 0 10px 10px;
}

#mainContents .dott_textbox p {
  color: #0064a9;
  text-align: center;
  font-size: 2.4em;
  font-weight: 500;
}

#mainContents #sec4 {
  margin-bottom: 0;
  padding: 0;
}

#mainContents #sec4 .sec4_inner {
  background-color: #f0f2f2;
  padding: 3em 0 0 0;
}

#mainContents #sec4 .sec4_inner .plus {
  color: #0064a9;
  font-size: 5em;
  font-weight: bold;
  display: block;
  width: 6%;
  margin: auto;
  text-align: center;
  padding: 0;
}

#mainContents #sec5 h2 {
  background: no-repeat url("../images/sec5_title_bg.jpg");
  line-height: 1.1;
  margin: 1em auto 0 auto;
  padding: 1em 0 0.3em 0;
}

#mainContents #sec5 .h2_sub {
  font-size: 0.4em;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
  font-weight: normal;
}

#mainContents #sec5 .sec5_inner {
  background: no-repeat url("../images/sec5_inner_bg.jpg");
  text-align: center;
}

#mainContents #sec5 .sec5_inner img {
  padding: 1em 0;
}

#mainContents #sec5 .sec5_inner02 {
  background: no-repeat url("../images/sec5_inner02_bg.jpg");
  position: relative;
  text-align: center;
  padding-top: 1em;
}

#mainContents #sec5 .sec5_inner02 p {
  margin: 0 auto 0.8em auto;
  padding-bottom: 0.3em;
  color: #0064a9;
  font-size: 2.1em;
  font-weight: 500;
  line-height: 1.3;
  border-bottom: dotted 5px;
  width: 77%;
}

#mainContents #sec5 .sec5_inner02 p:last-child {
  border-bottom: none;
  margin-bottom: 0;
}

#mainContents #sec5 h3 {
  margin: 1em auto 0 auto;
  line-height: 1.1;
}

#mainContents #sec5 .sec5_separate_box {
  width: 87%;
  height: auto;
  margin: auto;
  padding: 0;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

#mainContents #sec5 .sec5_separate_box .sec5_separate_left, #mainContents #sec5 .sec5_separate_box .sec5_separate_right {
  width: 49%;
  height: auto;
  background-color: #0064a9;
  border-radius: 30px;
}

#mainContents #sec5 .sec5_separate_box .sec5_separate_left h4, #mainContents #sec5 .sec5_separate_box .sec5_separate_right h4 {
  width: 100%;
  margin: 0;
  padding: 1em;
  background-color: #03377c;
  border-radius: 30px 30px 0 0;
  color: #fff;
  font-size: 2em;
  text-align: center;
  box-sizing: border-box;
}

#mainContents #sec5 .sec5_separate_box .sec5_separate_left p, #mainContents #sec5 .sec5_separate_box .sec5_separate_right p {
  width: 100%;
  margin: 0;
  padding: 1em 2em;
  color: #fff;
  font-size: 1.5em;
  box-sizing: border-box;
}

#mainContents #sec5 .sec5_separate_box+p {
  margin-top: 2em;
  font-size: 0.8em;
  text-align: right;
  color: #0064a8;
  padding-right: 5.3em;
}

#mainContents #sec5 .sec5_separate_box+p a {
  color: #0064a8;
  text-decoration: none;
}

#mainContents #sec5 .sec5_inner04 h3 {
  margin: 2em auto auto auto;
  color: #0064a9;
  font-size: 3em;
  font-weight: 500;
  text-align: center;
}

#mainContents #sec5 .sec5_inner04 .sec5_inner04_topic {
  display: block;
  margin: 3em auto 0 auto;
}

#mainContents #sec5 .sec5_inner04 h4 {
  margin: 0.3em auto auto auto;
  padding: 0 0 0.4em 0;
  color: #0064a9;
  font-size: 2.4em;
  font-weight: 500;
  text-align: center;
  border-bottom: dotted 5px #0064a9;
}

#mainContents #sec5 .sec5_inner04 .sec5_inner04_textarea {
  width: 61%;
  margin: auto;
  padding: 2em 0;
}

#mainContents #sec5 .sec5_inner04 .sec5_inner04_textarea img {
  display: block;
  margin: auto;
}

#mainContents #sec5 .sec5_inner04 .sec5_inner04_textarea p {
  color: #0064a9;
  font-size: 0.8em;
  margin-bottom: 0;
}

#mainContents #sec5 .sec5_inner04 .pseudo_text {
  color: #0064a9;
  font-size: 3em;
  font-weight: 500;
  margin: 1em auto;
  text-align: center;
}

#mainContents #sec5 .sec5_separate_box .sec5_separate_left_second {
  width: 49%;
  height: auto;
  background-color: #0064a9;
  border-radius: 30px;
  position: relative;
}

#mainContents #sec5 .sec5_separate_box .sec5_separate_left_second .sec5_check {
  position: absolute;
  top: -2em;
  left: 13.3em;
}

#mainContents #sec5 .sec5_inner04 .sec5_inner04_stitle {
  display: block;
  margin: 3em auto 0 auto;
}

#mainContents #sec5 .sec5_separate_box .sec5_separate_left_second p {
  width: 100%;
  margin: 0;
  padding: 1em 2em;
  color: #fff;
  font-size: 1.5em;
  box-sizing: border-box;
}

#mainContents #sec5 .sec5_separate_box .sec5_separate_right_second {
  width: 49%;
  height: auto;
  background-color: #f0f2f2;
  border-radius: 30px;
}

#mainContents #sec5 .sec5_separate_box .sec5_separate_right_second p {
  width: 100%;
  margin: 0;
  padding: 1em 2em;
  color: #0064a9;
  font-size: 1.5em;
  box-sizing: border-box;
}

#mainContents #sec5 .sec5_inner05 {
  width: 88%;
  margin: 2em auto;
}

#mainContents #sec5 .sec5_inner05 p {
  color: #0064a9;
  font-size: 1.5em;
}

#mainContents #sec5 .sec5_inner05 .sec5_inner_textarea {
  background: url("../images/sec5_inner05_bg.jpg");
  width: 99.2%;
}

#mainContents #sec5 .sec5_inner05 .sec5_inner_textarea p {
  margin: 0 auto 1em auto;
  padding: 1em 0;
  width: 90%;
}

#mainContents #sec6 {
  margin: 2em auto auto auto;
}

#mainContents #sec6 .sec6_inner {
  width: 88%;
  margin: auto;
}

#mainContents #sec6 .sec6_inner h3 {
  margin: -5em auto auto auto;
  padding: 0 0 0.4em 0;
  color: #0064a9;
  font-size: 2.4em;
  font-weight: 500;
  text-align: center;
}

#mainContents #sec6 .sec6_inner .sec6_resume1 {
  position: relative;
  margin: 1em auto 5em auto;
}

#mainContents #sec6 .sec6_inner .sec6_resume1 img {
  position: relative;
  z-index: 2;
}

#mainContents #sec6 .sec6_inner .sec6_resume1 .resume_box {
  background-color: #f0f2f2;
  border-radius: 30px;
  position: absolute;
  top: 3em;
  right: 0;
  width: 70%;
  z-index: 1;
  padding: 0 7em 2em 7em;
}

#mainContents #sec6 .sec6_inner .sec6_resume1 .resume_box h4 {
  color: #0064a9;
  font-size: 2em;
  font-weight: bold;
  text-align: center;
  margin: 1em auto 0 auto;
  border-bottom: solid 2px #0064a9;
}

#mainContents #sec6 .sec6_inner .sec6_resume1 .resume_box p {
  color: #0064a9;
  font-size: 1.2em;
  font-weight: 500;
  margin: 1em auto 0 auto;
}

#mainContents #sec7 {
  margin-top: 9em;
}

#mainContents #sec7 .sec7_inner {
  background-color: #0064a9;
  position: relative;
}

#mainContents #sec7 .sec7_inner h2 {
  color: #fff;
  font-size: 2.5em;
  font-weight: bold;
  background: url("../images/sec7_title_bg.jpg");
  width: 60%;
  padding: 0.8em 2em;
}

#mainContents #sec7 .sec7_inner .sec7_inner_firstimg {
  position: absolute;
  top: 0;
  right: 4.2em;
}

#mainContents #sec7 .sec7_inner .sec7_firsttext {
  color: #fff;
  font-size: 2.5em;
  font-weight: bold;
  margin: 0;
  padding: 0 0 0 2em;
}

#mainContents #sec7 .sec7_inner02 {
  background-color: #0064a9;
  position: relative;
  padding: 2em 0 5em 0;
}

#mainContents #sec7 .sec7_inner02 h3 {
  background: url("../images/sec7_title02_bg.jpg");
  background-repeat: no-repeat;
  color: #fff;
  font-size: 2.5em;
  font-weight: bold;
  padding: 1em 1.3em 1.3em 1.3em;
  text-align: center;
  width: 54%;
  line-height: 1.2;
  margin: 0 0 0 2em;
}

#mainContents #sec7 .sec7_inner02 .sec7_inner_firstimg {
  position: absolute;
  top: 2.11em;
  right: 4.2em;
}

#mainContents #sec7 .sec7_inner02 p {
  color: #fff;
  font-size: 1.4em;
  margin: 1em auto 0 3.3em;
  width: 54%;
}

#mainContents #sec7 .sec7_inner02 .sec7_inner_secondimg {
  position: absolute;
  top: 17em;
  right: 4.2em;
}

#mainContents #sec7 .sec7_inner_thirdimg {
  display: none;
}

#mainContents #sec8 {
  width: 100%;
  margin: auto;
  background-color: #f1f1f1;
}

#mainContents #sec8 .sec8_inner {
  width: 88%;
  margin: auto;
  padding: 3em 0 0 0;
}

#mainContents #sec8 .sec8_inner h3 {
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho Pro', serif;
  font-size: 4em;
  text-align: center;
  color: #0064a9;
  line-height: 1.2;
}

#mainContents #sec8 .h2_sub {
  font-size: 0.4em;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
  font-weight: normal;
}

#mainContents aside {
  width: 88%;
  margin: 4em auto;
  color: #0064a9;
}

#mainContents aside .aside_inner {
  background-color: #f0f2f2;
  border-radius: 10px;
  padding: 2em;
  margin-bottom: 2em;
}

#mainContents aside .aside_inner h2 {
  font-size: 1.5em;
  font-weight: 500;
  text-align: center;
  border-radius: 20px;
  background-color: #fff;
}

#mainContents aside .aside_inner .aside_top li {
  margin-bottom: 1em;
  padding-left: 1.2em;
  text-indent: -1.2em;
}

#mainContents aside .aside_inner ol {
  padding-left: 1.3em;
}

#mainContents aside .aside_inner ol li {
  list-style: decimal;
}

#mainContents aside .aside_under li {
  margin-bottom: 0.3em;
  padding-left: 1.2em;
  text-indent: -1.2em;
}

@media screen and (max-width:750px) {
  #mainContents {
    width: 100%;
    min-width: 100%;
  }
  #mainContents #sec_resume .sec_resume_text p {
    right: 0;
    padding: 8vw;
    width: 89%;
    font-size: 4.8vw;
    margin: 0;
    border-radius: 20px 0 0 20px;
  }
  #mainContents #sec1 .sec1_inner .sec1_voice01 p {
    position: absolute;
    top: 66vw;
    right: 7vw;
    width: 70%;
    font-size: 5vw;
  }
  #mainContents #sec1 .sec1_inner .sec1_voice02 p, #mainContents #sec1 .sec1_inner .sec1_voice04 p {
    position: absolute;
    top: 60vw;
    left: 8vw;
    width: 70%;
    font-size: 5vw;
  }
  #mainContents #sec1 .sec1_inner .sec1_voice03 p {
    position: absolute;
    top: 60vw;
    right: 7vw;
    width: 70%;
    font-size: 5vw;
  }
  #mainContents #sec3 .sec3_inner .trouble {
    background-image: url(../images/sp_sec3_trouble_bg.jpg);
    width: 100%;
    height: auto;
    height: 246vw;
    background-size: cover;
  }
  #mainContents #sec3 .sec3_inner .trouble p {
    font-size: 4.2vw;
    font-weight: 500;
    width: 34%;
    letter-spacing: 0.3vw;
  }
  #mainContents #sec3 .sec3_inner .trouble .touble_text01 {
    position: absolute;
    top: 20vw;
    left: 58vw;
  }
  #mainContents #sec3 .sec3_inner .trouble .touble_text02 {
    position: absolute;
    top: 69vw;
    left: 12vw;
  }
  #mainContents #sec3 .sec3_inner .trouble .touble_text03 {
    position: absolute;
    top: 117vw;
    left: 58vw;
  }
  #mainContents #sec3 .sec3_inner .trouble .touble_text04 {
    position: absolute;
    top: 166vw;
    left: 12vw;
  }
  #mainContents #sec3 .sec3_inner .trouble .touble_text05 {
    position: absolute;
    top: 214vw;
    left: 58vw;
  }
  #mainContents .dott_textbox {
    width: 88%;
    border: dotted 0.6vw #0064a9;
    border-radius: 10px;
  }
  #mainContents .dott_textbox .navytitle {
    width: 40vw;
    margin: -0.5vw auto auto auto;
    padding: 1vw;
    font-size: 5vw;
  }
  #mainContents .dott_textbox p {
    font-size: 5.5vw;
  }
  #mainContents #sec4 .sec4_inner .plus {
    font-size: 15vw;
    width: 10%;
  }
  #mainContents #sec5 h2 {
    background: no-repeat url(../images/sp_sec5_title_bg.jpg);
    background-size: cover;
    margin: 3vw auto 0 auto;
    padding: 8vw 0 6vw 0;
  }
  #mainContents #sec5 .sec5_inner {
    background: url(../images/sp_sec5_inner_bg.jpg);
    background-size: contain;
    padding: 0 5vw 3vw 5vw;
  }
  #mainContents #sec5 .sec5_inner img {
    padding: 5vw 0 3vw 0;
  }
  #mainContents #sec5 .sec5_inner02 {
    background: url(../images/sp_sec5_inner_bg.jpg);
    background-size: contain;
    padding-top: 1em;
  }
  #mainContents #sec5 .sec5_inner02 p {
    margin: 0 auto 6vw auto;
    padding-bottom: 3vw;
    font-size: 5vw;
    border-bottom: dotted 3px;
    width: 88%;
    line-height: 1.4;
  }
  #mainContents #sec5 .h2_sub {
    font-size: 5vw;
  }
  #mainContents #sec5 .sec5_separate_box {
    width: 88%;
    display: block;
  }
  #mainContents #sec5 .sec5_separate_box+p {
    margin-top: 5vw;
    font-size: 3vw;
    padding-right: 6vw;
  }
  #mainContents #sec5 .sec5_separate_box .sec5_separate_left, #mainContents #sec5 .sec5_separate_box .sec5_separate_right {
    width: 100%;
    border-radius: 10px;
    margin: 2vw auto;
  }
  #mainContents #sec5 .sec5_separate_box .sec5_separate_left h4, #mainContents #sec5 .sec5_separate_box .sec5_separate_right h4 {
    padding: 3vw;
    border-radius: 10px 10px 0 0;
    font-size: 6vw;
  }
  #mainContents #sec5 .sec5_separate_box .sec5_separate_left p, #mainContents #sec5 .sec5_separate_box .sec5_separate_right p {
    padding: 4vw 6vw;
    font-size: 4vw;
  }
  #mainContents #sec5 .sec5_inner04 h3 {
    margin: 9vw auto auto auto;
    font-size: 7vw;
  }
  #mainContents #sec5 .sec5_inner04 .sec5_inner04_topic {
    display: block;
    margin: 5vw ​auto 0 auto;
    width: 20%;
  }
  #mainContents #sec5 .sec5_inner04 h4 {
    margin: 3vw ​auto auto auto;
    padding: 0 0 2vw 0;
    font-size: 5.8vw;
    border-bottom: dotted 3px #0064a9;
    width: 88%;
    line-height: 1.3;
  }
  #mainContents #sec5 .sec5_inner04 .sec5_inner04_textarea {
    width: 88%;
    padding: 5vw 0;
  }
  #mainContents #sec5 .sec5_inner04 .sec5_inner04_textarea p {
    margin-top: 3vw;
    font-size: 3vw;
  }
  #mainContents #sec5 .sec5_inner04 .pseudo_text {
    font-size: 7vw;
    margin: 5vw auto;
    line-height: 1.3;
  }
  #mainContents #sec5 .sec5_separate_box .sec5_separate_left_second {
    width: 100%;
    border-radius: 10px;
    padding: 4vw;
    margin-bottom: 4vw;
  }
  #mainContents #sec5 .sec5_separate_box .sec5_separate_left_second .sec5_check {
    position: absolute;
    top: -4vw;
    left: 40vw;
    width: 10%;
  }
  #mainContents #sec5 .sec5_inner04 .sec5_inner04_stitle {
    margin: 0 auto;
  }
  #mainContents #sec5 .sec5_separate_box .sec5_separate_left_second p {
    padding: 2vw 4vw;
    font-size: 5vw;
  }
  #mainContents #sec5 .sec5_separate_box .sec5_separate_right_second {
    width: 100%;
    border-radius: 10px;
    padding: 4vw;
  }
  #mainContents #sec5 .sec5_separate_box .sec5_separate_right_second p {
    padding: 2vw 4vw;
    font-size: 5vw;
  }
  #mainContents #sec5 .sec5_inner05 {
    width: 100%;
    margin: 5vw auto;
  }
  #mainContents #sec5 .sec5_inner05 p {
    font-size: 4vw;
    width: 88%;
    margin: auto auto 5vw auto;
  }
  #mainContents #sec5 .sec5_inner05 .sec5_inner_textarea {
    width: 100%;
  }
  #mainContents #sec5 .sec5_inner05 .sec5_inner_textarea p {
    margin: 0 auto 1em auto;
    padding: 1em 0;
    width: 88%;
  }
  #mainContents #sec6 .sec6_inner {
    width: 100%;
  }
  #mainContents #sec6 .sec6_inner h3 {
    margin: -39vw auto auto auto;
    padding: 0 0 2vw 0;
    font-size: 7vw;
  }
  #mainContents #sec6 .sec6_inner .sec6_resume1 {
    margin: 3vw auto 60vw auto;
  }
  #mainContents #sec6 .sec6_inner .sec6_resume1 img {
    width: 50%;
  }
  #mainContents #sec6 .sec6_inner .sec6_resume1 .resume_box {
    border-radius: 10px 0 0 10px;
    position: absolute;
    top: 21vw;
    right: 0;
    width: 90%;
    padding: 7vw 5vw;
  }
  #mainContents #sec6 .sec6_inner .sec6_resume1 .resume_box h4 {
    font-size: 5vw;
    margin: 1em auto 0 auto;
  }
  #mainContents #sec6 .sec6_inner .sec6_resume1 .resume_box p {
    font-size: 4vw;
    margin: 1em auto 0 auto;
  }
  #mainContents #sec7 {
    margin-top: 62vw;
  }
  #mainContents #sec7 .sec7_inner h2 {
    font-size: 7vw;
    background: url(../images/sp_sec7_title_bg.jpg);
    background-size: contain;
    width: 100%;
    padding: 4vw 3vw;
    text-align: center;
  }
  #mainContents #sec7 .sec7_inner .sec7_firsttext {
    color: #fff;
    font-size: 6vw;
    font-weight: bold;
    margin: 5vw auto;
    padding: 0;
    text-align: center;
  }
  #mainContents #sec7 .sec7_inner .sec7_inner_firstimg {
    position: relative;
    top: 0;
    left: 0;
    width: 88%;
    margin: auto;
  }
  #mainContents #sec7 .sec7_inner02 {
    padding: 3vw 0 5vw 0;
  }
  #mainContents #sec7 .sec7_inner02 h3 {
    background: url(../images/sp_sec7_title02_bg.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    font-size: 7vw;
    padding: 7.3vw 0vw;
    width: 88%;
    margin: 3vw auto auto auto;
    box-sizing: border-box;
  }
  #mainContents #sec7 .sec7_inner02 .sec7_inner_firstimg, #mainContents #sec7 .sec7_inner02 .sec7_inner_secondimg {
    display: none;
  }
  #mainContents #sec7 .sec7_inner02 p {
    font-size: 5vw;
    margin: 6vw auto 0 auto;
    width: 88%;
  }
  #mainContents #sec7 .sec7_inner_thirdimg {
    display: block;
  }
  #mainContents #sec8 .sec8_inner h3 {
    font-size: 10vw;
    margin-bottom: 5vw;
    font-family: 'Noto Serif JP', serif;
  }
  #mainContents aside .aside_inner h2 {
    font-size: 4vw;
  }

  #mainContents aside .aside_inner .aside_top li,
  #mainContents aside .aside_under li {
    margin-bottom: 3vw;
    padding-left: 1.2em;
    text-indent: -1.2em;
    font-size: 3vw;
  }

  #mainContents aside .aside_inner ol {
    font-size: 3vw;
  }

}


/* ---------------------------------------------
offer
--------------------------------------------- */

#mainContents #offer_top {
  width: 100%;
  height: auto;
  background: no-repeat url("../images/offer_top_bg.jpg");
}

#mainContents .offer_normal {
  width: 100%;
  height: auto;
  background-color: #f0f2f2;
}

#mainContents .offer_white {
  width: 100%;
  height: auto;
  background-color: #fff;
  margin-top: 1em;
}

#mainContents .offer_inner {
  width: 960px;
  height: 595px;
  margin: auto;
  background: no-repeat url("../images/offer_inner_bg.png");
  position: relative;
}

#mainContents .offer_inner .offer_text {
  position: absolute;
  top: 20px;
  right: 32px;
  margin: 0;
}

#mainContents .offer_inner .bt_posi {
  padding: 26.7em 7em 0 7em;
}

#mainContents .offer_inner .bt_posi a:hover {
  opacity: 0.8;
  filter: brightness(130%);
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

#mainContents .offer_bottom {
  width: 88%;
  background-color: #f0f2f2;
  border-radius: 40px;
  margin: 2em auto 1em auto;
  padding: 2em;
}
#mainContents .offer_bottom h3 {
  color: #0064a9;
  font-size: 2.3em;
  text-align: center;
  padding-bottom: 0.5em;
  border-bottom: solid 1px #03377c;
  margin-bottom: 0;
}
#mainContents .offer_bottom h3+p {
  color: #03377c;
  font-size: 2em;
  text-align: center;
  margin: 0.2em auto 0 auto;
  padding-bottom: 0.5em;
  font-weight: bold;
  line-height: 1.5;
}
#mainContents .offer_bottom .generally {
  background-color: #fff;
  border-radius: 20px;
  padding: 0.4em 1em;
  margin-right: 0.5em;
  vertical-align: top;
  position: relative;
  top: 0.7em;
}
#mainContents .offer_bottom .discount {
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho Pro', serif;
}
#mainContents .offer_bottom .backslush {
  font-family: arial;
}
#mainContents .offer_bottom .offer_bottom_deco {
  color: #03377c;
}
#mainContents .offer_bottom .offer_bottom_bt_posi {
  display: block;
  margin: auto;
}
#mainContents .offer_anno {
  color: #0064a9;
  font-size: 0.8em;
  padding-left: 5.3em;
  margin-bottom: 0;
}
@media screen and (max-width:750px) {
  #mainContents .crown_anno {
    width: 100%;
    height: auto;
    background: no-repeat url(../images/sp_sec_crown02.jpg);
    background-size: cover;
  }
  #mainContents .crown_anno p {
    padding: 25em 5.3em 5.3em;
  }

  #mainContents #offer_top {
    width: 100%;
    height: auto;
    background: no-repeat url(../images/offer_top_bg.jpg);
    padding: 4vw;
  }

  #mainContents .offer_inner {
    width: 100%;
    height: auto;
    background: no-repeat url(../images/sp_offer_inner_bg.png);
    background-size: cover;
    position: relative;
  }

  #mainContents .offer_inner .offer_text {
    position: absolute;
    top: 2.2vw;
    right: 4vw;
    width: 90%;
  }

  #mainContents .offer_inner .bt_posi {
    padding: 68vw 3vw 6vw 3vw;
  }

  #mainContents .offer_anno {
    font-size: 3vw;
    padding-left: 0;
  }

  #mainContents .offer_normal, #mainContents .offer_white {
    padding: 4vw;
  }

  #mainContents .offer_bottom {
    width: 100%;
    border-radius: 20px;
    margin: 4vw auto 2vw auto;
    padding: 3vw;
  }

  #mainContents .offer_bottom h3 {
    font-size: 5vw;
    padding-bottom: 2vw;
  }

  #mainContents .offer_bottom h3+p {
    font-size: 5vw;
    margin: 1vw auto 0 auto;
    padding-bottom: 1vw;
  }
}

/* ---------------------------------------------
qa
--------------------------------------------- */
#mainContents #sec_qa {
  width: 88%;
  margin: 3em auto auto auto;
}
#mainContents #sec_qa h2 {
  font-size: 3em;
  font-weight: 500;
  text-align: center;
  margin: 0;
  color: #0064a9;
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho Pro', serif;
  letter-spacing: 0.1em;
}
#mainContents .accordion {
  text-align: left;
}
#mainContents .ac_area {
  margin-bottom: 1em;
}
#mainContents .ac_area dt {
  padding: 0.5em 2em;
  background: url(../images/arrow_ac1.png) no-repeat right 15px center;
  background-color: #0064a9;
  color: #fff;
  font-size: 1.5em;
  border-radius: 10px;
}
#mainContents .ac_area dt.open {
  background-image: url(../images/arrow_ac2.png);
  border-radius: 10px 10px 0 0;
}
#mainContents .ac_area dd {
  display: none;
  padding: 0.5em 2em;
  margin: 0;
  color: #0064a9;
  font-size: 1.5em;
  background-color: #f0f2f2;
  border-radius: 0 0 10px 10px;
}
#mainContents .ac_area.first dd {
  display: block;
}
@media screen and (max-width:750px) {
  #mainContents #sec_qa {
    width: 92%;
    margin: 5vw auto auto auto;
  }

  #mainContents #sec_qa h2 {
    font-size: 7vw;
    letter-spacing: 1vw;
  }

  #mainContents .accordion {
    width: 100%;
    margin: auto;
  }

  #mainContents .ac_area dt {
    padding: 3.2vw;
    font-size: 4vw;
    position: relative;
    background: url(../images/arrow_ac1_sp.png) no-repeat right 10px center;
    background-color: #0064a8;
  }

  #mainContents .ac_area dd {
    display: none;
    font-size: 4vw;
    padding: 3.2vw;
  }

  #mainContents .ac_area dt.open {
    background-image: url(../images/arrow_ac2_sp.png);
  }
}

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

footer {
  background-color: #0064a9;
  color: #fff;
}

footer .footer_inner {
  width: 1100px;
  margin: auto;
  padding: 2em;
}

footer ul {
  width: 1100px;
  margin: auto;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  flex-wrap: wrap;
  font-size: 0.8em;
}

footer ul li {
  margin: auto 1em;
}

footer ul li a {
  color: #fff;
  text-decoration: none;
}

footer p {
  text-align: center;
  font-size: 0.8em;
  padding-bottom: 1em;
  margin: 0;
}

@media screen and (max-width:750px) {
  footer .footer_inner {
    width: 100%;
    padding: 5vw;
  }

  footer ul {
    width: 100%;
    font-size: 3vw;
  }

  footer ul li {
    margin: auto 3vw 3vw 3vw;
  }

  footer p {
    font-size: 3vw;
    padding-bottom: 5vw;
  }

}