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


@media (max-width : 960px){
     
    #shop .wrapper, #about .wrapper, #news .wrapper, #recruit .wrapper{
        padding-top: 100px;
    }
    
    #recruit .wrapper{
        padding-bottom: 100px;
    }
    
    
/*ハンバーガーメニュー*/
.hamburger {
		display: block;
		position: fixed;
		z-index: 3;
		right: 13px;
		top: 18px;
		width: 42px;
		height: 42px;
		cursor: pointer;
		text-align: center;
		background: #FFECB5;
	}
	
	.hamburger span {
		display: block;
		position: absolute;
		width: 30px;
		height: 2px;
		left: 6px;
		background: #734E30;
		-webkit-transition: 0.3s ease-in-out;
		-moz-transition: 0.3s ease-in-out;
		transition: 0.3s ease-in-out;
	}
	
	.hamburger span:nth-child(1) {
		top: 10px;
	}

	.hamburger span:nth-child(2) {
		top: 20px;
	}
	
	.hamburger span:nth-child(3) {
		top: 30px;
	}
	
	.rwd_nav {
		width: 100%;
		height: 100%;
		height: -webkit-fill-available;
		display: block;
		position: fixed;
		z-index: 2;
		top: 0;
		left: 0;
		color: #333;
		text-align: center;
		transform: translateY(-100%);
		transition: all 0.6s;
        margin-top: 60px;
	}
    
    .bg_w{
        background-color: rgba(255, 255, 255,.7);
        height: 100vh;
    }
	
	.rwd_nav ul {
		width: 100%;
		padding: 0;
		margin: 0 auto;
		display: flex;
		flex-direction: column;
        background: #FFECB5;
	}
	
	.rwd_nav ul li {
		width: 100%;
		padding: 0;
		list-style-type: none;
		flex: 1;
	}
	
	.rwd_nav.active {
		transform: translateY(0%);
	}
	
	.hamburger.active span:nth-child(1) {
		top: 16px;
		left: 6px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
	
	.hamburger.active span:nth-child(2), .hamburger.active span:nth-child(3) {
		top: 16px;
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		transform: rotate(45deg);
	}
    
    .header-wrapper{
        padding: 10px 20px;
    }
    
    .rwd_nav ul a:hover{
        color: #734E30;
    }
    
    .rwd_nav ul a:active{
        color: #fff;
        background-color: #F79A35;
        transition: color 0.3s ease 0s;
    }

    
    
    h2 .title{
        font-size: 22px;
    }
    
    .shop .shop_container{
        grid-template-columns: 1fr 1fr;
        margin-right: 50px;
        margin-left: 50px;
    }
    
    .about{
        background-size: cover;
    }
    
    #shop h3,#about h3 {
        font-size: 20px;
    }
    
    footer .wrapper{
        display: block;
        padding: 50px 20px;
    }
    
    footer .logo{
        width: 100%;
        margin-bottom: 50px;
        display: block;
        text-align: center;
    }
    
    footer ul{
        justify-content: center;
    }
    
}

@media (max-width : 860px){
    #shop .shop_container_i{
        display: block;
    }
    
    #shop .shop_container{
        padding: 30px;
    }
    
    #shop h3{
        padding-bottom: 30px;
    }
    
    #shop .slide3{
        width: 100%;
        height: auto;
    }
    
    #shop .shop_info{
        width: 100%;
        margin-top: 50px;
    }
}


@media (max-width : 768px){
    
    .recruit .recruit_txt{
        position: static;
        text-align: center;
    }

}

@media screen and (max-width: 540px) {
/* モバイル向けスタイル */
    
    .wrapper{
        padding: 75px 20px;
    }
    
    .hamburger {
        top: 12px;
    }
    
     .slide1 .slide-items img{
        height: 60vh;
    }
    
    #shop .wrapper{
        padding-top: 50px;
    }
    
    #shop .shop_frame{
        margin-bottom: 75px;
    }
    
    #shop .shop_frame:last-child{
        margin-bottom: 0;
    }
    
    #recruit .wrapper{
        padding-bottom: 80px;
    }
    
    .rwd_nav, main{
        margin-top: 57px;
    }
    
    .logo img{
        width: 180px;
    }
    
    .breadcrumb{
        font-size: 16px;
    }

    .slide1 .slide_txt{
        width: 100%;
        top: 50%;
        left: 50%;
        background-color: rgba(255, 255, 255, .6);
        padding-top: 50px;
        padding-bottom: 50px;
        text-align: center;
    }
    
    .slide1 .slide_txt span{
        background: none;
    }

    h2{
        margin-bottom: 30px;
    }
    
    h2 .title{
        margin-bottom: 10px;
    }
    
    h2 .en{
        font-size: 12px;
    }
    
    .flex{
        display: block;
    }
    
    .shop .shop_txt br{
        display: none;
    }
    
    .shop .shop_container{
        grid-template-columns: 1fr;
        margin-top: 30px;
    }
    
    .about .wrapper{
        padding-top: 100px;
    }
    
    .about .about_txt h3{
        font-size: 18px;
    }
    
    .slide2 img{
        width: 200px;
    }
    
 
    .news .news_info dt{
        margin-bottom: 5px;
    }
    
    .recruit .r_main_txt{
        font-size: 18px;
    }
    
    .recruit .recruit_txt{
        text-align: start;
    }
    
    #shop .shop_txt_link{
        font-size: 16px;
        padding-top: 30px;
    }
    
    #about .philosophy .philosophy_txt{
        padding: 20px;
    }
    
    #about .philosophy .philosophy_txt p br{
        display: none;
    }
    
    #about .guidelines{
        padding: 75px 0;
    }
    
    #about .summary dl{
        display: block;
    }
    
    #about .summary dt{
        width: 100%;
        padding-bottom: 20px;
    }
    
    #about .summary dd{
        width: 100%;
    }
    
    #news .news_img{
        width: 100%;
    }
    
    #news .news_info{
        width: 100%;
        padding-top: 20px;
        padding-left: 0;
    }
      
    .r_top{
        display: block;
        position: fixed;
        right: 30px;
        bottom: 30px;
        right: 0;
        transition: all 0.5s;
        opacity: 0;
    }
    
    .r_top.visible{
        opacity: 1;
    }
    
    .r_top a{
        display: inline-block;
        background: #F79A35;
        padding: 10px;
        margin-right: 10px;
        border-radius: 50%;
    }

    .r_top .fa-angle-up{
        color: #fff;
    }

    
    footer ul{
        display: block;
    }
    
    footer li{
        text-align: center;
    }
    
    footer li a, .footer_link:first-child a{
        padding-right: 0;
    } 
    
}