@charset "UTF-8";
/* CSS Document */

/*--------------------------------------------------
top　ヘッダー
--------------------------------------------------*/
.content {
  padding-top: 0;
}
#header{
	display: none;
}
#header.fixed {
  display: block;
  position: fixed;
  z-index: 1;
  top: 0;
  left: 0;
  right: 0;
}
#top_header {
  width: 220px;
  background: #d7000f;
  padding: 24px 32px;	
  position: relative;	
}
#top_header.hidden {
  display: none;
}
#top_header::after {
  content: "";
  width: calc(100% + 60px);
  width: 100%;	
  position: absolute;
  bottom: -48px;
  background: #d7000f;
  height: 48px;
  z-index: 1;
  left: 0;
}
#top_header .h_logo {
  text-align: center;
  margin-bottom: 32px;	
}
#top_header .btm {
  position: absolute;
  bottom: -30px;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 2;	
}
#top_header .top_nav_li {
  margin-bottom: 4px;
  text-align: left;	
}
#top_header .top_nav_li a {
  font-size: 16px;
  color: #fff;
  line-height: 1.3;	
  text-decoration: none;
  letter-spacing: 0.08em;
  padding: 8px 8px;	
  display: block;	
}
#top_header .top_nav_li a:hover {
  background: #b70e1a;
  border-radius: 50px;
}
#top_header .top_nav_btn_li:nth-child(1) a:hover {
  background-image: url("../img/common/icn_h_tenpo_red.png");
  background-repeat: no-repeat;
  background-position: 16px center;
  background-size: 24px 19px;
}
#top_header .top_nav_btn_li a:hover {
  color: #d7000f;
  background: #fff;
  transition: 0.5s;
}
/*#top_header .top_nav_btn_li:nth-child(1) a {
  background-image: url("../img/common/icn_h_tenpo.png");
  background-repeat: no-repeat;
  background-position: 16px center;
  background-size: 24px 19px;
}*/
#top_header .top_nav_btn_li a {
  width: 150px;
  font-size: min(1.25vw,15px);
  color: #fff;
  text-decoration: none;
  display: flex;
  text-align: center;
  border: solid 1px #fff;
  padding: 8px 0;
  border-radius: 50px;
  line-height: 1;
  align-items: center;
  align-content: center;
  justify-content: center;
  margin: 0 auto 12px auto;	
}
#top_header .top_nav_btn_li:nth-child(2) a:hover {
  background-image: url("../img/common/icn_h_mypage_red.png");
  background-repeat: no-repeat;
  background-position: 16px center;
  background-size: 18px;
}
#top_header .top_nav_btn_li a:hover {
  color: #d7000f;
  background: #fff;
    background-position-x: 0%;
    background-position-y: 0%;
    background-repeat: repeat;
    background-image: none;
    background-size: auto;
  transition: 0.5s;
}
#top_header .top_nav_btn_li:nth-child(2) a {
  background-image: url("../img/common/icn_h_mypage.png");
  background-repeat: no-repeat;
  background-position: 16px center;
  background-size: 18px;
}
#top_header .language {
  text-align: center;
}
#top_header select {
  border: none;
  background: #b70e1a;
  width: 150px;
  padding: 5px;
  border-radius: 50px;
  text-align: center;
  font-size: 15px;
  color: #fff;
  background-image: url("../img/common/icn_langage.png");
  background-repeat: no-repeat;
  background-position: 10px center;
  background-size: 16px;
}

.top_main {
  display: flex;
  justify-content: space-between;
}
 .main_visual {
  width: calc(100% - 220px);
  position: relative;	
	 
}
.main_visual video{
  width: 100%;
}
.main_visual .frame {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.main_visual .frame video {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: cover;	
}
.frame_video iframe {
  position: absolute;
  width: 100%;
  height: 100%;
/*  pointer-events: none;*/
}
.frame_video {
  position: relative;
  aspect-ratio: 16/9;
}
/*動画のタイトル*/
h1.ytd-watch-metadata:not(:hover) {
  opacity: 0;
}
.ytp-title-enable-channel-logo .ytp-title {
  min-height: 0 !important;
}
.ytp-title-channel {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  min-height: 0 !important;
}
.ytp-gradient-top{
	opacity: 0 !important;
	visibility: hidden !important;
	min-height: 0 !important;
	display: none !important;
}


@media screen and (max-width:900px){
.main_visual {
  width: calc(100% - 160px);
	}
.main_visual .frame video {
height: 110%;
	}
#top_header {
  max-width: 160px;
  padding: 2%;
}
#top_header .btm {
  bottom: -30px;
	}
#top_header .h_logo {
  margin-bottom: 16px;
}	
}

@media screen and (max-width:768px){
#top_header {
  display: none;
}
.main_visual .frame video {
  height: 100%;
}	
#header {
  position: relative !important;
  display: block;
  width: 100%;
  top: 0;
  left: 0;
  right: 0;
}	
.content {
  padding-top: 0;
}	
.main_visual {
  width: 100%;
  position: relative;
}	
.main_visual .frame {
  padding-top: 0;
}
.main_visual .frame video {
  position: inherit;
	}
}

/* youtube設定 */

#youtube-area{
    position: fixed;
    z-index: 1;/*最背面に設定*/
    top: 0;
    right:0;
    left:0;
    bottom:0;
    overflow: hidden;
  opacity: 0;    
}

/*jQueryで付与されたappearクラスがついたらYoutubeエリアをふわっと表示*/
#youtube-area.appear {
  animation-name:PageAnimeAppear;
  animation-duration:.5s;
  animation-fill-mode:forwards;
}

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

#youtube {
/*天地中央配置*/
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
/*縦横幅指定*/
/*  width: 177.77777778vh;  16:9 の幅→16 ÷ 9＝ 177.77% 
  height: 56.25vw;  16:9の幅 → 9 ÷ 16 = 56.25% 
  min-height: 100%;
  min-width: 100%;*/
  aspect-ratio: 16/9;
}

/*youtubeがクリックされないためのマスク*/
#youtube-mask{
    position: absolute;
    z-index: 2;/*下から2番目に表示*/
    top:0;
    width:100%;
    height: 100%;
}

/*--------------------------------------------------
ページ内リンク
--------------------------------------------------*/
.page_link {
  transform: translateX(100%);	
  transition: 0.5s;	
  display: none;
  z-index: 2;
  right: 0;	
}
.page_link.fixed {
  position: fixed;
  right: 0;
  bottom: 140px;
  z-index: 2;
  display: flex;
}
.page_link.open {
    transform: translateX(0);
}
.page_link_li {
  margin-bottom: 4px;
}
.page_link_li a:hover {
  background: #434343;
}
.page_link_li a {
  font-size: 14px;
  color: #fff;
  text-decoration: none;
  padding: 8px 12px;
  display: block;
  background: #000;
  border-radius: 50px;
}
.page_link_li:last-child {
  margin-bottom: 0;
}
.page_link_list {
 padding: 16px 24px;
 background: #000;
 border-radius: 0;
min-height: 180px;
}
.page_link_tab {
  overflow: hidden;
  position: absolute;
  left: -80px;
}

@media screen and (max-width:768px){
.page_link_tab img {
  width: 50px;
}
.page_link {
  transform: translateX(calc(100% - 1px));
}	
.page_link_list {
  padding: 10px 10px;
}
.page_link_li a {
  font-size: 13px;
  padding: 8px 10px;
	}
.page_link_tab {
  left: -49px;
}	
.page_link.fixed {
  position: fixed;
  right: 0;
  bottom: 55px;
  z-index: 2;
  display: flex;
}	
}



