@charset "utf-8";

/* ==================================================================
    item.css

=================================================================== */

.contents .float_message{
    display: none;
    position: fixed;
    z-index: 10;
    background: #000;
    padding: 10px;
    border-radius: 8px;
    color: #fff;
    font-size: 84%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.contents main > section h2.title {
    margin-bottom: 40px;
}

.contents main > section h2.title span {
    margin-top: 20px;
}

.chapter.wide .container.border{
    border-bottom: 2px solid #ccc;
    padding-bottom: 60px;
}

.itemList .slick-list li{
    margin: 0 10px;
}

.itemBox{    
    width: 710px;
    float: left;
    margin-right: 84px;
}

.itemBox ul.itemslider li a{
    position: relative;
    display: block;
}

.itemBox ul.itemslider li a:before{
    content: "";
    position: absolute;
    background: url("../../images/common/icon/zoom.svg") no-repeat;
    right: 15px;
    bottom: 15px;
    width: 60px;
    height: 60px;
    cursor: pointer;
}

.itemBox .itemslider li img{
    width: 100%;
    height: 100%;
}

.explain{
    width: 30%;
}

.custom-thumb {
    margin-top: 26px;
    display: flex;
    flex-wrap: wrap;
}

.custom-thumb a{
    margin-bottom: 26px;
    box-sizing: border-box;
    width: calc(100% / 7);
    text-align: center;
}

.custom-thumb a{
    margin-bottom: 26px;
    box-sizing: border-box;
    width: calc(100% / 7);
    text-align: center;
}

.custom-thumb a img{
    border: 1px solid #f4f4f4;
    box-sizing: border-box;
}
.custom-thumb a.active img{
    border: 1px solid #c0c0c0;
}

.design{
    margin: 40px 0;
}

.design dt{
    margin-bottom: 8px;
    font-size: 90%;
}
.design dd p{
    text-align: center;
}

.rightarea{    
    width: 386px;
    float: right;
    padding-top: 40px;
}

.itemList p.image{
    position: relative;
}

.itemList .online{
    background: url("../../images/common/icon/online.svg") no-repeat;
    padding-left: 23px;
    font-size: 62%;
    margin-bottom: 15px;
}

.itemList .event{
    background: url("../../images/common/icon/event.svg") no-repeat;
    padding-left: 23px;
    font-size: 62%;
}

.itemList .image{
    position: relative;
}

.itemList p.type{
    position: relative;
    font-weight: 700;
    margin-bottom: 4px;
    font-size: 80%;
}

   .itemList p.type.new,
    .itemList p.type.reserve,
    .itemList p.type.soldout{
        padding-left: 68px;
    }

    .itemList p.type:before{
        content:"";
        position: absolute;
        left: 0;
        top: -4px;
        z-index: 2;
    }

   .itemList p.type.new:before{
        background: url("../../images/common/icon/new.svg") no-repeat;
        width: 46px;
        height: 28px;

    }
    .itemList p.type.reserve:before{
        background: url("../../images/common/icon/reserve.svg") no-repeat;
        width: 62px;
        height: 28px;
    }

    .itemList p.type.soldout:before{
        background: url("../../images/common/icon/soldout.svg") no-repeat;
        width: 62px;
        height: 28px;
    }

.itemList p.name{
    font-weight: 700;
    font-size: 150%;
    line-height: 1.8;
    margin-bottom: 12px;
    text-align: left;
}

.itemList p.number{
    font-size: 75%;
    color: #8D8D8D;
    margin-bottom: 20px;
    letter-spacing: 0.05em;
}

.itemList p.price{
    font-size: 112%;
    font-weight: 700;
}

.itemList .view{
    position: relative;
    font-size: 62%;
    margin-bottom: 35px;
}

.itemList .view:before{
    content: "★★★★★ 1review";
    color: #808080;
}

.rightarea .spinner_area input[type] {
    line-height: 3;
    font-size: 100%;
}

.rightarea table{
    margin-bottom: 40px;
    width: 100%;
}

.rightarea table th,
.rightarea table td{
    padding: 12px 0;
}

.rightarea table th{
    font-size: 81%;
    width: 5em;
}

.rightarea table td{
    font-size: 81%;
}

.rightarea table td span.price{
    font-size: 191%;
    font-weight: 700;
    letter-spacing: 0.05em;
}

.rightarea table td span.number{
    font-size: 150%;
    font-weight: 700;
}

.rightarea table td span.nomal{
    font-size: 83%;
}

.rightarea table tr.stock th,
.rightarea table tr.stock td{
    padding-top: 0;
}

.rightarea .loginText{
    font-size: 1.4rem;
    text-align: center;
}
.rightarea .loginText a{
    text-decoration: underline;
}

.rightarea .spinner_area{
    width: 60%;
}

.contents .buttonStyle button, 
.contents .buttonStyle a {
    width: 310px;
    font-size: 87%;
    position: relative;
    padding: 15px 40px;
}

.contents .buttonStyle.cart.pink a,
.contents .buttonStyle.cart.pink button{
    position: relative;
    background: #DC666A;
    border: 1px solid #DC666A;
    font-weight: bold;
    font-size: 100%;
}
.contents .buttonStyle.cart.pink a span:before{
    content: none;
}

.contents .buttonStyle.favorite a{
    background: #fff;
    color: #808080;
    border: 1px solid #808080;
}

.contents .buttonStyle.cart a:hover,
.contents .buttonStyle.cart button:hover,
.contents .buttonStyle.favorite a:hover{
    opacity: 0.7;
}

.contents .buttonStyle.favorite a span i{
    margin-right: 4px;
}
.contents .buttonStyle.favorite a.active{
    border: 1px solid #FC5AA5;
    color: #FC5AA5;
}
.contents .buttonStyle.favorite a.active span i{
    animation-name: anime_heart;
    animation-duration: 1.5s;
    color: #FC5AA5;
}
@keyframes anime_heart{
  0% {transform: rotateY(0deg);}
  100% {transform: rotateY(360deg);}
}


.tabInterface{
    margin-top: 75px;
    border-bottom: 2px solid #ccc;
}

.tabInterface ul.tab{
    width: 100%;
    overflow: hidden;
}

.tabInterface ul.tab li{
    float: left;
    width: 50%;
    text-align: center;
    margin: auto;
}

.tabInterface ul.tab li a{
    padding: 10px 0;
    display: block;
    color: #251F1C;
    text-decoration: none;
    border-bottom: 2px solid #C0C0C0;
    font-size: 81%;
    font-weight: bold;
}

.tabInterface ul.tab li.active a{
    border-bottom: 2px solid #251F1C;
}

.tabInterface .Interface{
    padding: 35px;
}

.tabInterface .Interface .tab{
}

.tabInterface .Interface .tab p.text{
    line-height: 2.5;
    font-size: 75%;
    font-weight: bold; 
    color: #4D4D4D;
}
.tabInterface .Interface .tab p.text a{
    text-decoration: underline;
    color: #e92b90;
}
.tabInterface .Interface .tab p.text a:hover{
    color: #c93081;
}


.tabInterface .Interface .tab table.tableStyle{
    margin-bottom: 0;
}

.tabInterface .Interface .tab table.tableStyle th,
.tabInterface .Interface .tab table.tableStyle td{
    padding: 15px;
    border: none;
    border-bottom: 1px solid #ccc;
}

.tabInterface .Interface .tab table.tableStyle th{
    font-size: 75%;
    width: 5em;
    background: #E4E4E4;
}

.tabInterface .Interface .tab table.tableStyle td{
    font-size: 75%;
}

.flexcart{
    display: flex;
    align-items: center;
}

.flexcart .buttonStyle.cart{
    margin-bottom: 0;
    margin-left: 15px;
}

.flexcart .buttonStyle.cart a,
.flexcart .buttonStyle.cart button{
    width: auto;
}

/* --------------------------------
   □ itemOutline
-------------------------------- */

#itemOutline{
    padding-bottom: 120px;
}

