@charset "UTF-8";

/* -----------------------------------------------
 *  	         base style setting
 * ----------------------------------------------- */

/* =========== font =========== 
@font-face {
  font-family: "Quickpen";
  src: url("../font/Quickpen/2F7BEE_0_0.eot?#iefix");
  src: url("../font/Quickpen/2F7BEE_0_0.eot?#iefix") format("eot"), url("../font/Quickpen/2F7BEE_0_0.woff2") format("woff2"), url("../font/Quickpen/2F7BEE_0_0.woff") format("woff");
}

@font-face {
  font-family: "Yumintyo";
  src: url("../font/yumintyo/yumin.ttf") format("ttf");
  src: url("../font/yumintyo/yumin.woff") format("woff");
}
*/

/* =========== base =========== */
html {
  margin: 0;
  padding: 0;
  font-size: 62.5%;
}

body {
  position: relative;
  margin: 0;
  padding: 0;
  color:#7c7963;
  background-color: #faf8f3;
  word-wrap: break-word;
  font-size: 14px;
  font-size: 1.4rem;
  font-family: YakuHanJP,"Noto Sans Japanese","メイリオ", "Meiryo", "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", sans-serif;
  line-height: 1.6;
  opacity:0;

  overflow-wrap: break-word;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
}
@media only screen and (max-width: 48em) {
  body {
    font-size: 12px;
    font-size: 1.2rem;
  }
}

article,
aside,
figure,
figcaption,
details,
footer,
header,
hgroup,
nav,
section,
summary,
div,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
li,
dl,
dt,
dd {
  margin: 0;
}

ul,
input {
  padding: 0;
}

article,
aside,
figure,
figcaption,
details,
footer,
header,
hgroup,
nav,
section,
summary,
div,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
li,
dl,
dt,
dd,
th,
td {
  box-sizing: border-box;
}

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

img {
  width: 100%;
  width: 100%\9;
  border: none;
  vertical-align: middle;
}

svg{width:100%;}

a {
	color:#beae7d;
	}
a:hover {
	text-decoration:none;
	}

/* font_yumin */
.yumin{
    font-family:"Yu Mincho","Yumintyo";
    font-weight: bold;
}

.italic{
    font-family:"Times New Roman", Times, "serif";
    font-weight: normal;
    font-style: italic;
}

/* =========== youtube setting =========== */
.youtube {
  position: relative;
  width: 100% !important;
  padding-top: 56.19%;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}


/* =========== imageLoaded =========== */
div#loadingArea{
    position: fixed;
    width: 100%;
    height: 100%;
    background-color: #fff;
    z-index: 500;
}
div.loading_image{
    position: absolute;
    top: 0; bottom: 0; left: 0; right: 0;
    margin: auto;
    width: 35px; /*★35*/
    height: 35px; /*★35*/
}
div.loading_image img{
    
}

div#progressBar{
    position: fixed;
    top: 0;
    left: 0;
    height: 5px;
    width: 0%;
    background-color: #beae7d;
    z-index: 501;
}

div#imageLoaded{
}

div#imageLoaded img{
    width: 35px;
}
p#pst{
    font-size: 45px;
}
p#maisu{
    font-size: 45px;
}

div.imgBackTest{
    background-image: url(./test7.jpg);
    width: 200px;
    height: 200px;
    background-size: cover;
}



/* =========== map_custmomize =========== */
div#map_custmomize{
	width:100%;
	height:550px;
	border:solid 1px #A7A7A7;
	}

/* =========== pageBase =========== */
div.base_area {
  position: relative;
  margin:0;
  padding:0;
  min-width: 320px;
  width: 100%;
}

/* =========== mainArea =========== */
div.main_area {
  	position: relative;
	width:100%;
	margin:0;
	padding:0;
	z-index:2;
}
/* 480px */
@media only screen and (max-width: 30em) {
div.main_area {
	width:100%;/* header分 */
	margin:0;
}
}




