@charset "UTF-8";
#wrap{
    overflow: hidden;
}
img{
    width: 100%;
    height: auto;
}
.h_nav li a {
    color: #fff;
}
/* subhead */
.subhead{
    height: 100vw;
    max-height:400px;
    background: url(../img/showcase/subhead.jpg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}
.subhead_ttl {
    display: flex;
    /* margin: 90px 0 0; */
    width: 100%;
    justify-content: center;
    align-items: center;
    height: 110px;
    text-align: center;
}
.subhead_ttl_ja {
    font-size: 36px;
    font-weight: 600;
    letter-spacing: 0.2em;
    color: #fff;
}

/**/
.biz_ul{
    max-width: 1000px;
    margin: 40px auto 200px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .biz_h{
    font-size: 20px;
    font-weight: bold;
  }
  .biz_ul li{
    width: 25%;
    text-align: center;
    
    height: 300px;
    max-width: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition-duration: 0.6s;
    cursor: pointer;
  }
  .biz_ul li:hover{
    z-index: 2;
  }
  .biz_ul li:hover::before{
    /* background: #1a77bd; */
    background: linear-gradient(to top, #0e7ed0, #2ea5fc);
    transition-duration: 0.6s;
    transition-delay: 0s;
    /* border:1px solid #1a77bd; */
    opacity: 1;
    
  }
  .biz_ul li:hover::after{
      visibility: hidden;
      transition-duration: 0s;
      transition-delay: 0s;
  }
  .biz_ul li:hover .biz_num{
    /* opacity: 0; */
    /* background: #124b77; */
    background: #fff;
    border: 1px solid #1384d7;
    color: #1081d3;
    /* height: 0; */
    transition-duration: 0.6s;
    transition-delay: 0s;
  }
  .biz_ul li:hover svg{
    opacity: 0;
    /* height: 0; */
    transition-duration: 0s;
    transition-delay: 0s;
  }
  .biz_ul li:hover p{
    color: #fff;
    transition-duration: 0.6s;
  }
  .biz_ul li::before{
    content: "";
    position: absolute;
    width: 115%;
    height: 95%;
    /* border: 1px solid #000; */
    background: linear-gradient(to top, #0e7ed0, #2ea5fc);
    opacity: 0;
    border-radius: 200px;
    top: 50%;
    left:50%;
    transform: translate(-50%,-50%);
    transition-duration: 0.6s;
    
  }
  /* .biz_ul li::after{
    content: "";
    position: absolute;
    width: 120%;
    height: 100%;
    border: 1px solid #fff;
    background: #fff;
    border-radius: 200px;
    top: 50%;
    left:50%;
    transform: translate(-50%,-50%);
    transition-duration: 0.6s;
    transform-origin: 0 25%;
    animation: draw 0.3s linear forwards;
    transform-origin: 0;
    
  } */
  @keyframes draw {
    0% {
      transform: rotate(0deg) translate(-50%,-50%);
    }
    100% {
      transform: rotate(180deg) translate(-50%,-50%);
    }
  }
  /* .biz_ul li::after{
    content: "";
    position: absolute;
    width: 120%;
    height: 100%;
    border: 1px solid #000;
    background: #000;
    border-radius: 200px;
    top: 50%;
    left:50%;
    transform: translate(-50%,-50%);
    transition-duration: 0.6s;
    opacity: 0;
    z-index: 1;
  } */
  .biz_ul li p{
    position: relative;
    z-index: 2;
    letter-spacing: 0.1em;
    width: 100%;
  }
  .biz_ul li p span{
    position: absolute;
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 12px;
    font-weight: normal;
    width: 100%;
    letter-spacing: 0.5px;
  }
  .biz_num{
    position: absolute !important;
    left: 0px;
    top: 28px;
    height: 40px;
    width: 70px !important;
    /* border-radius: 40px; */
    background: #fff;
    display: flex;
    align-items: center; 
    justify-content: center;        
    transition-duration: 0.6s;
    /* transition-delay: 0.5s; */
    letter-spacing: 0 !important;
    color: #777;
    border: 1px solid #777;
    }
    #biz01_s,#biz02_s,#biz03_s,#biz04_s{

        margin-top: -80px;
        padding-top: 80px;

    }

@media screen and (max-width: 650px) {
    .subhead_ttl_ja {
    font-size: 30px;
    }
    
}


/* main */
section.str_sec{
    margin: 120px 0 140px;
}

.sec_heading{
    max-width: 1240px;
    padding: 0 20px;
    margin: 0 auto 80px;
    text-align: center;
}
.sec_ttl{
    font-size: 30px;
    font-weight: bold;
    margin-bottom: 50px;
    letter-spacing: 0.1em;
}
.sec_text{
    font-size: 16px;
    line-height: 1.8;
}

.p_img{
    max-width: 270px;
    margin: 0 5px;
}
.slider_bg{
    background: #1b1b1b;
    padding: 10px 0;
}



/* biz */
.biz_showcase_flex{
    max-width: 1240px;
    padding: 0 20px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.biz_showcase_flex > div:first-child{
    margin-right: 40px;
}
.biz_showcase{
    padding: 100px 0;
}
.biz_showcase.odd{
    background-image: -webkit-gradient(linear, left bottom, right top, color-stop(0%,rgb(248,251,253)), color-stop(100%,rgb(242,247,251)));
    background-image: -moz-linear-gradient(90deg, rgb(248,251,253) 0%, rgb(242,247,251) 100%);
    background-image: -webkit-linear-gradient( 90deg, rgb(248,251,253) 0%, rgb(242,247,251) 100%);
    background-image: -ms-linear-gradient( 90deg, rgb(248,251,253) 0%, rgb(242,247,251) 100%);
    background-image: linear-gradient( 90deg, rgb(248,251,253) 0%, rgb(242,247,251) 100%);
}
.biz_square{    
    display: flex;
    flex-wrap: wrap;
    max-width: 470px;
    justify-content: space-between;
}
.biz_img {
    max-width: 230px;
    width: 49%;
    display: flex;
    align-items: center;
    overflow: hidden;
    height: 21vw;
    max-height: 220px;
    min-height: 140px;
}

.biz_img:nth-child(odd){
    margin-right: 2%;
}

.biz_img:nth-child(1), .biz_img:nth-child(2){
    margin-bottom: 2%;
}
.biz_ttl{
    font-size: 30px;
    font-weight: bold;
    margin-bottom: 50px;
    letter-spacing: 0.1em;
}
.biz_text{
    line-height: 1.8;
}
.biz_text_area{
    max-width: 490px;
}

/* showcase */
.showcase_area{
    background-image: -webkit-gradient(linear, left bottom, right top, color-stop(0%,rgb(248,251,253)), color-stop(100%,rgb(242,247,251)));
    background-image: -moz-linear-gradient(90deg, rgb(248,251,253) 0%, rgb(242,247,251) 100%);
    background-image: -webkit-linear-gradient( 90deg, rgb(248,251,253) 0%, rgb(242,247,251) 100%);
    background-image: -ms-linear-gradient( 90deg, rgb(248,251,253) 0%, rgb(242,247,251) 100%);
    background-image: linear-gradient( 90deg, rgb(248,251,253) 0%, rgb(242,247,251) 100%);
    padding: 100px 0 220px;
    text-align: center;
}
.showcase_area .sec_ttl{
    margin-bottom: 100px;
}
.click_slide_area{
    max-width: 1040px;
    padding: 0 20px;
    margin: 0 auto;
    position: relative;
}
.id_link {
	display: block;
	width: 1px;
	height: 1px;
	position:absolute;
	top: -100px;
}
.click_slide_area:not(:last-child){
    margin: 0 auto 80px;
}
.slide_ttl{
    font-size: 20px;
    font-weight: bold;
    line-height: 1;
    margin-top: 20px;
}
.slick-prev:before, .slick-next:before{
    font-family: none;
}
.slick-next::before{
	content: '';
	width: 13px;
	height: 13px;
	border: 0px;
	border-top: solid 3px #272727;
	border-right: solid 3px #272727;
	-ms-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	position: absolute;
	top: 50%;
	right: 0;
	margin-top: -4px;
}
.slick-prev::after{
	content: '';
	width: 13px;
	height: 13px;
	border: 0px;
	border-top: solid 3px #272727;
	border-right: solid 3px #272727;
	-ms-transform: rotate(-135deg);
	-webkit-transform: rotate(-135deg);
	transform: rotate(-135deg);
	position: absolute;
	top: 50%;
	left: 0;
	margin-top: -4px;
}

.br750{
    display: none;
}
.br650{
    display: none;
}
.br500{
    display: none;
}
.br450{
    display: none;
}
.br370{
    display: none;
}

@media screen and (max-width: 1100px){
    .br_biz_text{
        display: none;
    }
    .biz_img_area{
        width: 50%;
    }
    .biz_text_area{
        width: 50%;
    }
    .click_slide_area {
        padding: 0 40px;
    }
}

@media screen and (max-width: 1000px) {
    .sec_ttl {
        font-size: 28px;
        margin-bottom: 30px;
    }
    .biz_ttl{
        font-size: 28px;
        margin-bottom: 30px;
    }
    .sec_heading {
        margin: 0 auto 140px;
    }
    .biz_text{
        font-size: 14px;
    }
    .slide_ttl {
        font-size: 18px;
    }
    .sec_text {
        font-size: 14px;
    }

    /**/
    .biz_ul{
        justify-content: center;
        max-width: 600px;
      }
      .biz_ul li{
        width: 50%;
      }

      .biz_ul li::before {
        height: 113%;
      }
      .biz_num {
        left: 0px;
        top: 8px;
      }

}

@media screen and (max-width: 900px){

}

@media screen and (max-width: 768px){
    .showcase_area .sec_ttl {
        margin-bottom: 80px;
    }

    .biz_ul{
        margin: 40px auto 120px;
      }

    #biz01_s,#biz02_s,#biz03_s,#biz04_s{

        margin-top: -50px;
        padding-top: 50px;

    }
}

@media screen and (max-width: 750px){
    .br750{
        display: block;
    }
}

@media screen and (max-width: 650px){
    .str_flex {
        flex-wrap: wrap;
    }
    .sec_ttl {
        font-size: 22px;
    }
    .biz_ttl{
        font-size: 20px;
        margin-bottom: 10px;
    }
    .slide_ttl {
        font-size: 16px;
    }
    section.str_sec {
        margin: 80px 0;
    }
    .sec_heading {
        margin: 0px auto 80px;
    }
    .biz_showcase_flex {
        flex-wrap: wrap;
    }
    .biz_showcase_flex > div:first-child {
        margin-right: 0px;
    }
    .biz_text_area {
        width: 100%;
        text-align: center;
        margin: 0 auto !important;
        order: 2;
    }
    .biz_img_area {
        width: 100%;
        order: 1;
    }
    .biz_square {
        max-width: 280px;
        margin: 0 auto 30px;
    }
    .biz_showcase {
        padding: 80px 0;
    }
    .showcase_area {
        padding: 80px 0 120px;
    }
    .showcase_area .sec_ttl {
        margin-bottom: 40px;
    }
    .br650{
        display: block;
    }
    .click_slide_area:not(:last-child) {
        margin: 0 auto 60px;
    }
    .slick-next::before {
        border-top: solid 2px #272727;
        border-right: solid 2px #272727;
    }
    .slick-prev::after {
        border-top: solid 2px #272727;
        border-right: solid 2px #272727;
    }
    .biz_ul li p span {
        font-size: 10px;
    }

    .biz_h {
        font-size: 15px;
    }

    /**/
    .biz_ul {
        max-width: 400px;
    }
    .biz_ul li{
      height: 200px;
    }

    .biz_num {
        left: 0px;
        top: -2px;
        font-size: 13px;
        height: 35px;
        width: 35px !important;
    }
}

@media screen and (max-width: 500px){
    .br500{
        display: block;
    }
}

@media screen and (max-width: 450px){
    .br450{
        display: block;
    }
    .sec_heading {
        padding: 0 10px;
    }

    /**/

    .biz_ul{
        max-width: 320px;
      }

      .biz_ul li{
        height: 160px;
      }

      .biz_num {
        left: 0px;
        top: 10px;
        height: 25px;
        width: 40px !important;
        /* border-radius: 40px; */
        font-size: 12px;

      }
}

@media screen and (max-width: 370px){
    .br370{
        display: block;
    }
}



/* inview */
.blur {
	opacity: 0;
	filter: blur(20px);
	-ms-filter: blur(20px);
	-webkit-filter: blur(20px);
	-moz-filter: blur(20px);
	-webkit-transition-duration: 1s;
	transition-duration: 1s
}
.blur.is-show {
	opacity: 1;
	filter: blur(0);
	-ms-filter: blur(0);
	-webkit-filter: blur(0);
	-moz-filter: blur(0);
	-webkit-transition-duration: 1s;
	transition-duration: 1s
}

.de01{
    transition-delay: 0.4s;
}
.de02{
    transition-delay: 0.8s;
}
.de03{
    transition-delay: 1.2s;
}

@media all and (-ms-high-contrast: none) {
    svg{
        top:-10%;
        left: -10%;
    }
    .slick-next::before{
        right: 3px;
    }
    .slick-prev::after{
        left: 3px;
    }
}