@charset "utf-8";
/*------------------------------------------------------------------------------------------
*
*
    online_shop_pc.css
*
*
------------------------------------------------------------------------------------------ */
select::-ms-expand {
  display: none;
}

select:-moz-focusring { 
  color: transparent; 
  text-shadow: 0 0 0 #828c9a;
}

.slick-dots{ display: none !important;}

.coming_soon{ margin: 100px 0 0 0; text-align: center; font-size: 20px; letter-spacing: .1em; font-weight: bold;}

/*------------------------------------------------------------------------------------------
*
*
    min-width : 641px
*
*
------------------------------------------------------------------------------------------ */
@media screen and (min-width : 641px){ 
#contents_area{
    width: 950px;
    min-width: 950px;
    margin: 0 auto;
    padding: 35px 0 100px 0;
}

#section_yodogawa{
    margin: 0 0 60px 0;
    text-align: center;
}

#section_yodogawa p{
    margin: 0 0 20px 0;
    font-size: 15px;
    letter-spacing: .06em;
    line-height: 1.968em;
}

.is_pc #section_yodogawa a:hover,
.is_sp #section_yodogawa a.touch{
    text-decoration: underline;
}

#product_list{
    width: 950px;
}

/*
*
    .shop_nav
*
*/
.shop_nav{
    margin: 0 0 45px 0;
    text-align: center;
    letter-spacing: -.40em;
}
.shop_nav li{
    margin: 0 20px;
    text-align: left;
    display: inline-block;
    font-size: 14px;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: .06em;
    position: relative;
}

.shop_nav li a{
    width: 195px;
    height: 35px;
    border-radius: 35px;
    line-height: 33px;
    box-sizing: border-box;
    background-color: #fff;
    border: 1px solid #36749a;
    color: #36749a;
    background-repeat: no-repeat;
    background-position: 15px center;
    display: block;
    position: relative;
    transition: background .1s ease .0s;
}

.is_pc .shop_nav li a:hover,
.is_sp .shop_nav li a.touch{
    opacity: 1 !important;
    background-color: rgba(208, 220, 229, 1);
    background-position: 18px center;
    transition: background .15s ease .05s;
}

.shop_nav li.store_top a{
    padding-left: 45px;
}
.shop_nav li.store_top a:before{
    content: '';
    width: 27px;
    height: 100%;
    display: block;
    background-image:url(../images/parts_ico_hobo.png);
    background-repeat: no-repeat;
    background-size: 27px;
    background-position: center;
    position: absolute;
    top: 0;
    left: 15px;
}

.shop_nav li.store_help a{
    padding-left: 40px;
}
.shop_nav li.store_help a:before{
    content: '';
    width: 17px;
    height: 100%;
    display: block;
    background-image:url(../images/parts_ico_help.png);
    background-repeat: no-repeat;
    background-size: 17px;
    background-position: center;
    position: absolute;
    top: 0;
    left: 20px;
}

.shop_nav li.nav_cart a{
    padding-left: 63px;
}
.shop_nav li.nav_cart a:before{
    content: '';
    width: 18px;
    height: 100%;
    display: block;
    background-image:url(../images/parts_ico_cart.png);
    background-repeat: no-repeat;
    background-size: 18px;
    background-position: center;
    position: absolute;
    top: 0;
    left: 42px;
}

.shop_nav li.change a{
    padding-left: 50px;
}
.shop_nav li.change a:before{
    content: '';
    width: 15px;
    height: 100%;
    display: block;
    background-image:url(../images/parts_ico_change.png);
    background-repeat: no-repeat;
    background-size: 15px;
    background-position: center;
    position: absolute;
    top: 0;
    left: 30px;
}

/* --------------------------------------------------
*
    .col_l
*
-------------------------------------------------- */
.product_wrap{
    width: 100%;
    padding: 60px 0 0 0;
    border-top: 1px solid #bdbdbd;
}

.product_wrap:last-child{
    border-bottom: 1px solid #bdbdbd;
}

.product_wrap .col_left{
    width: 400px;
    float: left;
    vertical-align: top;
}

.product_wrap .col_left .img_slider div{
    width: 400px;
    overflow: hidden;
    position: relative;
}

.product_wrap .col_left .img_slider .pic{
    border: 1px solid #fff;
    transition: border .1s ease .0s;
    cursor: pointer;
    position: relative;
}

