@charset "utf-8";

/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
	* html .clearfix {
		zoom: 1;
	}

	*+html .clearfix {
		zoom: 1;
	}

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


::selection {
    background: #2A8FB9;
    color: #fff;
}

/*Firefox*/
::-moz-selection {
    background: #2A8FB9;
    color: #fff;
}


/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;
	font-size: 1em;
	font-family: 'Noto Sans JP', sans-serif;
}


html {
	font-size: 62.5%;
}


body, table, input, textarea, select, option, p, div, a, span {
	font-family: 'Noto Sans JP', sans-serif;
}


article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
	display: block;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

:focus {
	outline: 0;
}

ins {
	text-decoration: none;
}

del {
	text-decoration: line-through;
}

img {
	vertical-align: top;
	max-width: 100%;
}

a,
a:link {
	color: #2f2f2f;
	text-decoration: none;
	-webkit-transition: all .6s;
	transition: all .6s;
}

a:visited {
	color: #2f2f2f;
}

a:hover {
	color: #2f2f2f;
}

a:active {
	color: #2f2f2f;
}

a[href^="tel:"] {
	cursor: default;
	pointer-events: none;
}

@media all and (min-width: 750px) {
	.sp {
		display: none !important;
	}
}



/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/

body {
	color: #333;
	font-size: 1.4rem;
	line-height: 1.5;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	font-weight: 100;
}

#container {
	text-align: left;
	overflow: hidden;
	font-weight: 100;
}

.clearfix::after {
	content: "";
	display: block;
	clear: both;
}


@media all and (max-width: 750px) {
	body {
		min-width: inherit;
		font-size: 1.2rem;
	}
	
	a:hover,
	a:hover img {
		opacity: 1 !important;
	}
	
	.pc {
		display: none !important;
	}
	
	a[href^="tel:"] {
		cursor: pointer;
		pointer-events: auto;
	}

	.visual img{
		margin: 0px auto 0;
		
	}
}

/*------------------------------------------------------------
	文字サイズ
------------------------------------------------------------*/
h2 {
	font-size: 2.75rem;
	font-weight: 700;
	text-align: center;
	margin: 15px 0;
	color: #331F27;
}

h3 {
	font-size: 2.7rem;
	font-weight: 700;
}

h4 {
	font-size: 2.06rem;
	font-weight: 700;
}

p{
	font-size: 1.25rem;
	letter-spacing: 1px;
	line-height: 1.7em;
	font-weight: 400;
}



@media all and (max-width: 750px) {
	h2 {
		font-size: 2.8rem;
		font-weight: 900;
	}
	h3 {
		font-size: 2.65rem;
		font-weight: 700;
	}
	h4 {
		font-size: 2.06rem;
		font-weight: 700;
	}
	p{
		font-size: 1.3rem;
		letter-spacing: 1px;
		font-weight: 300;
		line-height: 1.7em;
	}
}



/*------------------------------------------------------------
	メニュー
------------------------------------------------------------*/

#gHeader{
	width: 100%;
	height: 40px;
	position: absolute;
	top: 0;
	z-index: 100;
	border: 2px solid g_reen;
}

#gHeader .s_head{
	border: 5px solid r_ed;
	width: 100%;
	height: 35px;
	position: fixed;
}


#gHeader .s_head .menu {
	position: absolute;
	right: 15px;
	top: 15px;
	z-index: 200;
}

#gHeader .s_head .menu a {
	padding: 8px 13px;
	display: block;
	transition: .7s;
}
#gHeader .s_head .menu a:hover{
	opacity: .5;
}




#gHeader .s_head .menu img {
	width: 25px;
}

#gHeader.header_fixed .menu img {
	width: 25px;
}


#gHeader.header_fixed .menu img {
	width: 20px;
}

.menuBox {
	padding: 0 23px 38px 0;
	width: 380px;
	max-width: 380px;
	position: fixed;
	top: 0;
	right: -400px;
	display: block;
	box-sizing: border-box;
	height: 100%;
	max-height: 100%;
	overflow-y: auto;
	box-sizing: border-box;
	transition: right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
	-webkit-transition: right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
	-ms-transition: right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
	z-index: 1000;
	overflow-x: hidden;
	transform:translate3d(0,0,0);
	box-shadow: 2px 0px 1px -5px rgba(0,0,0,0.05), 0px 0px 4px 0px rgba(115,115,115,0.1);
	background-color: #fff;
}



.menuBox.on {
	right: -0px;
	transform:translate3d(0,0,0); 
	border: 2px solid r_ed;
	background-color: #fff;
}




.menuBox .close {
	position: absolute;
	right: 15px;
	top: 15px;
	width: 53px;
	transform:translate3d(0,0,0); 
}
.menuBox .close a {
	padding: 10px;
	display: block;
}
.menuBox .close img,
#gHeader.header_fixed .close img {
	width: 30px;
}


