:root {
    --black: #050505;
    --panel: rgba(13, 12, 10, 0.78);
    --line: rgba(209, 162, 76, 0.24);
    --gold: #d1a24c;
    --gold-2: #f5deb0;
    --text: #f8f4ec;
    --muted: rgba(248, 244, 236, 0.62);
    --soft: rgba(255, 255, 255, 0.05);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    background: radial-gradient(circle at 80% 0%, rgba(209, 162, 76, .15), transparent 32rem), var(--black);
    color: var(--text);
    font-family: Inter, "Segoe UI", Arial, sans-serif;
}
a { color: inherit; text-decoration: none; }
img, video { max-width: 100%; display: block; }

.site-header {
    position: fixed;
    inset: 0 0 auto 0;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    height: 80px;
    padding: 0 clamp(20px, 4vw, 56px);
    border-bottom: 1px solid rgba(255,255,255,.1);
    background: rgba(0,0,0,.72);
    backdrop-filter: blur(22px);
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand img { width: 52px; height: 52px; object-fit: contain; border: 1px solid var(--line); padding: 4px; }
.brand strong, .brand small { display: block; text-transform: uppercase; letter-spacing: .24em; }
.brand small { color: var(--gold); font-size: 11px; }
.brand strong { font-size: 14px; }
.main-nav ul { display: flex; gap: 26px; list-style: none; padding: 0; margin: 0; }
.main-nav a { color: rgba(255,255,255,.62); font-size: 12px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; }
.main-nav a:hover { color: var(--gold-2); }
.header-actions { display: flex; gap: 12px; }
.menu-toggle { display: none; }

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 22px;
    border: 1px solid var(--gold);
    background: var(--gold);
    color: #070605;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: .08em;
}
.btn-outline { background: transparent; color: var(--gold-2); border-color: var(--line); }
.btn:hover { filter: brightness(1.12); }

.hero {
    position: relative;
    min-height: 100vh;
    padding: 160px clamp(20px, 4vw, 56px) 100px;
    overflow: hidden;
    display: grid;
    grid-template-columns: 1fr minmax(320px, 540px);
    align-items: center;
    gap: 8vw;
}
.hero video, .hero-overlay { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-overlay { background: linear-gradient(90deg, rgba(0,0,0,.94), rgba(0,0,0,.66), rgba(0,0,0,.2)), linear-gradient(180deg, transparent, #050505 96%); }
.hero-content, .hero-card { position: relative; z-index: 2; }
.eyebrow { color: var(--gold-2); font-size: 12px; font-weight: 900; letter-spacing: .24em; text-transform: uppercase; }
h1, h2, h3 { margin: 0; line-height: .96; letter-spacing: 0; }
.hero h1 { max-width: 800px; font-size: clamp(52px, 8vw, 116px); }
.hero h1 span, .section-head h1 span { display: block; color: var(--gold); }
.hero p:not(.eyebrow), .section-head p:not(.eyebrow), .panel p, .project-card p, .before-after p, .map-copy p { color: var(--muted); line-height: 1.75; }
.hero-content > p:not(.eyebrow) { max-width: 720px; font-size: 19px; }
.actions { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 34px; }
.hero-card, .panel, .quote-form, .before-after, .service-map {
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.02)), var(--panel);
    box-shadow: 0 28px 90px rgba(0,0,0,.42);
}
.hero-card { padding: 38px; }
.hero-card img { margin: 0 auto 28px; max-height: 360px; object-fit: contain; }

.section { padding: clamp(76px, 9vw, 140px) clamp(20px, 4vw, 56px); }
.section-dark { border-block: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.018); }
.section-head { max-width: 860px; margin-bottom: 48px; }
.section-head h1, .section-head h2 { margin-top: 18px; font-size: clamp(42px, 6vw, 74px); }
.section-head-compact { max-width: 620px; margin-bottom: 24px; }
.section-head-compact h2 { font-size: clamp(28px, 3.6vw, 42px); }
.page-hero { min-height: 520px; padding: 170px clamp(20px, 4vw, 56px) 90px; background-size: cover; background-position: center; position: relative; }
.page-hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, #050505, rgba(5,5,5,.72), #050505); }
.page-hero > * { position: relative; z-index: 1; }
.portfolio-hero { background-image: url('../media/estate-entry-gate.png'); }
.services-hero, .contact-hero { background-image: url('../media/luxury-metalwork-hero.png'); }
.about-hero { background-image: url('../media/floating-stair-railing.png'); }