/*--------------------------------------------------
top sns
--------------------------------------------------*/
.top_sns_wrap {
  display: flex;
  align-items: center;
  position: absolute;
  top: 20px;
  right: 40px;
}
.top_sns_wrap.media_pc {
  display: flex;
}
.top_sns_list {
  display: flex;
}
.top_sns_li{
	margin-right: 10px;
}
.top_sns_li:last-child{
	margin-right: 0;
}
.top_sns_icn {
  margin-right: 8px;
}

@media screen and (max-width:768px){
.top_sns_wrap.media_pc {
  display: none;
}	
.top_sns_wrap {
  bottom: -50px;
  left: 0;
  right: 0;
  margin: auto;
  text-align: center;
  justify-content: center;
}	
.top_sns_wrap.media_sp {
  display: flex;	
  align-items: center;
  position: relative;
  top: inherit;
  right: 40px;
  bottom: inherit;	
  display: none;
}	
}


/*--------------------------------------------------
top news
--------------------------------------------------*/
#top_news_area {
/*  width: 100%;
  max-width: 800px;	
*/
margin: 0 0 0 auto;
background: #000;
padding: 12px 20px;
display: flex;
align-items: flex-start;
width: calc(100% - 220px);
padding-right: 200px;
position: relative;	
}
#top_news_area .h2_title {
  width: 80px;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.05em;
  padding: 6px 10px;
  border: solid 2px #fff;
  border-radius: 50px;
  color: #fff;
  text-align: center;
  margin-right: 16px;	
}
#top_news_area .slider {
  width: calc(100% - 104px);
}
/*.slider{
  display: none;
}
.slider.slick-initialized{
  display: block; slick-initializedが付与されたら表示
}*/
.news_li {
  background: #000;
  color: #fff;
}
.news_li {
  max-width: 800px;	
  display: flex !important;
  justify-content: space-between;
  align-items: flex-start;	
}
.news_li a {
  width: calc(100% - 110px);	
  color: #fff;
  text-decoration: none;
}
.news_dt {
	font-size: 15px;
	margin-bottom: 10px;
	display: inline-block;
    position: relative;	
    padding-right: 90px;	
}
.news_dt::before {
  width: 80px;
  line-height: 16px;
  height: 20px;
}
.news_dt.news_info:before {
content: "新着情報";
font-size: 11px;
position: absolute;
right: 0;
top: -2px;
bottom: 0;
text-align: center;
color: #359ee0;
border: solid 1px #359ee0;
}
.news_dt.info:before {
content: "お知らせ";
font-size: 11px;
position: absolute;
right: 0;
top: -2px;
bottom: 0;
text-align: center;
color: #5eb583;
border: solid 1px #5eb583;
}
/* .news_dt.press:before {
  content: "プレスリリース";
  font-size: 11px;
  position: absolute;
  right: 0;
  top: -2px;
  bottom: 0;
  text-align: center;
  color: #f19149;
  border: solid 1px #f19149;
} */
.news_dt.press_release:before {
  content: "プレスリリース";
  font-size: 11px;
  position: absolute;
  right: 0;
  top: -2px;
  bottom: 0;
  text-align: center;
  color: #f19149;
  border: solid 1px #f19149;
  }
/* .news_dt.news_store:before {
content: "新店情報";
font-size: 11px;
position: absolute;
right: 0;
top: -2px;
bottom: 0;
text-align: center;
color: #db1927;
border: solid 1px #db1927;
} */
.news_dt.store:before {
content: "新店情報";
font-size: 11px;
position: absolute;
right: 0;
top: -2px;
bottom: 0;
text-align: center;
color: #db1927;
border: solid 1px #db1927;
}
.news_dd {
  font-size: 18px;
  line-height: 1.6;	
}
.news_img{
	width: 100px;
    height: 60px;	
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
.more a {
  display: flex;
  align-items: center;
  position: absolute;
  bottom: 0;
  right: 0;
  height: 100%;
  width: 160px;
  background: #fdd20f;
  top: 0;
  justify-content: center;
  transition: 0.5s;
	border: solid 1px #ffda3f;
}
.more a:hover {
  background: #fff;
  border: solid 1px #000;	
}
.slick-vertical .slick-slide {
  display: block;
  border: 1px solid transparent;
  overflow: hidden;
  height: 90px;
  min-height: 90px;
}

@media screen and (min-width:1200px){
#top_news_area .slider {
  width: 75%;
  max-width: 640px;	
}
}

@media screen and (max-width:900px){
#top_news_area {
  width: calc(100% - 160px);
  padding-right: 110px;
  margin-top: -16px;	
	}
.more a {
 width: 100px;
 padding: 0 4px;
}	
.news_dd {
  font-size: 16px;
	}
}
@media screen and (max-width:810px){
#top_news_area {
  margin-top: -22px;	
	}
}
@media screen and (max-width:781px){
#top_news_area {
  margin-top: -34px;
}
}

@media screen and (max-width:900px){
}

@media screen and (max-width:768px){
#top_news_area {
  width: 100%;
  margin: 0 auto;
  position: relative;
  display: block;
  padding: 10px;
  margin-bottom: 10px;	
	}
.more{
  display: none;
	}
.more_sp.media_sp a {
  font-size: 13px;
  color: #ffe100;
  position: absolute;
  top: 10px;
  right: 10px;
}	
#top_news_area .slider {
  width: 100%;
}	
#top_news_area .h2_title {
  width: 72px;
  font-size: 14px;
  padding: 4px 8px;
 margin-bottom: 16px;	
	}
.news_dl {
  margin-right: 8px;
  width: 100%;
}	
.news_dd {
  font-size: 14px;
}		
}

@media screen and (max-width:414px){
.news_li a {
  width: calc(100% - 90px);
}
}

/*--------------------------------------------------
緊急のお知らせ
--------------------------------------------------*/
.breaking_news_wrap {
 max-width: 1000px;
 margin: 20px auto auto;
 display: flex;
 align-items: center;
 background: #e60012;
 border-radius: 10px;
}
.breaking_news_title {
  width: 10%;
  font-size: 18px;
  color: #fff;	
  text-align: center;
  background: #e60012;
  border-radius: 10px 0 0 10px;	
}
.breaking_news {
  width: 90%;	
  margin: 0 auto;
  background: pink;
  border-radius: 0 10px 10px 0;
  border: solid 2px #e60012;
  display: flex;
  align-items: center;
  padding: 10px 16px;	
}
.news_ticker1 {
	width: 100%;
	overflow:hidden;
}
.news_ticker1 ul li{
	margin-bottom: 12px;
}
.news_ticker1 ul li:last-child{
	margin-bottom: 0;
}
.news_ticker1 ul li a {
  text-decoration: none;
  font-size: 18px;
  font-weight: 500;	
  line-height: 1.3;	
  letter-spacing: 0.05em;
  color: #000;
}
.news_ticker1 ul li a:hover {
  color: #e60012;
}
.breaking_news_dl {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;	
}
.breaking_news_dt {
  width: 20%;
}
.breaking_news_dd {
  width: 80%;
}

/*@keyframes hscroll {
	0% { transform:translateX(800px); }
	100% { transform:translateX(-100%); }
}
.news_ticker1 ul {
	display:inline-block;
	margin:0;
	padding:0;
	animation:hscroll 32s linear infinite;
}
.news_ticker1 li {
	display:inline-block;
}*/

