:root{
    --black:#080909;
    --dark:#111414;
    --charcoal:#181c1b;
    --panel:#202423;
    --gold:#d4a373;
    --green:#5e7d70;
    --light:#f5f5f5;
    --muted:#b9c0bd;
    --white:#ffffff;
    --line:rgba(255,255,255,0.1);
}

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

body{
    font-family:Arial, Helvetica, sans-serif;
    background:var(--black);
    color:var(--white);
    line-height:1.6;
}

a{
    color:inherit;
    text-decoration:none;
}

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

.container{
    width:88%;
    max-width:1200px;
    margin:auto;
}

header{
    background:rgba(8,9,9,0.96);
    border-bottom:1px solid var(--line);
    position:sticky;
    top:0;
    z-index:100;
    backdrop-filter:blur(12px);
}

.navbar{
    min-height:76px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:25px;
}

.logo{
    font-size:22px;
    font-weight:800;
    letter-spacing:0;
    white-space:nowrap;
}

.logo span,
nav a:hover,
nav a[aria-current="page"]{
    color:var(--gold);
}

nav{
    display:flex;
    align-items:center;
    gap:22px;
    flex-wrap:wrap;
}

nav a{
    font-size:14px;
    font-weight:700;
    opacity:0.94;
}

.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:48px;
    background:var(--gold);
    color:#111;
    padding:12px 22px;
    border-radius:6px;
    border:1px solid var(--gold);
    font-weight:800;
    transition:0.2s ease;
}

.btn:hover{
    transform:translateY(-2px);
    filter:brightness(1.08);
}

.btn-outline{
    color:var(--gold);
    background:transparent;
}

.text-link{
    color:var(--gold);
    font-weight:800;
}

.hero{
    min-height:660px;
    background:
        linear-gradient(90deg, rgba(8,9,9,0.9), rgba(8,9,9,0.68) 46%, rgba(8,9,9,0.9)),
        linear-gradient(135deg, rgba(94,125,112,0.55), rgba(212,163,115,0.16)),
        url("images/site/home-hero.jpg") center/cover no-repeat;
    display:flex;
    align-items:center;
}

.hero-content{
    max-width:900px;
}

.eyebrow{
    color:var(--gold);
    font-size:13px;
    font-weight:800;
    letter-spacing:1.8px;
    text-transform:uppercase;
    margin-bottom:12px;
}

.hero h1{
    font-size:56px;
    line-height:1.08;
    max-width:980px;
    margin-bottom:22px;
}

.hero p{
    font-size:20px;
    color:#e6ece9;
    max-width:780px;
    margin-bottom:30px;
}

.hero-buttons,
.contact-actions{
    display:flex;
    gap:14px;
    flex-wrap:wrap;
}

.section{
    padding:78px 0;
}

.section-title{
    margin-bottom:36px;
}

.section-title.compact{
    margin-bottom:24px;
}

.section-title small{
    color:var(--gold);
    font-weight:800;
    letter-spacing:1.8px;
    text-transform:uppercase;
}

.section-title h2{
    font-size:38px;
    line-height:1.15;
    margin-top:8px;
}

.section-title p{
    color:var(--muted);
    max-width:760px;
    margin-top:12px;
}

.inline-title{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:24px;
}

.split-grid,
.about-grid{
    display:grid;
    grid-template-columns:1.15fr 0.85fr;
    gap:34px;
    align-items:start;
}

.stats{
    display:grid;
    gap:18px;
}

.stat,
.service-item,
.form-box,
.contact-box,
.project-card{
    background:var(--charcoal);
    border:1px solid var(--line);
    border-radius:8px;
}

.stat{
    padding:26px;
}

.stat strong{
    display:block;
    font-size:32px;
    line-height:1;
    color:var(--gold);
    margin-bottom:8px;
}

.stat span{
    color:#d4dbd8;
}

.check-list{
    display:grid;
    gap:12px;
}

.check-list span{
    position:relative;
    padding-left:26px;
    color:#dde3e0;
}

