@charset "UTF-8";

#header_wrap{
	top:0px;
}

#kv{
	margin: 0 auto 40px;
	padding: 0 0 0 0;
	position:relative;
	height: 100vh;
	min-width: auto;
}

#kv_inner{
	margin: 0 0px ;
	padding: 0 0 0 0;
	height: 100vh;
	min-width: auto;
	position:relative;

}

h2.h2_kv{
	position: absolute;
	margin: auto;
	top:120px;
	left: 0;
	right:0;
	z-index:10;
	text-align:center;
}

h2.h2_kv img{
	width:210px;
	height:auto;
	vertical-align:top;
}

h2.kv_txt{
	margin: 0 auto 0;
	padding: 0 0 50px 0;
	position:relative;
font-weight: 500;
font-size: 20px;
line-height: 34px;
text-align: center;
color: #383837;
}



.flex_kv{
	margin: 0 0 0 0 !important;
	padding: 0 0;
	background:transparent !important;
}

.flex_kv ul.slides{
	margin: 0 0 0 0;
	padding: 0 0;
	height: 100vh;
}

.flex_kv ul.slides li{
	margin: 0 0 0 0;
	padding: 0 0;
	text-align:center;
	height: 100vh;
}

.flex_kv ul.slides li.slide1{
background:  url(../../images/crie/sp_kv_slide1.jpg) no-repeat left bottom;
background-size:cover;
}

.flex_kv ul.slides li.slide2{
background:  url(../../images/crie/sp_kv_slide2.jpg) no-repeat center bottom;
background-size:cover;
}

.flex_kv ul.slides li.slide3{
background:  url(../../images/crie/sp_kv_slide3.jpg) no-repeat center bottom;
background-size:cover;
}



#document{
	width: 100%;
	margin: 0 auto;
	padding: 0 0 0;
	position: relative;
	text-align:center;
	overflow: hidden;
}


.point_area{
	margin: 0 auto;
	padding: 0 0 10px 0;
	position:relative;
}

h2.h2_point{
	margin: 0 auto 20px;
	padding: 0 0 0;
	position: relative;
font-weight: 500;
font-size: 20px;
letter-spacing: 0.05em;
line-height: 34px;
text-align: center;
color: #383837;
}

ul.point_list{
	margin: 0 0;
	padding: 0 0 0;
	position: relative;
	text-align:center;
}

ul.point_list li{
	margin: 0 auto 50px;
	padding: 0;
	position: relative;
	width:335px;
}

ul.point_list li h3{
	margin: 0 auto 10px;
	padding: 0 0 0;
font-family: Roboto;
font-weight: 300;
font-size: 26px;
letter-spacing: 0.03em;
line-height: 34px;
text-align: center;
color: #383837;
}
ul.point_list li h4{
	margin: 10px auto 10px;
	padding: 0 0 0;
font-weight: normal;
font-size: 18px;
letter-spacing: 0.03em;
line-height: 48px;
text-align: center;
color: #156153;
}
ul.point_list li p{
font-weight: normal;
font-family: "Noto Sans JP";
font-weight: normal;
font-size: 14px;
line-height: 26px;
text-align:justify;
color: rgba(56, 56, 55, 0.85);
}


.point_box{
	margin: 0px auto 50px;
	padding: 0px 0;
	position: relative;
	text-align: center;
	background-color:#fff;
}

.point_box h3{
	margin: 0 15px 20px;
	padding: 15px 0;
	position: relative;

font-weight: 500;
font-size: 19px;
line-height: 32px;
text-align: center;
color: #383837;
background-color:#f4f4f4;
}

.point_box p{
	margin: 0 35px 0;
	padding: 0 0;
	position: relative;

font-weight: normal;
font-size: 14px;
line-height: 26px;
text-align:justify;
color: rgba(56, 56, 55, 0.85);

}



.area_inner{
	width: auto;
	margin: 0 auto;
	padding: 0 0;
	position:relative;
}

