@charset "UTF-8";

@font-face {
    font-family: 'Noto Sans Japanese';
    font-style: normal;
    font-weight: 400;
    src: url('fonts/NotoSansJP/NotoSansJP-Regular.woff') format('woff');
    font-display: swap;
  }
@font-face {
    font-family: 'Noto Sans Japanese';
    font-style: normal;
    font-weight: 700;
    src: url('fonts/NotoSansJP/NotoSansJP-Medium.woff') format('woff');
    font-display: swap;
  }
@font-face {
    font-family: 'Noto Sans Japanese';
    font-style: normal;
    font-weight: 700;
    src: url('fonts/NotoSansJP/NotoSansJP-Bold.woff') format('woff');
    font-display: swap;
  }

body {
	font-family: 'Noto Sans JP"', sans-serif, serif;
    color: #272727;
    line-height: 35px;
    letter-spacing: 4px;
    font-size: 16px;
}

.wf-notosansjapanese { font-family: "Noto Sans JP"; }

.wrap { width: 100%; overflow: hidden; }

.inner{
    width: 1000px;
    max-width: 90%;
    margin: 0 auto;
}

/* clearfix　*/ 
.clearfix:after {
	clear: both;
	display: block;
	visibility: hidden;
	height: 0;
	font-size: 0;
	content: ".";
}

.clearfix {
	clear: both;
	*zoom: 1;
}

.img_wrap{
    margin: 0 auto;
    overflow: hidden;
  }

  .img_wrap img{
    width: 100%;
    cursor: pointer;
    transition-duration: 0.3s;
  }
  .img_wrap:hover img{
    opacity: 0.6;
    transition-duration: 0.3s;
  }

  .slider{
    margin: 100px auto;
    width: 100%;
}
.slider img{
    height: auto;
    width: 100%;
}
/*slick setting*/
.slick-prev:before,
.slick-next:before {
    color: #000;
}

header{
	color: #fff;
	position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 9999;
    height: 100px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    will-change: transform;
    -webkit-transition: -webkit-transform .2s linear;
    transition: -webkit-transform .2s linear;
    transition: transform .2s linear;
    transition: transform .2s linear,-webkit-transform .2s linear;
    justify-content: space-around;
}

header ul.header_text {
    display: flex;
}

header ul.header_text li {
    border: 1px solid #fff;
    width: 170px;
    text-align: center;
    padding: 5px 20px;
    margin-right: 56px;
    border-radius: 50px;
}

/* contact */ 
#contact {
    background: linear-gradient(140.23deg,#6e2af7,#1da3f0 99.9%);
    color: #fff;
    padding: 80px 0;
}

#contact .contact_tit{
    text-align: center;
}

#contact .contact_tit h3 {
    font-size: 2vw;
    font-weight: bold;
    display: flex;
	align-items: center;
}

#contact .contact_tit h3:before, #contact .contact_tit h3:after {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #fff;
	display: block;
}
#contact .contact_tit h3:before {
	margin-right: .4em;
}
#contact .contact_tit h3:after {
	margin-left: .4em;
}

#contact .contact_tit p {
    font-size: 1.5vw;
    padding: 25px 0;
    font-weight: bold;
}

#contact .contact_link ul {
    display: flex;
    text-align: center;
    justify-content: space-around;
}

#keyvis{
    height: 100vh;
    background: linear-gradient(140.23deg,#6e2af7,#1da3f0 99.9%);
    position: relative;	
    display: flex;
    justify-content: space-around;
}

#keyvis::after{
	content: "";
    position: absolute;
    right: 0;
    top: 0;
    width: 30%;
    background-color: #222;
    height: 100%;
}

#keyvis .mv_text{
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    height: 100%;
    padding-left: 3.90625vw;
    position: relative;
    z-index: 1;
}

#keyvis .mv_text h1{
	font-size: 6vw;
	color: #fff;
	line-height: 1.4;
	letter-spacing: .03em;
	font-weight: 900;
	margin-bottom: 1.171875vw;
}

#keyvis .mv_text p {
    color: #fff;
    line-height: 2;
    font-size: 1.5vw;
    letter-spacing: .05em;
    margin-bottom: 4.6875vw;
}

