@charset "utf-8";

:root{
    --light-green:#d5edeb;
    --green:#63bdb0;
    --brown:#403632;
    --light-grey:#eee;
    --white:#fff;
    --oswald-font:'Oswald',sans-serif;
}



body{
    font-family: "Hiragino Kaku Gothic ProN","Hiragino Sans","BIZ UDPGothic", sans-serif;
    color: var(--brown);
    background: url('https://assets.codepen.io/85188/bg-shadow.jpg')
    no-repeat right bottom / cover fixed;
    text-align: center;
}



 /* common */
p{
    line-height: 1.7;
}


img{max-width: 100%;
}

.title{
    font-family: var(--oswald-font);
    font-size: min(10vw, 4rem);
    margin-bottom: 2rem;
}

.btn{
    color: var(--white);
    background: var(--brown);
    border: 1px solid var(--brown);
    text-decoration: none;
    padding: 1rem;
    display: inline-block;
    margin: 2rem 0;
    transition: .4s;

}

/* layout */

.wrapper{
    max-width: 38rem;
    margin: auto;
    padding: 0 1rem;
}


/* loading */


#loading{
    background-color: var(--light-grey);
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: grid;
    place-items: center;
}

#loading-screen{
    background-color: var(--light-green);
    position: fixed;
    inset: 0;
    z-index: 9998;
    translate: 0 100vh;
}

#loading p{
    font-size: 2rem;
    font-family: var(--oswald-font);
}



/* hero */
.hero{
    height: 100vh;
    position: relative;
}

.hero::after{
    content: '';
    width: auto;
    height: auto;
    background: url('../images/bridalx.png') no-repeat center / cover;
    position: absolute;
    inset: 0;
}

.hero .title{
    position: absolute;
    top: 25%;
    left: 50%;
    translate: -50% -50%;
    z-index: 2;
    width: 100%;
    font-size: max(12vw, 3rem);
    line-height: 1.2;
}

/* タブレット・PC用 */
@media screen and (min-width: 768px) {
    .hero::after{
        background: url('../images/bridaly.png') no-repeat center / cover;
    }
}


/* concept */

.concept{
    margin: 8rem 0;
    background-image: linear-gradient(
        to right,
        transparent 0%,
        transparent 20%,
        var(--light-grey)20%,
        var(--light-grey)100%
    );
}

.concept p{
    text-align: left;
    margin-bottom: 2rem;
}


/* gallery */

.gallery{
    display: flex;
    flex-direction: column-reverse;
}

.gallery-image{
    width: min(100%, clac(38rem - 2rem));
    margin: auto;
    position: relative;
    top: 3rem;
}

.gallery-image::after {
    display: block;
    content: '';
    width: calc(100% - 2rem);
    height: calc(100% - 2.5rem);
    z-index: 3;
    border: 3px solid var(--white);
    top: 1rem;
    left: 1rem;
    position: absolute;
}

.gallery-image img{
    aspect-ratio: 3/4;
    object-fit: cover;
    width: 100%;
}

.gallery-thumbnails {
   display: grid;
   gap: 1rem;
   grid-template-columns: repeat(5,1fr);
   list-style: none;
   max-width: 1rem 0;
}

.gallery-thumbnails img{
    aspect-ratio: 3/4;
    object-fit: cover;
    cursor: pointer;
}

/* shop info */

.shop{
    background: url(../images/shoplt.png)
    no-repeat center top / cover;
    margin-top: 16rem;
    position: relative;
    height: 60rem;
}

.shop-content{
    background: var(--white);
    padding: 3rem;
    position: absolute;
    top: -8rem;
    width: 90vw;
    left: 0;
    right: 0;
    
}

.shop h3{
    margin: 1rem 0;
    padding-top: 2rem;
    font-weight: normal;
    border-top: 1px solid var(--light-grey);
}