@charset "UTF-8";

/* ++++++++++++++++++++++++++++++++++++++++++++++++++ /
/ studio
/ 店舗情報 記事
/ ++++++++++++++++++++++++++++++++++++++++++++++++++ */

#mainCont {
	margin: 0 27px 27px;
	background: #c1bbb6;
	padding-bottom: 30px;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
#mainCont:before {
	content: "";
	display: block;
	background: no-repeat center center;
	background-size: cover;
	-moz-background-size: cover;
	-webkit-background-size: cover;
}
#mainCont .boxTitle {
	color: #fff;
}
#mainCont table {
	width: 100%;
	font-size: 12px;
	line-height: 18px;
	table-layout: fixed;
}
#mainCont table th {
	color: #fff;
	width: 114px;
}
#mainCont .roundLink a {
	color: #fff;
	background: #000;
	overflow: hidden;
}
#mainCont .roundLink a:before {
	top: -10px;
}
#mainCont .roundLink a:after {
	top: 23px;
}
#mainCont .roundLink a span {
	font-size: 12px;
	line-height: 18px;
}
#mainCont .roundLink a:hover {
	background: #ff4848;
}
.gallery {
	font-size: 0;
	text-align: center;
	margin: 25px 0 60px;
}
.gallery dl {
	margin: 0 1px;
	display: inline-block;
	vertical-align: middle;
}
.gallery img {
	width: 120px;
	height: auto;
}
.gallery > br { display: none; }

#cont > #wrap:first-child {
	margin-top: 25px;
}
#wrap .boxTitle {
	color: inherit;
}
#access {
	color: #c1bbb6;
	background: #646464;
}
#access #map p {
	font-size: 12px;
	line-height: 22px;
	margin-bottom: 15px;
}
#access .googlemap:after {
	content: "";
	display: block;
	margin-top: 50%;
}
#access #view p {
	font-size: 16px;
}
#access #view .wrap {
	padding-top: 50%;
	position: relative;
}
#access #view .wrap iframe {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	position: absolute;
}

#blog {
	color: #000;
	background: #c1bbb6;
}
#blog .post_list li {
	overflow: hidden;
}
#blog .post_list li + li {
	margin-top: 20px;
}
#blog .post_list li a {
	display: block;
}
#blog .post_list figure {
	float: left;
	width: 100px;
	height: 100px;
	overflow: hidden;
	position: relative;
}
#blog .post_list figure img {
	top: 0;
	left: -50%;
	right: -50%;
	width: auto;
	height: 100%;
	margin: 0 auto;
	max-width: none;
	overflow: hidden;
	position: absolute;
}
#blog .post_list .date {
	color: #fff;
	font-size: 12px;
}
#blog .post_list .title {
	margin: 0.5em 0;
	line-height: 1.5;
}
#blog .more {
	color: #000;
	width: 97px;
	padding-bottom: 7px;
	display: inline-block;
	background: url(../images/home/scroll_b.svg) no-repeat center bottom;
	background-size: 100% auto;
}
#blog .archiveLink {
	text-align: right;
}
#blog .archiveLink a {
	width: 90px;
	text-align: left;
	padding-bottom: 5px;
	display: inline-block;
	background: url(../images/home/scroll_b.svg) no-repeat center bottom;
	background-size: 100% auto;
}

#shops {
	text-align: center;
}
#shops .boxTitle {
	color: #000;
	font-size: 24px;
	margin-bottom: 40px;
	padding: 0;
}
#shops a {
	color: #fff;
	width: 236px;
	height: 56px;
	display: block;
	padding: 0 15px;
	background: #000;
	font-size: 16px;
	line-height: 56px;
	position: relative;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