/* --------------------------------
   □ variation
-------------------------------- */

#variation{
    padding-bottom: calc(120px + 50px);
}

#variation .slick-dotted.slick-slider {
    margin-bottom: 120px;
}

#variation .itemList .slick-list li{
    margin-bottom: 20px;
}

/* --------------------------------
   □ showWindow
-------------------------------- */

#showWindow{
    background: #f4f4f4;
    padding: 120px 0;
}

#showWindow .show{
    display: flex;
    align-items: center;
    margin-bottom: 35px;
}

#showWindow .show p.image{
    width: 50%;
    padding-right: 30px;
    box-sizing: border-box;
}

#showWindow .show dl {
    width: 50%;
    padding-left: 30px;
    font-size: 87%;
    box-sizing: border-box;
}

#showWindow .show dl dt{
    font-size: 121%;
    font-weight: 700;
    margin-bottom: 15px;
    line-height: 2;
}

#showWindow .show dl dd{
    line-height: 2;
}

#showWindow .movie p.image{
    margin-bottom: 65px;
}

#showWindow .movie .flex{
    display: flex;
    justify-content: flex-start;
}

#showWindow .movie .buttonStyle{
    margin-right: 125px;  
}

    #showWindow .movie .buttonStyle:nth-of-type(3n){
        margin-right: 0;  
    }

