@charset "utf-8";

/* --------------------------------
    common
-------------------------------- */

.d-db{
    display: block;
}
.d-mx{
    margin-left: auto;
    margin-right: auto;
}
.img-size{
    width: 100%;
    height: auto;
}
.img-mx{
    max-width: 1600px;
    margin-left: auto;
    margin-right: auto;
}
.ta-l{
    text-align: left;
}
.ta-c{
    text-align: center;
}
.td-u{
    text-decoration: underline;
}
.d-bl{
    display: block !important;
}
.d-ib{
    display: inline-block !important;
}
.d-i{
    display: inline !important;
}
.td-u{
    text-decoration: underline;
}
.btn.btn-type01{
    display: block;
    margin: 0 auto;
    padding: 20px 0;
    width: 100%;
    max-width: 320px;
    background-color: #f4f4f6;
}
.btn.btn-type01 img{
    max-width: 80px;
    margin: 0 auto;
}
#header #cart.cart{
    top:75px !important;
    left:-5px !important;
}

#header #cart p.errormsg.bg-danger{
    float: none;
}

/* --------------------------------
    header 上書き
-------------------------------- */
#header{
    z-index: 1003;
}

/* --------------------------------
    【共通】グローバルメニュー
-------------------------------- */
#gn_tgl{
    position: absolute;
    left:15px;
    top:25px;
    z-index: 1004;
}
.hamburger{
    padding:5px !important;
}
.hamburger-box {
    width: 25px !important;
    height: 24px !important;

}
.hamburger-inner,
.hamburger-inner::before,
.hamburger-inner::after{
    width: 25px !important;
    height: 2px !important;
}
.hamburger-inner::before{
    top:8px !important;
}
.hamburger-inner::after{
    bottom:8px !important;
}
#global_menu{
    position: relative;
    z-index: 1002;
    display: none;
    font-size: 1.4rem;
    width: 100%;;
    background: #f7f7f7;
    padding:75px 20px 0;
}
#global_menu a:link,
#global_menu a:visited,
#global_menu a:hover,
#global_menu a:active{
    color: #000;
    text-decoration: none;
}
#global_menu .global_menu_inner{
    margin: 0 auto;
    max-width: 1130px;
}
#global_menu .gm_btn{
    text-align: center;
    box-sizing: border-box;
    display: block;
    max-width: 260px;
    padding:20px;
    border: 2px solid #000;
    border-radius: 5px;
    margin:0 auto 0 0 ;

}
#global_menu .gm_btn.gm_btn01{
    background: #000;
    color: #FFF;
    margin:0 0 0 auto;
}

    #global_menu .upper{
        padding:0 0 20px;
    }

    #global_menu .upper table{
        width: 100%;
        border-bottom: 2px solid #cccccc;
    }

        #global_menu .upper table tr{

        }

        #global_menu .upper table tr td{
            width: 50%;
        }

        #global_menu .upper table tr td:first-child{
            border-right:2px solid #cccccc;
        }

        #global_menu .upper table thead tr td{
            padding:30px 0 15px;
            position: relative;
            font-weight: bold;
            color: #000;
        }

        #global_menu .upper table thead tr td::after{
            display: block;
            position: absolute;
            content:'';
            width:78%;
            width:70%;
            bottom:18px;
            right:10px;
            border-bottom:2px solid #999999;
        }

        #global_menu .upper table thead tr td:nth-child(2){
            padding:30px 0px 15px 10px;
        }
        #global_menu .upper table thead tr td:nth-child(2):after{
            width:72%;
            width:70%;
            right:0px;
        }
        #global_menu .upper table tbody tr td{
            padding:15px 0;
        }
        #global_menu .upper table tbody tr td .en{
            font-weight: bold;
        }
        #global_menu .upper table tbody tr:last-child td{
            padding:15px 0 30px;
        }
        #global_menu .upper table tbody tr td a{
            padding:0 20px 0 0;
            background: url('../img/common/ico_arrow01.png') center right 10px no-repeat;
            -webkit-background-size: 5px 8px;
            background-size: 5px 8px;
            display: block;
        }
        #global_menu .upper table tbody tr td:nth-child(2) a{
            padding:0 20px 0 10px ;
            background: url('../img/common/ico_arrow01.png') center right 0px no-repeat;

            -webkit-background-size: 5px 8px;
        }


        #global_menu .upper table tbody tr td a span{
            display: block;
        }

    #global_menu .lower{
        padding:0 0 20px;
    }

        #global_menu .lower .lower01{
            padding:0 0 20px;
        }
        #global_menu .lower .lower01 ul{
        }
        #global_menu .lower .lower01 ul li{
            box-sizing: border-box;
            padding:0 10px;
            width: 50%;
            float: left;
            font-weight: bold;
        }

        #global_menu .lower .lower02{
            padding:0 0 20px;
        }
        #global_menu .lower .lower02 ul{
        }
        #global_menu .lower .lower02 ul li{
            border-right: 1px solid #000;
            padding:0 30px;
            margin:10px 0 0;
            line-height: 1;
            width: 50%;;
            float: left;
            font-weight: bold;

        }
        #global_menu .lower .lower02 ul li:nth-child(odd){
            text-align: right;
        }

        #global_menu .lower .lower02 ul li:nth-child(even){
            border-right: none;
            text-align: left;
        }


