/*
Theme Name: Jeff Juma Real Estate
Theme URI: https://jeffjuma.com
Author: Jeff Juma
Author URI: https://jeffjuma.com
Description: Premium single-page real estate theme for Jeff Juma - Chicago's Premier Real Estate Broker. Features full-screen hero with multi-layer parallax, property showcase grid, stats section, expertise cards, testimonials, and contact CTA.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: jeffjuma
Tags: one-page, real-estate, custom-background, full-width-template
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 7.4
*/

/* =========================================================================
   CSS RESET & FOUNDATIONAL STYLES
   ========================================================================= */
*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

:root {
    --vh: 1vh;
    --real-vh: 1vh;
    --color-primary: #0F172A;
    --color-primary-light: #1E293B;
    --color-primary-dark: #020617;
    --color-accent: #D4AF37;
    --color-accent-light: #F4E4A6;
    --color-accent-dark: #B8941F;
    --color-white: #FFFFFF;
    --color-gray-50: #F8FAFC;
    --color-gray-100: #F1F5F9;
    --color-gray-200: #E2E8F0;
    --color-gray-300: #CBD5E1;
    --color-gray-400: #94A3B8;
    --color-gray-600: #475569;
    --color-gray-700: #334155;
    --color-gray-800: #1E293B;
    --color-gray-900: #0F172A;
    --font-sans: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
    --font-serif: 'Cormorant Garamond', Georgia, serif;
    --font-accent: 'Gotu', Georgia, serif;
    --space-xs: 0.5rem;
    --space-sm: 1rem;
    --space-md: 1.5rem;
    --space-lg: 2rem;
    --space-xl: 3rem;
    --space-2xl: 4rem;
    --space-3xl: 6rem;
    --space-4xl: 8rem;
    --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    --radius-sm: 0.375rem;
    --radius-md: 0.5rem;
    --radius-lg: 0.75rem;
    --radius-xl: 1rem;
    --radius-2xl: 1.5rem;
    --radius-full: 9999px;
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-in: cubic-bezier(0.4, 0, 1, 1);
    --duration-fast: 150ms;
    --duration-base: 250ms;
    --duration-slow: 350ms;
    --duration-slower: 500ms;
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: 80px;
    margin: 0 !important;
    padding: 0 !important;
    height: 100vh;
    height: 100dvh;
    height: -webkit-fill-available;
    min-height: 100vh;
    min-height: 100dvh;
    max-height: 100vh;
    max-height: 100dvh;
    width: 100%;
    position: relative;
    -webkit-overflow-scrolling: touch;
}

body {
    font-family: var(--font-sans);
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-gray-700);
    background: #0F172A;
    overflow-x: hidden;
    margin: 0 !important;
    padding: 0 !important;
    border: 0;
    height: 100vh;
    height: 100dvh;
    height: -webkit-fill-available;
    min-height: 100vh;
    min-height: 100dvh;
    max-height: 100vh;
    max-height: 100dvh;
    width: 100%;
    position: relative;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: 100%;
    -webkit-overflow-scrolling: touch;
}

* {
    -webkit-margin-before: 0;
    -webkit-margin-after: 0;
    -webkit-margin-start: 0;
    -webkit-margin-end: 0;
    -webkit-padding-before: 0;
    -webkit-padding-after: 0;
    -webkit-padding-start: 0;
    -webkit-padding-end: 0;
}

/* =========================================================================
   TYPOGRAPHY
   ========================================================================= */
h1, h2, h3, h4, h5, h6 { font-family: var(--font-serif); font-weight: 600; line-height: 1.2; color: var(--color-primary); margin: 0; }
h1 { font-size: clamp(2.5rem, 5vw, 5rem); letter-spacing: -0.01em; font-weight: 700; }
h2 { font-size: clamp(2rem, 4vw, 3.5rem); letter-spacing: -0.01em; }
h3 { font-size: clamp(1.5rem, 3vw, 2.25rem); }
p { margin: 0; font-size: clamp(1rem, 1.5vw, 1.125rem); }
a { text-decoration: none; color: inherit; transition: all var(--duration-base) var(--ease-in-out); }

