@charset "utf-8";

/*=================================================================
   ヒーローエリア
=================================================================*/
.top-hero__sliders{
   height: 650px;
   background: #0054a7;
}
.top-hero__sliders .swiper-slide{
   position: relative;
}
.top-hero__sliders .swiper-slide > .slide-img {
   position: absolute;
   top: 0;
   left: 50%;
   transform: translateX(-50%);
   width: 100%;
   height: 100%;
   object-fit: cover;
   z-index: -1;
}
.top-hero__sliders .swiper-slide > .top-hero__content {
   left: 50%;
   transform: translateX(-50%);
   width: 100%;
   max-width: 1320px;
   padding: 0 40px;
   margin: 0;
}

@media screen and (max-width: 767px) {
   .top-hero__sliders{
      height: 115vw;
   }
   .top-hero__sliders .swiper-slide > .top-hero__content {
      padding: 0 30px;
   }
}
@media screen and (max-width: 650px) {
   .top-hero__sliders{
      height: 125vw;
   }
}
@media screen and (max-width: 480px) {
   .top-hero__sliders{
      height: 550px;
   }
}


/* .main.swiper-slide 1枚目
-------------------------------------*/
.main.swiper-slide{
   position: relative;
   overflow: hidden;
}
.main.swiper-slide::after{
   content: '';
   position: absolute;
   bottom: 0;
   right: 0;
   border-bottom: 28vw solid var(--color-lightblue);  /* 三角を白にする */
   border-left: 70vw solid transparent;
}
.main.swiper-slide .top-hero__content{
   position: relative;
   top: 110px;
   z-index: 1;
   color: #fff;
}
.main.swiper-slide .top-hero__img{
   position: absolute;
   right: 0;
   bottom: -70px;
   width: 59%;
}
.main.swiper-slide .top-hero__heading1{
   font-size: 6rem;
   line-height: 120%;
}
.main.swiper-slide .top-hero__heading2{
   font-size: 3.4rem;
   margin: 20px 0;
}
.main.swiper-slide .top-hero__list{
   padding: 0;
   list-style: none;
}
.main.swiper-slide .top-hero__list li{
   position: relative;
   font-size: 2.2rem;
   font-weight: 600;
   padding-left: 30px;
}
.main.swiper-slide .top-hero__list li span{
   font-size: 1.2em;
}
.main.swiper-slide .top-hero__list li span.text-yellow{
   color: #fffd3a;
}
.main.swiper-slide .top-hero__list li span.text-small{
   font-size: .9em;
}
.main.swiper-slide .top-hero__list li::before{
   position: absolute;
   left: 0;
   top: 10px;
   content: "";
   display: inline-block;
   width: 24px;
   height: 24px;
   background: url("../img/common/icon_check.png");
   background-size: cover;
}
.main.swiper-slide .top-hero__link-btn{
   max-width: 440px;
}
.main.swiper-slide .top-hero__link-btn .btn_contact{
   width: 100%;
   height: 70px;
   font-size: 2.2rem;
}
.main.swiper-slide .top-hero__link-btn .btn_contact::before{
   width: 28px;
   height: 28px;
   margin-right: 15px;
}
@media screen and (max-width: 767px) {
   .main.swiper-slide .top-hero__content{
      top: 60px;
   }
   .main.swiper-slide .top-hero__heading1{
      font-size: 8.5vw;
   }
   .main.swiper-slide .top-hero__heading2{
      font-size: 5.4vw;
   }
   .main.swiper-slide .top-hero__list li{
      font-size: 4vw;
   }
   .main.swiper-slide .top-hero__img{
      position: static;
      width: 80%;
      margin: auto auto 3%;
   }
   .main.swiper-slide .top-hero__link-btn{
      margin: auto;
      width: 95%;
   }
}
@media screen and (max-width: 480px) {
   .main.swiper-slide .top-hero__content{
      top: 45px;
   }
   .main.swiper-slide::after{
      border-bottom: 55vw solid var(--color-lightblue);
      border-left: 64vw solid transparent;
   }
   .main.swiper-slide .top-hero__heading1{
      font-size: 3.6rem;
   }
   .main.swiper-slide .top-hero__heading2{
      font-size: 2.3rem;
   }
   .main.swiper-slide .top-hero__list li{
      font-size: 1.6rem;
      padding-left: 24px;
   }
   .main.swiper-slide .top-hero__list li::before{
      top: 4px;
      width: 19px;
      height: 19px;
   }
   .main.swiper-slide .top-hero__img{
      width: 100%;
      max-width: 360px;
      margin: auto auto 15px;
   }
   .main.swiper-slide .top-hero__link-btn .btn_contact{
      height: 65px;
      font-size: 1.8rem;
   }
}