h2.h2_style{
	margin: 0 auto 30px;
	padding: 0 0 0 0;
	position: relative;
font-family: "Noto Sans JP";
font-weight: bold;
font-size: 15px;
letter-spacing: 0.05em;
line-height: 1.5;
text-align:justify;
color: #585858;
}
h2.h2_style.sp_center{
	text-align: center;
}
h2.h2_style.sp{
	padding-left:20px;
}
h2.h2_style strong{
	margin: 0 0 0 0;
	padding: 0 0 0 20px;
	position: relative;
display:inline-block;
vertical-align:middle;
font-family: Poppins;
font-weight: 500;
font-size: 18px;
letter-spacing: 0.1em;
line-height: 1.5;
text-align:justify;
color: #585858;
border-right:0px solid #585858;
}

h2.h2_style span{
	margin: 0 0 0;
	padding: 0 0 0;
	position: relative;
	display:block;

font-family: "Noto Sans JP";
font-weight: 500;
font-size: 17px;
line-height: 30px;
text-align: center;
color: #585858;

}

h2.h2_style small{
	margin: 0 15px 15px;
	padding: 0 0 0;
	position: relative;

	display:inline-block;
	vertical-align:middle;
font-weight: normal;
font-size: 42px;
letter-spacing: normal;
line-height: 1.5;
color: #999;
}

.h2_lead{
	margin: 0 auto 25px;
	padding: 0 0 0;
	position: relative;

font-weight: 500;
font-size: 20px;
line-height: 34px;
text-align: center;
color: #585858;

}

.price_area{
	margin: 0 auto;
	padding: 0 0 50px;
	position:relative;
	text-align:center;
	background-color:rgba(255,255,255,0.9);
}

.price_area .h2_lead{
	margin: 0 15px 25px;
	padding: 15px 0;
	position: relative;

font-weight: 500;
font-size: 19px;
line-height: 32px;
text-align: center;
color: #585858;
background-color:#f4f4f4;

}

ul.price_list{
	margin: 0 auto 0;
	padding: 0 0;
	position:relative;
	text-align:center;
	display: flex;
align-items:stretch;
justify-content:center;
flex-wrap:wrap;
width:300px;
}

ul.price_list li{
	margin: 0 15px 20px;
	padding: 0 0;
	position:relative;
	text-align:center;
	width:40%;
}

.price_box{
	margin: 0 auto 10px;
	padding: 0 0 0;
	position:relative;
	text-align:center;
}

.price_box img{
	width:85%;
	height:auto;
}

.price_box .tsubo_txt{
	margin: 0px 0 0 0;
	padding: 0 0 0;
	position:absolute;
	bottom:5px;
	left:5px;

	display:block;
	letter-spacing:normal;
	box-sizing: border-box;
	
font-family: Lato;
font-weight: bold;
font-size: 24px;
text-align:justify;
color: #585858;

}

.price_box .tsubo_txt small{

font-weight: 700;
font-size: 12px;
letter-spacing: 0.05em;
line-height: 24px;
color: #585858;
}

.price_txt{
	margin: 0px 0 ;
	padding: 0px 0 0;
	position:relative;
	text-align:justify;
	
	text-align:center;
	display:block;
	vertical-align:middle;
	letter-spacing:normal;

	box-sizing: border-box;
	line-height: 1.2;
}

.price_txt strong{
font-family: Lato;
font-weight: bold;
font-size: 28px;
color: #585858;

	display:inline-block;
	vertical-align:center;
}

.price_txt small{
margin-left:5px;
font-weight: bold;
font-size: 7px;
letter-spacing: 0.05em;
text-align:justify;
color: #585858;
display:inline-block;

}

.price_txt small b{
font-family: "Noto Sans JP";
font-weight: bold;
font-size: 13px;
letter-spacing: 0.05em;
text-align:justify;
color: #585858;

}


.tsubo_block{
	margin: 0 20px 20px;
	padding: 0 0;
	position:relative;
	text-align:center;
column-count: 2;
column-gap: 5px;
}

ul.tsubo_list{
	margin: 0 0;
	padding: 0 0;
	position:relative;
	text-align:center;

}

