@charset "UTF-8";

/* ++++++++++++++++++++++++++++++++++++++++++++++++++ /
/ post
/ 記事ページ
/ ++++++++++++++++++++++++++++++++++++++++++++++++++ */

#content {
	padding-top: 27px;
}
#wrapper > header {
	width: 100%;
	position: absolute;
}
#mainVis {
	padding: 0 27px 27px;
}
#mainVis .slick-slide {
	background: no-repeat center center;
	background-size: cover;
	-moz-background-size: cover;
	-webkit-background-size: cover;
	height: calc(100vh - 54px);
}
#mainVis .slick-dots {
	position: absolute;
	top: 0;
	right: 10px;
	bottom: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
#mainVis .slick-dots li {
	margin: 0 5px;
}
#mainVis .slick-dots button {
	width: 7px;
	height: 0;
	border: none;
	padding: 7px 0 0;
	overflow: hidden;
	border-radius: 50%;
	-moz-border-radius: 50%;
	-webkit-border-radius: 50%;
	appearance: none;
	-webkit-appearance: none;
	background: #c1bbb6;
	cursor: pointer;
}
#mainVis .slick-dots .slick-active button {
	background: #000;
}
#cont { color: #000; }
#postTitle {
	font-size: 32px;
	line-height: 1.625;
	position: relative;
	text-align: center;
}
#cont > #postTitle {
	margin-top: 100px;
}
#mainVis ~ #cont > #postTitle {
	margin-top: 0;
}
#postTitle:after {
	content: "";
	width: 160px;
	height: 160px;
	display: block;
	background: #c1bbb6;
	border-radius: 50%;
	-moz-border-radius: 50%;
	-webkit-border-radius: 50%;
	position: absolute;
	top: -500px;
	left: 0;
	right: 0;
	bottom: -500px;
	margin: auto;
	z-index: 0;
	opacity: 0.2;
}
#postTitle span {
	z-index: 1;
	position: relative;
}
#cont > .copy {
	font-size: 26px;
	line-height: 48px;
	font-weight: 500;
	text-align: center;
	margin-top: 70px;
}
#mainText {
	font-size: 16px;
	line-height: 32px;
	max-width: 870px;
	margin-top: 30px;
}
#cont > .block {
	margin-top: 80px;
}
#cont > .block:after {
	content: "";
	display: block;
	clear: both;
}
#cont > .tmpl_2col_sp,
#cont > .tmpl_2col_sp_photo {
	background: #c1bbb6;
}
#cont > .block .inner {
	max-width: 980px;
}
#cont > .block.tmpl_1col .inner {
	max-width: 880px;
}
#cont > .block .blockTitle {
	font-size: 26px;
	line-height: 40px;
	text-align: center;
	padding: 2px 0 3px;
	margin-bottom: 50px;
	background-size: auto auto;
	background-image: repeating-linear-gradient(135deg, transparent, transparent 20px, rgba(193,187,182,0.2) 20px, rgba(193,187,182,0.2) 40px);
}
#cont > .block figcaption {
	color: #646464;
	font-size: 14px;
	line-height: 30px;
	margin-top: 10px;
}
#cont > .block .redTitle,
#cont > .block .ulTitle {
	color: #ff4848;
	font-size: 30px;
	text-align: center;
}
#cont > .block .redTitle span,
#cont > .block .ulTitle span {
	display: inline-block;
}
#cont > .block .redTitle span:after,
#cont > .block .ulTitle span:after {
	content: "";
	width: 100%;
	height: 4px;
	display: block;
	margin-top: 10px;
	background: #ff4848;
}
#cont > .block .sTitle {
	font-size: 20px;
	line-height: 36px;
	font-weight: 500;
}
#cont .column > *:first-child {
	margin-top: 35px;
}
#cont > .block .text {
	color: #646464;
	font-size: 14px;
	line-height: 28px;
}
#cont > .block .text > * + * {
	margin-top: 10px;
}
#cont > .block .mTitle {
	font-size: 26px;
	line-height: 48px;
	font-weight: 500;
	text-align: center;
	margin-top: 40px;
}
#cont > .tmpl_2col_sp .column *,
#cont > .tmpl_2col_sp_photo .inner * {
	color: #fff;
}
#cont > .block .notice {
	margin-top: 10px;
}
#cont > .block .notice li {
	color: #ff4848;
	font-size: 12px;
	line-height: 18px;
	padding-left: 1em;
	text-indent: -1em;
}
#cont .inner .sTitle {
	margin: 35px 0 15px;
}
#cont .sTitle .num {
	width: 56px;
	height: 56px;
	font-size: 20px;
	line-height: 56px;
	margin-right: 20px;
	text-align: center;
	background: #ff4848;
	display: inline-block;
	vertical-align: middle;
}
#cont .sTitle .num + span {
	line-height: 1.5;
	display: inline-block;
	vertical-align: middle;
	max-width: calc(100% - 76px);
}
#cont .tmpl_1col .inner .sTitle {
	text-align: center;
}
#cont .tmpl_2col_sp .sTitle,
#cont .tmpl_2col_sp_photo .sTitle {
	text-align: left;
	line-height: 72px;
}
#cont > .tmpl_2col_sp,
#cont > .tmpl_2col_sp_photo {
	padding-top: 80px;
	padding-bottom: 90px;
}
#cont > .tmpl_button_link {
	text-align: center;
}
#cont > .tmpl_button_link a {
	color: #fff;
	display: block;
	font-size: 28px;
	line-height: 48px;
	background: #ff4848;
	padding: 18px 0 22px;
	position: relative;
	margin: 0 auto;
}
#cont > .tmpl_button_link a:hover {
	background: #000;
}
#cont > .tmpl_button_link .large a {
	max-width: 980px;
}
#cont > .tmpl_button_link .small a {
	max-width: 470px;
}
#cont > .tmpl_button_link a:after {
	content: "";
	display: block;
	width: 14px;
	height: 37.5px;
	display: inline-block;
	vertical-align: middle;
	background: url(../images/arr_s.svg) no-repeat center top;
	background-size: 14px 75px;
	transform: rotate(90deg) scale(0.6);
	-moz-transform: rotate(90deg) scale(0.6);
	-webkit-transform: rotate(90deg) scale(0.6);
}
#cont > .tmpl_store {
	text-align: center;
}
#cont > .tmpl_store .sTitle {
	font-size: 24px;
	margin-bottom: 40px;
}
#cont > .tmpl_store a {
	color: #fff;
	width: 236px;
	height: 56px;
	display: block;
	background: #000;
	font-size: 16px;
	line-height: 56px;
	position: relative;
}
#cont > .tmpl_store a:hover {
	background: #ff4848;
}
#cont > .tmpl_store a:before,
#cont > .tmpl_store a:after {
	width: 0;
	height: 0;
	content: "";
	display: block;
	position: absolute;
	border: solid calc(17px / 2) transparent;
}
#cont > .tmpl_store a:before {
	top: 0;
	left: 0;
	border-top-color: #ff4848;
	border-left-color: #ff4848;
}
#cont > .tmpl_store a:after {
	right: 0;
	bottom: 0;
	border-right-color: #ff4848;
	border-bottom-color: #ff4848;
}
#cont > .tmpl_store a:hover:before {
	border-top-color: #fff;
	border-left-color: #fff;
}
#cont > .tmpl_store a:hover:after {
	border-right-color: #fff;
	border-bottom-color: #fff;
}
#cont > .tmpl_img_only img {
	width: 100%;
}
#cont > .tmpl_text_only {
	color: #646464;
	line-height: 2;
}
@media screen and (min-width:966px){
	#content {
		padding-bottom: 150px;
	}
	#cont {
		padding-top: 35px;
	}
	#cont > .tmpl_photo .photos:after {
		content: "";
		display: block;
		clear: both;
	}
	#cont > .tmpl_photo .photos li,
	#cont > .tmpl_2col .column,
	#cont > .tmpl_2col_sp .column {
		float: left;
		width: 470px;
	}
	#cont > .tmpl_photo .photos li:nth-child(odd),
	#cont > .tmpl_2col .column:nth-of-type(odd),
	#cont > .tmpl_2col_sp .column:nth-of-type(odd) {
		clear: both;
	}
	#cont > .tmpl_photo .photos li:nth-child(even),
	#cont > .tmpl_2col .column:nth-of-type(even),
	#cont > .tmpl_2col_sp .column:nth-of-type(even) {
		float: right;
	}
	#cont > .tmpl_photo .photos li:nth-child(2) ~ li {
		margin-top: 45px;
	}
	#cont > .tmpl_2col_photo .inner > div,
	#cont > .tmpl_2col_sp_photo .inner > figure {
		clear: both;
	}
	#cont > .tmpl_2col_photo .inner > div,
	#cont > .tmpl_2col_sp_photo .inner > div {
		float: right;
		width: 470px;
	}
	#cont > .tmpl_2col_photo .inner > figure,
	#cont > .tmpl_2col_sp_photo .inner > figure {
		float: left;
		width: 470px;
		margin-top: 40px;
	}
	#cont > .tmpl_button_link a:after {
		top: 0;
		bottom: 0;
		right: 20px;
		margin: auto 0;
		position: absolute;
	}
	#cont > .tmpl_store ul:after {
		content: "";
		display: block;
		clear: both;
	}
	#cont > .tmpl_store li {
		float: left;
		margin-top: 12px;
		margin-right: 12px;
	}
	#cont > .tmpl_store li:nth-child(4n) {
		margin-right: 0;
	}
	#cont > .tmpl_img_only ul:after {
		content: "";
		display: block;
		clear: both;
	}
	#cont > .tmpl_img_only ul + ul li {
		margin-top: 55px;
	}
	#cont > .tmpl_img_only .img_group_column1 li {
		width: 100%;
	}
	#cont > .tmpl_img_only .img_group_column2 li {
		float: left;
		width: 470px;
		margin-left: 40px;
	}
	#cont > .tmpl_img_only .img_group_column2 li:nth-child(2n+1) {
		clear: both;
		margin-left: 0;
	}
	#cont > .tmpl_img_only .img_group_column3 li {
		float: left;
		width: 310px;
		margin-left: 24px;
	}
	#cont > .tmpl_img_only .img_group_column3 li:nth-child(3n+1) {
		clear: both;
		margin-left: 0;
	}
}
@media screen and (max-width:965px){
	#content {
		padding-top: 29px;
		padding-bottom: 90px;
	}
	#mainVis {
		padding: 0;
	}
	#mainVis .slick-slide {
		height: 65.625vw;
	}
	#cont > #postTitle {
		font-size: 22px;
		line-height: 1.5;
		margin-top: 120px;
	}
	#mainVis ~ #cont > #postTitle {
		margin-top: 100px;
	}
	#cont > .copy,
	#mainText {
		padding: 0 30px;
	}
	#cont > .copy {
		font-size: 18px;
		line-height: 1.5;
	}
	#mainText {
		font-size: 14px;
	}
	#cont > .block .blockTitle {
		font-size: 18px;
		line-height: 1.5;
		font-weight: 500;
		padding: 12px 30px;
	}
	#cont > .block .inner {
		padding-left: 30px;
		padding-right: 30px;
	}
	#cont > .block .photos li + li {
		margin-top: 30px;
	}
	#cont .inner .sTitle {
		font-size: 16px;
		line-height: 1.5;
	}
	#cont > .tmpl_2col_photo .sTitle {
		text-align: left;
	}
	#cont > .tmpl_2col_photo div + figure,
	#cont > .tmpl_2col_sp_photo div + figure {
		margin-top: 30px;
	}
	#cont > .block .redTitle,
	#cont > .block .ulTitle,
	#cont > .block .mTitle {
		padding-left: 30px;
		padding-right: 30px;
	}
	#cont > .block .redTitle,
	#cont > .block .ulTitle {
		font-size: 22px;
		line-height: 1.5;
	}
	#cont > .block .mTitle {
		font-size: 18px;
		line-height: 1.5;
	}
	#cont .sTitle span {
		margin: 0 auto 25px;
	}
	#cont > .tmpl_2col_sp .column + .column,
	#cont > .tmpl_2col_sp_photo .column + .column {
		margin-top: 90px;
	}
	#cont > .tmpl_2col_photo .inner > figure,
	#cont > .tmpl_2col_sp_photo .inner > figure {
		margin-top: 20px;
	}
	#cont > .block figcaption {
		line-height: 1.5;
	}
	#cont > .tmpl_button_link {
		padding: 0 30px;
	}
	#cont > .tmpl_button_link a {
		font-size: 18px;
		line-height: 1.5;
		font-weight: 500;
		padding-left: 15px;
		padding-right: 15px;
		padding-bottom: 17px;
	}
	#cont > .tmpl_button_link a:after {
		display: block;
		margin: 0 auto;
	}
	#cont > .tmpl_store li a {
		margin: 0 auto 10px;
	}
	#cont > .tmpl_img_only li + li,
	#cont > .tmpl_img_only ul + ul li {
		margin-top: 24px;
	}
}