@media screen and (max-width:768px){
.breaking_news_wrap {
  width: 95%;	
  display: block;  
  margin: 0 auto 16px auto;
	}	
.breaking_news_title {
  width: 100%;
  font-size: 16px;
  text-align: left;
  border-radius: 8px 8px 0 0;
  padding: 8px 20px;
}
.breaking_news {
  width: 100%;
  border-radius: 0 0 8px 8px;
  display: block;
  padding: 10px 16px;
}
.news_ticker1 ul li a {
  text-decoration: none;
  font-size: 14px;
  line-height: 1.3;	
  letter-spacing: 0.04em;	
}
.breaking_news_dl {
  display: block;
	}
.breaking_news_dt {
  width: 100%;
  margin-bottom: 4px;
}	
.breaking_news_dd {
  width: 100%;
}	
}


/*--------------------------------------------------
こだわり
--------------------------------------------------*/
#about {
  background: url("../img/top/img_sukiya_ship.jpg");
  background-repeat: no-repeat;
  background-position: left top;
  background-size: cover;
  padding: 120px 0 200px 0;
  clip-path: polygon(0 0, 100% 0, 100% 80%, 0 100%);
}
#about .section_inner {
  display: flex;
  justify-content: end;
  flex-direction: row-reverse;
}
.top_h1 {
  display: flex;
  justify-content: right;
  align-items: flex-start;	
  opacity: 0;
  transition: 0.5s;	
}
.top_h1.show{
  opacity: 1;
}
.top_h1 span{
  font-size: 32px;
  font-weight: 700;
  color: #fff;	
  line-height: 1.6;
  text-align: right;
  background: #631c18;
  padding: 32px 16px;	
  margin-left: 10px;	
  position: relative;
}
.top_lead span {
  padding: 16px;
  margin-left: 6px;
  position: relative;	
}
.top_lead {
  display: flex;
  align-items: flex-start;
  flex-direction: row-reverse;
  margin-right: 16px;
  opacity: 0;
  transition: 0.5s;	
}
.top_lead.show{
 opacity: 1;
}

.top_lead .lead_01.show{
  background: #fff;
}
.top_lead .lead_02.show{
  background: #fff;
}
.top_lead .lead_03.show{
  background: #fff;
}
.top_lead .lead_04.show{
  background: #fff;
}
.top_h1 span::after {
  content: "";
  width: 100%;
  height: 100%;
  background: #631c18;
  position: absolute;
  left: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  transition: 1s;	
}
.top_h1 span.show::after {
  height: 0;	
}
.top_lead span::after {
  content: "";
  width: 100%;
  height: 100%;
  background: #fff;
  position: absolute;
  left: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  transition: 1s;	
}
.top_lead span.show::after {
  height: 0;	
}

@media screen and (max-width:768px){
#about {
  padding: 48px 20px 120px 20px;
  clip-path: polygon(0 0, 100% 0, 100% 80%, 0 100%);
}
.top_lead .lead_01.show{
  background: rgba(255,255,255,0.8);
}
.top_lead .lead_02.show{
  background: rgba(255,255,255,0.8);
}
.top_lead .lead_03.show{
  background: rgba(255,255,255,0.8);
}
.top_lead .lead_04.show{
  background: rgba(255,255,255,0.8);
}
	
}



/*--------------------------------------------------
page_common
--------------------------------------------------*/
.section_inner {
  max-width: 1000px;
  margin: 0 auto;
}
.title_h2 {
  font-size: min(4vw,40px);
  font-weight: bold;
  color: #000;
  letter-spacing: 0.05em;
  flex-wrap: wrap;
  text-align: center;
  margin-bottom: 60px;
}
.title_h2 span::before {
  content: "";
  width: 80px;
  height: 5px;
  background: #d7000f;
  position: absolute;
  top: -16px;
  left: 0;
  right: 0;
  margin: auto;
}
.title_h2 span {
  font-size: min(1.8vw,18px);
  display: block;
  width: 100%;
  text-align: center;
  margin-top: 27px;
  position: relative;
}

@media screen and (max-width:768px){
.title_h2 {
  font-size: 24px;
  margin-bottom: 40px;
}
.title_h2 span {
  font-size: 14px;
	}
.title_h2 span::before {
  width: 64px;
  height: 4px;
	}
}

/*--------------------------------------------------------------------
こだわり
--------------------------------------------------------------------*/
#kodawari {
  margin-top: -140px;
}
.kodawari_li{
  overflow: hidden;	
}
.b_content_l{
	position: relative;
}
.kodawari01{
    height: 640px;
	background-image: url("../img/top/img_kodawari_bg01_02.jpg");
	background-repeat: no-repeat;
	background-position: left;
	background-size: cover;
	clip-path: polygon(0 20%, 100% 0, 100% 80%, 0 100%);
	margin: 0 auto;
	position: relative;
	display: flex;
    justify-content: space-between;
    align-items: center;
}
#kodawari01::before {
  content: "";
  width: 100%;
  height: 100%;
  background: #333;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  transition: 1.5s;	
  z-index: 1;	
}
/*== 背景が流れる（斜め） */
#kodawari01.show::before {
  content: '';
  position: absolute;
  top: 0;
  left: 100%;
  background: #333;
  width: 120%;
  z-index: 1;
}

/*hoverした時のアニメーション*/
.bgskew:hover::before {
	animation: skewanime .5s forwards;/*アニメーションの名前と速度を定義*/
}

@keyframes skewanime {
	100% {
		left:-10%;/*画面の見えていない左から右へ移動する終了地点*/
	}
}
.kodawari01 .b_content_l {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  width: 70%;
}
.kodawari01 .b_content_r {
  width: 30%;
  height: 100%;	
  background: #333;
  position: relative;	
}
.kodawari01 .kodawari_h2 span {
  padding: 32px 24px;
}
.kodawari01 .kodawari_h2 {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  align-content: center;
  position: absolute;
  top: 21%;
  height: 38%;
  bottom: 41%;
  left: 30%;
  right: 30%;
  width: 40%;
}


/* kodawari02 */
#kodawari02 {
  margin-top: -140px;
}

.kodawari02 {
    height: 640px;
    background-color: #333;
    clip-path: polygon(0 20%, 100% 0, 100% 80%, 0 100%);
	margin: 0 auto;
	position: relative;
	display: flex;
    justify-content: space-between;
    align-items: center;
	
}
.kodawari02::before {
  content: "";
  width: 100%;
  height: 100%;
  background: #333;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  transition: 1.5s;	
  z-index: 1;	
}
/*== 背景が流れる（斜め） */
.kodawari02.show::before {
	content: '';
	position: absolute;
	top: -20%;
	left: -130%;/*数値が小さいと途中で止まる*/
	background:#333;
	width:120%;
	height: 140%;
	transform: rotate(7deg);
	z-index: 1;
}

/*hoverした時のアニメーション*/
.bgskew:hover::before {
	animation: skewanime02 .5s forwards;/*アニメーションの名前と速度を定義*/
}

@keyframes skewanime02 {
	100% {
		right:-10%;/*画面の見えていない左から右へ移動する終了地点*/
	}
}
.kodawari02 .b_content_l {
  width: 30%;
  background: #333;	
  position: relative;
  height: calc(640px + 20%);	
}
.kodawari02 .b_content_r {
  width: 70%;
}
.kodawari02 .b_content_r video {
  width: 140%;
  height: auto;
}
.kodawari02 .kodawari_h2 span {
  padding: 32px 24px;
}
.kodawari02 .kodawari_h2 {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  align-content: center;
  position: absolute;
  top: 34%;
  height: 44%;
  bottom: 24%;
  left: 30%;
  right: 30%;
  width: 40%;
}

