/* ═══════════════════════════════════════════════════════════════
   Leeds Loft Conversions — Premium Story Layout v4
   Containers: 1440px · Hero: 1500px · Section pad: 80/48px
   ═══════════════════════════════════════════════════════════════ */

:root {
    --brand-blue: #0B4EA2;
    --brand-red: #D91E18;
    --navy: #071F3A;
    --navy-soft: #0a2540;
    --heading: #071F3A;
    --royal: #0B4EA2;
    --royal-light: #eef4fa;
    --red: #D91E18;
    --red-hover: #b81914;
    --white: #fff;
    --warm: #f4f6f9;
    --warm-mid: #dde4ed;
    --text: #24364A;
    --text-dark: #071F3A;
    --text-muted: #5C6B7A;
    --muted: #5C6B7A;
    --text-on-dark: #EAF2FA;
    --text-on-dark-muted: #DDEAF7;
    --heading-on-dark: #FFFFFF;
    --accent-on-dark: #F2C94C;
    --prose-max: 42rem;
    --intro-max: 45rem;
    --radius: 20px;
    --radius-lg: 24px;
    --shadow: 0 20px 60px rgba(8,31,53,.1);
    --shadow-lg: 0 32px 80px rgba(8,31,53,.14);
    --font: 'Inter', system-ui, sans-serif;
    --font-head: 'Plus Jakarta Sans', system-ui, sans-serif;
    --wrap: 1440px;
    --wrap-hero: 1500px;
    --pad: 88px;
    --pad-m: 52px;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: var(--font);
    font-size: 1.125rem;
    line-height: 1.7;
    color: var(--text);
    background: var(--white);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

.home-story [id] {
    scroll-margin-top: calc(var(--header-h, 120px) + 1.25rem);
}

.home-story .story-block--white p,
.home-story .story-block--warm p,
.home-story .split-layout__main p {
    font-size: 1.125rem;
    line-height: 1.7;
    color: var(--text);
    margin: 0 0 1.5rem;
}

.home-story p:last-child {
    margin-bottom: 0;
}

img { max-width: 100%; display: block; height: auto; }
a { color: var(--royal); text-decoration: none; transition: color .2s; }
a:hover { color: var(--navy-soft); }

/* ─── Layout shells ─── */
.wrap,
.story-wrap {
    width: min(var(--wrap), 100% - 64px);
    margin-inline: auto;
}
.story-wrap--wide { width: min(var(--wrap), 100% - 48px); }

.story-block { padding: var(--pad) 0; }
.story-block--white { background: var(--white); }
.story-block--warm { background: var(--warm); }
.story-block--dark { background: var(--navy); color: var(--text-on-dark); }
.story-block--contact {
    background: linear-gradient(155deg, var(--navy) 0%, var(--navy-soft) 100%);
    color: var(--text-on-dark);
}

/* ─── Contrast: dark surfaces ─── */
.story-block--dark .kicker--light,
.story-block--contact .kicker--light {
    color: var(--accent-on-dark);
}

.story-block--dark .section-title--light,
.story-block--contact .section-title--light {
    color: var(--heading-on-dark);
}

.story-block--dark .section-intro--light,
.story-block--contact .section-intro--light {
    color: var(--text-on-dark-muted);
}

.story-block--contact .body-lg--light {
    color: var(--text-on-dark);
}

.story-block--contact .contact-list li {
    color: var(--text-on-dark);
    opacity: 1;
}

.story-block--contact .contact-address {
    color: var(--text-on-dark-muted);
    opacity: 1;
}

.story-block--contact .contact-address strong {
    color: var(--heading-on-dark);
}

.story-block--dark a:not(.btn),
.story-block--contact a:not(.btn) {
    color: var(--heading-on-dark);
}

.story-block--dark a:not(.btn):hover,
.story-block--contact a:not(.btn):hover {
    color: var(--text-on-dark);
}

.story-block--contact .btn--white {
    color: var(--navy);
}

.story-block--contact .btn--wa {
    color: var(--white);
}

/* ─── Typography ─── */
.kicker {
    display: block;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--brand-blue);
    margin: 0 0 1rem;
}
.kicker--red { color: var(--brand-red); }
.kicker--light { color: var(--accent-on-dark); }

