
/* CSS Document */

/*==================================================

top-contents
=================================================*/

.top-image {
	width: 100%;
    max-width: 100%;
	position: relative;
    z-index: 6;
}
.top-image .inner {
    width: 100%;
    position: relative;
}
.top-image .photo {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
}
.top-image .photo .mv_item {
    width: 100%;
    height: 100%;
    position: absolute;
    background-position: center top;
    background-repeat: no-repeat;
    background-size: auto 100%;
    top: 0;
    left: 0;
    z-index: 1;
}
.top-image .photo .mv_item.base {
    background-image: url("../../images/waku0.png");
}
.top-image .photo .mv_item.bg1 {
    mix-blend-mode: multiply;
    background-image: url("../../images/waku1.png");
    animation: Up_Down 1s ease-in-out infinite 0s alternate;
}
.top-image .photo .mv_item.bg2 {
    mix-blend-mode: multiply;
    background-image: url("../../images/waku2.png");
    animation: Down_Up 2s ease-in-out infinite 0s alternate;
}
.top-image .photo .mv_item.bg3 {
    mix-blend-mode: multiply;
    background-image: url("../../images/waku3.png");
    animation: Up_Down 3s ease-in-out infinite 0s alternate;
}
.top-image .photo .mv_item.bg4 {
    mix-blend-mode: multiply;
    background-image: url("../../images/music_icon.png");
    animation: Down_Up 1s ease-in-out infinite 0s alternate;
}

@keyframes load_up {
  0% {
    top: 40px;
    left: 0;
  }
  100% {
    top: 0;
    left: 0;
  }
}
@keyframes Up_Down {
  0% {
    top: 0;
    left: 0;
  }
  100% {
    top: 20px;
    left: 0;
  }
}
@keyframes Down_Up {
  0% {
    top: 20px;
    left: 0;
  }
  100% {
    top: 0;
    left: 0;
  }
}

.top-image .txt {
    width: 100%;
    max-width: 740px;
    position: relative;
    margin: 0 auto;
    padding: 160px 0 30px;
    z-index: 3;
}
.top-image .txt h1 {
    width: 20%;
    max-width: 127px;
    margin: 0 auto;
}
.top-image .txt h2 {
    width: 90%;
    max-width: 740px;
    margin: 60px auto;
}
.top-image .txt .link-b {
    width: 60%;
    max-width: 574px;
    display: block;
    position: relative;
    margin: 0 auto;
}
.top-image .txt .link-b::after {
    content: " ";
	display: block;
    position: absolute;
    width: 10%;
    background-image: url("../../images/arrow.png");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    top: 50%;
    right: 5%;
    
    padding: 10% 0;
    
	-webkit-transform: translate(0, -50%); 
	transform: translate(0, -50%);
    
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    z-index: 2;
}
.top-image .txt .link-b:hover {
    opacity: 1;
}
.top-image .txt .link-b:hover::after {
    right: 15px;
}
.top-image img {
    width: 100%;
	max-width: 100%;
	height: auto;
}

.top-service {
    width: 90%;
    max-width: 1280px;
    margin: 0 auto;
}
.top-service ul {
    width: 100%;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
}
.top-service ul li {
    width: 48%;
    max-width: 586px;
    margin-top: 80px;
}
.top-service ul li img {
    width: 100%;
	max-width: 100%;
	height: auto;
}
.top-service ul li a {
    display: block;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
}
@media (hover: hover) {
    .top-service ul li a:hover {
        opacity: 1;
        -webkit-transform: translate(0, -5%); 
        transform: translate(0, -5%);
    }
}
.top-service .program {
    width: 100%;
    max-width: 1200px;
    display: block;
    overflow: hidden;
    color: #FFF;
    text-decoration: none;
    background-color: #ff708f;
    border-radius: 160px;
    margin: 120px auto 0;
}
@media (hover: hover) {
    .top-service .program:hover {
        opacity: 1;
        color: #ff708f;
        background-color: #FFF;
    }
}
.top-service .program dl {
    width: 100%;
    position: relative;
    display: flex;
    flex-flow: row wrap;
}
.top-service .program dl dt {
    width: 50%;
    font-size: clamp(2rem, 3vw, 3.6rem);
    text-align: center;
    padding: 100px 5%;
}
.top-service .program dl dt span {
    display: inline-block;
    position: relative;
}
.top-service .program dl dt span::after {
    content: " ";
	display: block;
    position: absolute;
    width: 30px;
    height: 30px;
    background-image: url("../../images/arrow.png");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    top: 50%;
    right: 0;
    
	-webkit-transform: translate(150%, -50%); 
	transform: translate(150%, -50%);
    
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    z-index: 2;
}
.top-service .program dl dd {
    width: 50%;
    position: absolute;
    top: 50%;
    right: 0;
	-webkit-transform: translate(0, -50%); 
	transform: translate(0, -50%);
    z-index: 1;
}
.top-service .program dl dd img {
    width: 100%;
	max-width: 100%;
	height: auto;
}

