@charset "UTF-8";

/* @font-face {
	font-family: "Noto Sans JP";
	src: url("../fonts/noto-sans-jp/NotoSansJP-Regular.woff2") format("woff2"),
		url("../fonts/noto-sans-jp/NotoSansJP-Regular.woff") format("woff");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}


@font-face {
	font-family: "Noto Sans JP";
	src: url("../fonts/noto-sans-jp/NotoSansJP-Medium.woff2") format("woff2"),
		url("../fonts/noto-sans-jp/NotoSansJP-Medium.woff") format("woff");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

ｇ
@font-face {
	font-family: "Noto Sans JP";
	src: url("../fonts/noto-sans-jp/NotoSansJP-SemiBold.woff2") format("woff2"),
		url("../fonts/noto-sans-jp/NotoSansJP-SemiBold.woff") format("woff");
	font-weight: 600;
	font-style: normal;
	font-display: swap;
} */

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

.clearfix {
	display: inline-block;
}

/* Hide from Mac IE \*/

.clearfix {
	display: block;
}

* html .clearfix {
	height: 1%;
}

/* Hide from Mac IE */

body {
	font-family:
		"Yu Gothic", "Yu Gothic Medium", "游ゴシック体", "YuGothic", -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
	font-size: 16px;
	line-height: 1;
	color: #fff;
	/* 	background: #000; */
	background: #000 url(/img/loading.gif) no-repeat scroll center center;
}

/*
.body_en {
	font-family: "Times New Roman",serif;
	font-family: "adobe garamond pro",serif;
	font-size: 15px;
}
*/


.box {
	opacity: 0;
	filter: alpha(opacity=0);
	-ms-filter: "alpha(opacity=0)";
	-moz-opacity: 0;
	-khtml-opacity: 0;
	zoom: 1;
}

/*--common--*/
html,
body {
	height: 100%;
}

.backstretch img {
	display: none;
}

#wrap {
	width: 100%;
	position: relative;
	height: auto !important;
	height: 100%;
	min-height: 100%;
	background: rgba(0, 0, 0, 0.70);
}

.wrap_dark {
	background: rgba(0, 0, 0, 0.7) !important;
}

a {
	color: #d73f3f;
}

a:hover {
	text-decoration: none;
}

strong {
	color: #d73f3f;
}

a.btn {
	color: #fff;
	text-decoration: none;
}

a.btn:hover {
	color: #d73f3f;
}

.no_black {
	background: none !important;
}

#content {
	/* padding-bottom: 43px; */
	display: flex;
}

#id #content {
	padding-bottom: 0px;
	/*same as the #ftr height*/
}

#nav {
	font-family:
		"Yu Gothic",
		"Yu Gothic Medium",
		"游ゴシック体",
		"YuGothic",
		-apple-system,
		BlinkMacSystemFont,
		"Hiragino Kaku Gothic ProN",
		"Hiragino Sans",
		sans-serif;
	height: 570px;
}

#nav ul li {
	margin: 0 0 36px 0;
}

#nav ul li a {
	font-size: 21px;
	font-weight: 500;
	color: #fff;
	text-decoration: none;
	letter-spacing: 0.1em;
	transition: color 0.4s ease;
}

#nav ul li a:hover {
	color: #bd2c2e;
}

#greeting .nav-greeting,
#about .nav-about,
#logopage .nav-logo,
#manifesto .nav-manifesto,
#japanese .nav-japanese,
#archive .nav-archive,
#organization .nav-organization,
#contact .nav-contact,
#form .nav-contact {
	color: #bd2c2e;
}

.nav_en {
	margin: 60px 0 0 0 !important;
}

.nav_en ul li {
	margin: 0 0 21px 0 !important;
}

#ftr {
	/* margin-left: 30px; */
	height: 43px;
	/* display: none; */
	font-size: 9px;
	opacity: 0.8;
	padding-bottom: 80px;
}


.archiveTitle {
	color: #bd2c2e;
	text-align: center;
	font-size: 45px;
	font-weight: bold;
}

.textBox {
	background: rgba(0, 0, 0, 0.5);
	padding: 20px;
}

.textBox p {
	font-size: 23px;
	text-align: center;
	margin: 0 !important;
}



/*--intro--*/
#logo_intro {
	position: absolute;
	width: 84px;
	height: 174px;
	left: 50%;
	top: 50%;
	margin-left: -42px;
	/* 	margin-top:-87px; */
	margin-top: -153px;
}

/*-- 動画付きTOP --*/
#wrap2 {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	height: auto !important;
	height: 100%;
	min-height: 100%;
}

.fade_in {
	visibility: hidden;
	opacity: 0;
	transition: all 2s;
}

.show {
	visibility: visible;
	opacity: 1;
}

.flag {
	position: absolute;
	top: 20px;
	right: 20px;
}

#logo_intro2 {
	text-align: center;
}

#lang2 {
	margin-top: 100px;
	text-align: center;
}

#lang2 li {
	display: inline-block;
	margin: 0 20px;
}

#lang {
	position: absolute;
	width: 362px;
	height: 34px;
	left: 50%;
	top: 50%;
	margin-left: -100px;
	margin-top: 146px;
}

#lang ul li {
	float: left;
}

#lang ul li:first-child,
#lang ul li:nth-child(2) {
	margin: 0 43px 0 0;
}

/*--/intro--*/
#left {
	width: 317px;
	/* float: left; */
	margin: 50px 0 0 30px;
	/* position: fixed; */
	z-index: 3;
	max-height: 100vh;
	overflow-y: scroll;
	/* overflow: auto;
	-ms-overflow-style: none;
	scrollbar-width: none; */
}


