html
{
    font-size: 100%;

    overflow-y: scroll;
}

a
{
    text-decoration: none;

    color: #222;
    background-color: transparent;
    /* Remove the gray background on active links in IE 10 */

    -webkit-text-decoration-skip: objects;
    /* Remove gaps in links underline in iOS 8+ and Safari 8+ */
}

a:active,
a:hover
{
    outline-width: 0;
    /* Remove the outline when hovering in all browsers */
}

p
{
    line-height: 2;
}

ul
{
    list-style: none;

    outline: none;
}

body
{
    font-family: 'EB Garamond', serif;
    font-size: .8125rem;
    line-height: 1.5;

    width: 100%;

    background-color: #e0e0e0;
}

#wrapper
{
    opacity: 0;
}

#mainloading
{
    position: absolute;
    width: 100%;
    height:100%;
    z-index: 400;
    background: url(../images/loading_pc.jpg) no-repeat center center fixed;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;

    animation: flash 1.5s infinite linear;
    -webkit-animation: flash 1.5s infinite linear;
    -moz-animation: flash 1.5s infinite linear;

}

@keyframes flash {
    0% { opacity: 0.0; }
    50% { opacity: 1; }
    100% { opacity: 0.0; }
}
@-webkit-keyframes flash {
    0% { opacity: 0.0; }
    50% { opacity: 1; }
    100% { opacity: 0.0; }
}
@-moz-keyframes flash {
    0% { opacity: 0.0; }
    50% { opacity: 1; }
    100% { opacity: 0.0; }
}


#mainloading .maru
{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;

    display: block;

    width: 10px;
    height: 10px;
    margin: auto;
}

.undraggable
{
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;

    -khtml-user-select: none;
    -webkit-user-drag: none;
    -khtml-user-drag: none;
    -webkit-touch-callout: none;
}

.item img
{
    width: 100%;
}

