html {
    margin: 0;
    padding: 0;
    width: 100%;
}

body{
    margin: 0;
    width: 100%;
    background-color: #0e0e0e;
    color: #ffffff;
    font-weight: lighter;
}

main {
    margin: 0;
}

.top {
    margin: 0;
    font-size: 10vmin;
    width: 100%;
    height: 100vh;
    display: flex;
    justify-content: end;
    align-items: center;
    flex-direction: column;
    position: relative;
}

#top-video {
    margin: 0;
    padding: 0;
    position: relative;
    z-index: -1;
    width: 100%;
    height: 100vh;
    object-fit: cover;
}

.titlelogo{
    position: absolute;
    width: 40%;
    bottom: 2%;
    left: 1.5%;
    transform: translate(0%, 0%);
    z-index: 21;
    mix-blend-mode: difference;
    pointer-events: none;
    animation: title-move 3.5s 0.5s linear forwards;
    opacity: 1;
    -webkit-transform: translate(0%, 0%);
    -moz-transform: translate(0%, 0%);
    -ms-transform: translate(0%, 0%);
    -o-transform: translate(0%, 0%);
    -webkit-animation: title-move 3.5s 0.5s linear forwards;
}

.interval {
    width: 100%;
    height: 15vh;
    display: flex;
    justify-content: center;
    align-items: center;
}

.view-all-talents {
    background-color: #000000;
    padding: 2em 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

.view-all-talents a {
    text-decoration: none;
    color: #8f8f8f;
    font-size: 1.7vw;
    position: relative;
    transition: 0.5s;
}

.view-all-talents a:hover {
    color: #ffffff;
}

.view-all-talents a:hover::after {
    background-color: #ffffff;
    width: 140%;
}

.view-all-talents a:hover::before {
    background-color: #ffffff;
    right: -40%;
}

.view-all-talents a::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 120%;
    height: 1px;
    background-color: #8f8f8f;
    transition: 0.5s;
}

.view-all-talents a::before {
    content: "";
    position: absolute;
    bottom: 0;
    right: -20%;
    width: 15%;
    height: 1px;
    transform-origin: right;
    transform: rotateZ(40deg);
    background-color: #8f8f8f;
    transition: 0.5s;
}
.about {
    margin: 0;
    margin-top: 20vmin;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.about-title {
    width: 70%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0;
    margin-bottom: 8vmin;
}

.about-title p {
    margin: 0;
    font-size: 3vmin;
    white-space: nowrap;
    font-weight: bolder;
    color: #999999;
}

.about-title span {
    width: 50%;
    height: 1px;
    background-color: #999999;
    margin: 0;
    margin-right: 2vmin;
    margin-left: 2vmin;
}

.picture-wrp {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 15vmin;
}

#fg-picture {
    width: 60%;
    height: auto;
}

.about-text {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: 20vmin;
}

.about-jp {
    width: 100%;
    margin-bottom: 8vmin;
}

.about-text p {
    font-size: 2.7vmin;
    margin: 0;
    margin-bottom: 1.8vmin;
    text-align: center;
}

.fadeiner{
    animation: fadeIn 0.5s 0.2s linear forwards;
}

section {
    background-color: #0e0e0e;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: 20vmin;
    margin-top: 5vmin;
}

.works , .news {
    position: relative;
    width: 70%;
    display: flex;
    flex-direction: column;
    justify-content: start;
    align-items: center;
    margin: 0;
    padding: 0;
}

.works-title, .news-title {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0;
    margin-bottom: 8vmin;
}

.works-title p, .news-title p {
    margin: 0;
    font-size: 3vmin;
    white-space: nowrap;
    font-weight: bolder;
    color: #999999;
}

.works-title span, .news-title span {
    width: 50%;
    height: 1px;
    background-color: #999999;
    margin: 0;
    margin-right: 2vmin;
    margin-left: 2vmin;
}

.news-contents {
    width: 85%;
    display: flex;
    justify-content: center;
    align-items: start;
    flex-direction: column;
}