ul.tsubo_list li{
	margin: 0 0 0 0;
	padding: 5px 0;
	position:relative;
	text-align:center;

font-weight: normal;
font-size: 11px;
line-height: 17px;

}

ul.tsubo_list li span{
padding-right:5px;
border-right:1px solid #777;
}

ul.tsubo_list li strong{
	padding-right:5px;
	padding-left:10px;
	font-weight: 500;
	font-size: 16px;
	font-family: Lato;
	line-height: 18px;
	text-align:justify;
}

.tsubo_block ul:nth-child(1) li:nth-child(odd),
.tsubo_block ul:nth-child(3) li:nth-child(odd) {
	background-color:rgba(88,88,88,0.75);
	color:#fff;
}

.tsubo_block ul:nth-child(2) li:nth-child(even),
.tsubo_block ul:nth-child(4) li:nth-child(even) {
	background-color:rgba(88,88,88,0.75);
	color:#fff;
}

ul.cost_list{
	margin: 0 auto;
	padding: 0 0;
	position:relative;
	text-align:center;
}

ul.cost_list li{
	margin: 0 10px 0;
	padding: 0 0 0 1em;
	position:relative;
	text-align:justify;

font-weight: 400;
font-size: 11px;
line-height: 19px;
text-align:justify;
}

ul.cost_list_left{
	margin: 0 20px;
	padding: 0 0;
	position:relative;
	text-align:justify;
}

ul.cost_list_left li{
	margin: 0 0 0 1em;
	padding: 0 0;
	position:relative;
	text-align:justify;
	text-indent:-1em;
}

.price_area h3{
	margin: 30px 0 20px;
	padding: 0px 15px;
	position: relative;

font-weight: normal;
font-size: 15px;
letter-spacing: 0.02em;
line-height: 32px;
text-align: center;

border-bottom:1px solid #999;
display:inline-block;
}





.facility_area{
	margin: 0 auto 50px;
	padding: 50px 0 50px 0;
	position:relative;
	background-color: rgba(0,0,0,0.05);
}

.facility_txt{
	margin: 0 30px 30px;
	padding: 0 0;
	position:relative;
	text-align:center;
	font-family: "Noto Sans JP";
	font-weight: normal;
	font-size: 14px;
	line-height: 26px;
	text-align:justify;
	color: rgba(56, 56, 55, 0.85);
}
.facility_bottom_txt{
    margin: 0 20px;
	position:relative;
}
.facility_bottom_txt p{
	font-weight: normal;
	font-size: 12px;
	line-height: 1.6;
	text-align: left;
	color: rgba(56, 56, 55, 0.85);
}
ul.facility_list_p{
	margin: 0 10px 20px;
	padding: 0 0;
	position:relative;
	text-align:center;
	display: flex;
align-items:stretch;
justify-content:space-around;
flex-wrap:wrap;
width:auto;
}

ul.facility_list_p li{
	margin: 0 0 20px;
	padding: 0 0;
	position:relative;
	text-align:center;

font-weight: normal;
font-size: 12px;
line-height: 21px;
text-align: center;
width:45%;
}

ul.facility_list_p li img{
width:100%;
height:auto;
margin-bottom:8px;
}


.facility_area h3.h3_sp{
	margin: 0 20px 0;
	padding: 10px 0;
	position:relative;
font-weight: 500;
font-size: 18px;
letter-spacing: 0.04em;
line-height: 26px;
text-align: center;
color: #585858;
background-color:#e1e1e1;
}

.facility_block{display:none;}

.ac_icon_box {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 50%;
  right: 4%;
  width: 25px;
  height: 25px;
  transform: translateY(-50%);
  transform-origin: center center;
  transition-duration: 0.2s;
}
.ac_icon {
  display: block;
  width: 100%;
  height: 100%;
  transform-origin: center center;
  transition-duration: 0.2s;
  position: relative;
}
.ac_icon::before, .ac_icon::after {
  display: flex;
  content: '';
  background-color: #999;
  border-radius: 10px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transform-origin: center center;
}
.ac_icon::before {
  width: 100%;
  height: 2px;
}
.ac_icon::after {
  width: 2px;
  height: 100%;
}

