@charset "UTF-8";
/* 変数ファイルインポート */

a:hover {
  opacity: 0.5;
  transition: ease-in-out; }

a:link {
  opacity: 1;
  transition: 0.3s; }

button:hover {
  opacity: 0.8; }
	.sp_br{
		display: none;
	}

.googlemap{
	width: 564px;
	margin: 0;
	padding: 0;
}

@media (max-width: 980px) {
  .googlemap {
    width: 100%;
	margin-top: 20px;
  }

}
@media (max-width: 620px){
	.sp_br{
		display: block;
	}
	}



.wrapper {
  max-width: 100%;
  padding-left: 3rem;
  padding-right: 3rem;
  margin-left: auto;
  margin-right: auto;
}

*,
*:before,
*:after {
  box-sizing: border-box;
}

a {
  text-decoration: none;
	color: #3C3A3A;
}

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
	  scroll-behavior: smooth;

}



body {
  font-family: "Roboto", sans-serif;
}



section{
	display: block;
	clear: both;
}


/*スライドショー*/
.img-frame{
	position: relative;
   width: 100%;
	height: 840px;
}

@media screen and (max-width: 1280px){
.img-frame{
   width: 100%;
   height: 650px;
}
}
@media screen and (max-width: 980px){
.img-frame{
   width: 100%;
   height: 500px;
}
}
@media screen and (max-width: 640px){
.img-frame{
   width: 100%;
   height: 420px;
}
}
@media screen and (max-width: 540px){
.img-frame{
   width: 100%;
   height: 345px;
}
}

.img-01, .img-02, .img-03, .img-04{
   position: absolute;
   top:0;
   left:0;
   width: 100%;
   height: 100%;
   background-size:cover;
   background-repeat: no-repeat;
	background-position: center;
}
.img-01{
   background-image: url('../img/top-01.jpg');
   animation: slide-animation-01 18s infinite;
}
.img-02{
   background-image: url('../img/top-02.jpg');
   animation: slide-animation-02 18s infinite;
}
.img-03{
   background-image: url('../img/top-03.jpg');
   animation: slide-animation-03 18s infinite;
}
.img-04{
   background-image: url('../img/top-04.jpg');
   animation: slide-animation-04 18s infinite;
}



@keyframes slide-animation-01 {
    0% {opacity: 1;}
  20% {opacity: 1;}
  30% {opacity: 0;}
  80% {opacity: 0}
100% {opacity: 1;}
}
	
	
@keyframes slide-animation-02 {
   0% {opacity: 0;}
  20% {opacity: 0;}
  30% {opacity: 1;}
  50% {opacity: 1;}
  70% {opacity: 0;}
100% {opacity: 0;}
}


@keyframes slide-animation-03 {
    0% {opacity: 0;}
  50% {opacity: 0;}
  60% {opacity: 1;}
  80% {opacity: 1;}
100% {opacity: 0;}
}


@keyframes slide-animation-04 {
	0% {opacity: 0;}
  70% {opacity: 0;}
  90% {opacity: 1}
100% {opacity: 0;}
	}

.site-header__wrapper  a {
    opacity: 1;
}

.site-header__wrapper  a:hover {
    opacity: 0.8;
}


  .nav__wrapper a {
    color: #fff;
    opacity: 1;
}

.site-header__start{
	text-align: center;
	padding: 0 20px 20px;
	background-color: #000; 
}

.site-header {
	position: fixed; 
	z-index: 10;
	width: 100%;
	height: 100px;
	padding: 20px 0;
	color: #fff;
}

.site-header-box{
	position: fixed; 
	z-index: -1;
	min-width: 100%;
	height: 123px;
	top: 0;
	left: 0;
	background-color: #000; 
}



.site-header__wrapper {
	background-color: #950000;
	    opacity: 0.9;

}

  @media (min-width: 920px) {
    .site-header__wrapper {
      justify-content: initial; } }
@media (min-width: 920px) {
  .site-header__middle {
    margin-left: auto; } }

@media (max-width: 920px) {
  .site-header__end {
    padding-right: 4rem; } }