/* =========================================================================
   HERO
   ========================================================================= */
.hero { position: fixed; top: 0; left: 0; width: 100vw; width: 100dvw; height: 100vh; height: 100dvh; height: -webkit-fill-available; min-height: 100vh; min-height: 100dvh; overflow: hidden; background: linear-gradient(135deg, #0a0f1a 0%, var(--color-primary) 50%, #0a0f1a 100%); margin: 0 !important; padding: 0 !important; border: 0; }
@supports (-webkit-touch-callout: none) { .hero { height: -webkit-fill-available; } }
.hero__mansion { position: fixed; top: 0; left: 0; width: 100vw; width: 100dvw; height: 100vh; height: 100dvh; height: -webkit-fill-available; min-height: 100vh; min-height: 100dvh; max-height: 100vh; max-height: 100dvh; object-fit: cover; object-position: center; opacity: 0.7; filter: blur(2px) brightness(0.6); will-change: transform; z-index: 1; margin: 0; padding: 0; }
.hero__ambient { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: radial-gradient(circle at 30% 40%, rgba(212, 175, 55, 0.2) 0%, transparent 40%), radial-gradient(circle at 70% 60%, rgba(212, 175, 55, 0.15) 0%, transparent 40%), radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.05) 0%, transparent 60%); mix-blend-mode: overlay; z-index: 2; }
.hero__image { position: fixed; bottom: calc(-5vh + env(safe-area-inset-bottom, 0px)); bottom: calc(-5dvh + env(safe-area-inset-bottom, 0px)); left: 50%; width: auto; height: 95vh; height: 95dvh; max-height: 95vh; max-height: 95dvh; object-fit: contain; object-position: bottom center; transform: translateX(-50%); will-change: transform; z-index: 3; margin: 0; padding: 0; color-profile: display-p3; }
.hero__glass { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to bottom, rgba(255, 255, 255, 0.02) 0%, transparent 30%, transparent 70%, rgba(15, 23, 42, 0.8) 100%); backdrop-filter: blur(0.5px) saturate(1.4); -webkit-backdrop-filter: blur(0.5px) saturate(1.4); z-index: 4; }
.hero__overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to bottom, rgba(15, 23, 42, 0.4) 0%, transparent 20%, transparent 55%, rgba(15, 23, 42, 0.4) 75%, rgba(15, 23, 42, 0.85) 100%); z-index: 5; }
.hero__content { position: absolute; bottom: 0; left: 0; right: 0; z-index: 6; padding: var(--space-3xl) var(--space-lg); padding-bottom: max(var(--space-3xl), calc(env(safe-area-inset-bottom, 1rem) + var(--space-2xl))); padding-top: max(var(--space-lg), env(safe-area-inset-top, 0px)); max-width: 1600px; margin: 0 auto; animation: heroFadeIn 2s var(--ease-out) 0.5s backwards; }
@keyframes heroFadeIn { from { opacity: 0; transform: translateY(40px); } to { opacity: 1; transform: translateY(0); } }
@keyframes slideInFromLeft { from { opacity: 0; transform: translateX(-100%); } to { opacity: 1; transform: translateX(-50%); } }
@keyframes slideInFromRight { from { opacity: 0; transform: translateX(100%); } to { opacity: 1; transform: translateX(0); } }
.hero__title { font-family: var(--font-serif); font-size: clamp(3rem, 7vw, 7rem); color: var(--color-white); margin-bottom: var(--space-md); text-shadow: 0 4px 30px rgba(0, 0, 0, 0.7), 0 2px 10px rgba(0, 0, 0, 0.5); font-weight: 600; letter-spacing: 0.02em; line-height: 1.1; }
.hero__subtitle { font-family: var(--font-sans); font-size: clamp(1.125rem, 2vw, 1.5rem); color: var(--color-white); font-weight: 300; max-width: 650px; margin-bottom: var(--space-xl); text-shadow: 0 3px 20px rgba(0, 0, 0, 0.8), 0 2px 10px rgba(0, 0, 0, 0.6); line-height: 1.6; letter-spacing: 0.05em; }
.hero__cta { display: flex; gap: var(--space-md); flex-wrap: wrap; }