#keyvis .mv_img {
    width: 42%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    height: 100%;
    padding-left: 3.90625vw;
    position: relative;
    z-index: 1;
}

/* #keyvis ul {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    padding: 10px 0;
} */

#keyvis .mv_contact_link ul {
    display: flex;
    text-align: center;
    justify-content: space-between;
}

#keyvis .mv_contact_link ul li {
    text-decoration: none;
    font-size: 20px;
    font-weight: bold;
    width: 50%;
    border-radius: 50px;
}

#keyvis .mv_contact_link ul li a {
    color: #fff;
    text-decoration: none;
    font-size: 20px;

}

#contents01{
    padding: 80px 0;
    text-align: center;
}

#contents01 .main_text h2{ 
    font-size: 2.2vw;
    font-weight: bold;
    background: linear-gradient(140.23deg,#f77a31,#f0bf1d 99.9%);
    -webkit-background-clip: text;
    color: transparent;
    line-height: 50px;
}

#contents01 .main_text p{
    font-size: 1vw;
    padding: 20px 0;
}

#contents01 .main_text p img {
    width: 100%;
}

#contents02{
    padding: 80px 0;
    background: #222;
    color: #fff;
}

#contents02 .main_tit{
    text-align: center;
}

#contents02 .main_tit p {
    font-size: 1.5vw;
    padding-bottom: 25px;
    font-weight: bold;
}

#contents02 .main_tit h3 {
    font-size: 2.5vw;
}

#contents02 .list {
    padding: 30px 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

#contents02 .list dl {
    padding: 20px 0;
}

#contents02 .list dl dt {
    border-bottom: 1px solid #fff;
}

#contents02 .list dl dd {
    padding: 10px 0;
    font-size: 1.2vw;
}

#contents02 .list dl dd span{
    background: linear-gradient(140.23deg,#f77a31,#f0bf1d 99.9%);
    -webkit-background-clip: text;
    color: transparent;
    font-weight: bold;
}

#contents03{
    padding: 80px 0;
    background: url(../img/con3_bg.png);
    background-repeat: no-repeat;
}

#contents03 .main_tit h3 {
    font-size: 2vw;
    text-align: center;
    line-height: 60px;
    font-weight: bold;
}

#contents03 .main_tit h3 span{
    font-size: 2.5vw;
    background: linear-gradient(transparent 50%, #FFEE00 50%);
}

#contents03 .box_text {
    text-align: center;
    padding: 40px 0;
}

#contents03 .box_text dl {
    padding: 25px 0;
}

#contents03 .box_text dl p {
    font-weight: bold;
    font-size: 1vw;
}

#contents03 .box_text dl p::before{
    content: url(../img/tit_icon.png);
    display: block;
}

#contents03 .box_text dl dt {
    font-size: 1.2vw;
    font-weight: bold;
    color: #345CB0;
    padding: 10px 0;
}

#contents04 {
    padding-bottom: 80px;
}

#contents04 .main_tit {
    text-align: center;
}

#contents04 .main_tit h3{
    font-size: 2.5vw;
    font-weight: bold;
    margin-bottom: 35px;
}

#contents04 .main_tit h3 span{
    background: linear-gradient(transparent 50%, #FFEE00 50%);
}

#contents04 .main_tit p {
    font-weight: bold;
    font-size: 2vw;
}

#contents04 .area_con {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-top: 40px;
}

#contents04 .area_con .area_text {
    text-align: center;
    width: 50%;
}

p.area_detail {
    border: 1px solid #626262;
    padding: 29px;
}

#contents05{
    padding: 80px 0;
    background: #222;
    color: #fff;
}

#contents05 .main_tit{
    text-align: center;
}

#contents05 .main_tit h3 {
    font-size: 2.5vw;
    font-weight: bold;
}

#contents05 .box_text {
    padding: 50px 0;
}

#contents05 .box_text dl {
    padding: 30px 90px;
}

#contents05 .box_text dl dt {
    font-size: 1.8vw;
    font-weight: bold;
    margin-bottom: 20px;
}

#contents05 .box_text dl dt span{
    background: linear-gradient(transparent 50%, #345CB0 50%);
}

#contents06{
    padding: 80px 0;
}

#contents06 h3 {
    font-size: 2.5vw;
    font-weight: bold;
    text-align: center;
}