@media (min-width: 920px) {
  .nav__wrapper {
    display: flex; } }

@media (max-width: 920px) {
  .nav__wrapper {
position: fixed;
	  width: 200px;
	  height: 100%;
    top: 0;
    right: 0;
    z-index: 3;
    background-color: #fff;
    visibility: hidden;
    opacity: 0;
    transform: translateX(100%);
    transition: transform 0.3s ease-out, opacity 0.3s ease-out; }


		
.site-header-box {
	height: 80px;
}
}


.nav__item a {
  display: block;
	color: #fff;	
}

.nav__toggle {
  display: none; }


.drawer_hidden {
  display: none;
}


  @media (max-width: 920px) {
.drawer_open {
  display: block;
  height: 60px;
  width: 60px;
  align-items: center;
  position: absolute;
	right: 0;
	top: 40px;
	  z-index: 100;/* 重なり順を一番上にする */
  cursor: pointer;
}

	  
/* ハンバーガーメニューのアイコン */
.drawer_open span,
.drawer_open span:before,
.drawer_open span:after {
  content: '';
  display: block;
  height: 3px;
  width: 25px;
  border-radius: 3px;
  background: #fff;
  transition: 0.5s;
  position: absolute;
  right: 30px;
}

/* 三本線の一番上の棒の位置調整 */
.drawer_open span:before {
  bottom: 8px;
  right: 0;
}

/* 三本線の一番下の棒の位置調整 */
.drawer_open span:after {
  top: 8px;
  right: 0;
}

/* アイコンがクリックされたら真ん中の線を透明にする */
#nav__toggle:checked ~ .drawer_open span {
  background: rgba(255, 255, 255, 0);
}

/* アイコンがクリックされたらアイコンが×印になように上下の線を回転 */
#nav__toggle:checked ~ .drawer_open span::before {
  bottom: 0;
  transform: rotate(45deg);
  background: #000;
}

#nav__toggle:checked ~ .drawer_open span::after {
  top: 0;
  transform: rotate(-45deg);
  background: #000;
	  }
	  /* アイコンがクリックされたらメニューを表示 */
#nav__toggle:checked ~ .nav__wrapper {
	  visibility: visible;
      opacity: 1;
      transform: translateY(0); } 
}



.site-header__middle ul{
	max-width: 1160px;
	font-family: "Noto Serif JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 600;
	font-style: normal;
	font-size: 25px;
	margin: 0 auto;
}

.site-header__middle li{
	text-align: center;
	padding: 10px 0;
	margin: 0 auto;
}


@media (max-width: 920px) {
	.button{
		font-size:15px;
		background-size: 18px;
  background-position: left 10px center;
		padding: 5px 10px 5px 35px;
	}

	.brand{
		font-size:15px;
	}
	.brand span{
		font-size:25px;
	}
	.brand img{
	width: 70%;
} 

.site-header__middle li{
	width: 100%;
	padding: 20px;
	text-align:left;
	background-color: #fff;
}
	
	.nav__item a {
	color: #828181;	
}}

@media (max-width: 400px) {
	.button{
		font-size:12px;
		background-size: 15px;
  background-position: left 10px center;
		padding: 5px 10px 5px 30px;
	}

	.brand{
		font-size:12px;
	}
	.brand span{
		font-size:22px;
	}
.site-header__middle li{
	background-color: #fff;
}
	
	.nav__item a {
	color: #828181;	
}

}



/*フッター*/
footer{
	padding: 60px 20px;
	background-color: #950000;
}


.site-footer{
	max-width: 1160px;
	margin: 0 auto 30px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;
	}




.brand{
	font-family: "Noto sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-size:25px;
	color: #fff;
	margin-bottom: 10px;
}

.brand-footer img{
	max-width: 100%;
	height: 100px;
}


.address{
	font-family: "Noto sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 500;
	font-size: 15px;
	line-height: 25px;
	color: #fff;
	padding: 0;
	font-feature-settings: "palt" 1;
}