/* =========================================================================
   BUTTONS
   ========================================================================= */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--space-xs); padding: 1.125rem 2.5rem; font-family: var(--font-sans); font-size: 0.95rem; font-weight: 500; line-height: 1; letter-spacing: 0.1em; text-transform: uppercase; border-radius: var(--radius-full); border: 2px solid transparent; cursor: pointer; transition: all var(--duration-base) var(--ease-in-out); text-decoration: none; position: relative; overflow: hidden; white-space: nowrap; min-height: 44px; min-width: 44px; -webkit-tap-highlight-color: transparent; touch-action: manipulation; }
.btn::before { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-radius: 50%; background: rgba(255, 255, 255, 0.2); transform: translate(-50%, -50%); transition: width var(--duration-slow) var(--ease-out), height var(--duration-slow) var(--ease-out); }
.btn:hover::before { width: 400px; height: 400px; }
.btn__text { position: relative; z-index: 1; }
.btn--primary { background: var(--color-accent); color: var(--color-primary); border-color: var(--color-accent); box-shadow: 0 6px 25px rgba(212, 175, 55, 0.4); }
.btn--primary:hover { transform: translateY(-3px); box-shadow: 0 10px 35px rgba(212, 175, 55, 0.5); }
.btn--secondary { background: transparent; color: var(--color-white); border-color: var(--color-white); backdrop-filter: blur(10px); }
.btn--secondary:hover { background: var(--color-white); color: var(--color-primary); transform: translateY(-3px); }
.cta .btn--secondary { color: var(--color-primary); border-color: var(--color-primary); }
.cta .btn--secondary:hover { background: var(--color-primary); color: var(--color-white); }

/* =========================================================================
   PROPERTY SHOWCASE
   ========================================================================= */
.properties { padding: 0; background: var(--color-primary); margin-top: 110vh; margin-top: 110dvh; position: relative; z-index: 5; }
.properties__grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-template-rows: repeat(2, 50vh); min-height: 100vh; }
.property { position: relative; overflow: hidden; cursor: pointer; transition: all var(--duration-slow) var(--ease-out); }
.property:nth-child(1) { grid-column: 1 / 3; grid-row: 1 / 2; }
.property:nth-child(2) { grid-column: 3 / 5; grid-row: 1 / 2; }
.property:nth-child(3) { grid-column: 1 / 2; grid-row: 2 / 3; }
.property:nth-child(4) { grid-column: 2 / 4; grid-row: 2 / 3; }
.property:nth-child(5) { grid-column: 4 / 5; grid-row: 2 / 3; }
.property__image { width: 100%; height: 100%; object-fit: cover; transition: transform var(--duration-slower) var(--ease-out); }
.property:hover .property__image { transform: scale(1.1); }
.property__overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to top, rgba(15, 23, 42, 0.9) 0%, rgba(15, 23, 42, 0.4) 50%, transparent 100%); opacity: 0.7; transition: opacity var(--duration-base) var(--ease-in-out); }
.property:hover .property__overlay { opacity: 0.5; }
.property__content { position: absolute; bottom: 0; left: 0; right: 0; padding: var(--space-xl); transform: translateY(10px); transition: transform var(--duration-base) var(--ease-out); }
.property:hover .property__content { transform: translateY(0); }
.property__label { display: inline-block; padding: var(--space-xs) var(--space-md); background: rgba(212, 175, 55, 0.2); border: 1px solid var(--color-accent); border-radius: var(--radius-full); color: var(--color-accent); font-size: 0.75rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: var(--space-sm); backdrop-filter: blur(10px); }
.property__title { font-size: clamp(1.25rem, 2vw, 1.75rem); color: var(--color-white); margin-bottom: var(--space-xs); font-weight: 700; }
.property__location { font-size: 0.875rem; color: var(--color-gray-300); font-weight: 500; }