.stats, .card-grid, .project-grid, .process-grid, .contact-grid, .footer-grid, .two-col {
    display: grid;
    gap: 18px;
}
.stats { grid-template-columns: repeat(4, 1fr); padding: 0 clamp(20px, 4vw, 56px) 40px; margin-top: -64px; position: relative; z-index: 4; }
.stats div { border: 1px solid rgba(255,255,255,.1); background: rgba(0,0,0,.72); padding: 26px; }
.stats strong { display: block; font-size: 46px; }
.stats span { color: rgba(255,255,255,.46); font-size: 12px; font-weight: 900; letter-spacing: .18em; text-transform: uppercase; }
.card-grid { grid-template-columns: repeat(3, 1fr); }
.panel { padding: 28px; }
.panel > span, .contact-cards span { display: block; color: rgba(255,255,255,.32); font-size: 12px; font-weight: 900; letter-spacing: .18em; text-transform: uppercase; margin-bottom: 28px; }
.panel h3, .panel h2 { font-size: 28px; margin-bottom: 16px; }

.project-grid { grid-template-columns: repeat(2, 1fr); }
.project-card { position: relative; min-height: 460px; overflow: hidden; border: 1px solid rgba(255,255,255,.1); }
.project-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .7s ease; }
.project-card:hover img { transform: scale(1.05); }
.project-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(transparent, rgba(0,0,0,.86)); }
.project-card div { position: absolute; z-index: 2; inset: auto 0 0 0; padding: 30px; }
.project-card h3 { font-size: 34px; }

.before-after { display: grid; grid-template-columns: 1.15fr .85fr; gap: 34px; padding: 28px; align-items: center; }
.ba-stage { position: relative; aspect-ratio: 16/10; overflow: hidden; background: #000; }
.ba-stage img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ba-after-wrap { position: absolute; inset: 0 auto 0 0; overflow: hidden; border-right: 2px solid var(--gold); }
.ba-stage input { position: absolute; left: 20px; right: 20px; bottom: 20px; width: calc(100% - 40px); accent-color: var(--gold); }

.testimonial { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 28px; border: 1px solid var(--line); padding: 34px; background: var(--panel); }
.testimonial blockquote { margin: 0; font-size: clamp(28px, 4vw, 54px); line-height: 1.08; }
.testimonial button { border: 1px solid var(--line); background: transparent; color: var(--gold-2); padding: 12px 16px; }
.reviews-wrap { display: grid; gap: 18px; max-width: 1080px; }
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.review-card, .live-reviews {
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.018)), var(--panel);
    padding: 20px;
}
.review-card blockquote { margin: 0 0 18px; font-size: clamp(18px, 2vw, 24px); line-height: 1.28; }
.review-card .stars { color: var(--gold); letter-spacing: .12em; }
.review-card span, .reviews-note { color: rgba(255,255,255,.45); }
.reviews-note { margin: 0; font-size: 14px; line-height: 1.7; }

