 @charset 'UTF-8';

body
{
    /*font-size:62.5%;10px*/
    font-family: 'メイリオ', 'ＭＳ Ｐゴシック', Helvetica, sans-serif;
    font-size: 41.6875%;
    line-height: 1.6;
    position: relative;
    width: 100%;
    min-width: 320px;
    height: 100%;
    -webkit-text-size-adjust: 100%;
    color: #007cf7;
}

.bodyBg{
    position: fixed;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center top;
    background-image: url(../images/bg.jpg);
}

    @media screen and (max-width:750px){
        .bodyBg{
            background-image: url(../images/bg-sp.jpg);
        }
    }




img
{max-width: 100%;
    height: auto;
}

a{
    font-weight: bold;
    text-decoration: none;
}
a:link, a:hover, a:active{color: #383275;}
a:visited {color: #383275;}
button, a:focus {outline: none;}

a img:hover {
    position: relative;
    top:1px;
    left:1px;
}

/*clearfix*/
.cf:before,
.cf:after
{
    display: table;
    content: '';
}

.cf:after,
.clear
{
    clear: both;
}

cf::after
{
    line-height: 0;
    display: block;
    visibility: hidden;
    clear: both;
    height: 0;
    content: ' ';
}

ul {list-style: none;}

.is-tc {text-align: center !important;}
.is-posr {position: relative !important;} 
.is-mb3 {margin-bottom: 3% !important;}
.is-mt3 {margin-top: 3% !important;}
.is-mb8 {margin-bottom: 8% !important;}
.is-mt8 {margin-top: 8% !important;}
.is-pb5 {padding-bottom: 5% !important;}
.is-pb12 {padding-bottom: 12% !important;}
.att {padding-left: 1em;  text-indent: -1em;}
.sd {
    filter: drop-shadow(0 1px 0px rgba(0, 0, 0, .3));
    -webkit-filter: drop-shadow(0 1px 0px rgba(0, 0, 0, .3));
}

* {
    margin: 0;
    padding: 0;
    border: 0;
}



/*==================================
header
===================================*/

header {
    width: 100%;
    background-color:rgba(255,255,255,0.8);
}

.headerBox {
    position: relative;
    width: 100%;
    height: auto;
    margin: 0 auto;
    max-width: 1500px;
}

@media screen and (max-width:750px) {

    .headerBox {
        background: none;
    }
}

.mainImg {
    position: relative;
    z-index: 500;
    width: 100%;
    max-width: 1500px;
    margin: 0 auto;
    text-align: center;
}

@media screen and (max-width:750px) {
    .mainImg {
        width: 100%;
    max-width: auto;
    }
}
.snsBoxTop {
    z-index: 10000;
    width: 28%;
    position: absolute;
    top: 1%;
    right: 7%;
}

    .snsBtn  {
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .snsBtn li {
        width: 50px;
        margin: 0 4% 0 0;
    }

@media screen and (max-width:750px) {
    .snsBoxTop {
        width: 40%;
        margin: 0 auto;
        right: 10%;
    }

    .snsBtn li {
        width: 45px;
        margin:1% 3% 4% 3%;
    }

}
.mainImg.hidden{
    z-index: 10;
    opacity: 0;
    animation-name: fadeout;
    animation-duration: 1s; 
    animation-fill-mode: forwards; 
}
@keyframes fadeout { 
    0% {
      opacity: 1;
    }
    80% {
      opacity: 1;
    }
     100% {
      opacity: 0;
    } 
}
.catch{
    z-index: 100;
    position: absolute;
    width: 16%;
    top: 77%;
    right: 16%;
}
@media screen and (max-width:750px) {
    .catch{
        width: 19%;
        top: 72%;
    }
}
.kvlogo{
    opacity: 0;
    position: absolute;
    z-index: 400;
    top: 1%;
    left: 7%;
    width: 24.79%;
    margin: 0 auto;
    animation-delay: 1s;
    animation-duration: 3s; 
    animation-name: fade;
    animation-fill-mode: forwards; 
}

@media screen and (max-width:750px) {
    .kvlogo {
        width: 24%;
    }
}

.video-box{
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    overflow: hidden;
}
.video, .overlay, .dot{
    position: absolute;
    z-index: 100;
    top: 50%;
    left: 50%;
    min-width: 100%;
    width: 164vh;
    min-height: 100%;
    height: 56.25vw;
    transform: translate(-50%, -50%);
}
.overlay{
    z-index: 200;
    background: linear-gradient(
        180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 5%, rgba(255,255,255,0) 10%, rgba(255,255,255,0) 100%);
}
.dot{
    z-index: 300;
	background-image: radial-gradient(#FFF 21%, transparent 31%), radial-gradient(#FFF 10%, transparent 31%);
	background-size: 3px 3px;
	background-position: 0 0, 6px 6px;
    background-repeat: repeat;
}
@media screen and (max-width:750px) {
    .video, .overlay, .dot{
        width: 250vh;
    }
    .dot{
        background-image:none;
    }
    .overlay{
        background: linear-gradient(
            180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 1%, rgba(255,255,255,0) 15%, rgba(255,255,255,0) 100%);
    }
}

.thumArea{
    background-color:  #383275;
}
.thumbBox ul {
    display: flex;
    justify-content: center;
    padding: 1% 0;
}

.thumbBox li{
    position: relative;
    width: 30%;
    max-width: 294px;
    margin: 0 1%;
}

.thumbBox li:hover:before{
    content: "";
    z-index: 100;
    top: 0;
    left: 0;
    right: 0;
    position: absolute;
    background-image: url(../images/play.png);
    padding-top: 57%;
    background-size: cover;
    width: 100%;
    height: auto;
    opacity:0;
    animation-name: fade; 
    animation-duration: 0.5s; 
    animation-fill-mode: forwards; 
    pointer-events: none;
}
@keyframes fade { 
    0% {
      opacity: 0;
    }
     100% {
      opacity: 1;
    } 
}
.thumbBox p{
    font-size: 10px;
    padding-top: 2%;
    color: #FFF;
    font-weight: bold;
}
@media screen and (max-width:750px) {
    .thumbBox li {
        width: 30%;
        margin: 0 1%;
    }
    .thumbBox li:hover a::after{
        content: none;
    }
    .thumbBox p{
        font-size: 1.5rem;
    }
}


/*==================================
common
===================================*/

.content{
     background-color: rgb(255,255,255,0.8);
}
.content .is-chara{
    width: 100%;
    height: 100%;
    justify-content: center;
    align-items: center;
    background-attachment: fixed;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-image: url(../images/bg02.jpg);
}
@media screen and (max-width: 1024px){
  .content .is-chara{
    height: 100%;
    background-image: none;
  }
  .content .is-chara::before{
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background-image: url(../images/bg02.jpg);
    width: 100%;
    height: 100%;
    background-position: center;
    background-size: cover;
    z-index: 0;
  }
}

.title{
    position: relative;
    z-index: 0;
    margin: 0 auto;
    text-align: center;
    background-image: linear-gradient(#40b9d2 0%, #35a7d0 100%);
}

.title:before,
.title:after{
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.title:before{
    background-image: url(../images/title-dot-line.png);
    background-repeat: repeat-x;
    background-size: 18px / 980 * 100%;
    background-position: bottom;
    background-position: 0 9.2rem;
    background-size: 18px auto;
}

    @media screen and (max-width:750px) {
        .title:before{
          background-size: 1.8rem auto;
          background-position: 0 7rem;
        }
      }

.title:after{
    max-width: 1980px;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
    background-image: url(../images/title-puyo-pc.png);
}
     @media screen and (max-width:750px) {
         .title:after{
              background-image: url(../images/title-puyo-sp.png);
            }
      }


.contentBox {
    position: relative;
    z-index: 2;
    width: 98%;
    max-width: 875px;
    margin:0 auto;
}

.infoBtn {
    display: flex;
    margin:4% auto 0;
    justify-content: center;
}

.infoBtn p {
    width: 70%;
    max-width: 684px;
    margin:0  2%;
}

@media screen and (max-width:750px) {
    .infoBtn p {
        width: 90%;
        margin: 0 1%;
}}

.btn {
    width: 57.85%;
    max-width: 567px;
    margin:3% auto;
}

@media screen and (max-width:750px) {

    .btn {
        width: 70%;
        max-width: 567px;
        margin:3% auto;
    }

}

.miniChara {
    width: 43.06%;
    max-width: 422px;
    margin:0 auto;
}

@media screen and (max-width:750px) {
    .miniChara {
        width: 65%;
    } 
}

@media screen and (max-width:750px) {
.con03-note {
    width: 70%;
    margin: 1% auto;

}
}

.fin{
    z-index: 1000;
    position: absolute;
    width: 24.38%;
    top: -45%;
    right: 5%;
    margin: 0 auto;
}
.contentMovie{
    max-width: 500px;
    height: 300px;
    width: 100%;
    margin: 0 auto;
}
.contentMovie iframe {
  width: 100%;
  height: 100%;
}

/*==================================
banner
===================================*/

.siteBtn
{
    display: block;  width: 57.24%;  margin: 5% auto;
}

@media screen and (max-width:640px)
{
    .siteBtn
    {
        display: block;  width: 80.79%;  margin: 5% auto;
    }
}

.banner
{
    width: 100%;  min-width: 310px;  max-width: 970px;  margin: 0 auto;  text-align: center;
}

.banner li
{
    display: inline-block;  margin-right: 1%;  margin-bottom: 1%;
}

.banner li.portalBanner
{
    margin-top: 1%;
}

/*==================================
 appSpecArea
===================================*/
.secInner {
    position: relative;
    z-index: 0;
    max-width: 980px;
    margin: auto;
}
.appSpecArea{
  background-color: #383275;
}

 .appSpecArea .secInner{
    padding: 5rem 0 4rem;
}
 
    @media screen and (min-width:751px) {
        .appSpecArea .secInner{
            display: flex;
            justify-content: center;
            align-content: center;
        }
    }
    @media screen and (max-width:750px) {
        .appSpecArea .secInner{
          padding: 45px 0;
        }
    }

.logo,
.specWrap{
    margin: 0 2rem;
}

.logo{
    position: relative;
    z-index: 0;
    width: 360px;
}
   @media screen and (max-width:750px) {
       .logo{
          width: 260px;
          margin: auto;
        }
    }

.logo img{
    width: 100%;
}
 
    @media screen and (max-width:750px) {
        .specWrap{
              margin: 15px auto 0;
            }
    }
.buttonsWrap{
    display: flex;
    justify-content: center;
}

.buttonsWrap .button{
    display: block;
    margin: 0 5px;
}

.buttonsWrap .button img {width: 100%;}

.-app{
  width: 160px;
}
.-google{
  width: 200px;
}

    @media screen and (max-width:750px) {
        .-app{
            width: 132px;
        }
         .-google{
            width: 160px;
        }
    }   


.specText{
  margin: 1rem .5rem 0;
  color: #fff;
  font-weight: bold;
  font-size: 10px;
}

  @media screen and (max-width:750px) {
    .specText{
        width: 280px;
        margin: 10px auto 0;
      }
  }



/***********************************************/

.chaseBox {
    width: 30%;
    max-width: 140px;
    position: fixed;z-index: 9999;
    display: block;
    right: 1%;
    bottom: 1%;
    text-align: center;
}

.dlBtn {   
    width: 100%;
    max-width: 140px;
    height: auto;
    cursor: pointer;
        margin: 0 auto 5% auto;
}

.topBtn {
    width: 68.57%;
    max-width: 96px;
    height: auto;
    margin: 0 auto 5% auto;
    cursor: pointer;
}

@media screen and (max-width:750px) {
    .chaseBox {
        overflow: hidden;
        right: -5%;
    }
    .dlBtn {   
        width: 70%;
    }

    .topBtn {
        width: 50%;
    }
}

/*==================================
footer
===================================*/

footer
{
    font-size: 12px;
    font-weight: bold;
    position: relative;
    width: 100%;  color: #383275;  background: #DEEBFF;
}

.footer
{
    width: 90%;  min-width: 310px;  max-width: 970px;  margin: 0 auto;  padding-bottom: 5%;
}

#footerContents,
#footer_text
{
    padding: 10px 0;
}

#footer_text
{
    padding-top: 0;
}

#footerContents li
{
    display: table-cell;  margin-right: 16px;
}

#footerContents li p
{
    margin-top: 13px;
}

.sega-logo
{
    width: 140px;  height: 36px;  padding-top: 29px;  padding-right: 16px !important;
}

.copyFooter
{
    display: table-cell;  vertical-align: bottom;
}

#footer_text a
{
    display: inline-block;  margin-right: 10px;
}

@media screen and (max-width:1000px)
{
    footer
    {
        padding-bottom: 23%;
    }
}

@media screen and (max-width:700px)
{
    footer
    {
        padding-bottom: 24%;
    }
}

@media screen and (max-width:960px)
{
    footer
    {
        min-width: 320px !important;
    }
}

@media screen and (max-width:736px)
{
}

@media screen and (max-width:640px)
{
    footer
    {
        font-size: 2.3rem;
    }

    .copyFooter
    {
        line-height: inherit;  height: auto;  margin-top: 2%;  vertical-align: bottom;
    }

    #footerContents
    {
        padding: 10px 5px;
    }

    #footerContents li
    {
        display: block;  margin-right: 0;
    }

    .sega-logo
    {
        height: auto;
    }

    .footer
    {
        padding-bottom: 28%;
    }
}

/* anime */

[data-emergence=hidden] {
    opacity: 0;
    transform: translateY(50px); }
  [data-emergence=visible] {
    opacity: 1;
    transform: translateY(0px);
    transition: all .5s; }