/* =========================================================================
   STATS SECTION
   ========================================================================= */
.stats-section { padding: var(--space-4xl) var(--space-lg); background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 50%, #f1f5f9 100%); position: relative; z-index: 5; }
.stats-section::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: radial-gradient(circle at 20% 50%, rgba(212, 175, 55, 0.08) 0%, transparent 50%), radial-gradient(circle at 80% 50%, rgba(15, 23, 42, 0.05) 0%, transparent 50%); z-index: 0; }
.stats-section::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: url('/images/Chicago Skyline Photo.jpg'); background-size: cover; background-position: center 85%; opacity: 0.25; mix-blend-mode: multiply; filter: contrast(1.3) brightness(0.8); z-index: 0; }
.stats-section .container { position: relative; z-index: 1; }
.container { max-width: 1400px; margin: 0 auto; width: 100%; }
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: var(--space-2xl); }
.stat { text-align: center; padding: var(--space-xl); transition: transform var(--duration-base) var(--ease-in-out); }
.stat:hover { transform: translateY(-5px); }
.stat__number { font-family: var(--font-serif); font-size: clamp(3rem, 6vw, 5rem); font-weight: 900; color: var(--color-accent); line-height: 1; margin-bottom: var(--space-sm); letter-spacing: -0.02em; }
.stat__label { font-size: 1rem; font-weight: 600; color: var(--color-gray-700); text-transform: uppercase; letter-spacing: 0.05em; }

/* =========================================================================
   EXPERTISE SECTION
   ========================================================================= */
.expertise { position: relative; padding: var(--space-4xl) var(--space-lg); background: var(--color-gray-50); overflow: hidden; z-index: 5; }
.expertise__header { text-align: center; max-width: 800px; margin: 0 auto var(--space-3xl); }
.expertise__badge { display: inline-block; padding: var(--space-xs) var(--space-md); background: var(--color-accent-light); color: var(--color-accent-dark); border-radius: var(--radius-full); font-size: 0.75rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: var(--space-md); }
.expertise__title { margin-bottom: var(--space-md); }
.expertise__description { font-size: 1.25rem; color: var(--color-gray-600); line-height: 1.7; }
.expertise__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--space-lg); }
.expertise__item { padding: var(--space-2xl); background: var(--color-white); border-radius: var(--radius-xl); transition: all var(--duration-base) var(--ease-in-out); border: 2px solid transparent; }
.expertise__item:hover { border-color: var(--color-accent); transform: translateY(-5px); box-shadow: var(--shadow-xl); }
.expertise__icon { font-size: 3rem; margin-bottom: var(--space-md); display: block; }
.expertise__item-title { font-size: 1.5rem; margin-bottom: var(--space-sm); color: var(--color-primary); }
.expertise__item-description { color: var(--color-gray-600); line-height: 1.7; }

/* =========================================================================
   TESTIMONIALS
   ========================================================================= */
