@charset "utf-8";

/* clearfix */
.cf {
    zoom: 1;
}

.cf:before,
.cf:after {
    content: "";
    display: table;
}

.cf:after {
    clear: both;
}

html {
    font-size: 100%;
    color: #212121;
}

img {
    vertical-align: bottom;
}

.scroll-up {
    opacity: 0;
    visibility: hidden;
    transform: translateY(50px);
    transition: all 1s;
}

.scroll-up.is-show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0px);
}

/*ページ内リンク調整*/
#booth-caution-link_kaijo:before {
    content: "";
    display: block;
    height: 100px;
    /* 調整したい高さ（固定ヘッダーの高さ） */
    margin-top: -100px;
    /* heightと同じ分のネガティブマージン */
    visibility: hidden;
}


#booth-caution-link_ec:before {
    content: "";
    display: block;
    height: 100px;
    /* 調整したい高さ（固定ヘッダーの高さ） */
    margin-top: -100px;
    /* heightと同じ分のネガティブマージン */
    visibility: hidden;
}



/* /_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_
 全デバイス共通とPC向け 960px以上　1024px以上は固定
/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/


a {
    color: red;
    text-decoration: underline;
}

/* パソコンでは"pc"のclassがついた画像が表示 */
.pc {
    display: block !important;
}

.sp {
    display: none !important;
}



/* パソコンでは"pc-br"のclassがついた改行が効く */
.pc-br {
    display: block !important;
}

.sp-br {
    display: none !important;
}


.hr-sp {
    display: none !important;
}


body {
    width: 100%;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    background-color: black;
    color: #000;
}

.heading {
	position: relative;
	text-align: center;
	border-bottom: 5px solid orangered;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-weight: 900;
    font-size: 25px;
    padding-bottom: 10px;
	font-size: 35px;
    width: 80%;
    margin: 0 auto 10px auto;
}

.preopen {
    background-color: #FFF;
    text-align: center;
    padding: 15px;
}

.preopen p {
    font-weight: bold;
}



/*~~~~~~~~~~~~~~~~~~~~~~~~~
nav
~~~~~~~~~~~~~~~~~~~~~~~~~~*/


.nav_ex {
    display: none;
}

.goods {
    border: 0px solid green;
    width: 100%;
}


.nav-container {
    margin: 0px auto 0px auto;
    padding: 12px 0px 12px 0px;
    background-color: #FFF;
    text-align: center;
    border: solid 0px red;
    display: flex;
    width: 100%;
    justify-content: center;
    align-items: center;
    position: sticky;
    top: 0px;
    z-index: 100;
}

.nav-item {
    margin-right: 5px;
    border: solid 1px #000;
}


.nav-item img {
    width: 138px;
    border: solid 0px orange;

}

/*
.hqimg img {
    width: 160px;
    margin-top: 5px;
    border: 0px solid red;
}*/

/*~~~~~~~~~~~~~~~~~~~~~~~~~
main
~~~~~~~~~~~~~~~~~~~~~~~~~~*/

.top-img_Cont {
    width: 100%;
    padding-top: 15px;
    margin: 0 auto;
    margin-top: 0;
    text-align: center;
    border: 0px solid green;
    background-image: url(../bg3.jpg?2);
    background-repeat: no-repeat;
    background-size: cover;
    background-origin: center;
    background-attachment: fixed;

}

.jflogo img {
    width: 300px;
    border: 0px solid red;
    margin: 0px auto 20px auto;
    display: block;
}

.top1 img {
    width: 1000px;
    border: 0px solid red;
    margin: 0 auto 20px auto;
}


.flame {
    width: 1000px;
    /*width: 90%;*/
    background: #fff;
    /*padding: 0.5em;*/
    margin: 0 auto 50px auto;
    text-align: center;
    padding-bottom: 30px;
    border: 0px solid red;
}