.section-title {
    font-family: var(--font-head);
    font-size: clamp(2rem, 3.2vw, 3.5rem);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--heading);
    margin: 0 0 1.25rem;
}
.section-title--light { color: var(--heading-on-dark); }

.section-head {
    margin-bottom: 3.25rem;
    max-width: var(--intro-max);
}
.section-head--center {
    text-align: center;
    margin-inline: auto;
}
.section-intro {
    font-size: 1.125rem;
    line-height: 1.7;
    color: var(--text-muted);
    margin: 0;
    max-width: var(--intro-max);
}
.section-head--center .section-intro { margin-inline: auto; }
.section-intro--light { color: var(--text-on-dark-muted); }

.body-lg {
    font-size: 1.25rem;
    line-height: 1.65;
    color: var(--heading);
    font-weight: 500;
    margin: 0 0 1.75rem;
    max-width: var(--prose-max);
}
.body-lg--light { color: var(--text-on-dark); }

.prose {
    max-width: var(--prose-max);
}

.prose > .btn,
.prose > .btn-row {
    margin-top: 2rem;
}

.section-foot { margin-top: 3.5rem; }
.section-foot--center { text-align: center; }

/* ─── Buttons ─── */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: 1.0625rem 2.125rem;
    font-family: var(--font-head);
    font-size: 1.0625rem;
    font-weight: 700;
    border-radius: 999px;
    border: 2px solid transparent;
    cursor: pointer;
    transition: transform .2s, box-shadow .25s, background .2s;
    text-decoration: none;
}
.btn:hover { transform: translateY(-2px); }

.btn--cta {
    background: var(--brand-red);
    color: var(--white);
    box-shadow: 0 10px 28px rgba(217, 30, 24, .35);
}
.btn--cta:hover { background: var(--red-hover); color: var(--white); }

.btn--outline-navy,
.btn--outline {
    background: transparent;
    color: var(--brand-blue);
    border-color: rgba(11, 78, 162, .35);
}
.btn--outline-navy:hover,
.btn--outline:hover { background: var(--royal-light); color: var(--brand-blue); }

.btn--white { background: var(--white); color: var(--navy); box-shadow: var(--shadow); }
.btn--white:hover { background: var(--warm); }