.testimonials-section { position: relative; padding: var(--space-4xl) var(--space-lg); background: var(--color-primary); overflow: hidden; z-index: 5; }
.testimonials-section::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: url('/images/Chicago River Cityscape Photograph.jpg'); background-size: cover; background-position: center; opacity: 0.08; z-index: 0; }
.testimonials-section .container { position: relative; z-index: 1; }
.testimonials__header { text-align: center; max-width: 800px; margin: 0 auto var(--space-3xl); }
.testimonials__badge { display: inline-block; padding: var(--space-xs) var(--space-md); background: rgba(212, 175, 55, 0.2); border: 1px solid var(--color-accent); color: var(--color-accent); border-radius: var(--radius-full); font-size: 0.75rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: var(--space-md); backdrop-filter: blur(10px); }
.testimonials__title { color: var(--color-white); margin-bottom: var(--space-md); }
.testimonials__description { font-size: 1.25rem; color: var(--color-gray-300); line-height: 1.7; }
.testimonials { display: grid; grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); gap: var(--space-2xl); }
.testimonial { padding: var(--space-2xl); background: rgba(30, 41, 59, 0.8); border-radius: var(--radius-xl); border: 1px solid rgba(212, 175, 55, 0.2); transition: all var(--duration-base) var(--ease-in-out); backdrop-filter: blur(20px); }
.testimonial:hover { transform: translateY(-5px); border-color: var(--color-accent); box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3); }
.testimonial__content { margin-bottom: var(--space-lg); font-size: 1.125rem; line-height: 1.8; color: var(--color-gray-200); font-style: italic; }
.testimonial__author { display: flex; align-items: center; gap: var(--space-md); }
.testimonial__avatar { width: 56px; height: 56px; border-radius: 50%; background: var(--color-accent); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1.25rem; color: var(--color-primary); }
.testimonial__name { font-weight: 600; color: var(--color-white); margin-bottom: 0.25rem; }
.testimonial__role { font-size: 0.875rem; color: var(--color-gray-400); }
.testimonial__rating { color: var(--color-accent); font-size: 1rem; margin-top: 0.25rem; }

/* =========================================================================
   CTA SECTION
   ========================================================================= */
.cta { position: relative; min-height: 70vh; display: flex; align-items: center; justify-content: center; overflow: hidden; background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 50%, #f1f5f9 100%); z-index: 5; }
.cta__background { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0.15; filter: contrast(1.2) brightness(1.1); }
.cta__overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(135deg, rgba(248, 250, 252, 0.75) 0%, rgba(241, 245, 249, 0.85) 100%); }
.cta__content { position: relative; z-index: 1; text-align: center; max-width: 900px; margin: 0 auto; padding: var(--space-2xl); }
.cta__title { color: var(--color-primary); margin-bottom: var(--space-md); font-size: clamp(2.5rem, 5vw, 4rem); }
.cta__description { font-size: 1.375rem; color: var(--color-gray-700); margin-bottom: var(--space-2xl); line-height: 1.7; }
.cta__buttons { display: flex; gap: var(--space-md); justify-content: center; flex-wrap: wrap; }

/* =========================================================================
   FOOTER
   ========================================================================= */
.footer { background: var(--color-primary-dark); color: var(--color-gray-300); padding: var(--space-3xl) var(--space-lg) var(--space-lg); position: relative; z-index: 10; }
.footer__content { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: var(--space-2xl); margin-bottom: var(--space-2xl); }
.footer__section h3 { color: var(--color-white); font-size: 1.25rem; margin-bottom: var(--space-md); }
.footer__links { list-style: none; padding: 0; }
.footer__link { margin-bottom: var(--space-sm); }
.footer__link a { color: var(--color-gray-400); transition: color var(--duration-base) var(--ease-in-out); }
.footer__link a:hover { color: var(--color-accent); }
.footer__bottom { border-top: 1px solid rgba(255, 255, 255, 0.1); padding-top: var(--space-lg); text-align: center; color: var(--color-gray-500); }

/* =========================================================================
   RESPONSIVE DESIGN
   ========================================================================= */
