@charset "utf-8";
/*--基本--*/
:root{
	--font-size:15px;
	--max-width:1200px;
	--color: #717171;/*文字色*/
	--color-hover: #e08691;/*マウスオーバー時の文字色・色を変えない場合は「color」と同値にする*/
    --color-link: #e08691;
    --sub-color:#0a135c;
    --lang-active: red;
	--background: #fff;/*背景*/
    --spec-border: #000;
    --btn:#0b135c;/*ボタンの色*/
    --btn-hover:#fff;/*ボタンの色:hover*/
    --btn-color:#fff;/*ボタンの文字色*/
    --btn-color-hover:#000;/*ボタンの文字色:hover*/
    --btn-max-w:500px;/*ボタンの最大幅*/
    --border-radiue:10px;/*ボタンの角R。角Rにしない時は0・可愛くしたい時は100*/
    --slider-btn: #000;/*スライダー矢印*/
    --slider-page: #000;/*スライダーページネーション*/
}

@media screen and (max-width: 960px){
	:root{
        --font-size:12px;
    }
}


/*-----------
header
-----------*/
header{position: fixed; width: 95%; left: 2.5%; top: 2.5%; backdrop-filter: blur(20px); border-radius: 10px;background: rgba(255,255,255,0.3); color: var(--sub-color);}

/*-----------
mv
-----------*/
#mv{background: url(../images/bg.jpg);position: relative; overflow: hidden; background-size: 100% auto;}
#mv::before{content: "";  background: rgb(255,255,255);background: linear-gradient(0deg, rgba(255,255,255,1) 5%, rgba(255,255,255,0) 100%);width: 100%; height: 100px;position: absolute; bottom: 0; left: 0; z-index: 10;}
#mv .inner{width:98%; max-width: 1500px; margin: 0 auto; padding: calc(2.5% + 30px) 0 0 0;position: relative;z-index: 10;} 
#mv .inner {align-items: center; padding-bottom: 2em;}
#mv .inner .text_area{width: 49.2%;}
#mv h2{text-align: center; font-size: 1.8em; line-height: 1.3;text-shadow: 0 0 10px #fffdc5; color: var(--sub-color); color: #144581;}
#mv .inner h1{margin-top: -1%;}
#mv .inner .data{width: 95%; margin: -6% auto 0;}
#mv .inner .mv_img{width: 51.8%; margin-right: -1%; position: relative;z-index: 20;}

.bg{position: absolute;top: 0; left: 0 ;width: 100%;z-index: 2;  animation: 5s bg_anime infinite; opacity: 2;}

.bg2{position: absolute;top: 0; left: 0 ;width: 100%;z-index: 1; animation: 9s bg_anime2 infinite; opacity: 0;}

@keyframes bg_anime {
    0%{
        opacity: 1;
    }
    50%{
        opacity: 0;
    }
    100%{
        opacity: 1;
    }
}

@keyframes bg_anime2 {
    0%{
        opacity: 0;
    }
    50%{
        opacity: 1;
    }
    100%{
        opacity: 0;
    }
}

.bg-grd{background: linear-gradient(-45deg, rgba(255,255,255,.6), rgba(255,255,255,0) ) fixed;background-size: 800% 800%;animation: GradietionAnimation 9s ease infinite;}
 @keyframes GradietionAnimation { 
     0%{background-position:0% 50%}
     50%{background-position:100% 50%}
    100%{background-position:0% 50%}
    }

/*-----------
article commone
-----------*/
article section{max-width: 1500px; width: 95%; margin: 0 auto;}
.bottom article section{max-width: 1200px; width: 95%; margin: 0 auto;position: relative; z-index: 10; padding-bottom: 5em;}

