@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&display=swap');
@font-face {
 font-family: 'Hannari';
 src: url('fonts/HannariMincho-Regular.woff') format('woff'),
      url('fonts/HannariMincho-Regular.otf') format('opentype');
}

html {
 min-width: 100%;
 min-height: 100%;
	font-size: 62.5%;
}

body {
 font-family: 'Hannari'; /*, '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;*/
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	text-size-adjust: 100%;
	font-size: 2.0rem;
 line-height: 1.4;
	font-weight: 400;
	color: #333;
	background-color: #fff;
	position: relative;
 font-feature-settings: "palt" 1;
}
body,
body * {
	transition: all 0.2s;
}

.gothic {
	font-family: "Noto Sans JP", sans-serif;
}

img{
 margin: 0 auto;
}

.txt-center {
 text-align: center;
}
.txt-right {
 text-align: right;
}
.black {
	color: #1a1311;
}
.red {
 color: #f00;
}

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

header,
footer {
	color: #fff;
 width: 100%;
	padding: 20px 30px;
 background-color: rgba(0, 0, 0, 0.4);
}
header .hd_inner,
footer .ft_inner{
 display: flex;
 align-items: center;
 justify-content: space-between;
	width: 100%;
	max-width: 2000px;
	margin: 0 auto;
}
header a,
footer a {
	color: #fff;
	text-decoration: none;
}

 .is_sp {
  display: none !important;
 }
 .is_pc {
  display: block !important;
 }

/* Header
-------------------------------------------------*/
header {
 position: fixed;
	z-index: 100;
	top: 0;
	left: 0;
	padding: 10px 30px;
}
body.scroll header {
	transition: all 0.3s;
}
header h1,
footer h1{
 flex: 0 0 11.5%;
	max-width: 186px;
	margin-right: 2.5%;
}
body.scroll header h1 {
	flex: 0 0 8%;
	transition: all 0.3s;
}
header h1 img {
	width: 100%;
}
.left_content {
	flex: 0 0 51%;
	max-width: 625px;
	margin-right: auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.right_content,
footer .middle_content {
	flex: 0 0 40%;
	max-width: 425px;
	margin: 0 0 0 auto;
 display: flex;
 justify-content: space-between;
 align-items: center;
}
p.reserve {
 margin: auto 10px auto auto;
 border: 1px solid #fff;
 background-color: rgba(0, 0, 0, 0.4);
 background-blend-mode: multiply;
}
p.reserve:hover {
 background-color: rgba(160, 81, 70, 0.7);
}
p.reserve a.btn_reserve {
	display: block;
	box-sizing: border-box;
	width: 180px;
	padding: 5px 10px 8px;
	font-size: 2.4rem;
	letter-spacing: 0.05em;
	line-height: 1.1;
	color: #fff;
	text-align: center;
	text-decoration: none;
}
p.reserve a.btn_reserve span {
	display: block;
	margin: 0 auto;
	font-size: 1.8rem;
}
p.tel {
 font-size: 2.0rem;
 letter-spacing: 0.05em;
 margin: auto;
}
p.tel a {
	margin-left: 10px;
}

/* Global Menu
-------------------------------------------------*/
#global_menu,
#foot_menu {
	flex: 0 0 86%;
	display: flex;
	font-size: 2.0rem;
 margin-left: auto;
}
body.scroll #global_menu {
	flex: 0 0 89%;
}
#global_menu ul,
#foot_menu  ul {
	list-style: none;
 display: flex;
 margin: 0 auto 0 0;
 padding: 0;
 justify-content: space-between;
 text-align: center;
}
#global_menu ul li,
#foot_menu ul li {
 flex: 0 0 auto;
	margin: 0;
	padding: 0;
}
#global_menu ul li::before,
#foot_menu ul li::before {
 content: "";
 display: inline-block;
 vertical-align: middle;
 width: 1px;
 height: 23px;
 margin-bottom: 4px;
 background-color: #fff;
}
#global_menu ul li:first-child::before,
#foot_menu ul li:first-child::before {
	opacity: 0;
}
#global_menu ul a,
#foot_menu ul a {
	position: relative;
	padding: 0 30px;
	transition: all 0.3s;
}
#global_menu ul a::after,
#foot_menu ul a::after {
 content: '';
 position: absolute;
 left: 11%;
 width: 78%;
 height: 2px;
 background: #fff;
 bottom: -15px;
 transform: scale(0, 1);
 transform-origin: center top;
 transition: transform 0.3s;
}
#global_menu ul a:hover::after,
#foot_menu ul a:hover::after {
 transform: scale(1, 1);
}