/*=================================================================
   top-news
=================================================================*/
.top-news{
   max-width: 1000px;
   margin: auto;
   padding: 60px 0 0;
}
.top-news .sec-heading{
   position: relative;
}
.top-news .sec-heading__title{
   font-size: 3.6rem;
}
.top-news .news__list{
   margin: 30px 0 45px;
}
@media print, screen and (min-width: 768px) {
   .top-news__more{
      position: absolute;
      right: 0;
      top: 0;
   }
   .top-news__more .btn{
      width: 150px;
      height: 40px;
      font-size: 1.5rem;
      justify-content: flex-start;
      padding-left: 15px;
      box-shadow: 0px 4px 8px 2px rgb(var(--color-blue-rgb), 0.2);
   }
   .top-news__more .btn::after{
      right: 9px;
      width: 12px;
      height: 12px;
   }
}
@media screen and (max-width: 767px) {
   .top-news{
      padding: 40px 20px 30px;
   }
   .top-news .sec-heading__title {
      font-size: 2.6rem;
   }
   .top-news .news__list {
      margin: 20px 0 30px;
   }
}

/*=================================================================
   top-banner
=================================================================*/
.top-banner{
   text-align: center;
   margin: 0 auto 60px;
}
.top-banner__item img{
   transition: all 0.5s ease-in-out;
}
@media (hover: hover) {
   .top-banner__item img:hover{
      transform: scale(1.03);
      transition: all 0.5s ease-in-out;
   }
}