#showWindow .movie .buttonStyle a{
    padding: 15px 30px;    
}

#showWindow .free {
    margin-top: 80px;
}

/* --------------------------------
   □ special
-------------------------------- */

#special ul.bnr{ 
}

#special ul.bnr li {
    width: 48%;
    float: left;
}

#special ul.bnr li:first-child{
    margin-right: 4%;
}

/* --------------------------------
   □ keyword
-------------------------------- */ 
#keyword{
  margin-top: 30px;
    margin-bottom: 80px;
}
#keyword p.title{
    font-size: 114%;
    font-weight: 700;
    position: relative;
    margin-bottom: -13px;
}

#keyword p.title:before{
    content:"";
    display:block;
    width : -webkit-calc(100% - 140px) ;
    width : calc(100% - 140px) ;
    height:1px;
    background-color:#BFBFBF;
    position:absolute;
    top:0;
    left: 140px;
    bottom: 0;
    margin: auto;
}

#keyword ul.category{
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    padding: 30px 0 18px;
    border-bottom: 1px solid #BFBFBF;
}

#keyword ul.category li{
    margin-right: 16px;
    margin-bottom: 12px;
}

#keyword ul.category li a{
    display: block;
    padding: 6px 15px;
    border: 1px solid #666;
    border-radius: 30px;
    color: #666;
    text-decoration: none;
    transition: all 300ms 0s ease;
    font-size: 81%;
}

#keyword ul.category li a:hover{
    background: #666;
    color: #fff;
}

/* --------------------------------
   □ review
-------------------------------- */ 

#review .container{
    position: relative;
}

#review .reviewtitle{
    position: relative;
}

#review .reviewtitle:before{
    content: "";
    position: absolute;
    right: 5px;
    bottom: 25px;
    margin: auto;
    width: 10px;
    height: 10px;
    border-top: 1px solid #000;
    border-left: 1px solid #000;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    transition: all 300ms 0s ease;
}

#review .reviewtitle.open:before{
    transform: rotate(225deg);
}

#review .view{
    margin-bottom: 50px;
}

#review .view span{
    font-size: 81%;
}

#review .buttonStyle{
    position: absolute;
    right: 50px;
    top: 70px;
}

