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



.container {
    width: 100%;
    margin: 60px auto 0 auto;
    overflow: hidden;
}

#wrap {
    position: relative;
    z-index: 999;
}

/* header
---------------------------------------------------------------------------------------------------------------------*/
#header {
    z-index: 9999;
}


/* ポップアップ
---------------------------------------------------------------------------------------------------------------------*/
.fix-popup {
    max-width: 300px;
    position: fixed;
    bottom: 0;
    right: 0;
    z-index: 99999;
}

.popup-btn {
    display: block;
    color: #fff;
    width: 45px;
    height: 45px;
    border-radius: 45px;
    background: rgba(0, 0, 0, 0.8);
    font-size: 28px;
    line-height: 45px;
    text-align: center;
    cursor: pinter;
}

.popup-btn:hover {
    cursor: pinter;
}

.box {
    background: #fff;
}

/* close button */
.action-close {
    position: relative;
    right: 4%;
}

.action-close .btn {
    position: absolute;
    right: 0;
    top: -25px;
}

.action-close .box {
    padding: 5%;
}

/* checkbox 非表示 */
.fix-popup .checkbox {
    display: none;
}

/* close button's control */
.fix-popup .action-close #close:checked~.btn {
    display: none;
}

.fix-popup .action-close #close:checked~.box {
    display: none;
}

@media screen and (max-width: 767px) {
    .fix-popup {
        max-width: 220px;
    }

    .action-close .btn {
        top: -35px;
    }

    .popup-btn {
        width: 40px;
        height: 40px;
        border-radius: 40px;
        line-height: 35px;
    }

    .action-close .box {
        padding: 3%;
    }
}





/* top_slider
--------------------------------------------------------------------------------------------------------------------
.top_slider {
    overflow: hidden;
    padding-bottom: 80px;
	margin-top: 10px;
}
.top_slider .inner {
	width: width: 100%;
	margin: auto;
}
.top_slider .slick-list {overflow: visible !important;}
.top_slider .slick-slide {opacity: 0.5;transition: 0.5s;height: auto;}
.top_slider .slick-slide img { width: 100%;}
.top_slider .slick-now {opacity: 1;}
.top_slider .topic{margin:0;position: relative;
.top_slider .slick-slide:focus {outline:none;}
.top_slider .inner .slick-prev{left: -60px;}
.top_slider .inner .slick-next{right: -60px;}
.top_slider .slick-prev, .slick-next {top: 50%;}
.top_slider .slick-prev:before, .slick-next:before {display: block;}
.top_slider .slick-dots li.slick-active button:before {background-color: #231816;}-*/


/* info_link
---------------------------------------------------------------------------------------------------------------------*/
.info_block{
    padding-bottom:85px;
}

.info_link {
    display: block;
}

.info_link p {
    width: 95%;
    max-width: 1100px;
    font-size: 12px;
    font-weight: bold;
    line-height: 40px;
    border: 1px solid #707070;
    box-sizing: border-box;
    margin: 10px auto;
    color: #000;
    text-align: center;
}

.info_link:hover {
    transition: .5s;
    opacity: 0.6;
}


/* reservation_link
---------------------------------------------------------------------------------------------------------------------*/
.reservation_link {
    width: 92%;
    max-width: 1100px;
    margin: auto;
    height: auto;
    position: relative;
    overflow: hidden;
    filter: drop-shadow(0px 5px 5px rgba(0, 0, 0, 0.4));
}

.reservation_link a {
    width: 100%;
    display: block;
    float: left;
}

.reservation_link a img {
    width: 100%;
}

.reservation_link:hover {
    transition: .5s;
    filter: drop-shadow(0px 7px 7px rgba(0, 0, 0, 0.6));
}


/* event_link
---------------------------------------------------------------------------------------------------------------------*/
.event_link {
    width: 95%;
    max-width: 1100px;
    margin: auto;
    padding: 0;
    margin-top: 20px;
    height: auto;
    position: relative;
    overflow: hidden;
    /*filter: drop-shadow(0px 5px 5px rgba(0,0,0,0.4));*/
}

.event_link a {
    width: 100%;
    display: block;
    float: left;
}

.event_link a img {
    width: 100%;
}

.event_link:hover {
    transition: .5s;
}


/* page_title
---------------------------------------------------------------------------------------------------------------------*/

.page_title_inner p,
.page_title_inner h2 {
    font-size: 22px;
    font-weight: normal;
    letter-spacing: 0.1em;
    line-height: 1;
    padding: 0;
    margin: 85px 0 10px 0;
    color: #000;
    text-align: center;
}

.page_title_inner hr {
    width: 50px;
    margin: 0 auto 30px auto;
    height: 0.5px;
    background-color: var(--bk);
    border: none;
}


/* category new_products pre_order
---------------------------------------------------------------------------------------------------------------------*/

.category,
.new_products,
.pre_order {
    width: 100%;
    margin: auto;
    padding: 0 0 50px 0;
    overflow: hidden;
}

