@charset="UTF-8";

@font-face {
	font-family: 'MyFont';
	src: local('myfont Regular'), /* フォントがローカルにインストールされている場合に有効 */
	     url('fonts/almaqrefined.woff') format('woff'), /* woff - Modern Browsers */
	     url('fonts/almaqrefined.ttf')  format('truetype'); /* ttf - Safari, Android, iOS */
}



.ratio-1_1:before {content: "";display: block;padding-top: 100%; /* 1:1 */} 
.ratio-2_1:before {content: "";display: block;padding-top: 50%; /* 2:1 */} 
.ratio-3_1:before {content: "";display: block;padding-top: 30%; /* 3:1 */} 
.ratio-1_2:before {content: "";display: block;padding-top: 200%; /* 1:2 */} 
.ratio-4_3:before {content: "";display: block;padding-top: 75%; /* 4:3 */} 
.ratio-16_9:before {content: "";display: block;padding-top: 56.25%; /* 16:9 */} 
.ratio-8_5:before {content: "";display: block;padding-top: 62.5%; /* 8:5 ≒ 黄金比 */} 
.ratio-7_5:before {content: "";display: block;padding-top: 70%; /* 7:5 ≒ 白銀比 */} 


* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	font-family: 'Noto Sans JP', sans-serif;
}
img {
	width: 100%;
	height: auto;
	vertical-align: middle;
}

header {
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1000;
}
header h1 {
	width: 250px;
}
header .info_logo {
	width: 150px;
	position: absolute;
	top: 30px;
	right: 50px;
}

@media screen and (max-width: 600px) {
	header h1 {
		width: 50%;
	}
	header .info_logo {
		width: 25%;
		position: absolute;
		top: 20px;
		right: 20px;
	}
}


.btn_01 {
	width: 150px;
	text-align: center;
	padding: 13px 0 15px;
	display: block;
	background-color: #000;
	border-radius: 0 15px 0 0;
	color: #fff;
	font-size: 1.5em;
	font-weight: 900;
	text-decoration: none;
	margin: 30px auto 0;
	border: 1px solid #000;
	transition:ALL .3s ease;
	-webkit-transition:ALL .3s ease;
	-moz-transition:ALL .3s ease;
	-o-transition:ALL .3s ease;
}
.col .btn_01 {
	width: 90px;
	text-align: center;
	padding: 8px 0 7.5px;
	display: block;
	background-color: #000;
	border-radius: 0 15px 0 0;
	color: #fff;
	font-size: 1.2em;
	font-weight: 900;
	text-decoration: none;
	margin: 30px auto 0 0;
	border: 1px solid #000;
	transition:ALL .3s ease;
	-webkit-transition:ALL .3s ease;
	-moz-transition:ALL .3s ease;
	-o-transition:ALL .3s ease;
}

.btn_02 {
	width: 150px;
	text-align: center;
	padding: 0px 20px 4px;
	background-color: #000;
	border-radius: 0 15px 0 0;
	color: #fff;
	font-size: 1.1em;
	font-weight: 900;
	text-decoration: none;
	margin-left: 30px;
	position: relative;
	bottom: 9px;
	border: 1px solid #000;
	transition:ALL .3s ease;
	-webkit-transition:ALL .3s ease;
	-moz-transition:ALL .3s ease;
	-o-transition:ALL .3s ease;
}
.btn_03 {
	width: 175px;
	text-align: center;
	padding: 13px 0 15px;
	display: block;
	background-color: #000;
	border-radius: 0 15px 0 0;
	color: #fff;
	font-size: 1.3em;
	font-weight: 900;
	text-decoration: none;
	margin: 30px auto 0;
	border: 1px solid #000;
	transition:ALL .3s ease;
	-webkit-transition:ALL .3s ease;
	-moz-transition:ALL .3s ease;
	-o-transition:ALL .3s ease;
}
.btn_01:hover,.btn_02:hover,.btn_03:hover {
	background-color: #fff;
	color: #000;
}
@media screen and (max-width: 600px) {
	.btn_01 {
		width: 140px;
		padding: 11px 0 13px;
		font-size: 1.1em;
	}
	.col .btn_01 {
		font-size: 1em;
	}
	.btn_02 {
		font-size: 0.6em;
		padding: 3px 20px 4px;
		margin-left: 20px;
	}
}


.fv {
	position: relative;
}
.fv .imgbox {
	width: 100%;
	height: 100vh;
    min-height: 100vh;
}
.fv .imgbox img {
	width: 100%;
	height: 100%;
 	object-fit: cover;
 	object-position: center;
 	font-family: 'object-fit: cover; object-position: center;';
}
.fv .tatesen {
	display: block;
	width: 2px;
	height: 150px;
	background-color: #000;
	position: absolute;
	bottom: -75px;
	left: 0;
	right: 0;
	margin: auto;
}

.contents {
	font-size: 17px;
	font-family: 'Noto Sans JP', sans-serif;
}
.contents .wrap {
	width: 600px;
	margin: 0 auto;
}

@media screen and (max-width: 600px) {
	.contents {
		font-size: 3vw;
		width: 100%;
	}
	.contents .wrap {
		width: 100%;
		margin: 0 auto;
	}
}