/*=================================================================
   top-concept
=================================================================*/
.top-concept{
   position: relative;
   overflow: hidden;
   padding-bottom: 100px;
   background: var(--color-lightblue);
}
.top-concept::before,
.top-concept::after{
   content: '';
   position: absolute;
   display: inline-block;
   width: 0;
   height: 0;
   border-style: solid;
}
.top-concept::before {
   top: 0;
   left: 0;
   border-width: 19vw 100vw 0 0;
   border-color: #fff transparent transparent transparent;
}
.top-concept::after {
   z-index: 1;
   bottom: 0;
   left: 0;
   border-width: 0 0 25vw 100vw;
   border-color: transparent transparent #cbdced transparent;
}
.top-concept__head{
   position: relative;
   z-index: 1;
   display: flex;
   justify-content: space-between;
   align-items: center;
   max-width: 1200px;
   margin: auto auto 90px;
}
.top-concept__head-title{
   font-size: 3.6rem;
   font-weight: 700;
   line-height: 1.4;
}
.top-concept__block{
   position: relative;
   z-index: 2;
   display: flex;
   align-items: center;
   justify-content: space-between;
   padding: 60px 70px;
   margin: 60px auto;
   border-radius: 34px;
   background: #fff;
}
.top-concept__content{
   width: 52%;
}
.top-concept__img{
   width: 480px;
}
.top-concept__worries{
   position: relative;
   display: inline-block;
   padding: 0 0 15px 140px;
   border-bottom: 3px solid var(--color-blue);
}
.top-concept__worries:before {
   position: absolute;
   top: 100%;
   left: 50px;
   transform: skew(40deg);
   height: 18px;
   width: 15px;
   border-left: 4px solid var(--color-blue);
   background-color: white;
   content: "";
}
.top-concept__worries .w-badge{
   position: absolute;
   left: 0;
   display: inline-block;
   line-height: 1;
   font-weight: 700;
   padding: 8px 20px;
   color: var(--color-blue);
   border: 1px solid var(--color-blue);
   border-radius: 50px;
}
.top-concept__worries .w-title{
   margin: 0;
   font-size: 2.4rem;
   font-weight: 700;
}
.top-concept__subhead{
   color: var(--color-blue);
   font-size: 3.7rem;
   line-height: 1.4;
   margin: 30px 0 20px;
}
.top-concept__description{
   margin: 0;
}
.top-concept__more{
   margin-top: 25px;
}
.top-concept__more .btn{
   width: 250px;
   height: 60px;
   margin: 0;
}
.top-concept__btn{
   position: relative;
   z-index: 2;
   width: 340px;
   margin: auto;
}
@media screen and (max-width: 767px) {
   .top-concept{
      padding: 0 20px 60px;
   }
   .top-concept::before{
      border-width: 28vw 100vw 0 0;
   }
   .top-concept::after{
      border-width: 0 0 48vw 100vw;
   }
   .top-concept__head{
      flex-wrap: wrap;
      justify-content: center;
      margin: auto auto 20px;
   }
   .top-concept__head-title{
      width: 100%;
      order: 2;
      font-size: 2.1rem;
      text-align: center;
      margin-top: 25px;
   }
   .top-concept__head-img{
      width: 80%;
   }
   .top-concept__block{
      display: block;
      margin: 40px auto;
      border-radius: 20px;
      padding: 28px 32px 40px;
   }
   .top-concept__content{
      width: 100%;
   }
   .top-concept__img{
      width: 100%;
      text-align: center;
   }
   .top-concept__worries{
      display: block;
      padding: 0;
      border-width: 2px;
   }
   .top-concept__worries:before{
      height: 15px;
      border-width: 2px;
   }
   .top-concept__worries .w-badge{
      position: static;
      font-size: 1.3rem;
      padding: 6px 15px;
   }
   .top-concept__worries .w-title{
      font-size: 1.7rem;
      padding: 10px 0;
   }
   .top-concept__subhead{
      font-size: 2.2rem;
   }
   .top-concept__more {
      margin-top: 20px;
   }
   .top-concept__more .btn{
      height: 46px;
      margin: auto;
   }
}

