/*------------------------------------------------------------------------------
  PC or ALL
------------------------------------------------------------------------------*/
.side-sns{display: none;}

.mainvisual-catch{
  bottom: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: auto;
  padding: 40px;
  border: 3px solid #fff;
  text-align: center;
  .copy{
    margin-bottom: 20px;
    font-size: 6.2rem;
  }
  div.sub-text{
    line-height: 2;
    font-size: 1.6rem;
    letter-spacing: 5px;
  }
}

.home .page-content{

  max-width: 100%;
  padding: 0;
  .box-wrap{
    margin: 0 auto;
  }
  .box-wrap.sm{
    max-width: 1120px;
    padding: 0;
  }

  .box-wrap.sm.main-message{
    max-width: 1300px;
    padding: 0 0 70px;
    .box-h3{
      font-size: 2.4rem;
      color: #113e84;
    }
    .copy{
      font-size: 4.5rem;
    }
  }

  .box.title-type02{
    &::before{
      display: none;
    }
    .box-h2{
      display: flex;
      flex-flow: column;
      .ja{
        font-size: 5.2rem;
        /* order: 1; */
      }
      .en{
        opacity: 1;
        font-size: 2.4rem;
        color: #113e84;
        order: -1;
      }
      & strong{
        color: #f77a24;
      }
    }
  }

  .main-pro{
    padding-top: 60px;
    padding-bottom: 60px;
    background: #eee;

    .list-number-type01 .box-ol li{
      background: none;
      .image{
        border-radius: 50%;
        box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.15);
      }
    }
    .list-number-type01 .box-ol li::before{
      top: 0;
      left: 0;
      transform: none;
      line-height: 1;
      font-size: 6rem;
      color: #113e84;
    }
  }

  .main-menu{
    position: relative;
    padding: 160px 0 80px !important;
    background: url(../images/pro-more.png) no-repeat center top 40px;
    .text{
      line-height: 2;
      font-size: 1.6rem;
      .box-h3 {
        font-size: 3.3rem;
      }
      .box-h3 strong{
        color: #f77a24;
      }
    }
    .box-ul + .box-ul{
      margin-top: 30px;
    }
    .banner-type01 li{
      position: relative;
      .text,
      & a{
        display: block;
        height: 100%;
      }
      & a::after{
        position: absolute;
        bottom: 0;
        right: 0;
        width: 45px;
        height: 45px;
        text-align: center;
        line-height: 45px;
        background: #f77a24;
      }
    }
  }

  .main-reason {
    margin-bottom: 10vmin;
    .btn{
      text-align: center;
    }
  }

  .main-gal{
    max-width: 1120px;
    .blog-type04 .image img{
      /* aspect-ratio: 1 / 1; */
      object-fit: cover;
      border: 1px solid #ccc;
    }
  }
  .main-col{
    margin-top: 8vmin;
    margin-bottom: 8vmin;
    .blog-type01 .image img{
      border: 1px solid #ccc;
    }
  }
  .main-news{
    max-width: 1120px;
  }

  .mainbn{
    margin-top: 10vmin;
    margin-bottom: 10vmin;
    & a{
      display: flex;
      flex-flow: column;
      .ja{
        order: -1;
      }
    }
    & a::after{
      position: absolute;
      bottom: 0;
      right: 0;
      width: 9vmin;
      height: 9vmin;
      padding: 4vmin 0 0 4vmin;
      text-align: center;
      line-height: 45px;
      background: #f77a24;
      clip-path: polygon(100% 0, 0% 100%, 100% 100%);
    }
  }
}


.footer-top{
  padding: 0;
  .main-com{
    margin: 0;
    padding-top: 8vmin;
    padding-bottom: 8vmin;
    text-align: center;
    color: #fff;
    &.bg::before{
      background: url(../images/com-bg.jpg) repeat center 0;
    }
    .box-h3{
      margin-bottom: 5vmin;
    }
  }
  .main-area{
    margin-top: 0;
    margin-bottom: 0;
    padding-top: 10vmin;
    padding-bottom: 10vmin;
    background: #eee;
    .image-text-type03 .text:before{
      background: #fff;
      box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.15);
    }
    h3 span{
      display: block;
      opacity: 1;
      font-size: 2.2rem;
      color: #113e84;
      order: -1;
    }
  }

  .main-con{
    .title{
      display: flex;
      flex-flow: column;
      &::after{
        content:"";
        display: block;
        width: 80px;
        height: 4px;
        background: #f77a24;
        margin: 4vmin auto 0;
      }
      .en{
        order: -1;
        font-size: 6.4rem;
      }
      .ja{
        font-size: 1.8rem;
        color: #a0a0a0;
      }
    }
    .contact-type01 .text .tel:before{
      color: #f77a24;
    }
  }
}

.footer{
  background: #fff;
}

/* 20240130 added by Fabo */
.mt-s { margin-top: 4vh !important;}
.mt-m { margin-top: 7vh !important;}
.mt-l { margin-top: 10vh !important;}

.mb-s { margin-bottom: 4vh !important;}
.mb-m { margin-bottom: 7vh !important;}
.mb-l { margin-bottom: 10vh !important;}

.box-color {
    margin: 0 0 6vh;
    padding: 35px;
    background: #f7f7f7;
    border-radius: 10px;
}
.box-color :first-child {
    margin-top: 0 !important;
}
.box-color :last-child {
    margin-bottom: 0 !important;
}

.page-content .image-text-type01 .text {
    overflow: hidden;
}
.page-content  .list-check-type01 {
    display: flex;
    justify-content: flex-start;
}

.align-center {
    text-align: center;
}


/*------------------------------------------------------------------------------
  TABLET and SHONE
------------------------------------------------------------------------------*/
@media screen and (max-width: 1024px) {
}

/*------------------------------------------------------------------------------
  TABLET ONLY
------------------------------------------------------------------------------*/
@media screen and (min-width: 600px) and (max-width: 1024px) {
}

/*------------------------------------------------------------------------------
  SPHONE ONLY
------------------------------------------------------------------------------*/
@media screen and (max-width: 599px) {
  .mainvisual-catch{
    width: 80vw;
  }
  .home .page-content{
    .box-wrap.sm.main-message{
      padding: 8vmin 4vmin;
    }
    .main-menu,
    .main-reason,
    .main-col,
    .main-news{
      padding-left: 4vmin !important;
      padding-right: 4vmin !important;
    }
  }
  .image-text-type03 .text{
    background: #fff;
    box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.15);
  }
}