.check-list span::before{
    content:"";
    position:absolute;
    left:0;
    top:10px;
    width:10px;
    height:10px;
    border-radius:50%;
    background:var(--gold);
    box-shadow:0 0 0 4px rgba(212,163,115,0.14);
}

.check-list.boxed{
    background:var(--panel);
    border:1px solid var(--line);
    border-radius:8px;
    padding:26px;
}

.services-wrap{
    background:#101312;
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
}

.service-list{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));
    gap:18px;
}

.featured-services{
    grid-template-columns:repeat(3, 1fr);
}

.service-item{
    padding:26px;
    min-height:220px;
}

.service-number{
    display:block;
    color:var(--green);
    font-size:13px;
    font-weight:900;
    margin-bottom:22px;
}

.service-item h3{
    color:var(--gold);
    font-size:22px;
    line-height:1.2;
    margin-bottom:10px;
}

.service-item p{
    color:#d2d8d5;
    font-size:15px;
}

.projects-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(290px, 1fr));
    gap:22px;
}

.empty-state{
    background:var(--charcoal);
    border:1px solid var(--line);
    border-radius:8px;
    padding:34px;
    max-width:760px;
}

.services-wrap .empty-state{
    background:#171b1a;
}

.empty-state h3{
    color:var(--gold);
    font-size:26px;
    line-height:1.2;
    margin-bottom:10px;
}

.empty-state p{
    color:#d0d7d4;
}

.project-card{
    overflow:hidden;
}

.project-card-link{
    display:block;
    height:100%;
}

.project-media{
    position:relative;
    min-height:230px;
    background:
        linear-gradient(135deg, rgba(94,125,112,0.8), rgba(212,163,115,0.28)),
        #202423;
    overflow:hidden;
}

.project-media::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(transparent 48%, rgba(0,0,0,0.55));
    pointer-events:none;
}

.project-media.is-missing::before{
    content:attr(data-fallback);
    position:absolute;
    left:22px;
    right:22px;
    bottom:20px;
    z-index:2;
    color:var(--white);
    font-size:24px;
    font-weight:800;
    line-height:1.15;
}

.project-card img{
    width:100%;
    height:230px;
    object-fit:cover;
    transition:0.35s ease;
}

.project-card:hover img{
    transform:scale(1.04);
}

.project-body{
    padding:22px;
}

.project-meta{
    color:var(--green);
    font-size:13px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:1px;
    margin-bottom:6px;
}

.project-body h3{
    color:var(--gold);
    line-height:1.2;
    margin-bottom:8px;
}

.project-body p{
    color:#d0d7d4;
    font-size:15px;
}

.project-note{
    margin-top:12px;
    color:#f0d2b4 !important;
}

.project-detail-hero{
    min-height:360px;
    display:flex;
    align-items:center;
}

.project-facts{
    align-self:start;
}

.project-gallery{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:20px;
}

.project-gallery .gallery-card:first-child{
    grid-column:1 / -1;
}

.gallery-card{
    position:relative;
    min-height:280px;
    overflow:hidden;
    border-radius:8px;
    background:
        linear-gradient(135deg, rgba(94,125,112,0.8), rgba(212,163,115,0.28)),
        #202423;
    border:1px solid var(--line);
}

.gallery-card img{
    width:100%;
    height:100%;
    min-height:280px;
    object-fit:cover;
}

.project-gallery .gallery-card:first-child img{
    min-height:520px;
}

.gallery-card::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(transparent 56%, rgba(0,0,0,0.7));
    pointer-events:none;
}

.gallery-card figcaption{
    position:absolute;
    left:18px;
    bottom:14px;
    z-index:2;
    color:#ffffff;
    font-size:14px;
    font-weight:800;
}

.gallery-card.is-missing::before{
    content:"Photo coming soon";
    position:absolute;
    left:22px;
    bottom:20px;
    z-index:2;
    color:var(--white);
    font-size:22px;
    font-weight:800;
}

