@charset "utf-8";

/* CSS Document */
/*基本設定：ページ全体*/
@media(max-width:599px) {
:root {
	font-size: 14px;
}
}

@media(min-width:600px) and (max-width:799px) {
:root {
	font-size: 16px;
}
}

@media(min-width:800px) {
:root {
	font-size: 18px;
}
}
#coupon:hover {
	background:linear-gradient(to right,hsla(359,57%,52%,0.30),hsla(359,57%,52%,0.30),hsla(359,57%,52%,0.30),hsla(359,57%,52%,0.30),hsla(359,57%,52%,0.30),black);
}
#A{
	font-size: 30px;
	color:white;
	text-shadow: 3px 3px 3px black;
}
#AA{
	align-items: center;
	text-align: center;
	padding-top:50px;
	display: flex;
	justify-content: center;
	font-size: 30px;
	color:white;
}
#AA:hover{
	color:deeppink;
}
#B{
	font-size: 30px;
	color:white;
	text-shadow: 1px 1px 1px black;

}
#BB{
	align-items: center;
	text-align: center;
	padding-top:50px;
	display: flex;
	justify-content: center;
	font-size: 30px;
	color:white;
}
#BB:hover{
	color:deeppink;
}
#C{
	font-size: 30px;
	color:white;
}
#CC{
	align-items: center;
	text-align: center;
	padding-top:50px;
	display: flex;
	justify-content: center;
	font-size: 30px;
	color:white;
}
#CC:hover{
	color:deeppink;
}
#s{
	width: 25%;
}

#s:hover {
	transform: scale(1.1, 1.1);
}
/*トップページスライド*/
article .pc_tp{
	display: none;
}
article .s_tp{
	width: 100vw;
	min-height: 100vh;
}




/*トップページアニメーション*/
	.start_tp {
	background: #000;
	position: fixed;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	z-index: 9000;
}
.start_tp p {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	display: none;
	z-index: 9999;
	width: 280px;
}


body {
	margin: 0;
	font-family: "Hiragino Kaku Gothic Pro", "メイリオ", "sans-serif"
}
/*コンテンツA:ヒーローイメージ*/
video{
	width: 100%;
	
}
.header{
	background-color: antiquewhite;
}
body{
	background-color:hsla(336,97%,52%,0.59);
}
@media(min-width: 415px) {
.TOP_conB .TOP_DINNER, .TOP_conB .TOP_PARTY, .TOP_conC .TOP_LUNCH {
	border: 1px solid #fff;
}
	.TOP2_conB {
	border: 1px solid #000;
}
}
.TOP_main {
	background-color: #000;
}
.TOP_main h1 {
	text-align: center;
	padding: 20px;
	color: gray;
	font-size: 40px;
	font-family: 'Poppins', sans-serif;
	letter-spacing: 40px;
	padding-left: 40px;
	margin-top: -10px;
}
.TOP_main span {/*各テキストにanimationを設定*/
	color: transparent;/*テキストを透明にしてtext-shadowだけ表示する*/
	animation: blur 10s ease-out infinite;
}
.TOP_main span:nth-child(1) {/*一文字ずつ遅延させる*/
	animation-delay: 0.1s;
}
.TOP_main span:nth-child(2) {
	animation-delay: 0.2s;
}
.TOP_main span:nth-child(3) {
	animation-delay: 0.3s;
}
.TOP_main span:nth-child(4) {
	animation-delay: 0.4s;
}
 @keyframes blur {/*opacityとtext-shadow+animationでフェードインを表現する*/
 0% {
text-shadow:  0 0 100px #fff;
opacity:0;
}
 5% {
text-shadow:  0 0 90px #fff;
}
 15% {
opacity: 1;
}
 20% {
text-shadow:  0 0 0px #fff;
}
 80% {
text-shadow:  0 0 0px #fff;
}
 85% {
opacity: 1;
}
 95% {
text-shadow:  0 0 90px #fff;
}
 100% {
text-shadow:  0 0 100px #fff;
opacity:0;
}
}