.news-item {
    width: 100%;
    margin: 0;
    background-color: #242424;
    box-shadow: #000000 10px 10px 8px;
    margin-bottom: 4vmin;
    padding: 0;
    text-decoration: none;
    opacity: 0;
}

.news-item-title {
    font-size: 1.8vmin;
    color: #d1d1d1;
    margin: 0;
    margin: 1.5vmin 0 0 2vmin;
}

.news-date {
    font-size: 1.2vmin;
    color: #919191;
    margin: 0 2vmin 1.5vmin 0;
    text-align: right;
}

.work {
    width: 38%;
    margin: 0;
    margin-bottom: 5vmin;
    padding: 0;
    text-decoration: none;
    opacity: 0;
}

.works-contents {
    width: 100%;
    display: flex;
    justify-content: space-evenly;
    align-items: start;
    flex-wrap: wrap;
    margin: 0;
    margin-top: 3vmin;
}

.work-info {
    width: 95%;
    padding-left: 3vmin;
    padding-right: 3vmin;
}

.work-info p{
    margin: 0;
    margin-top: 1.5vmin;
}

.work-info p:nth-child(1) {
    font-size: 1.2vw;
    font-weight: bolder;
    color: #d1d1d1;
}

.work-info p:nth-child(2) {
    font-size: 1vw;
    color: #6b6b6b;
}

.work {
    height: 100%;
}

.sambnail {
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
    margin: 0;
}

.work img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    cursor: url(/images/viewcontent.png), default;
    transition: 0.5s;
}

.work img:hover {
    box-shadow: #ffffff 0 0 12px;
}

.works-more-wrp, .news-more-wrp {
    width: 100%;
    display: flex;
    justify-content: right;
    align-items: center;
    margin: 0;
    margin-top: 3vmin;
    margin-right: 10vw;
}

.works-more-wrp a , .news-more-wrp a {
    text-decoration: none;
    font-size: 2vmin;
    white-space: nowrap;
    padding: 1vmin;
    padding-right: 2vmin;
    padding-left: 2vmin;
    width: min-content;
    border-radius: 3vmin;
    border: #d6d6d6 2px solid;
    color: #d6d6d6;
    transition: 0.5s;
    margin-left: 5vw;
}

.works-more-wrp a:hover, .news-more-wrp a:hover {
    background-color: #d6d6d6;
    color: #0e0e0e;
}

@media screen and (max-width:1250px) {

    .about-title {
        width: 100%;
    }
    .picture-wrp {
        height: auto;
    }
    #fg-picture {
        width: 90%;
        margin: 2em 0;
    }
    .about-text {
        width: 100%;
    }
    .about-jp {
        width: 85%;
        margin-bottom: 10vmin;
    }
    .about-text p {
        font-size: 3.7vmin;
        margin-bottom: 1vmin;
    }
    .works, .news {
        width: 90%;
    }
    .news-contents {
        width: 95%;
    }
    .news-item-title {
        font-size: 3vmin;
    }
    .news-date {
        font-size: 2.2vmin;
    }
    .news-more-wrp {
        margin-top: 5vmin;
    }
    .news-more-wrp a {
        font-size: 3.5vmin;
    }
    .work {
        width: 90%;
    }
    .works-more-wrp {
        margin-top: 10vmin;
    }
    .works-more-wrp a {
        font-size: 4vmin;
    }
    .work-info p:nth-child(1) {
        font-size: 4vw;
    }
    .work-info p:nth-child(2) {
        font-size: 3.4vw;
    }
    #footer {
        display: none;
    }
}

@media screen and (max-width:1000px) {
    .top {
        justify-content: start;
    }
    .view-all-talents a {
        font-size: 3.7vw;
    }

}

@media screen and (min-width:1250px) {
    .top-left {
        cursor: url(/images/view-works.png), default;
    }
    .top-right {
        cursor: url(/images/view-talents.png), default;
    }
}

.inview {
    opacity: 0;
}
