@charset "UTF-8";

/* ▼▼▼ ショップガイド一覧
=====================================*/
/* 検索 */
#search_tub{
  margin: 0 auto;
  max-width: 600px;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: center;
}
#search_tub li{
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: center;
  align-content: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-flex: 0 0 33%;
  -ms-flex: 0 0 33%;
  flex: 0 0 33%;
  width: calc((100% - 4px)/3);
  max-width: calc((100% - 4px)/3);
  height: 70px;
  border-radius: 10px 10px 0 0;
  position: relative;
  cursor: pointer;
}

#search_tub li:not(:last-child){
  margin-right: 2px;
}
#search_tub li.active{
  background: #F7F2F5;
}
#search_tub li:not(.active){
  padding-bottom: 10px;
  background: #932F27;
  color: #FFF;
}
#search_tub li:not(.active)::after{
  content: '';
  width: 10px;
  height: 10px;
  border-style: solid;
  border-width: 1px;
  border-color: transparent #FFF #FFF transparent;
  position: absolute;
  bottom: 13px;
  left: calc(50% - 5px);
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
#search_block{
  padding: 50px 0;
  background: #F7F2F5;
}

#search_block .search_page:not(.active){
  display: none;
}
/* チェックリスト */
.check_title{
  margin-bottom: 20px;
  padding-left: 8px;
  border-left: #932F27 2px solid;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.2;
}
.check_list{
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 30px;
}
.check_list li{
  -webkit-flex: 0 0 25%;
  -ms-flex: 0 0 25%;
  flex: 0 0 25%;
  width: 25%;
  max-width: 25%;
}
/* チェックボックス */
input[type=checkbox]{
  display: none;
}
.checkbox01-parts{
  padding-left: 30px;
  position:relative;
  margin-right: 5px;
  border-radius: 5px;
  cursor: pointer;
  display: inline-block;
  padding: 5px 0;
  margin-bottom: 10px;
}
.checkbox01-parts::before{
  content: "";
  display: inline-block;
  margin-right: 10px;
  width: 18px;
  height: 18px;
  border: 1px solid #999;
  border-radius: 4px;
  background: #FFF;
  vertical-align: middle;
}
input[type=checkbox]:checked + .checkbox01-parts{
}
input[type=checkbox]:checked + .checkbox01-parts::after{
  content: "";
  display: inline-block;
  position: absolute;
  top: 14px;
  left: 7px;
  width: 4px;
  height: 9px;
  transform: rotate(40deg);
  border-bottom: 2px solid #E5012D;
  border-right: 2px solid #E5012D;
}
.checkbox01-parts span{
  vertical-align: middle;
}

/* フリーワード検索 */
.search_box{
  width: 100%;
  max-width: 500px;
  margin:  0 auto 30px;
  padding-right: 58px;
  background: #FFF;
  border: #CCC 1px solid;
  border-radius: 30px;
  position: relative;
  overflow: hidden;
}
.search_box input{
  width: 100%;
  border: none;
  outline: none!important;
  padding: 20px 10px 20px 30px;
  font-size: 16px;
}
.search_box button.search_btn{
  width: 58px;
  height: 58px;
  background-color: #fff;
  background-image: url(https://fr.takarazuka.ekimaru.com/common/img/icon_search_r.svg);
  -webkit-background-size: 18px;
  background-size: 18px;
  background-repeat: no-repeat;
  background-position: center center;
  border: none;
  border-radius: 0;
  outline: none!important;
  position: absolute;
  top: 0;
  right: 0;
  cursor: pointer;
}
/* 検索結果 */
#result_area{
  padding: 30px 0 70px;
}
.result_title{
  margin-bottom: 30px;
  font-size: 18px;
  font-weight: normal;
  text-align: center;
}

.result_title .result_num{
  display: inline-block;
  margin: 0 0.25em;
  font-size: 50px;
}