/* =========== headerArea =========== */
header.header_area{
    position: relative;
	  width:100%;
	  height: 90vh;
	  margin:0;
	  padding:0;
/*    background-image: url("../../img/mainvisual.jpg"); */
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    z-index: 1;
	}
header.header_area.schedule{
	  height: 60vh !important;
/*    background-image: url("../../schedule/img/mainvisual.jpg"); */
	}
header.header_area img{
  width: 30%;
  margin: auto;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  z-index: 10;
	}
div.header_area_inner{
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    background-image: url("../img/header_parts_1.png"),url("../img/header_parts_2.png");
    background-repeat: no-repeat;
    background-position: left center,right center;
    width: 100%;
    z-index: 2;
    }
div.header_area_inner_inner{
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    margin: auto;
    height: 100%;
    background-image: url("../img/header_parts_3.png"),url("../img/header_parts_3.png");
    background-repeat: no-repeat;
    background-position: left center,right center;
    width: 50%;
    z-index: 3;
    transition: all 0.3s;
    }
h1.main_heading_01{
    font-size: 12px;
    color: #fff;
    text-align: center;
    font-weight: normal;
    padding-top: 21px;
}

/* 768px */
@media only screen and (max-width: 45em) {
header.header_area img{
  width: 85%;
	}
div.header_area_inner_inner{
    width: 90%;
    }
}

/* 480px */
@media only screen and (max-width: 30em) {
header.header_area{
    position: relative;
	  width:100%;
	  height: 80vh;
	  margin:0;
	  padding:0;
    background-image: url("../../img/mainvisual_sp.jpg");
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    z-index: 1;
	}
header.header_area.schedule{
	  height: 20vh !important;
	}
div.header_area_inner{
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    background-image: url("../img/header_parts_1.png"),url("../img/header_parts_2.png");
    background-repeat: no-repeat;
    background-position: left center,right center;
    width: 100%;
    z-index: 2;
    }
div.header_area_inner_inner{
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    margin: auto;
    height: 100%;
    background-image: url("../img/header_parts_sp.png");
    background-repeat: no-repeat;
    background-position: left center;
    background-size: contain;
    width: 100%;
    z-index: 3;
    transition: all 0.3s;
    }
h1.main_heading_01{
    font-size: 12px;
    color: #fff;
    text-align: center;
    font-weight: normal;
    padding-top: 30px;
}
}


/*=====■navigation_area=====*/
section.navigation_area{
    display: none;
	position: fixed;
	top: 0;
	left: 0;
    width: 100%;
    height: 100%;
    z-index: 4;    
    background-color: #fff;
}
/*上の色*/
section.navigation_area::before{
    display: block;
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 46px;
    background-color: #beae7d;
}

section.navigation_area nav.global_navigation{
    max-width: 400px;
	margin: 0 auto;
	padding: 96px 20px 20px 20px;
}

/*メインナビリスト*/
ul.global_navigation_list{
	list-style: none;
}
ul.global_navigation_list li{
	line-height: 1;
	padding: 0;
	text-align: left;
}
ul.global_navigation_list li a{
	display: block;
	margin: 0 0 20px 0;
    color: #beae7d;
    font-size: 30px;
	box-sizing: border-box;
    text-decoration: none;
    line-height: 1.5;
    font-weight: 100;
    font-style: oblique;
    letter-spacing: 2px;
}
ul.global_navigation_list li a > span{
    font-size: 12px;
    color: #000;
    padding-left: 10px;
    font-weight: normal;
}

ul.global_navigation_list li a:hover{
}





