@charset "utf-8";

/*++++++++++++++++++++++++++++++ reset ++++++++++++++++++++++++++++++*/
/* HTML5 display definitions */ section, nav, article, aside, hgroup, header, footer, figure, figcaption, details {display: block; } video, audio, canvas {display: inline-block; *display: inline; *zoom: 1; } audio:not([controls]) {display: none; } [hidden] {display: none; } /* The root element */ html {font-size: 100%; overflow-y: scroll; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; } /* Sections */ body {font-family: sans-serif; margin: 0; } h1, h2, h3, h4, h5, h6 {font-size: 1em; margin: 0; } /* Grouping content */ p, blockquote, dl, dd, figure {margin: 0; } hr {color: inherit; height: auto; -moz-box-sizing: content-box; box-sizing: content-box; } pre {font-family: monospace, sans-serif; white-space: pre-wrap; word-wrap: break-word; margin: 0; } ol, ul {padding: 0; margin: 0; } li {list-style: none; } /* Text-level semantics */ a:focus {outline: none /*thin dotted*/; } a:hover, a:active {outline: 0; } strong, b {font-weight: bold; } small {font-size: 0.83em; } q {quotes: none; } abbr[title] {border-bottom: 1px dotted; } code, samp, kbd {font-family: monospace, sans-serif; } mark {color: black; background-color: yellow; } sub, sup {font-size: 0.83em; line-height: 0; vertical-align: baseline; position: relative; } sub {bottom: -0.25em; } sup {top: -0.5em; } br {letter-spacing: 0; } /* Embedded content */ img {width: 100%; border: 0; vertical-align: bottom; -ms-interpolation-mode: bicubic; } svg:not(:root) {overflow: hidden; } /* Tabular data */ table {border-collapse: collapse; border-spacing: 0; } caption {padding: 0; text-align: left; } th, td {text-align: left; vertical-align: baseline; padding: 0; } /* Forms */ form {margin: 0; } fieldset {border: 0; padding: 0; margin: 0; } legend {border: 0; *margin-left: -7px; } input, button, select, textarea {font-family: inherit; font-size: 1em; color: inherit; margin: 0; } input, button {line-height: normal; vertical-align: inherit; *vertical-align: middle; } input::-moz-focus-inner, button::-moz-focus-inner {border: 0; padding: 0; } input[type="search"] {-webkit-appearance: textfield; -webkit-box-sizing: content-box; -moz-box-sizing: content-box; box-sizing: content-box; } input[type="search"]:focus {outline-offset: -2px; } input[type="search"]::-webkit-search-decoration {-webkit-appearance: none; } input[type="checkbox"], input[type="radio"] {box-sizing: border-box; padding: 0; } input[type="submit"], input[type="reset"], input[type="button"], button {cursor: pointer; -webkit-appearance: button; *overflow: visible; } select {background-color: inherit; line-height: normal; } textarea {vertical-align: top; overflow: auto; *font-family: sans-serif; } address {font-style: normal; }
h1, h2,h3, h4, h5, h6, th, td {font-weight: normal; }
* {margin: 0; padding: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }
/*============================== reset ==============================*/

/*++++++++++++++++++++++++++++++ common ++++++++++++++++++++++++++++++*/
a			{color: rgba(53, 32, 0, 1); }
a:link			{text-decoration: none; }
a:visited		{text-decoration: none; }
a:hover		{text-decoration: underline; }
a:active		{text-decoration: none; }

