@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&display=swap');

:root{

    --bg:#0d0f0c;

    --surface:#141613;

    --primary:#89A63A;
    --primary-dark:#355F24;
    --primary-light:#E8E8D8;

    --text:#f4f4ee;
    --muted:#8f9485;

}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{

    background:var(--bg);

    color:var(--text);

    font-family:'Montserrat',sans-serif;

    overflow-x:hidden;
}

/* NAV */

.nav{

    position:fixed;

    top:0;

    width:100%;

    z-index:999;

    display:flex;
    justify-content:space-between;
    align-items:center;

    padding:24px 60px;

    backdrop-filter:blur(20px);

    background:rgba(10,10,10,.2);
}

.brand{

    display:flex;
    align-items:center;
    gap:14px;

    color:white;

    text-decoration:none;
}

.brand img{
    width:34px;
}

nav{

    display:flex;
    gap:30px;
}

nav a{

    color:#ddd;

    text-decoration:none;

    font-size:14px;
}

/* HERO */

.hero{

    height:100vh;

    position:relative;

    display:flex;
    align-items:center;
    justify-content:center;

    text-align:center;

    background-image:url('../img/studio.png');
    background-size:cover;
    background-position:center;
}

.hero-overlay{

    position:absolute;
    inset:0;

    background:
    linear-gradient(
        rgba(0,0,0,.45),
        rgba(0,0,0,.85)
    );
}

.hero-content{

    position:relative;
    z-index:2;

    max-width:900px;

    padding:20px;
}

.eyebrow{

    color:var(--primary);

    letter-spacing:4px;

    font-size:12px;
}

.hero h1{

    font-size:clamp(4rem,10vw,8rem);

    line-height:.95;

    margin:25px 0;

    letter-spacing:-.05em;
}

.hero p{

    max-width:600px;

    margin:auto;

    color:#c7c7c0;

    line-height:1.8;
}

.hero-actions{

    margin-top:40px;

    display:flex;
    justify-content:center;
    gap:16px;
}

.btn-primary{

    background:var(--primary);

    color:#111;

    padding:14px 28px;

    border-radius:999px;

    text-decoration:none;

    font-weight:600;
}

.btn-secondary{

    background:rgba(255,255,255,.08);

    backdrop-filter:blur(20px);

    color:white;

    padding:14px 28px;

    border-radius:999px;

    text-decoration:none;
}

/* STATEMENT */

.statement{

    padding:180px 10vw;

    text-align:center;
}

.statement p{

    font-size:clamp(2rem,6vw,5rem);

    font-weight:700;

    line-height:1.1;

    letter-spacing:-.04em;
}

/* GALLERY */

.gallery-section{

    padding:160px 5vw;
}

.gallery-header{

    text-align:center;
    margin-bottom:80px;
}

.gallery-header span{

    color:var(--primary);

    letter-spacing:4px;
    font-size:12px;
}

.gallery-header h2{

    margin-top:20px;

    font-size:clamp(3rem,6vw,5rem);

    letter-spacing:-.04em;
}

.gallery-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:20px;
}

.gallery-item{

    overflow:hidden;
    border-radius:24px;
}

.gallery-item.large{

    grid-column:span 2;
    grid-row:span 2;
}

.gallery-item img{

    width:100%;
    height:100%;

    object-fit:cover;

    display:block;

    transition:.6s;
}

.gallery-item:hover img{

    transform:scale(1.05);
}

@media(max-width:768px){

    .gallery-grid{

        grid-template-columns:1fr;
    }

    .gallery-item.large{

        grid-column:auto;
        grid-row:auto;
    }
}

/* SERVICES */

.services{

    max-width:1100px;

    margin:auto;

    padding:120px 40px;
}

.service{

    padding:40px 0;

    border-bottom:1px solid rgba(255,255,255,.08);

    display:flex;
    justify-content:space-between;
    align-items:center;

    transition:.3s;
}

.service:hover{

    transform:translateX(20px);
}

.service span{

    color:var(--primary);

    font-size:14px;
}

.service h2{

    font-size:clamp(2rem,4vw,4rem);
}

/* STUDIO */

.studio{

    padding:160px 0;
}

.studio-image{

    height:80vh;

    background-image:url('../img/studio.png');
    background-size:cover;
    background-position:center;
}

.studio-copy{

    text-align:center;

    padding:100px 20px;
}

.studio-copy span{

    color:var(--primary);

    letter-spacing:4px;
}

.studio-copy h2{

    margin-top:20px;

    font-size:clamp(3rem,7vw,6rem);

    line-height:1;
}

/* CONTACT */

.contact{

    text-align:center;

    padding:180px 20px;
}

.contact h2{

    font-size:clamp(3rem,7vw,6rem);

    margin-bottom:20px;
}

.contact p{

    color:var(--muted);

    margin-bottom:40px;
}

.contact-button{

    display:inline-block;

    background:var(--primary);

    color:black;

    text-decoration:none;

    padding:16px 32px;

    border-radius:999px;
}

.instagram{

    display:block;

    margin-top:30px;

    color:var(--primary);

    text-decoration:none;
}

footer{

    text-align:center;

    padding:60px;

    color:#777;
}

@media(max-width:768px){

    .nav{

        padding:20px;
    }

    nav{
        display:none;
    }

    .hero-actions{

        flex-direction:column;
    }

    .service{

        flex-direction:column;
        align-items:flex-start;
        gap:10px;
    }
}