/* .list-layout-type01 */
.list-layout-type01 > ul{
    overflow: hidden;
    padding: 0 3%;
}
.list-layout-type01 > ul > li{
    float: left;
    width: 50%;
    padding: 0 2% 30px;
}
.list-layout-type01 > ul > li:nth-of-type(2n+1){
    clear: both;
}
.list-layout-type01 > ul > li a{
    display: block;
    position: relative;
}
.list-layout-type01 > ul > li .ico01{
    display: block;
    position: absolute;
    z-index: 1;
    bottom: -14px;
    left: 0;
    text-align: center;
    width: 100%;
}
.list-layout-type01 > ul > li .ico01 img{
    display: block;
    margin: 0 auto;
    width: 28px;
    height: auto;
}
.list-layout-type01 > ul > li h3{
    padding-top: 14px;
}
.list-layout-type01 > ul > li footer p{
    color: #999;
}
.list-layout-type01 > ul > li h3{
    font-size: 1.4rem;
}
.list-layout-type01 > ul > li .tex01{
    font-size: 1.4rem;
}
.list-layout-type01 > ul > li footer p{
    font-size: 1.4rem;
}

/* .list-layout-type02 */
.list-layout-type02{
    overflow: hidden;
}
.list-layout-type02 li{
    float: left;
    position: relative;
    padding-left: .75rem;
    padding-right: 1rem;
    font-size: 1.4rem;
    color: #999;
}
.list-layout-type02 li::before{
    content: '#';
    position: absolute;
    top: 0;
    left: 0;
}
.list-layout-type02 li{
    width: auto;
}
.list-layout-type02 li:nth-of-type(2n+1){
    clear: none;
}

/* .list-layout-type03 */
.list-layout-type03{
    text-align: left;
}
.list-layout-type03 li{
    padding: 30px 0 0;
}
.list-layout-type03 .block01{
    padding-left: 35px;
    background: url('../img/top/c04_ico01.png') 0 2px no-repeat;
    -webkit-background-size: 19px 16px;
    background-size: 19px 16px;
    font-size: 1rem;
}
.list-layout-type03 .block01 h3{
    font-size: 1.4rem;
}
.list-layout-type03 .block01 p{
    font-size: 1.4rem;
}

/* .list-layout-type04 */
.list-layout-type04 > ul{
    text-align: left;
    overflow: hidden;
    margin: 0 -2%;
    color: #000;
}
.list-layout-type04 > ul > li{
    float: left;
    width: 50%;
    padding: 0 2% 30px;
}
.list-layout-type04 > ul > li:nth-of-type(2n+1){
    clear: both;
}
.list-layout-type04 > ul > li a{
    display: block;
    position: relative;
}
.list-layout-type04 > ul > li a > .img01{
    display: block;
    position: relative;
}
.list-layout-type04 > ul > li a > .img01.rank01::before{
        content:'';
        display: block;
        width: 25%;
        height: 25%;
        position: absolute;
        top:7%;
        right:7%;
        background: url('../img/common/ico_rank01.png') top left no-repeat;
        -webkit-background-size: 100%;
        background-size: 100%;
}
.list-layout-type04 > ul > li a > .img01.type01::before{
        content:'';
        display: block;
        width: 25%;
        height: 25%;
        position: absolute;
        top:7%;
        right:7%;
        background: url('../img/common/ico_type01.png') top left no-repeat;
        -webkit-background-size: 100%;
        background-size: 100%;
}
.list-layout-type04 > ul > li .ico01{
    display: block;
    position: absolute;
    z-index: 1;
    bottom: -14px;
    left: 0;
    text-align: center;
    width: 100%;
}
.list-layout-type04 > ul > li .ico01 img{
    display: block;
    margin: 0 auto;
    width: 28px;
    height: auto;
}
.list-layout-type04 > ul > li h3{
    margin: 15px 0 0 !important;
    padding: 0 !important;
    font-size: 1.4rem !important;
}
.list-layout-type04 > ul > li .tex01,
.list-layout-type04 > ul > li p{
    margin: 15px 0 0 !important;
    padding: 0 !important;
    font-size: 1.4rem !important;
}
.list-layout-type04 > ul > li small{
    display: block;
    margin: 15px 0 0 !important;
    padding: 0 !important;
    font-size: 1.3rem !important;
}
.list-layout-type04 > ul > li small::before{
    content: '\3010';
}
.list-layout-type04 > ul > li small::after{
    content: '\3011';
}

