@charset "UTF-8";

/* CSS Document */
.section-top {
    height: 100vh;
    position: relative;
    padding-top: 90px;
}
 /* .section-top__wrapper{
    position: relative;
    width: 100vw;
    height: 100vh;
    z-index: 500;
}  */
.section-top__shadow{
    position: absolute;
    
    z-index: 150;
}
.section-top__shadow img{
    width: 100vw;
    height: 100vh;

}

.section-top__top-hair-cut {
    display: none;
}

.section-top__top-asia-woman {
    position: absolute;
    left: 0;
    top: 90px;
    width: 45%;
    
}

.section-top__top-hairsalon-man {
    display: none;
}

.section-top__top-brownhair-woman {
    display: none;
}

.section-top__top-treatment {
    position: absolute;
    left: 0;
    bottom: 100px;
    width: 46%;
}

.section-top__top-bobhair-woman {
    position: absolute;
    width: 58%;
    top: 100px;
    right: 0px;
    z-index: 100;
}

.section-top__top-hair-cut-man {
    display: none;
}

.section-top__top-blondehair-woman {
    position: absolute;
    width: 49%;
    bottom: 63px;
    right: -32px;
}

.section-top__top-haircolor-sample {
    display: none;
}

.section-top__title {
    padding-top: 25vh;
    margin: 0 2vh;
    text-align: left;
    position: relative;
    z-index: 200;
    overflow-wrap: break-word;

}

.section-top__title p {
    font-family: "urw-din-condensed", sans-serif;
    font-weight: 900;
    font-style: normal;
    letter-spacing: 0.2em;
    font-size: 2.4rem;
    line-height: 4.0rem;
}