.facility_area h3.open .ac_icon_box {
  transform: translateY(-50%) rotate(-180deg);
}
.facility_area h3.open .ac_icon::after {
  content: none;
}
.facility_area h3.open + .ac_content {
  display: block;
}

ul.facility_list_txt{
	margin: 0 auto 0;
	padding: 30px 0 0;
	position:relative;
	text-align:center;
	display: flex;
align-items:stretch;
justify-content:center;
flex-wrap:wrap;

}

ul.facility_list_txt li{
	margin: 0 0 30px;
	padding: 0 0;
	position:relative;
font-weight: normal;
font-size: 12px;
line-height: 18px;
text-align: center;
color: rgba(56, 56, 55, 0.85);

width:30%;
}

ul.facility_list_txt li img{
margin-bottom:10px;
width:60%;
height:auto;
}


ul.facility_list_txt li small{
font-size: 12px;
display:block;
margin-top:10px;
}
































.btn_style{
	margin: 0 auto;
	padding: 0 0 0 0;
	position:relative;
	text-align:center;
}

.btn_style a{
	margin: 0 auto;
	padding: 8px 15px;
	position:relative;
	text-align:center;
	font-family: Poppins, sans-serif;
	font-weight: bold;
	font-size: 10px;
	letter-spacing: 0.05em;
	text-align:justify;
	color: #383837;
width: 140px;
border: 1px solid #383837;
display:inline-block;
transition-duration: .2s;
box-sizing: border-box;
background: url(../../images/top/btn_arr.svg) no-repeat right 10px top 50%;
background-color: #fff;
}

.link_more{
	margin: 0 auto ;
	padding: 0px 0 ;
	position:relative;
	text-align:center;
}
.link_more a{
	margin: 0 auto 0;
	padding: 0px 0px;
	position:relative;
	display:inline-block;
transition-duration: .2s;
font-family: Poppins, sans-serif;
font-weight: bold;
font-size: 10px;
letter-spacing: 0;
line-height: 10px;
text-align: center;
color: #156153;

}
.link_more a span{
	display:inline-block;
	vertical-align:middle;
	transition-duration: .2s;
}
.link_more a img{
	margin-left:3px;
	display:inline-block;
	vertical-align:middle;
	transition-duration: .2s;
	width:35px;
}

.standard_area{
	min-width: auto;
	margin: 0 auto 100px;
	padding: 0 0 0;
	position:relative;
	text-align:center;
}

.standard_area h5{
	margin: 0 0 30px;
	padding: 0 0;
	position:relative;
	text-align:center;
font-family: "Noto Sans JP";
font-weight: 500;
font-size: 20px;
line-height: 34px;
text-align: center;
color: #585858;

}

ul.standard_list{
	margin: 0 0px 0;
	padding: 15px 0;
	position:relative;
	text-align:center;
	display: flex;
align-items:center;
justify-content:center;
flex-wrap:wrap;
background-color:#797979;
}

ul.standard_list li{
	margin: 10px 0 10px 0;
	padding: 0 0;
	position:relative;
	text-align:center;
	width:45%;
}

ul.standard_list li img{
	width:100%;
	height:auto;
}


.btn_style.standard_btn{
	margin: 0 auto;
	padding: 0 0;
	position:relative;
	text-align:center;
}






.works_area{
	min-width: auto;
	margin: 0 20px 100px;
	padding: 0 0;
	position:relative;
	text-align:center;
}

.works_area h2.h2_style span{
	padding: 30px 0 0 0;
}

.btn_style.works_btn{
	position:absolute;
	top:0px;
	right:0px;
}



ul.works_list{
	margin: 0 -20px 0;
	padding: 0 0;
	position:relative;
	text-align:center;
}

ul.works_list li{
	margin: 0 0 20px;
	padding: 0 0px;
	position:relative;
	text-align:justify;

display: flex;
align-items:stretch;
justify-content:center;
}
ul.works_list li a{
	position:absolute;
	width:100%;
	height:100%;
	display:block;
	top:0;
	left:0;
	z-index:10;
}