/*=====header_trigger=====*/
div.navigation_trigger{
	position: fixed;
	top: 30px;
	right: 30px;
	height: 80px;
	width: 80px;
	cursor: pointer;
	z-index: 10;
    background-color: #fff;
    box-shadow: 1px 1px 5px rgba(0,0,0,0.2);
    border-radius: 50%;
}
div.navigation_trigger::after{
    content: "MENU";
    display: block;
	position: absolute;
    top: 44px;
    text-align: center;
    font-size: 12px;
    font-weight: normal;
    width: 100%;
}
div.navigation_trigger span.navigation_trigger_parts{
	position: absolute;
	display: block;
	width: 25px;
	height: 4px;
    left: 0;
    right: 0;
    margin: auto;
	background-color: #000;
	transition: all 0.3s;
}

div.navigation_trigger span.navigation_trigger_parts.trigger_parts1{
	top: 22px;
}
div.navigation_trigger span.navigation_trigger_parts.trigger_parts2{
	top: 30px;
}
div.navigation_trigger span.navigation_trigger_parts.trigger_parts3{
    top: 38px;
}
/*hover effect*/
div.navigation_trigger:hover span.navigation_trigger_parts.trigger_parts3{
}

/*=====header_trigger__is_open=====*/
div.navigation_trigger.is_open{

}
div.navigation_trigger.is_open span.navigation_trigger_parts{
	margin: auto;
}
div.navigation_trigger.is_open span.navigation_trigger_parts.trigger_parts1{
	top: 30px;
	transform: rotate(45deg);
}
div.navigation_trigger.is_open span.navigation_trigger_parts.trigger_parts2{
	opacity: 0;
}
div.navigation_trigger.is_open span.navigation_trigger_parts.trigger_parts3{
	top: 30px;
	transform: rotate(-45deg);
}
/* 480px */
@media only screen and (max-width: 30em) {
div.navigation_trigger{
	position: fixed;
	top: 10px;
	right: 10px;
	height: 80px;
	width: 80px;
	cursor: pointer;
	z-index: 10;
    background-color: #fff;
    box-shadow: 1px 1px 5px rgba(0,0,0,0.2);
    border-radius: 50%;
}
}

div .mat-icon-button{
  border: none;
  z-index: 100;
}

.badge {
  position: absolute;
  top: 0;
  right: 1%;
  font-size: 12px;
  line-height: 13px;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  background-color: #ff0000; 
  border: 4px solid #ff0000;
  color: #ffffff;
  text-align: center;
}

.badge2 {
  top: 3px;
  float: right;
  font-size: 12px;
  line-height: 13px;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  background-color: #ff0000; 
  border: 4px solid #ff0000;
  color: #ffffff;
  text-align: center;
}
.badge2_day {
  top: 3px;
  left: 1%;
  font-size: 12px;
  line-height: 13px;
  display: block;
  width: 30px;
  height: 20px;
  color: #ff0000;
  text-align: center;
}

.badge3 {
  position: absolute;
  margin-bottom: 3px;
  left: 0;
  margin-left: auto;
  font-size: 12px;
  line-height: 13px;
  width: 50px;
  /*border-radius: 10%;*/
  height: 20px;
  background-color: #ff0000; 
  border: 4px solid #ff0000;
  color: #fff;
  text-align: center;
}

/* =========== headerArea =========== */





/* =========== contentArea =========== */
div.content_area {
}
/* 1024px */
@media only screen and (max-width: 64em) {
div.content_area {
}
}
/* 864px */
@media only screen and (max-width: 54em) {
div.content_area {
}
}


/* =========== asideArea =========== */
/*contact*/
article.aside_contact_arti{
	margin: 0 auto;
	padding: 15px 0;
	background-color: #000000;
	color: #fff;
}
/*svg*/
svg.svg_aside_contact_logo{
	float: left;
	width: 130px;
	height: 60px;
	padding-top: 20px;
	fill:#ffffff;
}

div.aside_contact_arti_inner{
	float: left;
	width: calc(100% - 130px);
	text-align: center;
}