/* こだわり03 */
#kodawari03 {
  margin-top: -140px;
}
.kodawari03 {
  height: 640px;
  background-image: url("../img/top/img_kodawari_bg_03_02.jpg");
	background-repeat: no-repeat;
	background-position: left;
	background-size: cover;
	clip-path: polygon(0 20%, 100% 0, 100% 80%, 0 100%);
	margin: 0 auto;
	position: relative;
	display: flex;
    justify-content: space-between;
    align-items: center;
}

.kodawari03::before {
  content: "";
  width: 100%;
  height: 100%;
  background: #333;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  transition: 1.5s;	
  z-index: 1;	
}

/*== 背景が流れる（斜め） */
.kodawari03.show::before {
	content: '';
	position: absolute;
	top: 0;
	left: 100%;/*数値が小さいと途中で止まる*/
	background:#333;
	width:120%;
	height: 100%;
	z-index: 1;
}

/*hoverした時のアニメーション*/
.bgskew:hover::before {
	animation: skewanime03 .5s forwards;/*アニメーションの名前と速度を定義*/
}

@keyframes skewanime03 {
	100% {
		left:-10%;/*画面の見えていない左から右へ移動する終了地点*/
	}
}
.kodawari03 .b_content_l {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  width: 70%;
}
.kodawari03 .b_content_r {
  width: 30%;
  background: #333;
  position: relative;
  position: absolute;
  top: -10%;
  right: 0;
  bottom: 0;
  height: calc(640px + 20%);
}
.kodawari03 .kodawari_h2 span {
  padding: 32px 24px;
}
.kodawari03 .kodawari_h2 {
	display: flex;
	flex-direction: row-reverse;
	align-items: flex-start;
	align-content: center;
	position: absolute;
	top: 20%;
	height: 41%;
	bottom: 39%;
	left: 30%;
	right: 30%;
	width: 40%;
}
/* ボタン */
#kodawari .btn_area {
  max-width: 1000px;
  margin: -40px auto 0 auto;
}





@media screen and (max-width:768px){
.kodawari01 {
  height: 320px;
	}
.kodawari02 {
  height: 320px;
	}	
.kodawari03 {
  height: 320px;
	}
.kodawari01 .kodawari_h2 {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  align-content: center;
  position: absolute;
  top: 9%;
  height: 45%;
  bottom: 46%;
  left: 44%;
  right: 44%;
  width: 12%;
}	
.kodawari02 .kodawari_h2 {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  align-content: center;
  position: absolute;
  top: 37%;
  height: 22%;
  bottom: 41%;
  left: 42%;
  right: 45%;
  width: 13%;
}
.kodawari03 .kodawari_h2 {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  align-content: center;
  position: absolute;
 top: 14%;
 height: 45%;
 bottom: 41%;
 left: 44%;
 right: 44%;
 width: 12%;
}	
.kodawari02 .b_content_r video {
  width: 211%;
	}
#kodawari .btn_area {
  margin: 0 auto 0 auto;
	}
#kodawari .btn_area.arign_right a {
  margin-left: auto;
  margin-right: 0;
  margin: 0 auto;
}	
}




/*--------------------------------------------------
季節のメニュー
--------------------------------------------------*/
#limited_menu {
  padding: 40px 20px 80px 20px;
}
#limited_menu .section_inner {
  max-width: 100%;
  margin-bottom: 20px;	
}
#slider02 .slide-item {
  margin: 0 8px;
}
#slider02 .slide-item img {
  width: 100%;
  border-radius: 12px;	
}

#thumbnail_slider {
  width: 100%;
 margin: 24px auto 10px;
 padding: 0 30%; 	
}
#thumbnail_slider .thumbnail-item img {
  width: 98%;
  margin: 0 auto;
}
#slider02 {
  margin-left: -8px;
  margin-right: -8px;
}
#thumbnail_slider .thumbnail-item {
  margin: 0 4px;
}
#thumbnail_slider .slick-prev, #thumbnail_slider .slick-next {
  width: 40px;
  height: 40px;
}
#thumbnail_slider .slick-prev.slick-arrow, #thumbnail_slider .slick-next.slick-arrow {
  background: inherit;
}
#thumbnail_slider .slick-prev {
  left: 0;
}
#thumbnail_slider .slick-next {
  right: 0;
}
#thumbnail_slider .slick-prev::before {
  width: 40px;
  height: 40px;	
  content: "";
  background-image: url("../img/top/arrow_slider02_l.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  display: block;	
}
#thumbnail_slider .slick-next::before {
  width: 40px;
  height: 40px;	
  content: "";
  background-image: url("../img/top/arrow_slider02_r.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  display: block;		
}
#thumbnail_slider img{
	opacity: 0.5;
}
#thumbnail_slider .slick-current img{
  border:3px solid #000;
  opacity: 1;	
}
.slick-slide{
  padding:2px;
}	
.special_banner{
    text-align: left;
}
.special_banner a {
  max-width: 420px;
  width: 100%;
  height: auto;
  transition: 0.5s;	
  display: block;
  position: relative;
  margin: 0 auto;
  padding: 10px;
  border: solid 2px #000;
  border-radius: 16px;	
}
.special_banner a:hover {
  background: #ffd510;
  transition: 0.5s;
}
.special_banner a:after {
  content: "";
  width: 24px;
  height: 24px;
  background-image: url("/menu/img/arrow_special.png")	;
  background-repeat: no-repeat;
  background-position:center;
  background-size: contain;	
  position: absolute;
  top: 0;
  right: 12px;
  bottom: 0;
  margin: auto;
  transition: 0.5s;	
}
.special_banner a:hover:after {
  right: 6px;
}

@media screen and (max-width:1000px){
#limited_menu .section_inner {
  padding: 0;	
}
}
@media screen and (max-width:768px){	
#slider02_sp .slide-item img {
  border-radius: 12px;
}
#thumbnail_slider {
  display: none;
}	
.special_banner a img {
  width: 280px;
	}
.special_banner a {
  max-width: 340px;
  padding: 4px 10px;	
	}
.slick-dotted.slick-slider {
  margin-bottom: 50px;
}	
#limited_menu {
  padding: 60px 0 40px 0;
}
#thumbnail_slider .slick-prev {
  left: -20px;
}
#thumbnail_slider .slick-next {
  right: -20px;
}
#thumbnail_slider {
  margin: 16px auto 10px;
  padding: 0 30px;
}	
}


/*--------------------------------------------------
おすすめ
--------------------------------------------------*/
#recommend_menu {
  padding: 80px 0;
  position: relative;
  background: #fff;	
}
/* おすすめ商品のスライド */

/* 中央以外のスライド */
#slider03 .slick-img img {
  height: auto;
  transform: scale(.8);
  transition: opacity .5s, transform .5s;
  width: 100%;
}
/* 中央のスライド */

#slider03 .slick-center img {
  transform: scale(1);
}
#slider03 .slick-slide .img {
  padding-bottom: 40px;
  margin-bottom: 16px;	
}
#slider03 .slick-center.slick-active .img{
	background-image:url("../img/top/img_recommend_bg.png");
	background-repeat: no-repeat;
	background-position: bottom center;
    background-size: 100%;	
}
#slider03 .menu {
  font-size: 28px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 16px;
}
#slider03 .price {
  font-size: 16px;
  font-weight: 600;
  text-align: center;	
}
#slider03 .price span {
  font-size: 24px;
  margin: 0 4px;
}

