/* ==========================================================================
 *
 * Mobile Devices
 *
 * -------------------------------------------------------------------------- */
body
{
    font-size: 16px;
    line-height: 1.5rem;

    color: #333;
}

a
{
    text-decoration: none;

    color: #e62e8b;
}
a.btn
{
    font-size: 14px;

    display: inline-block;

    padding: .75rem 1.5rem;

    -webkit-transition: all .6s ease-in-out;
            transition: all .6s ease-in-out;
    text-align: center;
    white-space: nowrap;
    text-decoration: none;

    color: #fff;
    background-color: #e62e8b;
}

hr
{
    margin: 1.5rem 0;

    border-bottom: 1px solid rgba(172, 55, 139, .3);
}

.bold
{
    font-weight: bold;
}

.mt
{
    margin-top: 1.5rem;
}

.mb
{
    margin-bottom: 1.5rem;
}

.ml
{
    margin-left: 5%;
}

.mr
{
    margin-right: 5%;
}

::-moz-selection
{
    color: #333;
    background-color: rgba(230, 46, 139, .2);
}

::selection
{
    color: #333;
    background-color: rgba(230, 46, 139, .2);
}

::-moz-selection
{
    color: #333;
    background-color: rgba(230, 46, 139, .2);
}

#load
{
    position: fixed;
    z-index: 3;
    top: 0;
    left: 0;

    overflow: hidden;

    width: 100%;
    height: 100vh;

    background: #e62e8b url(../images/loader.gif) center center no-repeat;
    background-size: 200px 150px;
}

#container
{
    position: fixed;

    background: url(../images/bg-sub.jpg) repeat;
    background-size: cover;
}
#container.active
{
    position: relative;
}
#container.-top
{
    background-image: url(../images/bg-sub-top.jpg);
}

/* home */
.pc
{
    display: none;
}

.sp .nav-trigger
{
    position: absolute;
    top: .75rem;
    left: 5%;

    display: block;

    width: 48px;
}

.sp .twitter
{
    position: absolute;
    top: 0;
    right: 5%;

    display: block;

    width: 72px;
}

#main-sp
{
    position: relative;

    width: 100%;
    margin: auto;
    padding-bottom: 1.5rem;

    background: url(../images/bg-main-sp.jpg) center top no-repeat;
    background-size: cover;
}
#main-sp.pre
{
    background-image: url(../images/bg-main-sp-pre.jpg);
}
#main-sp.pre .main
{
    height: 175vw;
}
#main-sp .main
{
    display: block;

    width: 100%;
    margin: auto;
}
#main-sp .tvtokyo
{
    display: block;

    width: 198px;
    margin: auto;
}

#nav-sp
{
    position: fixed;
    z-index: 2;
    left: -100%;

    display: block;

    width: 100%;
    height: 100vh;
    padding: 3rem 0;

    background-color: #e62e8b;
}
#nav-sp li
{
    margin-bottom: .75rem;
}
#nav-sp .comingsoon
{
    opacity: .5;
}
#nav-sp.active
{
    left: 0;

    display: block;

    -webkit-transition: all .6s ease-in-out;
            transition: all .6s ease-in-out;
}

#bnr
{
    position: relative;
    z-index: 1;

    padding: .75rem 5% 2.25rem;
}

.slider
{
    overflow-x: hidden;
}

.swiper-pagination-bullet
{
    width: .75rem;
    height: .75rem;
}

.swiper-pagination-bullet-active
{
    background-color: #e62e8b;
}

.swiper-button-prev
{
    margin-left: 5%;
}

.swiper-button-next
{
    margin-right: 5%;
}