footer a		{color: #fff; }
footer a:link	{text-decoration: none; }
footer a:visited	{text-decoration: none; }
footer a:hover	{text-decoration: underline; }
footer a:active	{text-decoration: none; }

.goth		{font-family: 'Lucida Sans Unicode', 'Lucida Grande', Verdana, '游ゴシック', YuGothic, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, sans-serif; }
.serif		{font-family: 'Times New Roman', '游明朝', YuMincho, 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'メイリオ', Meiryo, serif; }
.mono	{font-family: 'Osaka－等幅', Osaka-mono, 'ＭＳ ゴシック', 'MS Gothic', monospace; }
.goth_m	{font-family: 'ヒラギノ丸ゴ ProN W4', 'Hiragino Maru Gothic ProN', 'メイリオ', Meiryo, fantasy; }	/* Maru-Gochic for OS X only*/

div.clear {clear: both; width: 0; height: 0; }
br.spc {display: none; }
div.hidden {overflow: hidden; }
th {white-space: nowrap; }
hr {height: 1px; margin: 5px 0; background: #ba9; border: 0; display: none; }
/*============================== common ==============================*/


/*++++++++++++++++++++++++++++++ basic ++++++++++++++++++++++++++++++*/
*	{
	margin:0;
	padding:0;
	font-size: 100%;
	}
html, body {
	width: 100%;
	height: 100%;
	}
html {font-size: 62.5%; }
body {
	font-family: AXIS Std, Yu Gothic, "メイリオ", Meiryo, sans-serif;
	background: rgba(53, 32, 0, 1);
	margin: 0 auto;
	padding: 0;
	font-size: 1.4em;
	line-height: 2.5;
	color: #4e3612;	/* main font color */
	letter-spacing: 0;
	animation: fx-body 1.5s ease 0.1s 1 normal both;
	-webkit-animation: fx-body 1.5s ease 0.1s 1 normal both;
	}
@keyframes fx-body {
	0%	{opacity: 0; }
	100%	{opacity: 1; }
	}
@-webkit-keyframes fx-body {
	0%	{opacity: 0; }
	100%	{opacity: 1; }
	}
/*============================== basic ==============================*/



/* GENERAL STYLES
**************************************************************************************************** */
body>div {
	position: relative;
	width: 100%;
	margin: 0 auto;
	border: solid 0px #000;
	}

div.header {
	position: absolute;
	width: 100%;
	border: dotted 0px #f00;
	pointer-events: none;
	z-index: 15;
	}

/*
header {
	background: rgba(255, 255, 255, 0.85);
	position: absolute;
	top: 100%;
	width: 100%;
	height: 80px;
	padding: 0;
	z-index: 15;
	border-bottom: solid 0px #f00;
	}
*/

header {
	background: rgba(255, 255, 255, 0.85);
	position: fixed;
	top: 0;
	width: 100%;
	height: 80px;
	padding: 0;
	z-index: 15;
	border-bottom: solid 0px #f00;
	}
.idx {
	position: absolute;
	top: 100%;
	}
.fixed {
	position: fixed;
	top: 0;
	margin: 0;
	}

header>div {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	}
header>div>div {position: relative; }

header div#logo {
	position: absolute;
	left: calc(50% - 35px);
	right: calc(50% - 35px);
	width: 70px;
	z-index: 99;
	pointer-events: auto;
	border: solid 0px #000;
	}
header div#logo a {
	display: block;
	padding: 5px 2%;
	}
header div#logo img {width: 100%; }



/*++++++++++++++++++++++++++++++ navigation ++++++++++++++++++++++++++++++*/

.contents {transition: transform .6s cubic-bezier(0.215, 0.61, 0.355, 1); }
#navTgl:checked ~ .contents {transform: translateX(0%); }		/*メインの移動位置*/

