@charset "utf-8";

.BLK10000 {
    position: fixed;
    width: 100%;
    z-index: 99
}

.BLK10000 h1,
.BLK10000 p,
.BLK10000 a {
    display: block;
    color: #fff;
    font-weight: 400;
    box-sizing: border-box
}

.BLK10000 div.frame {
    width: 100%
}

.BLK10000 div.frame div.section {
    margin: 0 auto;
    width: calc(100% - 4rem)
}

.BLK10000 div.frame.h-top {
    padding: .1rem .5rem;
    width: 100%;
    height: 1.9rem;
    background-color: #fff
}

.BLK10000 div.frame.h-top a {
    display: inline-block;
    margin-left: .2rem
}

.BLK10000 div.frame.h-navi {
    width: 100%;
    height: 2rem;
    line-height: 2rem;
    background-color: #333
}

.BLK10000 div.frame.h-navi div.section h1,
.BLK10000 div.frame.h-navi div.section p {
    float: left
}

.BLK10000 div.frame.h-navi div.section a {
    float: right;
    margin: .3rem 0 0 .5rem
}

@media screen and (min-width:0px) and (max-width:960px) {
    .BLK10000 div.frame.h-navi {
        display: none
    }

    .BLK10000 div.frame div.section {
        width: calc(100% - 2rem)
    }
}

.BLK10000 div.frame.h-body {
    position: relative;
    background-color: #e60014;
    height: 80px;
}

.h_block.block_type2 .BLK10004 {
    margin-top: 157px;
}

@media screen and (min-width:768px) and (max-width:960px) {
    .h_block.block_type2 .BLK10004 {
        margin-top: 152px;
    }
}

@media screen and (max-width:768px) {
    .BLK10000 div.frame.h-body {
        height: 55px
    }

    .h_block.block_type2 .BLK10004 {
        margin-top: 123px;
    }
}

.BLK10000 div.frame.h-body div.section .header_logo_part {
    margin: 0 auto;
}

.BLK10000 div.frame.h-body div.section .header_logo_part {
    width: 22rem
}

@media screen and (min-width:481px) and (max-width:768px) {
    .h_block.block_type2 .BLK10004 {
        margin-top: 128px;
    }
}

@media screen and (min-width:481px) and (max-width:960px) {
    .BLK10000 div.frame.h-body div.section .header_logo_part {
        width: 22rem
    }
}

@media screen and (min-width:0px) and (max-width:480px) {
    .BLK10000 div.frame.h-body div.section .header_logo_part {
        width: 18rem
    }
}

@media screen and (min-width:0px) and (max-width:360px) {
    .BLK10000 div.frame.h-body div.section .header_logo_part {
        width: 18rem
    }
}

@media screen and (max-width:768px) {
    .BLK10000 div.frame.h-body div.section .header_logo_part a {
        margin-top: -5px;
    }

    .BLK10000 div.frame.h-body div.section .header_logo_part img {
        max-width: 80%;
        margin: 0 auto;
    }
}

div.frame.remodal {
    padding: 2rem;
    width: 100%;
    text-align: left;
    background-color: #f0f0f0
}

div.frame.remodal h2 {
    font-size: 1rem;
    font-weight: 700
}

div.frame.remodal div.section {
    padding: 2rem;
    width: 100%;
    background-color: #fff
}

div.frame.remodal div.section>div,
div.frame.remodal div.section>div ul,
div.frame.remodal div.section>div li,
div.frame.remodal div.section>div a {
    display: block;
    width: 100%
}

div.frame.remodal div.section>div {
    margin-bottom: 2rem
}

div.frame.remodal div.section>div h2 {
    margin-bottom: 1rem
}

div.frame.remodal div.section>div:nth-of-type(1) li {
    background-color: #f7f7f7;
    border-bottom: 1px solid #ddd
}

div.frame.remodal div.section>div:nth-of-type(1) li a {
    position: relative;
    padding: 0 1rem;
    height: 3.6rem;
    line-height: 3.6rem;
    font-weight: 700
}

div.frame.remodal div.section>div:nth-of-type(1) li a:hover {
    color: red
}

div.frame.remodal div.section>div:nth-of-type(1) li a:before {
    position: absolute;
    top: calc(50% - 1rem);
    right: 1rem;
    width: 2rem;
    height: 2rem;
    content: '';
    background: #ddd;
    border-radius: 50%
}

div.frame.remodal div.section>div:nth-of-type(1) a:after {
    position: absolute;
    top: calc(50% - 0.5rem);
    right: 1.5rem;
    width: 0;
    height: 0;
    content: '';
    border-style: solid;
    border-width: .6rem 0 .6rem .8rem;
    border-color: transparent transparent transparent #fff
}

div.frame.remodal div.section>div:nth-of-type(1) li a:hover:before {
    background: red
}

div.frame.remodal div.section>div:nth-of-type(2) li {
    background-color: red;
    border-bottom: 1px solid #ddd
}

div.frame.remodal div.section>div:nth-of-type(2) li a {
    position: relative;
    padding: 0 1rem;
    height: 3.6rem;
    color: #fff;
    line-height: 3.6rem;
    font-weight: 700
}

div.frame.remodal div.section>div:nth-of-type(2) li a:hover {
    opacity: .7
}

div.frame.remodal div.section>div:nth-of-type(2) li img {
    width: 2.2rem;
    vertical-align: middle
}