.flame-title {
    /*font-size: 1.3em;*/
    width: 100%;
    height: auto;
    background: #000;
    color: #FFF;
    text-align: center;
    margin: 0;
    padding: 0.5em;
    /*height: 65px;*/
    border: 0px solid red;
    box-sizing: border-box;
}


.flame-title img {
    width: 45%;
    max-width: 100%;
    height: auto;
    text-align: center;
    margin: 0 auto;
}


.sale-caution-red {
    font-size: 0.7em;
    color: red;
}


.outline-wrapper {
    outline: 0px solid red;
    /*background-color: #eee;*/
    background-color: #FFF;
    width: 100%;


}


.outline-wrapper h4 {
    font-size: 18px;
    width: 100%;
    margin: 20px auto;
}

.outline {
    border: 0px solid gray;
    outline: 0px solid red;
    text-align: left;
    margin: 0 auto;
    padding: 25px 35px;
    width: 78%;
    background-color: #eee;
}

.outline-midashi {
    border-left: solid 5px orangered;
    padding: 5px 0px 5px 10px;
    /*background-color: #FFF000;*/
    color: orangered;
    font-weight: bold;
    font-size: 17px;
    margin-bottom: 8px;
}

.outline-midashi .title {
    font-weight: bold;
    font-size: 19px;

}

.outline_txt {
    margin-top: 10px;
    font-weight: bold;
}

.outline_txt p {
    font-size: 14px;
    margin-bottom: 10px;

}

.outline_txt li {
    list-style: none;
    padding-bottom: 5px;

}


/* menu design */

table {
    font-size: 15px;
    margin-bottom: 5px;
    width: 90%;
}

.tbl-r02 th {
    border-bottom: dashed 1px #555;
    padding: 8px;
}

.tbl-r02 td {
    border-bottom: dashed 1px #555;
    padding: 10px;
}


.tbl-r02 td::before {
    content: "｜　";
}

.outline_txt .outline-caution {
    font-size: 0.7em;
    font-weight: normal;

}


/*
.flame h4 {
    font-size: 1.2em;
    width: 100%;
    margin-bottom: 8px;
    margin-top: 15px;
}

.sale-midashi {
    font-weight: bold;
    font-size: 1em;
    margin-bottom: 3px;

}

.sale-explain {
    font-weight: bold;
    font-size: 0.9em;
    margin-bottom: 10px;
}

.sale-day {
    font-weight: bold;
    border: 2px solid #000;
    font-size: 0.9em;
    margin: 10px auto;
    padding: 10px;
    width: 80%;
    text-align: left;
}

.sale-box {
    width: 80%;
    margin: 0 auto;
    padding: 15px;
    background-color: #eeeeee;
}

.sale-day li {
    list-style: none;
    padding-bottom: 5px;
}*/
/*
.sale-caution-black {
    font-weight: normal;
    font-size: 0.8em;
    color: black;
    padding-bottom: 5px;
}*/




h1 {
    font-family: 'M PLUS 1p', sans-serif;
    color: #fff;
    margin-bottom: 0px;
    /*background-color: #00BCD4;第一候補*/
    background-color: #00BCD4;
    padding: 0.5em;
    display: inline-block;
    width: 100%;
    line-height: 1.5em;
}


.yoyaku {
    margin: 0px auto;
    text-align: center;
    width: 60%;
    background-color: #FFF;
    border: 0px solid #008E9E;
    padding: 10px 0 10px 0;
    color: #212121;
    /*box-shadow: 6px 6px #212121;*/
    /*box-shadow: 10px 10px #008E9E;*/
}

.flame-inner {
    margin: 0 auto;
}


.intro {
    /*width:60%;*/
    font-size: 1rem;
    font-weight: bold;
    margin: 0px auto;
    line-height: 1.8rem;
    border: 0px solid red;

}

.yoyaku_inner {
    /*background-color: rgb(97,207,240,0.5);*/
    border-radius: 0px;
    margin: 0 auto;
    border: 0px solid red;

}

.texts {
    font-size: 0.8rem;
    line-height: 1.2rem;
    border: 0px solid red;
    margin: 0 auto;
}