/* :::::: toggle button :::::: */
#navTgl {display: none; }
@media only screen and (max-width: 768px) /*++++++++++*/ {

header label {
	display: inline;
	position: absolute;
	top: 0;
	right: 0;
	opacity: 1;
	cursor: pointer;
	pointer-events: auto;
	}
header.idx label {
	display: none;
	opacity: 0;
	}
header.fixed label {
	display: inline;
	animation: fx_label 0.5s ease-out 0s 1 normal both;
	-webkit-animation: fx_label 0.5s ease-out 0s 1 normal both;
	}
@keyframes fx_label {
	0%	{opacity: 0; }
	100%	{opacity: 1; }
	}
@-webkit-keyframes fx_label {
	0%	{opacity: 0; }
	100%	{opacity: 1; }
	}

.open {
	z-index: 2;
	width: 60px;
	height: 60px;
	margin-top: 10px;
	background: none;
	border: solid 0px #000;
	transition: background .6s, transform .6s cubic-bezier(0.215, 0.61, 0.355, 1);
	}
.open::before, .open::after {content: ""; }
.open span, .open::before, .open::after {
	content: "";
	position: absolute;
	top: calc(50% - 0px);
	left: 30%;
	width: 40%;
	border-bottom: solid 2px rgba(53, 32, 0, 1);
	transition: transform .6s cubic-bezier(0.215, 0.61, 0.355, 1);
	}
.open::before {transform: translateY(-8px); }
.open::after {transform: translateY(8px); }
.close {
	z-index: 1;
	width: 100%;
	height: 100%;
	pointer-events: none;
	transition: background .6s;
	}
#navTgl:checked + .open {
/*	background: #fff;*/
	transform: translateX(0);	/*ボタンの移動位置*/
	}
#navTgl:checked + .open span {transform: scaleX(0); }
#navTgl:checked + .open::before {transform: rotate(45deg); }
#navTgl:checked + .open::after {transform: rotate(-45deg); }
#navTgl:checked ~ .close {
	pointer-events: auto;
	background: rgba(255,255,255,.9);	/*メニュー背景色*/
	}

/* :::::: drawer menu :::::: */
nav {	/**/
	z-index: 1;
	position: fixed;
	overflow: auto;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	pointer-events: auto;
	background: rgba(255,255,255, .95);	/*メニュー背景色*/
	transform: translateX(100%);		/*メニューが隠れてる位置*/
	transition: transform .6s cubic-bezier(0.215, 0.61, 0.355, 1);
	border: solid 0px #f00;
	}

nav span#snss {
	width: auto;
	margin: 80px auto 0;
	padding: 2px 0;
	pointer-events: auto;
	text-align: center;
	}
nav span#snss span {
	background: rgba(0, 0, 0, .3);
	padding: 20px;
	}
nav span#snss, nav span#snss span {
	display: block;
	border: solid 1px rgba(0,0,0,.1);
	border-left: none;
	border-right: none;
	}
nav span#snss img {
	width: 18%;
	max-width: 60px;
	margin: 0 4%;
	}

header div#ul {	/**/
	z-index: 10;
	margin:  0;
	pointer-events: auto;
	}
header ul {}
header ul li {	/**/
	font-size: 1.4rem;
	font-size: 3.0vw;
	line-height: 1.4;
	border-bottom: solid 1px rgba(0,0,0,.1);
	}
header ul li.cs {display:none; }
header ul li span {
	margin-right: 3vw;
	font-size: 1.8rem;
	font-size: 4.0vw;
	font-family: 'Shrikhand', cursive;
	font-weight: normal;
	}
header ul li a {	/**/
	display: block;
	padding: 1.5em 2em;
	color: rgba(53, 32, 0, 1);
	text-decoration: inherit;
	transition: background .6s cubic-bezier(0.215, 0.61, 0.355, 1);
	}
header ul li a:hover {	/**/
	background: rgba(53, 32, 0, 1);
	color: #fff;
	}

#navTgl:checked ~ nav {transform: none; }
}
/*++++++++++++++++++++++++++++++ navigation ++++++++++++++++++++++++++++++*/


footer {
	background: rgba(53, 32, 0, 1);
	width: 100%;
	padding-top: 40px;
	color: rgba(255, 251, 199, 1);
	border: dotted 0px #fff;
	}
footer>div {
	position: relative;
	width: 100%;
	margin: 0 auto;
	padding: 0 20px;
	border: solid 0px #888;
	}