#slider03 .slick-prev, #slider03 .slick-next {
  width: 70px;
  height: 70px;
}
#slider03 .slick-prev.slick-arrow, #slider03 .slick-next.slick-arrow {
  background: inherit;
}
#slider03 .slick-prev {
  left: 0;
}
#slider03 .slick-next {
  right: 0;
}
#slider03 .slick-prev::before {
  width: 70px;
  height: 70px;	
  content: "";
  background-image: url("../img/top/arrow_recommend_l.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  display: block;	
}
#slider03 .slick-next::before {
  width: 70px;
  height: 70px;	
  content: "";
  background-image: url("../img/top/arrow_recommend_r.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  display: block;		
}
#slider03 .slick-prev::before, #slider03 .slick-next::before {
  opacity: 1;
}
#slider03 .slick-next {
  right: -80px;
}
#slider03 .slick-prev {
  left: -80px;
}
#slider03 .slick-img a{
	text-decoration: none;
	color: #000;
}

@media screen and (max-width:768px){
#recommend_menu {
  padding: 40px 0;
}
#slider03 .menu {
  font-size: 15px;
	}
#slider03 .price {
  font-size: 12px;
	}
#slider03 .price span {
  font-size: 18px;
}	
#slider03 .slick-slide .img {
  padding-bottom: 20px;
  margin-bottom: 16px;	
}	
}
	

/*--------------------------------------------------
区切り
--------------------------------------------------*/
.img_point {
margin:0 0 20px;
width:100%;
overflow:hidden;
position:relative;
height: 400px;	
 z-index: -1; 	
}
.img_point img {
width:100%;
height:auto;
position:absolute;
left:0;
}

@media screen and (max-width:768px){
.img_point {
  height: 160px;
}
}



/*--------------------------------------------------
usefulmap
--------------------------------------------------*/

#usefulmap {
  padding: 80px 0;
  position: relative;
  background: #fff;
}
.map_base {
  max-width: 1000px;
  margin: 0 auto;
  position: relative;	
}
.map {
  position: relative;
}
.baloon {
  position: absolute;
  top: 4%;
  left: 14%;
  z-index: 0;
  width: 7%;
  right: 79%;
  height: 27%;
  bottom: 69%;
}
.map_list_ul {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}
.map_list_li a:hover {
  opacity: 0.7;
  transition: 0.5s;
}
.map_list_li{
  position: absolute;
  width: 18%;
   width: 12%;	
  height: 14%;
  z-index: 2;
}
.map_list_li.map01 {
  top: 10%;
  left: 35%;
  bottom: 76%;
  right: 47%;
}
.map_list_li.map02 {
  top: 37%;
  left: 7%;
  right: 75%;
  bottom: 49%;
}
.map_list_li.map03 {
  left: 24%;
  top: 53%;
  right: 58%;
  bottom: 33%;
}
.map_list_li.map04 {
  left: 56%;
  right: 28%;
  top: 5%;
  bottom: 82%;
}
.map_list_li.map05 {
  right: 14%;
  top: 45%;
  left: 68%;
  bottom: 41%;
}
.map_list_li.map06 {
  right: 45%;
  top: 38%;
  left: 37%;
  bottom: 48%;
}
.map_list_li.map07 {
  bottom: 39%;
  right: 28%;
  top: 47%;
  left: 54%;
}
.map_list_li.map08 {
  top: 64%;
  left: 6%;
  bottom: 22%;
  right: 76%;
}
.map_list_li.map09 {
  bottom: 37%;
  left: 8%;
  right: 74%;
  top: 49%;
}
.map_list_li.map10 {
  right: 45%;
  top: 79%;
  left: 37%;
  bottom: 7%;
}
.map_list_li.map11 {
  right: 35%;
  top: 64%;
  left: 47%;
  bottom: 22%;
}
.map_list_li.map12 {
  right: 21%;
  top: 73%;
  bottom: 13%;
  left: 61%;	
} 
.map_list_li.map13 {
  right: 63%;
  top: 82%;
  bottom: 3%;
  left: 16%;	
} 


.map_list_li.hidden{
  opacity : 0;
  animation: fadeout 1s linear;		
}

@keyframes fadeout {
0% {opacity: 1}
100% {opacity: 0}
}