/* .list-layout-type05 */
.list-layout-type05 > ul{
    text-align: left;
    overflow: hidden;
    margin: 0 -1px;
    padding-top: 30px;
    color: #000;
}
.list-layout-type05 > ul > li{
    float: left;
    width: 33.33%;
    padding: 0 1px 2px;
}
.list-layout-type05 > ul > li:nth-of-type(3n+1){
    clear: both;
}

/* .list-layout-type06 */
.list-layout-type06{
    text-align: left;
}
.list-layout-type06 > ul{
    text-align: left;
    overflow: hidden;
    margin: 0 -2%;
    color: #000;
}
.list-layout-type06 li{
    float: left;
    width: 50%;
    padding: 0 2% 30px;
}
.list-layout-type06 .block01{
    font-size: 1rem;
}
.list-layout-type06 .block01 h3{
    font-size: 1.3rem;
}
.list-layout-type06 .block01 p{
    font-size: 1.2rem;
}

.common_related01{
    padding: 40px 0 80px;
}


/* --------------------------------
    【共通】レイアウトパターン01
-------------------------------- */
.box-layout-type01 .ttl-type01 .ico01{
    display: block;
    position: relative;
    padding-left: 48px;
}
.box-layout-type01 .ttl-type01 .ico01:before{
    display: block;
    content: ' ';
    position: absolute;
    top: 9px;
    left: 0;
    width: 34px;
    height: 2px;
    background-color: #4d4d4d;
}

/* --------------------------------
    【共通】アイコン
-------------------------------- */
.ico-type01{
    display: inline-block;
    position: relative;
    padding-left: 20px;
}
.ico-type01::before{
    display: block;
    content: ' ';
    position: absolute;
    top: 3px;
    left: 0;
    width: 14px;
    height: 14px;
    background: url('../img/common/ico-type01.png') 0 0 no-repeat;
    -webkit-background-size: 14px;
    background-size: 14px;
}

/* --------------------------------
    【共通】Related01
-------------------------------- */
#common01 > .wrap01 > .inner01{
    border-top: 1px solid #d9d9d9;
    margin: 75px 5% 0;
}
#common01 h2{
    padding-top: 50px;
}
#common01 header h2 img{
    max-width: 68px;
}
#common01 header .btn01 img{
    max-width: 76px;
}
#common01 .header-layout-type01{
    position: relative;
    max-width: 1130px;
    margin: 0 auto 35px;
    padding: 0;
}
#common01 .header-layout-type01 ul{
    margin: 0;
    padding: 0;
}
#common01 .header-layout-type01 .btn01{
    position: absolute;
    right: 0;
    bottom: 0;
}
#common01 .header-layout-type01 a{
    line-height: 1;
}
#common01 .header-layout-type01 .btn01 .ico01{
    display: inline-block;
    position: relative;
    padding-left: 1rem;
}
#common01 .header-layout-type01 .btn01 .ico01::before {
    display: block;
    content: ' ';
    width: 5px;
    height: 8px;
    position: absolute;
    top: 0;
    left: 0;
    background: url('../img/common/ico_arrow01.png') 0 0 no-repeat;
        background-size: auto;
    -webkit-background-size: 5px 8px;
    background-size: 5px 8px;
}
/* OW - .list-layout-type04 */
#common01 .list-layout-type04{
    padding: 0;
}
#common01 .list-layout-type04 > ul > li{
    text-align: left;
    padding: 0 2% 45px;
}
#common01 .list-layout-type04 a:link,
#common01 .list-layout-type04 a:visited,
#common01 .list-layout-type04 a:hover,
#common01 .list-layout-type04 a:active{
    color: #000;
}
#common01 .list-layout-type04 .list-layout-type04_tex01{
    display: block;
}
#common01 .list-layout-type04 #ame_tex01 .ame_brfix01{
    display: block;
}