#review .reviewArea{
    background: #F8F5F3;
    padding: 50px;
    overflow: hidden;
}

#review .reviewArea ul.reviewList{
    overflow: hidden;
    margin-bottom: 20px;
}

#review .reviewArea ul.reviewList li{
    background: #fff;
    padding: 35px 20px;
    box-sizing: border-box;
    width: 48%;
    float: left;
    margin-right: 4%;
}

#review .reviewArea ul.reviewList li:last-child{
    margin-right: 0;
    float: right;
}

#review .reviewArea ul.reviewList li .title{
    font-weight: bold;
}

#review .reviewArea ul.reviewList li .star,
#review .reviewArea ul.reviewList li .text{
    font-size: 81%;
    line-height: 2;
}

#review .reviewArea ul.reviewList li .date{
    font-size: 62.5%;
}

.closeArea{
    clear: both;
}

.closeArea .close_box {
    text-align: right;
    font-size: 75%;
    font-weight: bold;
}

/* --------------------------------
   □ gallery
-------------------------------- */ 

#gallery{
    padding-bottom: calc(120px + 50px);
}

#gallery .galleryList .slick-list li{
    margin: 0 12px;
}

/* --------------------------------
   □ series
-------------------------------- */ 

#series{
    background: #F4F4F4;
}

.seriesList{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;    
}

.itemList li{
    width: calc(25% - 40px);
    margin-bottom: 50px;
}

.itemList li a{
    text-decoration: none;
}

.itemList li img{
    width: 100%;
}

#series .buttonStyle a{
    width: 175px;  
}

/* --------------------------------
   □ recently
-------------------------------- */ 

#recently{
    padding-bottom: 0;   
}

#recently .container{  
    padding-bottom: calc(120px + 50px);  
    border-bottom: 2px solid #ccc;
}

#recently .itemList .slick-list li {
    margin-bottom: 0;
}

/* --------------------------------
   □ campaign
-------------------------------- */ 

ul.campaignList .slick-list li{
    margin: 0 10px;
}

body.point .itemList table td.point{
    font-size: 112%;
    font-weight: 700;
}

body.point .itemList button{
    background: #878075;
    padding: 20px 40px;
}

body.point main{
    padding-bottom: 80px;
}

/* タブレット用
-------------------------------------------- 
@media screen and (min-width: 768px)  {


.itemBox {
    margin-right: 20px;
}

.custom-thumb a {
    margin-right: 6px;
}

.rightarea {
    width: 43%;
}

.rightarea table th {
    width: 4em;
}

}

*/


/* iframe
-------------------------------- */ 

.contents iframe{
  width: 100%;
  height: 664px;
  max-width: 100%;
}