.btn--wa { background: #128c43; color: var(--white); }
.btn--wa:hover { background: #0f7538; color: var(--white); }

.btn--lg { padding: 1.1875rem 2.375rem; font-size: 1.125rem; }
.btn--sm { padding: .625rem 1.125rem; font-size: .875rem; }
.btn--block { width: 100%; }
.btn-row { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2rem; }
.hide-mobile { display: inline-flex; }

.btn--hero-secondary {
    background: rgba(255, 255, 255, .1);
    color: var(--heading-on-dark);
    border: 2px solid rgba(255, 255, 255, .75);
}
.btn--hero-secondary:hover {
    background: rgba(255, 255, 255, .18);
    border-color: var(--heading-on-dark);
    color: var(--heading-on-dark);
}

/* ═══ 1. HERO — full-width photography ═══ */
.hero-banner {
    position: relative;
    display: flex;
    align-items: center;
    min-height: calc(100vh - var(--header-h));
    overflow: hidden;
    color: var(--white);
}

.hero-banner__photo {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 35%;
}

.hero-banner__overlay {
    position: absolute;
    inset: 0;
    background: rgba(7, 31, 58, 0.74);
    pointer-events: none;
}

.hero-banner__content {
    position: relative;
    z-index: 1;
    width: min(var(--wrap-hero), 100% - 48px);
    margin-inline: auto;
    padding: clamp(2.5rem, 6vh, 4rem) min(32px, 4vw) clamp(2.5rem, 5vh, 4rem);
}

.hero-banner__inner {
    max-width: 780px;
}

.hero-banner__label {
    margin: 0 0 1.25rem;
    font-size: .8125rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--accent-on-dark);
}

.hero-banner__title {
    margin: 0 0 1.25rem;
    font-family: var(--font-head);
    font-size: clamp(2.25rem, 4.5vw, 3.75rem);
    font-weight: 700;
    line-height: 1.12;
    letter-spacing: -0.02em;
    color: var(--heading-on-dark);
    max-width: 14em;
}

.hero-banner__lead {
    margin: 0 0 2.25rem;
    font-size: 1.125rem;
    line-height: 1.7;
    color: var(--text-on-dark);
    max-width: 36rem;
}

.hero-banner__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.hero-banner__trust {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0;
    list-style: none;
    margin: 2.75rem 0 0;
    padding: 2rem 0 0;
    border-top: 1px solid rgba(255, 255, 255, .35);
}

.hero-banner__trust li {
    font-size: .9375rem;
    font-weight: 600;
    letter-spacing: .01em;
    color: var(--heading-on-dark);
    padding-right: clamp(1rem, 2.5vw, 1.75rem);
    margin-right: clamp(1rem, 2.5vw, 1.75rem);
    border-right: 1px solid rgba(255, 255, 255, .35);
    line-height: 1.45;
}

.hero-banner__trust li:last-child {
    padding-right: 0;
    margin-right: 0;
    border-right: none;
}

.hero-banner__stars {
    color: var(--accent-on-dark);
    letter-spacing: 2px;
    margin-right: .375rem;
}

/* ═══ SPLIT LAYOUTS ═══ */
.split-layout {
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: clamp(3.5rem, 6vw, 5.5rem);
    align-items: start;
}
.split-layout--reverse { grid-template-columns: .95fr 1.05fr; }
.split-layout--reverse .split-layout__aside { order: -1; }

.split-layout__main.prose {
    padding-top: .25rem;
}

#about .section-title {
    font-size: clamp(2rem, 2.6vw, 3rem);
    line-height: 1.18;
    margin-bottom: 1.75rem;
}

#about .body-lg {
    margin-bottom: 1.75rem;
}

#about .split-layout__main p {
    max-width: none;
}

.quote-block {
    margin: 2.25rem 0;
    padding: 1.5rem 1.75rem;
    border-left: 4px solid var(--brand-blue);
    background: var(--royal-light);
    border-radius: 0 12px 12px 0;
    font-size: 1.125rem;
    font-style: normal;
    font-weight: 500;
    line-height: 1.7;
    color: var(--heading);
    max-width: none;
}

.frame-photo {
    margin: 0;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}
.frame-photo img { width: 100%; object-fit: cover; }
.frame-photo--portrait img { aspect-ratio: 4/5; min-height: 480px; }
.frame-photo:not(.frame-photo--portrait) img { aspect-ratio: 4/3; min-height: 400px; }
.contact-layout__copy {
    max-width: var(--prose-max);
}

.contact-layout__copy .section-title,
.contact-layout__copy .body-lg,
.contact-layout__copy p {
    max-width: none;
}

.frame-photo figcaption {
    padding: 1.125rem 1.375rem;
    background: var(--navy);
    color: var(--white);
    font-weight: 500;
    font-size: .9375rem;
    line-height: 1.5;
}

/* ═══ BEFORE / AFTER ═══ */
.ba-compare {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    margin-bottom: 3rem;
    position: relative;
}
.ba-compare:last-child { margin-bottom: 0; }

.ba-compare__panel {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow);
    min-height: 380px;
}
.ba-compare__panel img {
    width: 100%;
    height: 100%;
    min-height: 380px;
    object-fit: cover;
}
.ba-compare__label {
    position: absolute;
    top: 1.25rem;
    left: 1.25rem;
    padding: .5rem 1.125rem;
    font-family: var(--font-head);
    font-size: .8125rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
    border-radius: 999px;
}
.ba-compare__label--before { background: var(--navy); color: var(--white); }
.ba-compare__label--after { background: var(--brand-red); color: var(--white); }

