@charset "utf-8";

/*
************************************************************************
* タイトル
* @copyright Revolme Inc.
************************************************************************
*/

/*
************************************************************************
* タイトル部ボタン
************************************************************************
*/
.header-button-list
{
	display: none;
	
	position:absolute;
	top:1em;
	right:1em;
}
.header-button-list .header-button
{
	display:block;
	float:left;

	height:50px;
	min-width:50px;

	border-radius:50px;

	background-color:#FFFFFF;

	line-height:1;
	margin-left:0.5em;
	padding-left:15px;
	padding-right:15px;

	transition-duration:10.3s;
	transition-property:width;
	transition-timing-function:ease;
}
.header-button-list .header-button > span
{
	display:block;
	height:20px;
	margin-top:13px;
	margin-bottom:12px;
}
.header-button-list .header-button.tel > span
{
	height:36px;
	margin-top:8px;
	margin-bottom:6px;
}
.header-button-list .header-button > span .tel,
.header-button-list .header-button > span .time
{
	display:block;
	text-align:center;
}
.header-button-list .header-button > span .tel
{
	font-size:2.0rem;
}
.header-button-list .header-button > span .time
{
	margin-top:2px;
	font-size:1.3rem;
}


.header-button-list .header-button > span .icon
{
	display:block;
	float:left;
	font-size:20px;
}
.header-button-list .header-button > span .label
{
	display:block;
	float:left;
	width:0px;
	height:20px;

	overflow-y:hidden;

	line-height:20px;

	transition-duration:0.5s;
	transition-property:width;
	transition-timing-function:ease;
}
.header-button-list .header-button.mail:hover > span .label
{
	width:11.6em;
    margin-top: 0.1em;
    margin-left:0.4em;
}
.header-button-list .header-button.mail > span .icon.icon-mail:before
{
	width:1.1em;
    height:1.1em;
}
.header-button-list .header-button.reserve > span .icon.icon-reserve:before
{
	margin-left:0.1em;
	margin-bottom:-0.2em;
}
.header-button-list .header-button.reserve:hover > span .label
{
	width:4.6em;
    margin-left:0.4em;
}

/*繁体字・簡体字対応*/
.header-button-list #sub.header-button {
	box-shadow: 0px 0px 10px 2px rgba(0,0,0,.15);
	transition: 0.3s ease;
	padding-left: 24px;
}
.header-button-list #sub.header-button:hover{
	opacity:.6;
	transition: 0.3s ease;
}
.header-button-list #sub.header-button.mail > span .label{
	width: 2.7em;
	margin-top: 0.1em;
	margin-left:0.4em;
}

/*英語版対応*/
.header-button-list #en.header-button {
	box-shadow: 0px 0px 10px 2px rgba(0,0,0,.15);
	transition: 0.3s ease;
	padding-left: 24px;
}
.header-button-list #en.header-button:hover{
	opacity:.6;
	transition: 0.3s ease;
}
.header-button-list #en.header-button.mail > span .label{
	width:4em;
	margin-top: 0.1em;
	margin-left:0.4em;
}

/*
************************************************************************
* INDEXタイトル部
************************************************************************
*/
#index-title
{
	border-bottom:1px solid #e3e3e3;
}
#index-title .image
{
	width:100%;
	height:calc((100vw - 230px) * 0.5);
	max-height:630px;
}
#index-title .title
{
	display:block;

	padding:36px 30px;

	text-align:center;
}
#index-title .title .main
{
	font-size:2.4rem;
	line-height:1;
	
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* == スマートフォンサイズ ==========================================================*/
@media screen and (max-width: 768px) {
	#index-title
	{
	}
	#index-title .image
	{
		height:97.333333vw;
		max-height:auto;
	}
	#index-title .title
	{
		padding:6vw;
		padding-top:13vw;
	}
	#index-title .title .main
	{
		font-size:3.6rem;
	}
}

/*
************************************************************************
* ページタイトル部
************************************************************************
*/
#page-title
{
	border-bottom:1px solid #e3e3e3;
}
#page-title .image
{
	/*width:100%;
	height:calc((100vw - 230px) * 0.5);
	max-height:540px;*/
	height: 600px;

	background-color:transparent;
	background-position:center center;
	background-repeat:no-repeat;
	background-size:cover;
}
#page-title .title
{
	position: absolute;
	top: 36px;
	left: 50%;
	transform: translate(-50%, 0);
	-webkit-transform: translate(-50%, 0);
	-moz-transform: translate(-50%, 0);
	-ms-transform: translate(-50%, 0);
	
	display:block;
	width: 25vw;
	max-width: 365px;
	margin: 0 auto;
	z-index: 1;
}
#page-title .title .main
{
	font-size:3.6rem;
	line-height:1;
}

/* == スマートフォンサイズ ==========================================================*/
@media screen and (max-width: 767px) {
	#page-title
	{
	}
	#page-title .image
	{
		/*height:66.66666vw;*/
		height: 80vw;
	}
	#page-title .title
	{
		top: 25px;
		width: 55vw;
		/* padding: 4vw;*/
	}
	#page-title .title .main
	{
		font-size:4.2rem;
	}
}

/*
************************************************************************
* 段落見出し
************************************************************************
*/
.title-lv1
{
}
.title-lv1 .main
{
	font-family: 'Montserrat', sans-serif;
	display:block;
	text-align: center;
	font-size: 2.7em;
	font-weight: bold;
	letter-spacing: 2px;
}
.title-lv1 .main > small {
	font-weight: normal;
	font-size: .8em;
	margin-left: .4em;
}
.title-lv1 .main.ff-amiko
{
	font-size:2.6rem;
	line-height:1.4;
}
.title-lv1 .sub
{
	display:block;
	line-height:1;

	margin-top:1em;
}
.title-lv1 .button
{
	position:absolute;
	top:0;
	right:30px;
}
.title-lv1 .caption
{
	position:absolute;
	top:0;
	right:30px;
}
.title-lv1 .caption.kimono {
	color: #666666;
	font-size: 1.4rem;
}
.title-lv1 .caption-question
{
	display: inline-block;
	border: 1px solid #666666;
	border-radius: 50%;
	text-align: center;
	padding-top: 3px;
	padding-left: 1px;
	width: 20px;
	height: 20px;
	line-height: 1;
	margin-right: 0.5em;
	font-weight: 500;
}
.title-lv1 .caption.kimono:hover {
	text-decoration: none;
}
.title-lv1 .caption.tax {
	color: #666666;
	font-size: 1.4rem;
}

/* == スマートフォンサイズ ==========================================================*/
@media screen and (max-width: 767px) {
	.title-lv1
	{
	}
	.title-lv1 .main
	{
		font-family: 'Montserrat', sans-serif;
		font-size:3.8rem;
		line-height:1.5;
	}
	.title-lv1 .main.ff-amiko
	{
		font-size:3.8rem;
		line-height:1.0;
	}
	.title-lv1 .sub
	{
		display:block;
		line-height:1.5;

		margin-top:1em;
	}
	.title-lv1 .caption
	{
		position:absolute;
		top:0;
		right:10px;
	}
	.title-lv1 .caption.kimono {
		font-size: 2.0rem;
	}
	.title-lv1 .caption-question
	{
		font-size: 1.8rem;
		padding-top: 0.67vw;
		padding-left: 1px;
		width: 4vw;
		height: 4vw;
		vertical-align: middle;
	}
	.title-lv1 .caption.kimono:hover {
	}
	.title-lv1 .caption.tax {
		font-size: 2.0rem;
	}

}