.new_products,
.ranking_title,
.index_ranking {
    background-color: #f4f4f4;
}

.itemfrex {
    width: 100%;
    height: auto;
    max-width: 1100px;
    margin: auto;
    overflow: hidden;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.itemfrex li {
    width: calc(100%/2);
    padding: 0 1.5% 40px 1.5%;
    height: auto;
    overflow: hidden;

    cursor: pointer;
}

.itemfrex li a {
    display: block;
    text-align: center;
}

.itemfrex li li img {
    width: 100%;
}

.itemfrex li img:hover {
    opacity: 0.6;
    transition: .5s cubic-bezier(0.78, .18, .34, .98);
}


.itemfrex li p,
.itemfrex li h3 {
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0.02em;
    line-height: 1.6;
    overflow: hidden;
    text-overflow: ellipsis;
    margin: 15px 0 0 0;
}


.itemfrex li h3.st-en{
    font-size: 15px;
    letter-spacing: 0.08em;
}


.itemfrex li p span,
.itemfrex li h3 span {
    font-size: 12px;
    font-weight: normal;
}

.itemfrex li p.price {
    font-size: 14px;
    font-weight: normal;
    letter-spacing: 0.02em;
    margin: 0;
}

.itemfrex li p.price span {
    font-size: 10px;
}

.view_more {
    display: block;
    border: 1px solid #231816;
    box-sizing: border-box;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.028em;
    line-height: 50px;
    width: 96%;
    max-width: 370px;
    height: 50px;
    padding: 0;
    text-align: center;
    margin: auto;
    background-color: #fff;
    margin: 0 auto;
    background-image: url(https://gigaplus.makeshop.jp/johnsblend/assets/img/site_img/link_arrow.png);
    background-repeat: no-repeat;
    background-size: 20px;
    background-position: 80% 50%;
    background-color: #fff;
}

.view_more img {
    width: 6px;
    position: absolute;
    right: 10px;
    top: 50%;
    margin-top: -4px;
}

.view_more:hover {
    background-color: #231816;
    color: #fff;
    background-image: url(https://gigaplus.makeshop.jp/johnsblend/assets/img/site_img/link_arrow_wh.png);
    transition: .5s cubic-bezier(0.78, .18, .34, .98);
}




/* ranking
---------------------------------------------------------------------------------------------------------------------*/
.ranking_title {
    width: 100%;
    margin: auto;
    padding: 10px 0 20px 0;
    margin-bottom: 0;
    overflow: hidden;
}

.index_ranking {
    width: 100%;
    overflow: hidden;
    padding: 0;
    position: relative;
    margin-bottom: 50px;
}

.swiper-container {
    width: 100%;
}

.swiper-wrapper {
    width: 100%;
    list-style: none;
    margin: 0;
    padding: 0;
}

.swiper-slide {
    width: 81.3% !important;
    height: auto;
    margin: 0 1%;
    text-align: center;
    font-size: 14px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
    padding: 20px 0;
    background-color: #fff;
    overflow: hidden;
    position: relative;
}

.swiper-slide a {
    height: 100%;
}

.rank_no {
    position: absolute;
    font-size: 16px;
    line-height: 30px;
    font-weight: bold;
    color: #fff;
    width: 30px;
    height: 30px;
    top: 10px;
    left: 10px;
    background-color: #666666;
    border-radius: 50%;
    z-index: 10;
    margin: 0;
}




.rank_img img {
    width: 90%;
}

.rank_name {
    width: 90%;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.5;
    letter-spacing: 0.02em;
    overflow: hidden;
    text-overflow: ellipsis;
    margin: 15px auto 0 auto;
    text-align: center;
}

.rank_name a {
    text-decoration: none;
    color: #000;
    height: 450px;

}

.rank_price {
    width: 90%;
    font-size: 14px;
    line-height: 1.5;
    letter-spacing: 0.02em;
    overflow: hidden;
    text-overflow: ellipsis;
    margin: 5px auto 0 auto;
    text-align: center;
}

.rank_price span {
    font-size: 10px;
}

.swiper-button-next,
.swiper-button-prev {
    display: none;
}

.swiper-button-prev:after,
.swiper-button-next:after {
    font-family: swiper-icons;
    font-size: var(--swiper-navigation-size);
    text-transform: none !important;
    letter-spacing: 0;
    text-transform: none;
    font-variant: initial;
}

/* concept_movie
---------------------------------------------------------------------------------------------------------------------*/
.concept_movie {
    width: 92%;
    max-width: 1100px;
    margin: 0 auto;
    height: auto;
    position: relative;
    overflow: hidden;
}

.concept_movie video {
    width: 100%;
    margin: 0;

}

.concept_movie #video {
    width: 100%;
    margin: 50px 0;
    height: 51.80vw;
    vertical-align: top;
}

.youtube {
    width: 100%;
    max-width: 1100px;
    margin: auto;
    padding-top: 56.25%;
    position: relative;
}

.youtube iframe {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}


@media screen and (min-width:768px) {

    /*________________________________________________________________________________________________________*/
    .container {
        margin: 90px auto 0 auto;
    }

    .slick-prev:before {
        content: url(https://gigaplus.makeshop.jp/johnsblend/assets/img/site_img/slider-arrow-prev.png);
    }

    .slick-next:before {
        content: url(https://gigaplus.makeshop.jp/johnsblend/assets/img/site_img/slider-arrow-next.png);
    }

    .top_slider .inner {
        width: 60%;
        max-width: 800px;
        margin: auto;
    }

    .top_slider .topic {
        margin: 0 10px;
        position: relative;
    }

    .info_link p {
        font-size: 16px;
        font-weight: bold;
        line-height: 50px;
    }

    .event_link {
        width: 100%;
    }

    .itemfrex li {
        width: calc(100%/3);
    }

    .page_title_inner p,
    .page_title_inner h2 {
        font-size: 28px;
        margin: 120px 0 15px 0;
    }

    .itemfrex li p,
    .itemfrex li h3 {
        font-size: 18px;
        margin: 20px 0 0 0;
    }

    .itemfrex li h3.st-en {
        font-size: 20px;
        letter-spacing: 2px;
    }

    .itemfrex li p span,
    .itemfrex li h3 span {
        font-size: 16px;
    }

    .itemfrex li p.price {
        font-size: 16px;
        margin-top: 5px;
    }

    .itemfrex li p.price span {
        font-size: 14px;
    }

    .rank_price {
        font-size: 16px;
    }

    .rank_price span {
        font-size: 14px;
    }

    .swiper-container {
        width: 100%;
    }

    .swiper-slide {
        width: 32.35% !important;
        height: auto;
        margin: 0 0.5%;
    }

    .swiper-slide a {
        height: 100%;
    }

    .swiper-button-next,
    .swiper-container-rtl .swiper-button-prev {
        display: block;
    }

    .swiper-button-prev,
    .swiper-container-rtl .swiper-button-next {
        display: block;
    }

    .youtube iframe {
        width: 100%;
        height: 400px;
        margin: auto;
    }
}

@media screen and (min-width:1024px) {
    /*________________________________________________________________________________________________________*/


    .youtube iframe {
        width: 100%;
        height: 619px;
        margin: auto;
    }


}



/*topics 追加
--------------------------------------------------------------------------------------------------------------------*/
.index_topics {
    width: 100%;
    overflow: hidden;
    padding: 0;
    position: relative;
    margin-bottom: 50px;
}

.topics_txtwrap {
    padding: 0 2%;
}

.topics_ttl {
    font-size: 15px;
    font-weight: bold;
    text-align: left;
    margin: 3% 0 2%;
}

.topics_txt {
    width: 100%;
    text-align: left;
    /* overflow: hidden;
height: calc( 1.5em * 2 ); */
    line-height: 1.5;
}

.topics_img {
    height: 270px;
}

.topics_img img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.swiper-slide.topics {
    padding: 0;
}

/* .swiper-slide.topics::before{
    display: block;
    content:"Campaign";
    background:#D12A57;
    color:#fff;
    padding:7px 12px;
    position: absolute;
    font-family: 'Lato', sans-serif;
    top:10px;
    left:10px;
} */

/*スライダー調整
.swiper-slide.topics.pre::before{
    content:"Pre order";
    background:#000000;
}*/

.swiper-wrapper.topics {
    height: auto;
}

.swiper-button-next.topics {
    top: 40%;
}

.swiper-button-prev.topics {
    top: 40%;
}

.slick-slide {
    height: auto;
}


.fix-popup .btn {
    width: 25px;
    height: 25px;
    line-height: 22px;
    font-size: 35px;
    border-radius: 25px;
}

@media screen and (max-width: 767px) {
    .fix-popup {
        max-width: 180px !important;
        padding-bottom: 40px;
    }

    .action-close .btn {
        top: -25px !important;
    }

    .fix-popup .btn {
        width: 30px;
        height: 30px;
        line-height: 35px;
        border-radius: 30px;
    }
}


@media screen and (min-width:768px) {
    /*________________________________________________________________________________________________________*/

}

/* info */

.info-date {
    color: #888;
    font-size: 12px;
}

.info-container {
    max-width: 1100px;
    margin: 0 auto;
}

.info-tex-box li {
    /* border-bottom: 1px solid #e7e7e7; */
    padding-bottom: 5px;
    padding-top: 5px;
}


.info-tex-box li a {
    display: flex;
}

.info-tex-box span {
    margin-right: 20px;
    white-space: nowrap
}

.important-info {
    margin-bottom: 30px;
}


.important-info p {
    color: #d42222;
}

.info-tex-box ul {
    width: 50%;
    margin: 0 auto;
}

@media screen and (max-width: 1000px) {
    .info-tex-box ul {
        width: 96%;
    }

    .info-tex-box span {
        margin-right: 10px;
    }
}