@media only screen and
(max-width : 767px) {

.contents iframe{
  width: 100%;
  height: calc(100vw * 0.5625);
  max-width: 100%;
}


    .contents main > section {
        padding: 60px 0;
    }

    .contents main > section h2.title {
        margin-bottom: 10%;
    }

    .contents main > section h2.title span {
        margin-top: 8px;
    }

    .contents .buttonStyle button, 
    .contents .buttonStyle a {
        width: 100%;
    }

    .custom-thumb {
        /*display: none;*/
    }

    .custom-thumb a {
        margin-bottom: 8px;
        width: calc(100% / 5);
    }

    .design{
        margin: 20px 0;
    }

    .design.half dd p img {
        width: 60%;
    }

    .itemBox {
        width: 100%;
        float: none;
        margin-right: 0;
    }
    .itemBox ul.itemslider li a {
        text-align: center;
    }

    .rightarea {
        width: 100%;
        float: none;
        padding-top: 28px;
    }

    .rightarea table th,
    .rightarea table td {
        padding: 10px 0;
    }

    .itemList .view {
        margin-bottom: 20px;
    }

    .itemList p.name {
        font-size: 130%;
    }

    .tabInterface .Interface .tab table.tableStyle th,
    .tabInterface .Interface .tab table.tableStyle td {
        font-size: 87%;
    }
    .tabInterface .Interface .tab table.tableStyle th {
        width: 35%;
    }

    .tabInterface .Interface .tab p.text {
        font-size: 87%;
        line-height: 2;
    }

    .tabInterface .Interface {
        padding: 25px 0;
    }

    .tabInterface ul.tab li a {
        font-size: 94%;
    }

    .chapter.wide .container.border {
        border-bottom: none;
        padding-bottom: 0;
    }

    .contents .buttonStyle.cart.pink a{
        padding: 14px 0;
    }

    .rightarea table {
        margin-bottom: 28px;
    }

    /* --------------------------------
    □ itemOutline
    -------------------------------- */

    #itemOutline{
        padding-bottom: 40px;
    }

    /* --------------------------------
    □ variation
    -------------------------------- */

    #variation{
        padding-bottom: 60px;
    }	

    #variation .slick-dotted.slick-slider {
        margin-bottom: 70px;
    }

    /* --------------------------------
    □ showWindow
    -------------------------------- */

    #showWindow{
        padding: 60px 0;
    }

    #showWindow .show {
        display: block;
    }

    #showWindow .show p.image {
        width: auto;
        padding-right: 0;
    }

    #showWindow .show dl {
        width: auto;
        padding-left: 0;
    }

    #showWindow .movie .flex {
        display: block;
    }

    #showWindow .movie .buttonStyle {
        margin-right: 0;
        margin-bottom: 15px;
    }

    #showWindow .movie .buttonStyle a {
        padding: 15px 20px;
    }

    #showWindow .movie ul.btnlist {
        width: auto;
    }

    /* --------------------------------
    □ special
    -------------------------------- */

    #special ul.bnr li {
        width: auto;
        float: none;
    }

    #special ul.bnr li:first-child {
        margin-right: 0;
        margin-bottom: 30px;
    }

    /* --------------------------------
    □ keyword
    -------------------------------- */ 

    #keyword {
        margin: 0 -4% 60px;
    }

    #keyword ul.category {
        flex-wrap: wrap;
        padding: 30px 0 18px;
        justify-content: start;
    }

    #keyword ul.category li {
        margin: 0 9px 12px 0;
    }

    #keyword ul.category li a {
        font-size: 68%;
    }

    /* --------------------------------
    □ review
    -------------------------------- */ 

    #review .view {
        margin-bottom: 30px;
    }
    #review .reviewtitle:before {
        bottom: 90px;
    }

    #review .buttonStyle {
        position: relative;
        right: inherit;
        top: inherit;
        margin-bottom: 30px;
        width: auto;
    }

    #review .reviewArea {
        padding: 40px 20px;
    }
    #review .reviewArea ul.reviewList li {
        width: auto;
        float: none;
        margin-right: 0;
    }

    #review .reviewArea ul.reviewList li:last-child {
        margin-right: 0;
        float: none;
        margin-top: 30px;
    }

    /* --------------------------------
    □ gallery
    -------------------------------- */ 

    #gallery{
        padding-bottom: calc(60px + 50px);
    }	

    /* --------------------------------
    □ series
    -------------------------------- */ 

    .seriesList {
        display: flex;
    }
    .seriesList li {
        width: calc(50% - 10px);
        margin: 0;
        margin-bottom: 20px;
    }

    .flexcart .buttonStyle.cart {
        margin: 0 0 0 15px;
    }

    .flexcart .buttonStyle.cart a,
    .flexcart .buttonStyle.cart button{
        padding: 10px 25px;
    }

    /* --------------------------------
    □ recently
    -------------------------------- */ 

    #recently .container {
        padding-bottom: calc(60px + 50px);
    }	

    /* --------------------------------
    □ campaign
    -------------------------------- */ 

    #campaign {
        padding-bottom: calc(60px + 50px);
    }	

}