.product_wrap .col_left .img_slider .pic:after{
    content: '';
    width: 32px;
    height: 32px;
    display: block;
    position: absolute;
    background-image:url(../images/parts_ico_zoom.png);
    background-repeat: no-repeat;
    background-size: 32px;
    background-position: center;
    bottom: 15px;
    right: 15px;
    opacity: 0;
    transform-origin: bottom;
    -webkit-transform-origin: bottom;
    transform: scale(.85);
    transition: transform .1s ease .0s, opacity .1s ease .0s;
    -webkit-transform: scale(.85);
    -webkit-transition: transform .1s ease .0s, opacity .1s ease .0s;
}

.is_pc .product_wrap .col_left .img_slider .pic:hover:after,
.is_sp .product_wrap .col_left .img_slider .pic.touch:after{
    opacity: 1;
    transform: scale(1);
    transition: transform .15s ease .05s, opacity .15s ease .05s;
    -webkit-transform: scale(1);
    -webkit-transition: transform .15s ease .05s, opacity .15s ease .05s;
}

.product_wrap .col_left .thumb{
    width: 430px;
    margin: 10px 0 0 0;
    letter-spacing: -.40em;
}

.product_wrap .col_left .thumb .pic{
    width: 59px;
    margin: 0 9px 9px 0;
    display: inline-block;
    line-height: 0;
    letter-spacing: normal;
    overflow: hidden;
    cursor: pointer;
    position: relative;
}

.product_wrap .col_left .thumb .pic:after{
    content: '';
    width: 100%;
    height: 100%;
    display: block;
    opacity: 0;
    background-color: rgba(0, 0, 0, .2);
    position: absolute;
    top: 0;
    left: 0;
    transition: opacity .1s ease .0s;
}

.is_pc .product_wrap .col_left .thumb .pic:hover:after,
.is_sp .product_wrap .col_left .thumb .pic.touch:after,
.product_wrap .col_left .thumb .pic.on:after{
    opacity: 1;
    transition: opacity .15s ease .05s;
}

.product_wrap .col_right{
    width: 510px;
    padding: 0 0 0 40px;
    float: right;
    vertical-align: top;
}

.product_wrap h2{
    margin: 0 0 30px 0;
    font-size: 26px;
    font-weight: bold;
    letter-spacing: .06em;
    line-height: 1.59615em;
}

.product_wrap .price{
    margin: 0 0 20px 0;
    letter-spacing: .1em;
}

.product_wrap .price .price{
    font-size: 22px;
}

.product_wrap .price .s{
    font-size: 14px;
}

.product_wrap select{
    width: 510px;
    height: 50px;
    font-size: 16px;
}

.product_wrap select{
    margin: 0 0 20px 0;
    padding: 0 20px;
    font-size: 16px;
    opacity: 0;
    border: 1px solid #809dc1;
    border-radius: 10px;
    background-image:url(../images/parts_ico_select_arrow.png);
    background-repeat: no-repeat;
    background-size: 17px;
    background-position: calc(100% - 20px) center;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: none;
    transition: border .1s ease .0s;
    position: relative;
    cursor: pointer;
}

.product_wrap select.disabled{
    display: none;
}

.is_pc .product_wrap select:hover,
.is_sp .product_wrap select.touch{
    border-color: #10375c;
	transition: border .15s ease .05s;
}

.product_wrap select option{
    padding: 10px !important;
    font-size: 16px !important;
    background-color: #fff !important;
}

.product_wrap .cart_list{
    margin: 0 0 30px 0;
}

.product_wrap .cart_list p{
    display: none;
}

.product_wrap .cart_list a{
    width: 510px;
    height: 50px;
    margin: 0 0 5px 0;
    display: block;
    line-height: 50px;
    text-align: center;
    color: #10375c;
    background-image:url(../images/parts_ico_cart_w.png);
    background-color: #cdd9e2;
    background-size: 19px;
    background-repeat: no-repeat;
    background-position: calc(50% - 75px) center;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: .06em;
    border: 1px solid #809dc1;
    border-radius: 10px;
    position: relative;
    transition: background .1s ease 0s, color .1s ease 0s;
}

.product_wrap .cart_list a.sold{
    color: #10375c !important;
    background-color: #bdbdbd !important;
    background-image: none !important;
    border: none !important;
    cursor: default !important;
}