.copy_footer{
	font-size: 15px;
	font-family: "Noto sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 500;
	font-style: normal;
	margin-top: 5px;
	color: #fff;
	text-align: center;
}







/*トップページ・メニュー*/

#top{
	background-color: #000;
	padding: 100px 0px 0;
}

.top-bt{
	max-width: 1160px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 0 auto;
}

@media screen and (max-width: 640px){
.top-bt{
	padding-left: 20px;
	padding-right: 20px;
	justify-content: space-around;
	gap: 20px;
}
}


.top-bt-txt{
	font-family: "Noto sans JP", sans-serif;
	font-weight: 600;
	font-size: 20px;
	color: #fff;
	margin-top: 15px;
	text-align: center;
}

.top-bt-txt img{
	margin-top: 10px;
}

#top-catch,#menu,#menu-top{
	padding: 100px 0;
}

#menu-top,#shop,#coupon,#company,#recruit,#contact-1{
	padding: 140px 0;
}


.catch{
	max-width: 1160px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 0 auto;
}

.catch-text{
	font-family: "Noto Serif JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
	font-size: 20px;
	text-align: center;
	line-height: 45px;
	margin-right: 60px;
}



.catch-text span{
	color: #AF0000;
}

.catch-text img{
	margin-bottom: 20px;
}

#top-menu,#top-shop,#top-concept,#menu-cont{
	margin-bottom: 160px;
}

.menu,.menu00,.shop,.concept,.menu-top{
	position: relative;
}

h2{
	font-family: "Barlow", sans-serif;
	font-size: 198px;
	letter-spacing: 10px;
	font-weight: 700;
	color: #fff;
	position: absolute;
	bottom: -46px;
	right: 0;
	left: 0;
	text-align: center;
}

#menu h2{
	font-family: "Barlow", sans-serif;
	font-size: 150px;
	letter-spacing: 2px;
	font-weight: 700;
	color: #fff;
	position: absolute;
	bottom: -36px;
	right: 0;
	left: 0;
	text-align: center;
}

h3{
	font-family: "Noto sans JP", sans-serif;
	font-weight: 700;
	font-size: 25px;
	text-align: center;
	margin-top: 10px;
}

.menu img,.shop img,.concept img,.menu-top img{
	width: 100%;
}

.menu-cont00{
	width: 50%;
}

.menu-flex,.shop-flex,.concept-flex{
	max-width: 1160px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 auto;
	padding: 70px 0 0px;
}

.menu-flex00{
	max-width: 100%;
	display: flex;
	flex-wrap: wrap;
	margin: 0 auto;
	padding: 70px 0 0px;
}

.menu-drink,.menu-stand,.menu-lunch,.menu-special {
	width: 100%;
	text-align: center;
}

.menu-cont{
	border-right: 5px #950000 solid; 
	padding-right: 44px;
}
.menu-cont:last-child{
	border-right: none;
	padding-right: 0px;
}


.shop-bt,.menu-bt{
	max-width: 430px;
	font-family: "Noto sans JP", sans-serif;
	font-weight: 700;
	font-size: 25px;
	text-align: center;
	background-color: #950000;
	padding: 30px 0px;
	border-radius: 20px;
	margin: 25px auto 70px;
}

.menu-bt{
	width: 500px;
	font-family: "Noto sans JP", sans-serif;
	font-weight: 700;
	font-size: 25px;
	text-align: center;
	background-color: #950000;
	padding: 30px 0px;
	border-radius: 20px;
	margin: 25px auto 70px;
}

.menu-bt02{
	width: 500px;
	font-family: "Noto sans JP", sans-serif;
	font-weight: 700;
	font-size: 25px;
	text-align: center;
	background-color: #000;
	padding: 30px 0px;
	border-radius: 20px;
	margin: 25px auto 0;
}

.shop-bt a,.menu-bt a,.menu-bt02 a{
	color: #fff;
}

.concept-cont01,.concept-cont02{
	width: 520px;
	height: 254px;
	position: relative;
	font-family: "Noto Serif JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 600;
	font-style: normal;
	font-size: 18px;
	line-height: 40px;
	color: #fff;
	margin-bottom: 80px;
	margin-top: 40px;
}

