@media(min-width:768px){
  .sp_only{
    display: none!important;
  }
}/*@media(min-width:1141px){*/

@media(max-width:767px){
  .sp_hide{
    display: none!important;
  }

  main{
    padding-top: 60px;
  }

  .container{
    width: 92%;
    max-width: 350px;
    margin:0 auto;
  }
  .container02{
    width: 92%;
    max-width: 350px;
    margin:0 auto;
  }
  
  /*
  ----------------------------------------
  共通部分
  ----------------------------------------
  */
  
  /*セクションのタイトルセット*/
  .common_title_set{
    margin-bottom: 24px;
  
  }
  
  .common_title_set .en_title{
    font-size: 20px;
    line-height: 1.3;
  }
  
  .common_title_set .ja_title{
    margin-top: 10px;
    line-height: 1.3;
    font-size: 16px;
  }
  
  /*矢印付きのリンクボタン*/
  .common_arrow_link{
    width:200px;
    
    padding-bottom: 10px;
    padding-top: 10px;
  }

  
  .common_arrow_link::after{
    width:40px;
    height:1px;
  }
  
  
  /*アコーディオン*/
  .common_switch_block{
  
  }
  
  .common_switch_block .common_switch{

    padding:16px 32px 16px 16px;
  }
  
  .common_switch_block .common_switch::after{
    right:12px;
    border-width: 12px 7px 0 7px;
  }

  /*トピック一覧*/
  .common_topics_list{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    flex-direction: column;
    align-items: center;
    gap:24px 0;
  }
  
  .common_topics_list .topics_item{
    width: 100%;
  }

  .common_topics_list .topics_item:nth-child(n + 4){
    display: none;
  }
  
  .common_topics_list .topics_card{
    width: 100%;
  }
  
  .common_topics_list .topics_thumb{
    width: 150px;
    margin-right: 16px;
  }

  .common_topics_list .topics_shop_logo_frame{
    width:40px;
    height:40px;
  }
  
  
  .common_topics_list .topics_title{
    font-size: 13px;
  }
  
  .common_topics_list .topics_cat_list{
    margin-top: 8px;
    gap:8px;
  }
  
  .common_topics_list .topics_cat_list .cat{
    min-width: 80px;
    padding:3px 4px; 
    font-size: 10px;
    line-height: 1.4;
  }

  .common_topics_list .topics_excerpt{
    margin-top: 4px;
    font-size: 11px;
    -webkit-line-clamp: 2;
  }


  /*店舗からのお知らせ一覧*/
  .common_shop_info_list{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    flex-direction: column;
    align-items: center;
  }

  
  .common_shop_info_list li{
    margin-bottom: 40px;
    margin-right: 0;
    width:100%;
    display: none;
  }

  .common_shop_info_list li:nth-child(1),
  .common_shop_info_list li:nth-child(2),
  .common_shop_info_list li:nth-child(3){
    display: block;
  }
  
  .common_shop_info_list li:nth-child(3n){
    margin-right: 0;
  }
  .common_shop_info_list li:nth-child(n + 4){
    display: none;
  }
  
  .common_shop_info_list .card{
    width:100%;
  }
  
  .common_shop_info_list .card .topics_title{
    padding:12px 16px;
    font-weight: 400;
    line-height: 1.5;
    font-size: 12px;
  }



/*店舗カード一覧*/
  .common_shop_list{
    
  }
  
  .common_shop_list .shop_block{

    display: flex;
    flex-direction: column;
    align-items: center;
    width:100%;
    margin:0 auto 64px;
  }
  
  .common_shop_list .shop_block:last-child{
    margin-bottom: 0;
  }
  
  .common_shop_list .shop_block .thumb{
    width: 100%;
    flex-shrink: 0;

    margin-bottom: 16px;
  }
  
  .common_shop_list .shop_block .text_area{
    width:100%;
    padding-left: 0;
    display: block;
  }
  
  .common_shop_list .shop_block .shop_name_flex{
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    font-size: 20px;
  }

  .common_shop_list .shop_block .shop_name_flex img{
    height:40px;
    margin-right: 10px;
  }

  .common_shop_list .shop_block .shop_name{
    text-align: center;
  }
  
  .common_shop_list .shop_block .shop_name .text_link{
    font-size: 18px;
    font-weight: 400;
    line-height: 1.4;    
  }

  
  .common_shop_list .shop_block .shop_adress{
    margin-top: 16px;
    font-size: 14px;
    line-height: 1.5;
  }

  .common_shop_list .shop_block .info_block{
    margin-top: 16px;
    font-size: 14px;
    line-height: 1.5;
  }
  
  .common_shop_list .shop_block .info_block .label{
    flex-shrink: 0;
  }
  
  .common_shop_list .shop_block .time_block{
    margin-right: 0;
  }
  
  .common_shop_list .shop_block .tel_block a{
    pointer-events: auto;
  }
  
  
  .common_shop_list .shop_block .link_flex{
    margin-top: 24px;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    align-items: center;
  }
  
  .common_shop_list .shop_block .link_flex .button + .button{
    margin-left:0;
    margin-top: 12px;
  }

  .common_shop_list .shop_block .recruit_link{
    margin: 12px auto 0;
  }
  
  /*
  ----------------------------------------
  ヘッダー
  ----------------------------------------
  */
  
  header{
    position: fixed;
    width:100%;
    background-color:#060606;
    top:0;
    left:0;
    z-index: 100;
  }
  
  header .header_container{
    padding:0 24px;
  }
  
  header .header_flex{
    display: flex;
    justify-content: space-between;
    align-items: center;
    height:60px;
  }
  
  header .header_logo{
    display: block;
    width:130px;
  }
  
  header .header_logo .logo_text{
    color:#fff;
    line-height: 1;
    font-weight: 400;
    font-size: 14px;
  }
  
  header .header_logo img{
    width:100%;
  }
  
  header .header_right{
  
  }
  
  header .header_right nav{
    display: none;
  }
  
  header .parent_list{
    display: flex;
    align-items: center;
  }
  
  
  header .parent_list .parent_item{
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  
  header .parent_list .slash{
    width:42px;
    margin:0 24px;
  }
  
  header .parent_list .slash img{
    width:100%;
  }
  
  header .parent_list .parent_link{
    color:#fff;
    text-align: center;
  }
  
  header .parent_list .parent_link .en_title{
    font-size: 14px;
    font-weight: 400;
    line-height: 1;  
    margin-bottom: 6px;
  }
  
  header .parent_list .parent_link .ja_title{
    font-size: 12px;
    font-weight: 400;
    line-height: 1;
  }
  
  
  /*
  ----------------------------------------
  フッターバナーエリア
  ----------------------------------------
  */
  
  .common_banner_area{
    padding:0 0 100px;
    position: relative;
  }
  
  .common_banner_area .bg{
    width:100vw;
    position: absolute;
    z-index:-5;
    bottom:0;
    left:0;
  }
  
  
  /*
  ----------------------------------------
  イベントバナーエリア
  ----------------------------------------
  */
  
  .common_event_area{
    /* padding:30px 0 30px 0; */
  }
  
  .common_event_area .swiper_block{
    position: relative;
    /* padding:0 24px; */
  }
  
  .common_event_area .swiper_block .event_button{
    cursor: pointer;
    position:absolute;
    z-index: 10;
    top:0;
    bottom:0;
    margin:auto;
  }
  
  .common_event_area .swiper_block .event_prev_button{
    left:-8px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 7px 15px 7px 0;
    border-color: transparent #000 transparent transparent;
	 display:none;
  }
  
  .common_event_area .swiper_block .event_next_button{
    right:-8px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 7px 0 7px 15px;
    border-color: transparent transparent transparent #000;
	  display:none;
  }  
  

  /*
  ----------------------------------------
  フッター
  ----------------------------------------
  */

  /* footer .page_top{
    width:40px;
    bottom:auto;
    right:24px;
    top:-20px;
  } */

  footer .page_top{
    width:40px;
    border-radius: 40%; 
    bottom:50px;
    right:10px;
  }

  footer .menu_list li + li{
    margin-top: 24px;
  }

  footer .menu_list .menu_link .ja_title{
    font-size: 14px;
  }

  /*
  ----------------------------------------
  トップページ
  ----------------------------------------
  */
  
  body.top_body{
    
  }
  
  main.top_main{
  
  }
  
  .top_section{
    
  }
  
  .top_section01{
  
  }
  
  .top_section01 .mv img{
    width:100%;
    min-height:300px;
    object-fit: cover;
  }
  
  .top_section02{
    padding:60px 0;
  }

  .top_section02 .shop_frame{
    margin-bottom: 32px;
    overflow-x: scroll;
    width:fit-content;
    max-width: 100vw;
    margin: 0 calc(50% - 50vw) 32px;
  }
  
  .top_section02 .flex{
    display: flex;
    justify-content: space-between;
  }
  
  .top_section02 .flex .card{
    width: 150px;
    height: 265px;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
    margin:0 16px;
  }
  
  .top_section02 .flex .card .bg{
    width:100%;
    height:100%;
    object-fit: cover;
    transition: 0.4s;
  }
  
  .top_section02 .flex .card .shop_logo_frame{
    position: absolute;
    width:100px;
    height:100px;
    object-fit: cover;
    background-color: rgba(255,255,255,0.6);
    top:0;
    left:0;
    bottom:0;
    right:0;
    margin:auto;
  }
  
  .top_section02 .flex .card:hover .bg{
    transform: scale(1.1);
  }
  
  
  
  .top_section03{
    position: relative;
    padding:40px 0;
  }

  .top_section03 .bg{
    width:100vw;
  }
  
  .top_section03 .common_title_set{
    color:#fff;
  }
  
  .top_section03 .common_arrow_link{
    color:#fff;
    width:300px;
  }
  
  .top_section03 .common_arrow_link::before,
  .top_section03 .common_arrow_link::after{
    background-color: #fff;
  }

    
  .top_section04{
    padding-top: 60px;
    position: relative;
  }

  .top_recommend_section .common_shop_info_list{
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
  }

  .top_recommend_section .common_shop_info_list li:nth-child(n + 4) {
    display: block;
  }

  .top_recommend_section .common_shop_info_list li{
    width:48.5%;
    margin-bottom: 24px;
  }

  .top_recommend_section .common_shop_info_list .card .shop_info_shop_logo_frame {
    width: 40px;
    height: 40px;
  }

  .top_recommend_section .common_shop_info_list .card .cat{
    max-width: 120px;
  }

  .top_recommend_section .common_shop_info_list .card .shop_info_title {
    font-size: 10px;
  } 
  
  .top_section05{
    padding:60px 0 0;
  }
  
  .top_section05 .tiktok_frame{
    width:100%;
    height:450px;
    margin:0 auto;
  }
  
  .top_section05 .tiktok_frame blockquote{
    display: block;
    width:100%;
    height:100%;
  }
  
  .top_section06{
    padding:60px 0;
  }
  
  .top_section06 .youtube_frame{
    width:100%;
    height:180px;
    margin:0 auto;
  }
  
  .top_section06 .youtube_frame iframe{
    width:100%;
    height:100%;
    display: block;
  }
  
  .top_ranking_section{
    padding:80px 0;
  }
  
  .top_ranking_section h2{
    font-size: 20px;
  }
  
  .top_ranking_section .p01{
    margin-top: 10px;
    font-size: 16px;
    line-height: 1.5;
  }
  
  .top_ranking_section .rank_area{
    margin-top: 56px;
  }
  

  .top_ranking_section .rank_block .rank_footer .rank_shop_name{
    font-size: 12px;
  }
  
  .top_ranking_section .rank_block .rank_footer .rank_name{
    font-size: 16px;
  }
  
  .top_ranking_section .rank_block .rank_footer .rank_job{
    
    font-size: 12px;
  }
  
  .top_ranking_section .list01{
    display: flex;
    justify-content:center;
  }
  
  .top_ranking_section .list01 li{
    width:48%;
    margin-top: 32px;
  }

  .top_ranking_section .list01 li:first-child{
    width:245px;
    margin-top: 0;
  }

  .top_ranking_section .list01 .rank_block{
    width:100%;
    margin-left: 0;
  }

  
  .top_ranking_section .list01 .rank_block01{
    width:100%;
    margin-left: 0;
  }
  
  
  .top_ranking_section .list01 .rank_block .rank_footer{
    padding:16px 12px; 
  }
  
  .top_ranking_section .list02{
    margin-top: 56px;
  }
  
  .top_ranking_section .list02 .rank_arrow{
    display: none;
  }
  
  .top_ranking_section .list02 .swiper-slide{
    width: 155px;
    padding-right: 12px;
  }
  
  .top_ranking_section .list02 .rank_block{
    width:143px;
  }
  
  
  .top_ranking_section .list02 .rank_block .number_head{
    width: 40%;
    font-size: 11px;
    padding-top: 7px;
    padding-left: 24px;
  }
  
  .top_ranking_section .list02 .rank_block .rank_footer{
    padding:8px 12px; 
  }

  
  .top_ranking_section .common_arrow_link{
    margin-top: 32px;
  }
  
  .top_ranking_section .update_date{
    margin-top: 32px;
    font-size: 14px;
  }

  /*
  ----------------------------------------
  下層部分
  ----------------------------------------
  */
  
  .page_mv_section{
    height:300px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
  }
  
  .page_mv_section .mv{
    width:100vw;
    height:100%;
    object-fit: cover;
    z-index:-3;
    position: absolute;
    top:0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  }
  
  .page_mv_section .title_block{
    color:#fff;
    width: 320px;
    max-width: 100%;
  }
  
  .page_mv_section .title_block .en_title{
    font-size: 30px;
    line-height: 1.2;
    margin-bottom: 12px;
  }
  
  .page_mv_section .title_block .ja_title{
    font-size: 20px;
    line-height: 1.2;
  }
  
  /*
  ----------------------------------------
  店舗一覧
  ----------------------------------------
  */
  
  .shop_list_section01{
    padding:40px 0 80px;
  }
  
  .shop_list_section01 .goole_map{
    max-width:1000px;
    height:400px;
    margin:60px auto 0;
  }
  
  .shop_list_section01 .goole_map iframe{
    display: block;
    width:100%;
    height:100%;
  }
  
  /*
  ----------------------------------------
  店舗詳細
  ----------------------------------------
  */
  
  body.single_shop_body{
    
  }
  
  body.single_shop_body .common_banner_area {
    padding-top: 100px;
  }
  
  main.single_shop_main{
  
  }
  
  .single_shop_section01{
    padding:60px 0 0;
  }


  .single_shop_section01 .tab_list .tab{
    font-size: 15px;
    width:90px;
  }
  
  .single_shop_section01 .main_block{
    margin-bottom: 32px;
  }

  .single_shop_section01 .flex{
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .single_shop_section01 .sub_area{
    overflow-x: scroll;
    padding-left: 7vw;
    /* width:100%; */
  }
  
  .single_shop_section01 .sub_flex{
    display: flex;
  }
  
  .single_shop_section01 .sub_block{
    margin-left: 0;
    /* margin-right:30px; */
  }

  .single_shop_section01 .main_block .card{
    /* width: 200px;
    height: 350px; */
    width: 280px;
    height:505px;
  }
  
  .single_shop_section01 .card{
    display: block;
    width: 120px;
    height: 210px;
    position: relative;
    overflow: hidden;
    /* transition: 0.4s; */
  }
  
  .single_shop_section01 .card:hover{
    /* opacity: 0.8; */
  }

  
  .single_shop_section01 .card .pic{
    width:100%;
    height:100%;
    object-fit: cover;
    transition: 0.4s;
  }
  
  .single_shop_section01 .card:hover .pic{
    transform: scale(1.1);
  }
  
  .single_shop_section01 .card .no_pic{
    width:100%;
    height:100%;
    background-color: #D9D9D9;
  }
  
  .single_shop_section01 .card .number{
    position: absolute;
    top:8px;
    left:0;
    width:50px;
  }

  .single_shop_section01 .card .number_text{
    width: 45%;
    font-size: 11px;
    padding-top: 7px;
    padding-left: 20px;
  }

  .single_shop_section01 .sub_block .card .number_shop_logo{
    width:40px;
    height:40px;
  }

  .single_shop_section01 .sub_block .card .number_name {
    font-size: 15px;
    letter-spacing: 0.03em;
}

  .single_shop_section01 .card .name_area{
    font-size: 11px;
    padding:6px 8px;
  }

  .single_shop_section01 .main_block .card .name_area{
    font-size: 11px;
    line-height: 1.4;
  }

  .single_shop_section01 .main_block .card .number_text{
    width: 38%;
    font-size: 24px;
    padding-top: 10px;
    padding-left: 50px;
  }

  
  .single_shop_section02{
    padding:100px 0 0;
  }
  
  .single_shop_section02 .staff_list{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    flex-direction: column;
    align-items: center;
  }
  
  .single_shop_section02 .staff_block{
    width:100%;
    display: flex;
    margin-top: 50px;
    color:#000;
  }
  
  .single_shop_section02 .staff_block .thumb{
    width:120px;
    height:120px;
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
  }
  
  .single_shop_section02 .staff_block .thumb .pic{
    width:100%;
    height:100%;
    object-fit: cover;
    object-position: top;
    transition: 0.4s;
  }
  
  .single_shop_section02 .staff_block:hover .thumb .pic{
    transform: scale(1.1);
  }
  
  .single_shop_section02 .staff_block .thumb .no_pic{
    width:100%;
    height:100%;
    background-color: #D9D9D9;
  }
  
  
  .single_shop_section02 .staff_block .rank_area .box{
    width: 30px;
    height: 30px;
    font-size: 12px;
    margin-bottom: 5px;
  }
  
  .single_shop_section02 .staff_block .text_area{
    width:100%;
    padding-left: 16px;
  }
  
  .single_shop_section02 .staff_block .staff_birth{
    margin-bottom: 12px;
    font-size: 14px;
    line-height: 1.3;
  }
  
  .single_shop_section02 .staff_block .staff_info{
    display: flex;
    flex-wrap: wrap;
    font-size: 14px;
    line-height: 1.5;
  }
  
  .single_shop_section02 .staff_block .staff_info span{
    display: flex;
    align-items: center;
  }
  
  .single_shop_section02 .staff_block .staff_info span::before{
    content:"/";
    font-size: 14px;
    line-height: 1.5;
  }
  
  .single_shop_section02 .staff_block .staff_info span:first-child::before{
    content:"";
  }
  
  .single_shop_section03{
    padding:80px 0 0;
  }
  
  .single_shop_section03 .gal_area{
    width: 100vw;
    max-width: 100vw;
    margin: 60px calc(50% - 50vw) 40px;
  }
  
  .single_shop_section03 .link_flex{
    display: flex;
    justify-content: space-around;
    flex-direction: column;
    align-items: center;
    margin-bottom: 48px;
  }
  
  .single_shop_section03 .link_flex .common_arrow_link{
    margin:0;
    margin-bottom: 24px;
  }
  
  .single_shop_section03 .common_switch_block{
    border-bottom:1px solid #fff;
  }
  
  .single_shop_section03 .common_switch_contens{
    padding:12px;
    line-height: 1.5;
  }

  .single_shop_section .shop_sns{

  }

  .single_shop_section .shop_sns li + li{
    margin-left: 16px;
  }
  
  .single_shop_section .shop_sns a{
    width: 40px;
  }


  .single_shop_banner_section{
    padding:60px 0 0;
  }
  
  .single_shop_banner_section .banner{
    height:60px;
    display: flex;
    justify-content: center;
  }
  
  .single_shop_section04{
    padding:60px 0 0;
  }
  
  .single_shop_section04 .calendar_frame{
    width:100%;
    height:400px;
    margin:0 auto;
  }
  
  .single_shop_section04 .calendar_frame iframe{
    display: block;
    width:100%;
    height:100%;
  }
  
  
  
  /*
  ----------------------------------------
  スタッフ紹介
  ----------------------------------------
  */
  
  body.single_staff_body{
    
  }
  
  body.single_staff_body .common_banner_area {
    padding-top: 80px;
  }
  
  main.single_staff_main{
  
  }
  
  .single_staff_section01{
    padding:60px 0;
  }
  
  .single_staff_section01 .staff_block{
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 60px;
  }
  
  .single_staff_section01 .staff_block .thumb{
    width: 200px;
    height: 350px;
    position: relative;
    flex-shrink: 0;
    margin-bottom: 40px;
  }
  
  .single_staff_section01 .staff_block .thumb .pic{
    width:100%;
    height:100%;
    object-fit: cover;
  }
  
  .single_staff_section01 .staff_block .thumb .no_pic{
    width:100%;
    height:100%;
    background-color: #D9D9D9;
  }
  
  .single_staff_section01 .staff_block .thumb .number{
    position: absolute;
    top:16px;
    left:12px;
    width:50px;
  }

  .single_staff_section01 .staff_block .number_text{
    position: absolute;
    display: flex;
    position: absolute;
    top: 0;
    left: 0;
    color: #fff;
    background-color: rgba(0,0,0,0.5);
    line-height: 1;
    padding: 4px 8px;
    letter-spacing: 0.03em;
    font-size: 18px;
    justify-content: center;
    align-items: center;
    width: 50px;
    height: 50px;
  }
  

  .single_staff_section01 .staff_block .thumb .rank_area .box{
    width: 40px;
    height: 40px;
    font-size: 12px;
  }
  
  .single_staff_section01 .staff_block .text_area{
    width:100%;
    padding-left: 0;
  }
  
  .single_staff_section01 .staff_block .name_flex{
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    align-items: center;
    margin-bottom: 40px;
  }
	
	.sp-job{
		text-align:center;
		 margin-bottom: 10px;
	}
  
  .single_staff_section01 .staff_block .staff_name01{
    margin-right: 0;
    font-size: 30px;
    line-height: 1.3;
    margin-bottom: 12px;
  }
  
  .single_staff_section01 .staff_block .staff_name02{
    font-size: 16px;
    line-height: 1.3;
    padding-top: 0px;
  }
  
  .single_staff_section01 .staff_block ul{
    width: fit-content;
    margin:0 auto;
  }
  
  .single_staff_section01 .staff_block li{
    display: flex;
    margin-bottom: 24px;
  }
  
  .single_staff_section01 .staff_block li:last-child{
    margin-bottom: 0;
  }
  
  .single_staff_section01 .staff_block li .label{
    font-size: 16px;
    line-height: 1.5;
    flex-shrink: 0;
    width:90px;
  }
  
  .single_staff_section01 .staff_block li .contents{
    width:100%;
    font-size: 16px;
    line-height: 1.5;

  }
  
  
  .single_staff_section01 .img_flex{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  
  .single_staff_section01 .img_flex .thumb_pic{
    width:150px;
    height:100px;
    margin-bottom: 24px;
    overflow: hidden;
    cursor: zoom-in;
  }
  
  .single_staff_section01 .img_flex .thumb_pic img{
    width:100%;
    height:100%;
    object-fit: cover;
    transition: 0.4s;
  }

  
  
  .single_staff_section01 .popup{
    cursor: zoom-out;
    position: fixed;
    top:0;
    left:0;
    z-index:200;
    width:100%;
    height:100vh;
    background-color: rgba(0,0,0,0.6);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: 0.7s;
    pointer-events: none;
    opacity: 0;
  }
  
  .single_staff_section01 .popup.show{
    pointer-events: auto;
    opacity: 1;
  }
  
  .single_staff_section01 .popup .pop_pic{
    max-width: 75%;
  }
  
  .single_staff_section02{
    padding:32px 0;
    background-color: #000;
  }
  
  .single_staff_section02 .flex{
    display: flex;
    align-items: center;
    flex-direction: column;
    flex-wrap: wrap;
    gap:0;
  }
  
  .single_staff_section02 .flex .text{
    flex-shrink: 0;
    font-size: 20px;
    line-height: 1;
    color:#fff;
    margin-right: 0;
    padding-top: 0;
    margin-bottom: 24px;
  }
  
  .single_staff_section02 .sns_flex{
    display: flex;
    align-items: center;
    justify-content: center;
    width:100%;
  }
  
  .single_staff_section02 .sns_flex a{
    margin:0 5px ;
    width:50px;
  }
  
  .single_staff_section02 .sns_flex a img{
    width:100%;
  }
  
  .single_staff_section03{
    padding:80px 0 40px ;
  }
  
  .single_staff_section03 .tiktok_frame{
    width:100%;
    height:auto;
    margin:0 auto;
  }
  
  .single_staff_section03 .tiktok_frame blockquote{
    display: block;
    width:100%;
    height:100%;
  }
  
  
  .single_staff_section04{
    padding:40px 0 0;
  }
  
  .single_staff_section04 .flex{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    flex-direction: column;
    align-items: center;
    padding:0;
  }
  
  .single_staff_section04 .card{
    width: 100%;
    height: 230px;
    position: relative;
    overflow: hidden;
    margin-bottom: 32px;
  }

  .single_staff_section04 .card:last-child{
    margin-bottom: 0;
  }
  
  .single_staff_section04 .card .pic{
    width:100%;
    height:100%;
    object-fit: cover;
    transition: 0.4s;
  }
  
  .single_staff_section04 .card:hover .pic{
    transform: scale(1.1);
  }
  
  .single_staff_section04 .card .pickup_title{
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 6px 12px;
    font-weight: 400;
    line-height: 1.5;
    font-size: 14px;
    color: #fff;
    background-color: rgba(0,0,0,0.6);
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
  

  /*
  ----------------------------------------
  トピックス
  ----------------------------------------
  */
  
  body.topics_body{
    
  }
  
  body.topics_body .common_banner_area {
    padding-top: 80px;
  }
  
  main.topics_main{
  
  }
  
  .topics_section01{
    padding:0;
  }

  .topics_section01 .common_shop_info_list{
    display: flex;
    flex-direction: column;
  }
  
  .topics_section01 .common_shop_info_list li{
    margin-bottom: 40px;
    width: 100%;
    margin-right: 0;
  }

  .topics_section01 .common_topics_list {
    gap: 24px 0;
}

  .topics_section01 .common_topics_list .topics_item:nth-child(n + 4) {
    display: block;
  }
  .topics_section01 .common_topics_list .topics_thumb{
    width: 150px;
  }
  
  .topics_section01 .common_topics_list .topics_title {
    font-size: 13px;
  }
  
  .topics_section01 .common_topics_list .topics_cat_list {
    margin-top: 8px;
    gap: 8px; 
  }
  
  .topics_section01 .common_topics_list .topics_cat_list .cat {
    min-width: 80px;
    padding: 3px 6px;
    font-size: 10px;
    line-height: 1.4;
  }

  .topics_section01 .common_topics_list .topics_excerpt{
    font-size: 11px;
    -webkit-line-clamp: 2;
  }

  
  .topics_section01 .flex{
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: column-reverse;
  }
  
  .topics_section01 .topics_article{
    width:100%;
    margin-bottom: 0;
  }
  
  
  .topics_section01 .pagenation{
    display: flex;
    justify-content: center;
    align-items: center;
  }
  
  .topics_section01 .pagenation span.current{/*現在のページボタン*/
    width: 25px;
    height: 25px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin:0 6px;
    background-color: #000;
    color:#fff;
    font-size: 12px;
  }
  
  .topics_section01 .pagenation a.page-numbers{/*指定のページ移動ボタン*/
    width: 25px;
    height: 25px;
    display: flex;
    justify-content: center;
    align-items: center;
    border:1px solid #000;
    color:#000;
    margin:0 6px;
    transition: 0.4s;
    font-size: 12px;
  }
  
  .topics_section01 .pagenation a.page-numbers.next,
  .topics_section01 .pagenation a.page-numbers.prev{/*next prevボタン*/
    width:40px;
    font-size: 10px;
  }
  
  .topics_section01 .pagenation a.page-numbers:hover{
    background-color: #000;
    color:#fff;
  }

  .topics_section01 .sidebar_area{
    width:100vw;
    max-width: 400px;
  }
  
  .topics_section01 .sidebar{
    
    padding:24px 16px;
  }
  
  .topics_section01 .sidebar .common_switch{
    padding: 12px 24px 12px 16px;
  }
  
  .topics_section01 .sidebar .common_switch::after{
    right:16px;
    border-width: 12.5px 7.5px 0 7.5px;
    border-color: #fff transparent transparent transparent;
  }
  
  .topics_section01 .sidebar .shop_block{
  }
  
  .topics_section01 .sidebar .shop_block li{
    margin-top: 12px;
  }
  
  .topics_section01 .sidebar .shop_block li a{
    color:#fff;  
    font-weight: 400;
    line-height: 1.3;
    font-size: 14px;
  }
  
  .topics_section01 .sidebar .shop_block li a:hover{
    text-decoration: underline;
  }
  
  .topics_section01 .sidebar .shop_block li a.active{
    text-decoration: underline;
  }
  
  .topics_section01 .sidebar .category_block{
  }
  
  .topics_section01 .sidebar .category_block li{
    margin-top: 12px;
  }
  
  .topics_section01 .sidebar .category_block li a{
    color: #fff;
    font-weight: 400;
    line-height: 1.3;
    font-size: 14px;
  }
  
  .topics_section01 .sidebar .category_block li a:hover{
    text-decoration: underline;
  }
  
  .topics_section01 .sidebar .category_block li a.active{
    text-decoration: underline;
  }
  
  .topics_section01 .sidebar .rank_head{
    margin-bottom:24px;
    font-size: 18px;
    font-weight: 400;
    line-height: 1.5;
  }
  
  .topics_section01 .sidebar .rank_list{
  
  }

  .topics_section01 .sidebar .common_topics_list .topics_item:nth-child(n + 4){
    display: block;
  }

  .topics_section01 .sidebar_area .banner_flex{
    padding:0 16px;
  }
  

  
  .topics_section01 .single_block{
    padding:0 0 24px;

    margin-bottom: 32px;
  }
  
  .topics_section01 .single_block h1{
    margin-bottom: 32px;
    font-size: 20px;
    line-height: 1.4;
    padding-bottom: 8px;
  
  }
  
  .topics_section01 .single_block h2{
    font-size: 18px;
    line-height: 1.5;
    margin:20px 0;
  }
  
  
  .topics_section01 .single_block h3{
    font-size: 16px;
    line-height: 1.5;
    margin:16px 0;
  }
  
  .topics_section01 .single_block p{
    line-height: 1.8;
    margin:24px 0;
    font-size: 14px;
  }
  
  .topics_section01 .single_block figure{
    margin-top:32px;
    margin-bottom:32px;
  }
  
  .topics_section01 .link_flex{
    display: flex;
    justify-content: space-between;
  }
  
  .topics_section01 .link_flex .link a{
    width:140px;
    position: relative;
    padding-bottom: 10px;
    padding-top: 10px;
    display: flex;
    line-height: 1.2;
    color:#000;
  }
  
  .topics_section01 .link_flex .link a::before{
    transition: 0.4s;
    content:"";
    width:100%;
    height:1px;
    background-color: #000;
    position: absolute;
    bottom:0;
    left:0;
  }
  
  .topics_section01 .link_flex .link a::after{
    transition: 0.4s;
    content:"";
    width:40px;
    height:1px;
    background-color: #000;
    position: absolute;
    bottom:0;
    
  }
  
  .topics_section01 .link_flex .link_prev a{
    padding-left: 40px;
  }
  
  .topics_section01 .link_flex .link_prev a::after{
    left:0;
    transform: rotateZ(-50deg);
    transform-origin: left;
  }
  
  .topics_section01 .link_flex .link_next a{
    justify-content: flex-end;
    padding-right: 40px;
  }
  
  .topics_section01 .link_flex .link_next a::after{
    right:0;
    transform: rotateZ(50deg);
    transform-origin: right;
  }
  
  @media(min-width:768px){
    .topics_section01 .link_flex .link_prev:hover a::before{
      left:-20px;
    }
    .topics_section01 .link_flex .link_prev:hover a::after{
      left:-20px;
    }
    .topics_section01 .link_flex .link_next:hover a::before{
      left:20px;
    }
    .topics_section01 .link_flex .link_next:hover a::after{
      right:-20px;
    }
  }/*@media(min-width:768px){*/
  
  .topics_section02{
    padding:80px 0 0;
  }

  .topics_section02 .shop_info_frame{
    border:1px solid #000;
    padding:24px;
  }

  .topics_section02 .common_shop_list .shop_block .link_flex .common_arrow_link {
    width: 100%;
  } 

  .topics_section02 .shop_head{
    margin-bottom: 32px;
    font-size: 20px;
    font-weight: 400;
    line-height: 1.4;
    border-bottom:1px solid #000;
    padding-bottom: 8px;
  }
  
  .topics_section03{
    padding:80px 0 0;
  }
  
  .topics_section03 .recent_list{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    padding:0;
  }
  
  .topics_section03 .recent_list .recent_card{
    font-display: block;
    width: 100%;
    height: 230px;
    position: relative;
    overflow: hidden;
    margin-bottom: 32px;
  }
  
  .topics_section03 .recent_list .recent_card .thumb{
    width:100%;
    height:100%;
    object-fit: cover;
    transition: 0.4s;
  }
  
  .topics_section03 .recent_list .recent_card:hover .thumb{
    transform: scale(1.1);
  }
  
  .topics_section03 .recent_list .recent_card .recent_title{
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 6px 12px;
    font-weight: 400;
    line-height: 1.5;
    font-size: 14px;
    color: #fff;
    background-color: rgba(0,0,0,0.6);
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
  
  .topics_section04{
    padding:60px 0 0;
  }

  .topics_section04 .common_topics_list .topics_item:nth-child(4) {
    display: block;
  }


  /*
  ----------------------------------------
  ランキング
  ----------------------------------------
  */

  body.ranking_body{
    
  }

  main.ranking_main{

  }

  .ranking_section01{
    padding-bottom: 0!important;
  }


}/*@media(max-width:767px){*/

@media(max-width:767px){
	.single_shop_banner_section .banner img{
		object-fit:contain;
	}
}