/* --------------------------------
    【共通】Related
-------------------------------- */
#common_journal01 > .wrap01 > .inner01{
    border-top: 1px solid #d9d9d9;
    margin: 75px 5% 0;
}
#common_journal01 .common_journal_layout01{
    padding: 0 0 80px;
}
#common_journal01 h2{
    padding-top: 50px;
}
#common_journal01 header p{
    font-size: 1.3rem;
}
#common_journal01 header h2 img{
    max-width: 68px;
}
#common_journal01 header .btn01 img{
    max-width: 76px;
}
#common_journal01 .header-layout-type01{
    position: relative;
    max-width: 1130px;
    margin: 0 auto 20px;
    padding: 0;
}
#common_journal01 .header-layout-type01 ul{
    margin: 0;
    padding: 0;
}
#common_journal01 .header-layout-type01 .btn01{
    position: absolute;
    right: 0;
    bottom: 0;
}
#common_journal01 .header-layout-type01 a{
    line-height: 1;
}
#common_journal01 .header-layout-type01 .btn01 .ico01{
    display: inline-block;
    position: relative;
    padding-left: 1rem;
}
#common_journal01 .header-layout-type01 .btn01 .ico01::before {
    display: block;
    content: ' ';
    width: 5px;
    height: 8px;
    position: absolute;
    top: 0;
    left: 0;
    background: url('../img/common/ico_arrow01.png') 0 0 no-repeat;
        background-size: auto;
    -webkit-background-size: 5px 8px;
    background-size: 5px 8px;
}
/* OW - .list-layout-type04 */
#common_journal01 .list-layout-type04{
    padding: 0;
}
#common_journal01 .list-layout-type04 > ul > li{
    text-align: left;
    padding: 0 2% 30px;
}
#common_journal01 .list-layout-type04 a:link,
#common_journal01 .list-layout-type04 a:visited,
#common_journal01 .list-layout-type04 a:hover,
#common_journal01 .list-layout-type04 a:active{
    color: #000;
}

/* --------------------------------
    #common_how_to_use01
-------------------------------- */
#common_how_to_use01{
    padding: 60px 15px 0;
    font-size: 1.2rem;
    line-height: 1.75;
}
#common_how_to_use01 h5{
    margin: 0;
    padding: 0 0 20px;
    font-size: 1.2rem;
    line-height: 1;
    font-weight: bold;
}
#common_how_to_use01 ul{
    border-bottom: 1px solid #d9d9d9;
}
#common_how_to_use01 li{
    display: flex;
    align-items: center;
    padding: 20px 0;
    border-top: 1px solid #d9d9d9;
}
#common_how_to_use01 li .how_to_use_box01{
    width: 94px;
    min-width: 94px;
}
#common_how_to_use01 li .how_to_use_box02{
    padding-left: 20px;
}
#common_how_to_use01 .how_to_use_tex01{
    display: block;
    position: relative;
    padding-left: 13px;
    font-size: 1.2rem;
}
#common_how_to_use01 .how_to_use_tex01::before{
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    content: '\203B';
}

/* --------------------------------
    #common_faq01
-------------------------------- */
#common_faq01{
    padding: 60px 15px 0;
    font-size: 1.2rem;
    line-height: 1.6125;
}
#common_faq01 a:link,
#common_faq01 a:visited,
#common_faq01 a:hover,
#common_faq01 a:active{
    text-decoration: underline;
}
#common_faq01 h5{
    margin: 0;
    padding: 0 0 20px;
    font-size: 1.2rem;
    line-height: 1;
    font-weight: bold;
}
#common_faq01 .faq_box01{
    background-color: #f4f4f6;
    padding: 20px;
}
#common_faq01 h6{
    position: relative;
    margin: 0;
    padding: 0 0 0 15px;
    font-size: 1.2rem;
    line-height: 1.5;
    font-weight: bold;
}
#common_faq01 h6::before{
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    content: 'Q.';
}
#common_faq01 .faq_box02{
    padding: 15px 20px 30px;
}
#common_faq01 .faq_box02 p{
    margin: 0;
    padding: 0;
}