div.aside_contact_arti_inner h2{
	display: inline-block;
	font-size: 34px;
	font-family: 'Spectral', serif;
	font-weight: normal;
}
div.aside_contact_arti_inner h2 span{
	display: inline-block;
	margin: 0 10px 0 0;
	padding: 0 0 0 10px;
	font-size: 14px;
	font-size: 1.4rem;
	font-family:"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
}
div.aside_contact_arti_inner h2::after{
	display: inline-block;
	content: "";
	height: 1px;
	vertical-align: middle;
	width: 150px;
	background: #fff;
}
div.aside_contact_arti_inner a.aside_tell{
	display: inline;
	color: #ffffff;
	font-family: 'Spectral', serif;
	font-size: 34px;
	margin: 0 10px 0 0;
}
dl.aside_contact_dl{
	display: inline-block;
	font-size: 10px;
	line-height: 1.4;
	text-align: left;
}
dl.aside_contact_dl dt{
	float: left;
	width: 40px;
}
dl.aside_contact_dl dd{
	width: 200px;
}
/* 480px */
@media only screen and (max-width: 30em) {
svg.svg_aside_contact_logo{
	float: none;
	width: 100%;
	height: 45px;
	padding-top: 10px;
}
div.aside_contact_arti_inner{
	float: none;
	width: 100%;
}
div.aside_contact_arti_inner h2{
	display: block;
	font-size: 28px;
}
div.aside_contact_arti_inner h2 span{
	display: inline-block;
	margin: 0 10px 0 0;
	padding: 0 0 0 10px;
	font-size: 11px;
	font-size: 1.1rem;
}
div.aside_contact_arti_inner h2::after{
	display: block;
	width: 200px;
	margin: 0 auto;
}
div.aside_contact_arti_inner a.aside_tell{
	display: block;
	font-size: 24px;
	margin: 0 0 5px 0;
}
dl.aside_contact_dl{
	display: inline-block;
	font-size: 12px;
	line-height: 1.4;
	text-align: left;
}
dl.aside_contact_dl dt{
	float: left;
	width: 45px;
}
dl.aside_contact_dl dd{
	width: 200px;
}
}


/*instagram*/
article.aside_instagram_arti{
}

h2.aside_instagram_title{
	padding: 10px 0 0 0;
	text-align: center;
	font-family: 'Spectral', serif;
	font-size: 22px;
	font-size: 2.2rem;
	font-weight: normal;	
}

p.aside_instagram_txt{
	margin: 0 0 10px 0;
	text-align: center;
	font-family: 'Spectral', serif;
	font-size: 16px;
	font-size: 1.6rem;
}
svg.svg_aside_intragram_icon{
	display: inline-block;
	width: 18px;
	height: 18px;
	vertical-align:middle;
}


/* instafeed */
ul.aside_instafeed{
	width:100%;
	margin:0 auto;
	list-style:none;
	}
ul.aside_instafeed:after {
  display: block;
  visibility: hidden; 
  clear: both;
  height: 0;
  content: "";
}
ul.aside_instafeed li{
	float:left;
	width:11.111111111%;
	margin:0;
	padding:0;
	outline:solid 3px #FFFFFF;
	}
ul.aside_instafeed li img{
	width:100%;
	height:100%;
	margin:0;
	padding:0;
	line-height:0;
	}

/* 768px */
@media only screen and (max-width: 48em) {
ul.aside_instafeed{
	width:94%;
	margin:0 auto;
	}
ul.aside_instafeed li{
	width:33.333333%;
	}
}
/* 480px */
@media only screen and (max-width: 30em) {
article.aside_instagram_arti{
	margin: 0 0 10px 0;
}
}

/* =========== asideArea =========== */



/* =========== footerArea =========== */
footer.footer_area {
	position:relative;
	width:100%;
  	margin:0;
  	padding:20px 0 0 0;
	text-align:center;
	z-index:2;
}

/*footerlogo*/
div.footer_logo_box{
	margin: 0 auto 10px;
	text-align: center;
    width: 80px;
}

div.footer_logo_box a{
}

div.footer_logo_box a svg.svg_footer_logo{
	width: 200px;
	height: 35px;
	fill:#000;
}

