﻿

/*
#loader{
    display: none;
}
*/
/*
#video{
    position:relative;
}
#video::before {
    content: 'MOVIE';
    position: absolute;
    display: block;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    z-index: 2;
    color: #fff;
    letter-spacing: 10px;
}
*/

:root{
    --color1:#B9DEDE;
}


.linkStyle{
    color:#bf9d74;
}
.linkStyle:hover{
    transition:all 0.3s;
    opacity:0.7;
    text-decoration:underline;
}

body{
    overflow:hidden;
}
#wrap{
    background:url(./Dup/img/bg.jpg) repeat;
    background-size:300px;
}
.fixbnr{
    display:none;
}
#footer_info{
    background-color:var(--color1);
}
#footer_info > div{
    background-color:transparent!important;
}



/*--top page---------------------------
-------------------------------------*/
#mainwrap {
    background: url(./Dup/img/main_v1.png) no-repeat;
    background-size: 18%;
    background-position: bottom 4% right -2%;
    padding-left:0;
}
#header #sns_link li{
    margin:auto;
}
.video_title::before,
#top_contents1 .con1_img::after{
    content: '';
    position: absolute;
    display: block;
    pointer-events:none;
}
.cloud{
    width:400px;
    bottom:1%;
    right:3%;
    z-index:2;
}


#con_nav.t_con_nav ul{
    max-width: initial;
    width: calc(100% - 250px)!important;
    margin-left: 0;
    border-radius: 0 52px 52px 0;
}
.t_con_nav .con_navbar{
    padding-left:0;
}


#video_box {
    padding: 7% 0 10%;
    background: url(./Dup/img/wave1.png) no-repeat;
    background-size: 100%;
    background-position: bottom;
}
.rainbow2_box {
    bottom: 50px;
    right: 20px;
    width: 50vw;
    max-width: 1000px;
}
.rainbow2.img-container::before,
.rainbow2.img-container.active::before{
    background:#f8f2e2;
}
.video_title{
    margin-top:-50px;
}
.video_title::before {
    width: 120px;
    height: 100px;
    background: url(./Dup/img/v_title.png) no-repeat;
    background-size: contain;
    top: -45px;
    left: 10px;
    z-index: -1;
}
#video{
    z-index:2;
}

#top_contents1{
    background-color: #b9dede;
}
.star1 {
    width: 50px;
    top: -35px;
    left: 0px;
    height: fit-content;
    animation: star-anim1 8s 0s infinite;
}
.star2 {
    width: 30px;
    top: 10px;
    left: 40px;
    height: fit-content;
    animation: star-anim2 8s 0s infinite;
}

@keyframes star-anim1 {
  0% {opacity:0;}
  5% {opacity:1;}
  10% {opacity:0;}
  55% {opacity:1;}
  60% {opacity:1;}
  95% {opacity:0;}
  100% {opacity:1;}
}
@keyframes star-anim2 {
  0% {opacity:1;}
  5% {opacity:0;}
  10% {opacity:1;}
  55% {opacity:1;}
  60% {opacity:0;}
  95% {opacity:1;}
  100% {opacity:0;}
}

#top_contents1 .con1_img{
    padding-bottom: 66vh;
    position:relative;
}

#top_contents1 .con1_txt_wrap{
    padding-left: 5%;
    padding-right: 10%;
}
#top_contents1 .con_title{
    margin-left:-30px;
    position:relative;
}


#top_contents2{
    background-image:url(./Dup/img/wave2.png),url(./Dup/img/wave3.png),url(./Dup/img/reaf1.png),url(./Dup/img/reaf2.png);
    background-repeat:no-repeat,no-repeat,no-repeat,no-repeat;
    background-size:100%,100%,auto 100%,auto 100%;
    background-position:top,bottom,left,right;
    background-color:#fff;
}
#top_contents2 .con2_item{
    width:350px;
    height:300px;
    top:-50px;
    right:50px;
}

#top_contents3 {
    background-image:url(./Dup/img/con3_bg.png);
    background-repeat:no-repeat;
    background-size: 100%;
    background-position:left 8%;
    background-color: #fff;
}


#top_contents3 .con3_img4{
    margin-top:-70px;
}

#top_cms{
    background: url(./Dup/img/wave1.png) no-repeat;
    background-size: 100%;
    background-position:bottom;
    background-color:#fff;
}


/*--under page---------------------------
-------------------------------------*/
#con_nav ul{
    max-width: initial;
    width: calc(100% - 250px)!important;
}
#page_title h2{
    font-size:30px;
}


/* ---------- responshive ---------- */
@media screen and (max-width: 1536px){
.v_item2{
    right:-100px;
}
#top_contents1 .con1_img {
    padding-bottom: 60vh;
}
}


@media screen and (max-width: 1366px){
.v_item{
    right: -145px;
}
#top_contents1 .con1_img {
    padding-bottom: 54vh;
}
#top_contents3 {
    background-position: right 2% top 42%, left 8%;
}
}


/* ---------- タブレット ---------- */
@media screen and (max-width: 768px){

#mainwrap{
    background:none;
}
.rainbow{
        width: 350px;
    bottom: 5%;
    right: -2%;
    z-index: 2;
}
.cloud{
    z-index:3;
}
#video_box {
    padding: 18% 0 23%;
}
.video_title::before {
    width: 100px;
    height: 80px;
    top: -20px;
    left: 85px;
}
.rainbow2_box {
    bottom: -50px;
    right: -15px;
    width: 75vw;
    max-width: 1000px;
}
#top_contents1{
    background-size: 37%;
    background-position: bottom right 3%;
}
#top_contents1 .con1_img {
    padding-bottom: 66vh;
}
#top_contents1 .con_title {
    margin-left: 0;
}

#top_contents2 {
    padding-top: 20%;
    background-image: url(./Dup/img/wave2.png),url(./Dup/img/wave3.png),url(./Dup/img/reaf1_tb.png),url(./Dup/img/reaf2_tb.png);
    background-repeat: no-repeat,no-repeat,no-repeat,no-repeat;
    background-size: 100%,100%,100%,100%;
    background-position: top,left bottom -1%,top,bottom;
}
#top_contents2 .con2_item {
    width: 250px;
    height: 100px;
}
#top_contents3 {
    background-image: url(./Dup/img/con3_item.png),url(./Dup/img/con3_bg.png),url(./Dup/img/con3_bg.png);
    background-repeat: no-repeat,no-repeat,no-repeat;
    background-size: 150px,100%,100%;
    background-position: right 2% bottom 37%, left top 33%, bottom;
}

}

/* ---------- スマートフォン ---------- */
@media screen and (max-width: 667px){
.catch{
    font-size:1.5rem;
}
.rainbow {
    width: 220px;
    bottom: 1%;
    right: -16%;
}
.cloud {
    width: 200px;
    bottom: -1%;
    right: -8%;
}
#video_box {
    padding: 25% 0 40%;
}
.rainbow2_box {
    bottom: 2px;
    right: -65px;
    width: 100vw;
}
.video_title::before {
    width: 60px;
    height: 50px;
    top: -10px;
    left: 5px;
}

#top_contents1 .con1_img {
    padding-bottom: 49vh
}

#top_contents2 .con2_item {
    width: 170px;
    height: 100px;
    right: 5px;
}
#top_contents2{
    background-size: 100%,100%;
    background-repeat: no-repeat,no-repeat;
}
#top_contents3{
    background-size: 100px,100%,100%;
    background-position: right 2% bottom 54%, left top 33%, bottom;
}
#page_title h2{
    font-size:20px;
}
}




