:root{
    --color-black:#111111;
    --color-white:#ffffff;
    --color-primary:#79a56f;
    --color-primary-hover:#6f9666;
    --text-primary:#1a1a1a;
    --text-secondary:#5f5f5f;
    --text-light:rgba(255,255,255,.92);
    --font-serif:"Cormorant Garamond",serif;
    --font-sans:"Inter",sans-serif;
    --container:1380px;
    --transition:300ms ease;
    --radius-full:999px;
    --primary:#6f8f6a;
    --white:#ffffff;
    --black:#111111;
}

/* =========================
   RESET / BASE
========================= */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    font-family:var(--font-sans);
    background:#fff;
    color:#111;
    overflow-x:hidden;
}

img{
    max-width:100%;
    display:block;
}

a{
    text-decoration:none;
}

button{
    font:inherit;
}

.container{
    width:min(92%,var(--container));
    margin-inline:auto;
}

/* =========================
   HEADER - FIRST PAINT
========================= */

.site-header{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    z-index:1000;
}

.site-header::before{
    content:"";
    position:absolute;
    inset:0;
    height:180px;
    background:
        linear-gradient(
            to bottom,
            rgba(0,0,0,.34),
            rgba(0,0,0,.16),
            transparent
        );
    pointer-events:none;
    z-index:-1;
}

.navbar{
    padding:2.4rem 0;
}

.navbar-inner{
    display:grid;
    grid-template-columns:1fr auto 1fr;
    align-items:center;
}

.nav-group{
    display:flex;
    align-items:center;
    gap:3rem;
}

.nav-left{
    justify-content:flex-end;
}

.nav-right{
    justify-content:flex-start;
}

.nav-group a,
.dropdown-toggle{
    position:relative;
    display:inline-flex;
    align-items:center;
    white-space:nowrap;
    color:#ffffff;
    font-size:12px;
    font-weight:600;
    letter-spacing:.14em;
    text-transform:uppercase;
    text-shadow:
        0 2px 10px rgba(0,0,0,.28),
        0 4px 24px rgba(0,0,0,.18);
    background:none;
    border:none;
    cursor:pointer;
}

.nav-group a::after,
.dropdown-toggle::after{
    content:"";
    position:absolute;
    left:0;
    bottom:-8px;
    width:100%;
    height:1px;
    background:rgba(255,255,255,.95);
    transform:scaleX(0);
    transform-origin:left;
    transition:transform .28s ease;
}

.nav-group a:hover::after,
.dropdown-toggle:hover::after{
    transform:scaleX(1);
}

/* =========================
   LOGO
========================= */

.logo-center{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    margin-inline:5.5rem;
    transform:translateY(-2px);
    color:#fff;
}

.logo-center img{
    width:78px;
    height:auto;
    filter:
        drop-shadow(0 8px 18px rgba(0,0,0,.24))
        drop-shadow(0 14px 34px rgba(0,0,0,.18));
}

.logo-center span{
    margin-top:.45rem;
    font-size:9px;
    font-weight:500;
    letter-spacing:.18em;
    text-transform:uppercase;
    white-space:nowrap;
    color:rgba(255,255,255,.94);
    text-shadow:
        0 2px 12px rgba(0,0,0,.30),
        0 4px 26px rgba(0,0,0,.20);
}

/* =========================
   DROPDOWN - HIDDEN BY DEFAULT
========================= */

.nav-dropdown{
    position:relative;
}

.dropdown-menu{
    position:absolute;
    top:calc(100% + 1.2rem);
    right:0;
    min-width:220px;
    display:flex;
    flex-direction:column;
    gap:1rem;
    padding:1.4rem 1.6rem;
    border-radius:20px;
    background:rgba(255,255,255,.96);
    box-shadow:0 20px 60px rgba(0,0,0,.10);
    opacity:0;
    visibility:hidden;
    transform:translateY(10px);
    transition:
        opacity .25s ease,
        transform .25s ease,
        visibility .25s ease;
}

.dropdown-menu a{
    color:#111;
    font-size:11px;
    font-weight:600;
    letter-spacing:.14em;
    text-transform:uppercase;
    text-shadow:none;
}