@media (min-width:769px) {
.TOP_DINNER, .TOP_LUNCH {
	text-align: center;
	position: relative;
	border: hidden !important;
}
.bd div {
	background: #fff;
	position: absolute;
	-webkit-transition: all 1s;
	transition: all 1s;
}
	.bd2 div {
	background: #000;
	position: absolute;
	-webkit-transition: all 1s;
	transition: all 1s;
}
.bd div.bdT {
	width: 0;
	height: 1px;
	top: 0;
	left: 0;
}
.bd div.bdB {
	width: 0;
	height: 1px;
	bottom: 0;
	right: 0;
}
.bd div.bdR {
	height: 0;
	width : 1px;
	right: 0;
	top: 0;
}
.bd div.bdL {
	height: 0;
	width : 1px;
	left: 0;
	bottom: 0;
}
.TOP_conB:hover .bd1 div.bdT {
	width: 100%;
}
.TOP_conB:hover .bd1 div.bdB {
	width: 100%;
}
.TOP_conB:hover .bd1 div.bdR {
	height: 100%;
}
.TOP_conB:hover .bd1 div.bdL {
	height: 100%;
}
	.TOP2_conB:hover .bd1 div.bdT {
	width: 100%;
}
.TOP2_conB:hover .bd1 div.bdB {
	width: 100%;
}
.TOP2_conB:hover .bd1 div.bdR {
	height: 100%;
}
.TOP2_conB:hover .bd1 div.bdL {
	height: 100%;
}
.TOP_conC:hover .bd1 div.bdT {
	width: 100%;
}
.TOP_conC:hover .bd1 div.bdB {
	width: 100%;
}
.TOP_conC:hover .bd1 div.bdR {
	height: 100%;
}
.TOP_conC:hover .bd1 div.bdL {
	height: 100%;
}
}
.text a:hover{
	color:deeppink;
}
/* jQueryプラグイン scrollTop*/

.fadein {
    opacity : 0;
    transform : translate(0, 50px);
    transition : all 1.2s;
}
.fadein.scrollin {
    opacity : 1;
    transform : translate(0, 0);
	}
.scrollTop {
	transition: 2.5s;
	transform: translate(0, 40px);
	-webkit-transform: translate(0, 40px);
}
.scrollTop2 {
	transition: 3.8s;
	transform: translate(0, -40px);
	-webkit-transform: translate(0, -40px);
}
.scrollTop3 {
	transition: 2s;
	transform: translate(0, 20px);
	-webkit-transform: translate(0, 20px);
}
.scrollTop4 {
	transition: 2.5s;
	transform: translate(0, -20px);
	-webkit-transform: translate(0, -20px);
}
.scrollTopMV {
	transform: translate(0, 0);
	-webkit-transform: translate(0, 0);
}

.conA {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100vh;
	min-height: 450px;
	text-align: center;
	background-image: linear-gradient(rgba(0,0,0,0.1), rgba(0,0,0,0.1)), url(../images/IMG_1485.svg);
	background-position: center;
	background-size: cover;
	color: #fff;
}
.conA.compact {
	height: 450px;
	min-height: 0;
	background-image: linear-gradient(rgba(0,0,0,0.1), rgba(0,0,0,0.1)), url(../images/balloon.jpg);
}
.conA h1 {
	margin-top: 0;
	margin-bottom: 10px;
	font-family: 'Montserrat', sans-serif;
	font-size: 14vw;
	letter-spacing: 0.2em;
	margin-left: 0.2em;
	opacity: 0;
}
.conA p {
	margin-top: 0;
	margin-bottom: 0;
	font-size: 18px;
}
.conA img {
	width: 20%;
}
.conA a {
	display: inline-block;
	margin-top: 20px;
	padding: 10px 30px;
	border: solid 3px currentColor;
	border-radius: 6px;
	background-color: hsla(289,100%,37%,0.30);
	color: #fff;
	font-size: 14px;
	text-decoration: none;
}
.conA a:hover {
	background-image: linear-gradient(rgba(255,255,255,0.2), rgba(255,255,255,0.2));
}
/*ヘッダー*/
header {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 100;
	width: 100%;
	background-color: rgba(255,255,255,0.9);
}
.nohero header {
	position: static;
	border-bottom: solid 1px #ddd;
}
/*ヘッダー：サイト名
*/
.headA {
	display: inline-block;
	line-height: 70px;
	padding-left: 20px;
	padding-right: 20px;
	background-color: #000000;
	color: #fff;
	font-family: 'Montserrat', sans-serif;
	font-size: 24px;
	text-decoration: none;
}
/*ヘッダーB:ナビゲーションメニュー*/
.headB ul {
	margin: 0;
	padding: 0;
	list-style: none;
}
.headB a {
	display: block;
	padding: 15px;
	color: inherit;
	font-size: 12px;
	text-decoration: none;
}
.headB a:hover {
	background-color:hsla(61,74%,71%,0.33);
}


@media(min-width:768px) {
.headB ul {
	display: flex;
}
header .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
}
}

