/* body
==================================*/
body {
   color: #000;
   font-family: 'Noto Sans JP', sans-serif;
   font-size: 19px;
   font-weight: 500;
   line-height: 34px;
   background: #ffff;
   min-width: inherit;
   min-height: inherit;
   max-height: 100%;
   padding: 0;
   margin: 0;
   text-align: center;
}

@media screen and (max-width: 767px) {
   body {
      font-size: 13px;
      line-height: 22px;
   }
}

/*
==================================*/
.inner {
   width: 100%;
   max-width: 1100px;
   margin: 0 auto;
   box-sizing: border-box;
   padding: 60px 0;
}
.inner02 {
   width: 100%;
   max-width: 1100px;
   margin: 0 auto;
   box-sizing: border-box;
   padding: 90px 0;
}

@media screen and (max-width: 1200px) {
   .inner {
      max-width: 960px;
   }
   .inner02 {
      max-width: 960px;
      padding: 50px 0;
   }
}

@media screen and (max-width: 991px) {
   .inner {
      max-width: 720px;
   }
   .inner02 {
      max-width: 720px;
      padding: 30px 0;
   }
}

@media screen and (max-width: 767px) {
   .inner {
      max-width: 100%;
      padding: 30px 3%;
   }
}

/**/
img {
   width: 100%;
   height: auto;
}

a, a img {
   transition: all 0.3s;
}

a:hover {
   text-decoration: none;
}

a[href^="tel:"] {
   pointer-events: none;
   cursor: text;
}

@media screen and (max-width: 767px) {
   a[href^="tel:"] {
      pointer-events: auto;
      cursor: pointer;
   }
}

.pc {
   display: block;
}

.tablet {
   display: none;
}

.sp {
   display: none;
}

@media screen and (max-width: 991px) {
   .pc {
      display: none;
   }
   .tablet {
      display: block;
   }
   .sp {
      display: block;
   }
}

@media screen and (max-width: 767px) {
   .tablet {
      display: none;
   }
}

/**/
.txt-center {
   text-align: center;
}