.texts-red {
    color: red;
    font-size: 0.8rem;
    line-height: 1.2rem;
    border: 0px solid red;
    margin: 10px auto 0 auto;

}


/* good START */



.goods-wrapper {
    width: 90%;
    background-color: #FFF;
    margin: 0 auto 20px auto;
    border: 0px solid green;
    padding: 30px 0px 30px 0px;
}

.goods-wrapper-logo {
    text-align: center;
}

.goods-wrapper-logo img {
    width: 250px;
    margin: 0px auto 25px auto;
    border: 0px solid red;
}




/* 親要素(アイテム) */
.flex-container {
    margin: 0 auto 50px auto;
    width: 90%;
    /*height:1300px;*/
    border: 0px solid red;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    /*align-items: stretch;*/
    align-content: center;
}

/* 子要素(アイテム) */






.flex-item {
    /*background-color: #fff;*/
    color: #000;
    width: 285px;
    /*height: 580px;
    リンクあり*/
    height: 530px;
    /*リンクなし*/
    border: 1px solid #000;
    /*border: 1px solid #333;*/
    /*border: 5px solid #b2dde1;*/
    /*border: 5px solid #c2edf1;*/
    text-align: center;
    margin: 5px 8px 10px 0px;
    position: relative;
}


.goods_name {
    font-size: 1rem;
    width: 85%;
    margin: 10px auto 5px auto;
    font-weight: bold;
    line-height: 1.5em;
    border: 0px solid red;
    text-align: left;
}

.tag {
    font-size: 0.7rem;
    letter-spacing: 1px;
    color: #fff;
    padding: 0px 7px;
    /*padding: 2px 5px 0px 5px;*/
    margin-bottom: 5px;
    display: inline-block;

}

.trading {
    background-color: #29A7E1;
    margin-right: 5px;
}


.ec_gentei {
    background-color: #ee1c18;
}


.kikan_gentei {
    color: #fff;
    background-color: #9948C8;
    font-size: 0.7em;
    padding: 2px 8px;
}


.goods_img img {
    border: 0px solid red;
    width: 100%;

}




.goods_price {
    font-size: 0.9rem;
    width: 85%;
    /*height:93px;*/
    margin: 5px auto 0px auto;
    font-weight: bold;
    text-align: left;
    border: 0px solid red;
}



.caution {
    color: red;
    font-size: 0.77em;
    ;
    width: 100%;
    text-align: left;
    line-height: 1.5em;
    font-weight: normal;
    border: 0px solid blue;
    margin-top: 5px;
    display: block;

}


/*後日追加：詳細はこちらボタン*/
.btn {
    /*background-color: #FD7C04;*/
    /*background-color: #00BCD4;*/
    background-color: #fd5604;
    border-radius: 7px;
    padding: 8px;
    width: 90%;
    margin: 0px auto 0 auto;
    color: #FFF;
    /*color: #333333;*/
    border: 0px solid red;
    font-size: 0.9rem;
    position: absolute;
    bottom: 15px;
    left: 50%;
    transform: translateX(-50%);
    font-weight: bold;

}


.btn:hover {
    background-color: #ff8c21;
    -webkit-transition: all 0.6s ease;
    -moz-transition: all 0.6s ease;
    -o-transition: all 0.6s ease;
    transition: all 0.6s ease;
}


.item-caution {
    width: 70%;
    padding: 20px auto 0 auto;
    font-size: 0.8rem;
    line-height: 1.7em;
    margin: 20px auto 0 auto;
    text-align: left;
    border: 0px solid #000;

}




/* good END */


/* TOHO animechannel */



.booth-caution {

    margin: 15px auto 0 auto;
    width: 900px;
    padding: 30px;
    background-color: #FFF;
    border: 0px solid green;
    font-size: 0.8rem;
}

.booth-caution-midashi {
    font-weight: bold;
    font-size: 1.1rem;
}


.booth-caution-text {
    font-size: 0.9rem;
}