#page_head .sp_menu{
 display: none;
}

/* Main Visual(Youtube)
-------------------------------------------------*/
#youtube {
 position: relative;
 z-index: 0;
	width: 100%;
	height: auto;
 aspect-ratio: 16 / 9;
 overflow: hidden;
	background: url("../images/postar.jpg") no-repeat;
	background-size: cover;
}
#postar,
#yt_mov,
#mov video,
#youtube .overlay {
 width: 100%;
 height: 100%;
}
#postar {
	position: relative;
	z-index: 1;
}
#yt_mov,
#mov {
 position: absolute;
	top: 0;
	left: 0;
 z-index: 2;
}
#mov video {
	display: block;
	width: 100%;
	height: auto;
 aspect-ratio: 16 / 9;
}
#yt_mov {
	opacity: 0;
}
#youtube .overlay {
 position: absolute;
 top: 0;
 left: 0;
 z-index: 3;
}
#yt_mov.appear {
	animation-name:PageAnimeAppear;
	animation-duration: 4s;
	animation-fill-mode:forwards;
}

@keyframes PageAnimeAppear{
	0% {
  opacity: 0;
	}
	90% {
  opacity: 0;
	}
	100% {
  opacity: 1;
 }
}

.pr_mov_link {
	margin: 10px 10px;
	text-align: left;
}
p.modal_mov {
	position: relative;
 display: block;
 width: max-content;
 margin: 0 0 0 auto;
 padding: 0;
 text-align: center;
}
p.modal_mov::before {
 content: "";
 position: absolute;
 bottom: 0;
 left: 0;
 z-index: 1;
 width: 100%;
 height: 100%;
 border-top: 1px solid #666;
 border-bottom: 1px solid #666;
 opacity: 0;
 transform: scale(0, 1);
 transition: all 0.3s;
}
p.modal_mov::after {
 content: "";
 position: absolute;
 bottom: 0;
 left: 0;
 z-index: 1;
 width: 100%;
 height: 100%;
 background-color:#4c4c4c;
 transition: all 0.3s;
}
p.modal_mov:hover::before {
 opacity: 1; 
 transform: scale(1, 1);
}
p.modal_mov:hover::after {
 opacity: 0;
 transform: scale(0, 1);
}


p.modal_mov a.play_icon {
	position: relative;
	z-index: 2;
 display: block;
 padding: 8px 20px 10px;
 line-height: 1;
 color: #fff;
 text-decoration: none;
 transition: all 0.3s;
}

p.modal_mov:hover a.play_icon {
	padding: 8px 5px 10px;
	letter-spacing: 0.1em;
	color: #000;
}
p.modal_mov a.play_icon::before {
	content: "\025B7";
	margin-right: 0.5em;
}


/* Main Block
-------------------------------------------------*/
main{
 display: block;
}
section {
	width: 95%;
	max-width: 1120px;
	margin: -120px auto 80px;
	padding: 150px 0 0;
}
section h2 {
 font-size: 4.0rem;
 line-height: 1;
 text-align: center;
 font-weight: 400;
 letter-spacing: 0.1em;
	margin: 0 auto 40px;
}
section h2::before {
 content: "";
 display: inline-block;
 vertical-align: middle;
 flex: 0 0 4vw;
	width: 4vw;
 max-width: 54px;
 height: auto;
 margin: 0 10px 10px 0;
 aspect-ratio: 1 / 1;
 background: url(../images/hd_marker.svg) no-repeat;
 background-size: contain;
}
section h3 {
	font-size: 2.8rem;
	margin: 0 0 10px;
	line-height: 1.1;
}
section p {
	margin-bottom: 1em;
	letter-spacing: -0.04em;
}
section p.price,
section p.modal_mov {
	display: block;
	box-sizing: border-box;
	width: 80%;
	margin: 40px 0;
	line-height: 1.1;
	letter-spacing: normal;
	text-align: center;
}
section p.price {
	padding: 4px 0 8px;
	border: 1px solid #000;
}