.concept-cont01{
	background-color: #950000;
}

.concept-cont02{
	background-color: #000000;
}


.concept-cont01 p,.concept-cont02 p{
	position: absolute;
	top: 50%;
	left: 50%;
	transform:translate(-50%,-50%);
	text-align: center;
	width: 100%;
}


.concept-cont01 img,.concept-cont02 img{
	width: 106px;
	position: absolute;
	top: -30px;
	left: -30px;
}

/*メニュースライド*/

/* カルーセル全体 */
.carousel {
  /* 水平方向中央寄せ */
  display: flex;
  justify-content: center;
padding-left: 10px;
padding-right: 10px;
}
/* カルーセル内容 */
.contains {
  /* サイズは自由に変更してください。*/
  /* 下の.slideも同じサイズにしてください。 */
  width: 100%;
	height: 1565px;
  overflow: hidden;
  position: relative;
  padding: 0;
  list-style: none;
}
/* スライド切り換え用ラジオボタンは常に非表示 */
.slide_select {
  display: none;
}
/* 各スライド */
.slide {
  /* サイズは自由に変更してください。*/
  /* 上の.containsも同じサイズにしてください。 */
  width: 100%;
	height: 1565px;
  position: absolute;
  /* スライドの初期値は選択されていないので透明にしておく */
  opacity: 0;
	text-align: center;
}
/* 前へ次へボタン */
.scroll_button {
  position: absolute;
  display: block;
  /* 縦中央から20px上の位置 */
  top: 50%;
  margin-top: -20px;
  /* 上辺と右辺のみ幅5pxの枠線 */
  cursor: pointer;
  /* 普段はボタンはやや薄くする */
  opacity: 0.5;
  /* スライドよりも前面にする */
  z-index: 3;
}


/* ホバー時にボタンを強調 */
.scroll_button:hover {
  opacity: 1;
}

/* 前へボタン */
.scroll_prev {
  left: 0px;
}
/* 次へボタン */
.scroll_next {
  right: 0px;
}

/* スライド移動ボタンエリア */
.move_controler {
  position: absolute;
  bottom: 20px;
  width: 100%;
  text-align: center;
}
/* スライド移動の各ボタン */
.button_move {
  display: inline-block;
  height: 15px;
  width: 15px;
  margin: 0 2px;
  border-radius: 100%;
  cursor: pointer;
  /* 普段はやや薄くする */
  opacity: 0.5;
  /* スライドより前面にする */
  z-index: 2;
}
/* ホバー時はやや明るくする */
.button_move:hover {
  opacity: 0.75;
}
/* スライド移動ボタンの色 */
.button_move {
  background-color: #fdfdfd;
}
/* 1番目のスライド選択時 */
/* 1番目のスライドの透明度を0にして表示する */
.slide_select:nth-of-type(1):checked ~ .slide:nth-of-type(1) {
  opacity: 1;
}
/* スライド移動ボタンの1個目を明るくする */
/* （今選択されていることが分かるように） */
.slide_select:nth-of-type(1):checked ~ .move_controler .button_move:nth-of-type(1) {
  opacity: 1;
}
.slide_select:nth-of-type(2):checked ~ .slide:nth-of-type(2) {
  opacity: 1;
}
/* 2番目のスライド選択時（1番目のスライドと同じことをする） */
.slide_select:nth-of-type(2):checked ~ .move_controler .button_move:nth-of-type(2) {
  opacity: 1;
}
/* 3番目のスライド選択時 */
.slide_select:nth-of-type(3):checked ~ .slide:nth-of-type(3) {
  opacity: 1;
}
.slide_select:nth-of-type(3):checked ~ .move_controler .button_move:nth-of-type(3) {
  opacity: 1;
}

.slide_select:nth-of-type(4):checked ~ .slide:nth-of-type(4) {
  opacity: 1;
}
.slide_select:nth-of-type(4):checked ~ .move_controler .button_move:nth-of-type(4) {
  opacity: 1;
}