.ba-compare__caption {
    grid-column: 1 / -1;
    text-align: center;
    padding-top: .5rem;
}
.ba-compare__caption h3 {
    font-family: var(--font-head);
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--heading);
    margin: 0 0 .375rem;
}
.ba-compare__caption span { color: var(--text-muted); font-size: 1rem; }

/* ═══ LUXURY SERVICE CARDS ═══ */
.luxury-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
    margin-bottom: 4rem;
}

.luxury-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow);
    border: 1px solid var(--warm-mid);
    transition: transform .3s, box-shadow .3s;
}
.luxury-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }

.luxury-card__media { aspect-ratio: 16/10; overflow: hidden; }
.luxury-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .55s;
}
.luxury-card:hover .luxury-card__media img { transform: scale(1.05); }

.luxury-card__body { padding: 1.75rem 2rem 2rem; }
.luxury-card__body h3 {
    font-family: var(--font-head);
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.3;
    color: var(--heading);
    margin: 0 0 .75rem;
}
.luxury-card__body p {
    margin: 0;
    font-size: 1rem;
    line-height: 1.6;
    color: var(--text);
}

.service-promises {
    background: var(--warm);
    border-radius: var(--radius-lg);
    padding: 2.5rem 3rem;
    border: 1px solid var(--warm-mid);
}

.service-promises__title {
    font-family: var(--font-head);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--heading);
    margin: 0 0 1.5rem;
}
.service-promises__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .875rem 2rem;
    list-style: none;
    margin: 0;
    padding: 0;
}
.service-promises__list li {
    position: relative;
    padding-left: 1.75rem;
    font-size: 1rem;
    line-height: 1.6;
    font-weight: 400;
    color: var(--text);
}
.service-promises__list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--brand-blue);
    font-weight: 800;
}

/* ═══ MASONRY PROJECTS ═══ */
.masonry {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: minmax(300px, 340px);
    gap: 1.5rem;
}

.masonry__tile {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    display: block;
    box-shadow: var(--shadow-lg);
    border: 1px solid rgba(255,255,255,.06);
}
.masonry__tile--hero { grid-column: span 8; grid-row: span 2; }
.masonry__tile--wide { grid-column: span 4; }
.masonry__tile--tall { grid-column: span 4; grid-row: span 2; }

.masonry__tile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .55s cubic-bezier(.25,.46,.45,.94);
}
.masonry__tile:hover img { transform: scale(1.06); }

.masonry__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 2rem;
    background: linear-gradient(to top, rgba(7, 31, 58, .94) 0%, rgba(7, 31, 58, .55) 55%, transparent 100%);
    color: var(--heading-on-dark);
    opacity: 0;
    transition: opacity .35s;
}
.masonry__tile:hover .masonry__overlay { opacity: 1; }

@media (hover: none) {
    .masonry__overlay {
        opacity: 1;
        background: linear-gradient(to top, rgba(7, 31, 58, .92) 0%, rgba(7, 31, 58, .5) 45%, transparent 100%);
    }
}
.masonry__overlay strong {
    font-family: var(--font-head);
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: .375rem;
    color: var(--heading-on-dark);
}
.masonry__overlay span {
    font-size: .9375rem;
    line-height: 1.5;
    color: var(--text-on-dark-muted);
}

/* ═══ TIMELINE ═══ */
.timeline {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1.5rem;
}

.timeline__step {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: 2.25rem 1.75rem 2rem;
    text-align: center;
    box-shadow: var(--shadow);
    border: 1px solid var(--warm-mid);
    position: relative;
}

.timeline__num {
    width: 64px;
    height: 64px;
    margin: 0 auto 1.5rem;
    background: var(--brand-blue);
    color: var(--white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-head);
    font-size: 1.5rem;
    font-weight: 800;
    box-shadow: 0 8px 24px rgba(11, 78, 162, .35);
}

.timeline__step h3 {
    font-family: var(--font-head);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--heading);
    margin: 0 0 .625rem;
}
.timeline__step p {
    margin: 0;
    font-size: .9375rem;
    line-height: 1.6;
    color: var(--text-muted);
}