/*-----------
TOP contents
-----------*/
/*lead*/
#lead p{text-align: center; font-size: 1.1em; color: var(--sub-color);}
#lead a.btn{margin-top: 1em;}
/*cnt*/
#cnt{align-items: stretch; margin-top: 5em; color: var(--color);}
#cnt .box{width: calc(50% - 1em); background: #fff; border-radius: 20px;box-shadow: 0 0 20px #b6bfe9; padding: 2em;flex-direction: column;justify-content:flex-end; position: relative;}
#cnt .box:nth-child(1){background: url(../images/img_box_booth.png) no-repeat;background-position: left 30%;background-size: 60% auto;}
#cnt .box:nth-child(2){background: url(../images/img_box_sales.png) no-repeat;background-position: left 30%;background-size: 60% auto;}
#cnt .box:nth-child(3){background: url(../images/img_box_campaign.png) no-repeat;background-position: left 30%;background-size: 100% auto;margin-top: 2em;}
#cnt .box:nth-child(4){background: url(../images/img_box_livestream.png) no-repeat;background-position: left 30%;background-size: 100% auto;margin-top: 2em;}
#cnt .box:nth-child(2n){margin-left: 2em;}

#cnt .box.wd{margin-left: auto; margin-right: auto;}

#cnt .box/* :nth-child(2) */ .box_inner{align-items: flex-end;width: 100%;}
#cnt .box/* :nth-child(2) */ .text{width: 65%;}
#cnt .box:nth-child(1) .img_box{width: 30%; margin-left: 5%;}
#cnt .box:nth-child(2) .img_box,
#cnt .box:nth-child(3) .img_box/* ,
#cnt .box:nth-child(4) .img_box */{width: 35%;}
#cnt .box:nth-child(4) .text{width: 50%;}
#cnt .box:nth-child(4) .img_box{width: 50%; padding: 2em 0;}

#cnt a.btn{margin-top: 1em; max-width: 100%; width: 100%;}

#cnt .cs{width: 100%; text-align: center; margin: 2em 0 0 0; font-size: 1.5em; font-weight: 600;color: var(--sub-color);}

/*maker*/
#maker {margin-top: 10em;}
#maker.wd {margin-bottom: 10em;}
#maker h3{font-size: 1.5em; text-align: center;line-height: 1;font-weight: 500;}
#maker h3 span.small{font-size: .8em;}
#maker h3.en{line-height: 1.5;}

#maker .flex{margin-top: 1em;justify-content: center;align-items: center;}
#maker .flex a{margin: 1em .5em 0;}

