@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Sans:ital,wght@0,100..900;1,100..900&display=swap');

*:focus {
  outline: none;
}
body{
	margin: 0;
	padding: 0;
}
.Inter{
    font-family: "Inter", serif;
}
.BeVietnam{
    font-family: "Be Vietnam Pro", sans-serif;
}


#lp_wrap {
    width: 100%;
    margin: 0 auto;
	position: relative;
	text-align: center;
    display: block;
    padding: 0%;
    font-weight:400;
    letter-spacing: 1px;
	overflow: hidden;
	font-family: 'Noto Sans JP', sans-serif;
    -webkit-animation: fadein 1s forwards ease;
    animation: fadein 1s forwards ease;
}
@keyframes fadein {
		  0% {
			  opacity: 0;
		  }
		  100% {
			  opacity: 1;
			  transform: translate(0);
		  }
}
#lp_wrap img{
    width: 100%;
    vertical-align: bottom;
    line-height: 0;
    border: none;
}
#lp_wrap ul{
	padding: 0;
	overflow: hidden;
    margin: 0 auto;
}
#lp_wrap li{
	list-style: none;
}
#lp_wrap a{
    text-decoration: none;
}
#lp_wrap a:link{
    opacity: 1;
}
#lp_wrap a:hover{
    text-decoration: none;
}

#main_visual {
	position: relative;
	width: 100%;
	background: #9aa3aa;
	display: block;
}
#main_visual .visual {
	position: relative;
	width: 100%;
	padding-bottom: 30%;
	margin-left: 0%;
	display: inline-block;
}
#main_visual .visual li {
	position: relative;
	width: 20%;
	opacity: 0;
	transition: 1.5s all 0s ease;
    z-index: 4;
}
#main_visual .visual li:nth-of-type(2) {
	position: absolute;
	width: 28%;
    bottom: 0;
	left: 14%;
	transition: 1.5s all 0.3s ease;
    z-index: 6;
}
#main_visual .visual li:nth-of-type(3) {
	position: absolute;
	width: 30%;
    top: 0%;
	left: 34%;
    transition: 1.5s all 0.7s ease;
    z-index: 7;
}
#main_visual .visual li:nth-of-type(4) {
	position: absolute;
	width: 28%;
    bottom: 0;
    right: 14%;
	transition: 1.5s all 1.1s ease;
    z-index: 8;
}
#main_visual .visual li:nth-of-type(5) {
	position: absolute;
	width: 20%;
    top: 0;
    right: 0%;
	transition: 1.5s all 1.5s ease;
    z-index: 9;
}

#main_visual.ac .visual li {
	opacity: 1;
}
#lp_wrap .lp_box{
    width: 100%;
    position: relative;
    margin: 5% auto;
    display: inline-block;
}
#lp_wrap .lp_box .title{
	font-size: 40px;
    text-align: center;
    margin: 0 auto;
    position: relative;
	font-family: "Be Vietnam Pro", sans-serif;
	font-weight: 700;
	line-height: 1em;
}
#lp_wrap .lp_box .title_s{
	font-size: 20px;
	text-align: center;
	margin: 2.5% auto;
	position: relative;
	line-height: 1em;
	font-weight: 500;
}
#lp_wrap .lp_box .lead{
    font-size: 14px;
    text-align: center;
    line-height: 2em;
    margin: 5% auto 0;
    position: relative;
    
}

/**************************************************
ボタン
**************************************************/
.button01 a {
    background: #585858;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 8% auto 0;
    width: 80%;
    padding: 3% 4%;
    color: #FFFFFF;
    transition: 0.3s ease-in-out;
    font-size: 13px;
}
.button01 a:hover {
    background: #000000;
}
.button01 a:before, .button020 a:after {
  content: "";
  position: absolute;
  display: block;
  transition: all 0.3s;
  right: 0.6rem;
  top: 50%;
}
.button01 a:before {
  width: 1.4rem;
  height: 2px;
  background: #FFFFFF;
  transform: translateY(-50%);
}
.button01 a:after {
  opacity: 0;
  width: 0;
  height: 0;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}
.button01 a:hover:before {
  width: 1.5rem;
}
.button01 a:hover:after {
  opacity: 1;
  width: 8px;
  height: 8px;
}
.button02 a {
    border: #585858 2px solid;
    background: #FFFFFF;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 0% auto 0;
    width: 50%;
    padding: 2%;
    color: #585858;
    transition: 0.3s ease-in-out;
    font-size: 14px;
    border-radius: 5px;
}
.button02 a:hover {
    background: #585858;
    color: #FFFFFF;
}

.button_box{
    width: 80%;
    display: flex;
    justify-content:center;
    margin: 0 auto 0;
}
.button_box a{
	display: inline-block;
    width: 100%;
	text-align: center;
	vertical-align: middle;
	text-decoration: none;
	padding: 1% 0%;
	font-weight: normal;
    font-size: 14px;
	border: 2px solid #585858;
	color: #585858;
	transition: 0.5s;
    border-radius: 5px;
    margin: 0 10px;
    line-height: 1.5em;
}
.button_box a:hover {
	color: #fff;
	background: #585858;
}

.clear {
	clear: both;
}

.br_pc {
	display: block;
}

.br_sp {
	display: none;
}

.pc {
	display: block;
}
.sp {
	display: none;
}
.small{
    font-size: 85%;
}
.hr{
    width: 90%;
    text-align: center;
    border-bottom: #502c1d 1px solid;
    margin: 0 auto;
    display: block;
}


@media only screen and (max-width:768px){
	#lp_wrap {
		width: 100%;
	}
    #main_visual .visual{
        padding-bottom: 105%;
    }
    #main_visual .visual li{
        width: 35%;
    }
    #main_visual .visual li:nth-of-type(2){
        width: 45%;
        bottom: 32%;
		left: 10%;
    }
    #main_visual .visual li:nth-of-type(3){
        width: 50%;
        top: 5%;
        left: 45%;
    }
    #main_visual .visual li:nth-of-type(4){
        width: 45%;
        right: -5%;
		z-index: 3;
		bottom: 5%;
    }
    #main_visual .visual li:nth-of-type(5){
        width: 35%;
        top: inherit;
        right: 65%;
        bottom: 0;
    }
    #lp_wrap .lp_box{
        margin: 13% auto;
    }
    #lp_wrap .lp_box .title{
        font-size: 30px;
    }
	#lp_wrap .lp_box .title_s{
		font-size: 15px;
		margin: 2.5% auto 0;
	}
    
    #lp_wrap .lp_box .lead{
        font-size: 13px;
        margin: 10% auto 0;
		letter-spacing: .5px;
    }
    .button02 a{
        width: 96%;
        border-radius: 3px;
        font-size: 12px;
        padding: 3% 0;
        margin: 10% auto;
    }
    .button_box{
        width: 98%;
        margin: 7% auto;
    }
    .button_box a{
        font-size: 12px;
        margin: 0 5px;
        letter-spacing: 0px;
        padding: 3% 0;
    }
	
	.br_pc{
		display: none;
	}

	.br_sp{
		display: flex;
	}
	
	.pc {
		display: none;
	}
	
	.sp {
		display: block;
	}

	
}

.anim {
	opacity: 0;
	transition: 1.5s all 0s ease;
}
.anim.ac {
	opacity: 1;
}