@media (max-width: 1024px) {
    .hero { position: fixed; width: 100vw; width: 100dvw; height: 100vh; height: 100dvh; height: -webkit-fill-available; }
    .hero__mansion { width: 100vw; width: 100dvw; height: 100vh; height: 100dvh; }
    .hero__image { bottom: calc(-5vh + env(safe-area-inset-bottom, 0px)); bottom: calc(-5dvh + env(safe-area-inset-bottom, 0px)); height: 95vh; height: 95dvh; }
    .properties__grid { grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(3, 45vh); gap: 0; }
    .property:nth-child(1) { grid-column: 1 / 3; grid-row: 1; }
    .property:nth-child(2) { grid-column: 1 / 2; grid-row: 2; }
    .property:nth-child(3) { grid-column: 2 / 3; grid-row: 2; }
    .property:nth-child(4) { grid-column: 1 / 2; grid-row: 3; }
    .property:nth-child(5) { grid-column: 2 / 3; grid-row: 3; }
    .stats { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    .hero { position: fixed; top: 0; left: 0; width: 100vw; width: 100dvw; height: 100vh; height: 100dvh; height: -webkit-fill-available; min-height: 100vh; min-height: 100dvh; max-height: 100vh; max-height: 100dvh; }
    .hero__image { position: fixed; bottom: calc(-5vh + env(safe-area-inset-bottom, 0px)); bottom: calc(-5dvh + env(safe-area-inset-bottom, 0px)); left: 50%; height: 95vh; height: 95dvh; max-height: 95vh; max-height: 95dvh; width: auto; object-fit: contain; object-position: bottom center; transform: translateX(-50%); padding: 0 !important; margin: 0 !important; }
    .hero__mansion { position: fixed; width: 100vw; width: 100dvw; height: 100vh; height: 100dvh; top: 0; left: 0; }
    .hero__content { position: fixed; bottom: 0; left: 0; right: 0; padding: var(--space-sm) var(--space-md); padding-bottom: max(var(--space-md), calc(env(safe-area-inset-bottom, 0.5rem) + var(--space-sm))); padding-left: max(var(--space-md), env(safe-area-inset-left, 0px)); padding-right: max(var(--space-md), env(safe-area-inset-right, 0px)); text-align: center; }
    .hero__title { font-size: clamp(2.5rem, 10vw, 3.5rem); margin-bottom: var(--space-sm); text-shadow: 0 6px 40px rgba(0, 0, 0, 0.9), 0 3px 20px rgba(0, 0, 0, 0.7), 0 1px 8px rgba(0, 0, 0, 0.5); }
    .hero__subtitle { font-size: clamp(1rem, 4vw, 1.25rem); margin-bottom: var(--space-lg); text-shadow: 0 4px 30px rgba(0, 0, 0, 0.9), 0 2px 15px rgba(0, 0, 0, 0.7); }
    .hero__cta { flex-direction: column; width: 100%; gap: var(--space-sm); }
    .btn { width: 100%; justify-content: center; padding: 1rem 2rem; -webkit-tap-highlight-color: rgba(212, 175, 55, 0.2); }
    .properties__grid { grid-template-columns: 1fr; grid-template-rows: repeat(5, 50vh); }
    .property:nth-child(1), .property:nth-child(2), .property:nth-child(3), .property:nth-child(4), .property:nth-child(5) { grid-column: 1; grid-row: span 1; }
    .stats-section { padding: var(--space-2xl) var(--space-md); }
    .stats { grid-template-columns: 1fr 1fr; gap: var(--space-md); }
    .stat { padding: var(--space-md); }
    .stat__number { font-size: clamp(2rem, 8vw, 3rem); }
    .stat__label { font-size: 0.75rem; }
    .expertise__grid, .testimonials { grid-template-columns: 1fr; gap: var(--space-lg); }
    .footer__content { grid-template-columns: 1fr; }
}

/* =========================================================================
   ACCESSIBILITY
   ========================================================================= */
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; } }
@media (prefers-reduced-transparency: reduce) {
    .hero__glass, .btn--secondary { backdrop-filter: none; -webkit-backdrop-filter: none; }
    .hero__glass { background: rgba(15, 23, 42, 0.6); }
    .btn--secondary { background: rgba(15, 23, 42, 0.95); }
    .testimonial, .property__overlay { backdrop-filter: none; -webkit-backdrop-filter: none; }
}
*:focus-visible { outline: 3px solid var(--color-accent); outline-offset: 3px; }
::selection { background: var(--color-accent); color: var(--color-primary); }

/* WordPress admin bar */
body.admin-bar .hero { top: 32px; }
@media screen and (max-width: 782px) { body.admin-bar .hero { top: 46px; } }