/*-------- mapのリンクの位置 --------*/
.map_link_ul {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.map_link_li {
  position: absolute;
  z-index: 1;
}
.map_link_li a {
  width: 100%;
  height: 100%;
  display: block;
}
.map_link_li a:hover {
  cursor: grab;
}
.map_link_li.map_li01 {
  width: 12%;
  height: 8%;
  top: 18%;
  left: 39%;
  right: 49%;
  bottom: 74%;
}
.map_link_li.map_li02 {
  top: 41%;
  width: 16%;
  height: 19%;
  left: 14%;
  bottom: 40%;
  right: 70%;
}
.map_link_li.map_li03 {
  width: 19%;
  height: 13%;
  top: 42%;
  left: 43%;
  right: 38%;
  bottom: 45%;
}
.map_link_li.map_li04 {
  width: 7%;
  height: 20%;
  top: 8%;
  left: 64%;
  right: 29%;
  bottom: 72%;
}
.map_link_li.map_li05 {
  width: 12%;
  height: 35%;
  top: 44%;
  right: 14%;
  left: 74%;
  bottom: 21%;
}
.map_link_li.map_li06 {
  width: 16%;
  height: 12%;
  top: 58%;
  left: 31%;
  right: 53%;
  bottom: 30%;
}
.map_link_li.map_li07 {
  width: 10%;
  height: 21%;
  top: 53%;
  left: 63%;
  right: 27%;
  bottom: 26%;
}
.map_link_li.map_li08 {
  width: 13%;
  height: 15%;
  top: 69%;
  left: 16%;
  right: 71%;
  bottom: 16%;
}
.map_link_li.map_li09 {
  width: 10%;
  height: 26%;
  top: 47%;
  left: 3%;
  right: 87%;
  bottom: 27%;
}
.map_link_li.map_li10 {
  width: 9%;
  height: 7%;
  top: 89%;
  left: 44%;
  right: 47%;
  bottom: 4%;
}
.map_link_li.map_li11 {
  width: 23%;
  height: 13%;
  top: 75%;
  left: 42%;
  right: 35%;
  bottom: 12%;
}
.map_link_li.map_li12 {
  width: 21%;
  height: 15%;
  bottom: 3%;
  right: 13%;
  left: 66%;
  top: 82%;
}
.map_link_li.map_li13 {
  width: 21%;
  height: 15%;
  bottom: 3%;
  right: 63%;
  left: 16%;
  top: 82%;
}
.map_link_li:hover:before {
  content: "";
  width: 120px;
  height: 75px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 66px;
  right: 10px;
  display: none;
}
.map_link_li.show:hover:before{
	display: block;
}
.map_link_li.active:before {
content: "";
min-width: 120px;
min-height: 75px;
max-width: 120px;
max-height: 75px;
}
.map_link_li.map_li01:hover:before {
  background:url("../img/top/img_sukipass.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;	
  bottom: 48px;
  left: -40px;
}
.map_link_li.map_li01.active:before {
  background:url("../img/top/img_sukipass.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;	
  bottom: 48px;
  left: -40px;
}
.map_link_li.map_li02:hover:before {
  background:url("../img/top/img_sukiyaradio.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 113px;
  left: -65px;
}
.map_link_li.map_li02.active:before {
  background:url("../img/top/img_sukiyaradio.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 113px;
  left: -65px;
}
.map_link_li.map_li03:hover:before {	
  background:url("../img/top/img_tenposerch.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 66px;
  left: -65px;
}
.map_link_li.map_li03.active:before {
  content: "";	
  background:url("../img/top/img_tenposerch.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: -85%;
left: -40%;
width: 100%;
right: 0;
height: 100%;
bottom: 0;
}
.map_link_li.map_li04:hover:before {
  background:url("../img/top/img_campaing.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 98px;
  left: -85px;
}
.map_link_li.map_li04.active:before {
  background:url("../img/top/img_campaing.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 98px;
  left: -85px;
}
.map_link_li.map_li05:hover:before {
  background:url("../img/top/img_gallary.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: 10px;
  left: -80px;
}
.map_link_li.map_li05.active:before {
  background:url("../img/top/img_gallary.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: 10px;
  left: -80px;
}
.map_link_li.map_li06:hover:before {
  background:url("../img/top/img_netstore.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 38px;
  left: -65px;
}
.map_link_li.map_li06.active:before {
  background:url("../img/top/img_netstore.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 38px;
  left: -65px;
}
.map_link_li.map_li07:hover:before {
  background:url("../img/top/img_sukisukiset.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 113px;
  left: -87px;
}
.map_link_li.map_li07.active:before {
  background:url("../img/top/img_sukisukiset.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 113px;
  left: -87px;
}
.map_link_li.map_li08:hover:before {
  background:url("../img/top/img_arrange.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 66px;
  left: -65px;
}
.map_link_li.map_li08.active:before {
  background:url("../img/top/img_arrange.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 66px;
  left: -65px;
}
.map_link_li.map_li09:hover:before {
  background:url("../img/top/img_webbento.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: -3px;
  right: -75px;
}
.map_link_li.map_li09.active:before {
  background:url("../img/top/img_webbento.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: -3px;
  right: -75px;
}
.map_link_li.map_li10:hover:before {
  background:url("../img/top/img_delivery.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 66px;
  left: -65px;
}
.map_link_li.map_li10.active:before {
  background:url("../img/top/img_delivery.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 66px;
  left: -65px;
}
.map_link_li.map_li11:hover:before {
  background:url("../img/top/img_obentodial.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 66px;
  right: 24px;
}
.map_link_li.map_li11.active:before {
  background:url("../img/top/img_obentodial.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 66px;
 right: 24px;
}
.map_link_li.map_li12:hover:before {
  background:url("../img/top/img_mobile.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 80px;
  left: -35px;
}
.map_link_li.map_li12.active:before {
  background:url("../img/top/img_mobile.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 80px;
  left: -35px;
}
.map_link_li.map_li13:hover:before {
  background:url("../img/top/img_kitchencar.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 80px;
  left: -35px;
}
.map_link_li.map_li13.active:before {
  background:url("../img/top/img_kitchencar.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  bottom: 80px;
  left: -35px;
}

/* マップ下のバナー */
#usefulmap .banner_list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: 40px;	
}
#usefulmap .banner_list_li {
  width: calc((100% - 20px)/2);
  margin-bottom: 20px;	
}
/*#usefulmap .banner_list_li:nth-child(n+5) {
  margin-bottom: 0;	
}*/
#usefulmap .banner_list_li a:hover {
  opacity: 0.6;
  transition: 0.5s;
}
#usefulmap .banner_list_li img {
  width: 100%;
  height: auto;
}

@media screen and (max-width:768px){
.map_link_li.active:before {
content: "";
min-width: 60px;
min-height: 38px;
max-width: 60px;
max-height: 38px;
}	
#usefulmap {
  padding: 40px 0;
	}
.container {
  height: auto;
padding: 0;	
	}
#tab-content1 {
  margin-top: 20px;
}	
#usefulmap .banner_list {
  display: block;
  margin: 24px 20px 0 20px;
}
#usefulmap .banner_list_li {
  width: 100%;
  margin-bottom: 10px;
}	
#usefulmap .first_cover {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 10000;
  padding: 10px;
}	
#usefulmap .first_cover.inactive {
  display: none;
}	
	
	
	
}


/*--------------------------------------------------------------------
tab切り替え
--------------------------------------------------------------------*/
.tab-area{
margin: 0 auto;
}
.tab-btn{
display:none; 
}
.tab-list-wrap{
max-width: 320px;	
list-style-type:none; 
display:flex; 
justify-content: space-between;
margin: 0 0 32px auto;
background: #e3e3e3;
border-radius: 100px;	
padding: 4px; 	
}
 
.tab-list {
  display: block;
  width: 190px;
  height: 52px;
  line-height: 52px;	
  font-size: 18px;
  letter-spacing: 0.04em;
  color: #fff;		
  text-align: center;
  cursor: pointer;
  background: #c9c9c9;
  border-radius: 4px;
  padding-left: 36px;	
}
.tab-list-wrap li {
  margin-right: 10px;
}
.tab-list-wrap li:last-child {
  margin-right: 0;	
}
#tab-content1 {
  display: none;
  margin-top: 0;
}	
#tab-content1.selected {
  display: block;
}

#tab-content2 {
  display: none;
}
#tab-content2.selected {
  display: block;
}

/* mapモード */
.map_banner_ul {
  max-width: 1000px;
  margin: 0 auto;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
.map_banner_li {
  width: calc((100% - 100px)/6);
  margin-right: 20px;
  margin-bottom: 20px;
}
.map_banner_li:nth-child(6n){
	margin-right: 0;
}
#tab-content2 {
  padding: 40px 0 0 0;
}



/* スイッチ風切り替え */
.cb-enable, .cb-disable, .cb-enable span, .cb-disable span { 
/*	background: url(/sample/images/switch.gif) repeat-x;
	display: block;
	float: left; */
}
    .cb-enable span, .cb-disable span { 
/*		line-height: 30px;
		display: block;
		background-repeat: no-repeat;
		font-weight: bold;*/
}
    .cb-enable span { 
		background-position: left -90px;
		padding: 0 10px; 
        display: flex;
        align-items: center;
		color: #d7000f;
}
    .cb-enable span img{ 
		margin-right: 16px;
}
    .cb-disable span { 
		background-position: right -180px;
		padding: 0 10px; 
        display: flex;
        align-items: center;
		color: #d7000f;
}
    .cb-disable span img{ 
		margin-right: 8px;
}
    .cb-disable.selected { 
		background-position: 0 -30px; }
    .cb-disable.selected span { 
		background-position: right -210px; 
		color: #fff; }
    .cb-enable.selected { 
		background-position: 0 -60px;
}
    .cb-enable.selected span { 
		background-position: left -150px;
		color: #fff; 
}
    .switch label { 
		cursor: pointer; 
}
    .switch input {
		display: none; 
}	

.field.switch {
  background: #fff;
  width: 320px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100px;
  padding: 4px;
  margin: 0 0 0 auto;
  border: solid 2px #d7000f;
}

.cb-enable {
  height: 100%;
  width: 50%;
  border-radius: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.cb-enable.selected {
  background: #d7000f;
}
.cb-disable {
  height: 100%;
  width: 50%;
  border-radius: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.cb-disable.selected{
  background: #d7000f;
}

 
/*#tab-btn1:checked ~ .tab-list-wrap #tab-list1,
#tab-btn2:checked ~ .tab-list-wrap #tab-list2{
background:#d7000f; 
}
.tab-content{
display:none; 
}
#tab-btn1:checked ~ .tab-content-wrap #tab-content1,
#tab-btn2:checked ~ .tab-content-wrap #tab-content2{
display: block;
}
#tab-list1 {
  background-image:url("../img/img_ei_off.png") !important;
  background-repeat: no-repeat !important;
  background-position: 10px center !important;
  background-size: 40px !important;	
  width: 100%;
  border-radius: 100px;	
}
#tab-btn1:checked ~ .tab-list-wrap #tab-list1 {
  background-image:url("../img/img_ei_on.png") !important;
  background-repeat: no-repeat !important;
  background-position: 10px center !important;
  background-size: 40px !important;	
  width: 100%;
  border-radius: 100px;	
}
#tab-list2.to {
  background-image:url("../img/img_to_off.png") !important;
  background-repeat: no-repeat !important;
  background-position: 10px center !important;
  background-size: 40px !important;	
  width: 100%;
  border-radius: 100px;	
}
#tab-btn2:checked ~ .tab-list-wrap #tab-list2 {
  background-image:url("../img/img_to_on.png") !important;
  background-repeat: no-repeat !important;
  background-position: 10px center !important;
  background-size: 40px !important;	
  width: 100%;
  border-radius: 100px;	
}*/
.main_map {
  display: flex;
  justify-content: space-between;
  margin-top: 40px;	
}
.container {
  width: 79%;
  height: auto;	
}
.map_guide_list.inactive {
  pointer-events: none;
}
.map_guide_list {
  width: 19%;
  pointer-events: visible;	
}
.map_guide_li {
  padding-left: 32px;
  font-size: 14px;
  margin-bottom: 16px;
  position: relative;
}
.map_guide_li a {
  color: #000;
  text-decoration: none;
  font-size: 14px;
}
.map_guide_li a:hover {
  color: #888;
}
.map_guide_li::before {
  content: "";
  width: 16px;
  height: 16px;
  border-radius: 50px;
  background: #ccc;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
.map_guide_li.active::before {
  content: "";
  width: 16px;
  height: 16px;
  border-radius: 50px;
  background: #ee60ae;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  box-shadow: 0px 0px 4px #ee60ae;	
}

@media screen and (max-width:768px){
.tab-area {
  padding: 0 20px;
}	
.field.switch {
  width: 280px;
  height: 40px;
  padding: 2px;
  margin: 0 auto 20px auto;
}
.cb-enable img {
  width: 28px;
}
.cb-disable img {
  width: 28px;
}	
.map_banner_li {
  width: calc((100% - 30px)/4);
  margin-right: 10px;
  margin-bottom: 10px;
}	
.map_banner_li:nth-child(4n) {
  margin-right: 0;
}	
.map_banner_li:nth-child(6) {
  margin-right: 10px;
}	
#tab-content2 {
  padding: 20px 0 0 0;
}	
}

/* ポンポン表示 */
/*hoverで下のbaloonが出るのを防ぐ*/
#map_start.ready {
  z-index: 2;
}
#map_start {
  z-index: 0;
}
#map_start .map_list_li{
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.8s cubic-bezier(0,1.2,1.0,1.0);
  z-index: -2;	
}
#map_start .map_list_li.ready{
  opacity: 1;
  transform: translateY(0px);
  z-index: 1;	
}

/*--------------------------------------------------------------------
新着情報
--------------------------------------------------------------------*/
#news_info {
  padding: 80px 0;
}
#news_info .info_wrap {
  display: flex;
  justify-content: space-between;
  padding-top: 64px;	
}
#news_info .info_list_li a {
  text-decoration: none;
}
#news_info .info_dl {
  display: flex;
  justify-content: space-between;
}
#news_info .info_dt {
  font-size: 14px;
  color: #a0a0a0;
  width: 26%;	
  position: relative;	
}
#news_info .info_dd {
  font-size: 14px;	
  line-height: 1.4;	
  color: #000;
  width: 72%;		
}
#news_info .info_list_li {
  padding: 24px 0;
  border-bottom: solid 1px #a9a9a9;
}
#news_info .info_list_li:first-child {
  padding-top: 0;
}
#news_info .info_content {
  width: calc(100% - 304px);
}
#news_info .btn_area a {
  margin: 40px auto 0 auto;
}
#news_info .banner_list_li a:hover {
  opacity: 0.7;
  transition: 0.5s;
}
#news_info .banner_list_li {
  margin-bottom: 8px;
}
#news_info .banner_list_li img {
  max-width: 100%;
  height: auto;
}
#news_info .banner_list_li:last-child {
  margin-bottom: 0;
}
#news_info .info_side_wrap {
  position: relative;
}
#news_info .title {
  position: absolute;
  top: -64px;
  right: 0;
}
#news_info .cate.press::before {
  content: "プレスリリース";	
  border: solid 1px #f19149;
  color: #f19149;
}
#news_info .cate.info::before {
  content: "お知らせ";	
  border: solid 1px #5eb583;
  color: #5eb583;
}
#news_info .cate.news::before {
  content: "新着情報";	
  border: solid 1px #359ee0;
  color: #359ee0;
}
#news_info .cate.store::before {
  content: "新店情報";	
  border: solid 1px #db1927;
  color: #db1927;
}