/* Header
==================================*/
   #header {
   width: 100%;
   height: 75px;
   text-align: center;
   background-color: rgba(255, 255, 255, 0.8);
   position: fixed;
   top: 0;
   left: 0;
   z-index: 6;
   box-shadow: 0px 0px 4px 4px rgba(0, 0, 0, 0.03);
   }
   #header .inner{
   width: 100%;
   max-width: 100%;
   height: 100%;
   padding: 0;
   }
   .menu {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   justify-content: space-between;
   align-items: center;
   width: 100%;
   max-width: 1600px;
   height: 100%;
   }

   .menu a {
   display: block;
   font-size: 15px;
   line-height: 18px;
   letter-spacing: 0;
   font-weight: bold;
   text-align: center;
   padding: 0 20px;
   color: #000;
   }
   .menu a:first-child{
      padding: 0;
      position: relative;
      top: 65px;
   }
   .menu a figure{
   }
   .menu a .head-line{
   font-size: 12px;
   font-weight: 300;
   }
   .menu a:nth-child(2){
   margin: 0 0 0 auto;
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   align-items: center;
   font-weight: 500;
   font-size: 34px;
   }

   .menu a:nth-child(2) .tel_txt{
   background-color: #00c896;
   font-size: 27px;
   padding: 8px 11px;
   margin-right: 15px;
   transition: .3s;
   color: #fff;
   }
   .menu a .tel{
   color: #00c896;
   }
   .menu a:hover .tel{
      color: #004b87;
   }
   .tel span.tel_small {
      display: block;
      font-size: 12px;
      font-weight: 300;
      margin-top: 9px;
      color: #000;
   }
   .menu a:nth-child(2):hover{
   color: #00c896;
   }
   .menu a:nth-child(2):hover .tel_txt{
   color: #fff;
   background-color: #004b87;
   }
   .menu a:nth-child(2):hover .tel span.tel_small{
   color: #004b87;
   }
   .menu a:last-child {
   display: table;
   height: 100%;
   background-color: #00c896;
   color: #fff;
   border: 0;
   padding: 0 62px;
   position: relative;
   font-size: 25px;
   font-weight: 500;
   }
   .menu a:last-child::before{
      content: '';
      position: absolute;
      top: 10%;
      left: 0;
      width: 100%;
      height: 82%;
      background: url(../img/common/arrow_wh.svg) no-repeat center right 10px/14px 14px;
   }
   .menu a:last-child span {
   display: table-cell;
   vertical-align: middle;
   text-align: center;
   }

   .menu a:last-child:hover {
   opacity: 1;
   background-color: #004b87;
   }

   .menu a img {
   display: block;
   margin: 0 auto 0 auto;
   }
   @media screen and (max-width: 1310px){
   .menu a figure{
      width: 180px;
      margin-right: 15px;
   }
   .menu a .head-line{
      margin-top: 5px;
   }
   .menu a:nth-child(2){
      font-size: 28px;
      padding: 0 14px 0 0;
   }
   .menu a:nth-child(2) .tel_txt{
      font-size: 20px;
      padding: 5px 8px;
      margin-right: 7px;
   }
   .tel span.tel_small {
      font-size: 10px;
      margin-top: 5px;
   }
   .menu a:last-child{
         padding: 0 35px;
      font-size: 20px;
   }
   }
   @media screen and (max-width: 1600px){
      .menu a:first-child{
         width: 200px;
         top: 45px;
      }
   } 
   @media screen and (min-width: 991px) and (max-width: 1070px) {
   .menu a .head-line .sp{
      display: block !important;
   }
   }
   @media screen and (max-width: 991px) {
   #header {
      height: 50px;
      background-color: transparent;
      box-shadow: none;
   }
   .menu a:first-child{
         width: 150px;
         top: 35px;
      }
   .menu a:nth-child(2),
   .menu a:nth-child(3){
      display: none;
   }
   .menu a figure{
      width: 100%;
   }
   }
   @media screen and (max-width: 767px) {
   .menu a{
      padding: 0 8px;
   }
   .menu a:first-child{
         width: 100px;
         top: 15px;
      }
   .menu a .head-line {
      font-size: 10px;
      line-height: 1.4;
      text-align: left;
   }
   .menu a figure{
   margin-right: 20px;
   }
   }


   /* flex
========================*/
.flex{
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   }

/* Footer
==================================*/
footer {
   background-color: #004b87;
   color: #fff;
   font-size: 14px;
   line-height: 24px;
   letter-spacing: 0.05em;
   padding: 28px 0;
}

footer .inner {
   padding: 0;
}


@media screen and (max-width: 991px) {
   footer {
      font-size: 12px;
   }
}

@media screen and (max-width: 767px) {
   footer {
      padding: 23px 0 75px;
   }

   footer .inner {
   }
}

/* Main
==================================*/
main {
   overflow: hidden;
   padding-top: 75px;
}

@media screen and (max-width: 991px) {
   main {
      padding-top: 52px;
   }
}

@media screen and (max-width: 767px) {
   main {
      padding-top: 50px;
   }
}

/* -- key -- */
.key{
   position: relative;
}
.key img {
   width: 100%;
   height: auto;
}
.key .top_title{
   position: absolute;
   top: 37%;
   left: 57%;
   transform: translate(-50%, -50%);
   -webkit-transform: translate(-50%, -50%);
   -ms-transform: translate(-50%, -50%);
   width: 84%;
   z-index: 1;
}
.key .dec_box{
   position: absolute;
   bottom: 1%;
   right: 4%;
   transform: translate(0%, 0%);
   -webkit-transform: translate(0%, 0%);
   -ms-transform: translate(0%, 0%);
}
.key .building{
   position: absolute;
   bottom: 0%;
   left: 0%;
   transform: translate(0%, 0%);
   -webkit-transform: translate(0%, 0%);
   -ms-transform: translate(0%, 0%);
}
@media screen and (max-width: 1550px){
   .key .dec_box{
      width: 53%;
   }
   .key .building{
      width: 40%;
   }
   .key .top_title{
      top: 38%;
      width: 80%;
   }
}
@media screen and (max-width: 1250px){
   .key .top_title{
      top: 40%;
      width: 73%;
   }
}
/* --h2 -- */
.h2 {
   display: inline-block;
   position: relative;
   font-size: 29px;
   font-weight: 700;
   line-height: 1.6;
}