.nav-dropdown:hover .dropdown-menu{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
}

/* =========================
   MOBILE MENU - HIDDEN SAFELY
========================= */

.mobile-toggle{
    display:none;
    width:48px;
    height:48px;
    border:none;
    background:none;
    cursor:pointer;
}

.mobile-toggle span{
    display:block;
    width:28px;
    height:2px;
    margin:6px auto;
    background:#fff;
    box-shadow:0 2px 8px rgba(0,0,0,.24);
}

.mobile-menu{
    position:fixed;
    inset:0;
    background:#f7f7f7;
    z-index:9999;
    overflow-y:auto;
    opacity:0;
    visibility:hidden;
}

.mobile-menu.active{
    opacity:1;
    visibility:visible;
}

body.menu-open{
    overflow:hidden;
}

/* =========================
   HERO - FIRST PAINT
========================= */

.hero{
    position:relative;
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
}

.hero picture{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
}

.hero-image{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    contain:paint;
}

.hero-overlay{
    position:absolute;
    inset:0;
    background:
        linear-gradient(
            to bottom,
            rgba(0,0,0,.18),
            rgba(0,0,0,.32)
        );
}

.hero-content{
    position:relative;
    z-index:2;
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    transform:translateY(-30px);
}

.hero-subtitle{
    margin-bottom:1.3rem;
    font-family:var(--font-sans);
    font-size:2rem;
    font-weight:400;
    line-height:1.2;
    letter-spacing:-.02em;
    color:rgba(255,255,255,.95);
    text-shadow:
        0 2px 8px rgba(6,135,41,.35),
        0 4px 18px rgba(0,0,0,.18);
}

.hero-title{
    max-width:980px;
    margin:0 auto;
    font-family:var(--font-sans);
    font-size:clamp(2.8rem,3.8vw,4.4rem);
    font-weight:700;
    line-height:1.08;
    letter-spacing:-.04em;
    color:#fff;
    text-shadow:
        0 2px 8px rgba(8,75,22,.35),
        0 4px 18px rgba(0,0,0,.18);
}

.hero-button{
    margin-top:2.2rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    height:58px;
    padding-inline:2.8rem;
    border-radius:999px;
    background:#2f7d36;
    color:#fff;
    font-family:var(--font-sans);
    font-size:1rem;
    font-weight:600;
    text-decoration:none;
    transition:
        transform .3s ease,
        background .3s ease;
}

.hero-button:hover{
    background:#286d2f;
    transform:translateY(-2px);
}

/* =========================
   RESPONSIVE FIRST PAINT
========================= */

@media(max-width:1200px){

    .nav-group{
        gap:1.8rem;
    }

}

@media(max-width:1100px){

    .nav-group{
        display:none;
    }

    .navbar-inner{
        grid-template-columns:auto 1fr auto;
    }

    .logo-center{
        justify-self:center;
        margin-inline:0;
    }

    .mobile-toggle{
        display:block;
        justify-self:end;
    }

}

@media(max-width:768px){

    .navbar{
        padding:1.4rem 0;
    }

    .logo-center img{
        width:82px;
    }

    .logo-center span{
        font-size:8px;
        letter-spacing:.16em;
    }

    .hero{
        min-height:100svh;
    }

    .hero-image{
        object-position:18% center;
    }

    .hero-content{
        transform:translateY(-10px);
        padding-inline:1.5rem;
    }

    .hero-subtitle{
        max-width:280px;
        margin-bottom:1rem;
        font-size:1.05rem;
        line-height:1.25;
    }

    .hero-title{
        max-width:320px;
        font-size:clamp(2.4rem,9vw,3.8rem);
        line-height:1.02;
        letter-spacing:-.05em;
    }

    .hero-button{
        margin-top:1.8rem;
        height:50px;
        padding-inline:2rem;
        font-size:.95rem;
    }

}

@media(max-width:768px) and (prefers-reduced-motion:reduce){

    html{
        scroll-behavior:auto;
    }

    *,
    *::before,
    *::after{
        transition:none !important;
        animation:none !important;
    }

}