footer div#footer_logo {
	width: 100%;
	text-align: center;
	}
footer div#footer_logo img {width: 100px; }

footer div#snss {
	width: 100%;
	text-align: center;
	}
footer div#snss img {
	width: 10vw;
	max-width: 55px;
	margin: 40px 10px;
	}
footer ul {}
footer ul li {
	font-size: 1.4rem;
	line-height: 2;
	text-align: left;
	letter-spacing: 0;
	}
footer ul li a {display: block; }
footer ul li a br {display: none; }
footer ul li span:before {content: " ["; }
footer ul li span:after {content: "]"; }
footer ul li a:before {content: "・"; color: rgba(255, 255, 255, 1); }	/**/

footer address {
	margin: 0;
	padding: 40px 0;
	font-size: 1.2rem;
	text-align: center;
	font-family: 'Shrikhand', cursive;
	font-weight: normal;
	}




div#main {
	background: #fff;
	width: 100%;
	margin: 0 auto;
	padding: 0;
	}
#idx div#main {
	padding: 80px 0 0;
	}
#qa div#main {
	padding: 80px 0 30px;
	}



div#main>div {
	position: relative;
	width: 100%;
	margin: 0 auto 0;
	}

/*++++++++++++++++++++++++++++++ INDEX ++++++++++++++++++++++++++++++*/
div.slide_contents {
	position: relative;
	top: 0;
	width: 100%;
	margin: 0;
	padding: 0;
	z-index: 10;
	text-align: center;
	border: solid 0px #f00;
	}
#idx div.slide_contents {
	position: absolute;
	border: solid 0px #f00;
	}

div.slide_contents h1 {
	position: absolute;
	top: 1%;
	left: 1%;
	width: 98%;
	color: #fff;
	font-size: 3.0vmin;
	line-height: 1.5;
	}
/*div.slide_contents p {position: absolute; top: 60%; right: 0; left: 0; color: #fff; font-size: 7vmin; font-weight: bold; text-align: center; }*/
div.slide_contents span#logo {
	position: absolute;
	bottom: 18vmin;
	right: 0;
	left: 0;
	text-align: center;
	}
div.slide_contents span#logo img {height: 25vmin; }
#idx div.slide_contents span#logo {bottom: 45%; }
#idx div.slide_contents span#logo img {height: 50vmin; }

div.slide_contents span#snss {
	position: absolute;
	z-index: 1;
	bottom: 60px;
	right: 0;
	left: 0;
	text-align: center;
	border: dotted 0px #fff;
	}
div.slide_contents span#snss img {
	width: 10vw;
	max-width: 55px;
	margin: 0 10px;
	}
div.slide_contents span#reserve {
	position: absolute;
	bottom: 23%;
	right: 10%;
	left: 60%;
	transform: ratate(5deg);
	-webkit-transform: rotate(5deg);
	border: solid 0px #f00;
	}
div.slide_contents span#reserve img {
	height: 16vmin;
	min-height: 100px;
	}


@media only screen and (max-height: 481px) and (orientation: landscape) {
div.slide_contents span#logo {bottom: 25vh; }
div.slide_contents span#logo img {height: 50vh; }
div.slide_contents span#snss {
	top: calc(50% - 60px);
	bottom: auto;
	left: calc(100% - 55px);
	right: 20px;
	}
div.slide_contents span#snss img {
	width: 35px;
	margin: 5px 0;
	}
div.slide_contents span#reserve {
	bottom: 34vmin;
	right: calc(calc(100% - 10px) - 25vmin);
	left: 10px;
	transform: ratate(-5deg);
	-webkit-transform: rotate(-5deg);
	}
div.slide_contents span#reserve img {
	height: 25vmin;
	min-height: 100px;
	}
}





/* ***** Slide ***** */
div.slide {
	width: auto;
	border: solid 0px #f00;
	}