.h2 small {
   display: block;
   font-weight: 500;
   line-height: 1;
   letter-spacing: 0;
   margin-bottom: 15px;
   letter-spacing: 0.1em;
}

.h2 strong {
   line-height: 0;
   letter-spacing: 0.05em;
   font-weight: 700;
}
.h2 big{
   display: block;
   line-height: 1;
   color: #ed5b59;
   font-size: 50px;
   margin-bottom: 55px;
}
@media screen and (max-width: 767px) {
   .h2{
      font-size: 22px;
   }
   .h2 small {
      font-size: 17px;
      top: -25px;
      left: -25px;
   }

   .h2 strong {
      font-size: 20px;
      line-height: 1.6;
      display: block;
   }
   .h2 big{
      font-size: 37px;
      margin-bottom: 25px;
   }
}

/* --text-color -- */
.red{
   color: #f07876;
}
.green{
   color: #00c896;
}

/* SP parallax */
.img_parallax {
   display: none;
   clip: rect(0, auto, auto, 0);
   margin-bottom: 0;
   height: 100%;
   position: absolute;
   top: 0;
   left: 0;
   right: 0;
   z-index: -1;
}

.img_parallax img {
   width: 100%;
   height: 100vh;
   position: fixed;
   top: 0;
   left: 0;
   padding: 0;
   margin: 0;
   object-fit: cover;
   z-index: 0;
   transform: translateZ(0);
}

@media screen and (max-width: 767px) {
   .bg-parallax {
      position: relative;
   }

   .img_parallax {
      display: block;
   }
}

/* -- line -- */
.pink-line,
.yellow-line,
.white-line {
   position: relative;
   z-index: 1;
}

.white-line:after {
   content: '';
   position: absolute;
   left: 0;
   bottom: 4px;
   width: 0%;
   height: 8px;
   background: #fff;
   z-index: -1;
   transition: all 1s;
}
.yellow-line:after {
   content: '';
   position: absolute;
   left: 0;
   bottom: 4px;
   width: 0%;
   height: 8px;
   background: #ffe900;
   z-index: -1;
   transition: all 1s;
}
.pink-line:after {
   content: '';
   position: absolute;
   left: 0;
   bottom: 4px;
   width: 0%;
   height: 8px;
   background: #ffcad0;
   z-index: -1;
   transition: all 1s;
}
.pink-line.isActive:after,
.yellow-line.isActive:after,
.white-line.isActive:after {
   width: 100%;
}

/* -- sec-01 -- */
.sec-01 {}
@media screen and (max-width: 767px) {}

/* -- theme -- */
.theme {
   background-color: #ffe600;
}
.theme .h2{
   margin-bottom: 40px;
}
.theme .h2:nth-child(3){
   margin-bottom: 0px;
}
.theme .flex{
   margin-bottom: 70px;
}
.theme .flex li{}
.theme .flex li:nth-child(1){
   margin-right: -30px;
}
.theme .flex li:nth-child(2){
   margin-left: -30px;
}
.theme .flex li:nth-child(3){
   margin-right: -50px;
}
.theme .flex li:nth-child(4){
   margin-left: -50px;
}
@media screen and (max-width: 767px) {
   .theme .flex li:nth-child(1),
   .theme .flex li:nth-child(4){
      margin-top: 32px;
   }
   .theme .h2:nth-child(3) strong{
      font-size: 18px;
      line-height: 1.8;
   }
   .theme .flex{
   margin-bottom: 30px;
   }
}

/* -- bg -- */
.bg {
   background-color: #57ccd9;
}
@media screen and (max-width: 767px) {}

/* -- solution -- */
.solution {
   background-color: #fff;
   max-width: 1500px;
   width: 100%;
   margin: 0 auto;
}
.solution .h2{
   margin-bottom: 80px;
}
@media screen and (max-width: 767px) {
   .solution .h2{
   margin-bottom: 40px;
}
}