.service-map { display: grid; grid-template-columns: 1.1fr .9fr; min-height: 460px; overflow: hidden; }
.map-art { position: relative; min-height: 460px; background: radial-gradient(circle at 50% 0, rgba(209,162,76,.16), transparent 40%), #080807; }
.map-art svg { position: absolute; inset: 0; width: 100%; height: 100%; fill: rgba(255,255,255,.035); stroke: rgba(209,162,76,.32); }
.map-pin { position: absolute; transform: translate(-50%, -50%); width: 48px; height: 48px; border: 1px solid var(--line); background: rgba(0,0,0,.7); color: var(--gold-2); cursor: pointer; }
.map-pin.is-active, .map-pin:hover { background: var(--gold); color: #050505; }
.map-copy { padding: 44px; align-self: center; }
.map-copy h2 { font-size: 52px; }
.maps-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.map-embed {
    border: 1px solid var(--line);
    background: var(--panel);
    overflow: hidden;
}
.map-embed > div { padding: 24px; }
.map-embed h2 { font-size: clamp(26px, 3vw, 40px); }
.map-embed iframe {
    width: 100%;
    min-height: 380px;
    border: 0;
    filter: grayscale(1) invert(.92) contrast(.9);
}

.contact-grid { grid-template-columns: .78fr 1.22fr; }
.contact-cards { display: grid; gap: 14px; }
.contact-cards strong { font-size: 22px; line-height: 1.25; }
.quote-form { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; padding: 32px; }
.quote-form label { color: var(--muted); font-size: 14px; }
.quote-form input, .quote-form select, .quote-form textarea {
    width: 100%;
    margin-top: 8px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.035);
    color: #fff;
    padding: 14px;
}
.quote-form .full, .quote-form .btn, .notice { grid-column: 1 / -1; }
.project-options {
    border: 1px solid rgba(255,255,255,.12);
    padding: 18px;
    margin: 0;
}
.project-options legend { color: var(--muted); font-size: 14px; padding: 0 8px; }
.project-options div { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-top: 10px; }
.project-options label { position: relative; cursor: pointer; }
.quote-form .project-options input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    margin: 0;
    padding: 0;
}
.project-options span {
    display: block;
    min-height: 48px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.035);
    color: #fff;
    padding: 14px;
    transition: border-color .2s ease, background .2s ease, color .2s ease;
}
.project-options input:checked + span {
    border-color: var(--gold);
    background: rgba(209,162,76,.16);
    color: var(--gold-2);
}
.project-options input:focus-visible + span { outline: 2px solid var(--gold); outline-offset: 2px; }
.upload { border: 1px dashed var(--line); padding: 24px; }
.notice { border: 1px solid var(--line); background: rgba(209,162,76,.12); padding: 14px; color: var(--gold-2); }
.notice-error { border-color: rgba(255, 120, 120, .35); background: rgba(255, 80, 80, .08); color: #ffd6d6; }
.captcha-field {
    border: 1px solid rgba(209,162,76,.28);
    background: rgba(209,162,76,.06);
    padding: 18px;
}
.captcha-field input { max-width: 180px; }
.captcha-label { margin: 0 0 12px; color: var(--gold-2); font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.hp-field {
    position: absolute !important;
    left: -10000px !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}
.location-list { display: grid; gap: 14px; margin-top: 24px; }
.location-list a { border: 1px solid rgba(255,255,255,.1); background: var(--soft); padding: 18px; }
.location-list span { display: block; color: var(--muted); margin-top: 6px; }
.logo-panel { border: 1px solid var(--line); background: #000; padding: 42px; }
.two-col { grid-template-columns: .8fr 1.2fr; align-items: center; }

.site-footer { border-top: 1px solid rgba(255,255,255,.1); background: #000; padding: 70px clamp(20px, 4vw, 56px) 24px; }
.footer-grid { grid-template-columns: 1.2fr 1fr 1.2fr 1fr 1fr; }
.footer-logo { max-width: 150px; margin-bottom: 20px; }
.site-footer h2 { font-size: 12px; color: var(--gold-2); letter-spacing: .24em; text-transform: uppercase; margin-bottom: 18px; }
.site-footer a, .site-footer p { display: block; color: rgba(255,255,255,.58); line-height: 1.7; margin: 0 0 12px; }
.protected-contact.btn span { display: none; }
.protected-contact.btn strong { font-size: inherit; }
.footer-contact-link strong { display: block; color: rgba(255,255,255,.58); font-weight: 400; }
.site-footer a:hover { color: var(--gold-2); }
.site-footer span { display: block; color: rgba(255,255,255,.42); }
.copyright { border-top: 1px solid rgba(255,255,255,.1); padding-top: 22px; margin-top: 50px !important; font-size: 12px; text-transform: uppercase; letter-spacing: .16em; }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .85s ease, transform .85s ease; }
.reveal.in-view { opacity: 1; transform: translateY(0); }

@media (max-width: 980px) {
    .site-header { height: auto; min-height: 78px; flex-wrap: wrap; }
    .menu-toggle { display: inline-flex; border: 1px solid var(--line); background: transparent; color: var(--gold-2); padding: 12px 14px; }
    .main-nav, .header-actions { display: none; width: 100%; }
    .site-header.is-open .main-nav, .site-header.is-open .header-actions { display: block; }
    .main-nav ul, .header-actions { padding: 16px 0; }
    .main-nav ul { display: grid; gap: 10px; }
    .header-actions { display: none; }
    .hero, .before-after, .service-map, .contact-grid, .two-col, .maps-grid { grid-template-columns: 1fr; }
    .hero-card { display: none; }
    .stats, .card-grid, .project-grid, .process-grid, .footer-grid, .reviews-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 620px) {
    .brand span { display: none; }
    .hero { padding-top: 130px; }
    .stats, .card-grid, .project-grid, .process-grid, .footer-grid, .quote-form, .reviews-grid { grid-template-columns: 1fr; }
    .project-options div { grid-template-columns: 1fr; }
    .project-card { min-height: 390px; }
    .testimonial { grid-template-columns: 1fr; }
}