/* ═══ VIDEO STAGE ═══ */
.video-stage {
    max-width: 1200px;
    margin: 0 auto;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    aspect-ratio: 16/9;
    background: var(--navy);
    border: 8px solid var(--white);
    outline: 1px solid var(--warm-mid);
}
.video-stage iframe { width: 100%; height: 100%; border: 0; display: block; }

/* ═══ GOOGLE REVIEWS ═══ */
.reviews-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
}

.g-review {
    background: var(--white);
    border-radius: var(--radius);
    border: 1px solid var(--warm-mid);
    box-shadow: var(--shadow);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.g-review__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.5rem;
    background: var(--warm);
    border-bottom: 1px solid var(--warm-mid);
}
.g-review__google {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .875rem;
    font-weight: 700;
    color: var(--muted);
}
.g-review__stars { color: #f59e0b; font-size: 1.125rem; letter-spacing: 2px; }

.g-review__user {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem .75rem;
}
.g-review__avatar {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: var(--brand-blue);
    color: var(--white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-head);
    font-weight: 800;
    font-size: 1.25rem;
    flex-shrink: 0;
}
.g-review__user strong { display: block; font-family: var(--font-head); font-size: 1.0625rem; color: var(--text-dark); }
.g-review__user span { font-size: .875rem; color: var(--muted); }

.g-review p {
    flex: 1;
    margin: 0;
    padding: 0 1.5rem 1.5rem;
    font-size: 1rem;
    line-height: 1.7;
    color: var(--text);
}

.reviews-more { margin-top: 2.5rem; text-align: center; }
.reviews-more summary { list-style: none; cursor: pointer; display: inline-flex; }
.reviews-more summary::-webkit-details-marker { display: none; }
.reviews-grid--more { margin-top: 2rem; }

/* ═══ FAQ ═══ */
.faq-list { max-width: 960px; margin: 0 auto 3rem; }

.faq-item {
    background: var(--white);
    border: 1px solid var(--warm-mid);
    border-radius: var(--radius);
    margin-bottom: 1rem;
    overflow: hidden;
    box-shadow: var(--shadow);
    transition: border-color .25s, box-shadow .25s;
}

.faq-item[open] {
    border-color: rgba(11, 78, 162, .25);
    box-shadow: 0 12px 40px rgba(11, 78, 162, .1);
}

.faq-item__summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
    padding: 1.25rem 1.75rem;
    font-family: var(--font-head);
    font-size: 1.0625rem;
    font-weight: 600;
    line-height: 1.45;
    color: var(--heading);
    cursor: pointer;
    list-style: none;
    user-select: none;
}

.faq-item__summary::-webkit-details-marker { display: none; }

.faq-item__text {
    flex: 1;
    min-width: 0;
}

.faq-item__toggle {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    background: var(--royal-light);
    color: var(--brand-blue);
    transition: transform .3s ease, background .25s ease, color .25s ease;
}

.faq-item__toggle svg {
    width: 1.125rem;
    height: 1.125rem;
}

.faq-item[open] .faq-item__toggle {
    transform: rotate(180deg);
    background: var(--brand-blue);
    color: var(--white);
}

.faq-item[open] .faq-item__summary {
    color: var(--brand-blue);
}

.faq-item__answer {
    padding: 0 1.75rem 1.375rem 1.75rem;
    border-top: 1px solid var(--warm-mid);
    animation: faq-open .3s ease;
}

.faq-item__answer p {
    margin: 1.125rem 0 0;
    padding: 0;
    font-size: 1rem;
    line-height: 1.7;
    color: var(--text);
    max-width: none;
}

@keyframes faq-open {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: translateY(0); }
}

.work-types {
    margin-top: 4rem;
    background: var(--warm);
    border-radius: var(--radius-lg);
    padding: 2.5rem 3rem;
    border: 1px solid var(--warm-mid);
}
.work-types__title {
    font-family: var(--font-head);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--heading);
    margin: 0 0 1.5rem;
}
.work-types__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .75rem 2rem;
    list-style: none;
    margin: 0;
    padding: 0;
}
.work-types__grid li {
    font-size: 1rem;
    line-height: 1.6;
    font-weight: 400;
    color: var(--text);
    padding: .5rem 0 .5rem 1.5rem;
    position: relative;
}
.work-types__grid li::before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--brand-red);
    font-weight: 800;
}