.section-top__title span {
    font-size: 4.4rem;
}
.fadeIn500ms {
    animation-name: fadeIn500ms;
    animation-delay: 500ms;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(50px);
    opacity: 0;
}
@keyframes fadeIn500ms {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
.fadeIn1s {
    animation-name: fadeIn1s;
    animation-delay: 1s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(50px);
    opacity: 0;
}
@keyframes fadeIn1s {
    0% {
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}
.fadeIn1500ms {
    animation-name: fadeIn1500ms;
    animation-delay: 1500ms;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(50px);
    opacity: 0;
}
@keyframes fadeIn1500ms {
    0% {
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}
.fadeIn2s {
    animation-name: fadeIn2s;
    animation-delay: 2s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(50px);
    opacity: 0;
}
@keyframes fadeIn2s {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
.fadeIn2500ms {
    animation-name: fadeIn2500ms;
    animation-delay: 2500ms;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(50px);
    opacity: 0;
}
@keyframes fadeIn2500ms {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
.fadeIn3s {
    animation-name: fadeIn3s;
    animation-delay: 3s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(50px);
    opacity: 0;
}
@keyframes fadeIn3s {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
.fadeIn3500ms {
    animation-name: fadeIn3500ms;
    animation-delay: 3500ms;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(50px);
    opacity: 0;
}
@keyframes fadeIn3500ms {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
.fadeIn4s {
    animation-name: fadeIn4s;
    animation-delay: 4s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(50px);
    opacity: 0;
}
@keyframes fadeIn4s {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
.fadeIn4500ms {
    animation-name: fadeIn4500ms;
    animation-delay: 4500ms;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(50px);
    opacity: 0;
}
@keyframes fadeIn4500ms {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
.fadeIn5500ms {
    animation-name: fadeIn5500ms;
    animation-delay: 5500ms;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    opacity: 0;
}
@keyframes fadeIn5500ms {
    0% {
    }
    100% {
        opacity: 1;
    }
}
.fadeIn6500ms {
    animation-name: fadeIn6500ms;
    animation-delay: 6500ms;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(50px);
    opacity: 0;
}
@keyframes fadeIn6500ms {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}

@media(min-width:768px) {

    .section-top__top-hair-cut,
    .section-top__top-hairsalon-man,
    .section-top__top-brownhair-woman,
    .section-top__top-hair-cut-man,
    .section-top__top-haircolor-sample {
        display: block;
    }

    .section-top__top-hair-cut {
        position: absolute;
        left: 0;
        top: 90px;
        width: 26%;
    }

    .section-top__top-asia-woman {
        position: absolute;
        left: 23vw;
        top: 98px;
        width: 29%;
    }

    .section-top__top-bobhair-woman {
        width: 30%;
        /* right: 170px; */
        right: 17vw;
    }

    .section-top__top-hair-cut-man {
        position: absolute;
        width: 19%;
        top: 111px;
        right: 0px;
    }

    .section-top__top-hairsalon-man {
        position: absolute;
        left: 3vw;
        /* top: 260px; */
        top: 41vh;
        width: 26%;
    }

    .section-top__top-brownhair-woman {
        position: absolute;
        left: 0;
        bottom: 0;
        width: 34%;
        z-index: 100;
    }

    .section-top__top-treatment {
        width: 28%;
        left: 30vw;
        bottom: 35px;

    }

    .section-top__top-blondehair-woman {
        width: 27%;
        right: 20vw;
        z-index: 100;
    }

    .section-top__top-haircolor-sample {
        position: absolute;
        width: 30%;
        bottom: 100px;
        right: 0;
    }

    .section-top__title {
        padding-top: 30vh;
        margin: 0 10vh;
    }

    .section-top__title p {
        font-size: 4.0rem;
        letter-spacing: 0.12em;
        line-height: 7.6rem;
    }

    .section-top__title span {
        font-size: 6.0rem;
    }
}

@media(min-width:1140px) {
    .section-top__top-hair-cut {
        max-width: 321px;
    }

    .section-top__top-asia-woman {
        width: 25%;
    }

    .section-top__top-bobhair-woman {
        max-width: 419px;
        right: 22vw;
    }

    .section-top__top-hair-cut-man {
        max-width: 275px;
    }

    .section-top__top-hairsalon-man {
        max-width: 370px;
    }

    .section-top__top-brownhair-woman {
        max-width: 386px;
    }

    .section-top__top-treatment {
        max-width: 320px;
    }

    .section-top__top-blondehair-woman {
        max-width: 321px;
        right: 27vw;
    }

    .section-top__top-haircolor-sample {
        max-width: 421px;
    }

    .section-top__title {
        padding-top: 10vh;
        margin: 0 20vh;
    }

    .section-top__title p {
        font-size: 6.0rem;
        letter-spacing: 0.2em;
        line-height: 8.2rem;
    }

    .section-top__title span {
        font-size: 9.0rem;
    }

}

.section-company {
    margin-top: 100px;
    padding: 0 30px;
}

.section-company__text {
    margin-bottom: 50px;
}



.section-company__button01 {
    margin-top: 40px;
}

.section-company__button01 a {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-left: 0;
    padding: 1em 0;
    max-width: 276px;
    color: #333;
    font-size: 2.4rem;
    background-color: #fff;
    border: 1.8px solid #333;
    text-decoration: none;
    transition: 0.3s;
    font-family: "urw-din-condensed", sans-serif;
    font-weight: 700;
    font-style: normal;
    letter-spacing: 0.6rem;

}

.section-company__button01 a:hover {
    text-decoration: none;
    background-color: #333;
    color: #fff;
}

.section-company__button02 {
    display: none;
}
.section-company__image01{
    width: 67%;
}
.section-company__image02{
    width: 66%;
    margin: 0 auto;
    position: relative;
    bottom: 67px;
}


@media(min-width:786px) {
    .section-company {
        margin-top: 200px;
        padding: 0 50px;
    }

    .section-company__wrapper {
        display: flex;
        flex-direction: row-reverse;
        align-items: flex-start;
        gap: 50px;
    }

    .section-company__image {
        width: 50%;
        margin-right: 40px;
    }

    .section-company__text-wrapper {
        width: 50%;
    }

    .section-company__button01 {
        display: none;
    }

    .section-company__button02 {
        display: block;
    }


    .section-company__button02 a {
        display: flex;
        justify-content: center;
        align-items: center;
        margin-left: 0;
        padding: 1em 0;
        max-width: 276px;
        color: #333;
        font-size: 2.4rem;
        background-color: #fff;
        border: 1.8px solid #333;
        text-decoration: none;
        transition: 0.3s;
        font-family: "urw-din-condensed", sans-serif;
        font-weight: 700;
        font-style: normal;
        letter-spacing: 0.6rem;

    }

    .section-company__button02 a:hover {
        text-decoration: none;
        background-color: #333;
        color: #fff;
    }

    .section-company__text {
        margin-bottom: 32px;
    }
}

@media(min-width:1140px) {
    .section-company {
        max-width: 1140px;
        margin: 200px auto 0;
        padding: 0;
    }

    .section-company__image {
        width: 50%;
        margin-right: 90px;
    }
    .section-company__wrapper{
        gap: 100px;
    }
}

.section-service {
    margin-top: 100px;
    
    background: url(../images/home/home-service-bg.jpg) 50% center;
    background-repeat: no-repeat;
    background-size: cover;
    width: 100%;
    height: 100%;
}
.section-service__contents-wrapper{
    color: #fff;
}
.section-service__bg-shadow{
    position: relative;
    display: block;
    height: 100%;
    padding: 50px 30px;
}

.section-service__contents-wrapper, .section-service__button01{
    position: relative;
    z-index: 100;
}

.section-service__text {
    margin-bottom: 50px;
}

.section-service__item {
    margin-bottom: 50px;
}

.section-service__item-title {
    position: relative;
    z-index: 1;
    margin-top: -19px;
}

.section-service__item-title h3 {
    font-family: "urw-din-condensed", sans-serif;
    font-weight: 900;
    font-style: normal;
    font-size: 4.2rem;
    letter-spacing: 0.4rem;
    margin-bottom: 15px;
}

.section-service__item-title p {
    font-weight: 600;
    font-size: 2.2rem;
}

.section-service__button01 a {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-left: 0;
    padding: 1em 0;
    max-width: 276px;
    color: #333;
    font-size: 2.4rem;
    background-color: #fff;
    border: 1.8px solid #333;
    text-decoration: none;
    transition: 0.3s;
    font-family: "urw-din-condensed", sans-serif;
    font-weight: 700;
    font-style: normal;
    letter-spacing: 0.6rem;

}

.section-service__button01 a:hover {
    text-decoration: none;
    background-color: #333;
    color: #fff;
}

.section-service__button02 {
    display: none;
}

@media(min-width:768px) {
    .section-service {
        margin-top: 200px;
    }

    .section-service__contents-wrapper {
        display: flex;
        justify-content: space-between;
    }

    .section-service__text-wrapper {
        width: 50%;
    }

    .section-service__item {
        margin-left: 40px;
        width: calc(33% - 40px);
    }

    .section-service__text {
        margin-bottom: 32px;
    }

    .section-service__button01 {
        display: none;
    }

    .section-service__button02 {
        display: block;
    }

    .section-service__button02 a {
        display: flex;
        justify-content: center;
        align-items: center;
        margin-left: 0;
        padding: 1em 0;
        max-width: 276px;
        color: #333;
        font-size: 2.4rem;
        background-color: #fff;
        border: 1.8px solid #333;
        text-decoration: none;
        transition: 0.3s;
        font-family: "urw-din-condensed", sans-serif;
        font-weight: 700;
        font-style: normal;
        letter-spacing: 0.6rem;

    }

    .section-service__button02 a:hover {
        text-decoration: none;
        background-color: #333;
        color: #fff;
    }
    .section-service__bg-shadow{
        padding: 50px ;
    }

}

@media(min-width:1140px) {
    .section-service {
        margin: 200px auto 0;
    }
    .section-service__contents-wrapper{
        max-width: 1140px;
        margin: 0 auto;
    }
    .section-service__bg-shadow {
        padding: 150px 0 ;
    }
}


.section-maker {
    margin-top: 100px;
   
}
.section-maker__text-wrapper, .section-maker__button01{
    padding: 0 30px;
}
.section-maker__button01{
    margin-top: 50px;
}
.section-maker__text {
    margin-bottom: 50px;
}

.section-maker__image {
    margin-bottom: 50px;
}

.section-maker__button01 a {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-left: 0;
    padding: 1em 0;
    max-width: 276px;
    color: #333;
    font-size: 2.4rem;
    background-color: #fff;
    border: 1.8px solid #333;
    text-decoration: none;
    transition: 0.3s;
    font-family: "urw-din-condensed", sans-serif;
    font-weight: 700;
    font-style: normal;
    letter-spacing: 0.6rem;

}

.section-maker__button01 a:hover {
    text-decoration: none;
    background-color: #333;
    color: #fff;
}

.section-maker__button02 {
    display: none;
}
.slider img {
    width:100%;/*スライダー内の画像を横幅100%に*/
    height:auto;
}

/*slickのJSで書かれるタグ内、スライド左右の余白調整*/

.slider .slick-slide {
    margin:0 10px;/*スライド左右の余白調整*/
}
@media(min-width:768px) {
    .section-maker {
        margin-top: 200px;
        
    }
    .section-maker__text-wrapper, .section-maker__button01 {
        padding: 0 50px;
    }
   
    .section-maker__button02 a {
        display: flex;
        justify-content: center;
        align-items: center;
        margin-left: 0;
        padding: 1em 0;
        max-width: 276px;
        color: #333;
        font-size: 2.4rem;
        background-color: #fff;
        border: 1.8px solid #333;
        text-decoration: none;
        transition: 0.3s;
        font-family: "urw-din-condensed", sans-serif;
        font-weight: 700;
        font-style: normal;
        letter-spacing: 0.6rem;
    
    }
    
    .section-maker__button02 a:hover {
        text-decoration: none;
        background-color: #333;
        color: #fff;
    }
    .section-maker__wrapper{
        /* display: flex;
        flex-direction: row-reverse;
        align-items: flex-start; */
    }
    
    .section-maker__image{
        width: 50%;
        margin-right: 40px;
    }
    .section-maker__text{
        margin-bottom: 32px;
    }
    .section-company__image02{
        margin: 0 0 0 auto;
    }
}
@media(min-width:1140px){
    .section-maker {
        max-width: 1140px;
        margin: 200px auto 0;
    }
    .section-maker__text-wrapper, .section-maker__button01 {
        padding: 0;
    }
    .section-maker__wrapper{
        display: flex;
        align-items: center;
        gap: 100px;
        flex-direction: row-reverse;
    }
    .slider-wrapper{
        width: 50%;
    }
    .section-maker__button02{
        display: block;
    }
    .section-maker__button01{
        display: none;
    }
}

.section-company__wrapper, .section-service__contents-wrapper, .section-maker__wrapper {
    opacity: 0;
    transition: all 1s;
    transform: translateY(100px);
    
  }
  .section-company__wrapper.show {
    opacity: 1;
    transform: translateY(0px);
  }
  .section-service__contents-wrapper.show {
    opacity: 1;
    transform: translateY(0px);
  }
  .section-maker__wrapper.show {
    opacity: 1;
    transform: translateY(0px);
  }
