html,body{
    overflow-x: hidden;
}
#contents_top h1{
    font-size: 13px;
    color: #999;
    font-weight: 300;
    text-align: right;
    margin: 80px 20px 0 0;
}
h2{
    font-family: "Alata", sans-serif;
    text-align: center;
    font-size: 34px;
    letter-spacing: 1px;
    font-weight: 400;
}
header a{
    color: #000;
    text-decoration: none;
}
.header_wrap{
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 120px;
}
.header_logo_wrap{
    padding: 20px;
}
ul.header_nav_list{
    display: flex;
}
ul.header_nav_list li{
    margin-left: 50px;
    font-size: 16px;
    font-weight: 400;
    letter-spacing: .5px;
    display: flex;
    align-items: center;
    font-family: "Alata", sans-serif;
}
ul.header_nav_list li.header_nav_item.online_store{
    border: 1px solid #000;
    background: #000;
    font-size: 13px;
}
ul.header_nav_list li.header_nav_item.online_store a{
    padding: 7px 18px;
    color: #fff;
    display: block;
    line-height: 120px;
}
.hero_section{
    position: relative;
}
.overlay{
    position: absolute;
    top: 0;
    left: 0;
    width: 30%;
    height: 100%;
    display: flex;
    align-items: center;
    background: rgb(0, 0, 0,.6);
}
.overlay_contents{
    margin: 0 auto;
}
.ToOnlineStore_section{
    background-image: url(images/bnr_to_online_store.jpg);
    height: 300px;
    background-size: cover;
    background-position: center;
    animation: moveBackground 120s infinite linear;
    position: relative;
}
@keyframes moveBackground {
    0% { background-position: 0% 0%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 0%; }
}
.ToOnlineStore_section a .text_onlinestore{
    position: absolute;
    top: 50%;
    left: 50%;
    color: #fff;
    transform: translate(-50%,-50%);
    font-family: "Alata", sans-serif;
    font-size: 26px;
    letter-spacing: 2px;
    font-weight: 400;
    padding-bottom:2px;
    border-bottom: 1px solid #fff;
}
.ToOnlineStore_section{
    margin-top: 50px;
}
.brand_section{
    margin-top: 70px;
}
.shop_section{
    margin-top: 70px;
}
.brand_slider{
    margin-top: 50px;
    line-height: 0;
    font-size: 0;
}
.slick-initialized .slick-slide{
    height: 360px;
}
.brand_slider a img{
    width: 260px;
}
.brand_slider a {
	transform: scale(1);
	transition: transform .3s;
    display: block;
    z-index: 1;
    margin-top:40px;
    position: relative;
}
.brand_slider .slick-slide{
    z-index:1;
    margin-left: 11px;
    position: relative;
}
.brand_slider .slick-center{
    z-index:100;
    position: relative;
}
.brand_slider .slick-center a {
    transform: scale(1.25);
    height:0;
    line-height:300px;
     margin-top:0px;
}
.view_more_btn{
    width: 180px;
    margin: 0 15px 0 auto;
}
.view_more_btn a{
    color: #000;
    padding: 10px;
    display: block;
    text-align: left;
    text-decoration: none;
    border-bottom: 1px solid #000;
    font-size: 13px;
    position: relative;
}
.view_more_btn a::before{
    width:20px;
    height:1px;
    background:#000;
    position:absolute;
    bottom:5px;
    right:-2px;
    content:"" ;
    transform: translateX(0) rotate(35deg);
}
.shop_section{
    width: 1200px;
    margin: 40px auto 0;
}
.shop_section h2{
    text-align: left;
}
.shop_section h4{
    font-weight: 300;
    margin-top: 40px;
    font-size: 18px;
}
.shop_contents_inner{
    display: flex;
    justify-content: start;
    margin-top: 20px;
}
.shop_contents_inner .shop_img{
    width: 50%;
}
.shop_contents_inner .shop_text_wrap{
    width: 40%;
    margin-left:5%
}
.shop_contents_inner .shop_info_list li{
    margin-bottom: 16px;
}
.shop_contents_inner .shop_info_list li i{
    margin-right: 15px;
}
.shop_contents_inner .map_btn{
    font-size: 14px;
    background: #000;
    display: inline-block;
    margin-top: 20px;
    text-align: center;
}
.shop_contents_inner .map_btn a{
    color: #fff;
    text-decoration: none;
    display: block;
    padding: 10px 30px;
    letter-spacing: 1px;
}
footer{
    background: #000;
    margin-bottom: 0;
    color: #fff;
    margin-top: 20px;
}
footer .footer_wrap{
    width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}
footer .footer_nav_list{
    display: flex;
    width: 60%;
    align-items: center;
    padding: 40px 0;
}
footer .footer_nav_list li{
    margin-right: 10%;
    font-size: 14px;
}
.footer_sns_list{
    font-size: 22px;
    display: flex;
    align-items: center;
}
footer a{
    color: #fff;
    text-decoration: none;
}
.footer_copyright{
    font-size: 11px;
    color: #888;
    padding: 10px;
    text-align: center;
}