/* ═══ CONTACT ═══ */
.contact-layout {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: clamp(3rem, 6vw, 5rem);
    align-items: start;
}

.contact-list {
    list-style: none;
    margin: 0 0 2.5rem;
    padding: 0;
}
.contact-list li {
    position: relative;
    padding: .5rem 0 .5rem 1.75rem;
    font-size: 1.0625rem;
    line-height: 1.6;
    opacity: .92;
    max-width: none;
}
.contact-list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: #6ee7a0;
    font-weight: 800;
}

.contact-address {
    font-style: normal;
    font-size: 1.0625rem;
    opacity: .85;
    line-height: 1.75;
    margin-top: 2rem;
}

.survey-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.survey-card__head {
    padding: 1.75rem 2rem 1.25rem;
    background: var(--warm);
    border-bottom: 1px solid var(--warm-mid);
}
.survey-card__head h3 {
    font-family: var(--font-head);
    font-size: 1.375rem;
    font-weight: 700;
    line-height: 1.25;
    color: var(--heading);
    margin: 0 0 .375rem;
}
.survey-card__head p {
    margin: 0;
    font-size: 1rem;
    line-height: 1.6;
    color: var(--text-muted);
}

.survey-card__success {
    margin: 1.25rem 2rem 0;
    padding: 1rem 1.125rem;
    background: #ecfdf3;
    border: 1px solid #a7f3c7;
    border-radius: 10px;
    color: #065f36;
    font-weight: 600;
    font-size: .9375rem;
    line-height: 1.6;
}

.survey-form {
    padding: 1.75rem 2rem 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.survey-form__field label {
    display: block;
    font-family: var(--font-head);
    font-size: .8125rem;
    font-weight: 600;
    letter-spacing: .02em;
    color: var(--heading);
    margin-bottom: .4375rem;
}

.survey-form__field input,
.survey-form__field select {
    width: 100%;
    padding: .875rem 1rem;
    font-family: var(--font);
    font-size: 1rem;
    line-height: 1.5;
    border: 1px solid var(--warm-mid);
    border-radius: 10px;
    background: var(--white);
    color: var(--heading);
    transition: border-color .2s, box-shadow .2s;
}

.survey-form__field input::placeholder {
    color: var(--text-muted);
    opacity: .75;
}
.survey-form__field input:focus,
.survey-form__field select:focus {
    outline: none;
    border-color: var(--brand-blue);
    box-shadow: 0 0 0 4px rgba(11, 78, 162, .12);
}

.survey-form__error {
    display: block;
    color: var(--red);
    font-size: .875rem;
    margin-top: .375rem;
}

/* ═══ FOOTER ═══ */
.site-footer { background: var(--warm); border-top: 1px solid var(--warm-mid); }
.site-footer__main {
    display: grid;
    grid-template-columns: 1.75fr 1fr 1fr 1fr;
    gap: 3rem;
    padding: 4.5rem min(32px, 4vw) 3rem;
    max-width: var(--wrap-hero);
    margin-inline: auto;
}
.site-footer__brand img { height: 72px; width: auto; object-fit: contain; }
.site-footer__brand p { font-size: 1.0625rem; color: var(--muted); line-height: 1.75; margin: 1.5rem 0; max-width: 380px; }
.site-footer__contact-chips { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; }
.site-footer__phone { font-family: var(--font-head); font-size: 1.4375rem; font-weight: 800; color: var(--brand-blue); }
.site-footer h3 { font-family: var(--font-head); font-size: .8125rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--brand-blue); margin: 0 0 1.5rem; }
.site-footer ul { list-style: none; margin: 0; padding: 0; }
.site-footer li { margin-bottom: .75rem; }
.site-footer li a { font-size: 1.0625rem; color: var(--muted); }
.site-footer li a:hover { color: var(--brand-blue); }
.site-footer address { font-style: normal; font-size: 1.0625rem; line-height: 1.75; color: var(--muted); margin-bottom: 1rem; }
.site-footer address strong { color: var(--brand-blue); }
.site-footer__survey-link { font-weight: 700; color: var(--brand-red); font-size: .9375rem; }
.site-footer__legal { background: var(--white); border-top: 1px solid var(--warm-mid); padding: 1.25rem min(32px, 4vw); }
.site-footer__legal-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: .75rem 1rem;
    max-width: var(--wrap-hero);
    margin-inline: auto;
}
.site-footer__legal p { margin: 0; font-size: .875rem; color: var(--muted); }
.site-footer__credit { margin-left: auto; text-align: right; }
.site-footer__credit a {
    color: var(--brand-blue);
    font-weight: 600;
    text-decoration: none;
}
.site-footer__credit a:hover { color: var(--navy); text-decoration: underline; }