/*=================================================================
   top-service
=================================================================*/
.top-service{
   position: relative;
   padding: 100px 0;
}
.top-service::after{
   position: absolute;
   top: 0;
   left: 0;
   z-index: -1;
   content: "";
   display: block;
   width: 100%;
   height: 80%;
   background: #e9eef4;
}
.top-service__cate{
   display: flex;
   justify-content: center;
   flex-wrap: wrap;
   list-style: none;
   margin: 0 0 30px;
   padding: 0;
}
.top-service__cate-item{
   color: var(--color-blue);
   text-align: center;
   line-height: 1.3;
   font-weight: 700;
   max-width: 190px;
   min-height: 60px;
   width: 100%;
   padding: 7px 15px;
   margin: 5px 10px;
   background: #fff;
   display: flex;
   align-items: center;
   justify-content: center;
   border-radius: 50px;
   cursor: pointer;
}
.top-service__cate-item.is-active{
   color: #fff;
   background: var(--color-blue);
}
.top-service__list{
   display: flex;
   flex-wrap: wrap;
}
.top-service__item{
   position: relative;
   text-align: center;
   width: 32%;
   margin-bottom: 2%;
}
.top-service__item .badge{
   position: absolute;
   z-index: 1;
   top: -.5em;
   right: 1.5em;
   color: #fff;
   font-size: .85em;
   line-height: 1;
   border-radius: 6px;
   padding: 5px 10px;
   background: var(--color-orange);
}
@media print, screen and (min-width: 768px) {
   .top-service__item:nth-child(3n-1){
      margin-left: 2%;
      margin-right: 2%;
   }
}
.top-service__item-link{
   position: relative;
   display: block;
   height: 100%;
   width: 100%;
   border-radius: 16px;
   background: #fff;
   overflow: hidden;
   text-decoration: none;
   padding: 32px;
   box-shadow: 0px 7px 16px 3px rgb(var(--color-blue-rgb), 0.15);
}
.top-service__item-link::before,
.top-service__item-link::after{
   position: absolute;
   content: "";
   display: block;
   pointer-events: none;
}
.top-service__item-link::before{
   z-index: 1;
   right: 10px;
   bottom: 10px;
   width: 14px;
   height: 14px;
   background: url("../img/common/icon_arrows_w.png");
   background-size: cover;
}
.top-service__item-link::after{
   right: 0;
   bottom: 0;
   width: 0;
   height: 0;
   border-style: solid;
   border-width: 0 0 54px 54px;
   border-color: transparent transparent var(--color-blue) transparent;
   transition: .5s;
}
@media (hover: hover) {
   .top-service__item-link:hover{
      box-shadow: none;
   }
   .top-service__item-link:hover::after{
      border-color: transparent transparent var(--color-aqua) transparent;
   }
   .top-service__item-link:hover .top-service__item-title{
      color: var(--color-aqua);
   }
}
.top-service__item-title{
   margin: 25px 0 10px;
   line-height: 1.2;
}
.top-service__item-description{
   color: var(--color-base);
   text-align: left;
   font-size: 1.6rem;
   font-weight: 500;
   margin: 0;
}
@media screen and (max-width: 767px) {
   .top-service {
      padding: 50px 20px;
   }
   .top-service::after{
      height: 91%;
   }
   .top-service__cate{
      flex-wrap: wrap;
      justify-content: space-between;
   }
   .top-service__cate-item{
      width: 49%;
      min-height: inherit;
      margin: 0;
      padding: 15px 10px;
   }
   .top-service__item{
      width: 100%;
      margin-bottom: 15px;
   }
   .top-service__item-link{
      display: flex;
      align-items: center;
      padding: 24px 12px 24px 20px;
      border-radius: 10px;
   }
   .top-service__item-img{
      width: 40%;
      order: 2;
      margin-left: 12px;
   }
   .top-service__item-title{
      margin: 0 0 10px;
      text-align: left;
   }
   .top-service__item-description{
      font-size: 1.3rem;
   }
   .top-service__item-link::before{
      width: 12px;
      height: 12px;
      bottom: 8px;
   }
   .top-service__item-link::after{
      border-width: 0 0 45px 45px;
   }
}