.flex_block {
 display: flex;
 justify-content: space-between;
 align-items: flex-start;
}
.flex_block.col2 > .img_block {
	flex: 0 0 50%;
	max-width: 550px;
}
.flex_block.col2 > .txt_block {
	flex: 0 0 47%;
}
.flex_block .left_side {
	order: 1;
}
.flex_block .right_side {
	order: 2;
}


/* Read Block -----------------------------------*/
#read_sec {
	text-align: center;
	font-size: 2.4rem;
	margin-top: 0;
	padding-top: 0;
}
#read_sec h2 {
	font-size: 4.8rem;
	margin-bottom: 1em;
}
#read_sec h2::before {
	content: none;
}
#read_sec p {
	margin-bottom: 2em;
	letter-spacing: normal;
}

/* Access Block -----------------------------------*/
#access .gmap {
	width: 100%;
	height: auto;
	aspect-ratio: 275 / 149;
}
#access .gmap iframe {
	width: 100%;
	height: 100%;
}
#access address {
	font-style: normal;
	margin: 10px 0 40px;
}
#access address ul {
	list-style: none;
	display: flex;
	margin: 0;
	padding: 0;
}
#access address li {
	width: max-content;
	margin: 0 0 0 1em;
	font-size: 1.8rem;
}
#access address li:first-child {
	margin-left: 0;
}

/* Footer
-------------------------------------------------*/
footer {
 display: flex;
 align-items: center;
 justify-content: space-between;
	width: 100%;
}
footer .middle_content {
 margin: 0 0 0 auto;
}
footer .right_content {
	flex: 0 0 13.2%;
	max-width: 180px;
	margin: 0 0 0 auto;
}
footer .fukujuya_bnr {
	width: 100%;
	padding: 5px;
	border: 1px solid #fff;
	background-color: rgba(0, 0, 0, 0.4);
	transition: all 0.3s;
}
footer .fukujuya_bnr:hover {
	background-color: rgba(164, 142, 42, 0.7);
}
footer .fukujuya_bnr a {
	display: block;
	width: 100%;
}
footer .fukujuya_bnr img {
	display: block;
	width: 100%;
	height: auto;
}

/* Page Top
-------------------------------------------------*/
p.page_top {
 position: fixed;
 right: 2%;
 bottom: 8%;
 z-index: 10;
}
p.page_top a {
 position: relative;
 display: block;
 width: 60px;
 height: 60px;
 text-indent: -9999px;
 overflow: hidden;
 border: 2px solid #fff;
 border-radius: 50%;
 background-color: rgba(0,0,0,0.5);
 opacity: 0.9;
}
p.page_top a::before {
 content: "";
 position: absolute;
 top: 50%;
 left: 50%;
 display: block;
 width: 20px;
 height: 20px;
 border-style: solid;
 border-width: 5px 5px 0 0;
 border-color: #fff #fff transparent transparent;
 transform: rotate(-45deg) translate(-10%, -55%);
 transition: all 0.3s;
}
p.page_top a:hover {
 opacity: 0.65;
 transition: all 0.3s;
}

/* For English Style
-------------------------------------------------*/
html:lang(en) body {
	font-size: 1.8rem;
	letter-spacing: -0.04em;
}
html:lang(en) section h2 {
	letter-spacing: normal;
}
html:lang(en) #read_sec h2 {
	font-size: 4.0rem;
	margin-bottom: 1em;
}
html:lang(en) #read_sec p {
	margin-bottom: 1.8em;
	letter-spacing: -0.04em;
}
html:lang(en) section p.price, section p.modal_mov {
	letter-spacing: -0.04em;
}
html:lang(en) p.modal_mov:hover a.play_icon {
	letter-spacing: 0.03em;
}