/* --------------------------------
    .common_layout01
-------------------------------- */
.common_layout01{
    background: #F4F4F6;
}
    .common_layout01 > .inner01{
        color: #000;
        margin: 0 20px;
        padding: 45px 0 10px;
    }
    .common_layout01 > .inner01 > section{
    }
    .common_layout01 > .inner01 > section > .inner02{
    }
    .common_layout01 > .inner01 > section > .inner02::before{
        content:'';
        border-top: 2px solid #d9d9d9;
        display: block;
        margin : 0px 5px;
    }
    .common_layout01 > .inner01 > section:first-child > .inner02::before{
        display: none;
    }

    .common_layout01 h2{
        font-size: 1.4rem;
        line-height: 1;
        cursor: pointer;
        padding:30px 0 ;
        margin : 0px 5px ;
        background: url('../img/common/ico_plus01.png') center right no-repeat;
        -webkit-background-size: 14px auto;
        background-size:14px auto;
    }
    .common_layout01 h2.active{
        background: url('../img/common/ico_minus01.png') center right no-repeat;
        -webkit-background-size: 14px auto;
        background-size: 14px auto;
    }

        .common_layout01 .items_wrap{
            display: none;
            padding:0 0 40px;
        }

        .common_layout01 .items{

        }
        .common_layout01 .items.active{
        }

        .common_layout01 .item{
            font-size: 1.4rem;
            padding:5px;
        }
        .common_layout01 .item.item_layout01 header{
            display: flex;
            align-items: flex-start;
        }
        .common_layout01 .item.item_layout01 header .item_image,
        .common_layout01 .item.item_layout01 header .item_detail{
            width: 50%;
        }

        .common_layout01 .item a{
            height: 100%;
            display: block;
            padding: 20px 20px 10px;
            background:  #FFF url('../img/common/ico_arrow02.png') bottom 32px right 20px  no-repeat;
            -webkit-background-size: 9px 16px;
            background-size: 9px 16px;
        }

        .common_layout01 .item .item_image{
            position: relative;
            padding:0 0 20px;
        }
        .common_layout01 .item .img01_tex01 li{
            padding-top: 10px;
        }

        .common_layout01 .item .item_image.rank01::before{
            content:'';
            display: block;
            width: 25%;
            height: 25%;
            position: absolute;
            top:7%;
            left:7%;
            background: url('../img/common/ico_rank01.png') top left no-repeat;
            -webkit-background-size: 100%;
            background-size: 100%;
        }

        .common_layout01 .item .item_detail{
            text-align: left;
            padding: 0 10px 20px;
        }
            .common_layout01 .item .tex01{
                padding: 25px 0 5px;
            }
            .common_layout01 .item .tex01 span{
                font-weight: bold;
            }
            .common_layout01 .item .tex02::before{
                content: '[';
            }
            .common_layout01 .item .tex02::after{
                content: ']';
            }
            .common_layout01 .item .summary{
                line-height: 1.6;
                padding:0 0 10px;
            }
            .common_layout01 .item dl{
                padding:0 0 10px;
                margin:0 0 10px;
                border-bottom: 2px solid #d9d9d9;
            }
            .common_layout01 .item dl dt{
                padding:0 0 10px;
            }
            .common_layout01 .item dl dd{
                padding:0 0 10px;
            }
            .common_layout01 .item dl dd span{
                font-weight: bold;
            }
            .common_layout01 .item dl dd span{
                font-weight: bold;
            }
            .common_layout01 .item .target_wrap{
                padding:5px 0 20px;
                font-size: 1.2rem;
            }

            .common_layout01 .item .target_wrap ul{
                padding-top: 15px;
            }
            .common_layout01 .item .target_wrap li{
                float: left;
                padding:5px 5px 0 0;
            }
            .common_layout01 .item .target_wrap li span{
                display: inline-block;
                background: #000;
                color: #FFF;
                padding:2px 15px;
                border-radius: 15px;
            }
            .common_layout01 .item .target_wrap li.target01 span{
                background: #e97b9b;
            }
            .common_layout01 .item .target_wrap li.target02 span{
                background: #73a7ff;
            }
            .common_layout01 .item .target_wrap li.target03 span{
                background: #9f60f4;
            }
            .common_layout01 .item .target_wrap li.target04 span{
                background: #e30000;
            }
            .common_layout01 .item .target_wrap li.target05 span{
                background: #897bc3;
            }

        .common_layout01 .items.layout02 .item .item_image{
            padding:0 0 10px;
        }

        .common_layout01 .items.layout02 {
            display: flex;
            flex-flow: row wrap;
        }
        .common_layout01 .items.layout02.active {
        }

        .common_layout01 .items.layout02 .item{
            width: 50%;
        }
        .common_layout01 .items.layout02 .item a{
            background:  #FFF url('../img/common/ico_arrow02.png') center right  no-repeat;
            -webkit-background-size: 9px 16px;
            background-size: 9px 16px;
        }
        .common_layout01 .items.layout02 .item h3{
            font-size: 1.4rem;
            margin: 0;
            padding:0 0 30px;
        }

        .common_layout01 .items.layout02 .item h4{
            font-size: 1.4rem;
            margin: 0;
            padding:0 0 20px;

        }
        .common_layout01 .items.layout02 .item h4::before{
            content:'';
            border-top: 2px solid #d9d9d9;
            display: block;
            padding:0 0 15px;

        }
            .common_layout01 .items.layout02 .item .target_wrap{
                padding:5px 0 40px;
            }

            .common_layout01 .items.layout02 .item .target_wrap li{
                float: none;
            }