/*=================================================================
   top-function
=================================================================*/
.top-function{
   text-align: center;
   padding-bottom: 100px;
}
.top-function__box{
   margin-top: 50px;
   padding: 50px 90px;
   background: var(--color-lightblue);
   border-radius: 34px;
}
.top-function__tit{
   font-size: 2.8rem;
}
.top-function__subtit{
   font-weight: 700;
   margin: 8px auto 20px;
}
.top-function__list{
   display: flex;
   flex-wrap: wrap;
}
.top-function__item{
   width: 32.5%;
   margin-bottom: 1.5%;
}
.top-function__link{
   display: flex;
   align-items: center;
   text-decoration: none;;
   width: 100%;
   height: 100%;
   padding: 10px 15px 10px 30px;
   background: #fff;
   border-radius: 14px;
   box-shadow: 0px 7px 16px 3px rgb(var(--color-blue-rgb), 0.15);
}
@media (hover: hover) {
   .top-function__link:hover{
      box-shadow: 0px 0px 2px 0px rgb(var(--color-blue-rgb), 0.15);
   }
   .top-function__link:hover .top-function__link-tit{
      color: var(--color-blue);
   }
}
@media print, screen and (min-width: 768px) {
   .top-function__item:nth-child(3n-1){
      margin-left: 1.25%;
      margin-right: 1.25%;
   }
}
.top-function__img{
   width: 45px;
}
.top-function__link-tit{
   flex: 1;
   color: var(--color-base);
   font-weight: 500;
   line-height: 1.3;
   text-align: left;
   font-size: 2rem;
   padding-left: 20px;
}
.dan2 .top-function__link-tit{
   margin: 10px 0;
   font-size: .95em;
}
.top-function__free{
   position: relative;
}
.top-function__free::after{
   position: absolute;
   bottom: -50px;
   left: 0;
   right: 0;
   margin: auto;
   content: "";
   width: 70px;
   height: 70px;
   background: url("../img/common/icon_plus.png");
   background-size: cover;
}
.top-function__option{
   margin-top: 30px;
   background: var(--color-lightblue2);
}
.top-function__option .top-function__tit{
   margin-bottom: 30px;
}
.top-function__more-tit{
   font-weight: 700;
   font-size: 2.2rem;
   margin: 60px 0 25px;
}
@media screen and (max-width: 767px) {
   .top-function{
      padding: 0 20px 50px;
   }
   .top-function__box{
      padding: 30px 15px;
      margin-top: 20px;
      border-radius: 16px;
   }
   .top-function__tit {
      font-size: 1.8rem;
   }
   .top-function__list{
      border-radius: 10px;
      overflow: hidden;
      background: #fff;
      box-shadow: 0px 7px 16px 3px rgb(var(--color-blue-rgb), 0.15);
   }
   .top-function__item{
      width: calc(100% / 3);
      margin: 0;
   }
   .top-function__link{
      position: relative;
      border-radius: 0;
      box-shadow: none;
      padding: 12px 5px;
      flex-flow: column;
      justify-content: center;
      border-top: 1px solid #f2f6fb;
   }
   .top-function__item:nth-child(-n+3) .top-function__link{
      border-top: 0;
   }
   .top-function__item:nth-child(3n-1) .top-function__link::before,
   .top-function__item:nth-child(3n-1) .top-function__link::after{
      content: "";
      position: absolute;
      top: 0;
      width: 1px;
      height: 100%;
      background: #f2f6fb;
   }
   .top-function__item:nth-child(3n-1) .top-function__link::before{
      left: 0;
   }
   .top-function__item:nth-child(3n-1) .top-function__link::after{
      right: 0;
   }
   .top-function__img{
      width: 35%;
   }
   .top-function__link-tit{
      flex: none;
      padding: 0;
      margin: 10px 0 0;
      font-size: 1.2rem;
      line-height: 1.2;
      text-align: center;
   }
   .dan2 .top-function__link-tit{
      font-size: 1.2rem;
   }
   .top-function__free::after{
      width: 45px;
      height: 45px;
      bottom: -31px;
   }
   .top-function__option .top-function__tit{
      margin: 0 10px 15px;
      text-align: center;
      font-size: 1.4rem;
      line-height: 1.5;
   }
   .top-function__more-tit{
      font-size: 1.4rem;
      margin: 30px 0 20px;
   }
}

/*=================================================================
   top-contact
=================================================================*/
.top-contact{
   padding: 70px 0;
   background: var(--color-blue);
}
.top-contact__list{
   display: flex;
   justify-content: space-between;
}
.top-contact__item{
   width: 31%;
}
.top-contact__title{
   color: #fff;
   font-size: 1.1em;
   font-weight: 700;
   text-align: center;
   margin: 0 0 15px;
}
.top-contact__btn .btn{
   height: 76px;
   font-size: 1.1em;
   box-shadow: 0px 7px 10px 2px rgb(var(--color-base-rgb), 0.15);
}
.top-contact__btn .btn::before{
   width: 32px;
   height: 32px;
   margin-right: 15px;
   transition: .5s;
}
.top-contact__btn .btn::after{
   display: none;
}
.btn_consultation::before{
   content: "";
   display: inline-block;
   background: url("../img/common/icon_mail_b.png");
   background-size: cover;
}
.btn_faq::before{
   content: "";
   display: inline-block;
   background: url("../img/common/icon_faq_b.png");
   background-size: cover;
}
@media (hover: hover) {
   .top-contact__btn .btn:not(.btn_contact):hover{
      color: var(--color-blue);
      background: #fff;
   }
   .top-contact__btn .btn:hover{
      box-shadow: none;
   }
}