/* adress */
address.footer_address_box{
    padding: 10px 0;
}
address.footer_address_box p{
    text-align: center;
    font-size: 14px;
    font-style: normal;
}

address.footer_address_box a.footer_tell{
    text-align: center;
    font-size: 24px;
    font-style: normal;
    text-decoration: none;
    font-weight: bold;
}

/* footer sns area */
div.footer_sns_area{
	margin:0 0 10px 0;
	padding:0;
	}

ul.sns_list{
	}
	
ul.sns_list li{
	display: inline-block;
	margin:0 5px 0 0;
	width:20px;
	height:20px;
	}
ul.sns_list li::last-child{
	margin:0 0 0 0;
	}
ul.sns_list li a{
	position: relative;
	display:block;
	width: 100%;
	height: 100%;
	}
	
ul.sns_list li a svg{
	position: absolute;
	top:0;
	bottom:0;
	left: 0;
	right: 0;
	margin: auto;
	fill:#fff;
	width:20px;
	height:20px;
	}


/* footerOtherPageNavi */
nav.footer_nav{
	display: flex;
	margin: 0 auto 20px;
	}	
nav.footer_nav ul.footer_nav_list{
	width: 20%;
	margin: 0;
	padding: 0;
	text-align: left;
	}
nav.footer_nav ul.footer_nav_list li{
	display:block;
	margin:0;
	font-size:1.2em;
	font-size:12px;
	}
nav.footer_nav ul.footer_nav_list li a{
	text-decoration:none;
	letter-spacing:2px;
	color: #fff;
	}
/* 768px */
@media only screen and (max-width: 48em) {
nav.footer_nav{
	display: flex;
	flex-wrap: wrap;
	}	
nav.footer_nav ul.footer_nav_list{
	width: calc(100%/3);
	text-align: center;
	}
}

/* footer_copy */
small.footer_copy{
	display: block;
	text-align:center;
	font-size:1.0em;
	font-size:10px;
	letter-spacing: 1.4px;
	padding: 20px 0;
	}

/* 480px */
@media only screen and (max-width: 30em) {
footer.footer_area {

}

/*footerlogo*/
div.footer_logo_box{
	margin: 0 auto 10px;
	text-align: center;
}

div.footer_logo_box a{
}

div.footer_logo_box a svg.svg_footer_logo{
	width: 100%;
	height: 50px;
}
}

/* =====pagetop_btn===== */
.pagetop {
    height: 40px;
    width: 40px;
    position: fixed;
    right: 1%;
    bottom: 2%;
    background: #beae7d;
/*    border: solid 1px #beae7d; */
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2;
/*    opacity: 80%;　*/
}

.pagetop__arrow {
    height: 10px;
    width: 10px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    transform: translateY(20%) rotate(-45deg);
}

.pagetop:hover {
    background: #7c7963;
    transition: 0.5s;
}
.pagetop__arrow:hover {
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    transform: translateY(20%) rotate(-45deg);
}

/* 480px */
@media only screen and (max-width: 30em) {
.pagetop {
    height: 40px;
    width: 40px;
    right: 1%;
    bottom: 1%;
    opacity: 80%;
}

.pagetop__arrow {
    height: 10px;
    width: 10px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    transform: translateY(20%) rotate(-45deg);
}
}
/* =====pagetop_btn end ===== */



/* 1400px */
@media only screen and (max-width: 87.5em) {
}
/* 1024px */
@media only screen and (max-width: 64em) {
}
/* 960px */
@media only screen and (max-width: 60em) {
}
/* 768px */
@media only screen and (max-width: 48em) {
}
/* 720px */
@media only screen and (max-width: 45em) {
}
/* 600px */
@media only screen and (max-width: 37.5em) {
}
/* 480px */
@media only screen and (max-width: 30em) {
}
/* 320px */
@media only screen and (max-width: 20em) {
}