.booth-caution-text-red {
    font-size: 0.9rem;
    color: black;
}

.pay-guide img {
    width: 400px;
    border: 0px solid red;
    margin: 8px 0px;
}

.map {
    margin-top: 30px;
    border: 1px solid red;
}

.tas-link {
    text-align: center;
    margin: 40px auto 0px auto;
}

.tas-link img {
    width: 350px;
    text-align: center;
}




/*~~~~~~~~~~~~~~~~~~~~~~~~~
footer
~~~~~~~~~~~~~~~~~~~~~~~~~~*/
footer {
    text-align: center;
    margin: 10px auto 0 auto;
    /*margin: 50px auto 0 auto;本アップ時*/
    width: 100%;
    color: #FFF;
    /*background-color: #00BCD4;*/
    background-color: #000;
}

.copyright {
    border: 0px solid red;
    padding: 10px 0;
    font-size: 0.5rem;
    line-height: 1rem;

}





/*~~~~~~~~~~~~~~~~~~~~~~~~~
ページTOP
~~~~~~~~~~~~~~~~~~~~~~~~~~*/
#page_top {
    width: 90px;
    height: 90px;
    position: fixed;
    right: 0;
    bottom: 50px;
    opacity: 0.7;
    border: 0px solid red;
}

#page_top a {
    position: relative;
    display: block;
    width: 90px;
    height: 90px;
    text-decoration: none;
}

#page_top a::before {
    /*font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f102';
    font-size: 25px;*/
    color: gray;
    content: '';
    display: inline-block;
    background-image: url(../top.png);
    position: absolute;
    width: 18px;
    height: 18px;
    top: -20px;
    background-size: contain;
    /*vertical-align: middle;*/
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}

#page_top a::after {
    content: 'PAGE TOP';
    font-size: 12px;
    font-weight: bold;
    position: absolute;
    top: 45px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
    color: gray;
}



/* /_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_
 タブレット向け：560px～959px
/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/
@media screen and (max-width: 959px) {



    body {
        background-repeat: repeat;
        background-size: contain;
    }

    .jflogo img {
        border: 0px solid red;
    }


    .top1 img {
        width: 95%;
        border: 0px solid red;
    }


    .midashi-left {
        display: inline-block;
    }


    h1 {
        border: 0px solid red;
        padding: 0px 0 10px 0;
    }



    .heading {
	    font-size: 30px;
        width: 95%;
    }


    /*nav*/



    .nav-container {
        margin: 20px auto 20px auto;
        padding: 12px 0px 5px 0px;
        background-color: #FFF;
        text-align: center;
        border: solid 0px red;
        display: flex;
        flex-wrap: wrap;
        width: 100%;
        justify-content: center;
        align-items: center;
        top: 0px;
        z-index: 100;
    }

    .nav-item {
        margin-right: 5px;
        margin-bottom: 5px;
        border: solid 1px #000;
    }


    .nav-item img {
        width: 138px;
        border: solid 0px orange;

    }


    .nav_ex {
        display: block !important;
        border: solid 0px red;
        text-align: center;
        margin: 0 auto 30px auto;
        font-size: 1em;
        line-height: 1.5em;
        font-weight: bold;

    }


    .flame {
        width: 95%;
        margin: 0 auto 0px auto;
    }


    .flame h4 {
        font-size: 1em;
    }


    .sale-midashi {
        font-size: 1em;

    }

    .sale-explain {
        font-weight: bold;
        font-size: 0.9em;
        margin-bottom: 10px;
    }

    .sale-box {
        width: 90%;
        margin: 0 auto;
        padding: 15px;
    }


    .sale-day {
        width: 95%;
    }


    .yoyaku {
        width: 80%;
    }

    .anime-channel-midashi {

        width: 90%;
    }



    .channel-image-sche {
        width: 100%;
        border: 0px solid red;
    }


    .channel-image-sche img {
        border: 0px solid red;
        width: 95%;
    }



    .channel-image-tenji {
        width: 100%;
    }



    .channel-image-tenji img {
        border: 0px solid blue;
        width: 95%;
    }


    .goods-wrapper {
        width: 95%;
        margin: 0 auto;
    }

    .booth-caution {
        width: 95%;
        font-size: 0.8rem;
    }



    .flex-container {
        width: 100%;
    }

    .flex-item {
        width: 30%;
    }



}