/* ショップリスト */
.shop_list{
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.shop_list li{
  -webkit-flex: 0 0 23.5%;
  -ms-flex: 0 0 23.5%;
  flex: 0 0 23.5%;
  width: 23.5%;
  max-width: 23.5%;
  margin-bottom: 40px;
}
.shop_list li:not(:nth-child(4n)){
  margin-right: 2%;
}
.shop_list a.list_inner{
  display: block;
  height: 100%;
}
.shop_list .img_wrap{
  display: block;
  margin-bottom: 10px;
  padding-top: 100%;
  border: #EEEEEE 1px solid;
  border-radius: 10px;
  -webkit-background-size: cover;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.shop_list .shop_name_wrap{
  margin-bottom: 10px;
  padding-left: 35px;
  position: relative;
}
.shop_name_wrap .shop_num,
.shop_table .shop_num{
  display: inline-block;
  margin-right: 5px;
  border-radius: 50%;
  background: #000;
  color: #FFF;
  font-weight: bold;
  text-align: center;
  vertical-align: top;
}
.shop_name_wrap .shop_name{
  color: #932F27;
  font-weight: bold;
  vertical-align: top;
}
.shop_list .shop_name_wrap .shop_num{
  min-width: 26px;
  font-size: 12px;
  line-height: 26px;
  position: absolute;
  top: 0;
  left: 0;
}
.shop_list .shop_name_wrap .shop_name{
  font-size: 16px;
}
.shop_list .shop_txt{
  font-size: 12px;
}

/* 店舗詳細ページ */
.shop_logo_wrap{
  padding: 20px;
}
.shop_logo_wrap .shop_logo{
  width: 170px;
  height: 72px;
  margin: 0 auto;
  text-align: center;
}
.shop_wrap{
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  max-width: 1040px;
  padding: 0 20px;
  margin: 0 auto 90px;
}
.shop_wrap .img_wrap{
  -webkit-flex: 0 0 50%;
  -ms-flex: 0 0 50%;
  flex: 0 0 50%;
  width: 50%;
  max-width: 50%;
}
.shop_wrap .txt_wrap{
  -webkit-flex: 0 0 45%;
  -ms-flex: 0 0 45%;
  flex: 0 0 45%;
  width: 45%;
  max-width: 45%;
}
/* 店舗画像 */
.shop_img_main:not(:last-child){
  margin-bottom: 20px;
}
.shop_img_main .slide-item .slide-item_img{
  padding-top: 100%;
}
.shop_img_sub{
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
}

.shop_img_sub .slideThumb{
  -webkit-flex: 0 0 21.1%;
  -ms-flex: 0 0 21.1%;
  flex: 0 0 21.1%;
}
.shop_img_sub .slideThumb:not(:nth-child(4n)){
  margin-right: 5.2%;
}
.shop_img_sub .slideThumb .slideThumb_img{
  padding-top: 100%;
  cursor: pointer;
}

/* 店舗情報 */
.shop_wrap .shop_name_wrap{
  margin-bottom: 30px;
  position: relative;
  padding-left: 50px;
}
.shop_table .shop_num{
  min-width: 26px;
  font-size: 14px;
  line-height: 26px;
}
.shop_wrap .shop_name_wrap .shop_num{
  min-width: 40px;
  font-size: 20px;
  line-height: 40px;
  position: absolute;
  top: 0;
  left: 0;
}
.shop_wrap .shop_name_wrap .shop_name{
  font-size: 32px;
  line-height: 40px;
}
.shop_info{
  margin-bottom: 25px;
}
.shop_tag_list{
  margin-bottom: 25px;
}
.shop_tag_list li{
  display: inline-block;
  min-width: 125px;
  margin: 0 6px 8px 0;
  padding: 0 5px;
  border: #BE2626 1px solid;
  border-radius: 12px;
  color: #BE2626;
  font-size: 12px;
  text-align: center;
  line-height: 22px;
}
.shop_table{
  width: 100%;
  margin-bottom: 30px;
}
.shop_table th,
.shop_table td{
  padding: 24px 0 13px;
  border-bottom: #CCCCCC 1px solid;
  vertical-align: top;
}
.shop_table th{
  width: 100px;
  color: #932F27;
}
.shop_table td{
  width: calc(100% - 100px);
	word-wrap: break-word;
	word-break: break-all;
}
.shop_table .shop_floor{
  display: inline-block;
  vertical-align: middle;
}
.shop_table .shop_num{
  margin: 0 20px 0 7px;
  vertical-align: middle;
}
.shop_table a.map_btn{
  display: inline-block;
  padding: 0 20px;
  border: #000 1px solid;
  border-radius: 14px;
  font-weight: bold;
  vertical-align: middle;
  line-height: 26px;
}
.shop_table .shop_table_floor td,
.shop_table .shop_table_sns td{
  padding-top: 20px;
}
.shop_sns_list li{
  display: inline-block;
  vertical-align: middle;
}
.shop_sns_list li:not(:last-child){
  margin-right: 20px;
}
.icon_sns_link{
  display: block;
  width: 30px;
  height: 30px;
}
.icon_sns_link.icon_sns_link_ig{background: url(https://fr.takarazuka.ekimaru.com/common/img/shopguide/icon_sns_ig.svg) no-repeat center center/23px;}
.icon_sns_link.icon_sns_link_tw{background: url(https://fr.takarazuka.ekimaru.com/common/img/shopguide/icon_sns_tw.svg) no-repeat center center/27px;}
.icon_sns_link.icon_sns_link_fb{background: url(https://fr.takarazuka.ekimaru.com/common/img/shopguide/icon_sns_fb.svg) no-repeat center center/24px;}

.shop_order{
  margin-bottom: 40px;
}
/* 定番商品 */
#popular_area{
  padding: 70px 0 50px;
}
.shop_list .product_name{
  text-align: center;
  font-weight: bold;
}
/* ショップニュース */
#news_list_area{
  padding: 20px 0 70px;
}
#shopnews #news_list_area{
  padding: 0 0 50px;
}
/* おすすめのお店 */
#recommend_area{
  padding: 50px 0 20px;
  background: #F7F2F5;
}

/* ショップニュース詳細 */
.shop_news_title{
  padding: 30px;
  color: #932F27;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}
#shop_area{
  padding: 50px 0;
}
.shop_news_date{
  font-size: 14px;
  margin-bottom: 20px;
}
.shop_news_info{
  font-size: 18px;
}
.btn_wrap{
  padding: 0 0 100px;
}
/* ▼▼▼ 480px〜768px
=====================================*/
@media screen and (max-width: 768px) {

  /* 検索 */
  #search_tub li{
    height: 50px;
  }
  #search_tub li:not(.active){
    padding-bottom: 7px;
  }
  #search_tub li:not(.active)::after{
    width: 6px;
    height: 6px;
    bottom: 10px;
    left: calc(50% - 3px);
  }
  #search_block{
    padding: 30px 0;
  }

  /* チェックリスト */
  .check_title{
    margin-bottom: 10px;
    font-size: 12px;
  }
  .check_list{
    margin-bottom: 20px;
  }
  .check_list li{
    -webkit-flex: 0 0 50%;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    width: 50%;
    max-width: 50%;
  }
  /* チェックボックス */
  .checkbox01-parts{
    margin-bottom: 5px;
  }
  .checkbox01-parts::before{
    margin-right: 5px;
  }
  input[type=checkbox]:checked + .checkbox01-parts::after{
    top: 12px;
  }
  .checkbox01-parts span{
    font-size: 12px;
  }

  /* フリーワード検索 */
  .search_box{
    width: 100%;
    max-width: 500px;
    margin:  0 auto 30px;
    padding-right: 58px;
    background: #FFF;
    border: #CCC 1px solid;
    border-radius: 30px;
    position: relative;
    overflow: hidden;
  }
  .search_box input{
    width: 100%;
    border: none;
    outline: none!important;
    padding: 20px 10px 20px 30px;
    font-size: 16px;
  }
  .search_box button.search_btn{
    width: 58px;
    height: 58px;
    background-color: #fff;
    background-image: url(https://fr.takarazuka.ekimaru.com/common/img/icon_search_r.svg);
    -webkit-background-size: 18px;
    background-size: 18px;
    background-repeat: no-repeat;
    background-position: center center;
    border: none;
    border-radius: 0;
    outline: none!important;
    position: absolute;
    top: 0;
    right: 0;
  }
  /* 検索結果 */
  #result_area{
    padding: 20px 0 50px;
  }
  .result_title{
    font-size: 14px;
  }

  .result_title .result_num{
    font-size: 32px;
  }

  /* ショップリスト */
  .shop_list li{
    -webkit-flex: 0 0 47%;
    -ms-flex: 0 0 47%;
    flex: 0 0 47%;
    width: 47%;
    max-width: 47%;
    margin-bottom: 40px;
  }
  .shop_list li:not(:nth-child(4n)){
    margin-right: 0;
  }
  .shop_list li:not(:nth-child(2n)){
    margin-right: 6%;
  }

  .shop_list .shop_name_wrap{
    padding-left: 25px;
  }
  .shop_list .shop_name_wrap .shop_num{
    min-width: 20px;
    font-size: 10px;
    line-height: 20px;
  }
  .shop_list .shop_name_wrap .shop_name{
    font-size: 14px;
    line-height: 16px;
  }
  .shop_list .shop_txt{
    font-size: 10px;
  }


  /* 店舗詳細ページ */
  .shop_wrap{
    display: block;
    padding: 0;
    margin: 0 auto 50px;
  }
  .shop_wrap .img_wrap,
  .shop_wrap .txt_wrap{
    width: 100%;
    max-width: 100%;
  }
  /* 店舗画像 */
  .shop_img_sub{
    padding: 0 20px;
  }
  .shop_wrap .img_wrap{
    margin-bottom: 50px;
  }

  /* 店舗情報 */
  .shop_wrap .shop_name_wrap{
    padding-left: 35px;
  }
  .shop_wrap .shop_name_wrap .shop_num{
    min-width: 26px;
    font-size: 14px;
    line-height: 26px;
  }
  .shop_wrap .shop_name_wrap .shop_name{
    font-size: 20px;
    line-height: 26px;
  }
  .shop_wrap .txt_wrap{
    padding: 0 20px;
  }
  .shop_order{
    margin-bottom: 40px;
  }

  /* ショップニュース */
  #news_list_area{
    padding: 50px 0;
  }
  #shopnews #news_list_area{
    padding: 0 0 30px;
  }
  /* おすすめのお店 */
  #recommend_area{
    padding: 40px 0 20px;
  }

  /* ショップニュース詳細 */
  .shop_news_title{
    padding: 25px 20px;
    font-size: 16px;
  }
  #shop_area{
    padding: 30px 0;
  }
  .shop_news_date{
    font-size: 12px;
    margin-bottom: 15px;
  }
  .shop_news_info{
    font-size: 14px;
  }
  .btn_wrap{
    padding: 0 0 50px;
  }
}