#youtube
{
    position: relative;
    z-index: 1;

    padding-top: 2.25rem;
    padding-bottom: 2.25rem;
}
#youtube img
{
    display: block;

    width: 50%;
    max-width: 284px;
    margin: 0 auto .375rem;
}
#youtube ul
{
    margin-bottom: .75rem;
}
#youtube li
{
    position: relative;

    width: 100%;
    padding-top: 56.25%;
}
#youtube li iframe
{
    position: absolute;
    top: 0;
    right: 0;

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

#news h1
{
    background: url(../images/title-news@2x.png) center top no-repeat;
}

#media h1
{
    background: url(../images/title-media@2x.png) center top no-repeat;
}

#event h1
{
    background: url(../images/title-event@2x.png) center top no-repeat;
}

#movie h1
{
    background: url(../images/title-movie@2x.png) center top no-repeat;
}

#goods h1
{
    background: url(../images/title-goods@2x.png) center top no-repeat;
}

#dvd h1
{
    background: url(../images/title-dvd@2x.png) center top no-repeat;
}

#news h1,
#media h1,
#event h1,
#movie h1,
#goods h1,
#dvd h1
{
    height: 218px;

    text-indent: -9999px;

    background-size: 995px 218px;
}

.content
{
    width: 90%;
    margin: 0 auto 1.5rem;
}
.content h2
{
    font-size: 18px;
    font-weight: bold;

    margin-bottom: .75rem;
    padding: .75rem;

    text-align: justify;

    background-color: rgba(230, 46, 139, .2);
}

.list li
{
    margin-bottom: .75rem;
    padding: .75rem;

    border-bottom: 1px solid rgba(172, 55, 139, .3);
    border-radius: 4px;
    background-color: rgba(255, 255, 255, .8);
}
.list li:last-child
{
    margin-bottom: 0;
}

.list a
{
    display: block;
}

.list .date
{
    font-size: 14px;
    font-weight: bold;

    margin-right: .75rem;

    color: #333;
}

.list .tag
{
    font-size: 12px;

    padding: 0 .75rem;

    color: #fff;
    border-radius: .75rem;
    background-color: #ac378b;
}

.list p
{
    margin-top: .75rem;

    text-align: justify;

    color: #333;
}

.list .movie
{
    position: relative;

    width: 100%;
    padding-top: 56.25%;
}

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

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

.list-bnr li
{
    margin-bottom: .75rem;
}
.list-bnr li:last-child
{
    margin-bottom: 0;
}

#media .list .tag
{
    background-color: #e62e8b;
}

/* 2nd */
#bg section
{
    position: relative;

    margin-top: -3rem;
}

#main-sp2
{
    width: 100%;
}
#main-sp2 .logo
{
    width: 100%;
}

.detail
{
    padding: .75rem;

    border-radius: 4px;
    background-color: rgba(255, 255, 255, .8);
}

.text
{
    padding: 1.5rem .75rem;
}
.text iframe
{
    max-width: 100%;
}

.pager
{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;

    width: 90%;
    margin: 3rem auto;

    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
            justify-content: space-between;
}
.pager img
{
    display: block;

    height: 2.25rem;
}
.pager ul
{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;

    width: 50%;

    -webkit-justify-content: space-around;
    -ms-flex-pack: distribute;
            justify-content: space-around;
}

.back
{
    width: 90%;
    margin: 1.5rem auto;
}
.back img
{
    height: 2.25rem;
    margin-right: .375rem;
}

#nav-sub-sp
{
    display: block;

    width: 90%;
    height: 3rem;
    margin: 0 auto 1.5rem;

    text-indent: 15px;
    text-overflow: '';

    color: #e62e8b;
    border: 1px solid rgba(172, 55, 139, .3);
    border-radius: 4px;
}

#dvd .wrap
{
    margin: 0 .75rem;
    padding: 2.25rem 0;

    border-top: 1px dashed #ddd;
}

#dvd .sub
{
    padding-bottom: 1.5rem;

    text-align: center;
}
#dvd .sub li
{
    padding-top: .75rem;
}

#dvd h3
{
    font-size: 16px;
    font-weight: bold;

    margin-bottom: 1.5rem;
}

#dvd .main p
{
    font-size: 14px;

    padding-bottom: 1.5rem;
}

#dvd ol
{
    font-size: 14px;

    margin-bottom: 2rem;

    list-style: none;
}
#dvd ol img
{
    margin-left: .375rem;
}

#dvd #nav-sub-sp
{
    font-weight: bold;

    color: #3c19c3;
    border-color: #7248dd;
    background-color: #7248dd;
    text-shadow: #fff 1px 1px 0, #fff -1px -1px 0,
    #fff -1px 1px 0, #fff 1px -1px 0,
    #fff 0 1px 0, #fff  0 -1px 0,
    #fff -1px 0 0, #fff 1px 0 0;
}

.tab
{
    display: none;

    width: 90%;
    margin: 0 auto 1.5rem;

    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
            justify-content: space-between;
}
.tab li
{
    width: 32%;

    -webkit-flex-shrink: 0;
    -ms-flex-negative: 0;
            flex-shrink: 0;
}
.tab a
{
    display: block;
    overflow: hidden;

    border: 2px solid #7248dd;
    border-radius: 10px;
    background-color: #e3daf8;
}
.tab a.on
{
    background-color: #7248dd;
}
.tab img
{
    display: block;
}

.sub-title
{
    font-size: 16px;
    font-weight: bold;

    width: 90%;
    margin: 0 auto;
    padding: 0 1.5rem .75rem;
}

.buy
{
    line-height: 2.125rem;

    display: block;

    text-align: center;

    color: #fff;
    border: 2px solid #e62e8b;
    border-radius: 1.125rem;
    background-color: #e62e8b;
}

.list-image
{
    font-size: 14px;

    text-align: center;
}
.list-image li
{
    padding-bottom: 1.5rem;

    list-style: none;
}
.list-image figcaption
{
    padding: .75rem;
}

/* footer */
.sns-list
{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;

    width: 90%;
    margin: 0 auto;
    padding: .75rem 0;

    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
            justify-content: center;
}
.sns-list li
{
    margin: 0 .375rem;
}

#footer
{
    background-color: #b951a0;
}

.bnr-list
{
    padding: .75rem 5%;

    background-color: #a8388a;
}
.bnr-list li
{
    margin-bottom: .75rem;
}
.bnr-list li:last-child
{
    margin-bottom: 0;
}

.series-list
{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;

    padding: .75rem 2.5%;

    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-justify-content: space-around;
    -ms-flex-pack: distribute;
            justify-content: space-around;
}
.series-list li
{
    margin-bottom: .75rem;

    -webkit-flex-basis: 30%;
    -ms-flex-preferred-size: 30%;
            flex-basis: 30%;
}
.series-list li:nth-child(n+2):last-child
{
    margin-right: 32.5%;
}
.series-list li:last-child
{
    margin-bottom: 0;
}

.userdata
{
    padding: 1.5rem 0 0;

    text-align: center;
}

.userdata a
{
    font-size: 10px;

    color: #fff;

    text-decoration: underline;
}

.copyright
{
    font-size: 10px;

    padding: 0 0 1.5rem;

    text-align: center;

    color: #fff;
}

.vbox-container
{
    overflow: hidden;
}

.figlio
{
    display: inline-block;
}

.list-buy
{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;

    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
            justify-content: center;
}
.list-buy li
{
    padding: .75rem;
}

.modal-content
{
    padding: 1.5rem 5%;
}
.modal-content h2
{
    font-size: 18px;
    font-weight: bold;

    margin-bottom: .75rem;
    padding: .75rem;

    text-align: justify;

    background-color: rgba(230, 46, 139, .2);
}
.modal-content .swiper-wrapper
{
    height: auto;
}
.modal-content .swiper-slide
{
    height: auto;
}
.modal-content .main-column
{
    padding-bottom: 1.5rem;

    text-align: center;
}

#modal-sub-image
{
    padding-top: 1.5rem;
}
#modal-sub-image li
{
    width: 25%;
    padding: 0 .75rem;
}

.player
{
    margin: 0 0 0 .375rem;
}

.player .switch
{
    width: 70px;
    height: 18px;
    margin: 0;
    padding: 0;

    text-align: center !important;
    vertical-align: middle;

    border-radius: 9px;
    background: -webkit-linear-gradient(#eb5ca4, #e62e8b);
    background:         linear-gradient(#eb5ca4, #e62e8b);
}

/* ==========================================================================
 *
 * Desktops
 *
 * -------------------------------------------------------------------------- */
@media only screen and (min-width: 769px)
{
    body
    {
        min-width: 1152px;
    }
    a:hover
    {
        color: #e62e8b;
    }
    a:hover img
    {
        -webkit-transition: all .6s ease-in-out;
                transition: all .6s ease-in-out;
        text-decoration: none;

        opacity: .8;
    }
    /* home */
    .sp
    {
        display: none;
    }
    .pc
    {
        display: block;
    }
    #main-pc
    {
        position: relative;

        height: 93rem;

        background: url(../images/bg-main@2x.jpg) center top no-repeat;
        background-size: 1600px;
    }
    #main-pc.pre
    {
        background-image: url(../images/bg-main-pre@2x.jpg);
    }
    #main-pc.pre .tvtokyo
    {
        top: 22.35rem;
    }
    #main-pc .twitter
    {
        position: absolute;
        top: 0;
        left: 31.5rem;

        display: block;

        width: 72px;
        margin-left: 50%;
    }
    #main-pc .tvtokyo
    {
        position: absolute;
        top: 23.4375rem;
        right: 7.5rem;

        width: 198px;
        margin-right: 50%;
    }
    #main-pc #nav
    {
        position: absolute;
        top: 42rem;

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

        width: 100%;

        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
                justify-content: center;
    }
    #main-pc #nav li
    {
        margin: 0 .75rem;

        -webkit-flex-basis: 168px;
        -ms-flex-preferred-size: 168px;
                flex-basis: 168px;
    }
    #bnr
    {
        position: absolute;
        top: 27rem;
        right: 8.25rem;

        width: 470px;
        margin-right: 50%;
        padding: 0 0 2.25rem;
    }
    .swiper-button-prev,
    .swiper-button-next
    {
        margin: 0;
    }
    #youtube
    {
        overflow-x: hidden;

        width: 816px;
        margin: -42rem auto 0;
        padding-top: 0;
    }
    #youtube li
    {
        padding: 0;
    }
    #youtube li iframe
    {
        position: relative;

        width: 816px !important;
        height: 459px !important;
    }
    #news,
    #media,
    #movie
    {
        width: 1152px;
        margin: 0 auto;
        padding-top: 3rem;
    }
    .content
    {
        width: 816px;
    }
    .content h2
    {
        font-size: 24px;
        line-height: 2.25rem;

        padding: 1.5rem;
    }
    .list li
    {
        padding: 1.5rem;
    }
    .list a:hover p
    {
        color: #e62e8b;
    }
    .img
    {
        width: 294px;
        margin: 1.5rem auto 0;
    }
    /* 2nd */
    #bg
    {
        background: url(../images/bg-main2@2x.jpg) center top no-repeat;
        background-size: 1600px;
    }
    #bg .twitter
    {
        position: absolute;
        top: 0;
        left: 31.5rem;

        display: block;

        width: 72px;
        margin-left: 50%;
    }
    #bg #nav
    {
        position: absolute;
        top: 12rem;

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

        width: 100%;
        min-width: 1152px;

        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
                justify-content: center;
    }
    #bg #nav li
    {
        margin: 0 .75rem;

        -webkit-flex-basis: 168px;
        -ms-flex-preferred-size: 168px;
                flex-basis: 168px;
    }
    .logo
    {
        display: block;

        width: 311px;
        margin: 0 auto;
        padding: 1.5rem 0 9rem;
    }
    .detail
    {
        padding: 1.5rem;
    }
    .text
    {
        padding: 3rem;
    }
    .text a
    {
        text-decoration: underline;
    }
    .text a:hover
    {
        color: #ac378b;
    }
    .pager
    {
        width: 816px;
    }
    .back
    {
        width: 816px;
    }
    #nav-sub
    {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display:         flex;

        width: 816px;
        margin: 0 auto;
        padding-bottom: 1.5rem;

        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
                justify-content: space-between;
    }
    #nav-sub li
    {
        width: 15%;
    }
    #nav-sub a
    {
        line-height: 2.125rem;

        display: block;

        -webkit-transition: all .6s ease-in-out;
                transition: all .6s ease-in-out;
        text-align: center;

        color: #fff;
        border: 2px solid #e62e8b;
        border-radius: 1.125rem;
        background-color: #e62e8b;
    }
    #nav-sub a.on,
    #nav-sub a:hover
    {
        color: #e62e8b;
        background-color: #fff;
    }
    #nav-sub-sp
    {
        display: none;
    }
    #dvd .wrap
    {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display:         flex;

        margin: 0 3rem;
    }
    #dvd .sub
    {
        width: 200px;
        margin-right: 3rem;

        -webkit-flex-shrink: 0;
        -ms-flex-negative: 0;
                flex-shrink: 0;
    }
    #dvd h3
    {
        font-size: 16px;
        font-weight: bold;

        margin-bottom: 1.5rem;
    }
    #dvd .main p
    {
        font-size: 14px;

        padding-bottom: 1.5rem;
    }
    .tab
    {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display:         flex;

        width: 816px;
        margin-bottom: 2.25rem;
    }
    .tab li
    {
        width: 250px;
    }
    .tab a
    {
        -webkit-transition: all .6s ease-in-out;
                transition: all .6s ease-in-out;
    }
    .tab a:hover
    {
        background-color: #7248dd;
    }
    .sub-title
    {
        font-size: 20px;

        width: 816px;

        text-align: center;
    }
    .buy
    {
        -webkit-transition: all .6s ease-in-out;
                transition: all .6s ease-in-out;
    }
    .buy:hover
    {
        color: #e62e8b;
        background-color: #fff;
    }
    .list-image
    {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display:         flex;

        -webkit-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
                flex-wrap: wrap;
    }
    .list-image li
    {
        width: 33.33333%;
        padding: .75rem;
    }
    /* footer */
    .sns-list
    {
        margin-top: 3rem;

        -webkit-box-pack: start;
        -webkit-justify-content: flex-start;
        -ms-flex-pack: start;
                justify-content: flex-start;
    }
    .bnr-list
    {
        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;
    }
    .bnr-list li
    {
        margin: 0 .75rem;

        text-align: center;

        -webkit-flex-basis: 288px;
        -ms-flex-preferred-size: 288px;
                flex-basis: 288px;
    }
    .series-list
    {
        width: 1152px;
        margin: auto;

        -webkit-flex-wrap: nowrap;
            -ms-flex-wrap: nowrap;
                flex-wrap: nowrap;
        -webkit-box-pack: start;
        -webkit-justify-content: flex-start;
        -ms-flex-pack: start;
                justify-content: flex-start;
    }
    .series-list li
    {
        margin-right: .75rem;

        -webkit-flex-basis: auto;
        -ms-flex-preferred-size: auto;
                flex-basis: auto;
    }
    .series-list li:nth-child(n+2):last-child
    {
        margin-right: 0;
    }
    .modal-body
    {
        min-width: 0;
    }
    .modal-content
    {
        padding: 1.5rem;
    }
    .modal-content .wrap
    {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display:         flex;

        max-width: 816px;
        margin: 0 auto;
    }
    .modal-content .main-column
    {
        width: 50%;
    }
    .modal-content .sub-column
    {
        width: 50%;
    }
}

/* ==========================================================================
 *
 * Print
 *
 * -------------------------------------------------------------------------- */
@media print
{
    *
    {
        color: black !important;
        border-color: black !important;
        background: transparent !important;
        box-shadow: none !important;
        text-shadow: none !important;
    }
    #nav,
    .nav-trigger,
    .nav,
    .foot-col,
    .sns,
    #pagetop
    {
        display: none;
    }
    #footer::after
    {
        content: '';
    }
}