#gHeader .ul_outer{
	border: 2px solid r_ed;
	margin-top: 60px;
	margin-left: 10px;
	margin: 70px 0 0 29px;
}

.menuBox .ul_outer li {
	margin: 3.0em 0 0 0;
}

#gHeader .ul_outer li a{
	font-weight: 600;
	font-size: 160%;
	letter-spacing: 1px;
	transition: .5s;
	border: 1px solid g_reen;
	text-decoration: none;
	color: #331F27;
	line-height: 1;
}
#gHeader .ul_outer li a:hover{
	opacity: .7;
}

#gHeader .ul_outer li a span{
	font-weight: 400;
	font-size: 75%;
	font-family: 'Noto Sans JP';
	opacity: .8;
	display: inline-block;
	margin-left: 10px;
	border: 1px solid r_ed;
}
#gHeader .ul_outer li a img{
	width: 230px;
}
#gHeader .ul_outer li:nth-child(4) a img{
	width: 200px;
}

#gHeader .ul_outer li .ul_inner{
	border: 1px solid g_reen;
	font-size: 80%;
	margin-left: 55px;
}
#gHeader .ul_outer li .ul_inner li a span{
	display: block;
	border: 1px solid r_ed;
	margin-left: 0;
	margin-top: 2px;
	letter-spacing: 0px;
	font-size: 70%;
	font-weight: 400;
	opacity: .9;
}






@media all and (max-width: 750px) {

	#gHeader{
		width: 100%;
		height: 40px;
		position: absolute;
		top: 0;
		z-index: 100;
	}
	
	
	
	#gHeader .s_head{
		border: 5px solid r_ed;
		width: 100%;
		height: 50px;
		position: fixed;
	}
	
	#gHeader .s_head h1 {
		width: 140px;
		margin: 6px auto 0;
		border: 1px solid r_ed;
	}
	#gHeader .s_head h1 img{
		width: 140px;
		margin: 5px auto 0;
	}
	
	#gHeader .s_head .book{
		position: absolute;
		right: 12px;
		top: 20px;
		width: 55px;
		transition: .7s;
	}
	
	#gHeader .s_head .book:hover{
		opacity: .7;
	}
	
	
	
	
	
	#gHeader .s_head .menu {
		position: absolute;
		left: 84vw;
		top: 0px;
		width: 16vw;
		z-index: 200;
	}
	
	#gHeader .s_head .menu a {
		padding: 13px 17px;
		display: block;
		transition: .7s;
	}
	
	#gHeader .s_head .menu img {
		width: 90px;
	}
	
	#gHeader.header_fixed .menu img {
		width: 80px;
	}
	
	


		
	.menuBox {
		padding: 0 23px 38px 0;
		width: 100vw;
		display: block;
		position: fixed;
		top: 0;
		right: -100%;
		height: 100%;
		max-height: 100%;
		overflow-y: auto;
		box-sizing: border-box;
		transition: right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
		-webkit-transition: right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
		-ms-transition: right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
		z-index: 1000;
		overflow-x: hidden;
		transform:translate3d(0,0,0);
		box-shadow: 2px 0px 1px -5px rgba(0,0,0,0.05), 0px 0px 4px 0px rgba(165,165,165,0.6);
		background-color: rgba(255, 255, 255, 0.67); /* 背景色 */
		-webkit-backdrop-filter: blur(10px); /* ぼかしエフェクト */
		backdrop-filter: blur(10px);
}


	.menuBox.on {
		width: 101vw;
		max-width: 101vw;
		right: 0%;
		transform:translate3d(0,0,0); 
		border: 2px solid r_ed;
		box-shadow: 2px 0px 1px -5px rgba(0,0,0,0.05), 0px 0px 4px 0px rgba(181,165,92,0.6);
		background-color: rgba(255, 255, 255, 0.92); /* 背景色 */
		-webkit-backdrop-filter: blur(10px); /* ぼかしエフェクト */
		backdrop-filter: blur(10px);
	
	}




	.menuBox .close {
		position: absolute;
		left: 87vw;
		top: 3px;
		transform:translate3d(0,0,0); 
	}
	.menuBox .close a {
		padding: 10px;
		display: block;
	}
	.menuBox .close img,
	#gHeader.header_fixed .close img {
		width: 70px;
	}

	.menuBox nav {
		border: 3px solid g_reen;
		width: 80%;
		margin: 0 auto 0 13vw;
	}

	.menuBox nav ul{
		border: 0px solid g_reen;
		margin: 1.5em 0 0 29px;
	}
	.menuBox nav ul li {
		margin: .8em 0 2em 0;
		font-size: 110%;
	}

	.menuBox nav ul li a{
		border: 0px solid r_ed;
		font-weight: 700;
		font-size: 100%;
	}
}