#page-layout-type01 .common_layout01 .item.item_layout01 .item_detail h4{
    margin: 0;
    padding: 0;
}
#page-layout-type01 .common_layout01 .item.item_layout01 footer{
    border-top: 1px solid #ccc;
}


/* --------------------------------
    【共通】下層ページ01
-------------------------------- */
body.page01{
}
body.page01 #contents > .container-fluid{
    padding: 0;
}
body.page01 #contents > .inner{
    max-width: none;
}
body.page01 #main{
    margin: 0;
    padding: 0;
}

body.page01 #page-layout-type01{
    background-color: #fff;
}
body.page01 #page-layout-type01 h1,
body.page01 #page-layout-type01 h2,
body.page01 #page-layout-type01 h3,
body.page01 #page-layout-type01 h4,
body.page01 #page-layout-type01 h5,
body.page01 #page-layout-type01 h6{
    margin: 0;
    padding: 2.2rem 0 0;
}
body.page01 #page-layout-type01 p{
    margin: 0;
    padding: 1.5rem 0 0;
}

body.page01 #page-layout-type01 #common01 .header-layout-type01 p{
    padding: 5px 0 0;
    font-size: 1.2rem;
}

/* --------------------------------
    h1
-------------------------------- */
body.page01 #page-layout-type01 h1{
    padding-bottom: 40px;
}
body.page01 #page-layout-type01 h1{
    font-size: 2.6rem;
}

/* --------------------------------
    h2
-------------------------------- */
body.page01 #page-layout-type01 h2{
    font-size: 1.6rem;
    color: #1f232e;
}

/* --------------------------------
    h2
-------------------------------- */
body.page01 #page-layout-type01 h3 {
    font-size: 1.6rem;
}

/* --------------------------------
    h2
-------------------------------- */
body.page01 #page-layout-type01 p {
    font-size: 1.4rem;
}

@media only screen and (min-width: 320px){
/* --------------------------------
    .common_layout01
-------------------------------- */
    .common_layout01 .items.layout02 .item{
        width: 100%;
    }
    .common_layout01 .item .target_wrap{
        font-size: 1rem;
    }
}

@media only screen and (min-width: 375px){
/* --------------------------------
    .common_layout01
-------------------------------- */
    .common_layout01 .items.layout02 .item{
        width: 50%;
    }
    .common_layout01 .item .target_wrap{
        font-size: 1.2rem;
    }
}
@media only screen and (min-width: 376px){
    #common01 .list-layout-type04 .list-layout-type04_tex01,
    #common01 .list-layout-type04 #ame_tex01 .ame_brfix01{
        display: inline;
    }
}

@media only screen and (min-width: 480px){
    #global_menu .upper table thead tr td::after{
        width:83%;
    }
    #global_menu .upper table thead tr td:nth-child(2):after{
        width:81%;
    }
}
@media only screen and (min-width: 768px) {
/* --------------------------------
    common
-------------------------------- */
    .d-sm-bl{
        display: block !important;
    }
    .d-sm-ib{
        display: inline-block !important;
    }
    .d-sm-i{
        display: inline !important;
    }
    .ta-sm-l{
        text-align: left !important;
    }
    .ta-sm-c{
        text-align: center !important;
    }
    .ta-sm-r{
        text-align: right !important;
    }

    body.page01 #page-layout-type01 h2,
    body.page01 #page-layout-type01 h3,
    body.page01 #page-layout-type01 h4,
    body.page01 #page-layout-type01 h5,
    body.page01 #page-layout-type01 h6{
        margin: 0;
        padding: 5rem 0 0;
    }
    body.page01 #page-layout-type01 p{
        margin: 0;
        padding: 1.5rem 0 0;
    }

    #header #cart.cart{
        top:60px !important;
        left:-5px !important;
    }