@media (max-width: 640px) {
    .site-footer__legal-inner {
        flex-direction: column;
        align-items: flex-start;
    }
    .site-footer__credit {
        margin-left: 0;
        text-align: left;
    }
}

/* ═══ RESPONSIVE ═══ */
@media (min-width: 1200px) {
    .ba-compare__panel,
    .ba-compare__panel img { min-height: 460px; }
    .masonry { grid-auto-rows: minmax(320px, 380px); }
}

@media (max-width: 1200px) {
    .masonry__tile--hero { grid-column: span 12; grid-row: span 1; min-height: 400px; }
    .masonry__tile--wide, .masonry__tile--tall { grid-column: span 6; grid-row: span 1; }
    .timeline { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 1024px) {
    .hero-banner { min-height: calc(85vh - var(--header-h)); }
    .hero-banner__title { max-width: none; }
    .split-layout, .split-layout--reverse { grid-template-columns: 1fr; }
    .split-layout--reverse .split-layout__aside { order: -1; }
    .luxury-grid { grid-template-columns: 1fr; }
    .reviews-grid { grid-template-columns: 1fr; max-width: 560px; margin-inline: auto; }
    .contact-layout { grid-template-columns: 1fr; }
    .site-footer__main { grid-template-columns: 1fr 1fr; }
    .service-promises__list { grid-template-columns: 1fr; }
    .work-types__grid { grid-template-columns: repeat(2, 1fr); }
    .timeline { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    :root { --pad: var(--pad-m); }

    .section-title {
        font-size: clamp(1.75rem, 6vw, 2.25rem);
        line-height: 1.2;
    }

    #about .section-title {
        font-size: clamp(1.75rem, 5.5vw, 2.125rem);
    }

    .section-intro,
    .home-story p,
    .body-lg {
        font-size: 1.0625rem;
    }

    .hero-banner { min-height: calc(75vh - var(--header-h)); }
    .hero-banner__content { width: min(100% - 32px, var(--wrap-hero)); }
    .hero-banner__actions { flex-direction: column; }
    .hero-banner__actions .btn { width: 100%; }
    .hero-banner__trust {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 1rem 1.25rem;
        margin-top: 2rem;
        padding-top: 1.75rem;
    }
    .hero-banner__trust li {
        border-right: none;
        padding-right: 0;
        margin-right: 0;
        font-size: .8125rem;
        color: var(--heading-on-dark);
    }
    .story-block { padding: var(--pad-m) 0; }
    .story-wrap { width: min(100% - 32px, var(--wrap)); }
    .ba-compare { grid-template-columns: 1fr; }
    .masonry { grid-template-columns: 1fr; grid-auto-rows: auto; }
    .masonry__tile--hero, .masonry__tile--wide, .masonry__tile--tall {
        grid-column: span 1;
        min-height: 280px;
    }
    .timeline { grid-template-columns: 1fr; }
    .work-types__grid { grid-template-columns: 1fr; }
    .site-footer__main { grid-template-columns: 1fr; }
}