/*-------------------------------------------------
End English Style */


/* For Responsive Style
-------------------------------------------------*/
@media only screen and (max-width: 1530px){
	html {
  font-size: 0.65vw;
 }
/* Header ---------------------------------------*/
	.right_content,
	footer .middle_content {
		flex: 0 0 35%;
	}
	#global_menu, #foot_menu {
  font-size: 2.15rem;
 }
 #global_menu ul a, #foot_menu ul a {
  padding: 0 15px;
 }
	
	p.reserve a.btn_reserve {
  font-size: 2.0rem;
  width: fit-content;
  padding: 5px 14px 8px;
 }
	p.reserve a.btn_reserve span {
		font-size: 1.5rem;
	}
}

@media only screen and (max-width: 820px){
	#global_menu ul a, #foot_menu ul a {
		padding: 0 10px;
	}
}

/* For Mobile Style
-------------------------------------------------*/
@media only screen and (max-width: 767px){
	html{
  font-size: 3.8vw;
	}
 body{
  line-height: 1.6;
		font-size: 1rem;
 }
	
 a[href^="tel:"] {
  pointer-events: all;
 }

	.left_content,
	footer .middle_content,
	.right_content {
		display: block;
		flex: none;
		width: 100%;
		max-width: 100%;
		margin-left: auto;
		margin-right: auto;
	}
	p.modal_mov {
  width: 100%;
 }
	
 .is_sp {
  display: block !important;
 }
 .is_pc {
  display: none !important;
 }

/* Header ---------------------------------------*/
	header,
 body.scroll header {
		padding: 10px 20px;
	}
	header h1,
	body.scroll header h1 {
  flex: 0 0 20%;
		position: relative;
		z-index: 110;
 }
 
/* Global Menu ---------------------------------------*/
 #global_menu {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 100;
		display: none;
		flex-direction: column;
		justify-content: center;
		align-items: center;
  width: 100vw;
  height: 100vh;
		font-size: 1.4rem;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(3px);
		transform: scale(0,0);
		animation-name: FadeOUT;
  animation-duration: 0.3s;
  animation-fill-mode: forwards;
  transition: 0.3s all;
 }
	#global_menu.open {
		display: flex;
		transform: scale(1,1);
		opacity: 1;
		animation-name: FadeIN;
  animation-duration: 0.3s;
  animation-fill-mode: forwards;
  transition: 0.3s all;
	}
	
	.sp_menu {
		position: relative;
		z-index: 110;
		display: block;
		width: 7vw;
		height: 7vw;
	}
	.sp_menu::before,
	.sp_menu::after {
		content: "";
	}
	.sp_menu span,
	.sp_menu::before,
	.sp_menu::after {
		position: absolute;
		left: 0;
		display: block;
		width: 100%;
		height: 2px;
		background-color: #fff;
		transition: all 0.5s;
	}
	.sp_menu span {
		top: 50%;
		opacity: 1;
	}
	.sp_menu::before {
		top: 10%;
	}
	.sp_menu::after {
		bottom: 4%;
	}
	.sp_menu.enabled span {
		opacity: 0;
		transform: scale(0.5, 1);
	}
 .sp_menu.enabled::before {
		top: 50%;
  transform: rotate(-135deg) translate(0px, 1px);
	}
	.sp_menu.enabled::after {
		bottom: 50%;
  transform: rotate(135deg) translate(1px, -1px);
	}

	
	#global_menu ul {
		display: block;
		width: 90%;
		margin: 0 auto;
	}
	#global_menu ul li {
		width: 100%;
		padding: 10px 0;
		text-align: center;
		border-top: 1px solid #fff;
	}
	#global_menu ul li::before {
		content: none;
	}
	#global_menu ul a {
		display: block;
		width: 100%;
		padding: 5px 10px;
	}
	#global_menu p.reserve,
	#global_menu p.tel{
		width: 90%;
		margin: 0 auto;
	}
	#global_menu p.tel {
  margin: 15px auto;
		text-align: center;
 }

 