.contents p {
	line-height: 1.7;
}

.contents .read {
	margin-top: 120px;
	padding: 0;
}
.contents .read .wrap {
	width: 800px;
}
.contents .read h2 {
	text-align: center;
	font-size: 1.5em;
	letter-spacing: .1em;
	font-weight: 600;
}
.contents .read p {
	margin-top: 40px;
	text-align: center;
	font-size: 1.2em;
}
@media screen and (max-width: 800px) {
	.contents .read .wrap {
		width: 100%;
	}
}

.contents .style_block {
	margin-top: 85px;
}
.contents .style_block h2 {
	width: 80%;
	margin: 0 auto;
	padding-bottom: 30px;
	text-align: center;
	font-size: 2em;
	font-weight: 700;
	font-family: 'MyFont';
	border-bottom: 1.5px solid #000;
}
.contents .style_block h2 span {
	font-size: 2em;
	letter-spacing: .03em;

}
.contents .style_block .style_main {
	width: 80%;
	margin: 30px auto 0;
}
.contents .style_block .style_main h3 {
	margin-top: 50px;
	font-size: 1.3em;
	text-align: center;
}
.contents .style_block .style_main .desc {
	margin-top: 35px;
	padding: 0 10%;
}
.contents .style_block .style_main .price {
	font-size: 1.4em;
	margin-top: 60px;
	font-weight: 900;
	text-align: center;
}
.contents .style_block .style_main .price + .price {
	margin-top: 40px;
}

.contents .style_block.style_b .style_main .price {
	font-size: 1.3em;
	text-align: right;
}
@media screen and (max-width: 600px) {
	.contents .style_block.style_b .style_main .price {
		font-size: 1.3em;
	}
	.contents .style_block .style_main .price {
		margin-top: 60px;
	}
	.contents .style_block .style_main .price + .price {
		margin-top: 20px;
	}
}
@media screen and (max-width: 520px) {
	.contents .style_block.style_b .style_main .price {
		font-size: 1.2em;
	}
}


.contents .style_block .col {
	display: flex;
	align-items: center;
}
.contents .style_block .col:nth-of-type(3) {
	flex-direction: row-reverse;
}
.contents .style_block .col_item:nth-of-type(1) {
	width: 55%;
}
.contents .style_block .col_item:nth-of-type(2) {
	width: 45%;
	padding: 0 2.5%;
	position: relative;
}
.contents .style_block .col {
	margin-top: 90px;
}
.contents .style_block .col + .col {
	margin-top: 60px;
}
.contents .style_block .col_item .desc {
	font-size: .8em;
	padding-top: 25px;
	position: relative;
}
.contents .style_block .col_item .desc::before {
	content: "";
	width: 17.5px;
	height: 17.5px;
	background-color: #000;
	position: absolute;
	bottom: 100%;
	left: calc(100% - 17.5px);
	transition:ALL .6s ease;
	-webkit-transition:ALL .6s ease;
	-moz-transition:ALL .6s ease;
	-o-transition:ALL .6s ease;
}
.contents .style_block .col_item .desc::after {
	content: "";
	width: 0;
	height: 1.5px;
	background-color: #000;
	position: absolute;
	bottom: 100%;
	right: 0;
	transition:ALL .6s ease;
	-webkit-transition:ALL .6s ease;
	-moz-transition:ALL .6s ease;
	-o-transition:ALL .6s ease;
}
.contents .style_block .col_item .desc.started::before {
	left: 0;
}
.contents .style_block .col_item .desc.started::after {
	width: 100%;
}

.contents .style_block .col_item h3 {
	font-size: 1.1em;
	margin-top: 50px;
}
.contents .style_block .col_item .price {
	font-size: 1.1em;
	font-weight: 700;
	margin-top: 10px;
}
.contents .style_06 .col_item:nth-of-type(2) .desc {
	margin-bottom: 50px;
}
.contents .style_06 .col_item:nth-of-type(2) h3 {
	display: inline;
	margin-right: 15px;
}
.contents .style_06 .col_item:nth-of-type(2) .price {
	display: inline;
}
.contents .style_06 .col_item a {
	margin-top: 5px;
}
.contents .style_06 .col_item a:nth-of-type(1) {
	margin-bottom: 15px;
}
@media screen and (max-width: 600px) {
	.contents .style_block .col_item h3 {
		margin-top: 20px;
	}
	.contents .style_06 .col_item:nth-of-type(2) .desc {
		margin-bottom: 20px;
	}
	.contents .style_06 .col_item:nth-of-type(2) h3 {
		margin-right: 5px;
	}
	.contents .style_06 .col_item a {
		margin-top: 5px;
	}
	.contents .style_06 .col_item a:nth-of-type(1) {
		margin-bottom: 15px;
	}
}



.all {
	margin: 150px auto;
}



.featherlight-content {
	width: 35%;
}
.featherlight-next span, .featherlight-previous span {
	color: #fff !important;
	font-weight: 900 !important;
}
@media screen and (max-width: 520px) {
	.featherlight-content {
		width: 90%;
	}
}