/*------------------------------------------------------------
//////////////////////////////////////////////////////////////
	メニュー
------------------------------------------------------------*/

#gHeader{
	width: 100%;
	height: 40px;
	position: absolute;
	top: 0;
	z-index: 100;
}

#gHeader .s_head{
	border: 5px solid r_ed;
	width: 10%;
	height: 95px;
	position: fixed;
	top: 0;
	right: 0;
}


#gHeader .s_head .menu {
	position: absolute;
	right: 43px;
	top: 20px;
	width: 70px;
	z-index: 200;
	border: 1px solid r_ed;
}

#gHeader .s_head .menu a {
	display: block;
	transition: .7s;
}
#gHeader .s_head .menu .menu_linebox{
	position: relative;
	width: 5vw;
	max-width: 50px;
	height: 4vw;
	border: 1px solid y_ellow;
	text-align: right;
}
#gHeader .s_head .menu span{
	display: inline-block;
	position: absolute;
	height: 2px;
	right: 0;
	width: 80%;
	transition: all .4s;
	background: #222;
}

#gHeader .s_head .menu span:nth-of-type(1){
	top: 15px;
	transition: 1s ;
}

#gHeader .s_head .menu span:nth-of-type(2){
	top: 25px;
}
#gHeader .s_head .menu span:nth-of-type(3){
	top: 35px;
}


#gHeader .s_head .menu a:hover span:nth-of-type(1){
	transform: translateY(3px);
}
#gHeader .s_head .menu a:hover span:nth-of-type(3){
	transform: translateY(-3px);
}

/*****/


.hum_menuBox {
	padding: 0 23px 38px 0;
	width: 101vw;
	position: fixed;
	top: 0;
	display: block;
	box-sizing: border-box;
	height: 100%;
	max-height: 100%;
	overflow-y: auto;
	box-sizing: border-box;
	-ms-overflow-style: none;
	/*
	transition: all right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
	-webkit-transition: all right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
	-ms-transition: all right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
	z-index: 1000;
	overflow-x: hidden;
	transform:translate3d(0,0,0);*/

	background: rgba( 255, 255, 255, 0.1 );
	box-shadow: 0 8px 32px 0 rgba( 31, 38, 135, 0.37 );
	backdrop-filter: blur( 12px );
	-webkit-backdrop-filter: blur( 12px );
	border-radius: 0px;
	border: 1px solid rgba( 255, 255, 255, 0.18 );
/****/
	display: flex;
	visibility: hidden;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	font-size: 29px;
	opacity: 0;
	transition: opacity 0.6s ease, visibility 0.6s ease;
}
.hum_menuBox::-webkit-scrollbar{
	display: none;
}




.hum_menuBox.on {
	border: 2px solid r_ed;
	background: rgba( 255, 255, 255, 0.85 );
	box-shadow: 0 8px 32px 0 rgba( 31, 38, 135, 0.37 );
	backdrop-filter: blur( 32px );
	-webkit-backdrop-filter: blur( 12px );
	border-radius: 0px;
	border: 1px solid rgba( 255, 255, 255, 0.18 );
/****/
	visibility: visible;
	opacity: 1;
}

.hum_menuBox_out .close {
	position: fixed;
	right: 50px;
	top: 30px;
	width: 43px;
	opacity: .2;
	z-index: 500;
	visibility: hidden;
}
.hum_menuBox_out.on .close {
	opacity: 1;
	transition: transform 10s ease, opacity 0.9s ease;
	transition-delay: .5s;
	visibility:visible;
}


.hum_menuBox .close a {
	padding: 10px;
	display: block;
}
.hum_menuBox .close img,
#gHeader.header_fixed .close img {
	width: 40px;
}



.hum_menuBox.on .tree1,.hum_menuBox.on .tree2,.hum_menuBox.on .tree3,.hum_menuBox.on .tree4,.hum_menuBox.on .tree5,.hum_menuBox.on .tree6,.hum_menuBox.on .tree7 ,.hum_menuBox.on .tree8,.hum_menuBox.on .tree9 {
	opacity: 1;
	transform: translateX(0);
	transition: transform 1s ease, opacity 0.9s ease;
}


/*********/

.menu_outer{
	position: absolute;
	margin: 0px;
	padding-bottom: 60px;
	padding-left: 150px;
	top: 130px;
	width: 500px;
	z-index: 20;
}





.menu_outer .treebox{
	position: relative;
	z-index: 20;
}

.menu_singlelink a{
	color: #222;
	text-decoration: none;
	transition: .5s;
	font-size: 60%;
	font-weight: 800;
	display: inline-block;
	margin-left: 63px;
	margin-bottom: 15px;
}
.menu_singlelink a:hover{
	opacity: .5;
}
.weddlink a::after{
	content: '';
	display: inline-block;
	width: 1em;
	height: 1em;
	background: url(img/common_/outlink.svg) no-repeat;
	position: relative;
	left: 5px;
}