@media screen and (max-width:768px){
#news_info {
  padding: 40px 20px;
}
#news_info .info_wrap {
  display: block;
  padding-top: 0;
}	
#news_info .info_content {
  width: 100%;
  margin-bottom: 40px;	
}	
#news_info .info_dl {
  display: block;
}	
#news_info .info_dt {
  font-size: 13px;
  margin-bottom: 8px;
  width: 100%;	
}	
#news_info .info_dd {
  width: 100%;		
}	
#news_info .info_list_li {
  padding: 16px 0;
	}
#news_info .title {
  position: relative;
  top: 0;
	}
#news_info .banner_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#news_info .banner_list_li {
  width: calc((100% - 8px)/2);
}
	
}


/*タブ切り替え*/

.tab_list {
  display: flex;
  margin-bottom: 64px;
}
.tab_list_li {
  width: 130px;
  font-size: 16px;
  text-align: center;
  padding-bottom: 4px;
  border-bottom: solid 4px #eee;
  margin-right: 16px;
}
.tab_list_li.active{
 border-bottom: solid 4px #dc000d;
}
.tab_content {
  display: none;
}
.tab_content.active {
  display: block;
}

@media screen and (max-width: 768px){
.tab_list_li {
  font-size: 14px;
  margin-right: 8px;
}
.tab_content ul li {
  position: relative;
}
.tab_content_wrap ul li {
  display: block;
}
.tab_content ul li a {
  display: block;
  width: 100%;
}
.tab_list {
  display: flex;
  margin-bottom: 32px;
}	
}


.news_list a {
  display: flex;
  text-decoration: none;
  font-size: 14px;
  color: #000;
  line-height: 1.3;	
}
.news_list time {
  margin-right: 16px;
  white-space: nowrap;	
  font-size: 14px;
  color: #a0a0a0;
}
.news_list {
  display: flex;
  padding-bottom: 16px;
  margin-bottom: 16px;
  border-bottom: 1px solid #eee;	
  position: relative;	
}
.cate {
  width: 72px;
  font-size: 12px;
  height: 20px;
  line-height: 18px;	
  border: solid 1px #000;
  padding: 0 6px;
  margin-right: 8px;
  display: block;
  text-align: center;
}
.news_info a .cate {
  color: #359ee0;
  border: solid 1px #359ee0;
}
.info a .cate {
  color: #5eb583;
  border: solid 1px #5eb583;
  height: 20px;
  line-height: 16px;
}
.store a .cate {
  color: #db1927;
  border: solid 1px #db1927;
}
.press_release a .cate {
  color: #f19149;
  border: solid 1px #f19149;
  letter-spacing: -0.2em;
  font-size: 10px;
}