div.frame.remodal div.section>div:nth-of-type(2) li span {
    display: inline-block;
    margin-left: 1rem;
    height: 100%
}

div.frame.remodal div.section>div:nth-of-type(2) li:first-of-type {
    position: relative
}

div.frame.remodal div.section>div:nth-of-type(2) li:first-of-type div.cart_count {
    position: absolute;
    top: 1rem;
    left: 8rem;
    padding-top: .1rem;
    padding-left: .4rem;
    width: 25px;
    height: 25px;
    font-size: .9rem;
    color: #fff;
    background-color: #000;
    border-radius: 50%
}

div.frame.remodal div.section>div:nth-of-type(3) {
    text-align: center
}

.BLK10000 div.frame.h-body div.section:nth-of-type(2),
.BLK10000 div.frame.h-body div.section:nth-of-type(3) {
    position: absolute;
    display: none;
    width: 100%;
    height: 100vh;
    background: rgba(0, 0, 0, .6)
}

.BLK10000 div.frame.h-body div.section:nth-of-type(2)>div,
.BLK10000 div.frame.h-body div.section:nth-of-type(3)>div {
    margin: 0 auto;
    padding: 2rem;
    width: calc(100% - 30rem);
    max-height: calc(100vh - 14rem);
    overflow-y: scroll;
    background-color: #fff
}

.BLK10000 div.frame.h-body div.section:nth-of-type(2)>div h2,
.BLK10000 div.frame.h-body div.section:nth-of-type(3)>div h2 {
    margin-bottom: 2rem;
    font-size: 1.4rem
}

.BLK10000 div.frame.h-body div.section:nth-of-type(2)>div p,
.BLK10000 div.frame.h-body div.section:nth-of-type(3)>div p {
    color: #333
}

.BLK10000 div.frame.h-body div.section:nth-of-type(2)>div ul,
.BLK10000 div.frame.h-body div.section:nth-of-type(3)>div ul {
    margin: 0 auto;
    width: 100%
}

.BLK10000 div.frame.h-body div.section:nth-of-type(2)>div li,
.BLK10000 div.frame.h-body div.section:nth-of-type(3)>div li {
    float: left;
    width: 25%;
    border-bottom: .2rem solid transparent;
    border-left: .2rem solid transparent;
    border-right: .2rem solid transparent
}

.BLK10000 div.frame.h-body div.section:nth-of-type(2)>div a,
.BLK10000 div.frame.h-body div.section:nth-of-type(3)>div a,
.BLK10000 div.frame.h-body div.section:nth-of-type(2)>div a img,
.BLK10000 div.frame.h-body div.section:nth-of-type(3)>div a img {
    width: 100%
}

@media screen and (min-width:1025px) and (max-width:1280px) {

    .BLK10000 div.frame.h-body div.section:nth-of-type(2)>div,
    .BLK10000 div.frame.h-body div.section:nth-of-type(3)>div {
        width: calc(100% - 20rem)
    }

    .BLK10000 div.frame.h-body div.section:nth-of-type(2)>div li,
    .BLK10000 div.frame.h-body div.section:nth-of-type(3)>div li {
        width: 33%
    }
}

@media screen and (min-width:481px) and (max-width:1024px) {

    .BLK10000 div.frame.h-body div.section:nth-of-type(2)>div,
    .BLK10000 div.frame.h-body div.section:nth-of-type(3)>div {
        width: calc(100% - 8rem)
    }

    .BLK10000 div.frame.h-body div.section:nth-of-type(2)>div li,
    .BLK10000 div.frame.h-body div.section:nth-of-type(3)>div li {
        width: 50%
    }
}

@media screen and (min-width:0px) and (max-width:480px) {

    .BLK10000 div.frame.h-body div.section:nth-of-type(2)>div,
    .BLK10000 div.frame.h-body div.section:nth-of-type(3)>div {
        width: calc(100% - 2rem)
    }

    .BLK10000 div.frame.h-body div.section:nth-of-type(2)>div li,
    .BLK10000 div.frame.h-body div.section:nth-of-type(3)>div li {
        width: 50%
    }
}

.BLK10000 div.frame.h-menu {
    background-color: #f7f7f7;
    border-bottom: .2rem solid #ccc
}

.BLK10000 div.frame.h-menu div.section ul {
    margin: .8rem 0 .5rem
}

.BLK10000 div.frame.h-menu div.section li {
    float: left;
    height: 4.5rem;
    width: 4.6rem;
    text-align: center;
    border-right: .2rem solid #fff
}

.BLK10000 div.frame.h-menu div.section img {
    width: 2rem;
    margin: 0 auto;
}

.BLK10000 div.frame.h-menu div.section img:hover {
    opacity: .7
}

.BLK10000 div.frame.h-menu div.section p {
    height: .8rem;
    color: #668;
    line-height: .8rem;
    font-size: .8rem;
    padding-top: 5px;
}

@media screen and (min-width:0px) and (max-width:960px) {
    .BLK10000 div.frame.h-navi {
        display: none
    }
}

@media screen and (min-width:0px) and (max-width:359px) {
    .BLK10000 div.frame.h-menu div.section li {
        width: 4.1rem
    }

    .BLK10000 div.frame.h-menu div.section p {
        font-size: .7rem
    }
}