/* --------------------------------
    #common_how_to_use01
-------------------------------- */
    #common_how_to_use01{
        margin: 0 auto;
        padding: 75px 15px 0;
        font-size: 1.6rem;
        max-width: 800px;
    }
    #common_how_to_use01 h5{
        padding: 0 0 30px;
        font-size: 1.8rem;
    }
    #common_how_to_use01 .how_to_use_tex01{
        padding-left: 20px;
        font-size: 1.6rem;
    }

/* --------------------------------
    #common_faq01
-------------------------------- */
    #common_faq01{
        margin: 0 auto;
        padding: 75px 15px 0;
        font-size: 1.6rem;
        max-width: 800px;
    }
    #common_faq01 h5{
        padding: 0 0 30px;
        font-size: 1.8rem;
    }
    #common_faq01 h6{
        padding: 0 0 0 20px;
        font-size: 1.6rem;
    }
    #common_faq01 .faq_box02{
        padding: 15px 20px 45px;
    }

/* --------------------------------
    .common_layout01
-------------------------------- */
    .common_layout01 > .inner01{
        max-width: 800px;
        margin: 0 auto;
        margin: 0 auto;
        padding: 40px 5%;
    }
    .common_layout01 > .inner01 > section > .inner02::before{
        content:'';
        border-top: 2px solid #d9d9d9;
        display: block;
        margin : 0px 5px;
    }
    .common_layout01 > .inner01 > section:first-child > .inner02::before{
        display: none;
    }
    .common_layout01 h2{
        font-size: 1.8rem;
    }
    .common_layout01 .item.item_layout01 .item_detail h4{
        font-size: 1.8rem;
    }
    .common_layout01 .item .tex01 span{
        font-size: 1.8rem;
    }
    .common_layout01 .item .tex02::before{
        padding-right: .25rem;
    }
    .common_layout01 .item .tex02::after{
        padding-left: .25rem;
    }
    body.page01 #page-layout-type01 p{
        font-size: 1.6rem;
        line-height: 1.75;
    }

/* --------------------------------
    h1
-------------------------------- */
    body.page01 #page-layout-type01 h1{
        padding-top: 80px;
    }

/* --------------------------------
    h2
-------------------------------- */
    body.page01 #page-layout-type01 h2 {
        font-size: 2.2rem;
    }

/* --------------------------------
    h3
-------------------------------- */
    body.page01 #page-layout-type01 h3 {
        font-size: 1.8rem;
    }

    /* common */
    #global_menu a:link,
    #global_menu a:visited,
    #global_menu a:hover,
    #global_menu a:active{
        color: #000;
        text-decoration: none;
    }
    #global_menu a:hover{
        opacity: .8;
    }

    .btn.btn-type01 img{
        max-width: 88px;
    }

    /* .list-layout-type01 */
    .list-layout-type01 > ul{
        max-width: 1260px;
        margin: 0 auto;
    }
    .list-layout-type01 > ul > li{
        width: 25%;
    }
    .list-layout-type01 > ul > li:nth-of-type(2n+1){
        clear: none;
    }
    .list-layout-type01 > ul > li:nth-of-type(4n+1){
        clear: both;
    }
    .list-layout-type01 > ul > li h3{
        font-size: 1.8rem;
    }
    .list-layout-type01 > ul > li .tex01{
        font-size: 1.6rem;
    }
    .list-layout-type01 > ul > li footer p{
        font-size: 1.2rem;
    }
    body.page01 #page-layout-type01 #common01 .header-layout-type01 p {
        margin: 0;
        padding: 10px 0 0;
        font-size: 1.3rem;
    }

    /* .list-layout-type02 */
    .list-layout-type02 li{
        font-size: 1.2rem;
    }

    /* .list-layout-type03 */
    .list-layout-type03{
        text-align: left;
    }
    .list-layout-type03 ul{
        display: flex;
        margin: 0 -2%;
    }
    .list-layout-type03 li{
        float: left;
        padding: 30px 2% 0;
        width: 50%;
    }
    .list-layout-type03 .block01{
        padding-left: 35px;
        background: url('../img/top/c04_ico01.png') 0 5px no-repeat;
        -webkit-background-size: 19px 16px;
        background-size: 19px 16px;
        font-size: 1.4rem;
    }
    .list-layout-type03 .block01 h3{
        margin: 20px 0 0;
        font-size: 1.8rem;
    }
    .list-layout-type03 .block01 p{
        font-size: 1.6rem;
    }

    /* .list-layout-type04 */
    .list-layout-type04 > ul{
        text-align: left;
        overflow: hidden;
        margin: 0 -2%;
        padding: 30px 0 0;
        color: #000;
    }
    .list-layout-type04 > ul > li{
        float: left;
        width: 33.33%;
        padding: 0 2% 60px;
    }
    .list-layout-type04 > ul > li:nth-of-type(2n+1){
        clear: none;
    }
    .list-layout-type04 > ul > li:nth-of-type(3n+1){
        clear: both;
    }
    .list-layout-type04 > ul > li h3{
        margin-top: 15px !important;
        padding-top: 0 !important;
        font-size: 1.8rem !important;
    }
    .list-layout-type04 > ul > li .tex01,
    .list-layout-type04 > ul > li p{
        font-size: 1.6rem !important;
    }
    .list-layout-type04 > ul > li small{
        display: block;
        padding-top: 1rem;
        font-size: 1.2rem;
    }