#left::-webkit-scrollbar {
	display: none;
}

#left img.copy {
	margin: 0 0 30px;
}

#right {
	position: relative;
	text-align: justify;
	line-height: 1.6;
	margin: 145px 30px 0 0;
	padding-bottom: 60px;
	/* height: calc(100vh - 180px); */
	width: 1000px;
}

@media (min-width: 1700px) {
	#right {
		margin-left: 130px;
	}
}

@media (max-height: 600px) {
	#right {
		margin-top: 130px;
	}
}


#right p {
	/* margin: 0 0 24px 0; */
	font-size: 18px;
	/* 	opacity: 0.7; */
}

p.Maintxt {
	text-align: center;
	font-size: 34px !important;
	font-weight: bold;
}


#title_reserve {
	margin: 172px 0 32px 0;
}

.hl_page_en {
	margin: 172px 0 47px 0;
}

.subhl {
	font-size: 28px;
	;
	margin: 0 0 42px 0;
}

.subhl_en {
	font-size: 36px;
	;
	margin: 0 0 38px 0;
}


#map {
	width: 600px;
	height: 400px;
	margin: 0 0 20px 0;
}


.table_reserve th,
.table_reserve td {
	width: 440px;
	padding: 20px 0;
}

.table_reserve th {
	width: 141px;
}

.link {
	display: inline-block;
	border: 1px solid;
	padding: 3px 5px;
	text-decoration: none;
}

.form_btn {
	display: inline-block;
	border: 1px solid;
	margin-top: 20px;
	padding: 15px 25px;
	color: #fff;
	text-decoration: none;
	transition: .3s all;
	line-height: 1.5;
}

.form_btn:hover {
	color: #d73f3f;
}

input:focus,
textarea:focus {
	outline: none;
}

.desc_box {
	margin: 0 0 16px 0;
	line-height: 2;
}

#contact_table {
	width: 100%;
	line-height: 2;
	font-size: 14px;
}

#contact_table p {
	margin: 0 0 -5px 0;
}

#contact_table .comment {
	text-align: right;
	display: block;
	margin: 0 13px 7px 0;
}

#contact_table .comment span {
	color: #ff0000;
}

#contact_table #btnarea {
	text-align: center;

}

#contact_table {
	border-collapse: collapse;
}

#contact_table td {
	border: 1px solid #ccc;
}

#contact_table td.hl_td_wrap {
	border: none;
	padding: 30px 0 25px 0;
}

#contact_table td .hl_td {
	color: #c9aa6c;
	padding: 0 0 3px 0;
	font-size: 133.3%;
	border-bottom: 1px solid #c9aa6c;
	width: 600px;
}

.formLeft {
	width: 140px;
	vertical-align: top;
	padding: 20px;
	line-height: 1.5;
	background: #fff;
	text-align: left;
	color: #000;
}

.formRight {
	width: 399px;
	padding: 20px;
}

.formRight dl dt {
	width: 40px;
	float: left;
}

.formRight ul li {
	margin: 0 0 15px 0;
}

#contact_table label {
	margin: 0 15px 0 0;
}

.inputStyle {
	font-size: 12px;
	color: #333;
	padding: 7px 10px;
	width: 400px;
	border: none;
	background: #fff;
}

.inputStyle-s {
	font-size: 12px;
	color: #333;
	padding: 7px 10px;
	width: 80px;
	border: none;
	background: #fff;
}

.textAreaStyle {
	font-size: 12px;
	color: #333;
	border: none;
	background: #fff;
	padding: 7px 10px;
	line-height: 150%;
	width: 400px;
	height: 150px;
}

.label_padding {
	margin: 10px 0 0 0;
	padding: 0;
	display: block;
}

.price {
	font-size: 1.5em;
	margin: 0 3px 0 0;
}

.nomark {
	padding: 0 0 0 22px;
}

.dropdown {
	border-right: #999 1px solid;
	border-top: #999 1px solid;
	font-size: 12px;
	border-left: #999 1px solid;
	color: #fff;
	border-bottom: #999 1px solid;

}

.necessary {
	color: #d73f3f;
	margin: 0 0 0 10px;
}

.posttitle,
.postdate {
	margin: 0 20px 0 0;
}

#btnarea {
	margin: 30px 0 0 0;
	text-align: center;
	display: flex;
	justify-content: center;
	gap: 20px;
	width: 100%;
}

#btnarea p {
	cursor: pointer;
	border: 1px solid #fff;
	padding: 10px 30px 8px;
	transition: 0.3s ease;
}

#btnarea p:hover {
	transition: 0.3s ease;
	background: #fff;
	color: #000;
}

.error {
	color: #c00;
}


#btn_modify {
	margin: 0 40px 0 0;
}

/*--/contact--*/
#form p.caution {
	margin-bottom: 20px;
}




/* --------------------- */

.en_rsv span {
	display: block;
	width: 505px;
	text-align: center;
	margin-bottom: 10px;
}


.leftinner {
	height: 100vh;
	position: sticky;
	top: 50px;
	left: 30px;
	display: flex;
	position: fixed;
	width: 317px;
	flex-direction: column;
	gap: 30px;
	overflow-y: scroll;
}

.leftinner::-webkit-scrollbar {
	width: 0;
}


/* bnr */
.bnr_sister {
	text-align: center;
	position: absolute;
	right: 50px;
	top: 50px;
}
.bnr_sister a img{
	max-width: 130px; 
	height: auto;
}
.bnr_sister span {
	display: block;
    font-size: 18px;
	color: #fff;
	margin-top: 10px;
}