/*media*/
a.media{border: 1px solid #666; padding: 1em 3em 1em 1em; width: 80%;max-width: 600px; margin: 5em auto;display: block; text-align: center;position: relative; color: var(--color);}
a.media::after{content: "";background: url(../images/icon_blank.png) no-repeat; background-size: 100% auto ; background-position: center center; width: 1em; height: 1em; display: block;position: absolute; right: 1em; top: calc(50% - .5em);}
a.media:hover{text-decoration: none;}

/*bnr*/
.bnr_gallery{max-width: 800px; width: 95%; display: block; margin: 0 auto 2em; }

/*thanks*/
#thanks{margin:4em auto 10em;}
#thanks h2{text-align: center;width: fit-content; margin:0 auto .5em;font-size: 3em; line-height: 1.5;/* display: inline-block; */
    background: linear-gradient(90deg, #001998, #2c7ace 60%, #11d7ff);
    background: -webkit-linear-gradient(90deg, #001998, #2c7ace 50%, #11d7ff); -webkit-background-clip: text; background-clip: text;  -webkit-text-fill-color: transparent;}
#thanks p{text-align: center; font-size: 1.5em;font-weight: 600;}
/*-----------
bottom commone
-----------*/
body.bottom{background: url(../images/commone/bg_bottom.jpg) no-repeat; background-position: top center; background-size: 100% auto;}

body.bottom article{padding: calc(2.5% + 57px) 0 0 0; color: var(--sub-color);}
body.bottom article h2{padding: 1em 0 2em; text-align: center; color: var(--sub-color);}

/*header*/
body.bottom header{padding: 10px 20px;}
header .logo_head{width: 250px;}
header .logo_head a{line-height: 0; display: block;}

/*section*/
.bottom_lead{text-align: center; width: 95%; margin: 0 auto;}
.bottom_lead span{font-size: .8em;}
.sub_ttl{border-bottom: 1px solid var(--sub-color); margin-bottom: 1em;}
.h4_ttl{font-weight: 600; margin-top: 1em;}
.h4_ttl + p{margin-bottom: 0.5;}
.h5_ttl {font-size: 1.2em; border-left: 12px solid var(--sub-color); padding: 0 0 0 .5em;line-height: 1.4;}
.h6_ttl {font-size: 1em; margin-top: 1em;}
.h6_ttl:first-of-type{margin-top: 0;}
.caution {width: 95%; font-size: .8em; margin-top: 1em;}
.caution a{ color: var(--color-link);}
.caution{display: block;}

.bottom hr{margin-top: 1em; border: 1px solid var(--sub-color); border-width: 1px 0 0 0;}
/*-----------
event
-----------*/
.info_detail {display: flex;flex-wrap: wrap;justify-content: flex-start;}
.info_detail dt {width: 250px;;font-weight: bold;padding: 20px 0;line-height: 1.7;position: relative;}
.info_detail dt:after {content: "";position: absolute;width: 1px;height: 100%;background: var(--sub-color);top: 0;right: 0;
}
.info_detail dd {width: calc(100% - 300px);line-height: 1.7;padding: 20px 0 20px 40px;position: relative; font-size: 1em;}
.info_detail dd .small {display: block;color: #f00;}
.info_detail:not(.campaign_detail) dd:last-of-type:before {content: "";display: inline-block;padding-top: 54.8%;}
.info_detail:not(.campaign_detail) dd:last-of-type {margin: 20px 0 20px 40px;}

.info_detail dd a {color: var(--color-link);text-decoration: underline;}
.info_detail dd a:hover {color: #e08691;}
.info_detail dd a:hover {text-decoration: none;}
.info_detail iframe {width: 100%;border: none;position: absolute;height: 100%;top: 0;left: 0;right: 0;}
.info_detail:not(.info_detail) dd:last-of-type {margin: 20px 0 20px 40px;}
.info_detail:not(.info_detail) dd:last-of-type:before {content: "";display: inline-block;padding-top: 54.8%;}


/*-----------
booth
-----------*/
#formBlock{margin-top: 2em;}
#mainform{margin-top: 1em;}
#mainform h6.required::after {content: "必須";background: red;font-size: .7em;color: #fff;margin-left: .5em;padding: .2em .5em .3em;border-radius: 3px;line-height: 1;font-weight: 400;}
#mainform .photo input{margin-top: .5em;}
#mainform .btn{position: relative;display: block;background: var(--btn);border: 1px solid #000;border-color: var(--btn);color: var(--btn-color);text-align: center;padding: .8em 2em .8em 1em;max-width: var(--btn-max-w);width: 80%;margin: 1em auto 0;text-decoration: none;border-radius: var(--border-radiue);}
#mainform .btn::after{content: "";position: absolute; top: calc(50% - .25em); right: 1.5em;width: 0;height: 0;border: 1px solid #fff; border-width: 1px 1px 0 0; width: .5em; height: .5em;transform: rotate(45deg) }
#mainform .btn:hover{color: var(--btn-color-hover); background:var(--btn-hover); transition: all 0.2s linear; cursor: pointer;}
#mainform .btn:hover::after{border-color: var(--btn);}
#soudan .caution.last{margin-top: 3em;}
h3.thanks,.thanks {text-align: center;}
/*-----------
sales
-----------*/
.sales_list {display: flex;flex-wrap: wrap;justify-content: flex-start;padding: 0; margin-top: 2em;}

.sales_list li {color: var(--sub-color);width: 100%;align-items: center;justify-content: center;}

.sales_list li:nth-of-type(4n) {margin: 0 0 80px;}

.sales_list li .red {color: #f00;margin: 10px 0 0;}
.sales_list li figure {margin-bottom: 10px;text-align: center;}

.sales_list li .label {display: flex;flex-wrap: wrap;justify-content: baseline;}

.sales_list li .label li {
    width: auto;
    margin: 0 5px 5px 0;
    padding: 4px 8px;
    font-size: .8em;
    font-weight: 700;
    color: #666;
}

.sales_list li .label .venue {
    background: #d8e3f2;
}

.sales_list li .label .online {
    background: #ddeee0;
}

.sales_list li .label .order {
    background: #fcecde;
}

.sales_list li .label .preceding {
    background: #fcdeee;
}

.sales_list li h4 {
    font-weight: bold;
    margin: 3px 0 15px;
}

.sales_list li .series {
    margin-top: 5px;
}

.sales_list li .detail {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.sales_list li .detail dt {
    width: 80px;

    position: relative;
    padding: 10px 0;
}

.sales_list li .detail.en dt{
    width: 95px;
}

.sales_list li .detail dd {
    width: calc(100% - 80px);

    position: relative;
    padding: 10px 0 12px;
}

.sales_list li .detail.en dd{
    line-height: 1.7;
}

.sales_list li .detail dt:before,
.sales_list li .detail dd:before {
    content: "";
    width: 100%;
    height: 1px;
    background: #a9acbf;
    position: absolute;
    bottom: 0;
    left: 0;
}

.sales_list li .period dt:before,
.sales_list li .period dd:before {
    display: none;
}


.sales_list.en li .detail dt {
    width: 120px;
}

.sales_list li .detail .period dt {
    width: 100%;
    margin: 2px 0 0;
    padding: 0;
}

.sales_list li .detail dd {
    width: calc(100% - 80px);
}

.sales_list li .detail.en dd {
    width: calc(100% - 95px);
}

.sales_list li .detail .period dd {
    width: 100%;
    padding: 0 0 10px;
}

.sales_list li .detail .period dd:last-of-type {
    padding: 0;
}

.sales_list li .btn_wrap {
    margin-top: auto;
}

.sales_list li .btn_wrap li {
    width: 100%;
    margin: 0;
    display: block;
}

.sales_list li .btn_wrap li a {
    display: block;
    width: 100%;
    color: #fff;
    position: relative;
    margin-top: 10px;
    margin: 1rem auto 0;
    max-width: 100%;
}

.sales_list li .text_area{width: 30%; margin-left: 4%;}
.sales_list li figure{width: 48%;}
.sales_list li .btn{margin-top: 1em;}
.btn.long a {
    max-width: 450px;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.limit{
    padding: 20px;
    border: 1px solid var(--text-color);
}

.limit .attend
{margin-top: 15px;
}
.limit .attend li{
    font-size:1.2rem
}

/*-----------
campaign
-----------*/
#campaign figure img{border: 1px solid #e6e6e6;}
#campaign #survey .survey{width: 80%;margin: 0 auto 1em;}
#campaign #survey .disc + p{margin-top: 1em;}
#campaign #survey a{color: #e08691;text-decoration: underline;}
#campaign #survey a:hover{text-decoration: none;}

/*-----------
livestream
-----------*/
#livestream .guest{border: 1px solid #bdbdbd; border-width: 1px 0 0 0; padding: 1em 0; margin-top: 1em;}
/* #livestream .guest .flex{flex-wrap: wrap;} */
#livestream .guest img{max-width: 150px;}
#livestream .guest .text_area{margin-left: 1em; width: calc(100% - 1em - 150px);}
#livestream .guest .text_area h5{font-size: 1.2em;}
#livestream .guest .text_area h5 span{font-size: .8em;}
#livestream .guest + a{margin-top: 2em;}

@media screen and (max-width: 1500px){
    /*-----------
    mv
    -----------*/
    #mv .inner{padding-top: calc(2.5% + 57px);} 
    #mv .inner h2{text-align: center; font-size: 2vw;}

    /*-----------
    sales
    -----------*/
    .sales_list li .text_area{width: 49%; margin-left: 3%;}
    .sales_list li figure{width: 48%;}

}

@media screen and (max-width: 768px){

    /*-----------
    mv
    -----------*/
    #mv {background-size: 300% auto; background-repeat: no-repeat;}
    #mv .inner{flex-direction: column-reverse; padding-top: 0; margin-top: -2%;} 
    #mv .inner .mv_img{width: 100%;}
    #mv .inner .text_area{margin-top: -10%; z-index: 50;position: relative; width: 80%;}
    #mv h2{color: #144581; padding-top: calc(2.5% + 57px);position: relative;z-index: 30; text-align: center; line-height: 1.5; margin-top: 1em;}
    .bg,.bg2{width: 300%;}

    /*-----------
    TOP contents
    -----------*/
    /*cnt*/
    #cnt .box{width: 100%; margin: 2em auto 0; min-height: auto;}
    #cnt .box:nth-child(2n){margin-left: auto;}
    #cnt .box:nth-child(4) .img_box{width: 50%; padding: 0;}
    

    /*maker*/
    #maker {margin-top: 5em;}
    .maker_wrap a{width: 30%;}
    .maker_wrap a.logo_or,
    .maker_wrap a.logo_gsas{width: 13%;}
    .maker_wrap a.logo_threezero{width: 14%;}
    .maker_wrap a.logo_plm{width: 19%;}
    .maker_wrap a.logo_kadokawa{width: 38%;}
    .maker_wrap a.logo_phat,
    .maker_wrap a.logo_freeing{width: 18%;}
    .maker_wrap a.logo_wing,
    .maker_wrap a.logo_miyuki{width: 24%;}
    .maker_wrap a.logo_wonderfulworks{width: 45%;}
    .maker_wrap a.logo_solarain{width: 19%;}
    .maker_wrap a.logo_proof{width: 23%;}
    .maker_wrap a.logo_inrelligent{width: 35%;}
    .maker_wrap a.logo_starspace{width: 16.5%;}
    .maker_wrap a.logo_alumina{width: 25%;}
    .maker_wrap a.logo_annulus{width: 28%;}
    .maker_wrap a.logo_klockworx{width: 20%;}
    .maker_wrap a.logo_popmart{width: 26%;}
    .maker_wrap a.logo_popmart{width: 24%;}
    .maker_wrap a.logo_16d{width: 16%;}
    .maker_wrap a.logo_gsr,
    .maker_wrap a.logo_figureproduction{width: 21%;}



    /*-----------
    bottom commone
    -----------*/
    body.bottom article h2{padding-bottom: 0;}

    /*-----------
    event
    -----------*/
    .info_detail dt {
        width: 100%;
        padding: 15px 0 5px;
    }
    .info_detail dd {
        width: 100%;
        padding: 15px 0 10px;
        margin-bottom: 10px;
    }
    .info_detail dt:after {
        width: 100%;
        height: 1px;
        top: 100%;
    }
    
    .info_detail:not(.campaign_detail) dd:last-of-type {
        margin: 20px 0 0;
    }

    /*-----------
    sales
    -----------*/
    .sales_list {display: flex;flex-wrap: wrap;justify-content: flex-start;padding: 0; margin-top: 1em;}

    .sales_list li {flex-direction: column;}
    .sales_list li .text_area{width: 90%; margin-left: 0;}
    .sales_list li figure{width: 70%;}

    /*-----------
    livestream
    -----------*/
    #livestream .guest .flex{flex-direction: column; justify-content: center; align-content: center;align-items: center;}
    #livestream .guest img{width: 50%; max-width: 100%;}
    #livestream .guest .text_area{margin-left: 0; margin-top: 1em; width: 100%;}
    
}


@media screen and (max-width: 600px){
/*-----------
campaign
-----------*/
#campaign #survey .survey{width: 100%;margin: 0 auto 1em;}

}