#contents06 .box_text {
    margin-top: 70px;
}

#contents06 .q-and-a {
    margin: 30px 0;
}

#contents06 .q-and-a dt {
    cursor: pointer;
    background: #345cb0;
    color: #fff;
    padding: 20px;
  }
  
#contents06 .q-and-a dd {
    display: none;
    margin: 0;
    background: #ececec;
    padding: 40px;
  }

footer{
    background: #272727;
}

footer .footer_con {
    display: flex;
    justify-content: space-around;
    align-items: center;
}

footer .footer_con .menu {
    color: #fff;
}

footer .footer_con  .menu ul {
    display: flex;
    justify-content: space-between;
}

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

footer .footer_con .menu p {
    font-size: 0.7vw;
}

#footerFloatingMenu {
    display: block;
    width: 100%;
    position: sticky;
    left: 0px;
    bottom: 0px;
    z-index: 9999;
    text-align: center;
    padding: 0 auto;
    background: linear-gradient(140.23deg,#ff4545,#ffb11f 99.9%);
    height: 200px;
}
 
#footerFloatingMenu img {
    max-width: 99%;
    height: 23vh;
    position: relative;
    top: 15px;
}

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

#contact .contact_tit h3 {
    font-size: 7.5vw;
    }

#contact .contact_tit p {
    font-size: 4.5vw;
}

#contact .contact_link ul{
    display: block;
}

#contact .contact_link ul li{
    margin-bottom: 20px;
}

#contact .contact_link ul li a img {
    width: 100%;
}

header .header_con {
        display: none;
    }

header h1.logo img {
        width: 100%;
    }

header p img {
        width: 90%;
    }

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

#keyvis {
    height: 100vh;
    display: block;
}

#keyvis::after {
    width: 0%;
}

#keyvis .mv_text {
    height: 75%;
    text-align: center;
    width: 90%;
    margin: 0 auto;
    padding-left: 0px;
    top: 65px;
}

#keyvis .mv_text h1{
    font-size: 10vw;
}

#keyvis .mv_text p {
    font-size: 4vw;
}

#keyvis .mv_img {
    /* height: 0%; */
    padding-left: 0px;
    display: block;
    width: 100%;
}

#keyvis .mv_img img {
    width: 100%;
}

#keyvis .mv_contact_link ul{
    display: block;
}

#keyvis .mv_contact_link ul li{
    width: 100%;
    margin-bottom: 15px;
}

#contents01 .main_text h2 {
    font-size: 6vw;
}

#contents01 .main_text p {
    font-size: 4vw;
}

#contents02 .main_tit p {
    font-size: 5.5vw;
}

#contents02 .main_tit h3 {
    font-size: 7.5vw;
}

#contents02 .list{
    display: block;
}

#contents02 .list dl p img {
    width: 100%;
}

#contents02 .list dl dt {
    font-size: 5vw;
    padding: 15px 0;
}

#contents02 .list dl dd {
    padding: 15px 0;
    font-size: 6.2vw;
}

#contents03 .main_tit h3 {
    font-size: 7.5vw;
}

#contents03 .main_tit h3 span {
    font-size: 9.5vw;
}
   
#contents03 .box_text dl p {
    font-size: 4vw;
}

#contents03 .box_text dl dt {
    font-size: 4vw;
}

#contents04 .main_tit h3 {
    font-size: 6vw;
}

#contents04 .main_tit p {
    font-size: 4vw;
}

#contents04 .area_con {
    display: block;
    text-align: center;
}

#contents04 .area_con .area_text {
    text-align: center;
    width: 100%;
}

#contents05 .main_tit h3 {
    font-size: 6vw;
}

#contents05 .box_text dl {
    padding: 30px 0px;
}

#contents05 .box_text dl dt {
    font-size: 5vw;
}

#contents06 .main_tit h3 {
    font-size: 6vw;
}

footer .footer_con {
    display: block;
    text-align: center;
}

footer .footer_con .menu ul {
    display: block;
}

footer .footer_con .menu p {
    font-size: 1vw;
}

#footerFloatingMenu {
    height: 15vh;
}

#footerFloatingMenu img {
    height: 13vh;
    position: relative;
    top: 20px;
}
}