/* -- decision -- */
.decision {
   background-color: #ffe600;
   max-width: 1500px;
   width: 100%;
   margin: 0 auto;
}
.decision .h2{
   margin-bottom: 50px;
}
.decision .flex{
   justify-content: space-between;
   align-items: center;
   font-weight: 700;
}
.decision .flex .img{
   width: 40%;
}
.decision .flex .txt_box{
   width: 53%;
   height: 100%;
   background-color: #fff;
   border-radius: 15px;
   box-shadow:#ffbe01 7px 7px;
   padding: 3.5% 1%;
}
.decision .flex .txt_box .big_red{
   font-size: 35px;
   color: #ee1e28;
   margin: 27px 0;
}
@media screen and (max-width: 767px) {
   .decision .h2{
      margin-bottom: 25px;
   }
   .decision .flex{
      flex-wrap: wrap;
      flex-direction: column-reverse;
   }
   .decision .flex .img{
      width: 65%;
      margin-top: 25px;
   }
   .decision .flex .txt_box{
      width: 100%;
      padding: 5% 1%;
   }
   .decision .flex .txt_box .big_red{
      font-size: 29px;
      margin: 10px 0 20px;
   }
}

/* -- voice -- */
.voice {
   background-image: linear-gradient(#f3f3f3 1px, transparent 0),
                  linear-gradient(90deg, #f3f3f3 1px, transparent 0);
                  background-size: 10px 10px;
}
.voice .h2{
   margin-bottom: 65px;
}
.voice .h2 small{
   color: #f4ba1b;
}
.voice .flex{
   text-align: left;
   background-color: #f4ba1b;
}
.voice .flex:nth-child(3){
   margin-top: 50px;
   background-color: #f4a39c;
}
.voice .flex .img{
   width: 30%;
}
.voice .flex .txt_box{
   width: 70%;
   padding: 2.5% 2.5%;
}
.voice .flex .txt_box .dd_small{
   font-size: 20px;
   letter-spacing: 0.2em;
   margin-bottom: -5px;
}
.voice .flex .txt_box dt{
   font-size: 30px;
   color: #fff;
   font-weight: 700;
   line-height: 1.4;
   margin-bottom: 20px;
}
@media screen and (max-width: 1200px) {
   .voice .flex .img{
      width: 38%;
   }
   .voice .flex .txt_box{
      width: 65%;
   }
}
@media screen and (max-width: 991px){
   .voice .flex{
      flex-wrap: wrap;
      position: relative;
   }
   .voice .flex .sp{
      display: block !important;
   }
   .voice .flex .img{
      position: absolute;
      top: 0;
      right: 0;
      width: 40%;
      height: 44%;
      overflow: hidden;
}

   .voice .flex .txt_box{
      width: 100%;
      padding: 9% 5% 5%;
   }
}
@media screen and (max-width: 767px) {
   .voice .h2{
   margin-bottom: 30px;
   }
   
   .voice .flex .txt_box dt{
      font-size: 19px;
   }
   .voice .flex .txt_box .dd_small{
      font-size: 12px;
      margin-bottom: 7px;
   }
}
@media screen and (max-width: 375px){
   .voice .flex .img{
      width: 33%;
   }
} 
/* -- faq -- */
.faq {
   background:#ffe600 url(../img/faq/bg.png) no-repeat center top/cover;
   background-attachment: fixed;
}
.faq .h2{
   margin-bottom: 60px;
}
.faq .flex{
   flex-wrap: wrap;
   justify-content: space-between;
}
.faq_box dl {
   background-color: #fff;
   margin-bottom: 20px;
   font-weight: 700;
   width: 48%;
}
.faq_box dl:last-child{
   width: 100%;
}
.faq_box dl dt {
   font-size: 25px;
   text-align: left;
   padding-left: 95px;
   position: relative;
   border-bottom: 1px solid #cecece;
   height: 110px;
   display: flex;
   align-items: center;
}

.faq_box dl dt:before {
   content: "Q";
   width: 36px;
   height: 100%;
   background-color: #57ccd9;
   color: #fff;
   font-size: 30px;
   font-weight: 700;
   letter-spacing: 0;
   line-height: 34px;   
   text-align: center;
   padding-bottom: 2px;
   position: absolute;
   top: 0;
   left: 0;
   width: 80px;
   display: flex;
   align-items: center;
   justify-content: center;
}
.faq_box dl:nth-child(2) dt:before,
.faq_box dl:nth-child(3) dt:before,
.faq_box dl:nth-child(6) dt:before,
.faq_box dl:nth-child(7) dt:before{
   background-color: #f4ba1b;
}
.faq_box dl dd {
   letter-spacing: 0;
   padding: 0 0 0 95px;
   position: relative;
   font-size: 45px;
   color: #ff6c67;
   line-height: 1.3;
   height: 176px;
   vertical-align: middle;
   display: table-cell;
}

.faq_box dl dd:before {
   content: "A";
   width: 36px;
   height: 100%;
   background-color: #d7f3f6;
   color: #57ccd9;
   font-size: 30px;
   font-weight: 400;
   line-height: 34px;
   letter-spacing: 0;
   text-align: center;
   padding-bottom: 2px;
   position: absolute;
   top: 0;
   left: 0;
   width: 80px;
   display: flex;
   align-items: center;
   justify-content: center;
}
.faq_box dl:first-child dd{
   font-size: 70px;
}
.faq_box dl:nth-child(2) dd:before,
.faq_box dl:nth-child(3) dd:before,
.faq_box dl:nth-child(6) dd:before,
.faq_box dl:nth-child(7) dd:before{
   background-color: #fae097;
   color: #f4ba1b;
}
.faq_box dl:nth-child(2) dd{
   text-align: left;
   
}
.faq_box dl:nth-child(2) dd small{
   font-size: 15px;
   color: #000;
   display: block;
   font-weight: 400;
   margin-top: 10px;
}
.faq_box dl dd .red{
   font-size: 22px;
   margin-top: 5px;
   display: block;
}
.faq_box dl:last-child dd{
   font-size: 25px;
   line-height: 1.4;
}
@media screen and (max-width: 991px) {
   .faq_box dl{
      width: 100%;
   }
   .faq_box dl dt {
      font-size: 18px;
      line-height: 1.6;
      padding-left: 60px;
      height: 85px;
   }
   .faq_box dl dd{
      padding-left: 60px;
      font-size: 30px;
      height: 110px;
   }
   .faq_box dl dd:before,
   .faq_box dl dt:before{
      font-size: 20px;
      width: 45px;
   }
   .faq_box dl:first-child dd{
      font-size: 55px;
   }
   .faq_box dl:last-child dd{
      font-size: 18px;
      text-align: left;
      padding: 10px 10px 10px 60px;
   }
   .faq_box dl dd .red{
      font-size: 15px;
   }
}

/* -- about -- */
.about {
   background: url(../img/about/bg.jpg) no-repeat center top/cover;
   background-attachment: fixed;
}
.about .h2{
   margin-bottom: 65px;
}
.about .h2 small{
   color: #00b2c5;
}
.about .box{
   background-color: rgba(255 255 255 / 60%);
   padding: 50px 40px 70px;
}
.about .box .h2{
   color: #00b2c5;
   margin-bottom: 35px;
}
.about .box p{
   text-align: left;
   margin-bottom: 30px;
}
.about .box .btn{
   margin-top: 45px;
}
.btn a{
   background-color: #004b87;
   color: #fff;
   border: 0;
   padding: 10px 50px;
   position: relative;
   font-size: 19px;
   font-weight: 500;
   display: block;
   width: 55%;
   margin: 0 auto;
   line-height: 1.2;
}
.btn a:hover{
   background-color: #00c896;
}
.btn a::before{
   content: '';
   position: absolute;
   top: 10%;
   left: 0;
   width: 100%;
   height: 82%;
   background: url(../img/common/arrow_wh.svg) no-repeat center right 10px/10px 10px;
}
@media screen and (max-width: 767px) {
   .about .h2{
      margin-bottom: 30px;
   }
   .about .box{
      padding: 25px 20px 35px;
   }
   .about .box .btn{
      border-top: 20px;
   }
   .btn a{
      width: auto;
      padding: 10px 30px;
      font-size: 15px;
   }
}

/* -- cta -- */
   .cta {}
   .cta .inner{
   padding: 75px 0;
   }
   .cta .box{
   background-color: #fff;
   }
   .cta h2{
   margin-bottom: 25px;
   }
   .cta h2 small{
   color: #00c896;
   }
   .cta .flex{
   justify-content: center;
   text-align: center;
   }
   .cta .flex li{
   width: 50%;
   border: 3px solid #00c896;
   transition: .3s;
   }
   .cta .flex li:nth-child(2){
   background-color: #00c896;
   }
   .cta .flex li:nth-child(2) a{
   /* display: table-cell; */
   }
   .cta .flex li:nth-child(2) a p{
   width: 100%;
   display: inline-block;
   vertical-align: middle;
   }
   .cta .flex li a{
   padding: 5px;
   display: block;
   width: 100%;
   height: 100%;
   }
   .cta .flex li a .txt{
   font-weight: 600;
   transition: .3s;
   }
   .cta .flex li a .tel{
   transition: .3s;
   font-weight: 700;
   font-size: 43px;
   color: #00c896;
   }
   .cta .flex li a .tel::before{
      content: '';
      display: inline-block;
      width: 30px;
      height: 35px;
      background-image: url(../img/common/tel_gr.svg);
      background-repeat: no-repeat;
      background-size: contain;
      vertical-align: middle;
      margin-right: 1px;
      transition: .3s;
   }
   .cta .flex li a .small{
   font-size: 15px;
   font-weight: 400;
   }
   .cta .flex li a .green{
      font-size: 17px;
      line-height: 1.4;
      font-weight: 700;
   }
   .cta .flex li a .now{
      color: #fff;
      font-size: 21px;
      margin-bottom: 7px;
   }
   .cta .flex li:hover a .green,
   .cta .flex li:hover a .tel{
      color: #fff;
   }
   .cta .flex li:hover a .tel::before{
      background-image: url(../img/common/tel_wh.svg);
   }
   .cta .flex li a .contact{
   font-weight: 700;
   font-size: 36px;
   color: #fff;
   }
   .cta .flex li a .contact::after{
   content: '';
   display: inline-block;
   width: 32px;
   height: 32px;
   background-image: url(../img/common/pen_wh.svg);
   background-repeat: no-repeat;
   background-size: contain;
   vertical-align: middle;
   margin-left: 8px;
   margin-bottom: 7px;
   }
   .cta .flex li a .small02{
   color: #fff;
   font-weight: 400;
   line-height: 1.4;
   margin-top: 10px;
   }
   .cta .flex li:first-child:hover{
      border: 3px solid #00c896;
      background-color: #10d9a7;
   }
   .cta .flex li:first-child a:hover .tel,
   .cta .flex li:first-child a:hover .green{
      color: #fff;
   }
   .cta .flex li:first-child a:hover .tel::before{
      background-image: url(../img/common/tel_wh.svg);
   }
   .cta .flex li:hover:nth-child(2){
      background-color: #ddfff6;
   }
   .cta .flex li:hover:nth-child(2) a .now,
   .cta .flex li:hover:nth-child(2) a .contact,
   .cta .flex li:hover:nth-child(2) a .small02{
      color: #00c896;
   }
   .cta .flex li:hover:nth-child(2) a .contact::after{
      background-image: url(../img/common/pen_gr.svg);
   }
   @media screen and (max-width: 991px) {
   }
   @media screen and (max-width: 767px) {
      .cta .inner {
         padding: 30px 3% 40px;
      }
      .cta .box{
         padding: 0 0 0;
      }
      .cta .flex{
         flex-wrap: wrap;
      }
      .cta .flex li{
         width: 100%;
      }
      .cta h2 small{
         font-size: 14px;
         margin-top: 5px;
      }
      .cta .flex li a{
         padding: 5% 5px;
         height: auto;
      }
      .cta .flex li a .small02{
         margin-top: 0;
      }
      .cta .flex li:nth-child(2) a{
         padding: 15px 0 20px;
      }
      .cta .flex li a .tel{
         font-size: 35px;
         margin: 6px 0 5px;
      }
      .cta .flex li a .tel::before{
         width: 20px;
         height: 24px;
         margin-bottom: 5px;
      }
      .cta .flex li a .green{
         font-size: 16px;
         margin-top: 5px;
      }
      .cta .flex li a .contact{
         font-size: 29px;
      }
      .cta .flex li a .contact::after{
         margin-left: 5px;
         margin-bottom: 11px;
      }
   }

/* -- caution -- */
.caution {
   background-color: #f1f1f1;
}
.caution .inner{
   padding: 30px 0;
}
.caution .txt{
   font-size: 13px;
   line-height: 1.8;
}
@media screen and (max-width: 991px){
   .caution .inner {
      padding: 20px 3%;
}
}
@media screen and (max-width: 767px) {
   .caution .txt{
   font-size: 11px;
      text-align: left;
   }
}

/* -- site -- */
.site {
   background-color: #004b87;
   color: #fff;
}
.site .flex{
   justify-content: center;
}
.site .flex .img{
   width: 20%;
}
.site .txt{
   text-align: left;
}
.site .txt p{
   font-size: 20px;
}
.site .txt .btn{
   margin-top: 20px;
}
.site .txt .btn a{
   background-color: #fff;
   color: #004b87;
   padding: 15px 25px 15px 30px;
   width: 33%;
   font-size: 15px;
   border: 2px solid #fff;
}
.site .txt .btn a::before{
   background: url(../img/common/arrow_bu.svg) no-repeat center right 10px/8px 8px;
}
.site .txt .btn a:hover{
   background-color: #004b87;
   color: #fff;
}
.site .txt .btn a:hover::before{
   background: url(../img/common/arrow_wh.svg) no-repeat center right 10px/8px 8px;
}
@media screen and (max-width: 991px) {
   .site .flex{
      flex-wrap: wrap;
   }
   .site .flex .img{
      width: 35%;
      margin-bottom: 3px;
   }
   .site .flex .txt{
      text-align: center;
   }
   .site .txt p{
      font-size: 18px;
   }
   .site .txt .btn a{
      width: 65%;
      padding: 10px 25px 10px 20px;
   }
}

/* -- footer_list -- */
.footer_list {
   background-color: #004b87;
   color: #fff;
   text-align: left;
}
.footer_list .inner{
   padding: 0 0 10px;
}
.footer_list .flex{
   justify-content: space-between;
}
.footer_list .access p{
   font-size: 17px;
   font-weight: 400;
}
@media screen and (max-width: 991px) {
   .footer_list .inner{
      padding: 0 3%;
   }
   .footer_list .flex{
      flex-wrap: wrap;
   }
   .footer_list .flex .img{
      width: 53%;
      margin: 3% auto 4%;
   }
   .footer_list .access{
      margin-bottom: 3%;
   }
   .footer_list .access p{
      font-size: 13px;
   }
}


/* pagetop */
#page_top{
   display: none;
   z-index: 1;
}

@media screen and (max-width: 991px){
   #page_top{
      position: fixed;
      display: block;
      display: flex;
      justify-content: center;
      align-items: center;
      width: 100%;
      background-color: #fff;
      box-shadow: -4px -4px 0px 0px rgb(0 0 0 / 3%);
      
   }
   #page_top a{
      width: 50%;
      text-align: center;
      line-height: 1.2;
      padding: 11px 0;
   }
   #page_top a:first-child{
      color: #00c896;
      background-color: #fff;
   }
   #page_top a:first-child::before{
      content: '';
      display: inline-block;
      width: 15px;
      height: 19px;
      background-image: url(../img/common/tel_gr.svg);
      background-repeat: no-repeat;
      background-size: contain;
      vertical-align: middle;
      margin-right: 3px;
   
   }
   #page_top a:last-child{
      color: #fff;
      background-color: #00c896;
      position: relative;
   }
   #page_top a:last-child::after{
      content: '';
      position: absolute;
      top: 10%;
      left: 0;
      width: 100%;
      height: 70%;
      background: url(../img/common/pen_wh.svg) no-repeat center right 5px/20px 20px;
   }
}