.product_wrap .cart_list a.sold:after{
    opacity: 1 !important;
}

.product_wrap .cart_list .sold span{
    display: none !important;
}

.product_wrap .cart_list a:after{
    content: '';
    width: 19px;
    height: 100%;
    display: block;
    background-image:url(../images/parts_ico_cart_b.png);
    background-size: 19px;
    background-repeat: no-repeat;
    position: absolute;
    top: calc(50% - 10px);
    left: calc(50% - 84px);
    transition: opacity .1s ease .0s;
}

.is_pc .product_wrap .cart_list a:hover,
.is_sp .product_wrap .cart_list a.touch{
    color: #cdd9e2;
    background-color: #367497;
    transition: background .15s ease .05s, color .15s ease .05s;
}

.is_pc .product_wrap .cart_list a:hover:after,
.is_sp .product_wrap .cart_list a.touch:after{
    opacity: 0;
    transition: opacity .15s ease .05s;
}

.product_wrap .cart_list .price{
    display: none;
}

.product_wrap .cart_list .stock,
.product_wrap .cart_list .shipment{
    display: block;
    text-align:center;
    font-size: 13px;
    letter-spacing: .06em;
    line-height: 1.5em;
    color: #ff3e4b;
}

.product_wrap .product_desc{
    margin: 0 0 50px 0;
    font-size: 15px;
    letter-spacing: .05em;
    line-height: 1.95em;
}

.product_wrap .related_post{
    margin: 0 0 25px 0;
    clear: both;
}

.product_wrap .product_desc p{
    margin: 0 0 25px 0;
}

.product_wrap .product_desc a{
    padding: 0 0 3px 0;
    border-bottom: 1px solid #e18dc4;
    transition: border .1s ease .0s;
}

.is_pc .product_wrap .product_desc a:hover,
.is_sp .product_wrap .product_desc a.touch{
    border-bottom: 1px solid transparent;
    transition: border .15s ease .05s;
}

.product_wrap .related_post h3{
    margin: 0 0 20px 0;
    font-size: 15px;
    font-weight: bold;
    letter-spacing: .12em;
}

.product_wrap .related_post ul{
    margin: 0 0 40px 0;
    letter-spacing: -.40em;
}

.product_wrap .related_post li{
    margin: 0 0 12px 0;
    overflow: hidden;
    display: block;
    vertical-align: top;
    letter-spacing: normal;
    position: relative;
}

.product_wrap .related_post li a{
    padding: 0 5px 0 50px;
    height: 29px;
    border-radius: 29px;
    line-height: 29px;
    color: #36749a;
    opacity: .7;
    font-size: 14px;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: .06em;
    background-image:url(../images/parts_ico_dot_arrow_b.png);
    background-repeat: no-repeat;
    background-size: 29px;
    background-position: 15px center;
    display: inline-block;
    position: relative;
    left: -10px;
    transition: background .1s ease .0s, opacity .1s ease .0s;
}

.is_pc .product_wrap .related_post li a:hover,
.is_sp .product_wrap .related_post li a.touch{
    color: #36749a;
    opacity: 1 !important;
    background-position: 18px center;
    transition: background .15s ease .05s, opacity .15s ease .05s;
}

.product_wrap .product_info{
    width: 100%;
    padding: 30px 15px 25px 15px;
    border-top: 1px dashed #bdbdbd;
    box-sizing: border-box;
    display: table;
    clear: both;
}

.product_wrap .product_info .col_l{
    width: 50%;
    display: table-cell;
}

.product_wrap .product_info .col_r{
    width: 50%;
    padding: 0 0 0 30px;
    display: table-cell;
}

.product_wrap .product_info h4{
    margin: 0 0 40px 0;
    font-size: 18px;
    font-weight: bold;
    letter-spacing: .1em;
    color: #367497;
}

.product_wrap .product_info h4:before{
    content: '●';
    color: #cdd9e2;
}

.product_wrap .product_info h5{
    margin: 0 0 5px 0;
    font-size: 16px;
    letter-spacing: .1em;
    line-height: 1.6em;
    color: #367497;
}

.product_wrap .product_info li{
    margin: 0 0 25px 0;
}

.product_wrap .product_info li:last-child{
    margin: 0;
}

.product_wrap .product_info p{
    font-size: 13px;
    letter-spacing: .05em;
    line-height: 1.7em;
}