/* /_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_
 スマートフォン向け：560px未満
/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

@media screen and (max-width: 559px) {




    body {
        background-repeat: repeat;
        background-size: contain;
    }



    /* スマートフォンでは"sp"のclassがついた画像が表示 */
    .pc {
        display: none !important;
    }

    .sp {
        display: block !important;
    }



    /* スマートフォンでは"sp-br"が改行される */
    .pc-br {
        display: none !important;
    }

    .sp-br {
        display: block !important;
    }


    .texts {
        font-size: 0.6em;
        line-height: 1.5em;
        width: 80%;
    }


    .texts-red {
        color: red;
        font-size: 0.6rem;
        line-height: 1rem;
        border: 0px solid red;
        margin: 10px auto 0 auto;

    }



    /*~~~~~~~~~~~~~~~~~~~~~~~~~
    メイン
    ~~~~~~~~~~~~~~~~~~~~~~~~~~*/

    .top-img_Cont {
        margin: 0 auto 10px auto;
        background-size: contain;

    }


    .jflogo img {
        width: 200px;
        border: 0px solid green;
        margin: 10px auto 10px auto;
    }


    .top1 img {
        width: 100%;
        border: 0px solid red;
        margin: 0 auto 0px auto;
    }

    h1 {
        border: 0px solid red;
        width: 100%;
    }

        

    .outline-wrapper {
        width: 100%;


    }


    .outline {
        outline: 0px solid red;
        padding: 0.5em;
        width: 85%;
    }


    .outline-midashi {
        font-size: 12px;
    }


    .outline-midashi .title {
        font-weight: bold;
        font-size: 17px;

    }




    .flame {
        width: 100%;
        background: #fff;
        /*padding: 0.5em;*/
        margin: 0 auto 0x auto;
        text-align: center;
    }

    .flame-title {
        /*font-size: 1.3em;*/
        width: 100%;
        background: #000;
        color: #FFF;
        text-align: center;
        margin: 0 auto;
        padding: 10px;
        height: auto;
        border: 0px solid red;
    }

    .flame-title img {
        width: 80%;
        margin: 0px auto;
        text-align: center;
        border: 0px solid red;
    }

    .flame h4 {
        font-size: 15px;
        width: 100%;
        margin-bottom: 0px;
        margin-top: 0px;
        padding: 10px;
    }


    table {
        font-size: 15px;
        margin-bottom: 15px;
        width: 85%;
    }

    .tbl-r02 td::before {
        display: none;
    }

    .tbl-r02 {
        width: 95%;
    }


    .tbl-r02 th {
        border-bottom: dashed 0px #555;
        padding: 0px;
        display: block;
        width: 100%;
    }

    .tbl-r02 td {
        border-bottom: dashed 1px #555;
        padding: 0px 0px 5px 0px;
        display: block;
        width: 100%;
        margin-bottom: 3px;
    }


    .sale-explain {
        font-weight: bold;
        font-size: 0.8em;
        margin-bottom: 10px;
    }


    .heading {
	    font-size: 18px;
        width: 100%;
        border-bottom: 3px solid orangered;
    }

        
    .preopen p {
        font-size: 12px;
    }




    .nav-container {
        margin: 10px auto 0px auto;
        padding: 10px 0;
        background-color: #FFF;
        text-align: center;
        border: solid 0px yellow;
        display: flex;
        flex-wrap: wrap;
        width: 100%;
        justify-content: center;
        align-items: center;
    }

    .nav-item {
        margin-right: 5px;
        margin-bottom: 5px;
        border: solid 1px #000;
    }


    .nav-item img {
        width: 110px;
    }



    .tag {
        font-size: 0.5rem;
        color: #fff;
        padding: 0px 5px 0px 5px;
        margin-bottom: 5px;
        display: inline-block;

    }

    .trading {
        background-color: #29A7E1;
        margin-right: 5px;
    }


    .ec_gentei {
        background-color: #ee1c18;
    }



    .goods-wrapper {
        width: 100%;
        padding: 15px 0px 25px 0px;
        border: 0px solid red;
        margin: 0 auto;
    }

    .goods-wrapper-logo img {
        width: 170px;
        margin: 10px auto 25px auto;
        border: 0px solid red;
    }




    /* 親要素(アイテム) */
    .flex-container {
        width: 100%;
        border: 0px solid blue;
        justify-content: space-around;
    }


    .flex-item {
        width: 48%;
        height: 410px;
        /*リンクなし*/
        margin: 0 auto 10px auto;
        border: 1px solid grey;

    }

    /*
    .goods_img {
        width: 100%;
    }*/

    .goods_img img {
        width: 95%;
    }


    .goods_name {
        font-size: 0.9rem;
        width: 90%;
        margin: 10px auto 0px auto;
        border: 0px solid red;
    }



    .goods_price {
        font-size: 0.7rem;
        width: 90%;
        margin: 5px auto 0px auto;
        border: 0px solid red;
    }



    .caution {
        color: red;
        font-size: 0.8em;
        width: 90%;
        text-align: left;
        margin: 8px auto 0px auto;
        border: 0px solid blue;
        display: inline-block;
        line-height: 1.5em;

    }


    /*後日追加：詳細はこちらボタン*/
    .btn {
        border-radius: 5px;
        padding: 5px;
        width: 95%;
        margin: 0px auto 0 auto;
        color: #FFF;
        /*color: #333333;*/
        border: 0px solid red;
        font-size: 0.8rem;
        position: absolute;
        bottom: 15px;
        left: 50%;
        transform: translateX(-50%);

    }

    .hr-sp {
        display: block !important;
        border-top: 5px solid yellow;
        margin-top: 2px;
        width: 80%;
        margin: 0 auto;
    }


    .yoyaku {
        width: 90%;
        margin-top: 10px;
        padding: 15px 15px 15px 15px;
    }

    .intro {
        font-size: 0.8rem;
        line-height: 1.5rem;
    }



    .yoyaku_inner {
        margin: 10px auto 0 auto;
        border: 0px solid red;

    }

    .day {
        font-size: 0.8rem;
        line-height: 1.3rem;
        margin-bottom: 5px;
    }



    .box {
        font-size: 1rem;
        line-height: 1.5rem;
    }




    .booth-caution {
        font-size: 0.7rem;
        margin: 15px auto 0px auto;
        border: 0px solid #333;
        width: 95%;
        padding: 15px;
        line-height: 1.1rem;
    }

    .booth-caution-midashi {
        font-weight: bold;
        font-size: 0.8rem;
    }


    .booth-caution-text {
        font-size: 0.7rem;
    }


    .booth-caution-text-red {
        color: red;
    }


    .pay-guide img {
        width: 98%;
        border: 0px solid red;
        margin: 8px 0px;
    }




    .movie-wrapper {
        width: 90%;
        /*width: 560px;*/
        margin: 0 auto 10px auto;
        border: 0px solid blue;
    }


    .youtube-link {
        border: 0px solid red;
        text-align: center;
        color: #fff;
        width: 90%;
        padding: 8px 10px;
        margin: 0 auto 30px auto;
        font-size: 0.8rem;

    }


    .tas-link img {
        width: 75%;
    }



    /*~~~~~~~~~~~~~~~~~~~~~~~~~
    フッター
    ~~~~~~~~~~~~~~~~~~~~~~~~~~*/

    footer {
        width: 100%;
        border: 0px solid yellow;
    }



    .copyright {
        border: 0px solid red;
        padding: 10px 0;
        font-size: 0.5rem;
    }




}