.slide_select:nth-of-type(5):checked ~ .slide:nth-of-type(5) {
  opacity: 1;
}
.slide_select:nth-of-type(5):checked ~ .move_controler .button_move:nth-of-type(5) {
  opacity: 1;
}


/*店舗一覧*/
.shop-all{
	margin-bottom: 110px;
}

.shop-all02{
	background-color: #FFF2F2;
	padding: 110px 0 55px;
	margin-bottom: 110px;
}



.shop-all02,.coupon-all02:last-child{
	margin-bottom: 0;
}

#shop p,#coupon p,#company p,#recruit p,#contact-1 p{
	font-family: "Noto sans JP", sans-serif;
	font-weight: 500;
	font-size: 35px;
	text-align: center;
	letter-spacing: 2px;
	margin-top: 20px;
}

.shop-tittle h4{
	font-family: "Noto sans JP", sans-serif;
	font-weight: 900;
	max-width: 950px;
	font-size: 35px;
	letter-spacing: 2px;
	color: #950000;
	padding-bottom: 5px;
	border-bottom: 5px #950000 solid ;
	margin: 0 auto;
}

.shop-flex01{
	max-width: 950px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 20px auto 110px;
}

.shop-cont {
	font-family: "Noto sans JP", sans-serif;
	font-feature-settings: "palt" 1;
}

.shop-cont h5{
	font-weight: 700;
	font-size: 30px;
}

.shop-cont h5 span{
	font-size: 25px;
}

.tel{
	font-weight: 700;
	font-size: 38px;
	letter-spacing: 2.5px;
}

.time{
	font-weight: 500;
	font-size: 24px;	
	margin-bottom: 4px;
}

.shop-address{
	font-weight: 500;
	font-size: 18px;
	line-height: 24px;
}


/*特典*/
.coupon-all{
	margin-bottom: 110px;
	text-align: center;
}

.coupon-all02{
	max-width: 100%;
	background-color: #F0F0F0;
	padding: 110px 0;
	margin-bottom: 110px;
	text-align: center;
}

/*会社概要*/
.contents-table{
	max-width: 1080px;
	font-family: "Noto sans JP", sans-serif;
	font-size: 25px;
	margin: 0 auto 100px;
	border-top: 2px solid #000;
}

.table-txt th{
	min-width: 280px;
	font-weight: 900;
	background-color: #E3E3E3; 
	padding: 36px 64px;
	text-align-last: justify;
	border-bottom: 2px solid #000;
}

.table-txt td{
	width: 100%;
	font-weight: 500;
	padding: 36px 64px;
	line-height: 40px;
	border-bottom: 2px solid #000;
	background-color: #Fff; 
}

/*採用情報*/
.recruit-contact{
	font-family: "Noto sans JP", sans-serif;
	background-color: #F0F0F0;
	font-weight: 700;
	padding: 100px 0;
	text-align: center;
	margin-bottom: 110px;
}

.recruit-contact-tittle{
	font-size: 35px;
}

.recruit-contact-tel{
	max-width: 770px;
	font-size: 80px;
	color: #950000;
	background-color: #fff;
	padding: 20px 0;
	border-radius: 20px;
	text-align: center;
	margin: 20px auto;
}

.recruit-contact-time{
	font-size: 25px;
}

.recruit-tittle{
	max-width: 1080px;
	font-family: "Noto sans JP", sans-serif;
	font-size: 34px;
	letter-spacing: 3px;
	color: #fff;
	background-color: #950000;
	font-weight: 900;
	padding: 20px 0px 20px 60px;	
	margin: 0 auto;
}

.recruit-table01{
	margin-bottom: 100px;
}

.recruit-table02{
	margin-top: 100px;
	padding: 100px 0 50px;
	background-color: #F0F0F0;
}


/*おといあわせ*/


@media only screen and (max-width: 768px) {
     #contact-2 {
        /*　画面サイズ $spWidth まではここを読み込む　*/
        padding: 20px; } }



.contact-box{
	max-width: 1060px;
	background-color: #F0F0F0;
	margin: 0 auto;
	padding: 60px 40px 40px;
}