.top-about {
    width: 90%;
    max-width: 1280px;
    margin: 0 auto;
}
.top-about ul {
    width: 100%;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
}
.top-about ul li {
    width: 48%;
    max-width: 590px;
    margin-top: 120px;
}
.top-about ul li:nth-of-type(1) a {
    background-color: #83ce5a;
}
.top-about ul li:nth-of-type(2) a {
    background-color: #f8ca3c;
}
.top-about ul li:nth-of-type(3) a {
    background-color: #f89332;
}
.top-about ul li:nth-of-type(4) a {
    background-color: #5b82d1;
}

@media (hover: hover) {
    .top-about ul li:nth-of-type(1) a:hover {
        opacity: 1;
        color: #83ce5a;
        background-color: #FFF;
    }
    .top-about ul li:nth-of-type(2) a:hover {
        opacity: 1;
        color: #f8ca3c;
        background-color: #FFF;
    }
    .top-about ul li:nth-of-type(3) a:hover {
        opacity: 1;
        color: #f89332;
        background-color: #FFF;
    }
    .top-about ul li:nth-of-type(4) a:hover {
        opacity: 1;
        color: #5b82d1;
        background-color: #FFF;
    }
}
.top-about ul li img {
    width: 100%;
	max-width: 100%;
	height: auto;
}
.top-about ul li a {
    display: block;
    overflow: hidden;
    color: #FFF;
    text-decoration: none;
    border-radius: 20px;
}
.top-about ul li a dl {
    width: 100%;
    display: flex;
    flex-flow: column-reverse wrap;
}
.top-about ul li a dl dt {
    width: 100%;
    font-size: clamp(1.6rem, 3vw, 3.6rem);
    text-align: center;
    padding: 100px 5%;
}
.top-about ul li a dl dt span {
    display: inline-block;
    position: relative;
}
.top-about ul li a dl dt span::after {
    content: " ";
	display: block;
    position: absolute;
    width: 30px;
    height: 30px;
    background-image: url("../../images/arrow.png");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    top: 50%;
    right: 0;
    
	-webkit-transform: translate(150%, -50%); 
	transform: translate(150%, -50%);
    
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    z-index: 2;
}
.top-about ul li a dl dd {
    width: 100%;
}



@media only screen and (min-width:1px) and (max-width: 1200px) {
    .top-image .txt {
        padding: 15% 0 5%;
        z-index: 3;
    }
    .top-image .txt h1 {
        width: 12%;
    }
    .top-image .txt h2 {
        margin: 6% auto;
    }
}
@media only screen and (min-width:1px) and (max-width: 768px) {
	
	.top-image {
        width: 100%;
	}
    .top-image .txt {
        padding: 100px 0 5%;
    }
    
    .top-service ul {
        width: 100%;
        flex-direction: column;
        align-items: center;
    }
    .top-service ul li {
        width: 80%;
        margin-top: 8%;
    }
    .top-service ul li a:hover {
        opacity: 1;
        -webkit-transform: translate(0, 0); 
        transform: translate(0, 0);
    }
    
    .top-service .program {
        width: 100%;
        max-width: 590px;
        border-radius: 20px;
        margin: 12% auto 0;
    }
    .top-service .program dl {
        width: 100%;
        position: relative;
        flex-direction: column-reverse;
    }
    .top-service .program dl dt {
        width: 100%;
        font-size: clamp(2rem, 3vw, 3.6rem);
        text-align: center;
        padding: 15% 5%;
    }
    .top-service .program dl dt span {
        display: inline-block;
        position: relative;
    }
    .top-service .program dl dd {
        width: 100%;
        position: relative;
        overflow: hidden;
        top: 0;
        right: 0;
        -webkit-transform: translate(0, 0); 
        transform: translate(0, 0);
        z-index: 1;
    }
    .top-service .program dl dd img {
        display: block;
        margin-top: -28%;
    }

    .top-about {
        width: 90%;
        max-width: 1280px;
        margin: 0 auto;
    }
    .top-about ul {
        width: 100%;
        display: flex;
        flex-flow: row wrap;
        justify-content: center;
    }
    .top-about ul li {
        width: 100%;
        max-width: 590px;
        margin-top: 8%;
    }
    .top-about ul li a {
        border-radius: 10px;
    }
    .top-about ul li a dl {
        width: 100%;
        display: flex;
        flex-direction: row-reverse;
        align-items: center; 
    }
    .top-about ul li a dl dt {
        width: 60%;
        text-align: left;
        padding: 10% 5%;
    }
    .top-about ul li a dl dt span {
        width: 80%;
    }
    .top-about ul li a dl dt span::after {
        content: " ";
        display: block;
        position: absolute;
        width: 25px;
        height: 25px;
        z-index: 2;
    }
    .top-about ul li a dl dd {
        width: 40%;
    }
}

@media only screen and (min-width:1px) and (max-width: 568px) {
	

}
	
@media only screen and (min-width:1px) and (max-width: 480px) {
	

}