/* Main ---------------------------------------*/
	section {
  width: 90%;
  margin: -70px auto 30px;
  padding: 80px 0 0;
	}
	#read_sec {
  margin: 30px auto;
		font-size: 1.0rem;
 }
	#read_sec h2 {
  font-size: 2.4rem;
		margin-bottom: 24px;
 }
	#read_sec p {
		margin-bottom: 1.3em;
		letter-spacing: -0.05em;
	}
	
	section h2 {
  font-size: 2.1rem;
  margin-bottom: 20px;
 }
	section h2::before {
  flex: 0 0 9vw;
  width: 9vw;
  margin: 0 5px 10px 0;
 }
	section h3 {
		font-size: 1.6rem;
	}
 .flex_block {
  flex-direction: column;
 }
	.flex_block.col2 > * {
		margin-bottom: 20px;
	}
	.flex_block.col2 > .img_block {
		order: 1;
		flex: 0 0 100%;
		width: 100%;
		max-width: 100%;
	}
	.flex_block.col2 > .img_block img {
		width: 100%;
	}
	section p.price,
	section p.modal_mov{
		width: 100%;
		text-align: center;
		margin: 20px auto;
	}
	
	#access ul {
		padding: 0 0 0 1.6em;
	}
	#access .gmap {
  aspect-ratio: 1 / 1;
	}
	#access address {
		margin-bottom: 20px;
	}
 #access address ul {
		flex-wrap: wrap;
	}
	#access address li {
		font-size: 1rem;
		margin-left: 0;
	}
	#access address li:last-child {
		margin-left: 1.4em;
	}
	
 
/* Footer ---------------------------------------*/
	footer .ft_inner,
	#foot_menu,
	#foot_menu ul,
	#foot_menu ul li{
		display: block;
		width: 100%;
	}
	footer {
		padding: 15px;
	}
	footer h1 {
		display: block;
		width: 40%;
		margin: 0 auto 10px;
	}
	#foot_menu {
		font-size: 1rem;
	}
	#foot_menu ul li::after {
		content: "";
		display: block;
		width: 100%;
		height: 1px;
		background-color: #fff;
	}
	#foot_menu ul li::before,
	#foot_menu ul li:last-child::after,
	#foot_menu ul a::after {
		content: none;
	}
	#foot_menu ul a {
		display: block;
		width: 100%;
		padding: 10px 0;
		text-align: left;
	}
	p.reserve,
	p.reserve a.btn_reserve {
		width: 100%;
		margin: 0 auto;
  font-size: 1.5rem;
  padding: 5px 0 7px;
	}
	p.reserve a.btn_reserve span {
  display: inline;
  vertical-align: text-bottom;
  margin-left: 1em;
  font-size: 1.4rem;
 }
	p.tel {
  font-size: 1.6rem;
  margin: 10px 0;
 }
	footer .right_content {
  margin: 20px auto 10px;
		width: 50%;
 }
	

/* Page Top -------------------------------------*/
 p.page_top {
		bottom: 2%;
  margin: 10px auto;
 }
 p.page_top a{
  margin: 0 auto;
  width: 12vw;
  height: 12vw;
 }
 p.page_top a::before {
  width: 4vw;
  height: 4vw;
  border-width: 3px 3px 0 0;
  transform: rotate(-45deg) translate(-20%, -50%);
 } 
}
/*-------------------------------------------------
End Mobile Style */

@keyframes FadeIN {
 0% {
  opacity: 0;
  transform: scale(0,0);
 }
 100% {
  opacity: 1;
  transform: scale(1,1);
 }
}
@keyframes FadeOUT {
 0% {
  opacity: 1;
  transform: scale(1,1);
 }
 100% {
  opacity: 0;
  transform: scale(0, 0);
 }
}

/* For Print Style
-------------------------------------------------*/
@media print {
 body {
  padding-left: 0;
  width: 1200px;
  transform: scale(0.88);
  transform-origin: 0 0;
 }
}
@page {
 size: A4;
 margin-bottom: -57.73mm;
}
/*-------------------------------------------------
End Print Style */