/* --------------------------------------------------
*
    #modal
*
-------------------------------------------------- */
#modal{
    width: 100%;
    min-width: 950px;
    text-align: center;
    height: 100%;
    visibility: hidden;
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 65535;
}

#modal.off{
    opacity: 0;
    transition: opacity .3s ease;
}

#modal_inner{
    width: auto;
    max-width: auto;
    height: 90%;
    min-height: 480px;
    margin: 0 auto;
    display: inline-block;
    text-align: center;
    padding: 20px 20px 60px 20px;
    line-height: 0;
    background-color: #fff;
    box-sizing: border-box;
    opacity: 0;
    -ms-filter: "alpha(opacity=0)";
    text-align: left;
    position: relative;
    top: 0;
    z-index: 2;
}

#modal_data{
    min-width: 380px;
    height: 100%;
    display: inline-block;
    line-height: 0;
    transition: height .3s ease !important;
}

#modal_data img{
    width: auto;
    height: 100%;
    line-height: 0;
    transform: translate3d(0, 0, 0);
}

#modal .overlay{
    width: 100%;
    height: 100%;
    background-color: #000;
    opacity: .5;
    -ms-filter: "alpha(opacity=50)";
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1;
    cursor: pointer;
}

#modal_data{
    text-align: center;
}

.modal_loader{
    width: 100%;
    height: 100%;
    display: none;
    opacity: 0;
    min-height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 65535;
}

.modal_loader span{
    width: 64px;
    height: 64px;
    display: block;
    background-image:url(../images/img_loader.gif);
    background-repeat: no-repeat;
    background-size: 64px;
    position: absolute;
    top: calc(50% - 32px);
    left: calc(50% - 32px);
}

.btn_nav .disabled{
    visibility: hidden;
}

.btn_close{
    width: 120px;
    display: inline-block;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: .06em;
    position: absolute;
    bottom: 15px;
    left: calc(50% - 60px);
}

.btn_close a{
    padding: 0 15px;
    height: 29px;
    border-radius: 29px;
    line-height: 29px;
    background-color: #fff;
    border: 1px solid #36749a;
    color: #36749a;
    background-repeat: no-repeat;
    background-size: 29px;
    background-position: 15px center;
    display: block;
    position: relative;
    transition: background .1s ease .0s;
}

.is_pc .btn_close a:hover,
.is_sp .btn_close a.touch{
    opacity: 1 !important;
    background-color: rgba(208, 220, 229, 1);
    background-position: 12px center;
    transition: background .15s ease .05s;
}

.nav_prev{
    display: inline-block;
    font-size: 16px;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: .06em;
    position: absolute;
    bottom: 15px;
    left: calc(50% - 185px);
}

.nav_prev a{
    padding: 0 15px 0 50px;
    height: 29px;
    border-radius: 29px;
    line-height: 29px;
    background-color: #fff;
    border: 1px solid #36749a;
    color: #36749a;
    background-image:url(../images/parts_ico_dot_arrow_l.png);
    background-repeat: no-repeat;
    background-size: 29px;
    background-position: 15px center;
    display: block;
    position: relative;
    transition: background .1s ease .0s;
}

.is_pc .nav_prev a:hover,
.is_sp .nav_prev a.touch{
    opacity: 1 !important;
    background-color: rgba(208, 220, 229, 1);
    background-position: 12px center;
    transition: background .15s ease .05s;
}

.nav_next{
    display: inline-block;
    font-size: 16px;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: .06em;
    position: absolute;
    bottom: 15px;
    right: calc(50% - 185px);
}

.nav_next a{
    padding: 0 50px 0 15px;
    height: 29px;
    border-radius: 29px;
    line-height: 29px;
    background-color: #fff;
    border: 1px solid #36749a;
    color: #36749a;
    background-image:url(../images/parts_ico_dot_arrow.png);
    background-repeat: no-repeat;
    background-size: 29px;
    background-position: calc(100% - 15px) center;
    display: block;
    position: relative;
    transition: background .1s ease .0s;
}

.is_pc .nav_next a:hover,
.is_sp .nav_next a.touch{
    opacity: 1 !important;
    background-color: rgba(208, 220, 229, 1);
    background-position: calc(100% - 12px) center;
    transition: background .15s ease .05s;
}


} /* ----- min-width : 641px ----- */