.menu_singlelink a img{
	width: 180px;
}
.menu_singlelink a .headarrow{
	position: relative;
	top: 10px;
	width: 12px;
}
.menu_singlelink .blackbox{
	color: #fff;
	background-color: #000;
	display: inline-block;
	font-size: 80%;
	font-weight: 500;
	padding: 2px 10px 3px;
}


/*****/






@media all and (max-width: 750px) {

	#gHeader{
		width: 100%;
		height: 40px;
		position: absolute;
		top: 0;
		z-index: 100;
		border: 2px solid g_reen;
	}
	
	#gHeader .s_head{
		border: 5px solid r_ed;
		width: 100%;
		height: 95px;
		position: fixed;
	}
	
	
	#gHeader .s_head .menu {
		position: absolute;
		right: -1px;
		top: 0px;
		width: 50px;
		z-index: 200;
		border: 1px solid r_ed;
	}
	
	#gHeader .s_head .menu a {
		display: block;
		transition: .7s;
	}
	#gHeader .s_head .menu .menu_linebox{
		position: relative;
		width: 8vw;
		max-width: 50px;
		height: 4vw;
		border: 1px solid y_ellow;
		text-align: right;
	}
	#gHeader .s_head .menu span{
		display: inline-block;
		position: absolute;
		height: 2px;
		right: 0;
		width: 100%;
		transition: all .4s;
		background: #222;
	}
	
	#gHeader .s_head .menu span:nth-of-type(1){
		top: 15px;
		transition: 1s ;
	}
	
	#gHeader .s_head .menu span:nth-of-type(2){
		top: 25px;
	}
	#gHeader .s_head .menu span:nth-of-type(3){
		top: 35px;
	}
	
	
	#gHeader .s_head .menu a:hover span:nth-of-type(1){
		transform: translateY(3px);
	}
	#gHeader .s_head .menu a:hover span:nth-of-type(3){
		transform: translateY(-3px);
	}
	
	/*****/
	
	.hum_menuBox {
		padding: 0 23px 38px 0;
		width: 100vw;
		position: fixed;
		top: 0;
		display: block;
		box-sizing: border-box;
		height: 100%;
		max-height: 100%;
		overflow-y: auto;
		box-sizing: border-box;
	
		/*
		transition: all right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
		-webkit-transition: all right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
		-ms-transition: all right 1s cubic-bezier(0.075, 0.82, 0.165, 1);
		z-index: 1000;
		overflow-x: hidden;
		transform:translate3d(0,0,0);*/
	
		background: rgba( 255, 255, 255, 0.1 );
		box-shadow: 0 8px 32px 0 rgba( 31, 38, 135, 0.37 );
		backdrop-filter: blur( 12px );
		-webkit-backdrop-filter: blur( 12px );
		border-radius: 0px;
		border: 1px solid rgba( 255, 255, 255, 0.18 );
	/****/
		display: flex;
		visibility: hidden;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		font-size: 29px;
		opacity: 0;
		transition: opacity 0.6s ease, visibility 0.6s ease;
	}
	
	
	
	
	
	.hum_menuBox.on {
		right: -0px;
		transform:translate3d(0,0,0); 
		border: 2px solid r_ed;
		background: rgba( 255, 255, 255, 0.85 );
		box-shadow: 0 8px 32px 0 rgba( 31, 38, 135, 0.37 );
		backdrop-filter: blur( 32px );
		-webkit-backdrop-filter: blur( 12px );
		border-radius: 0px;
		border: 1px solid rgba( 255, 255, 255, 0.18 );
	/****/
		visibility: visible;
		opacity: 1;
	}
	
	.hum_menuBox_out .close {
		position: fixed !important;
		right: 7px;
		top: 7px;
		width: 53px;
		transform:translate3d(0,0,0); 
		z-index: 2;
	}
	.hum_menuBox_out .close a {
		padding: 10px;
		display: block;
	}
	.hum_menuBox_out .close img,
	#gHeader.header_fixed .close img {
		width: 30px;
	}
	.hum_menuBox_out .close {
		position: fixed;
		right: 18px;
		top: 10px;
		width: 43px;
		opacity: .2;
		z-index: 500;
		visibility: hidden;
	}
	.hum_menuBox_out.on .close {
		opacity: 1;
		transition: transform 10s ease, opacity 0.9s ease;
		transition-delay: .5s;
		visibility:visible;
	}
	.treebox{
		border: 1px solid r_ed;
		width: 90%;
		position: relative;
		left: -13vw;
	}
	.treebox .menu_singlelink{
		border: 1px solid r_ed;
		padding-left: 0;
	}
}