/* --------------------------------
    【共通】Related
-------------------------------- */
    #common01 > .wrap01{
        margin: 0 auto;
        max-width: 1260px;
    }
    #common01 > .wrap01 > .inner01{
        border-top: 1px solid #d9d9d9;
        margin: 75px 5% 0;
    }
    #common01 h2{
        padding-top: 12rem;
    }
    #common01 header h2 img {
        max-width: 112px;
    }
    #common01 .header-layout-type01{
        margin: 0 auto 20px;
    }
    #common01 .list-layout-type04 > ul > li{
        padding: 0 2% 30px;
    }

/* --------------------------------
    OW - .list-layout-type04
-------------------------------- */
    #common01 .list-layout-type04{
        margin: 0 auto;
        padding: 0;
        max-width: 1130px;
    }
    #common01 .list-layout-type04 > ul > li{
        width: 25%;
        padding: 0 2% 60px;
    }
    #common01 .list-layout-type04 > ul > li:nth-of-type(2n+1),
    #common01 .list-layout-type04 > ul > li:nth-of-type(3n+1){
        clear: none;
    }
    #common01 .list-layout-type04 > ul > li:nth-of-type(4n+1){
        clear: both;
    }
    #common01 .list-layout-type04 a:hover{
        opacity: .7;
    }
    .list-layout-type06 li{
        float: left;
        width: 25%;
        padding: 0 2% 30px;
    }

/* --------------------------------
    【共通】Related01
-------------------------------- */

/* --------------------------------
    【共通】Journal01
-------------------------------- */
    #common_journal01 > .wrap01{
        margin: 0 auto;
        max-width: 1260px;
    }
    #common_journal01 > .wrap01 > .inner01{
        border-top: 1px solid #d9d9d9;
        margin: 75px 5% 0;
    }
    #common_journal01 h2{
        padding-top: 40px;
    }
    #common_journal01 header h2 img{
        max-width: 116px;
    }
    #common_journal01 .list-layout-type04{
        margin: 0 auto;
        padding: 0;
        max-width: 1130px;
    }
    #common_journal01 .list-layout-type04 > ul > li{
        width: 25%;
        padding: 0 2% 60px;
    }
    #common_journal01 .list-layout-type04 > ul > li:nth-of-type(2n+1),
    #common_journal01 .list-layout-type04 > ul > li:nth-of-type(3n+1){
        clear: none;
    }
    #common_journal01 .list-layout-type04 > ul > li:nth-of-type(4n+1){
        clear: both;
    }
    #common_journal01 .list-layout-type04 a:hover{
        opacity: .7;
    }

/* --------------------------------
    【共通】グローバルメニュー
-------------------------------- */

    #btn_menu {
        display: block !important;
    }
    #header .header_logo_area{
        float: none !important;
    }
    #gn_tgl{
        left:0px;
        top:15px;
    }

    #global_menu{
        padding: 75px 5% 0;
        font-size: 1.8rem;
        margin: 0 auto;
    }
    #global_menu .global_menu_inner{
        margin: 0 auto;
        max-width: 1130px;
    }
    #global_menu .upper table thead tr td:nth-child(2){
        padding: 30px 0px 15px 20px;
    }
    #global_menu .upper table thead tr td::after{
        right:20px;
    }
    #global_menu .upper table tbody tr td a{
        background:url('../img/common/ico_arrow01.png') center right 20px no-repeat;
        padding:0 40px 0 0;
        background-size: 10px auto;
    }
    #global_menu .upper table tbody tr td:nth-child(2) a{
        padding: 0 40px 0 20px;

    }
}