.bxslider {
	width: 100vw;
/*	min-height: 100%;*/
	margin: 0 auto;
	border: dotted 0px #f00;
	}
.bx-wrapper img {
/*	width: 100vw;*/
	height: 100vh;
	object-fit: cover;
	}
/* ***** Slide ***** */

/*++++++++++++++++++++++++++++++ INDEX ++++++++++++++++++++++++++++++*/



div.bb {
	background: #222 url("./img/bb.png");
	width: 100%;
	padding: 100px 0;
	}
div.bb div {
	width: 100%;
	margin: 0 auto;
	color: #fff;
	line-height: 1.8;
	text-align: center;
	border: dotted 0px #fff;
	}
#idx div.bb div {width: 98%; }

#idx div.bb div h2 {
	margin-bottom: 40px;
	color: #00757f;
	font-size: 3.6vw;
	font-weight: bold;
	}
div.bb h3 {
	width: 100%;
	max-width: 100%;
	margin: 0 auto 50px;
	padding: 0px 0;
	font-family: 'Shrikhand', cursive;
	font-size: 2.0rem;
	line-height: 1;
	font-weight: normal;
	text-align: center;
	border: solid 0px #f00;
	}
div.bb h3 span {
	display: inline-block;
	padding: 20px 100px;
	border: solid 2px rgba(255, 255, 255, 1);
	border-left: none;
	border-right: none;
	}





div.bb div.btn {
	width: 70vw;
	margin: 0 auto;
	}
div.bb div.btn a {
	display: block;
	margin-top: 30px;
	padding: 10px;
	color: #fff;
	font-size: 4.5vw;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
	border: solid 3px #fff;
	border-radius: 3px;
	transition: 0.25s;
	}
div.bb div.btn a:hover {
	background: #fff;
	color: #000;
	}




div.bb div p.tel {
	margin-top: 30px;
	font-size: 3vw;
	line-height: 1.5;
	}
div.bb div p.tel a {
	color: #fff;
	font-size: 5vw;
	font-weight: bold;
	}
#idx div.bb div p {font-size: 2.6vw; }
















section {
/*	background: rgba(53, 32, 0, 0.05);*/
	background: #f5f2ef;	/**/
	position: relative;
	width: 100%;
	display: block;
	border: solid 0px #f00;
	}
section>span {
	position: absolute;
	top: -80px;
	opacity: 0;
	border: solid 1px #f00;
	}


section div.bg {
	width: 100%;
	height: 100%;
	}
section div.bg img {
	width: 100%;
	height: 100%;
	}
div.area1 {
	z-index: 1;
	width: 100%;
	}
div.area2 {position: relative; }
div.area3 {
	width: 100%;
	padding: 50px 5% 80px;
	text-align: center;
	}
div.area4 {text-align: left; }

div.area1 h3, div.area1 h4 {
	position: absolute;
	color: #fff;
	font-family: 'Shrikhand', cursive;
	font-size: 6vw;
	line-height: 1;
	}
div.area1 h3 {
	top: -6vw;
	right: 2%;
	}
div.area1 h4 {
	top: -8vw;
	left: 2%;
	font-size: 8vw;
	}
div.area4 div.txt_logo {
	font-family: 'Shrikhand', cursive;
	font-size: 7vw;
	line-height: 1;
	text-align: center;
	}
div.area4 img {
	height: 200px;
	}
div.area4 p {
	margin-top: 30px;
	color: #000;
	font-size: 3.9vw;
	}
div.area4 div.btn {}
div.area4 div.btn a {
	display: block;
	margin-top: 30px;
	padding: 10px;
	color: #000;
	font-size: 4.5vw;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
	border: solid 3px #000;
	border-radius: 3px;
	transition: 0.25s;
	}
div.area4 div.btn a:hover {
	background: #000;
	color: #fff;
	}











div.box {
	background: #fff;
	width: 100%;
	padding: 100px 0 0;
	border: solid 0px #f00;
	}