.cta{
    background:
        linear-gradient(135deg, rgba(94,125,112,0.22), rgba(212,163,115,0.18)),
        #111414;
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
    text-align:center;
}

.cta h2{
    font-size:38px;
    line-height:1.15;
    margin-bottom:12px;
}

.cta p{
    color:#d6ddda;
    max-width:760px;
    margin:0 auto 26px;
}

.page-hero{
    padding:98px 0;
    background:
        linear-gradient(90deg, rgba(8,9,9,0.9), rgba(8,9,9,0.72)),
        linear-gradient(135deg, rgba(94,125,112,0.48), rgba(212,163,115,0.16)),
        url("images/site/page-hero.jpg") center/cover no-repeat;
}

.page-hero h1{
    font-size:48px;
    line-height:1.1;
    max-width:920px;
}

.page-hero p{
    color:#dee5e2;
    max-width:760px;
    margin-top:14px;
    font-size:18px;
}

.form-box,
.contact-box{
    padding:30px;
}

.quote-grid{
    display:grid;
    grid-template-columns:1.15fr 0.85fr;
    gap:24px;
    align-items:start;
}

.form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
}

label{
    display:grid;
    gap:7px;
    color:#dce3e0;
    font-size:14px;
    font-weight:800;
}

input,
textarea{
    width:100%;
    padding:14px;
    background:#0f1111;
    color:white;
    border:1px solid rgba(255,255,255,0.15);
    border-radius:6px;
    font-size:15px;
}

input:focus,
textarea:focus{
    outline:2px solid rgba(212,163,115,0.45);
    border-color:var(--gold);
}

textarea{
    min-height:160px;
    resize:vertical;
}

.full{
    grid-column:1 / -1;
}

.quote-aside h2,
.contact-box h2{
    color:var(--gold);
    font-size:26px;
    line-height:1.2;
    margin-bottom:18px;
}

.quote-aside .btn{
    margin-top:24px;
    width:100%;
}

.contact-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:24px;
}

.contact-line{
    margin-bottom:18px;
}

.contact-line strong{
    color:var(--gold);
    display:block;
    margin-bottom:4px;
}

.contact-line a,
.contact-line span,
.contact-box p{
    color:#d7dedb;
}

.contact-actions{
    margin-top:24px;
}

footer{
    background:#050606;
    padding:28px 0;
    color:#bfc7c3;
    border-top:1px solid var(--line);
    font-size:14px;
}

.footer-grid{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    flex-wrap:wrap;
}

@media(max-width:900px){
    .navbar{
        align-items:flex-start;
        flex-direction:column;
        padding:18px 0;
    }

    nav{
        gap:14px;
    }

    .hero{
        min-height:590px;
    }

    .hero h1{
        font-size:40px;
    }

    .hero p,
    .page-hero p{
        font-size:17px;
    }

    .split-grid,
    .about-grid,
    .contact-grid,
    .quote-grid,
    .form-grid,
    .featured-services,
    .project-gallery{
        grid-template-columns:1fr;
    }

    .project-gallery .gallery-card:first-child{
        grid-column:auto;
    }

    .project-gallery .gallery-card:first-child img{
        min-height:320px;
    }

    .section-title h2,
    .cta h2{
        font-size:31px;
    }

    .page-hero h1{
        font-size:38px;
    }

    .inline-title{
        display:block;
    }

    .inline-title .text-link{
        display:inline-block;
        margin-top:10px;
    }
}

@media(max-width:560px){
    .container{
        width:90%;
    }

    nav a{
        font-size:13px;
    }

    .hero{
        min-height:560px;
    }

    .hero h1{
        font-size:34px;
    }

    .section{
        padding:58px 0;
    }

    .page-hero{
        padding:74px 0;
    }

    .page-hero h1{
        font-size:34px;
    }

    .btn{
        width:100%;
    }

    .contact-actions .btn,
    .hero-buttons .btn{
        width:100%;
    }
}