.contact_boxttl{
	font-family: "Noto sans JP", sans-serif;
	font-weight: 900;
	font-size: 23px;
	color: #000;
	padding: 10px;
}


.center{
	text-align: center;
}



   #contact-2 .contact_read {
      text-align: center;
      margin-bottom: 50px;
      color: #FFFFFF;
      font-size: 25px;
      font-weight: bold;
      -webkit-font-smoothing: antialiased; }
   #contact-2 .contact_rapper {
      max-width: 940px;
      margin: 0 auto; }
     #contact-2 .contact_rapper span {
		 font-size: 16px;
		 color: red; }
     #contact-2 .contact_rapper .flex {
        display: flex;
        width: 100%;
        justify-content: space-between;
        margin-bottom: 40px; }
        @media only screen and (max-width: 768px) {
         #contact-2 .contact_rapper .flex {
            /*　画面サイズ $spWidth まではここを読み込む　*/
            flex-direction: column; } }
       #contact-2 .contact_rapper .flex .contact_box_ttl {
          width: 40%;
          color: #FFFFFF; }
          @media only screen and (max-width: 768px) {
           #contact-2 .contact_rapper .flex .contact_box_ttl {
              /*　画面サイズ $spWidth まではここを読み込む　*/
              width: 100%; } }
       #contact-2 .contact_rapper .flex .contact_box_normal,#contact-2 .contact_rapper .flex .contact_box_textarea {
		   width: 70%;
		   padding: 20px;
		   border: none;
}
          @media only screen and (max-width: 768px) {
           #contact-2 .contact_rapper .flex .contact_box_normal,#contact-2 .contact_rapper .flex .contact_box_textarea {
              /*　画面サイズ $spWidth まではここを読み込む　*/
              width: 100%; } }


   #contact-2 .privacy_ttl_1 {
      font-size: 20px;
      font-weight: bold;
      -webkit-font-smoothing: antialiased;
      margin-bottom: 10px; }
   #contact-2 .privacy_wrap .privacy_ttl {
      font-size: 18px;
      font-weight: bold;
      -webkit-font-smoothing: antialiased;
      margin-bottom: 10px; }
   #contact-2 .privacy_wrap .privacy_txt {
      margin-bottom: 10px; }
   #contact-2 .privacy_wrap .privacy_h {
      font-size: 16px;
      font-weight: bold;
      -webkit-font-smoothing: antialiased;
      margin-bottom: 5px; }
   #contact-2 .btn-mail {
      padding: 24px 90px;
      font-family: "Noto Sans JP", sans-serif;
      font-optical-sizing: auto;
      font-weight: 900;
      font-style: normal;
      font-size: 23px;
      position: relative;
      margin: 60px auto 100px;
      text-align: center;
	  color: #fff;
      background-color: #000;
}

   #contact-2 .btn_return {
      background-color: #A5A5A5;
      padding: 20px;
      width: 200px;
      border-radius: 10px;
      font-family: "Noto Sans JP", sans-serif;
      font-optical-sizing: auto;
      font-weight: 800;
      font-style: normal;
      font-size: 30px;
      position: relative;
      margin: 0 auto;
      color: #fff;
      text-align: center;
      margin-top: 10px;
      }
 #contact-2 .privacy_wrap {
    height: 250px;
    border: none;
    overflow-y: scroll;
    text-align: left;
    font-size: 16px;
    line-height: 1.7;
    padding: 16px;
    box-sizing: border-box;
    margin: 50px auto;
    background-color: #ededed; }
 #contact-2 p.privacy {
    line-height: 1.7; }
 #contact-2 .privacy_strong_title {
    font-weight: bold; }
 #contact-2 .contact_field {
    display: none; }

#contact2{
position: relative;
}

.contact-ilust01{
	position: absolute;
	bottom: 0;
	right: 28%;
}


@media (max-width: 768px) {
 #contact-2 .contact_read {
     font-size: 20px;
	  }

.copy_footer{
	font-size: 12px;
}
	