/*	ヘッダーC：トグルボタン
*/
@media(max-width:767px) {
/*小さい画面用の設定*/
header .container-small {
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.headC {
	margin-right: 10px;
	padding: 0;
	border: none;
	outline: none;
	background: none;
	font-size: 28px;
	opacity: 0.5px;
	cursor: pointer;
}
.headC:hover {
	opacity: 0.3;
}
.headB {
	display: none;
}
}

@media(min-width:768px) {
/*大きい画面用の設定*/
.headC {
	display: none;
}
.headB {
	display: block !important;
}
}
/*コンテンツページ：記事
*/

/*コンテンツB：概要(アイコン+テキスト)*/
.conB .container {
	padding-top: 80px;
	padding-bottom: 20px;
}
.conB .text {
	text-align: center;
	padding-left: 20px;
	padding-right: 20px;
	padding-bottom: 60px;
}
.conB h2 {
	margin-top: 0;
	margin-bottom: 10px;
	font-size: 20px;
}
.conB p {
	margin-top: 0;
	margin-bottom: 20px;
	font-size: 14px;
	line-height: 1.8;
	opacity: 0.8;
}
.conB a {
 color:#000000 text-decoration: none;
}
.conB a:hover {
	text-decoration: underline;
}
.conB .icon {
	display: inline-block;
	margin-bottom: 20px;
	font-size: 40px;
	width: 2em;
	line-height: 2em;
	text-align: center;
	background-color: #ddd;
	border-radius: 50%;
	color: #fff;
}

@media(min-width:768px) {
.conB .container {
	display: flex;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}
.conB .text {
	flex: 1;
}
}

@media(min-width: 768px) {
.conA h1 {
	font-size: 115px;
}
.conA p {
	font-size: 24px;
}
}
/*コンテンツC：画像+テキスト*/
.conC {
	background-color: #000000;
	color: #fff;
}
.conC .text {
	padding: 20px;
}
.conC h2 {
	margin-top: 0;
	margin-bottom: 10px;
	font-size: 20px;
}
.conC p {
	margin-top: 0;
	margin-bottom: 20px;
	font-size: 14px;
	line-height: 1.8;
	opacity: 0.8;
}
.conC a {
	display: inline-block;
	margin-top: 20px;
	padding: 10px 30px;
	border: solid 3px currentColor;
	border-radius: 6px;
	background-color: hsla(289,100%,37%,0.60);
	color: #fff;
	font-size: 14px;
	text-decoration: none;
}
.conC a:hover {
	background-image: linear-gradient(rgba(255,255,255,0.3), rgba(255,255,255,0.3));
}
.conC .photo {
	min-height: 200px;
	background-image:url(../images/IMG_bksneaker.jpg);
	background-position: center;
	background-size: cover;
}
.conC .photo_b {
	min-height: 200px;
	background-image:url(../images/UNADJUSTEDNONRAW_thumb_3c5.jpg);
	background-position: center;
	background-size: cover;
}
.conC .photo_d {
	min-height: 200px;
	background-image:url(../images/IMG_2382.jpg);
	background-position: center;
	background-size: cover;
}
.conC .photo_e {
	min-height: 200px;
	background-image:url(../images/IMG_2529.jpg);
	background-position: center;
	background-size: cover;
}
@media(min-width:768px) {
.conC .container {
	display: flex;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}
.conC .photo,.photo_b,.photo_d,.photo_e {
	flex: 3;
}
.conC .text {
	flex: 2;
	padding: 50px;
}
}
/*コンテンツD：画像+テキスト：逆配置*/
.conD .container {
	padding-top: 2px;
}
.conD .text {
	padding: 20px;
}
.conD h2 {
	margin-top: 0;
	margin-bottom: 10px;
	font-size: 20px;
}
.conD p {
	margin-top: 0;
	margin-bottom: 20px;
	font-size: 14px;
	line-height: 1.8;
	opacity: 0.8;
}
.conD a {
	display: inline-block;
	margin-top: 20px;
	padding: 10px 30px;
	border: solid 3px currentColor;
	border-radius: 6px;
	background-color: hsla(289,100%,37%,0.90);
	color: #fff;
	font-size: 14px;ß
	text-decoration: none;
	box-shadow: 0 0 0 1px #888;
}
.conD a:hover {
	background-image: linear-gradient(rgba(255,255,255,0.4), rgba(255,255,255,0.4));
}
.conD .photo {
	min-height: 200px;
	background-image: url(../images/IMG_2389.JPG);
	background-position: center;
	background-size: cover;
}
.conD .photo_b {
	min-height: 200px;
	background-image:url(../images/IMG_1883.jpg);
	background-position: center;
	background-size: cover;
}
.conD .photo_c {
	min-height: 200px;
	background-image:url(../images/IMG_vava.jpg);
	background-position: center;
	background-size: cover;
}
.conD .photo_d {
	min-height: 200px;
	background-image:url(../images/IMG_1444.jpg);
	background-position: center;
	background-size: cover;
}

@media(min-width:768px) {
.conD .container {
	display: flex;
	flex-direction: row-reverse;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	padding-top: 40px;
	padding-bottom: 40px;
}
.conD .photo,.photo_b,.photo_c,.photo_d {
	flex: 0 0 400px;
}
.conD .text {
	flex: 1;
	padding: 50px;
}
}
/*フッター*/
footer {
	color: #fff;
	background-color: #000000;
}
footer .container {
	padding: 40px 20px;
}

@media (min-width:768px) {
footer .container {
	display: flex;
	flex-wrap: wrap;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}
.footA {
	flex: 0 0 40%;
}
.footB {
	flex: 0 0 60%;
}
.footC {
	flex: 0 0 100%;
}
}
/*フッターA:サイト情報*/
.footA h2 {
	margin-top: 0;
	font-family: 'Montserrat', sans-serif;
	letter-spacing: 0.2em;
	font-size: 40px;
	margin-bottom: 10px;
}
.foot p {
	margin-top: 0;
	margin-bottom: 0;
	font-size: 14px;
}
.footA a {
	color: inherit;
	text-decoration: none;
}
/*フッターB：フッターメニュー*/
.footB　div {
	margin-bottom: 20px;
}
.footB h3 {
	margin-top: 0;
	margin-bottom: 10px;
	border-bottom: solid 1px currentColor;
	font-size: 14px;
}
.footB ul {
	margin: 0;
	padding: 0;
	list-style: none;
}
.footB a {
	display: block;
	padding: 5px;
	color: inherit;
	font-size: 12px;
	text-decoration: none;
}
.footB a:hover {
	background-color: rgba(0,0,0,0.3);
}

@media(min-width:768px) {
.footB {
	display: flex;
}
.footB div {
	flex: 1;
}
.footB div:not(:first-child) {
	margin-left: 40px;
}
}
/*フッターC：コピーライト*/
.footC {
	font-size: 12px;
	text-align: center;
	font-family: 'Montserrat', sans-serif;
}
/*フッターD：SNSメニュー*/
.footD {
	margin-top: 20px;
}
.footD ul {
	display: flex;
	margin: 0;
	padding: 0;
	list-style: none;
}
.footD a {
	display: block;
	margin-right: 8px;
	padding: 0px;
	color: inherit;
	font-size: 16px;
	font-size: 12px;
	text-decoration: none;
	border: solid 1px currentColor;
	width: 2em;
	line-height: 2em;
	border-radius: 50%;
	text-align: center;
}
.footD a:hover {
	background-color: rgba(0,0,0,0.3);
}
.post .container {
	padding: 30px 10px;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
}
.post h1 {
	font-size: 2rem;
	padding-left: 0.5rem;
	border-left: solid 0.75rem black;
}
.post p {
	font-size: 1rem;
	line-height: 2;
}
.post span {
	color:red;
}
.post img {
	max-width: 100%;
	display: block;
	transition: 0.5s;
}
.post img:hover{
	transform: scale(1.1, 1.1);
}
/*コンテンツページ：パンくずリスト*/
.bread ol {
	display: flex;
	margin: 0;
	padding: 0;
	list-style: none;
}
.bread a {
	display: block;
	padding: 5px;
	color: inherit;
	font-size: 0.875rem;
	text-decoration: none;
}
.bread a::after {
	margin-left: 10px;
	content: '\f054';
	font-family: 'FontAwesome';
	opacity: 0.3;
}
.bread a:hover {
	background-color: rgba(0,0,0,0.3);
}
/*アバウトページ：画像と沿革
*/
.history {
	background-color: #5d9ab2;
	color: #fff;
}
.history .text {
	padding: 20px;
}
.history h2 {
	margin-top: 0;
	margin-bottom: 10px;
	font-size: 1.5rem;
}
.history .photo {
	min-height: 300px;
	background-image: url(../images/plant.jpg);
	background-position: center;
	background-size: cover;
}
.hstory table {
	border-collapse: collapse;
	border-top: solid 1px #ddd;
	font-size: 0.875rem;
}
.history th, .history td {
	border-bottom: solid 1px #ddd;
	padding-top: 1.8rem;
	padding-bottom: 1.8rem;
}
.history th {
	padding-right: 1rem;
	text-align: left;
	word-break: keep-all;
}

@media(min-width:768px) {
.history .container {
	display: flex;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}
.history .photo {
	flex: 3;
}
.history .text {
	flex: 2;
	padding: 50px;
}
}
/*お問い合わせページ：お問い合わせ先
*/
.contact {
	margin-top: 20px;
	margin-bottom: 20px;
	padding: 20px;
	border: solid 1px #ddd;
	text-align: center;
}
.contact span {
	display: inline-block;
	margin-bottom: 20px;
	font-size: 2.2rem;
	width: 2em;
	line-height: 2em;
	text-align: center;
	background-color: #5d9ab2;
	border-radius: 50%;
	color: #fff;
}
.contact h2 {
	margin-top: 0;
	font-size: 1.2rem;
}
.contact a {
	font-size: 1.4rem;
	color: inherit;
	text-decoration: none;
}

@media(min-width:768px) {
.contact-wrap {
	display: flex;
}
.contact {
	flex: 1;
}
.contact:first-child {
	margin-right: 20px;
}
}
/*お問い合わせページ：地図
*/
.location iframe {
	width: 100%;
	height: 400px;
	vertical-align: bottom;
}
.location h2 {
	margin: 0;
	padding-top: 20px;
	padding-bottom: 20px;
	background-color: #5d9ab2;
	color: #fff;
	font-size: 1.5rem;
	text-align: center;
}
/*記事一覧A*/
.listA h1 {
	text-align: center;
}
.listA .container {
	display: flex;
	flex-wrap: wrap;
	max-width: 1000px;
	margin: 30px auto;
}
.listA article {
	flex: 1 1 300px;
	display: flex;
}
.listA a {
	flex: 1;
	margin: 10px;
	display: block;
	border: solid 1px #ddd;
	color: inherit;
	text-decoration: none;
}
.listA a:hover {
	opacity: 0.8;
}
.listA .photo {
	min-height: 150px;
	background-position: center;
	background-size: cover;
}
.listA .text {
	margin: 10px;
}
.listA h2 {
	font-size: 18px;
}
.listA p {
	font-size: 14px;
	opacity: 0.8;
}
/*記事一覧B
*/
.lisB h1 {
	text-align: center;
}
.listB .container {
	display: flex;
	flex-wrap: wrap;
	max-width: 1000px;
	margin: 30px auto;
}
.listB article {
	flex: 1 1 384px;
	display: flex;
}
.listB a {
	flex: 1;
	margin: 10px;
	display: flex;
	border: solid 1px #ddd;
	color: inherit;
	text-decoration: none;
}
.listB a:hover {
	opacity: 0.8;
}
.listB .photo {
	flex: 2;
	min-height: 0;
	background-position: center;
	background-size: cover;
}
.listB .text {
	flex: 3;
	margin: 10px;
}
.listB h2 {
	font-size: 18px;
}
.listB p {
	font-size: 14px;
	opacity: 0.8;
}

@media (max-width:384px) {
.listB .photo {
	flex: 1;
}
.listB p {
	display: none;
}
}
/*記事一覧C*/
.listC h1 {
	text-align: center;
}
.listC .container {
	display: flex;
	flex-wrap: wrap;
	max-width: none;
	margin: 2px auto;
}
.listC article {
	flex: 1 1 250px;
	display: flex;
}
.listC a {
	posion: relative;
	flex: 1;
	margin: 2px;
	display: block;
	border: solid 1px #ddd;
	background-color: currentColor;
	color: inherit;
	text-decoration: none;
}
.listC a:hover {
	opacity: 0.7;
}
.listC .photo1 {
	min-height: 250px;
	background-position: center;
	background-size: cover;
 opacity:1;
}
.listC .photo {
	min-height: 250px;
	background-position: center;
	background-size: cover;
	opacity: 1;
}
.listC .photo2 {
	min-height: 250px;
	background-position: center;
	background-size: cover;
	opacity: 1;
}
.listC .photo3 {
	min-height: 250px;
	background-position: center;
	background-size: cover;
	opacity: 0.7;
}
.listC .text {
	margin: 10px;
	position: absolute;
	bottom: 0;
	left: 0;
	color: #fff;
}
.listC h2 {
	font-size: 18px;
	margin: 0;
}
.listC p {
	margin: 0;
	font-size: 14px;
	opacity: 0.8;
}

@media(min-width:1000px) {
.listC article {
	flex: 1 1 25%;
}
}