@media screen and (min-width:769px) { 
    .sp-only{
        display: none;
    }
 
 }
 /* SP */
@media screen and (min-width: 0px) and (max-width:768px) {
    .pc-only{
        display: none;
    }
    header .header_wrap{
        height: 80px;
    }
    header .header_nav_list li{
        display: none;
    }
    header .header_nav_item.online_store{
        display: block;
    }
    header .header_logo_wrap{
        width: 40%;
        padding: 15px;
    }
    header ul.header_nav_list li.header_nav_item.online_store a{
        height: 80px;
        line-height: 66px;
    }
    .hero_img{
        width: 100%;
        height: 100vw;
        background-image: url(images/hero_img_202505.jpg);
        background-size: cover;
        background-position: center;
    }
    .overlay{
        width: 42%;
    }
    .overlay_img{
        width: 70%;
        margin: 0 auto;
    }
    .ToOnlineStore_section{
        background-image: url(images/bnr_to_online_store.jpg);
        height: 100px;
        background-size: cover;
        background-position: center;
        animation: moveBackground 120s infinite linear;
    }
    @keyframes moveBackground {
        0% { background-position: 0% 0%; }
        50% { background-position: 100% 50%; }
        100% { background-position: 0% 0%; }
    }
    .ToOnlineStore_section a .text_onlinestore{
        font-size: 18px;
    }
    .ToOnlineStore_section img{
        display: none;
    }

    .shop_section{
        width: calc(100% - 30px);
        margin: 50px auto;
    }
    .shop_section h2 {
        text-align: center;
    }
    .shop_contents h4{
        text-align: center;
        margin-top: 20px;
        font-size: 15px;
    }
    .shop_contents_inner{
        display: block;
    }
    .shop_contents_inner .shop_img,
    .shop_contents_inner .shop_text_wrap{
        width: 100%;
    }
    .shop_contents_inner .map_btn{
        margin: 20px auto;
        width: 100%;
    }
    .shop_contents_inner .shop_text_wrap{
        width: 90%;
        margin: 30px auto;
    }
    .shop_contents_inner .map_btn a {
        font-size: 13px;
    }
    footer .footer_wrap{
        width: 100%;
        display: block;
    }
    footer .footer_nav_list{
        justify-content: space-between;
        width: 80%;
        margin: 0 auto;
    }
    footer .footer_nav_list li{
        margin-right: 0;
    }
    .footer_sns_list{
        justify-content: center;
        font-size: 26px;
    }

    ul.brand_list{
        display: flex;
        flex-wrap: wrap;
        padding: 15px;
        justify-content: space-between;
        margin-top: 20px;
    }
    /* .brand_list_item:first-child{
        width: 100%;
    }
    .brand_list_item:first-child img{
        width: 100%;
    } */
    .brand_slider a{
        margin-top: 0;
    }
    .brand_list_item{
        width: 49%;
        margin-bottom: 2%;
    }
    .view_more_btn{
        width: 150px;
        margin: 0 25px 0 auto;
    }
    .view_more_btn a{
        color: #000;
        padding: 10px;
        display: block;
        text-align: left;
        text-decoration: none;
        border-bottom: 1px solid #000;
        font-size: 13px;
        position:relative;
    }
    
    .view_more_btn a::before{
        width:20px;
        height:1px;
        background:#000;
        position:absolute;
        bottom:4px;
        right:-2px;
        content:"" ;
        transform: translateX(0) rotate(35deg);
    }
    
}

/* Loading背景画面設定　*/
.splash_text img{
    margin: 0 auto 20px;
    width: 100px;
}
.progressbar-text{
    display: none;
}
#splash {
    /*fixedで全面に固定*/
  position: fixed;
  z-index: 999;
  width: 100%;
  height: 100%;
  background: #000;
  text-align:center;
  color:#fff;
}

/* Loadingバー中央配置　*/
#splash_text {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 999;
  width: 100%;
  transform: translate(-50%, -50%);
  color: #000;
}

/* Fadein animation */
.fade-in {
	opacity: 0;
	transition-duration: 500ms;
	transition-property: opacity, transform;
  }
  .fade-in-up {
	transform: translate(0, 50px);
  }
  .fade-in-down {
	transform: translate(0, -50px);
  }
  .fade-in-left {
	transform: translate(-50px, 0);
  }
  .fade-in-right {
	transform: translate(50px, 0);
  }
  .scroll-in {
	opacity: 1;
	transform: translate(0, 0);
  }
  

/* reset */
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}
li{
    list-style: none;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role="list"],
ol[role="list"] {
  list-style: none;
}
ul{
    padding-inline-start: 0;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture {
  max-width: 100%;
  display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove all animations and transitions for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
   scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}