@charset "UTF-8";
#fv{
    display: flex;
    width: 100vw;
    height: 100vh;
    margin-bottom: calc(50vh + 100px);
}
#fv-item{
    position: absolute;
    transform: translate(-50%,-50%);
    left: 50%;
    top: 50%;
    height: 100%;
    width: 90%;
    max-width: 1200px;
}
#fv-copy-en{
    position: relative;
    color: rgb(49, 48, 48);
    overflow: hidden;
}
#fv-copy-en span{
    font-size: 5em;
    font-weight: 300;
    display: inline-block;
    transform: translate(0,-100%);
}

#fv-text-wrapper{
    position: absolute;
    transform: translate(0%,0%);
    left: 0%;
    bottom: 15%;
    color: rgb(49, 48, 48);
    font-weight: 500;
}
#fv-text-wrapper #fv-copy-jp{
    font-size: 2em;
    overflow: hidden;
    margin-bottom: 20px;
}
#fv-text-wrapper #fv-copy-jp span{
    font-size: 1em;
    font-weight: 500;
    display: inline-block;
    transform: translate(0,-100%);
}
#fv-text-wrapper p{
    font-size: 0.9em;
    line-height: 2em;
}

.text-transition-first-B{
    opacity: 0;
}




.content{
    margin-bottom: 200px;
}
h2{
    margin-bottom: 0px;
}
.text-transition-to-right-wrapper{
    display: inline-block;
    width: 500px;
}
.text-transition-to-right{
    display: inline-block;
    overflow: hidden;
    width: 0%;
}
.text-transition-h2{
    font-size: 4em;
    font-weight: 300;
    line-height: 1.3em;
    white-space: nowrap;
}
.text-transition-h5{
    font-size: 1em;
    font-weight: 500;
    line-height: 1em;
    margin-bottom: 30px;
    white-space: nowrap;
}
.content p{
    line-height: 2em;
}
.text-transition-to-top{
    opacity: 0;
}

.column-wrapper{
    display: grid;
    grid-template-columns: 1fr 1fr minmax(260px, 26%) minmax(260px, 26%);
    grid-template-rows: 300px 300px;
}
.column-item{
    position: relative;
    border-radius: 6px;
    margin: 5px;
    overflow: hidden;
}
.service{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    padding: 30px;
    border-radius: 6px;
    background-color: #f0f0f065;
}
.service-bg{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    border-radius: 6px;
    background-color: #d0d0d0;
}
.column-wrapper .column-item:nth-child(1){
    grid-column: 1/3;
    grid-row: 1/3;
    margin: 5px 5px 5px 0;
}
.column-wrapper .column-item:nth-child(4){
    grid-column: 3/5;
    grid-row: 2/3;
}
.column-item h3{
    font-size: 2.2em;
    font-weight: 300;
}
.column-item h4{
    font-size: 1em;
    font-weight: 500;
    margin-bottom: 20px;
}
.column-item p{
    font-size: 0.8em;
}
.service-number{
    position: absolute;
    right: 20px;
    bottom: 20px;
    font-weight: 400;
    font-size: 0.8em;
    color: #FF640C;
}

.content-item-entry{
    padding-bottom: 75px;
}
#fixed-button{
    position: absolute;
    right: 50px;
    bottom: 0;

    width: 150px;
    height: 150px;
    border-radius: 75px;
    border: solid 1px #282a2c;
    z-index: 10;
}
#fixed-button-text{
    position: absolute;
    transform: translate(-50%,-50%);
    left: 50%;
    top: 50%;
    color: #282a2c;
}
#ball-box{
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 75px;
    transform:rotate(220deg);
}
#ball{
    position: absolute;
    background-color: #FF640C;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: solid 4px #DDDCDB;
    transform: translate(-50%,-50%);
    left: 50%;
    top: 0;
}

@media screen and (max-width:900px) {
    #fv-copy-en span{
        font-size: 3em;
        font-weight: 300;
        display: inline-block;
        transform: translate(0,-100%);
    }
    .column-wrapper{
        display: grid;
        grid-template-columns: unset;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: 300px 300px 300px;
    }
    .column-wrapper .column-item:nth-child(1){
        grid-column: 1/3;
        grid-row: 1/2;
        margin: 5px;
    }
    .column-wrapper .column-item:nth-child(4){
        grid-column: 1/3;
        grid-row: 3/4;
    }
    .text-transition-to-right-wrapper{
        display: inline-block;
        width: 100%;
    }
}
@media screen and (max-width:800px) {
    .column-wrapper{
        display: grid;
        grid-template-columns: unset;
        grid-template-columns: 1fr;
        grid-template-rows: 300px 300px 300px 300px;
    }
    .column-wrapper .column-item:nth-child(1){
        grid-column: 1;
        grid-row: 1;
        margin: 5px;
    }
    .column-wrapper .column-item:nth-child(4){
        grid-column: 1;
        grid-row: 4;
    }
    .text-transition-to-right-wrapper{
        display: inline-block;
        width: 100%;
    }
    .content-item-entry{
        padding-bottom: 200px;
    }
    #fixed-button{
        position: absolute;
        right: 40px;
        bottom: 0;
    
        width: 150px;
        height: 150px;
        border-radius: 75px;
        border: solid 1px #282a2c;
        z-index: 10;
    }
    .content{
        margin-bottom: 120px;
    }
}
@media screen and (max-width:375px) {
    #fv-copy-en span{
        font-size: 2.5em;
    }
}