ul.works_list li .works_img_wrap{
	margin: 0 0;
	padding: 0 0px;
	position:relative;
	text-align:justify;
	width:65%;
}


ul.works_list li .works_img{
	margin: 0 0;
	padding: 0 0px;
	position:relative;
	text-align:center;
	width:100%;
display: flex;
align-items:stretch;
justify-content:space-between;
flex-wrap:wrap;
}
ul.works_list li .works_img span{
	display:block;
	width:100%;
	aspect-ratio: 100 / 72.5;
	overflow: hidden;
	margin-bottom:2%;
}
ul.works_list li .works_img img{
	width:49%;
	height:auto;
	vertical-align:top;
}

ul.works_list li .works_img img:nth-child(1){
	width:100%;
	height:100%;
	object-fit:cover;
	vertical-align:top;
	transition-duration: .4s;
}
ul.works_list li .works_txt{
	margin: 0 auto;
	padding: 10px 0 0px 0;
	position:relative;
	width:35%;
}

ul.works_list li .works_txt span{
position: absolute;
top: 5%;
left: 50%;
padding-bottom:1em;
transform: translate(-50%, 0);
font-weight: 500;
font-size:14px;
letter-spacing: 0.05em;
line-height: 2.0;
text-align:justify;
color: #585858;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright; /* 英数字も縦に表示 */
}



ul.works_list li .works_more{
position: absolute;
bottom: 0px;
right:10%;
	display:none !important;
}

.works_more{
	margin: 0 auto ;
	padding: 0px 0 ;
	position:relative;
	text-align:center;
}
.works_more a{
	margin: 0 auto 0;
	padding: 10px 0px;
	position:relative;
	display:inline-block;

transition-duration: .2s;
font-family: Poppins, sans-serif;
font-weight: bold;
font-size:clamp(10px, 0.7vw, 11px);
letter-spacing: 0.05em;
line-height: 1.5;
text-align:justify;
color: #545454;
}
.works_more a span{
	display:inline-block;
	vertical-align:middle;
	transition-duration: .2s;
}
.works_more a img{
	margin-left:5px;
	display:inline-block;
	vertical-align:middle;
	transition-duration: .2s;
}



/*　アニメーションSP
====================================================*/

/*　共通　※wow.jsでタイミング指定　*/

@keyframes fadeIn01 {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}
.fadein01 {
    animation-name: fadeIn01;
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
}

@keyframes fadeInUp02 {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
.fadein_up02 {
    animation-name: fadeInUp02;
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
}

@keyframes fadeInRight02 {
    from {
        opacity: 0;
        transform: translateX(10px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}
.fadein_right02 {
    animation-name: fadeInRight02;
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
}





/*　個別　*/
@keyframes fadeInUp01 {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
.h2_kv01 {
    animation-name: fadeInUp01;
    animation-duration: 0.4s; /* アニメーションの所要時間 */
    animation-delay: 0.4s; /* アニメーション開始までの遅延時間 */
    animation-fill-mode: backwards; /* 遅延時間中の要素のスタイルをどう扱うか */
    animation-timing-function: ease-out; /* タイミング関数をease-outに設定 */
}
.h2_kv02 {
    animation-name: fadeInUp01;
    animation-duration: 0.4s;
    animation-delay: 0.9s;
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
}

@keyframes fadeInRight01 {
    from {
        opacity: 0;
        transform: translateX(6px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}
.h3_kv {
    animation-name: fadeInUp01;
    animation-duration: 0.4s;
    animation-delay: 1.5s;
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
}

h3.tit{
	margin: 0 0 30px;
	padding: 0 0;
	position:relative;
	text-align:center;
	font-family: "Noto Sans JP";
	font-weight: 500;
	font-size: 20px;
	line-height: 34px;
	text-align: center;
	color: #585858;
}
ul.standard_list.v2{
	margin-bottom: 60px;
}