@media screen and (max-width: 767px) {
   .top-contact{
      position: relative;
      padding: 30px 20px;
   }
   .top-contact::after {
      content: '';
      position: absolute;
      bottom: 0;
      right: 0;
      border-bottom: 35vw solid rgb(255,255,255, 0.15);
      border-left: 60vw solid transparent;
   }
   .top-contact__list{
      display: block;
   }
   .top-contact__item{
      position: relative;
      z-index: 1;
      width: 100%;
      margin: 20px 0;
   }
   .top-contact__title{
      margin: 0 0 8px;
   }
   .top-contact__btn .btn{
      width: 90%;
      height: 60px;
      justify-content: flex-start;
   }
   .top-contact__btn .btn::before{
      width: 24px;
      height: 24px;
      margin: 0 25px 0 25px;
   }
}

/*=================================================================
   top-case
=================================================================*/
.top-case{
   padding: 100px 0;
   overflow: hidden;
}
.top-case__sliders{
   position: relative;
   display: none;
   margin: 40px 0 80px;
}
.top-case__sliders.swiper-initialized{
   display: block;
}
.top-case__item{
   height: auto;
   overflow: hidden;
}
.top-case__item-link{
   display: block;
   text-decoration: none;
   height: 100%;
}
.top-case__name{
   color: var(--color-base);
   font-weight: 700;
}
.top-case__item-title{
   color: var(--color-base);
   font-weight: 600;
}
.top-case__img{
   width: 100%;
   height: 100%;
   object-fit: cover;
}
@media print, screen and (min-width: 768px) {
   .top-case__item{
      width: 770px!important;
      border-radius: 16px;
      box-shadow: 0px 5px 15px 2px rgb(var(--color-blue-rgb), 0.2);
   }
   .top-case__item-link{
      display: flex;
      justify-content: space-between;
      padding: 35px 40px;
   }
   .top-case__item-thumb{
      width: 50%;
   }
   .top-case__item-contents{
      width: 46%;
   }
   .top-case__name{
      font-size: 2.2rem;
      margin-bottom: 15px;
   }
   .top-case__item-title{
      margin: 0;
   }
}
@media print, screen and (min-width: 1400px) {
   .top-case__item{
      width: 880px!important;
   }
}
@media screen and (max-width: 767px) {
   .top-case{
      padding: 50px 0 60px;
   }
   .top-case__sliders{
      padding: 0 20px;
      margin: 30px 0 60px;
   }
   .top-case__item {
      width: 78%!important;
      border-radius: 12px;
      box-shadow: 0px 5px 10px 2px rgb(var(--color-blue-rgb), 0.15);
   }
   .top-case__item-contents{
      padding: 15px 20px;
   }
   .top-case__name{
      margin-bottom: 10px;
   }
}

/* swiper-button
-------------------------------------*/
.top-case .swiper-button-prev,
.top-case .swiper-button-next{
   top: 42%;
   position: absolute;
}
.top-case .swiper-button-prev{
   left: calc( 50% - 440px);
}
.top-case .swiper-button-next{
   right: calc( 50% - 440px);
}
@media print, screen and (min-width: 1400px) {
   .top-case .swiper-button-prev{
      left: calc( 50% - 495px);
   }
   .top-case .swiper-button-next{
      right: calc( 50% - 495px);
   }
}

/* swiper-pagination
-------------------------------------*/
.top-case .swiper-pagination{
   bottom: -50px;
}
@media screen and (max-width: 767px) {
   .top-case .swiper-pagination{
      bottom: -40px;
   }
}


/*=================================================================
   top-model
=================================================================*/
.top-model{
   padding: 100px 0 80px;
   overflow: hidden;
}

@media screen and (max-width: 767px) {
   .top-model{
      padding: 50px 20px 30px;
   }
}
