@charset "utf-8";


.visual {
    position: relative;
    background-color: #fff;
}

.visual img {}

.main_h1 {
    position: absolute;
    top: 15vw;
    left: 50%;
    transform: translateX(-50%);
    background-color: #ffffffdb;
    padding: 0.2em 1em;
    font-size: clamp(1.125rem, 0.739rem + 1.93vw, 3.125rem)
        /*18-50px*/
    ;
    width: max-content;
    margin: 0;
}

.main_h1 .name {
    font-size: 85%;
}

/*600px以上*/
@media (min-width: 600px) {}

/*900px以上*/
@media (min-width: 900px) {
    .visual {
        height: 55vw;
        min-height: 600px;
        padding: 3rem;
    }

    .visual img {
        object-fit: contain;
        height: 100%;
        width: 100%;
    }
}

#bread {
    display: none;
}



section h2 {
    font-size: clamp(1.25rem, 1.023rem + 1.14vw, 1.875rem);
}

section h3 {
    font-size: clamp(1.125rem, 0.989rem + 0.68vw, 1.5rem);
    margin-bottom: 1em;
}

section h4 {
    font-size: clamp(1.125rem, 0.943rem + 0.91vw, 1.625rem);
    margin-bottom: .75em;
}

section h2::first-letter {
    font-size: clamp(1.875rem, 1.42rem + 2.27vw, 3.125rem);

}



.anchor {
    padding-top: 60px;
    margin-top: -60px;
}


.wide_sec {
    position: relative;
}

.wide_sec::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
}

#front_concept::after {
    background: url(../images/concept/main_img.jpg) top right;
    background-size: cover;
    width: 100%;
    height: 100%;
}

#front_recommended::after {
    background: url(../images/recommend/main_img.jpg) top right;
    background-size: cover;
    width: 100%;
    height: 100%;
}

#front_voice::after {
    background: url(../images/voice/main_img.jpg) top right;
    background-size: cover;
    width: 100%;
    height: 100%;
}

#front_staff::after {
    background: url(../images/index/front_staff_bg.jpg) top right;
    background-size: cover;
    width: 100%;
    height: 100%;
}

.wide_sec .box {
    width: 70%;
    background: rgba(255, 255, 255, .8);
    padding: 3em 3.5em;
}

#front_recommended .box,
#front_staff .box {
    margin-left: auto;
}



#front_style .txt_area {
    width: 50%;
    padding: 6%;
}

#front_style .img_area {
    width: 50%;
}

#front_style .img_area li {
    width: calc(100% / 3);
}



#front_news li {
    margin: 2em 0;
}

#front_news li a {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    color: #fff;
}

#front_news li .thumb {
    width: 25%;
}

#front_news li .news_text {
    width: 70%;
}

#front_news li .news_text .day {
    font-size: .875rem;
    margin-bottom: .5em;
}

#front_news li .news_text dl dt {
    margin-bottom: .75em;
}

#front_news li .news_text dl dd {
    font-size: 1rem;
}

.bg_img {
    background-image: url(../images/index/bg_img.jpg);
    background-size: cover;
    max-width: 100vw;
    margin: 0 calc((100vw - 100%) / -2);
    aspect-ratio: 16 / 9;
    background-position: center;
    position: relative;
}

.bg_img p {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    margin: auto;
    width: 50vw;
    max-width: 462px;
    opacity: .5;
}

.bg_img p img {
    width: 100%;
}


#front_menu a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

#front_menu .img_area {
    width: 40%;
}

#front_menu .img_area img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    height: 100%;
    width: 100%;
}

#front_menu .txt_area {
    width: 54%;
}




#front_salon h3 .small {
    font-size: 1rem;
}

#front_salon .img_area {
    width: 50%;
}

#front_salon .txt_area {
    width: 45%;
}

#front_salon .txt_area dt {
    width: 8em;
    font-family: "Oswald", sans-serif;
}

#front_salon .txt_area dd {
    width: calc(100% - 10em);
}



@media (min-width: 900px) {
    .bg_img {
        min-height: 80vh;
        background-size: cover;
        background-attachment: fixed;
        max-width: 100vw;
    }
}


@media (max-width: 799px) {


    .wide_sec>div {
        padding: 1em 0;
    }

    .wide_sec .box,
    #front_style .txt_area,
    #front_menu li {
        width: 100%;
        background: rgba(255, 255, 255, 1);
        padding: 1.5em 2em;
    }

    .wide_sec::after,
    #front_concept::after,
    #front_recommended::after,
    #front_voice::after,
    #front_staff::after {
        height: 50vw;
        max-height: 265px;
        position: static;
    }


    #front_style .txt_area {
        width: 94%;
        margin: 3%;
    }

    #front_style .img_area {
        width: 100%;
    }

    .bg_img {
        display: none;
    }

    #front_menu .txt_area {
        width: 100%;
    }

    #front_menu .img_area {
        width: 100%;
        max-width: 460px;
        margin: 0 auto 1em;
    }

}






@media (max-width: 899px) {

    #front_salon {}

    #front_salon .box {
        display: block;
        width: 100%;
    }

    #front_salon .img_area {
        width: 100%;
        margin: 0 auto;
    }

    #front_salon .txt_area {
        width: 100%;
    }

}

@media (max-width: 599px) {
    #front_salon dl {}

    #front_salon .txt_area dt {
        width: 20%;
    }

    #front_salon .txt_area dd {
        width: 80%;
        padding: 0 0 0 5%;
    }
}