div.box2 {
	background: #f5f2ef;	/**/
	}
div.box h2 {
	width: 100%;
	max-width: 100%;
	margin: 0 auto 50px;
	padding: 0px 0;
	font-family: 'Shrikhand', cursive;
	font-size: 2.0rem;
	line-height: 1;
	font-weight: normal;
	text-align: center;
	border: solid 0px #f00;
	}
div.box h2 span {
	display: inline-block;
	padding: 20px 100px;
	border: solid 2px rgba(53, 32, 0, 1);
	border-left: none;
	border-right: none;
	}
div.box iframe {
	width: 100%;
	height: 50vh;
	border: 0;
	}

div.box dl.access {
	width: 96%;
	margin: 0 auto 80px;
	}
div.box dl.access dt, div.box dl.access dd {
	width: 100%;
	margin-top: 20px;
	}
div.box dl.access dt {adding-right: 5px; }
div.box dl.access dd {
	margin-top: 2px;
	padding: 0 0 0 10px;
	border-left: solid 5px #eee;
	}







div.box div.qa {
	width: 90vw;
	max-width: 1200px;
	margin: 0 auto 100px;
	}
div.qa span.qabox {
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	align-items: center;
	margin-bottom: 30px;
	border: dotted 0px #f00;
	}
div.qa span.qabox h5, div.qa span.qabox p {
	width: calc(100% - 12vw);
	margin-left: 2vw;
	line-height: 2;
	}
div.qa span.qabox h5 {
	color: #00757f;
	font-size: 3.5vw;
	line-height: 1.5;
	}
div.qa span.qabox p {font-size: 2.8vw; }
div.qa span.qabox span {
	display: block;
	width: 10vw;
	height: 10vw;
	font-family: 'Shrikhand', cursive;
	font-size: 4vw;
	text-align: center;
	}
div.qa span.qabox span:first-child {
	background: #00757f;
	color: #fff;
	line-height: 10vw;
	border-radius: 50%;
	}
div#qa h4 {
	background: rgba(53, 32, 0, 1);
	margin-bottom: 30px;
	padding: 5px 10px;
	color: #fff;
	font-size: 1.8rem;
	line-height: 1.8;
	text-align: center;
	}






div.b1200 {
	width: 100%;
	max-width: 1180px;
	margin: 0 auto;
	padding-bottom: 100px;
	}

div.atent_box {padding-bottom: 60px; }
div.atent_box div {margin-bottom: 40px; }

div#attention h4, div#attention p {
	font-size: 1.6rem;
	line-height: 1.8;
	}
div#attention h4 {
	background: rgba(53, 32, 0, 1);
	padding: 5px 10px;
	color: #fff;
	text-align: center;
	}
div#attention p {
	margin: 10px 20px 0;
	padding-left: 1.6rem;
	text-indent: -1.6rem;
	}
div#attention p:before {content: "●"; }



div#ig_body {
	width: 100%;
	margin: 100px auto 100px;
	overflow-x: scroll;
	-ms-overflow-style:none;
	border: solid 0px #000;
	}
div#ig_body::-webkit-scrollbar {display: none; }

div.gallery {
	display: flex;
	flex-wrap: wrap;
	width: 450%;
	margin: 0;
	padding: 0;
	}
div.gallery div.ig_photo {
	flex: 1 1 10%;
	-ms-flex: 1 1 10%;
	}
div.ig_photo img {
	max-width: 100%;
	height: auto;
	}





div#twfb {
/*	background: #fff;*/
/*	background: #f5f2ef;	/**/
	width: 100%;
	padding: 50px 5%;
	text-align: center;
	border: solid 0px #f00;
	}
div#twfb>div {}
div.tw {
	margin: 0 auto;
	padding: 0;
	}
div.tw:nth-of-type(1) {margin-bottom: 50px; }



div.line {}
div.line img {
	width: 100px;
	margin-top: 10px;
	}



