@charset "utf-8";

/* CSS Document */
/** 
 * 基本情報
 */
body {
	color: #000;
	font-family: 'Noto Sans Japanese';
	font-style: normal;
	font-weight: 300;
	font-size: 18px;
	line-height: 1.9375;
	/* 16 / 31 */
	text-align: justify;
	text-justify: inter-ideograph;
	background: #fff;
	padding-top: 124px;
}

@media screen and (max-width: 768px) {
	body {
		font-size: 15px;
		padding-top: 19.76vw;
	}
}

a {
	color: inherit;
	text-decoration: none;
}

a:hover {
	text-decoration: underline;
}

a:hover img {
	opacity: 0.5;
}

a:hover img.notOpacity {
	opacity: 1;
}

/*IMGにSVGをしている親要素の横幅が指定してある必要あり*/
/*IEでこれがないと表示領域がおかしくなる場合がある*/
img[src$=".svg"] {
	width: 80%;
}

.contentIn {
	/*background: #fab8b8;*/
	/*確認用です*/
	width: 1000px;
	margin: 0 auto;
	position: relative;
}

.clearfix:after,
.contentIn:after,
#gNavi:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

img {
	max-width: 100%;
	height: auto;
}

@media screen and (max-width: 768px) {
	.contentIn {
		width: 100%;
		padding: 28px 2.666666% 0;
	}
}

* {
	word-break: break-all;
}

/** 
 * ヘッダー
 */
#header {
	width: 100%;
	position: fixed;
	top: 0;
	z-index: 100;
}

.headerIn {
	background: #fff;
	position: relative;
	width: 1000px;
	margin: 0 auto;
}

@media screen and (max-width: 768px) {
	.headerIn {
		width: 100%;
		padding: 0 2.666666%;
	}
}

.siteTitle {
	float: left;
	width: 174px;
	margin: 28px 0 15px;
}

@media screen and (max-width: 768px) {
	.siteTitle {
		width: 27.323943%;
		margin: 27px 0 15px 18.5%;
	}
}

@media screen and (max-width: 768px) {
	.headerIn .utility {
		float: right;
		width: 46.3%;
		margin-top: 8%;
		display: flex;
		justify-content: space-between;
	}
	.headerIn .nvInstagram {
		width: 15%;
	}
	.headerIn .nvPhone {
		width: 26.8%;
	}
	.headerIn .nvTxt {
		width: 48.5%;
	}
	.headerIn .nvYb {
		width: 21%;
	}
}

/** 
 * グローバルナビゲーション
 */
#gNavi {
	float: right;
	list-style-type: none;
	padding: 0;
	position: absolute;
	right: 0;
	bottom: 30px;
}

#gNavi .rTxt {
	margin-bottom: 14px;
	text-align: right;
	font-family: 'Cinzel';
}

#gNavi .rTxt a {
	display: inline-block;
	position: relative;
	z-index: 2;
	font-size: 18px;
}

#gNavi .rTxt a:hover {
	opacity: 0.7;
	text-decoration: none;
}

#gNavi .rTxt a:before {
	position: absolute;
	left: -2px;
	bottom: 11px;
	right: -2px;
	background-color: #AADBEC;
	height: 5px;
	content: "";
	z-index: -1;
}

#gNavi li {
	position: relative;
	float: left;
	margin: 0;
	padding: 0;
	text-align: center;
	font-size: 0;
	margin-left: 36px;
}

#gNavi li a {
	font-size: 18px;
	font-family: 'Cinzel';
	font-weight: 400;
	line-height: 1;
	margin: 0;
	padding-left: 15px;
	text-decoration: none;
}

@media screen and (min-width: 769px) {
	#gNavi li a {
		color: #a9a9a9;
	}
	#gNavi li a.current {
		color: #000;
	}
}

@media screen and (max-width: 768px) {
	#navOverlay {
		opacity: 0;
		visibility: hidden;
		-webkit-transition: opacity .4s ease, visibility .4s ease, max-height .4s ease;
		transition: opacity .4s ease, visibility .4s ease, max-height .4s ease;
		z-index: 9990;
		max-height: 0;
		overflow: hidden;
		position: fixed;
		right: 0;
		top: 0;
		bottom: 0;
		left: 0;
		width: 100%;
	}
	.open #navOverlay {
		opacity: 1;
		visibility: visible;
		max-height: 100%;
		background: rgba(255, 255, 255, 0.8);
		text-align: center;
		font-size: 14px;
		font-weight: normal;
		padding-top: 80px;
	}
	#gNavi {
		opacity: 0;
		visibility: hidden;
		-webkit-transition: opacity .4s ease, visibility .4s ease, max-height .4s ease;
		transition: opacity .4s ease, visibility .4s ease, max-height .4s ease;
		z-index: 9990;
		overflow: hidden;
		position: fixed;
		right: 0;
		top: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		padding-top: 80px;
	}
	#gNavi .rTxt {
		display: none;
	}
	.open #gNavi {
		opacity: 1;
		visibility: visible;
		max-height: 100%;
		text-align: center;
		font-size: 14px;
		font-weight: normal;
		padding-top: 80px;
	}
	#gNavi ul {
		display: block;
		margin-top: 20px;
	}
	#gNavi li {
		width: 100%;
		float: none;
		text-align: center;
		margin: 0;
	}
	#gNavi li a {
		display: block;
		font-size: 18px;
		line-height: 1.74;
		padding-left: 0;
	}
}

/** 
 * メインコンテンツ
 */
#content {
	margin-bottom: 30px;
}

@media screen and (max-width: 768px) {
	#content {
		margin-bottom: 15px;
	}
}

/** 
 * フッター
 */
.footerIn {
	width: 1000px;
	margin: 0 auto;
	padding: 25px 0;
}

.copyright {
	color: #221714;
	font-size: 14px;
	text-align: center;
}

@media screen and (max-width: 768px) {
	.footerIn {
		width: 100%;
		padding: 0;
	}
	.copyright {
		padding: 3% 0;
	}
}