#shops a:hover {
	background: #ff4848;
}
#shops a:before,
#shops a:after {
	width: 0;
	height: 0;
	content: "";
	display: block;
	position: absolute;
	border: solid calc(17px / 2) transparent;
}
#shops a:before {
	top: 0;
	left: 0;
	border-top-color: #ff4848;
	border-left-color: #ff4848;
}
#shops a:after {
	right: 0;
	bottom: 0;
	border-right-color: #ff4848;
	border-bottom-color: #ff4848;
}
#shops a:hover:before {
	border-top-color: #000;
	border-left-color: #000;
}
#shops a:hover:after {
	border-right-color: #000;
	border-bottom-color: #000;
}
#shops a span {
	line-height: 1.2;
	display: inline-block;
	vertical-align: middle;
}
@media screen and (min-width:966px){
	.article #content {
		padding-top: 27px;
	}
	#sideLinks {
		left: 15px;
		padding-left: 0;
	}
	#mainCont {
		min-height: 500px;
		padding-left: 50px;
		position: relative;
		padding-right: calc(50% + 50px);
	}
	#mainCont:before {
		width: 50%;
		top: 0;
		right: 0;
		height: 100%;
		position: absolute;
	}
	#mainCont table tr:nth-last-child(1) td,
	#mainCont table tr:nth-last-child(2) td {
		padding-right: 120px;
	}
	#mainCont .roundLink {
		right: calc(50% + 75px);
		bottom: 50px;
		position: absolute;
	}
	#wrap {
		display: flex;
	}
	#wrap > * {
		width: 50%;
		padding: 0 50px 150px;
	}
	#wrap .boxTitle {
		padding: 90px 0 150px;
	}
	#access #view {
		margin-top: 55px;
	}
	#access #view p {
		margin-bottom: 15px;
	}

	#blog .post_list figure {
		margin-right: 25px;
	}
	#blog .post_list .title {
		font-size: 16px;
	}
	#blog .archiveLink {
		margin-top: 35px;
	}

	#cont #shops {
		padding-bottom: 145px;
	}
	#shops .boxTitle {
		margin-bottom: 50px;
	}
	#shops .boxTitle .ja {
		font-size: 16px;
	}
	#shops ul {
		margin: 0 auto;
		max-width: 980px;
	}
	#shops ul:after {
		content: "";
		display: block;
		clear: both;
	}
	#shops li {
		float: left;
		margin-top: 12px;
		margin-right: 12px;
	}
	#shops li:nth-child(4n) {
		margin-right: 0;
	}
}
@media screen and (max-width:965px){
	.article #wrapper > header h1 {
		top: 71px;
	}
	.article #content {
		padding-top: 100px;
	}
	#mainCont {
		margin: 0;
		padding-bottom: 40px;
	}
	#mainCont:before {
		padding-top: 87.5%;
	}
	#mainCont .table {
		padding-left: 35px;
		padding-right: 15px;
	}
	#mainCont .table th:after {
		height: 1.2em;
		top: 0.1em;
		bottom: auto;
	}
	#mainCont #reserve {
		margin-top: 20px;
	}
	.gallery {
		margin: 40px 0;
	}
	.gallery img {
		width: 128px;
	}
	#access {
		padding: 0 40px 90px;
	}
	#wrap .boxTitle {
		padding: 75px 0 55px;
	}
	#wrap .boxTitle .en {
		font-size: 24px;
	}
	#wrap .boxTitle .ja {
		font-size: 12px;
	}
	#access #view p {
		margin: 40px 0 10px;
	}

	#blog .post_list figure {
		margin-right: 10px;
	}
	#blog .post_list .title {
		font-size: 14px;
	}
	#blog .post_list li a {
		padding-right: 20px;
	}
	#blog .archiveLink {
		padding-right: 25px;
		padding-bottom: 100px;
	}

	#shops .boxTitle {
		margin-bottom: 80px;
	}
	#shops .boxTitle .ja {
		font-size: 12px;
	}
	#shops li a {
		margin: 0 auto 10px;
	}
}

/* ++++++++++++++++++++++++++++++++++++++++++++++++++ /
/ studio
/ 店舗情報 一覧
/ ++++++++++++++++++++++++++++++++++++++++++++++++++ */

.archive #cont h2 {
	color: #c1bbb6;
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 40px;
}
.archive #cont ul + h2 {
	margin-top: 115px;
}
.archive #cont li {
	width: 210px;
	display: flex;
	margin-bottom: 10px;
	background: #c1bbb6;
}
.archive #cont li a {
	width: 100%;
	display: block;
	position: relative;
}
.archive #cont li figure {
	overflow: hidden;
	padding-top: 85.7%;
	position: relative;
}
.archive #cont li figure img {
	top: -50%;
	left: -50%;
	right: -50%;
	bottom: -50%;
	margin: auto;
	position: absolute;
	transition-duration: .5s;
	transition-property: transform;
	transform-origin: center center;
}
.archive #cont li figure.vertical img {
	width: 100%;
	max-height: none;
}
.archive #cont li figure.horizontal img {
	height: 100%;
	max-width: none;
}
.archive #cont li a:hover figure img {
	transform: scale(1.1);
}
.archive #cont li a > div {
	min-height: 184px;
	padding: 10px 15px 45px;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
.archive #cont li h3,
.archive #cont li .table th,
.archive #cont li .more {
	color: #fff;
}
.archive #cont li h3 {
	margin-bottom: 2px;
}
.archive #cont li .address {
	font-size: 12px;
	line-height: 19px;
	transform-origin: left center;
}
.archive #cont li .table {
	font-size: 12px;
	border-spacing: 0 5px;
}
.archive #cont li .table th {
	white-space: nowrap;
	padding-right: 15px;
}
.archive #cont li .more {
	left: 18px;
	bottom: 20px;
	position: absolute;
	width: 97px;
	padding-bottom: 7px;
	background: url(../images/home/scroll.svg) no-repeat center bottom;
	background-size: 100% auto;
}
@media screen and (min-width:966px){
	.archive #cont {
		margin: 0 auto;
		max-width: 870px;
	}
	.archive #cont ul {
		display: flex;
		flex-wrap: wrap;
		margin-right: -10px;
	}
	.archive #cont li {
		margin-right: 10px;
	}
	.archive #cont li h3 {
		height: 40px;
	}
	.archive #cont li .address {
		height: 57px;
	}
}
@media screen and (max-width:965px){
	.archive #cont li {
		margin-left: auto;
		margin-right: auto;
	}
}