header
{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;

    width: 83%;
    height: 210px;
    margin: 0 auto;

    isplay: block; /* before Android4.3 iOS6:Safari */
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

header .logo
{
    width: 244px;
    height: 125px;
    margin-top: 69px;
    background: url(../images/header_logo.png) no-repeat center center;
}

header .menuhum_sp
{
    display: none;
}



header nav
{
    display: block;
    font-size: 125%;

    float: right;

    margin-top: 178px;
}

header nav li
{
    display: inline-block;

    margin-left: 54px;

    vertical-align: top;
}
header nav .menu a
{
    /*padding: 2px;*/
    text-decoration: none;

    color: #666;
    background-color: transparent;
    /*background-color: #e0e0e0;*/
    transition: background-color 0.5s ease;
}
header nav .menu a:hover
{
    background-color: #fff;
}
header nav ._hoge a
{
    background-color: #fff;
}
header nav .nomenu
{
    margin-top: 3px;
}


.mainVisual
{
    width: 100%;
    height: auto;
    margin-top: 30px;
}


footer
{
    display: block; /* before Android4.3 iOS6:Safari */
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;

    width: 86%;
    height: 214px;
    margin: 0 auto;

    border-top: 1px solid #000000;

    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
/*214*/
footer a.item_logo_pc
{
    display: block;
    width: 152px;
    height: 79px;
    margin-top: 20px;

    background: url(../images/footer_logo_pc.png) no-repeat left 0;
}
footer a.item_logo_sp
{
    display: none;
}

footer div.item_copy
{
    width: 120px;
    height: 12px;
    margin-top: 56px;
    float: right;

    background: url(../images/footer_copy_pc.png) no-repeat left 0;
}

footer .footermenu
{
    display: none;
}

#globale_next
{
    display: block;
    position: fixed;
    z-index: 999;
    margin:auto 0;
}

#globale_back
{
    display: block;
    position: fixed;
    z-index: 999;
    margin:auto 0;
    right: 0;
}

#nextbtn
{
    width: 40px;
    height: 41px;
    padding-top: 50px;
    padding-right: 50px;
    padding-bottom: 50px;

    background-image: url("../images/sub_arrow_left.png");
    background-position: center left;
    background-repeat: no-repeat;
    background-size: 40px 41px;
}

#backbtn
{
    width: 40px;
    height: 41px;
    padding-top: 50px;
    padding-bottom: 50px;
    padding-left: 50px;

    background-image: url("../images/sub_arrow_right.png");
    background-position: center right;
    background-repeat: no-repeat;
    background-size: 40px 41px;
}

#aboutmain
{
    display: block;
}

#aboutbox
{
    display: block;

    width: 62.5%;
    margin: 0 auto;
    margin-top: 4%;
    margin-bottom: 10%;

    text-align: justify;
    text-justify: inter-ideograph;
}

#aboutbox p
{
    font-size: .8125rem;
}

#aboutbox .font_jp
{
    font-family: 'ヒラギノ明朝 Pro W3','Hiragino Mincho ProN','HG明朝E' , 'Hiragino Mincho Pro' , 'HiraMinProN-W3' , '游明朝' , 'Yu Mincho' , '游明朝体' , 'YuMincho'  , 'HGS明朝E' , 'ＭＳ Ｐ明朝' , 'MS PMincho' , serif;
}

#aboutbox  h1
{
    font-size: 1.0rem;
}

#sub_main
{
    display: block;

    width: 100%;
    margin-top: 41px;
}

#sub_main div.btnbackwapper
{
    position: absolute;
    display: block;
    margin-top: -1px;
    right:0%;
}

#sub_main div.btnbackwapper a
{
    display: block;
    width: 40px;
    height: 40px;
    padding-bottom: 50px;
    padding-left: 50px;
    background-image: url('../images/sub_btn_back.png');
    background-repeat: no-repeat;
    background-position: top right;
    background-size: 40px 40px;
}

#sub_main div.imgbox
{
    display: block;
}

#sub_main div.imgbox:after
{
    display: block;
    clear: both;

    content: '';
}



#sub_main div.textbox
{
    width: 83%;
    margin-top: 63px;
    margin-bottom: 39px;
    margin-left: auto;
    margin-right: auto;
}

#sub_main div.textbox h1
{
    font-size: 1.0rem;

    margin-bottom: 24px;

}

#sub_main div.textbox p
{
    font-size: .75rem;

    margin-bottom: 24px;
}


#sub_main .font_en
{
    font-family: 'EB Garamond' , 'ヒラギノ明朝 Pro W3' , 'Hiragino Mincho Pro' , 'HiraMinProN-W3' , '游明朝' , 'Yu Mincho' , '游明朝体' , 'YuMincho'  , 'HGS明朝E' , 'ＭＳ Ｐ明朝' , 'MS PMincho' , serif;
}

#sub_main .font_jp
{
    font-family: 'ヒラギノ明朝 Pro W3','Hiragino Mincho ProN','HG明朝E' , 'Hiragino Mincho Pro' , 'HiraMinProN-W3' , '游明朝' , 'Yu Mincho' , '游明朝体' , 'YuMincho'  , 'HGS明朝E' , 'ＭＳ Ｐ明朝' , 'MS PMincho' , serif;
}
.font_en
{
    font-family: 'EB Garamond' , 'ヒラギノ明朝 Pro W3','Hiragino Mincho ProN','HG明朝E'  , 'Hiragino Mincho Pro' , 'HiraMinProN-W3' , '游明朝' , 'Yu Mincho' , '游明朝体' , 'YuMincho'  , 'HGS明朝E' , 'ＭＳ Ｐ明朝' , 'MS PMincho' , serif;
}
.font_jp
{
    font-family: 'ヒラギノ明朝 Pro W3','Hiragino Mincho ProN','HG明朝E' , 'Hiragino Mincho Pro' , 'HiraMinProN-W3' , '游明朝' , 'Yu Mincho' , '游明朝体' , 'YuMincho'  , 'HGS明朝E' , 'ＭＳ Ｐ明朝' , 'MS PMincho' , serif;
}
.youtube
{
    position: relative;

    overflow: hidden;

    width: 100%;
    padding-bottom: 56.25%;

    background-color: #000;
}
.youtube iframe
{
    position: absolute;
    top: 0;
    right: 0;

    width: 100% !important;
    height: 100% !important;
}



.item_big
{
    width: 100%;
}

.item_column_1
{
    width: 100%;
}


.item_small
{
    width: 50%;
}

.item_column_2
{
    width: 50%;
}

.item_column_3
{
    width: 33.33%;
}

.item_small
{
    float: left;
}

.item_big
{
    float: left;
}
.item_column_1
{
    float: left;
}
.item_column_2
{
    float: left;
}
.item_column_3
{
    float: left;
}

.item_big img
{
    display: block;

    width: 100%;
    height: auto;
}

.item_column_1 img
{
    display: block;

    width: 100%;
    height: auto;
}

.item_column_1
{
    display: block;

    width: 100%;
    height: auto;
}

.item_small img
{
    display: block;

    width: 100%;
    height: auto;
}

.item_column_2 img
{
    display: block;

    width: 100%;
    height: auto;
}

.item_column_3 img
{
    display: block;

    width: 100%;
    height: auto;
}

main
{
    display: block; /* before Android4.3 iOS6:Safari */
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;

    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
}

main #itembox
{
    display: block; /* before Android4.3 iOS6:Safari */
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;

    width: 87%;
    margin-top: 111px;

    -webkit-flex-flow: row wrap;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
}

main div.item
{
    width: 260px;
    margin-right: 20px;
    margin-bottom: 80px;
    margin-left: 20px;
}

main div.item_bg
{
    width: 100%;
    height: 173px;

    background-position: center center;
    background-size: cover;
}

main .item_bg_top
{
    width: 100%;
    height: 0;
    padding-top: 66.53%;

    background-position: center center;
    background-size: cover;
}

main div.itemtext
{
    width: 100%;
}

main div.item img
{
    width: 100%;
}

main div.item:hover p
{
    background-color: #FFFFFF;
}

main div.item:hover h1
{
    background-color: #FFFFFF;
}


main div.item h1
{
    font-size: 1rem;

    padding-left: 2px;
    padding-right: 2px;
    margin-top: 10px;
    margin-right: 10px;
    margin-left: 10px;
    display: inline-block;
    background-color: #e0e0e0;
    transition: background-color 0.5s ease;
}

main div.item p
{
    font-size: .6875rem;
    padding-left: 2px;
    padding-right: 2px;
    margin-right: 10px;
    margin-left: 10px;
    display: inline-block;
    background-color: #e0e0e0;
    transition: background-color 0.5s ease;
}


main div.item.is-empty
{
    height: 0;
    margin-top: 0;
    margin-bottom: 0;
    padding-top: 0;
    padding-bottom: 0;
}


main #loadbox
{
    position: relative;

    width: 260px;
    height: 180px;
    margin-right: 27px;
    margin-bottom: 90px;
    margin-left: 27px;

    cursor: pointer;

    /*background-color: #fff;*/
}

main #loadboximg
{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;

    display: block;

    width: 260px;
    height: 168px;
    margin: auto;
    background-size: 260px 168px;
    background-image: url(../images/btn_more.png);
}

.loading
{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;

    display: block;

    width: 260px;
    height: 168px;
    margin: auto;
    background-size: 260px 168px;
    background-image: url(../images/btn_more.gif);
}

@media (max-width: 1100px)
{
    body
    {
        width: 1100px;
        /*めにゅーこていよう*/
    }
}

@media (max-width: 768px)
{
    .mainVisual
    {
        display: none;
    }
    footer div.item_menu a p
    {
        font-size: .50rem;
    }

    html
    {
        font-size: 100%;
    }

    body
    {
        width: 100%;
    }

    #aboutbox
    {
        display: block;

        width: 62.5%;
        margin-top: 10%;
        margin-bottom: 20%;

        text-align: justify;
        text-justify: inter-ideograph;
    }

    #sub_main
    {
        display: block;

        width: 100%;
        margin-top: 7px;
    }

    #sub_main div.btnbackwapper
    {
        display: none;
    }

    #sub_main div.imgbox
    {
        display: block;
    }

    #sub_main div.imgbox:after
    {
        display: block;
        clear: both;

        content: '';
    }

    #sub_main div.textbox
    {
        display: block;

        width: 65%;
        margin: 0 auto;
        margin-top: 40px;
        margin-bottom: 40px;

        text-align: justify;
        text-justify: inter-ideograph;
    }

    #sub_main div.textbox h1
    {
        font-size: 1.0rem;

        margin-bottom: 10%;
    }

    #sub_main div.textbox p
    {
        font-size: .75rem;

        margin-bottom: 10%;
    }

    .item_small
    {
        float: left;
    }

    .item_big
    {
        float: left;
    }

    .item_column_1
    {
        float: left;
    }

    .item_column_2
    {
        float: left;
    }

    .item_column_3
    {
        float: left;
    }

    .youtube
    {
        position: relative;

        overflow: hidden;

        width: 100%;
        padding-bottom: 56.25%;

        background-color: #000;
    }

    .youtube iframe
    {
        position: absolute;
        top: 0;
        right: 0;

        width: 100% !important;
        height: 100% !important;
    }

    #globale_next
    {
        display: none;
    }

    #globale_back
    {
        display: none;
    }


    #nextbtn
    {
        width: 20px;
        height: 20.5px;
        padding-top: 25px;
        padding-right: 25px;
        padding-bottom: 25px;

        background-image: url("../images/sub_arrow_left.png");
        background-position: center left;
        background-repeat: no-repeat;
        background-size: 20px 20.5px;
    }

    #backbtn
    {
        width: 20px;
        height: 20.5px;
        padding-top: 25px;
        padding-bottom: 25px;
        padding-left: 25px;

        background-image: url("../images/sub_arrow_right.png");
        background-position: center right;
        background-repeat: no-repeat;
        background-size: 20px 20.5px;
    }

    main #itembox
    {
        display: block;
        /* before Android4.3 iOS6:Safari */

        width: 81.25%;
        /*margin-top: 9.3%;*/
        margin-top: 9px;

        -webkit-flex-flow: row nowrap;
        -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    main div.item
    {
        width: 100%;
        margin-right: 0;
        margin-bottom: 0;
        margin-left: 0;
        padding-bottom: 17.5%;
    }
    main div.item:hover p
    {
        background-color: #e0e0e0;
    }

    main div.item:hover h1
    {
        background-color: #e0e0e0;
    }

    main div.item_bg
    {
        width: 100%;
        height: 0;
        padding-top: 66.53%;

        background-position: center;
        background-size: cover;
    }

    main #loadbox
    {
        position: relative;

        width: 100%;
        height: auto;
        margin-right: 0;
        margin-bottom: 17.5%;
        margin-left: 0;
    }

    main #loadbox:before
    {
        display: block;

        padding-top: 64.61%;

        content: '';
        /* 高さと幅の比を16:9に固定。9/16*100=56.25 */
    }

    main #loadboximg
    {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;

        display: block;

        width: 260px;
        height: 168px;
        margin: auto;
        z-index: 80;

        background-image: url(../images/btn_more.png);
        background-position: center;
        background-size: contain;
    }

    .loading
    {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;

        display: block;

        width: 260px;
        height: 168px;
        margin: auto;

        background-image: url(../images/btn_more.gif);
        background-position: center;
        background-size: contain;
    }

    header
    {
        display:         block;

        width: 83%;
        height: auto;
    }

    header .logo
    {
        display: block;
        width: 121.5px;
        height: 63px;
        margin-top: 32.5px;
        background: url(../images/header_logo_sp.png);
        background-size: 121.5px 63px;
    }

    header .menuhum_sp
    {
        display: block;
    }

    header .menuhum_sp ul
    {
        display: block;
        margin-left: 21.5px;
        height: 0;
        overflow: hidden;
    }

    header .menuhum_sp li
    {
        margin-bottom: 15px;
    }

    header .menuhum_sp li img
    {
        padding-left: 1px;
        padding-right: 1px;
        padding-top: 2px;
        padding-bottom: 2px;
    }

    header #humclick
    {
        cursor: pointer;
        width: 40%;
        margin-top: 23.5px;
        margin-bottom: 16.5px;
    }
    header #humclick img
    {
        width: 9px;
        height: 6.5px;
        vertical-align:middle;
        margin-left: 1.5px;
        margin-right: 9.5px;
        margin-top: 1px;
    }

    header #humclick span
    {

    }
    header #humclick span img
    {
        padding-left: 1px;
        padding-right: 1px;
        padding-top: 2px;
        padding-bottom: 2px;
        vertical-align:middle;
        background-color: #FFFFFF;
    }

    header nav
    {
        display: none;
    }

    footer
    {
        /* before Android4.3 iOS6:Safari */
        font-size: 1.1125rem;

        display: block;
        width: 83%;
        height: auto;

        padding-bottom: 38px;
        padding-top: 43px;
        border-top: 1px solid #000000;

        -webkit-flex-flow: row nowrap;
        -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    footer a.item_logo_pc
    {
        display: none;
    }
    footer a.item_logo_sp
    {
        display: block;
        width: 152px;
        height: 79px;
        margin: auto;
        margin-top: 20px;

        background: url(../images/footer_logo_sp.png) no-repeat left 0;
        background-size: contain;
    }

    footer div.item_copy
    {
        display: block;

        float: none;

        width: 90px;
        height: 7.5px;
        margin-top: 0;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 54px;


        background: url(../images/footer_copy_sp.png) no-repeat;
        background-size: 90px 7.5px;
    }

    footer .footermenu
    {
        display: block;
        width: 90px;
        margin-top: 0;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 38px;
    }

    footer .footermenu li a
    {
        display: block;
    }

    footer .footermenu  a
    {
        margin: 0;
        width: 100%;
        height: auto;
        padding-top: 14px;
        padding-bottom: 14px;
    }

    footer .nomenu
    {
        margin: 0;
        width: 100%;
        height: auto;
        padding-top: 14px;
        padding-bottom: 14px;
    }
}