.address{
	font-size: 13px;
}


}




/* ボタン全体 */
#page_top {
	width: 100px;
	height: 100px;
	background: #9DB0FF;
	opacity: 1;
	border-radius: 50%;
	z-index: 99;
	position: relative;
}

/* Font Awesome */
#page_top::before {
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	content: '\f106';
	font-size: 60px;
	color: #ffffff;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
}



@media screen and (max-width: 640px){
.catch-text{
	font-size: 12px;
	line-height: 24px;
	margin: 0 auto;
}
.catch-text img{
	padding-left: 30px;
	padding-right: 20px;
	margin-top: 20px;
}

h2{
	font-size: 60px;
	bottom: -12px;
}

#top-menu,#top-shop,#top-concept,#menu-cont{
	margin-bottom: 80px;
}

#top-catch,#menu,#menu-top{
	padding: 50px 0;
}

#menu-top,#shop,#coupon,#company,#recruit,#contact-1{
	padding: 70px 0;
}


.menu-flex,.shop-flex,.concept-flex{
	justify-content: space-around;
	gap: 20px;
}



.menu-cont{
	border-right: none; 
	border-bottom: 5px #950000 solid; 
	padding-right: 0;
	padding-bottom: 20px;
}

.shop-bt,.menu-bt{
	width: 340px;
}

.menu-bt{
	width: 340px;
	margin-bottom: 0;
	font-size: 16px;
}

.menu-bt02{
	width: 340px;
	font-size: 16px;
}

.concept-cont01,.concept-cont02{
	width: 340px;
	height: 180px;
	font-size: 13px;
	line-height: 26px;
	margin-bottom: 30px;
	margin-top: 20px;
}

.concept-cont01 img,.concept-cont02 img{
	width: 70px;
	position: absolute;
	top: -20px;
	left: -10px;
}

.site-footer{
	justify-content: space-around;
}

#page_top {
	width: 80px;
	height: 80px;
	margin-top: 20px;
	margin-bottom: 20px;
}

.menu-flex00{
	display: block;
	margin: 0 auto;
	padding: 40px 0 0px;
}

.menu-cont00{
	width: 100%;
	margin-bottom: 40px;
}

#menu h2{
	font-size: 70px;
	bottom: -14px;
}

.contains {
  /* サイズは自由に変更してください。*/
  /* 下の.slideも同じサイズにしてください。 */
  width: 100%;
	height: 440px;
  overflow: hidden;
  position: relative;
  padding: 0;
  list-style: none;
}

/* 各スライド */
.slide {
  /* サイズは自由に変更してください。*/
  /* 上の.containsも同じサイズにしてください。 */
  width: 100%;
	height: 440px;
  position: absolute;
  /* スライドの初期値は選択されていないので透明にしておく */
  opacity: 0;
	text-align: center;
}

.scroll_button img{
	width: 20px;
}

#top-menu,#top-shop,#top-concept,#menu-cont{
	margin-bottom: 40px;
}

#shop p,#coupon p,#company p,#recruit p,#contact-1 p{
	font-size: 20px;
	letter-spacing: 1px;
}

/*特典*/
.coupon-all{
	margin-bottom: 60px;
	padding-left: 10px;
	padding-right: 10px
}

.coupon-all02{
	padding: 60px 10px;
	margin-bottom: 60px;
}

/*会社概要*/
.contents-table{
	font-size: 18px;
	padding-left: 10px;
	padding-right: 10px;
	border-top: none;
}


.table-txt th, .table-txt td{
	display: block;
	padding: 18px 32px;
}

.table-txt th{
	text-align-last: left;
	border-bottom: 1px solid #000;
}

.table-txt th:first-child{
	border-top: 1px solid #000;
}

.table-txt td{
	line-height: 24px;
	border-bottom: 1px solid #000;
}

.shop-tittle {
	padding-left: 24px;
	padding-right: 24px;
}

.shop-tittle h4{
	font-size: 30px;
}

.shop-flex01{
	justify-content: space-around;
}

.googlemap{
	padding: 10px 20px;
}

}