@media screen and (max-width:768px){
.news_list {
  display: block;
}
.cate {
  width: 72px;
  font-size: 11px;
  border: solid 1px #000;
  padding: 0 4px;
  margin-right: 0;
  position: absolute;
  top: 0;
  right: 0;
}	
.news_list a {
  display: block;
  margin-top: 8px;
}	
}


/*--------------------------------------------------------------------
ワールドマップ
--------------------------------------------------------------------*/
#worldmap {
  padding: 80px 0;
}
#worldmap .lead {
  font-size: 16px;
  line-height: 1.6;
  text-align: center;
  margin-bottom: 40px;
}
#worldmap .w_map_list_wrap {
  position: relative;
}
#worldmap .w_map_list {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
#worldmap .s_map_li {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  opacity: 0;
  transition: 0.5s;	
}
#worldmap .s_map_li.show {
  opacity: 1;
}
#worldmap .w_map_deatil_wrap {
  display: flex;
  max-width: 900px;
  margin: 0 auto;
  background: #ffda3f;
  padding: 20px;
  align-content: center;
  align-items: center;
  padding-left: 100px;	
  background-image:url("../img/top/img_awred_prize.png");
  background-repeat: no-repeat;
  background-position: 20px center;
  background-size: 62px auto;
}
#worldmap .txt {
  font-size: 13px;
  line-height: 1.6;
  margin-bottom: 24px;
}
#worldmap .award_wrap {
  margin-right: 20px;
}
#worldmap .w_map_detail {
  margin-left: 40px;
}
#worldmap .w_map_detail_li {
  position: relative;
}
#worldmap .link {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0,0,0,0.4);
  color: #fff;
  display: flex;
  justify-content: space-between;
  padding: 4px 8px;
  align-items: center;	
}
#worldmap .link a {
  font-size: 13px;
  color: #fff;
  text-decoration: none;
  display: flex;
  align-items: center;
}
#worldmap .link a img {
  margin-left: 8px;
}
#worldmap .w_map_link_list {
  width: 28%;	
  height: 38%;	
  position: absolute;
  margin: auto;
  background: rgba(000,000,000,0.7);
  padding: 16px;
  border-radius: 16px;
  display: flex;
  flex-wrap: wrap;
  top: 54%;
  right: 22%;
  bottom: 8%;
  left: 50%;
}
#worldmap .w_map_link_li {
  font-size: 14px;
  color: #fff;
  margin-bottom: 16px;
  width: calc((100% - 10px)/2);	
}
#worldmap .w_map_link_li:last-child {
  margin-bottom: 0;
}
#worldmap .w_map_link_li img {
  margin-right: 8px;
}
#worldmap .w_map_link_li:hover {
  opacity: 0.7;
  transition: 0.5s;
}
#worldmap .w_map_detail_li {
  display: none;	
}
#worldmap .w_map_detail_li.show {
  display: block;
}
.w_map_link_list.media_sp {
  display: none !important;
}
.w_map_link_list.media_pc {
  display: flex !important;
}

@media screen and (max-width:768px){
.w_map_link_list.media_sp {
  display: flex !important;
}
.w_map_link_list.media_pc {
  display: none !important;
}	
#worldmap {
  padding: 40px 0;
}
#worldmap .w_map_deatil_wrap {
 flex-wrap: wrap;
 flex-direction: column-reverse;	
  padding: 20px;
  background-image: none;	
}	
#worldmap .txt {
  font-size: 13px;
  line-height: 1.4;
  margin: 8px auto;
}	
#worldmap .award_wrap {
  margin-right: 0;
}
#worldmap .w_map_detail {
  margin-left: 0;
  margin-top: 10px;
}	
#worldmap .w_map_link_list {
  width: calc(100% - 40px);
  height: auto;
  position: relative;
  margin: -15px auto 10px auto;
  background: rgba(000,000,000,0.7);
  padding: 16px;
  border-radius: 16px;
  display: flex;
  flex-wrap: wrap;
  top: inherit;
  right: inherit;
  bottom: inherit;
  left: inherit;
  min-height: auto;
}	
#worldmap .w_map_link_li {
  font-size: 13px;
  margin-bottom: 12px;
	}
#worldmap #tab-content2 {
  padding: 20px 0 0 0;
	}
	
}


/*--------------------------------------------------------------------
求人情報
--------------------------------------------------------------------*/
#recruit {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
#recruit .banner_list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
#recruit .banner_list_li {
  width: calc((100% - 40px)/3);
  position: relative;
  margin-bottom: 20px;
}
#recruit .banner_list_li:last-child {
  margin-bottom: 0;
}
#recruit .banner_list_li a {
  font-size: 21px;
  color: #fff;
  text-decoration: none;
  letter-spacing: 0.05em;
  font-weight: 600;
}
#recruit .banner_list_li .link {
  background: red;
  padding: 0 20px;
  background-image: url("../img/top/icn_window.png");
  background-repeat: no-repeat;
  background-position: 97% 85%;
  background-size: 20px;	
  height: 80px;
  line-height: 80px;	
  display: flex;
  align-items: center;	
}
#recruit .banner_list_li:nth-child(1) .link {
  background-color: #d7000f;
}
#recruit .banner_list_li:nth-child(2) .link {
  background-color: #0a256a;
}
#recruit .banner_list_li:nth-child(3) .link {
  background-color: #0142bb;
}
#recruit .banner_list_li .link img {
  margin-right: 10px;
}
#recruit .banner_list_li a:hover {
  opacity: 0.7;
  transition: 0.5s;
}


@media screen and (max-width:768px){
#recruit {
  padding: 40px 20px 0 20px;
}	
#recruit .banner_list_li {
  width: calc((100% - 20px)/2);
	}
#recruit .banner_list_li a {
  font-size: 14px;
	}
#recruit .banner_list_li .link {
  height: 48px;
  line-height: 1.3;
	}
#recruit .banner_list_li .link {
  padding: 0 20px 0 10px;
	}
.link img {
  width: 20px;
}	
#recruit .banner_list_li .link {
  background-size: 12px;
}
}



.container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
/*  width: 100%;*/
 /* height: 100vh;*/
  /*padding: 1em;*/
  background-color: #fff;
}
.outer {
  position: relative;
/*  width: clamp(300px, 100%, 600px);
  height: 400px;*/
  overflow: hidden;
  border: 3px solid #555;
  border-radius: 5px;
  background-color: #8BC6EC;
}
#panzoom {
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 800px;	
  height: 100%;	
}
#panzoom img {
  width: auto;
  height: auto;
  vertical-align: bottom;
}


@media screen and (max-width:768px){
.main_map {
  display: block;
	}
.container {
  width: 100%;	
  height: auto;
  padding: 0;
  display: block;	
}
.map_guide_list {
  width: 100%;
  pointer-events: visible;
  display: flex;
  flex-wrap: wrap;
  margin-top: 20px;
}	
.map_guide_li {
  padding-left: 20px;
  font-size: 14px;
  width: calc((100% - 30px) / 4);
}	
}

@media screen and (max-width:414px){
.map_guide_li {
  font-size: 13px;
  width: calc((100% - 20px) / 3);
}
}

/*------------------------------------------------------------------------
map スマホ用
------------------------------------------------------------------------*/
.map_sp {
  position: relative;
  display: none;
}
.main_map {
  display: flex;
}

@media screen and (max-width:768px){
.main_map {
  display: none;
}
.map_sp {
  display: block;
  z-index: 0;	
}
.beautify-marker.circle.leaflet-zoom-animated.leaflet-interactive {
  background: #ddd !important;
}	
}


