/*
Theme Name: Celsa Property Theme
Theme URI: https://celsaproperties.com
Author: KM Digital Solutions
Author URI: https://km-digitalsolutions.com
Description: Custom premium theme for Celsa Property Group. Quiet luxury aesthetic: black, white, champagne. Built for Western Cape real estate.
Version: 1.0.44-qa-fixes-20260520
License: Proprietary
Text Domain: celsa-property
Requires at least: 6.0
Requires PHP: 8.0
*/

/* ─── CSS Custom Properties ─── */
:root {
    /* Brand Colors */
    --color-black: #000000;
    --color-white: #FFFFFF;
    --color-champagne: #CBBBA0;
    --color-champagne-light: #E8DFD1;
    --color-champagne-dark: #A89878;
    --color-grey: #BDBDBD;
    --color-grey-light: #F5F3F0;
    --color-grey-dark: #595959;

    /* Semantic */
    --color-success: #1B7A3D;
    --color-error: #C0392B;
    --color-info: #2C5282;

    /* Typography */
    --font-heading: 'Montserrat', sans-serif;
    --font-body: 'Inter', sans-serif;

    /* Spacing */
    --space-xs: 0.5rem;
    --space-sm: 1rem;
    --space-md: 1.5rem;
    --space-lg: 2.5rem;
    --space-xl: 4rem;
    --space-2xl: 6rem;

    /* Layout */
    --container-max: 1200px;
    --container-narrow: 800px;
    --nav-height: 72px;

    /* Transitions */
    --transition-fast: 0.2s ease;
    --transition-base: 0.3s ease;
    --transition-slow: 0.6s ease;

    /* Shadows */
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.1);
    --shadow-lg: 0 8px 30px rgba(0,0,0,0.12);
}

/* ─── Reset & Base ─── */
*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body {
    font-family: var(--font-body);
    font-weight: 400;
    line-height: 1.6;
    color: var(--color-black);
    background: var(--color-white);
    overflow-x: hidden;
}

/* ─── Typography ─── */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 600;
    line-height: 1.15;
    color: var(--color-black);
}

h1 { font-size: clamp(2.5rem, 5vw, 4rem); }
h2 { font-size: clamp(1.75rem, 3.5vw, 2.5rem); }
h3 { font-size: clamp(1.25rem, 2.5vw, 1.75rem); }
h4 { font-size: 1.125rem; }

p {
    margin-bottom: 1rem;
    color: var(--color-grey-dark);
}

a {
    color: var(--color-champagne-dark);
    text-decoration: none;
    transition: color var(--transition-fast);
}

a:hover {
    color: var(--color-champagne);
}

/* ─── Utility Classes ─── */
.container {
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--space-md);
}

.container--narrow {
    max-width: var(--container-narrow);
}

.section {
    padding: var(--space-2xl) 0;
}

.section--dark {
    background: var(--color-black);
    color: var(--color-white);
}

.section--dark h2,
.section--dark h3 {
    color: var(--color-white);
}

.section--dark p {
    color: var(--color-grey);
}

.section--cream {
    background: var(--color-grey-light);
}

.text-champagne {
    color: var(--color-champagne);
}

.text-center { text-align: center; }
.text-uppercase {
    text-transform: uppercase;
    letter-spacing: 4px;
    font-size: 0.75rem;
    font-weight: 300;
}

/* WCAG AA fix: small uppercase kicker labels in champagne are illegible on
   light/cream backgrounds (1.88:1). Use a darker bronze on light sections
   (6.6:1 on white, 6:1 on cream). Champagne is kept on dark sections, where
   it already passes at ~11:1. Decorative .text-champagne heading accents
   (which are large text, not .text-uppercase) are intentionally untouched. */
.section:not(.section--dark) .text-uppercase.text-champagne {
    color: #6F5A2E;
    font-weight: 400;
}

/* ─── Buttons ─── */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.875rem 2rem;
    font-family: var(--font-heading);
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 1px;
    text-transform: uppercase;
    border: none;
    cursor: pointer;
    transition: all var(--transition-base);
    text-decoration: none;
}

.btn--primary {
    background: var(--color-champagne);
    color: var(--color-black);
}

.btn--primary:hover {
    background: var(--color-champagne-dark);
    color: var(--color-black);
}

.btn--outline {
    background: transparent;
    color: var(--color-white);
    border: 1px solid var(--color-champagne);
}

.btn--outline:hover {
    background: var(--color-champagne);
    color: var(--color-black);
}

.btn--dark {
    background: var(--color-black);
    color: var(--color-white);
}

.btn--dark:hover {
    background: var(--color-grey-dark);
    color: var(--color-white);
}

/* ─── Navigation ─── */
.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    padding: 0 var(--space-md);
    height: var(--nav-height);
    display: flex;
    align-items: center;
    transition: all var(--transition-base);
}

.site-header--transparent {
    background: transparent;
}

.site-header--scrolled {
    background: rgba(0, 0, 0, 0.95);
    backdrop-filter: blur(10px);
    box-shadow: var(--shadow-md);
}

.site-header .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.site-header .site-logo img {
    height: 36px;
    width: auto;
    max-width: none;
    transition: opacity var(--transition-fast);
}

/* Keep the nav clear of the logo on tighter desktop widths */
.nav-menu {
    margin-left: var(--space-lg);
}
@media (min-width: 1024px) {
    .nav-list { gap: 1.5rem; }
}
@media (max-width: 1023px) and (min-width: 769px) {
    .nav-list { gap: 1.05rem; }
    .nav-list a, .nav-dropdown-toggle { font-size: 0.72rem; letter-spacing: 1px; }
    button.nav-cta { padding: 0.55rem 1.1rem; font-size: 0.72rem; }
}

.site-logo:hover img {
    opacity: 0.8;
}

.nav-menu {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
    list-style: none;
}

.nav-menu a {
    font-family: var(--font-heading);
    font-size: 0.8125rem;
    font-weight: 400;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--color-white);
    transition: color var(--transition-fast);
}

.nav-menu a:hover {
    color: var(--color-champagne);
}

.nav-cta {
    padding: 0.625rem 1.5rem;
    background: var(--color-champagne);
    color: var(--color-black) !important;
    font-weight: 500;
}

.nav-cta:hover {
    background: var(--color-champagne-dark);
    color: var(--color-black) !important;
}

/* Mobile menu toggle */
.menu-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
}

.menu-toggle span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--color-white);
    margin: 5px 0;
    transition: all var(--transition-base);
}

@media (max-width: 768px) {
    .menu-toggle { display: block; }
    /* Mobile nav drawer rules live in the dedicated block below */
}

/* ─── Hero Section ─── */
.hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-black);
    color: var(--color-white);
    text-align: center;
    overflow: hidden;
}

.hero__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0.4;
}

.hero__content {
    position: relative;
    z-index: 2;
    max-width: 700px;
    padding: 0 var(--space-md);
}

.hero__badge {
    font-family: var(--font-heading);
    font-weight: 300;
    font-size: 0.6875rem;
    letter-spacing: 6px;
    text-transform: uppercase;
    color: var(--color-champagne);
    margin-bottom: var(--space-lg);
}

.hero__title {
    color: var(--color-white);
    margin-bottom: var(--space-md);
}

.hero__title span {
    color: var(--color-champagne);
}

.hero__sub {
    font-size: 1.125rem;
    color: var(--color-grey);
    margin-bottom: var(--space-xl);
    line-height: 1.7;
}

.hero__actions {
    display: flex;
    gap: var(--space-sm);
    justify-content: center;
    flex-wrap: wrap;
}

/* ─── Hero Overlay & Scroll Hint ─── */
.hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to bottom,
        rgba(0,0,0,0.3) 0%,
        rgba(0,0,0,0.5) 50%,
        rgba(0,0,0,0.8) 100%
    );
    z-index: 1;
}

.hero__scroll-hint {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
}

.hero__scroll-hint span {
    display: block;
    width: 1px;
    height: 40px;
    background: linear-gradient(to bottom, var(--color-champagne), transparent);
    animation: scroll-hint 2s ease-in-out infinite;
}

@keyframes scroll-hint {
    0%, 100% { opacity: 0.4; transform: scaleY(0.6); transform-origin: top; }
    50% { opacity: 1; transform: scaleY(1); }
}

/* ─── Service Card Link ─── */
.service-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-heading);
    font-size: 0.8125rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-champagne-dark);
    margin-top: var(--space-sm);
    transition: gap var(--transition-base), color var(--transition-base);
}

.service-card__link:hover {
    color: var(--color-black);
    gap: 0.75rem;
}

.service-card__link span {
    transition: transform var(--transition-base);
}

.service-card__link:hover span {
    transform: translateX(4px);
}

/* ─── Reduced Motion ─── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    .hero__scroll-hint { display: none; }
}

/* ─── Agent Cards ─── */
.agent-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--space-lg);
}

.agent-card {
    background: var(--color-white);
    border: 1px solid var(--color-grey-light);
    overflow: hidden;
    transition: all var(--transition-base);
}

.agent-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-4px);
}

.agent-card__photo {
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--color-grey-light);
}

.agent-card__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.agent-card:hover .agent-card__photo img {
    transform: scale(1.05);
}

.agent-card__info {
    padding: var(--space-md);
}

.agent-card__name {
    font-family: var(--font-heading);
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.agent-card__role {
    font-size: 0.8125rem;
    color: var(--color-champagne-dark);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--space-sm);
}

.agent-card__contact {
    display: flex;
    gap: var(--space-sm);
}

.agent-card__contact a {
    font-size: 0.875rem;
    color: var(--color-grey-dark);
}

.agent-card__contact a:hover {
    color: var(--color-champagne-dark);
}

/* ─── Team Carousel (homepage Trusted Experts) ─── */
.team-section-heading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(1rem, 4vw, 3rem);
    margin: 0 auto var(--space-md);
    max-width: 880px;
}

.team-section-heading__squiggle {
    flex: 0 0 auto;
    width: clamp(60px, 14vw, 140px);
    height: auto;
    color: var(--color-champagne);
    opacity: 0.85;
}

.team-section-heading__squiggle--right {
    transform: scaleX(-1);
}

.team-section-heading__title {
    position: relative;
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-weight: 500;
    font-size: clamp(2rem, 4.4vw, 3.4rem);
    line-height: 1.1;
    letter-spacing: 0.5px;
    color: var(--color-white);
    margin: 0;
    text-align: center;
    white-space: nowrap;
    isolation: isolate;
    /* Single soft drop-shadow renders as one continuous Gaussian halo —
       no stacking, no concentric rings, no animation jitter. */
    filter:
        drop-shadow(0 0 18px rgba(245, 235, 211, 0.45))
        drop-shadow(0 0 48px rgba(203, 187, 160, 0.35));
}

.team-section-heading__title em {
    font-style: italic;
    font-weight: 600;
    background: linear-gradient(180deg, #F5EBD3 0%, var(--color-champagne) 50%, #A89878 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.team-carousel-wrap {
    position: relative;
    margin: 0 auto;
    max-width: 1180px;
    padding: 0 clamp(0px, 4vw, 60px);
}

.team-carousel {
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x proximity;
    scroll-padding-left: 8px;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding: var(--space-md) 0 var(--space-lg);
    -webkit-overflow-scrolling: touch;
}

.team-carousel::-webkit-scrollbar {
    display: none;
}

.team-carousel__track {
    display: flex;
    gap: var(--space-md);
    padding: 0 max(8px, calc((100% - 1180px) / 2));
}

.team-slide {
    flex: 0 0 calc((100% - var(--space-md) * 3) / 4);
    min-width: 220px;
    max-width: 280px;
    scroll-snap-align: start;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(203, 187, 160, 0.15);
    transition: all var(--transition-base);
    text-align: center;
    position: relative;
}

.team-slide:hover {
    border-color: rgba(203, 187, 160, 0.5);
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(203, 187, 160, 0.12);
}

.team-slide__photo {
    aspect-ratio: 4 / 5;
    flex: 0 0 auto;
    overflow: hidden;
    background: #1a1a1a;
    position: relative;
    margin: 0;
    line-height: 0;
}

.team-slide__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: transform var(--transition-slow);
    display: block;
    margin: 0;
    padding: 0;
    border: 0;
}

.team-slide:hover .team-slide__photo img {
    transform: scale(1.06);
}

.team-slide__photo--placeholder::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.18));
    pointer-events: none;
}

.team-slide__info {
    flex: 1 1 auto;
    padding: var(--space-md) var(--space-sm) var(--space-lg);
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    /* Reserve space for a 2-line role beneath the name so single-line and
       two-line cards have identical total height — no top gap on shorter cards. */
    min-height: 7rem;
}

.team-slide__name {
    flex: 0 0 auto;
}

.team-slide__role {
    flex: 0 0 auto;
    /* Lock first-line baseline by reserving exactly 2 line heights. */
    min-height: calc(0.7rem * 1.4 * 2 + 0.05rem);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    text-align: center;
    line-height: 1.4;
}

.team-slide__name {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-size: 1.35rem;
    font-weight: 500;
    color: var(--color-white);
    margin: 0 0 0.35rem;
    line-height: 1.2;
}

.team-slide__role {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1.6px;
    color: var(--color-champagne);
    margin: 0;
}

.team-slide__role--placeholder {
    color: rgba(203, 187, 160, 0.5);
    font-style: italic;
    text-transform: none;
    letter-spacing: 0.6px;
    font-size: 0.75rem;
}

.team-carousel__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(203, 187, 160, 0.12);
    border: 1px solid rgba(203, 187, 160, 0.4);
    color: var(--color-champagne);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 5;
    transition: all var(--transition-base);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.team-carousel__nav:hover {
    background: rgba(203, 187, 160, 0.25);
    border-color: var(--color-champagne);
    color: var(--color-white);
    transform: translateY(-50%) scale(1.06);
}

.team-carousel__nav:disabled {
    opacity: 0.25;
    cursor: not-allowed;
    pointer-events: none;
}

.team-carousel__nav svg {
    width: 20px;
    height: 20px;
}

.team-carousel__nav--prev {
    left: -4px;
}

.team-carousel__nav--next {
    right: -4px;
}

.team-carousel__nav--next svg {
    transform: scaleX(-1);
}

@media (max-width: 1024px) {
    .team-slide { flex: 0 0 calc((100% - var(--space-md) * 2) / 3); }
}

@media (max-width: 768px) {
    .team-section-heading__title { white-space: normal; }
    .team-section-heading__squiggle { width: clamp(40px, 12vw, 80px); }
    .team-slide { flex: 0 0 calc((100% - var(--space-md)) / 2); min-width: 0; }
    .team-carousel__nav { width: 40px; height: 40px; }
    .team-carousel__nav--prev { left: 4px; }
    .team-carousel__nav--next { right: 4px; }
}

@media (max-width: 480px) {
    .team-slide { flex: 0 0 80%; }
    .team-section-heading { gap: 0.75rem; }
}

/* ─── Service Cards ─── */
.service-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--space-lg);
}

.service-card {
    padding: var(--space-xl) var(--space-lg);
    background: var(--color-white);
    border: 1px solid var(--color-grey-light);
    transition: all var(--transition-base);
}

.service-card:hover {
    border-color: var(--color-champagne);
    box-shadow: var(--shadow-md);
}

.service-card__icon {
    width: 48px;
    height: 48px;
    margin-bottom: var(--space-md);
    color: var(--color-champagne-dark);
}

.service-card__title {
    font-size: 1.25rem;
    margin-bottom: var(--space-sm);
}

.service-card__text {
    font-size: 0.9375rem;
    line-height: 1.7;
}

/* ─── Area Cards ─── */
.area-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--space-md);
}
.area-card--expansion .area-card__overlay::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(168, 152, 120, 0.18), rgba(0, 0, 0, 0.55));
    pointer-events: none;
}
.area-card__count--expansion {
    display: inline-block;
    padding: 0.25rem 0.6rem;
    border: 1px solid var(--color-champagne);
    color: var(--color-champagne);
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 1.4px;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(2px);
}

.area-card {
    position: relative;
    aspect-ratio: 16/10;
    overflow: hidden;
    cursor: pointer;
}

.area-card__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transition: transform var(--transition-slow);
}

.area-card:hover .area-card__bg {
    transform: scale(1.08);
}

.area-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.7), transparent);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: var(--space-md);
}

.area-card__name {
    font-family: var(--font-heading);
    font-size: 1.375rem;
    font-weight: 600;
    color: var(--color-white);
}

.area-card__count {
    font-size: 0.8125rem;
    color: var(--color-champagne-light);
}

/* ─── Footer ─── */
.site-footer {
    background: var(--color-black);
    color: var(--color-grey);
    padding: var(--space-2xl) 0 var(--space-lg);
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--space-xl);
    margin-bottom: var(--space-xl);
}

.footer-col h4 {
    color: var(--color-white);
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: var(--space-md);
}

.footer-col a {
    display: block;
    color: var(--color-grey);
    font-size: 0.875rem;
    padding: 0.25rem 0;
    transition: color var(--transition-fast);
}

.footer-col a:hover {
    color: var(--color-champagne);
}

.footer-social {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    align-items: center;
}

.footer-social a {
    display: inline-block;
    padding: 0.25rem 0;
    color: var(--color-grey);
    font-size: 0.8125rem;
    letter-spacing: 0.5px;
    transition: color var(--transition-fast);
    border-bottom: 1px solid transparent;
}

.footer-social a:hover {
    color: var(--color-champagne);
    border-bottom-color: var(--color-champagne);
}

.footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.1);
    padding-top: var(--space-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--space-sm);
    font-size: 0.75rem;
}

.footer-bottom a {
    color: var(--color-champagne-dark);
}

@media (max-width: 768px) {
    .site-footer {
        padding-bottom: 5rem; /* clearance for floating-actions stack */
    }
    .footer-bottom {
        flex-direction: column;
        align-items: flex-start;
        text-align: left;
        padding-right: 4.5rem;
        gap: 0.5rem;
    }
    .footer-bottom span {
        line-height: 1.5;
    }
}

/* ─── Forms ─── */
.form-group {
    margin-bottom: var(--space-md);
}

.form-group label {
    display: block;
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-grey-dark);
    margin-bottom: 0.5rem;
}

.form-group input,
.form-group select,
.form-group textarea {
    width: 100%;
    padding: 0.875rem 1rem;
    font-family: var(--font-body);
    font-size: 0.9375rem;
    border: 1px solid var(--color-grey);
    background: var(--color-white);
    color: var(--color-black);
    transition: border-color var(--transition-fast);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--color-champagne);
}

.form-group textarea {
    min-height: 120px;
    resize: vertical;
}

/* ─── Blog Cards ─── */
.blog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: var(--space-lg);
}

.blog-card {
    background: var(--color-white);
    border: 1px solid var(--color-grey-light);
    overflow: hidden;
    transition: all var(--transition-base);
}

.blog-card:hover {
    box-shadow: var(--shadow-md);
}

.blog-card__image {
    aspect-ratio: 16/9;
    overflow: hidden;
}

.blog-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.blog-card:hover .blog-card__image img {
    transform: scale(1.05);
}

.blog-card__content {
    padding: var(--space-md);
}

.blog-card__category {
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-champagne-dark);
    margin-bottom: 0.5rem;
}

.blog-card__title {
    font-size: 1.125rem;
    margin-bottom: 0.75rem;
}

.blog-card__excerpt {
    font-size: 0.875rem;
    color: var(--color-grey-dark);
    line-height: 1.6;
}

/* ─── Trust Signals ─── */
.trust-bar {
    display: flex;
    justify-content: center;
    gap: var(--space-xl);
    flex-wrap: wrap;
    padding: var(--space-lg) 0;
}

.trust-stat {
    text-align: center;
}

.trust-stat__number {
    font-family: var(--font-heading);
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--color-champagne);
    line-height: 1;
}

.trust-stat__label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-grey);
    margin-top: 0.5rem;
}

/* ─── Page Hero (inner pages) ─── */
.page-hero {
    background: var(--color-black);
    color: var(--color-white);
    text-align: center;
    padding: calc(var(--nav-height) + var(--space-2xl)) var(--space-md) var(--space-2xl);
    min-height: 40vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.page-hero__content h1 {
    color: var(--color-white);
    margin-bottom: var(--space-sm);
}

.page-hero__sub {
    font-size: 1.0625rem;
    color: var(--color-grey);
    max-width: 500px;
    margin: 0 auto;
}

/* ─── About Grid ─── */
.about-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: var(--space-xl);
    align-items: center;
}

.about-text h2 { margin-bottom: var(--space-md); }
.about-text p { font-size: 1.0625rem; line-height: 1.8; }

.about-image img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

@media (max-width: 768px) {
    .about-grid { grid-template-columns: 1fr; }
}

/* ─── Values Grid ─── */
.values-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
}

.value-card {
    text-align: center;
    padding: var(--space-lg);
}

.value-card h3 {
    font-size: 1.5rem;
    margin-bottom: var(--space-sm);
}

.value-card p {
    color: var(--color-grey);
    line-height: 1.7;
}

@media (max-width: 768px) {
    .values-grid { grid-template-columns: 1fr; }
}

/* ─── Director Cards ─── */
.director-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    gap: var(--space-xl);
}

.director-card {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: var(--space-lg);
    align-items: start;
}

.director-card__photo {
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--color-grey-light);
}

.director-card__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.director-card__info h3 {
    font-size: 1.375rem;
    margin-bottom: 0.25rem;
}

.director-card__info .btn svg {
    width: 16px;
    height: 16px;
}

@media (max-width: 600px) {
    .director-grid { grid-template-columns: 1fr; }
    .director-card { grid-template-columns: 1fr; text-align: center; }
    .director-card__photo { max-width: 200px; margin: 0 auto; }
}

/* ─── Admin Grid ─── */
.admin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--space-md);
}

.admin-card {
    text-align: center;
    padding: var(--space-md);
}

.admin-card__photo {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    overflow: hidden;
    margin: 0 auto var(--space-sm);
    background: var(--color-grey-light);
}

.admin-card__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.admin-card h4 {
    font-size: 0.9375rem;
    margin-bottom: 0.25rem;
}

/* ─── Slide-from-right reveal (homepage Services preview) ─── */
.slide-right-item {
    will-change: transform, opacity;
}

/* If JS hasn't run yet keep them visible — animation only enhances. */
.slide-right-item:not(.is-revealed) {
    opacity: 1;
}

/* ─── Champagne underglow on accented words ─── */
.text-glow {
    position: relative;
    text-shadow:
        0 0 12px rgba(203, 187, 160, 0.55),
        0 0 28px rgba(203, 187, 160, 0.30);
}

/* Animated gentle pulse for the underglow — luxurious, never frantic. */
@keyframes celsa-glow-pulse {
    0%, 100% {
        text-shadow:
            0 0 12px rgba(203, 187, 160, 0.55),
            0 0 28px rgba(203, 187, 160, 0.30);
    }
    50% {
        text-shadow:
            0 0 18px rgba(203, 187, 160, 0.75),
            0 0 36px rgba(203, 187, 160, 0.45);
    }
}

.text-glow--pulse {
    animation: celsa-glow-pulse 4s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
    .text-glow--pulse { animation: none; }
}

/* ─── Contact / Lead Gen Layout ─── */
.lead-forms-container {
    width: 100%;
    margin: 0 auto var(--space-xl);
    max-width: 980px;
}

/* Contact section is now a single-column flow: forms first, then the
   contact-sidebar below as a 4-up horizontal row. */
.section > .container:has(.lead-forms-container) {
    display: block;
}

/* ─── Intent Selector ─── */
.intent-selector {
    text-align: center;
    margin-bottom: var(--space-xl);
}

.intent-selector__label {
    font-family: var(--font-heading);
    font-size: 1.125rem;
    font-weight: 500;
    margin-bottom: var(--space-md);
}

.intent-options {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
    flex-wrap: wrap;
}

.intent-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 1.25rem;
    background: var(--color-white);
    border: 1px solid var(--color-grey);
    cursor: pointer;
    transition: all var(--transition-base);
    min-width: 120px;
}

.intent-btn:hover {
    border-color: var(--color-champagne);
    background: var(--color-grey-light);
}

.intent-btn--active {
    border-color: var(--color-champagne);
    background: var(--color-black);
    color: var(--color-white);
}

.intent-btn__icon {
    width: 28px;
    height: 28px;
    color: var(--color-champagne-dark);
}

.intent-btn--active .intent-btn__icon {
    color: var(--color-champagne);
}

.intent-btn__icon svg { width: 100%; height: 100%; }

.intent-btn__text {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

@media (max-width: 600px) {
    .intent-options { gap: 0.5rem; }
    .intent-btn { min-width: 90px; padding: 0.75rem 0.5rem; }
    .intent-btn__text { font-size: 0.625rem; }
}

/* ─── Lead Forms ─── */
.lead-form {
    background: var(--color-white);
    border: 1px solid var(--color-grey-light);
    padding: var(--space-xl);
}

.lead-form__header {
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid var(--color-grey-light);
}

.lead-form__header h2 { font-size: 1.5rem; margin-bottom: 0.5rem; }
.lead-form__header p { font-size: 0.9375rem; color: var(--color-grey-dark); margin: 0; }

.form-step__label {
    font-family: var(--font-heading);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-champagne-dark);
    margin-bottom: var(--space-md);
}

.form-row--3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
}

@media (max-width: 480px) {
    .form-row--3 { grid-template-columns: 1fr; }
}

.form-divider {
    height: 1px;
    background: var(--color-grey-light);
    margin: var(--space-lg) 0;
}

.form-actions {
    display: flex;
    gap: var(--space-md);
}

.form-disclaimer {
    font-size: 0.75rem;
    color: var(--color-grey);
    margin-top: 0.75rem;
    line-height: 1.5;
}

.field-error {
    border-color: var(--color-error) !important;
}

/* ─── WhatsApp Card ─── */
.whatsapp-card {
    background: #075E54;
    color: var(--color-white);
    padding: var(--space-lg);
    margin-bottom: var(--space-md);
}

.whatsapp-card h3 { color: var(--color-white); font-size: 1rem; margin-bottom: 0.5rem; }
.whatsapp-card p { color: rgba(255,255,255,0.8); font-size: 0.875rem; margin-bottom: var(--space-sm); }

.btn--whatsapp {
    background: #25D366;
    color: var(--color-white);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    font-family: var(--font-heading);
    font-size: 0.875rem;
    font-weight: 500;
    border: none;
    cursor: pointer;
    text-decoration: none;
    transition: background var(--transition-fast);
    width: 100%;
    justify-content: center;
}

.btn--whatsapp:hover { background: #1DA851; color: var(--color-white); }

/* ─── Contact Sidebar (now a horizontal row below the form) ─── */
.contact-sidebar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-md);
    margin-top: var(--space-xl);
    padding-top: var(--space-xl);
    border-top: 1px solid var(--color-grey-light);
    align-items: stretch;
}

.contact-sidebar > * {
    margin: 0;
    height: 100%;
}

.contact-sidebar .contact-info__card,
.contact-sidebar .whatsapp-card {
    padding: var(--space-md);
    margin: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.contact-sidebar h3 {
    font-size: 0.95rem;
    margin-bottom: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-champagne-dark);
}

.contact-sidebar .whatsapp-card h3 {
    color: var(--color-white);
}

.contact-sidebar .whatsapp-card p,
.contact-sidebar .contact-info__card p {
    font-size: 0.8125rem;
    line-height: 1.55;
    margin: 0 0 0.4rem;
}

.contact-sidebar .contact-info__item {
    align-items: flex-start;
    gap: 0.6rem;
    font-size: 0.8125rem;
    line-height: 1.5;
    margin-bottom: 0.5rem;
}

.contact-sidebar .contact-info__item:last-child { margin-bottom: 0; }

.contact-sidebar .contact-info__icon {
    flex: 0 0 18px;
    width: 18px;
    height: 18px;
    color: var(--color-champagne-dark);
    margin-top: 2px;
}

.contact-sidebar .btn--whatsapp {
    margin-top: auto;
    padding: 0.65rem 1rem;
    font-size: 0.8125rem;
}

@media (max-width: 960px) {
    .contact-sidebar {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .contact-sidebar {
        grid-template-columns: 1fr;
    }
}

.contact-sidebar .contact-info__card + .contact-info__card { margin-top: 0; }

.director-quick__item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    margin-bottom: 0.75rem;
    font-size: 0.875rem;
}

.director-quick__item strong { font-size: 0.9375rem; }

.director-quick__wa {
    display: inline-block;
    font-size: 0.75rem;
    color: #25D366;
    font-weight: 500;
}

.director-quick__wa:hover { color: #1DA851; }

/* ─── Bond Calculator ─── */
.bond-calculator {
    margin-top: var(--space-xl);
    padding: var(--space-lg);
    background: var(--color-grey-light);
    border: 1px solid var(--color-grey);
}

.bond-calculator h3 {
    font-size: 1.125rem;
    margin-bottom: 0.25rem;
}

.bond-calculator__sub {
    font-size: 0.875rem;
    color: var(--color-grey-dark);
    margin-bottom: var(--space-md);
}

.bond-results {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm);
    margin-top: var(--space-md);
}

.bond-result {
    padding: var(--space-sm);
    background: var(--color-white);
    border: 1px solid var(--color-grey-light);
    text-align: center;
}

.bond-result--primary {
    grid-column: 1 / -1;
    background: var(--color-black);
    border-color: var(--color-black);
}

.bond-result--primary .bond-result__label { color: var(--color-grey); }
.bond-result--primary .bond-result__value { color: var(--color-champagne); font-size: 1.75rem; }

.bond-result__label {
    display: block;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-grey-dark);
    margin-bottom: 0.25rem;
}

.bond-result__value {
    display: block;
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-black);
}

.bond-calculator__disclaimer {
    font-size: 0.6875rem;
    color: var(--color-grey);
    margin-top: var(--space-sm);
    line-height: 1.5;
}

@media (max-width: 480px) {
    .bond-results { grid-template-columns: 1fr; }
    .bond-result--primary { grid-column: auto; }
}

/* ─── Contact Grid (legacy) ─── */
.contact-grid {
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    gap: var(--space-xl);
    align-items: start;
}

@media (max-width: 768px) {
    .contact-grid { grid-template-columns: 1fr; }
}

.form-tabs {
    display: flex;
    gap: 0;
    margin-bottom: var(--space-lg);
    border-bottom: 2px solid var(--color-grey-light);
}

.form-tab {
    flex: 1;
    padding: 0.875rem 1rem;
    font-family: var(--font-heading);
    font-size: 0.8125rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
    background: none;
    border: none;
    color: var(--color-grey);
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all var(--transition-fast);
}

.form-tab--active {
    color: var(--color-black);
    border-bottom-color: var(--color-champagne);
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
}

@media (max-width: 480px) {
    .form-row { grid-template-columns: 1fr; }
}

.hidden { display: none; }

.contact-info__card {
    padding: var(--space-lg);
    background: var(--color-grey-light);
}

.contact-info__card h3 {
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: var(--space-md);
}

.contact-info__item {
    display: flex;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
    font-size: 0.9375rem;
    line-height: 1.6;
}

.contact-info__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    margin-top: 2px;
    color: var(--color-champagne-dark);
}

.contact-info__icon svg {
    width: 100%;
    height: 100%;
}

.contact-map {
    line-height: 0;
}

/* ─── Service Detail ─── */
.service-detail__icon {
    width: 48px;
    height: 48px;
    margin-bottom: var(--space-md);
    color: var(--color-champagne-dark);
}

.service-detail__icon svg {
    width: 100%;
    height: 100%;
}

.service-detail__list {
    list-style: none;
    padding: 0;
}

.service-detail__list li {
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: 0.5rem;
    font-size: 0.9375rem;
    line-height: 1.6;
}

.service-detail__list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.5rem;
    width: 8px;
    height: 1px;
    background: var(--color-champagne);
}

/* ─── Area Detail ─── */
.areas-list { display: flex; flex-direction: column; gap: 0; }

.area-detail {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-xl);
    align-items: center;
    padding: var(--space-xl) 0;
}

.area-detail:nth-child(even) .area-detail__image { order: 2; }

.area-detail__image img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

@media (max-width: 768px) {
    .area-detail { grid-template-columns: 1fr; }
    .area-detail:nth-child(even) .area-detail__image { order: 0; }
}

/* ─── Property Type Nav ─── */
.property-type-nav {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--space-md);
}

.property-type-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--space-xl) var(--space-md) var(--space-lg);
    background: linear-gradient(180deg, #ffffff 0%, #faf8f4 100%);
    border: 1px solid rgba(203, 187, 160, 0.25);
    border-radius: 4px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 6px 16px -10px rgba(0,0,0,0.06);
    transition: transform 0.45s cubic-bezier(.2,.8,.2,1), box-shadow 0.45s ease, border-color 0.45s ease, background 0.45s ease;
    text-decoration: none;
    color: var(--color-black);
    overflow: hidden;
    isolation: isolate;
}

.property-type-card::before {
    content: '';
    position: absolute;
    inset: auto 0 0 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--color-champagne), transparent);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 0.5s cubic-bezier(.2,.8,.2,1);
    z-index: 1;
}

.property-type-card::after {
    content: '';
    position: absolute;
    top: -40%;
    right: -40%;
    width: 220px;
    height: 220px;
    background: radial-gradient(circle, rgba(203, 187, 160, 0.18) 0%, transparent 70%);
    opacity: 0;
    transition: opacity 0.5s ease;
    z-index: 0;
    pointer-events: none;
}

.property-type-card:hover {
    transform: translateY(-6px);
    border-color: var(--color-champagne);
    box-shadow: 0 4px 12px rgba(0,0,0,0.06), 0 24px 48px -16px rgba(168, 152, 120, 0.28);
    color: var(--color-black);
    background: linear-gradient(180deg, #ffffff 0%, #f6f1e8 100%);
}

.property-type-card:hover::before { transform: scaleX(1); }
.property-type-card:hover::after  { opacity: 1; }

.property-type-card:hover .property-type-card__icon {
    transform: scale(1.08) rotate(-2deg);
    color: var(--color-champagne-dark);
}

.property-type-card:hover h3 { color: var(--color-champagne-dark); }

.property-type-card--active {
    border-color: var(--color-champagne);
    background: var(--color-white);
}

.property-type-card__icon {
    position: relative;
    z-index: 2;
    width: 56px;
    height: 56px;
    margin: 0 auto var(--space-md);
    color: var(--color-champagne-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.45s cubic-bezier(.2,.8,.2,1), color 0.45s ease;
}

.property-type-card__icon svg { width: 100%; height: 100%; stroke-width: 1.25; }

.property-type-card h3 {
    position: relative;
    z-index: 2;
    font-size: 1.0625rem;
    font-weight: 500;
    letter-spacing: 0.5px;
    margin-bottom: 0.5rem;
    transition: color 0.4s ease;
}

.property-type-card p {
    position: relative;
    z-index: 2;
    font-size: 0.8125rem;
    line-height: 1.5;
    color: var(--color-grey-dark);
    margin: 0;
}

/* ─── P24 Embed ─── */
.p24-embed {
    padding: var(--space-xl);
    background: var(--color-grey-light);
}

/* ─── Single Post ─── */
.single-hero-image {
    max-height: 500px;
    overflow: hidden;
    line-height: 0;
}

.single-hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.single-content {
    font-size: 1.0625rem;
    line-height: 1.8;
}

.single-content h2 { margin: var(--space-xl) 0 var(--space-sm); }
.single-content h3 { margin: var(--space-lg) 0 var(--space-sm); }
.single-content p { margin-bottom: 1.25rem; }
.single-content ul,
.single-content ol { margin-bottom: 1.25rem; padding-left: 1.5rem; }
.single-content li { margin-bottom: 0.5rem; }
.single-content img { max-width: 100%; height: auto; margin: var(--space-md) 0; }
.single-content blockquote {
    border-left: 3px solid var(--color-champagne);
    padding: var(--space-md) var(--space-lg);
    margin: var(--space-lg) 0;
    background: var(--color-grey-light);
    font-style: italic;
}

.single-tag {
    display: inline-block;
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    border: 1px solid var(--color-grey);
    color: var(--color-grey-dark);
    margin-right: 0.5rem;
    margin-bottom: 0.5rem;
    transition: all var(--transition-fast);
}

.single-tag:hover {
    border-color: var(--color-champagne);
    color: var(--color-champagne-dark);
}

.author-box {
    display: flex;
    gap: var(--space-md);
    align-items: center;
    padding: var(--space-lg);
    background: var(--color-grey-light);
}

.author-box__avatar img { border-radius: 50%; }

/* ─── Blog Meta ─── */
.blog-card__meta {
    font-size: 0.75rem;
    color: var(--color-grey);
    margin-top: 0.75rem;
}

/* ─── Pagination ─── */
.pagination {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    margin-top: var(--space-xl);
}

.pagination a,
.pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 0.75rem;
    font-family: var(--font-heading);
    font-size: 0.8125rem;
    border: 1px solid var(--color-grey);
    color: var(--color-grey-dark);
    transition: all var(--transition-fast);
}

.pagination a:hover {
    border-color: var(--color-champagne);
    color: var(--color-champagne-dark);
}

.pagination .current {
    background: var(--color-black);
    border-color: var(--color-black);
    color: var(--color-white);
}

/* ─── Responsive ─── */
@media (max-width: 1024px) {
    .footer-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    .section { padding: var(--space-xl) 0; }
    /* Hero: anchor content top with safe header clearance so the EST. 2004
       badge can't bleed into the fixed nav bar. Min-height grows naturally
       with content; bottom padding keeps the chip row off the trust-bar. */
    .hero {
        min-height: 88vh;
        align-items: flex-start;
        padding-top: calc(var(--nav-height) + 1.5rem);
        padding-bottom: 3rem;
    }
    .hero__content { padding-top: 0; }
    .hero__badge { margin-bottom: var(--space-md); }
    .hero__service-chips { margin-bottom: 0; }
    .trust-bar { gap: var(--space-lg); }
    .trust-stat__number { font-size: 2rem; }
    .agent-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
    .service-grid { grid-template-columns: 1fr; }
    .blog-grid { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
    .hero__actions { flex-direction: column; align-items: center; }
    .btn { width: 100%; justify-content: center; }
}

/* ═══════════════════════════════════════════════════════ */
/* PREMIUM GLOW EFFECTS                                    */
/* ═══════════════════════════════════════════════════════ */

.glow-text {
    text-shadow: 0 0 60px rgba(203, 187, 160, 0.2);
}

.section--dark h2 {
    text-shadow: 0 0 40px rgba(203, 187, 160, 0.15);
}

.section--dark .agent-card,
.section--dark .service-card {
    box-shadow: 0 0 30px rgba(203, 187, 160, 0.05);
}

.section--dark .agent-card:hover,
.section--dark .service-card:hover {
    box-shadow: 0 0 40px rgba(203, 187, 160, 0.12);
    border-color: rgba(203, 187, 160, 0.2);
}

.hero__title {
    text-shadow: 0 0 80px rgba(203, 187, 160, 0.25), 0 0 30px rgba(203, 187, 160, 0.1);
}

.trust-stat__number {
    text-shadow: 0 0 20px rgba(203, 187, 160, 0.3);
}

/* ═══════════════════════════════════════════════════════ */
/* NAV — BUTTON CTA (replacing anchor)                     */
/* ═══════════════════════════════════════════════════════ */

.nav-list {
    display: flex;
    align-items: center;
    gap: 1.35rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.nav-list a {
    font-family: var(--font-heading);
    font-size: 0.78rem;
    font-weight: 400;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: var(--color-white);
    text-decoration: none;
    transition: color var(--transition-fast);
    white-space: nowrap;
}

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

button.nav-cta {
    padding: 0.625rem 1.5rem;
    background: var(--color-champagne);
    color: var(--color-black);
    font-family: var(--font-heading);
    font-size: 0.8125rem;
    font-weight: 500;
    letter-spacing: 1px;
    text-transform: uppercase;
    border: none;
    cursor: pointer;
    transition: all var(--transition-base);
}

button.nav-cta:hover {
    background: var(--color-champagne-dark);
}

/* ═══════════════════════════════════════════════════════
   MOBILE NAV DRAWER — full-viewport overlay, vibrant + clean
   ═══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    /* Hamburger → X morph on .is-active */
    .menu-toggle {
        position: relative;
        width: 32px;
        height: 32px;
        z-index: 1001;
    }
    .menu-toggle span {
        position: absolute;
        left: 4px;
        right: 4px;
        height: 2px;
        background: var(--color-white);
        margin: 0;
        transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.2s ease, background 0.25s ease;
        transform-origin: center;
    }
    .menu-toggle span:nth-child(1) { top: 10px; }
    .menu-toggle span:nth-child(2) { top: 15px; }
    .menu-toggle span:nth-child(3) { top: 20px; }
    .menu-toggle.is-active span { background: var(--color-champagne); }
    .menu-toggle.is-active span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
    .menu-toggle.is-active span:nth-child(2) { opacity: 0; }
    .menu-toggle.is-active span:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }

    /* Drawer base (closed) */
    .nav-menu {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        width: 100vw;
        height: 100dvh;
        background:
            radial-gradient(ellipse at 50% -10%, rgba(203, 187, 160, 0.13), transparent 65%),
            linear-gradient(180deg, #0a0908 0%, #050505 80%);
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        gap: 0;
        margin: 0;
        padding: calc(var(--nav-height) + 1.5rem) 1.5rem 1.75rem;
        z-index: 999;
        display: flex;
        opacity: 0;
        pointer-events: none;
        transform: translateY(-12px);
        transition: opacity 0.35s ease, transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }
    .nav-menu.is-open {
        opacity: 1;
        pointer-events: auto;
        transform: translateY(0);
    }
    .nav-menu__inner {
        max-width: 480px;
        margin: 0 auto;
        width: 100%;
        display: flex;
        flex-direction: column;
        flex: 1 0 auto;
    }
    .nav-menu__eyebrow {
        font-family: var(--font-body);
        font-size: 0.62rem;
        font-weight: 500;
        text-transform: uppercase;
        letter-spacing: 3.5px;
        color: var(--color-champagne);
        text-align: center;
        margin: 0 0 1.25rem;
        opacity: 0.75;
    }

    /* Nav list — italic serif item per row, divider lines */
    .nav-list {
        list-style: none;
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        height: auto;
        gap: 0;
    }
    .nav-list > li:not(.nav-cta-item) {
        border-bottom: 1px solid rgba(203, 187, 160, 0.10);
    }
    .nav-list > li:not(.nav-cta-item):first-child {
        border-top: 1px solid rgba(203, 187, 160, 0.10);
    }
    .nav-list a {
        display: block;
        padding: 0.95rem 0.5rem;
        font-family: 'Cormorant Garamond', Georgia, serif;
        font-style: italic;
        font-weight: 500;
        font-size: 1.4rem;
        letter-spacing: 0.5px;
        text-transform: none;
        color: var(--color-white);
        text-align: center;
        transition: color 0.25s ease, background 0.25s ease, letter-spacing 0.3s ease;
        position: relative;
    }
    .nav-list a:hover,
    .nav-list a:focus-visible {
        color: var(--color-champagne);
        background: rgba(203, 187, 160, 0.04);
        letter-spacing: 1px;
    }
    .nav-list a[aria-current="page"] {
        color: var(--color-champagne);
    }
    .nav-list a[aria-current="page"]::after {
        content: '';
        position: absolute;
        bottom: 0.6rem;
        left: 50%;
        transform: translateX(-50%);
        width: 28px;
        height: 1px;
        background: var(--color-champagne);
        opacity: 0.7;
    }

    .nav-cta-item {
        margin-top: 1.35rem;
        text-align: center;
        border-bottom: none !important;
    }
    button.nav-cta {
        display: inline-block;
        background: linear-gradient(180deg, var(--color-champagne) 0%, var(--color-champagne-dark) 100%);
        color: var(--color-black) !important;
        padding: 0.95rem 1.85rem;
        margin-top: 0;
        font-family: var(--font-body);
        font-size: 0.78rem;
        font-weight: 600;
        letter-spacing: 2.2px;
        text-transform: uppercase;
        border: 0;
        border-radius: 2px;
        cursor: pointer;
        transition: transform 0.25s ease, box-shadow 0.25s ease;
        box-shadow: 0 8px 22px -10px rgba(203, 187, 160, 0.45);
    }
    button.nav-cta:hover,
    button.nav-cta:focus-visible {
        transform: translateY(-2px);
        box-shadow: 0 14px 28px -12px rgba(203, 187, 160, 0.55);
    }

    /* Contact block */
    .nav-menu__contact {
        margin-top: 1.75rem;
        padding-top: 1.4rem;
        border-top: 1px solid rgba(203, 187, 160, 0.18);
        text-align: center;
    }
    .nav-menu__contact-label {
        font-family: var(--font-body);
        font-size: 0.6rem;
        text-transform: uppercase;
        letter-spacing: 3px;
        color: var(--color-champagne);
        margin: 0 0 0.85rem;
        font-weight: 500;
    }
    .nav-menu__contact-row {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0.55rem;
        padding: 0.45rem 0;
        font-family: var(--font-body);
        font-size: 0.88rem;
        color: var(--color-white);
        text-decoration: none;
        transition: color 0.25s ease;
    }
    .nav-menu__contact-row:hover { color: var(--color-champagne); }
    .nav-menu__contact-row svg {
        color: var(--color-champagne);
        flex: 0 0 14px;
    }
    .nav-menu__address {
        margin: 0.7rem 0 0;
        font-family: 'Cormorant Garamond', Georgia, serif;
        font-style: italic;
        font-size: 0.88rem;
        color: rgba(255, 255, 255, 0.55);
        line-height: 1.4;
    }

    /* Decorative footer mark */
    .nav-menu__decor {
        margin-top: auto;
        padding-top: 1.5rem;
        text-align: center;
    }
    .nav-menu__decor-mark {
        display: block;
        font-family: 'Cormorant Garamond', Georgia, serif;
        font-style: italic;
        font-weight: 500;
        font-size: 1.6rem;
        background: linear-gradient(180deg, #F5EBD3 0%, var(--color-champagne) 55%, #8E7E60 100%);
        -webkit-background-clip: text;
        background-clip: text;
        -webkit-text-fill-color: transparent;
        color: transparent;
        line-height: 1;
        letter-spacing: 0.5px;
    }
    .nav-menu__decor-sub {
        display: block;
        font-family: var(--font-body);
        font-size: 0.55rem;
        font-weight: 500;
        letter-spacing: 3.5px;
        text-transform: uppercase;
        color: rgba(203, 187, 160, 0.55);
        margin-top: 0.35rem;
    }

    /* Lock page scroll when menu is open */
    body.menu-open { overflow: hidden; }

    /* Hide floating actions + their bubbles while drawer is open so they
       don't poke through the overlay */
    body.menu-open .floating-actions,
    body.menu-open .floating-bubble {
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.2s ease;
    }
}

/* Hide drawer-only decorations on desktop nav */
@media (min-width: 769px) {
    .nav-menu__eyebrow,
    .nav-menu__contact,
    .nav-menu__decor { display: none; }
}

/* ═══════════════════════════════════════════════════════ */
/* EVALUATION MODAL                                        */
/* ═══════════════════════════════════════════════════════ */

.modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 2000;
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition-base);
}

.modal-overlay.is-open {
    opacity: 1;
    visibility: visible;
}

.modal {
    background: var(--color-black);
    color: var(--color-white);
    max-width: 560px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
    padding: var(--space-xl);
    position: relative;
    border: 1px solid rgba(203, 187, 160, 0.15);
    box-shadow: 0 0 60px rgba(203, 187, 160, 0.08);
}

.modal__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: none;
    border: none;
    color: var(--color-grey);
    font-size: 1.5rem;
    cursor: pointer;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color var(--transition-fast);
}

.modal__close:hover { color: var(--color-white); }

.modal__header {
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.modal .form-group label { color: var(--color-grey); }

.modal .form-group input,
.modal .form-group select,
.modal .form-group textarea {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.12);
    color: var(--color-white);
}

.modal .form-group input:focus,
.modal .form-group select:focus,
.modal .form-group textarea:focus {
    border-color: var(--color-champagne);
    background: rgba(255, 255, 255, 0.08);
}

.modal .form-group input::placeholder,
.modal .form-group textarea::placeholder {
    color: var(--color-grey-dark);
}

.modal .form-group select option {
    background: var(--color-black);
    color: var(--color-white);
}

/* ═══════════════════════════════════════════════════════ */
/* AGENT PROFILE MODAL                                     */
/* ═══════════════════════════════════════════════════════ */

.team-slide {
    appearance: none;
    -webkit-appearance: none;
    border: 1px solid rgba(203, 187, 160, 0.15);
    background: rgba(255, 255, 255, 0.03);
    color: inherit;
    text-align: center;
    font: inherit;
    cursor: pointer;
    padding: 0;
    position: relative;
    display: flex;
    flex-direction: column;
    align-self: stretch;
}

.team-slide__view {
    position: absolute;
    inset: auto 0 0 0;
    padding: 0.6rem 0.8rem;
    background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.55) 60%, rgba(0,0,0,0.85) 100%);
    color: var(--color-champagne-light);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1.8px;
    font-family: var(--font-body);
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 0.35s ease, transform 0.35s ease;
    pointer-events: none;
}

.team-slide:hover .team-slide__view,
.team-slide:focus-visible .team-slide__view {
    opacity: 1;
    transform: translateY(0);
}

.team-slide:focus-visible {
    outline: 2px solid var(--color-champagne);
    outline-offset: 3px;
}

.agent-modal-overlay {
    background: rgba(8, 6, 4, 0.78);
}

.agent-modal {
    max-width: 760px;
    width: 92%;
    padding: 0;
    background: linear-gradient(180deg, #111 0%, #0A0A0A 100%);
    border: 1px solid rgba(203, 187, 160, 0.22);
    box-shadow:
        0 0 0 1px rgba(0,0,0,0.4),
        0 30px 80px rgba(0,0,0,0.6),
        0 0 120px rgba(203, 187, 160, 0.12);
    overflow: hidden;
    position: relative;
}

.agent-modal::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(203, 187, 160, 0.4) 25%,
        rgba(245, 235, 211, 0.85) 50%,
        rgba(203, 187, 160, 0.4) 75%,
        transparent 100%);
    z-index: 1;
}

.agent-modal .modal__close {
    z-index: 4;
    background: rgba(0, 0, 0, 0.55);
    border-radius: 50%;
    border: 1px solid rgba(203, 187, 160, 0.25);
    color: var(--color-champagne-light);
    transition: all var(--transition-base);
}

.agent-modal .modal__close:hover {
    background: rgba(203, 187, 160, 0.18);
    border-color: var(--color-champagne);
    color: var(--color-white);
    transform: rotate(90deg);
}

.agent-modal__top {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: var(--space-lg);
    padding: var(--space-xl) var(--space-xl) var(--space-md);
    align-items: center;
}

.agent-modal__photo {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    background: #1a1a1a;
    border: 1px solid rgba(203, 187, 160, 0.2);
    position: relative;
    line-height: 0;
}

.agent-modal__photo::after {
    content: '';
    position: absolute;
    inset: 0;
    box-shadow: inset 0 -40px 60px rgba(0,0,0,0.3);
    pointer-events: none;
}

.agent-modal__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.agent-modal__intro {
    text-align: left;
}

.agent-modal__eyebrow {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-champagne);
    margin: 0 0 0.6rem;
    line-height: 1.4;
}

.agent-modal__eyebrow:empty { display: none; }

.agent-modal__name {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-weight: 500;
    font-size: 2.2rem;
    line-height: 1.05;
    color: var(--color-white);
    margin: 0 0 0.3rem;
    letter-spacing: 0.3px;
    text-shadow:
        0 0 24px rgba(245, 235, 211, 0.3),
        0 0 60px rgba(203, 187, 160, 0.25);
}

.agent-modal__role {
    font-family: var(--font-body);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-champagne-light);
    margin: 0 0 0.9rem;
}

.agent-modal__short {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-size: 1.05rem;
    color: var(--color-grey);
    margin: 0;
    line-height: 1.45;
}

.agent-modal__short:empty { display: none; }

.agent-modal__bio {
    padding: 0 var(--space-xl);
    font-size: 0.95rem;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.78);
}

.agent-modal__bio:empty { display: none; }

.agent-modal__highlights {
    list-style: none;
    margin: var(--space-md) 0 0;
    padding: 0 var(--space-xl);
    display: grid;
    gap: 0.55rem;
}

.agent-modal__highlights:empty { display: none; }

.agent-modal__highlights li {
    position: relative;
    padding-left: 1.5rem;
    color: rgba(255, 255, 255, 0.86);
    font-size: 0.92rem;
    line-height: 1.4;
}

.agent-modal__highlights li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.55rem;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-champagne);
    box-shadow: 0 0 12px rgba(203, 187, 160, 0.6);
}

.agent-modal__contact {
    margin: var(--space-lg) 0 0;
    padding: var(--space-lg) var(--space-xl) var(--space-xl);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.65rem;
    background: linear-gradient(180deg, transparent 0%, rgba(203, 187, 160, 0.04) 100%);
    border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.agent-modal__cta {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.85rem 0.9rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(203, 187, 160, 0.18);
    color: var(--color-white);
    text-decoration: none;
    transition: all var(--transition-base);
    font-family: var(--font-body);
    line-height: 1.2;
}

.agent-modal__cta:hover {
    background: rgba(203, 187, 160, 0.12);
    border-color: var(--color-champagne);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(203, 187, 160, 0.18);
}

.agent-modal__cta[aria-disabled="true"],
.agent-modal__cta.is-disabled {
    opacity: 0.35;
    pointer-events: none;
    transform: none;
}

.agent-modal__cta-icon {
    flex: 0 0 auto;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(203, 187, 160, 0.14);
    color: var(--color-champagne);
}

.agent-modal__cta--whatsapp .agent-modal__cta-icon {
    background: rgba(37, 211, 102, 0.14);
    color: #4dd486;
}

.agent-modal__cta-icon svg {
    width: 18px;
    height: 18px;
}

.agent-modal__cta-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.agent-modal__cta-label {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 1.6px;
    color: var(--color-champagne-light);
}

.agent-modal__cta-value {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--color-white);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.agent-modal__placeholder-note {
    margin: 0;
    padding: var(--space-md) var(--space-xl);
    background: rgba(203, 187, 160, 0.08);
    border-top: 1px solid rgba(203, 187, 160, 0.18);
    color: var(--color-champagne-light);
    font-size: 0.9rem;
    line-height: 1.5;
    font-style: italic;
}

.agent-modal__placeholder-note a {
    color: var(--color-champagne);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.agent-modal__placeholder-note[hidden] {
    display: none !important;
}

@media (max-width: 720px) {
    .agent-modal__top {
        grid-template-columns: 1fr;
        gap: var(--space-md);
        text-align: center;
        padding: var(--space-lg);
    }
    .agent-modal__photo {
        max-width: 200px;
        margin: 0 auto;
    }
    .agent-modal__intro { text-align: center; }
    .agent-modal__bio,
    .agent-modal__highlights,
    .agent-modal__placeholder-note { padding-left: var(--space-lg); padding-right: var(--space-lg); }
    .agent-modal__contact {
        grid-template-columns: 1fr;
        padding: var(--space-md) var(--space-lg) var(--space-lg);
    }
    .agent-modal__name { font-size: 1.8rem; }
}

/* ═══════════════════════════════════════════════════════ */
/* FLOATING ACTIONS                                        */
/* ═══════════════════════════════════════════════════════ */

.floating-actions {
    position: fixed;
    bottom: 1.5rem;
    z-index: 1500;
    transition: opacity var(--transition-base);
}

.floating-actions--left { left: 1.5rem; }

.floating-actions--right {
    right: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.floating-btn {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    cursor: pointer;
    transition: all var(--transition-base);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.25);
    opacity: 0;
    text-decoration: none;
}

.floating-btn--google {
    background: var(--color-white);
    color: var(--color-black);
}

.floating-btn--google:hover {
    background: var(--color-grey-light);
    transform: scale(1.08);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
}

.floating-btn--email {
    background: var(--color-champagne);
    color: var(--color-black);
}

.floating-btn--email:hover {
    background: var(--color-champagne-dark);
    transform: scale(1.08);
}

.floating-btn--chatbot {
    background: var(--color-black);
    border: 1px solid var(--color-champagne);
    color: var(--color-champagne);
}

.floating-btn--chatbot:hover {
    background: rgba(203, 187, 160, 0.1);
    transform: scale(1.08);
    box-shadow: 0 0 20px rgba(203, 187, 160, 0.15);
}

@media (max-width: 768px) {
    .floating-actions { bottom: 1rem; }
    .floating-actions--left { left: 1rem; }
    .floating-actions--right { right: 1rem; }
    .floating-btn { width: 42px; height: 42px; }
}

/* ═══════════════════════════════════════════════════════ */
/* CHATBOT PANEL                                           */
/* ═══════════════════════════════════════════════════════ */

.chatbot-panel {
    position: fixed;
    bottom: 5.5rem;
    right: 1.5rem;
    z-index: 1600;
    width: 340px;
    max-height: 480px;
    background: var(--color-black);
    border: 1px solid rgba(203, 187, 160, 0.2);
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.4), 0 0 30px rgba(203, 187, 160, 0.05);
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: all var(--transition-base);
    overflow: hidden;
}

.chatbot-panel.is-open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.chatbot-panel__header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.chatbot-panel__avatar {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--color-champagne);
    border-radius: 50%;
    color: var(--color-champagne);
}

.chatbot-panel__close {
    background: none;
    border: none;
    color: var(--color-grey);
    font-size: 1.25rem;
    cursor: pointer;
    padding: 0.25rem;
}

.chatbot-panel__close:hover { color: var(--color-white); }

.chatbot-panel__actions {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.chatbot-quick-btn {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--color-white);
    padding: 0.75rem 1rem;
    text-align: left;
    cursor: pointer;
    font-family: var(--font-body);
    font-size: 0.8125rem;
    transition: all var(--transition-fast);
}

.chatbot-quick-btn:hover {
    border-color: var(--color-champagne);
    background: rgba(203, 187, 160, 0.08);
}

.chatbot-quick-btn__icon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    color: var(--color-champagne);
}

.chatbot-quick-btn__icon svg { width: 100%; height: 100%; }

.chatbot-panel__input {
    padding: 0.75rem 1rem 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.chatbot-panel__input input {
    width: 100%;
    padding: 0.625rem 0.875rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--color-grey);
    font-family: var(--font-body);
    font-size: 0.8125rem;
}

@media (max-width: 768px) {
    .chatbot-panel {
        right: 0.5rem;
        left: 0.5rem;
        width: auto;
        bottom: 4.5rem;
    }
}

/* ═══════════════════════════════════════════════════════ */
/* FUN FACT TOAST                                          */
/* ═══════════════════════════════════════════════════════ */

.toast {
    position: fixed;
    bottom: 1.5rem;
    left: 5rem;
    z-index: 1400;
    max-width: 360px;
    background: var(--color-black);
    color: var(--color-white);
    padding: 1rem 2.5rem 1rem 1.25rem;
    border-left: 3px solid var(--color-champagne);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3);
    opacity: 0;
    visibility: hidden;
    transform: translateX(-20px);
    transition: all var(--transition-base);
}

.toast.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
}

.toast__close {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    background: none;
    border: none;
    color: var(--color-grey);
    font-size: 1rem;
    cursor: pointer;
    padding: 0.25rem;
}

.toast__close:hover { color: var(--color-white); }

.toast__label {
    font-family: var(--font-heading);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-champagne);
    margin-bottom: 0.375rem;
}

.toast__text {
    font-size: 0.8125rem;
    line-height: 1.5;
    color: var(--color-grey);
    margin: 0;
}

@media (max-width: 768px) {
    .toast { left: 1rem; right: 1rem; max-width: none; bottom: 5rem; }
}

/* ═══════════════════════════════════════════════════════ */
/* CALCULATOR TABS (Services page)                         */
/* ═══════════════════════════════════════════════════════ */

.calc-tabs {
    display: flex;
    gap: 0;
    margin-bottom: var(--space-lg);
    border-bottom: 2px solid var(--color-grey-light);
}

.calc-tab {
    flex: 1;
    padding: 0.875rem 1rem;
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-align: center;
    background: none;
    border: none;
    color: var(--color-grey);
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all var(--transition-fast);
}

.calc-tab--active {
    color: var(--color-black);
    border-bottom-color: var(--color-champagne);
}

.calc-tab:hover:not(.calc-tab--active) {
    color: var(--color-grey-dark);
}

.calc-panel { padding: var(--space-lg) 0; }

/* ═══════════════════════════════════════════════════════ */
/* SERVICE PREVIEW CARDS (image-backed, homepage)          */
/* ═══════════════════════════════════════════════════════ */

.service-preview-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
}

.service-preview-card {
    position: relative;
    aspect-ratio: 4/5;
    overflow: hidden;
    display: block;
    text-decoration: none;
    color: var(--color-white);
}

.service-preview-card__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transition: transform var(--transition-slow);
}

.service-preview-card:hover .service-preview-card__bg {
    transform: scale(1.06);
}

.service-preview-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.2) 50%, transparent 100%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: var(--space-lg);
}

.service-preview-card__title {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
    color: var(--color-white);
}

.service-preview-card__text {
    font-size: 0.875rem;
    color: var(--color-grey);
    line-height: 1.5;
    margin: 0;
}

@media (max-width: 768px) {
    .service-preview-grid { grid-template-columns: 1fr; }
    .service-preview-card { aspect-ratio: 16/9; }
}

/* ═══════════════════════════════════════════════════════ */
/* LISTINGS PLACEHOLDER CARDS                              */
/* ═══════════════════════════════════════════════════════ */

.listing-card {
    background: var(--color-white);
    border: 1px solid var(--color-grey-light);
    overflow: hidden;
    transition: all var(--transition-base);
}

.listing-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

.listing-card__image {
    aspect-ratio: 16/10;
    background: var(--color-grey-light);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-grey);
    font-size: 0.75rem;
}

.listing-card__content {
    padding: var(--space-md);
}

.listing-card__price {
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-black);
    margin-bottom: 0.25rem;
}

.listing-card__address {
    font-size: 0.875rem;
    color: var(--color-grey-dark);
    margin-bottom: 0.75rem;
}

.listing-card__specs {
    display: flex;
    gap: var(--space-sm);
    font-size: 0.75rem;
    color: var(--color-grey);
}

.listing-card__spec {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.listing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--space-md);
}

/* ═══════════════════════════════════════════════════════ */
/* MILESTONES TIMELINE (About page)                        */
/* ═══════════════════════════════════════════════════════ */

.milestones {
    position: relative;
    padding-left: 2rem;
}

.milestones::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 1px;
    background: var(--color-champagne-light);
}

.milestone {
    position: relative;
    padding-bottom: var(--space-xl);
    padding-left: var(--space-lg);
}

.milestone::before {
    content: '';
    position: absolute;
    left: -2rem;
    top: 0.25rem;
    width: 10px;
    height: 10px;
    background: var(--color-champagne);
    border-radius: 50%;
    transform: translateX(-50%);
    margin-left: 0.5px;
}

.milestone__year {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-champagne-dark);
    margin-bottom: 0.375rem;
}

.milestone h4 {
    font-size: 1.0625rem;
    margin-bottom: 0.375rem;
}

.milestone p {
    font-size: 0.9375rem;
    color: var(--color-grey-dark);
    line-height: 1.6;
}

.milestone:last-child { padding-bottom: 0; }

/* Active area card */
.area-card--active {
    box-shadow: 0 0 0 2px var(--color-champagne);
}

/* ═══════════════════════════════════════════════════════ */
/* TEAM PAGE                                               */
/* ═══════════════════════════════════════════════════════ */

/* ── Hero ───────────────────────────────────────────────── */
.team-hero {
    position: relative;
    min-height: 92vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-xl) 0 var(--space-lg);
    background: var(--color-black);
    overflow: hidden;
    color: var(--color-white);
}

.team-hero__bg {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 25% 30%, rgba(203, 187, 160, 0.18) 0%, transparent 55%),
        radial-gradient(ellipse at 75% 75%, rgba(232, 223, 209, 0.10) 0%, transparent 60%),
        linear-gradient(180deg, #050505 0%, #0F0D0A 50%, #050505 100%);
    z-index: 0;
}

.team-hero__bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(circle at 20% 50%, rgba(203, 187, 160, 0.06) 0, transparent 1px),
        radial-gradient(circle at 80% 70%, rgba(245, 235, 211, 0.05) 0, transparent 1px);
    background-size: 60px 60px, 90px 90px;
    opacity: 0.6;
    pointer-events: none;
}

.team-hero__inner {
    position: relative;
    z-index: 1;
    text-align: center;
    max-width: 920px;
}

.team-hero__title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-weight: 400;
    font-size: clamp(2.4rem, 6vw, 5.4rem);
    line-height: 1.05;
    letter-spacing: -0.5px;
    color: var(--color-white);
    margin: var(--space-md) 0 var(--space-md);
    filter:
        drop-shadow(0 0 22px rgba(245, 235, 211, 0.35))
        drop-shadow(0 0 70px rgba(203, 187, 160, 0.25));
}

.team-hero__title-em {
    font-style: italic;
    font-weight: 500;
    background: linear-gradient(180deg, #F5EBD3 0%, var(--color-champagne) 50%, #A89878 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.team-hero__lede {
    font-family: var(--font-body);
    font-size: clamp(0.95rem, 1.3vw, 1.125rem);
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.78);
    max-width: 640px;
    margin: 0 auto var(--space-xl);
}

.team-hero__stats {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: clamp(1rem, 3vw, 2.4rem);
    margin: var(--space-lg) auto var(--space-xl);
    max-width: 760px;
}

.team-hero__stat {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    align-items: center;
}

.team-hero__stat-num {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-weight: 500;
    font-size: clamp(2rem, 3.6vw, 3rem);
    line-height: 1;
    color: var(--color-champagne);
    text-shadow: 0 0 18px rgba(203, 187, 160, 0.35);
}

.team-hero__stat-label {
    font-family: var(--font-body);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: rgba(255, 255, 255, 0.55);
}

.team-hero__stat-divider {
    width: 1px;
    height: 36px;
    background: linear-gradient(180deg, transparent, rgba(203, 187, 160, 0.4), transparent);
}

.team-hero__scroll-cue {
    margin-top: var(--space-xl);
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 0.6rem;
}

.team-hero__scroll-line {
    width: 1px;
    height: 48px;
    background: linear-gradient(180deg, transparent, rgba(203, 187, 160, 0.6));
    position: relative;
    overflow: hidden;
}

.team-hero__scroll-line::after {
    content: '';
    position: absolute;
    top: -100%;
    left: 0;
    width: 100%;
    height: 60%;
    background: linear-gradient(180deg, transparent, var(--color-champagne));
    animation: team-scroll-line 2.4s ease-in-out infinite;
}

@keyframes team-scroll-line {
    0%   { top: -100%; }
    100% { top: 100%; }
}

.team-hero__scroll-text {
    font-family: var(--font-body);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 2.4px;
    color: rgba(203, 187, 160, 0.65);
}

@media (prefers-reduced-motion: reduce) {
    .team-hero__scroll-line::after { animation: none; }
}

/* ── Section heading ───────────────────────────────────── */
.team-section {
    padding: clamp(4rem, 9vw, 7rem) 0;
    position: relative;
    background: var(--color-black);
    color: var(--color-white);
}

.team-section + .team-section {
    border-top: 1px solid rgba(203, 187, 160, 0.06);
}

.team-section__header {
    text-align: center;
    max-width: 700px;
    margin: 0 auto clamp(2.5rem, 5vw, 4rem);
}

.team-section__eyebrow {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--color-champagne);
    margin: 0 0 0.75rem;
}

.team-section__title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-weight: 500;
    font-size: clamp(2rem, 4.4vw, 3.4rem);
    line-height: 1.1;
    color: var(--color-white);
    margin: 0;
    letter-spacing: 0.3px;
    filter:
        drop-shadow(0 0 14px rgba(245, 235, 211, 0.28))
        drop-shadow(0 0 40px rgba(203, 187, 160, 0.22));
}

.team-section__title em {
    font-style: italic;
    background: linear-gradient(180deg, #F5EBD3 0%, var(--color-champagne) 50%, #A89878 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.team-section__rule {
    width: 60px;
    height: 1px;
    margin: 1.25rem auto;
    background: linear-gradient(90deg, transparent, var(--color-champagne), transparent);
}

.team-section__subtitle {
    font-family: var(--font-body);
    font-size: 0.95rem;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.7);
    margin: 0;
}

/* ── Leadership row (full-bleed cards, larger) ─────────── */
.team-leadership-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(1.25rem, 3vw, 2.4rem);
    max-width: 1100px;
    margin: 0 auto;
}

.team-leader {
    appearance: none;
    -webkit-appearance: none;
    display: grid;
    grid-template-rows: auto 1fr;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(203, 187, 160, 0.15);
    color: inherit;
    padding: 0;
    cursor: pointer;
    text-align: left;
    font: inherit;
    overflow: hidden;
    transition: transform var(--transition-base),
                border-color var(--transition-base),
                box-shadow var(--transition-base);
    position: relative;
}

.team-leader::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 50% 0%, rgba(203, 187, 160, 0.10), transparent 65%);
    opacity: 0;
    transition: opacity 0.5s ease;
    pointer-events: none;
}

.team-leader:hover {
    transform: translateY(-6px);
    border-color: rgba(203, 187, 160, 0.45);
    box-shadow:
        0 30px 60px rgba(0, 0, 0, 0.55),
        0 0 80px rgba(203, 187, 160, 0.12);
}

.team-leader:hover::before { opacity: 1; }

.team-leader__photo {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    background: #1a1a1a;
    position: relative;
    line-height: 0;
}

.team-leader__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: transform 0.9s cubic-bezier(0.2, 0.8, 0.2, 1);
    display: block;
}

.team-leader:hover .team-leader__photo img {
    transform: scale(1.05);
}

.team-leader__view-pill {
    position: absolute;
    top: var(--space-md);
    right: var(--space-md);
    padding: 0.4rem 0.85rem;
    background: rgba(0, 0, 0, 0.65);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border: 1px solid rgba(203, 187, 160, 0.4);
    color: var(--color-champagne-light);
    font-family: var(--font-body);
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 1.8px;
    border-radius: 999px;
    opacity: 0;
    transform: translateY(-6px);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.team-leader:hover .team-leader__view-pill,
.team-leader:focus-visible .team-leader__view-pill {
    opacity: 1;
    transform: translateY(0);
}

.team-leader__info {
    padding: clamp(1.25rem, 2.4vw, 2rem);
    position: relative;
    z-index: 1;
}

.team-leader__role {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 2.4px;
    color: var(--color-champagne);
    margin: 0 0 0.4rem;
}

.team-leader__name {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-weight: 500;
    font-size: clamp(1.6rem, 2.6vw, 2.2rem);
    line-height: 1.1;
    color: var(--color-white);
    margin: 0 0 0.85rem;
}

.team-leader__short {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-size: 1.0625rem;
    color: rgba(255, 255, 255, 0.7);
    margin: 0 0 var(--space-md);
    line-height: 1.5;
}

.team-leader__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-champagne);
    border-bottom: 1px solid transparent;
    padding-bottom: 2px;
    transition: border-color var(--transition-base), gap var(--transition-base);
}

.team-leader:hover .team-leader__cta {
    border-color: var(--color-champagne);
    gap: 0.85rem;
}

.team-leader__cta-icon svg {
    width: 18px;
    height: 18px;
}

@media (max-width: 720px) {
    .team-leadership-grid { grid-template-columns: 1fr; }
}

/* ── Standard team grid ────────────────────────────────── */
.team-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: clamp(1rem, 2vw, 1.6rem);
    max-width: 1280px;
    margin: 0 auto;
}

.team-card {
    appearance: none;
    -webkit-appearance: none;
    display: flex;
    flex-direction: column;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(203, 187, 160, 0.13);
    color: inherit;
    padding: 0;
    cursor: pointer;
    text-align: center;
    font: inherit;
    overflow: hidden;
    transition: transform var(--transition-base),
                border-color var(--transition-base),
                box-shadow var(--transition-base);
    position: relative;
}

.team-card:hover {
    transform: translateY(-5px);
    border-color: rgba(203, 187, 160, 0.4);
    box-shadow:
        0 22px 50px rgba(0, 0, 0, 0.5),
        0 0 50px rgba(203, 187, 160, 0.1);
}

.team-card__photo {
    aspect-ratio: 4 / 5;
    flex: 0 0 auto;
    overflow: hidden;
    background: #1a1a1a;
    position: relative;
    line-height: 0;
}

.team-card__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: transform 0.7s cubic-bezier(0.2, 0.8, 0.2, 1), filter 0.7s ease;
    display: block;
}

.team-card:hover .team-card__photo img {
    transform: scale(1.06);
    filter: brightness(1.05);
}

.team-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 0%, transparent 60%, rgba(0, 0, 0, 0.85));
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: var(--space-md);
    opacity: 0;
    transition: opacity 0.4s ease;
    pointer-events: none;
}

.team-card:hover .team-card__overlay,
.team-card:focus-visible .team-card__overlay { opacity: 1; }

.team-card__overlay-text {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 2.5px;
    color: var(--color-champagne-light);
    padding: 0.5rem 1rem;
    border: 1px solid rgba(203, 187, 160, 0.6);
    border-radius: 999px;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    background: rgba(0, 0, 0, 0.4);
}

.team-card__info {
    flex: 1 1 auto;
    padding: var(--space-md) var(--space-md) var(--space-lg);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    min-height: 9rem;
}

.team-card__name {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-weight: 500;
    font-size: 1.4rem;
    color: var(--color-white);
    margin: 0 0 0.3rem;
    line-height: 1.15;
}

.team-card__role {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1.6px;
    color: var(--color-champagne);
    margin: 0 0 0.6rem;
    line-height: 1.4;
    min-height: calc(0.7rem * 1.4 * 2);
    display: flex;
    align-items: flex-start;
    justify-content: center;
}

.team-card__spec {
    font-family: var(--font-body);
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.55);
    margin: 0;
    line-height: 1.45;
}

.team-card:focus-visible {
    outline: 2px solid var(--color-champagne);
    outline-offset: 3px;
}

@media (max-width: 480px) {
    .team-grid { grid-template-columns: repeat(2, 1fr); gap: 0.75rem; }
    .team-card__name { font-size: 1.15rem; }
    .team-card__info { padding: var(--space-sm) var(--space-sm) var(--space-md); min-height: 7rem; }
}

/* ── Closing "Join Us" panel ───────────────────────────── */
.team-join {
    padding: clamp(4rem, 8vw, 6.5rem) 0;
    background: linear-gradient(180deg, var(--color-black) 0%, #0E0C09 100%);
    border-top: 1px solid rgba(203, 187, 160, 0.10);
    position: relative;
    overflow: hidden;
}

.team-join::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 50% 0%, rgba(203, 187, 160, 0.08), transparent 60%);
    pointer-events: none;
}

.team-join__inner {
    position: relative;
    text-align: center;
    max-width: 680px;
    margin: 0 auto;
}

.team-join__eyebrow {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--color-champagne);
    margin: 0 0 0.8rem;
}

.team-join__title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-weight: 500;
    font-size: clamp(1.8rem, 3.6vw, 2.8rem);
    color: var(--color-white);
    margin: 0 0 var(--space-md);
    line-height: 1.2;
    filter: drop-shadow(0 0 18px rgba(203, 187, 160, 0.2));
}

.team-join__title em {
    background: linear-gradient(180deg, #F5EBD3 0%, var(--color-champagne) 60%, #A89878 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.team-join__text {
    font-family: var(--font-body);
    font-size: 1rem;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.72);
    margin: 0 auto var(--space-lg);
    max-width: 540px;
}

/* ── Office head solo card (Kyla) ──────────────────────── */
.team-office-head-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    max-width: 520px;
    margin: 0 auto clamp(2.5rem, 5vw, 3.75rem);
}

.team-leader--solo .team-leader__photo {
    aspect-ratio: 4 / 4.6;
}

.team-leader--solo .team-leader__monogram {
    font-size: clamp(5rem, 11vw, 8rem);
}

@media (min-width: 720px) {
    .team-office-head-grid {
        max-width: 480px;
    }
}

/* ── Office admin 3-up grid (6 admin staff) ────────────── */
@media (min-width: 720px) {
    .team-grid--three-up {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        max-width: 1080px;
    }
}

/* ── Office compliance 2-up grid (Alfred + Stefan) ─────── */
@media (min-width: 600px) {
    .team-grid--two-up {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: 720px;
    }
}

/* ── Sales & Rentals 5-up row (Madre, Morne, Rita, Jean, Kim) ─────── */
/* Desktop shows all five practitioners in one clean row; steps down to
   3-up on small laptops/tablets, then the base grid handles smaller widths. */
@media (min-width: 760px) and (max-width: 1099px) {
    .team-grid--five-up {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
@media (min-width: 1100px) {
    .team-grid--five-up {
        grid-template-columns: repeat(5, minmax(0, 1fr));
        max-width: 1320px;
    }
}

/* ── Office sub-section header (Compliance & Maintenance) ─ */
.team-section__subheader {
    margin: clamp(2.5rem, 5vw, 3.75rem) auto clamp(1.5rem, 3vw, 2.25rem);
    text-align: center;
    max-width: 720px;
}

.team-section__subeyebrow {
    font-family: var(--font-body);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 4px;
    color: var(--color-champagne);
    margin: 0 0 0.85rem;
    font-weight: 500;
}

.team-section__subrule {
    width: 56px;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--color-champagne), transparent);
    margin: 0 auto;
}

/* ── Placeholder team cards (office staff, photos pending) ─ */
.team-card__photo--placeholder,
.team-leader__photo--placeholder {
    background:
        radial-gradient(ellipse at 50% 30%, rgba(203, 187, 160, 0.10), transparent 60%),
        linear-gradient(135deg, #1a1612 0%, #0a0908 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.team-card__photo--placeholder img,
.team-leader__photo--placeholder img {
    display: none;
}

.team-card__photo--placeholder::after,
.team-leader__photo--placeholder::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 55%, rgba(0, 0, 0, 0.45));
    pointer-events: none;
}

.team-card__monogram,
.team-leader__monogram {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-weight: 500;
    font-style: italic;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
    background: linear-gradient(180deg, #F5EBD3 0%, var(--color-champagne) 55%, #8E7E60 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    filter: drop-shadow(0 0 28px rgba(203, 187, 160, 0.18));
    position: relative;
    z-index: 1;
}

.team-card__monogram {
    font-size: clamp(2.75rem, 6vw, 4rem);
}

.team-leader__monogram {
    font-size: clamp(4.5rem, 9vw, 7rem);
}

.team-card--placeholder .team-card__photo {
    aspect-ratio: 4 / 5;
}

.team-card--placeholder:hover .team-card__photo--placeholder {
    background:
        radial-gradient(ellipse at 50% 30%, rgba(203, 187, 160, 0.18), transparent 60%),
        linear-gradient(135deg, #221c16 0%, #0d0b09 100%);
}

.team-card--placeholder:hover .team-card__monogram {
    transform: scale(1.04);
    transition: transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* ── Office section: compliance & maintenance contact strip ─ */
.team-section__compliance-strip {
    max-width: 760px;
    margin: clamp(2.5rem, 4.5vw, 3.5rem) auto 0;
    padding: clamp(1.5rem, 2.5vw, 2rem) clamp(1.5rem, 3vw, 2.5rem);
    background:
        linear-gradient(180deg, rgba(203, 187, 160, 0.06) 0%, rgba(203, 187, 160, 0.02) 100%);
    border-left: 2px solid var(--color-champagne);
    border-radius: 0 4px 4px 0;
    text-align: left;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: clamp(1.25rem, 3vw, 2rem);
    align-items: center;
}

.team-section__compliance-label {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 2.5px;
    color: var(--color-champagne);
    margin: 0 0 0.5rem;
    grid-column: 1;
}

.team-section__compliance-lede {
    font-family: var(--font-body);
    font-size: 0.9rem;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.68);
    margin: 0;
    grid-column: 1;
    grid-row: 2;
    max-width: 460px;
}

.team-section__compliance-strip .btn--ghost {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: center;
}

@media (max-width: 640px) {
    .team-section__compliance-strip {
        grid-template-columns: 1fr;
        text-align: center;
    }
    .team-section__compliance-lede { max-width: none; margin: 0 0 1rem; }
    .team-section__compliance-strip .btn--ghost {
        grid-column: 1;
        grid-row: auto;
        justify-self: center;
    }
}

/* ── Office section contact footer ─────────────────────── */
.team-section__contact-footer {
    max-width: 760px;
    margin: clamp(2.75rem, 5vw, 4rem) auto 0;
    padding: clamp(1.75rem, 3vw, 2.5rem) clamp(1.5rem, 3vw, 2.75rem);
    background:
        radial-gradient(ellipse at 50% 0%, rgba(203, 187, 160, 0.10), transparent 70%),
        rgba(255, 255, 255, 0.025);
    border: 1px solid rgba(203, 187, 160, 0.20);
    border-radius: 6px;
    text-align: center;
}

.team-section__contact-label {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--color-champagne);
    margin: 0 0 0.85rem;
}

.team-section__contact-lede {
    font-family: var(--font-body);
    font-size: 0.95rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.72);
    margin: 0 auto 1.75rem;
    max-width: 560px;
}

.team-section__contact-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.85rem 1rem;
}

.btn--ghost {
    appearance: none;
    background: transparent;
    color: var(--color-champagne);
    border: 1px solid rgba(203, 187, 160, 0.55);
    padding: 0.85rem 1.6rem;
    font-family: var(--font-body);
    font-size: 0.85rem;
    text-decoration: none;
    text-transform: none;
    letter-spacing: 0.02em;
    transition:
        background var(--transition-base),
        color var(--transition-base),
        border-color var(--transition-base),
        transform var(--transition-base);
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 0.2rem;
    cursor: pointer;
}

.btn--ghost .btn__label {
    font-weight: 500;
    font-size: 0.9rem;
    letter-spacing: 0.03em;
}

.btn--ghost .btn__sub {
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: rgba(203, 187, 160, 0.7);
}

.btn--ghost:hover {
    background: var(--color-champagne);
    color: var(--color-black);
    border-color: var(--color-champagne);
    transform: translateY(-2px);
}

.btn--ghost:hover .btn__sub {
    color: rgba(0, 0, 0, 0.6);
}

@media (max-width: 480px) {
    .team-section__contact-actions {
        flex-direction: column;
        align-items: stretch;
    }
    .btn--ghost {
        padding: 0.85rem 1.25rem;
    }
}

/* === Listings === */

/* Filter bar */
.listings-filters {
    background: #faf8f4;
    border: 1px solid rgba(203, 187, 160, 0.35);
    padding: var(--space-md);
    margin-bottom: var(--space-lg);
}
.listings-filters__tabs {
    display: flex;
    gap: 0;
    margin-bottom: var(--space-md);
    border-bottom: 1px solid rgba(203, 187, 160, 0.35);
}
.listings-filter-tab {
    padding: 0.75rem 1.25rem;
    font-family: var(--font-display);
    font-size: 0.875rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--color-grey-dark);
    border-bottom: 2px solid transparent;
    transition: color 0.2s ease, border-color 0.2s ease;
    text-decoration: none;
}
.listings-filter-tab:hover {
    color: var(--color-black);
}
.listings-filter-tab.is-active {
    color: var(--color-black);
    border-bottom-color: var(--color-champagne);
}
.listings-filters__row {
    display: grid;
    grid-template-columns: repeat(4, 1fr) auto auto;
    gap: 0.75rem;
    align-items: end;
}
.listings-filter-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0; /* allow grid track to shrink below select content width */
}
.listings-filter-field span {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--color-grey-dark);
}
.listings-filter-field select,
.listings-filter-field input {
    padding: 0.6rem 0.75rem;
    border: 1px solid rgba(0, 0, 0, 0.15);
    background: #fff;
    font-family: var(--font-body);
    font-size: 0.9rem;
    color: var(--color-black);
}
.listings-filter-field select:focus,
.listings-filter-field input:focus {
    outline: none;
    border-color: var(--color-champagne);
}
.listings-filter-submit {
    padding: 0.6rem 1.5rem;
}
.listings-filter-reset {
    font-size: 0.8rem;
    color: var(--color-grey-dark);
    text-decoration: underline;
    align-self: center;
    padding: 0 0.5rem;
}

@media (max-width: 768px) {
    .listings-filters__row {
        grid-template-columns: 1fr; /* stack filters; prevents 122px h-overflow at 375px */
    }
    .listings-filter-field select,
    .listings-filter-field input {
        width: 100%;
        max-width: 100%;
    }
    .listings-filter-submit {
        grid-column: auto;
        width: 100%;
    }
    .listings-filter-reset {
        align-self: start;
    }
}

/* Listings grid */
.listings-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
}
@media (max-width: 1024px) {
    .listings-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .listings-grid { grid-template-columns: 1fr; }
}

/* Listing card */
.listing-card {
    background: #fff;
    border: 1px solid rgba(203, 187, 160, 0.25);
    overflow: hidden;
    transition: transform 0.4s cubic-bezier(.2,.8,.2,1), box-shadow 0.4s ease, border-color 0.4s ease;
    position: relative;
}
.listing-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.06), 0 24px 48px -16px rgba(168, 152, 120, 0.28);
    border-color: rgba(203, 187, 160, 0.6);
}
.listing-card__link {
    display: block;
    color: var(--color-black);
    text-decoration: none;
}
.listing-card__media {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: #f5f3f0;
}
.listing-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(.2,.8,.2,1);
}
.listing-card:hover .listing-card__media img {
    transform: scale(1.04);
}
.listing-card__type {
    position: absolute;
    top: 12px;
    left: 12px;
    padding: 4px 10px;
    background: var(--color-champagne);
    color: var(--color-black);
    font-family: var(--font-display);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}
.listing-card__status {
    position: absolute;
    top: 12px;
    right: 12px;
    padding: 4px 10px;
    background: var(--color-black);
    color: #fff;
    font-family: var(--font-display);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}
.listing-card__status.is-sold,
.listing-card__status.is-rented {
    background: #c0392b;
}
.listing-card__body {
    padding: 1rem 1.25rem 1.25rem;
}
.listing-card__price {
    font-family: var(--font-display);
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--color-black);
    margin-bottom: 0.4rem;
    letter-spacing: -0.3px;
}
.listing-price__period {
    font-size: 0.8rem;
    font-weight: 400;
    color: var(--color-grey-dark);
}
.listing-card__title {
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--color-black);
    margin: 0 0 0.25rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.listing-card__address {
    font-size: 0.85rem;
    color: var(--color-grey-dark);
    margin: 0 0 0.75rem;
}
.listing-card__stats {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    gap: 1rem;
    font-size: 0.85rem;
    color: var(--color-grey-dark);
    border-top: 1px solid rgba(203, 187, 160, 0.25);
    padding-top: 0.75rem;
}
.listing-card__stats strong {
    color: var(--color-black);
    font-weight: 600;
    margin-right: 0.2rem;
}

/* Pagination */
.listings-pagination {
    display: flex;
    justify-content: center;
    gap: 0.4rem;
    margin: var(--space-lg) 0;
}
.listings-pagination .page-numbers {
    padding: 0.5rem 0.85rem;
    border: 1px solid rgba(0, 0, 0, 0.1);
    color: var(--color-grey-dark);
    text-decoration: none;
    font-size: 0.9rem;
    transition: all 0.2s ease;
}
.listings-pagination .page-numbers:hover {
    border-color: var(--color-champagne);
    color: var(--color-black);
}
.listings-pagination .page-numbers.current {
    background: var(--color-black);
    color: var(--color-champagne);
    border-color: var(--color-black);
}

/* Empty state */
.listings-empty {
    text-align: center;
    padding: var(--space-xl) var(--space-md);
    background: #faf8f4;
    border: 1px dashed rgba(203, 187, 160, 0.4);
}
.listings-empty h3 {
    margin-bottom: 0.75rem;
}
.listings-empty p {
    color: var(--color-grey-dark);
    margin-bottom: var(--space-md);
}
.listings-empty .btn {
    margin: 0 0.4rem;
}

/* P24 supplementary block */
.listings-p24-supplementary {
    margin-top: var(--space-xl);
    padding: var(--space-lg);
    background: #f5f3f0;
    border: 1px solid rgba(203, 187, 160, 0.2);
    text-align: center;
}
.listings-p24-supplementary p {
    font-size: 0.95rem;
    color: var(--color-grey-dark);
    margin: 0.5rem 0 1rem;
}
.btn--small {
    padding: 0.5rem 1.25rem;
    font-size: 0.85rem;
}
.listings-p24-supplementary__disclaimer {
    font-size: 0.75rem !important;
    margin-top: 0.75rem !important;
    color: rgba(89, 89, 89, 0.7) !important;
}

/* === Single Listing === */
/* Push listing content below the fixed header so the breadcrumb does not sit
   under it. Scoped to article.single-listing (NOT .single-listing, which also
   matches the body class) to avoid doubling the offset. */
article.single-listing {
    padding-top: var(--nav-height);
}
/* Listing pages have no dark hero behind the header, so a transparent header
   reads as invisible/overlapping over the light content. Keep it solid here. */
body.single-listing .site-header.site-header--transparent {
    background: rgba(0, 0, 0, 0.95);
    backdrop-filter: blur(10px);
    box-shadow: var(--shadow-md);
}
.listing-breadcrumb {
    padding: var(--space-md) 0 var(--space-sm);
    font-size: 0.85rem;
    color: var(--color-grey-dark);
}
.listing-breadcrumb a {
    color: var(--color-grey-dark);
    text-decoration: none;
    transition: color 0.2s ease;
}
.listing-breadcrumb a:hover {
    color: var(--color-black);
}
.listing-breadcrumb span { margin: 0 0.4rem; }
.listing-breadcrumb .is-current {
    color: var(--color-black);
    margin: 0;
    margin-left: 0.4rem;
}

.listing-hero {
    padding-bottom: var(--space-md);
}
.listing-hero__main {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: #000;
    cursor: pointer;
}
.listing-hero__main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.listing-hero__type,
.listing-hero__status {
    position: absolute;
    top: 16px;
    padding: 6px 14px;
    font-family: var(--font-display);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}
.listing-hero__type {
    left: 16px;
    background: var(--color-champagne);
    color: var(--color-black);
}
.listing-hero__status {
    right: 16px;
    background: var(--color-black);
    color: #fff;
}
.listing-hero__status.is-sold,
.listing-hero__status.is-rented { background: #c0392b; }
.listing-hero__gallery-btn {
    position: absolute;
    bottom: 16px;
    right: 16px;
    padding: 0.6rem 1rem;
    background: rgba(0, 0, 0, 0.75);
    color: #fff;
    border: 0;
    cursor: pointer;
    font-family: var(--font-body);
    font-size: 0.85rem;
}
.listing-hero__gallery-btn:hover { background: var(--color-black); }
.listing-hero__thumbs {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 6px;
    margin-top: 6px;
}
.listing-hero__thumb {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border: 0;
    padding: 0;
    cursor: pointer;
    background: #f5f3f0;
    opacity: 0.7;
    transition: opacity 0.3s ease;
}
.listing-hero__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.listing-hero__thumb.is-active,
.listing-hero__thumb:hover {
    opacity: 1;
}
@media (max-width: 768px) {
    .listing-hero__thumbs { grid-template-columns: repeat(3, 1fr); }
}

.listing-body {
    padding-top: var(--space-md);
}
.listing-body__grid {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: var(--space-lg);
}
@media (max-width: 1024px) {
    .listing-body__grid { grid-template-columns: 1fr; }
}

.listing-header {
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid rgba(203, 187, 160, 0.3);
}
.listing-header__price {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 600;
    color: var(--color-black);
    margin-bottom: 0.5rem;
}
.listing-header h1 {
    font-size: 1.5rem;
    margin: 0 0 0.4rem;
    line-height: 1.3;
}
.listing-header__address {
    color: var(--color-grey-dark);
    margin: 0 0 var(--space-md);
    font-size: 1rem;
}
.listing-header__stats {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    font-size: 0.95rem;
    color: var(--color-grey-dark);
}
.listing-header__stats strong {
    color: var(--color-black);
    font-weight: 600;
    margin-right: 0.3rem;
}

.listing-description h2,
.listing-features h2,
.listing-extras h2 {
    font-size: 1.15rem;
    margin: var(--space-lg) 0 var(--space-md);
    letter-spacing: -0.2px;
}
.listing-description p {
    line-height: 1.75;
    color: #333;
    margin-bottom: 1rem;
}

.listing-features__grid {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem 1rem;
}
.listing-features__grid li {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.95rem;
}
.listing-features__tick {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    background: var(--color-champagne);
    color: var(--color-black);
    border-radius: 50%;
    font-weight: 700;
    font-size: 0.85rem;
}
@media (max-width: 600px) {
    .listing-features__grid { grid-template-columns: 1fr 1fr; }
}

.listing-extras__list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.listing-extras__list li {
    display: flex;
    justify-content: space-between;
    padding: 0.6rem 0;
    border-bottom: 1px dashed rgba(203, 187, 160, 0.3);
}
.listing-extras__list span { color: var(--color-grey-dark); }

.listing-disclaimer {
    margin-top: var(--space-lg);
    font-size: 0.75rem;
    color: var(--color-grey-dark);
    border-top: 1px solid rgba(203, 187, 160, 0.25);
    padding-top: 0.75rem;
}

/* Sidebar agent + form */
.listing-body__sidebar {
    position: sticky;
    top: 100px;
    align-self: start;
}
@media (max-width: 1024px) {
    .listing-body__sidebar { position: static; }
}

.listing-agent-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    background: var(--color-black);
    color: #fff;
    padding: 1rem 1.25rem;
}
.listing-agent-card__photo {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
}
.listing-agent-card__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 22%;
}
.listing-agent-card__role {
    margin: 0;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--color-champagne);
}
.listing-agent-card__name {
    margin: 0.2rem 0 0.3rem;
    font-size: 1.1rem;
    color: #fff;
}
.listing-agent-card__trust {
    margin: 0;
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.7);
}

.listing-inquiry-form {
    background: #faf8f4;
    border: 1px solid rgba(203, 187, 160, 0.35);
    border-top: 0;
    padding: 1.25rem;
}
.listing-inquiry-form h3 {
    font-size: 1.05rem;
    margin: 0 0 1rem;
}
.listing-inquiry-form label {
    display: block;
    margin-bottom: 0.85rem;
}
.listing-inquiry-form label > span {
    display: block;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--color-grey-dark);
    margin-bottom: 4px;
}
.listing-inquiry-form input[type="text"],
.listing-inquiry-form input[type="email"],
.listing-inquiry-form input[type="tel"],
.listing-inquiry-form textarea {
    width: 100%;
    padding: 0.6rem 0.75rem;
    border: 1px solid rgba(0, 0, 0, 0.15);
    background: #fff;
    font-family: var(--font-body);
    font-size: 0.9rem;
    box-sizing: border-box;
}
.listing-inquiry-form input:focus,
.listing-inquiry-form textarea:focus {
    outline: none;
    border-color: var(--color-champagne);
}
.listing-inquiry-form__check {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.listing-inquiry-form__check input { margin: 0; }
.listing-inquiry-form .btn {
    width: 100%;
    margin-top: 0.5rem;
}
.listing-inquiry-form__note {
    font-size: 0.75rem;
    color: var(--color-grey-dark);
    margin: 0.75rem 0 0;
    text-align: center;
}

.listing-agent-card__contact {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    margin-top: 6px;
}
.listing-agent-card__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    padding: 0.7rem;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.1);
    color: var(--color-black);
    text-decoration: none;
    font-size: 0.85rem;
    transition: all 0.2s ease;
}
.listing-agent-card__btn svg {
    width: 16px;
    height: 16px;
}
.listing-agent-card__btn:hover {
    background: var(--color-champagne);
    border-color: var(--color-champagne);
}
.listing-agent-card__btn--whatsapp {
    grid-column: span 2;
    background: #25D366;
    color: #fff;
    border-color: #25D366;
}
.listing-agent-card__btn--whatsapp:hover {
    background: #1ebe5a;
    border-color: #1ebe5a;
    color: #fff;
}

/* Lightbox
   z-index 2300: must beat navbar (1000), evaluation modal (2000), and the
   testimonials overlay (2200). Earlier value (999) sat UNDER the navbar,
   which hid the close button at top-right and trapped users on the gallery.
   Floating actions (TESTIMONIALS pill, Kaja, email) are explicitly hidden
   while the gallery is open via body.has-listing-lightbox-open so they
   don't peek through the dark backdrop. */
.listing-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.95);
    z-index: 2300;
    display: flex;
    align-items: center;
    justify-content: center;
}
.listing-lightbox[hidden] {
    display: none;
}
.listing-lightbox__img {
    max-width: 90vw;
    max-height: 84vh;
    object-fit: contain;
}
.listing-lightbox__close,
.listing-lightbox__prev,
.listing-lightbox__next {
    position: absolute;
    background: rgba(0, 0, 0, 0.55);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    width: 52px;
    height: 52px;
    cursor: pointer;
    font-size: 1.6rem;
    line-height: 1;
    transition: background 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
    z-index: 2;
}
.listing-lightbox__close:hover,
.listing-lightbox__prev:hover,
.listing-lightbox__next:hover {
    background: rgba(203, 187, 160, 0.85);
    color: var(--color-black);
    border-color: var(--color-champagne);
    transform: scale(1.05);
}
.listing-lightbox__prev:hover,
.listing-lightbox__next:hover { transform: translateY(-50%) scale(1.05); }
/* Close pinned well clear of any browser chrome / safe-area */
.listing-lightbox__close { top: max(20px, env(safe-area-inset-top, 20px)); right: 20px; }
.listing-lightbox__prev  { top: 50%; left: 20px; transform: translateY(-50%); }
.listing-lightbox__next  { top: 50%; right: 20px; transform: translateY(-50%); }
.listing-lightbox__counter {
    position: absolute;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    color: rgba(255, 255, 255, 0.9);
    background: rgba(0, 0, 0, 0.45);
    border: 1px solid rgba(203, 187, 160, 0.35);
    border-radius: 999px;
    padding: 0.35rem 0.85rem;
    font-size: 0.85rem;
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
}

/* Hide site chrome + other floaters while gallery is open */
body.has-listing-lightbox-open .site-header,
body.has-listing-lightbox-open .floating-actions,
body.has-listing-lightbox-open .toast-fun-fact,
body.has-listing-lightbox-open .chatbot-panel { display: none !important; }
body.has-listing-lightbox-open { overflow: hidden; }

/* === Featured Listings (homepage) === */
.featured-listings-grid {
    display: grid;
    grid-template-columns: 1.35fr 1fr;
    gap: 1.25rem;
    align-items: stretch;
}

.featured-listings-grid__primary { display: block; }
.featured-listings-grid__primary > .featured-listing-card { width: 100%; }
.featured-listings-grid__secondary {
    display: grid;
    grid-template-rows: 1fr 1fr;
    gap: 1.25rem;
}

.featured-listing-card {
    position: relative;
    display: block;
    overflow: hidden;
    border-radius: 6px;
    text-decoration: none;
    color: #fff;
    isolation: isolate;
    background: #0a0a0a;
    box-shadow: 0 12px 32px -18px rgba(0,0,0,0.45);
    transition: transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
    will-change: transform;
}

.featured-listing-card--hero  { min-height: 560px; height: 100%; }
.featured-listing-card--small { min-height: 270px; height: 100%; }

.featured-listing-card__media {
    position: absolute; inset: 0;
    z-index: 1;
    overflow: hidden;
}

.featured-listing-card__img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 1.4s cubic-bezier(0.2, 0.8, 0.2, 1), filter 0.8s ease;
    transform: scale(1.04);
}

.featured-listing-card__shade {
    position: absolute; inset: 0;
    z-index: 2;
    background:
        linear-gradient(180deg, rgba(0,0,0,0.0) 35%, rgba(0,0,0,0.78) 100%),
        linear-gradient(180deg, rgba(0,0,0,0.20) 0%, rgba(0,0,0,0.0) 30%);
    transition: background 0.6s ease;
}

.featured-listing-card__chip {
    position: absolute;
    top: 1rem; left: 1rem;
    z-index: 4;
    display: inline-block;
    padding: 0.4rem 0.85rem;
    background: var(--color-champagne, #CBBBA0);
    color: #0a0a0a;
    font-family: var(--font-display);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    border-radius: 2px;
    box-shadow: 0 4px 14px -4px rgba(0,0,0,0.45);
}

.featured-listing-card__base {
    position: absolute;
    left: 0; right: 0; bottom: 0;
    z-index: 3;
    padding: 1.4rem 1.5rem 1.5rem;
    transition: opacity 0.4s ease, transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.featured-listing-card__price {
    font-family: var(--font-display);
    font-size: 1.45rem;
    font-weight: 600;
    color: var(--color-champagne, #CBBBA0);
    letter-spacing: 0.5px;
    text-shadow: 0 2px 12px rgba(0,0,0,0.55);
}

.featured-listing-card--hero .featured-listing-card__price { font-size: 1.85rem; }

.featured-listing-card__location {
    margin: 0.35rem 0 0;
    font-size: 0.95rem;
    color: rgba(255,255,255,0.92);
    text-shadow: 0 2px 10px rgba(0,0,0,0.6);
    letter-spacing: 0.3px;
}

.featured-listing-card__hover {
    position: absolute;
    inset: 0;
    z-index: 5;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 1.5rem 1.6rem 1.7rem;
    background: linear-gradient(180deg, rgba(10,10,10,0.30) 0%, rgba(10,10,10,0.85) 60%, rgba(10,10,10,0.96) 100%);
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 0.45s ease, transform 0.55s cubic-bezier(0.2, 0.8, 0.2, 1);
    pointer-events: none;
}

.featured-listing-card__title {
    margin: 0 0 0.55rem;
    font-family: var(--font-display);
    font-size: 1.2rem;
    font-weight: 600;
    line-height: 1.3;
    color: #fff;
    letter-spacing: 0.3px;
}

.featured-listing-card--hero .featured-listing-card__title { font-size: 1.45rem; }

.featured-listing-card__excerpt {
    margin: 0 0 0.85rem;
    font-size: 0.9rem;
    line-height: 1.6;
    color: rgba(255,255,255,0.88);
}

.featured-listing-card__stats {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1.1rem;
    font-size: 0.85rem;
    color: rgba(255,255,255,0.92);
    letter-spacing: 0.4px;
}
.featured-listing-card__stats li { display: flex; align-items: baseline; gap: 0.3rem; }
.featured-listing-card__stats strong {
    color: var(--color-champagne, #CBBBA0);
    font-weight: 600;
}

.featured-listing-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    align-self: flex-start;
    padding: 0.55rem 1rem;
    border: 1px solid rgba(203,187,160,0.65);
    color: var(--color-champagne, #CBBBA0);
    font-family: var(--font-display);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    border-radius: 2px;
    transition: background 0.35s ease, color 0.35s ease, border-color 0.35s ease;
}
.featured-listing-card__cta svg { width: 14px; height: 14px; }

/* Hover state */
@media (hover: hover) {
    .featured-listing-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 28px 60px -28px rgba(0,0,0,0.65);
    }
    .featured-listing-card:hover .featured-listing-card__img {
        transform: scale(1.10);
        filter: brightness(0.95);
    }
    .featured-listing-card:hover .featured-listing-card__base {
        opacity: 0;
        transform: translateY(12px);
    }
    .featured-listing-card:hover .featured-listing-card__hover {
        opacity: 1;
        transform: translateY(0);
    }
    .featured-listing-card:hover .featured-listing-card__cta {
        background: var(--color-champagne, #CBBBA0);
        color: #0a0a0a;
        border-color: var(--color-champagne, #CBBBA0);
    }
}

/* Focus-visible (keyboard) — same as hover */
.featured-listing-card:focus-visible {
    outline: 2px solid var(--color-champagne, #CBBBA0);
    outline-offset: 4px;
}
.featured-listing-card:focus-visible .featured-listing-card__hover {
    opacity: 1;
    transform: translateY(0);
}
.featured-listing-card:focus-visible .featured-listing-card__base {
    opacity: 0;
}

/* Reveal on scroll (paired with GSAP in scroll-animations.js) */
.reveal-up {
    opacity: 0;
    transform: translateY(30px);
}
.reveal-up.is-revealed {
    opacity: 1;
    transform: none;
}

@media (max-width: 980px) {
    .featured-listings-grid {
        grid-template-columns: 1fr;
    }
    .featured-listing-card--hero  { min-height: 420px; }
    .featured-listing-card--small { min-height: 320px; }
    .featured-listings-grid__secondary {
        grid-template-rows: auto auto;
    }
}

@media (max-width: 600px) {
    .featured-listing-card--hero  { min-height: 360px; }
    .featured-listing-card--small { min-height: 280px; }
    .featured-listing-card__hover {
        padding: 1.2rem 1.25rem 1.4rem;
    }
    .featured-listing-card__excerpt {
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
}

@media (prefers-reduced-motion: reduce) {
    .featured-listing-card,
    .featured-listing-card__img,
    .featured-listing-card__hover,
    .featured-listing-card__base { transition: none !important; }
    .featured-listing-card__img { transform: scale(1) !important; }
    .reveal-up { opacity: 1; transform: none; }
}

/* ============================================================
   Post-Troy-meeting additions (1.0.24-post-troy-meeting-20260505)
   - Hero service chips
   - Services hub grid
   - Service detail related cards
   - Form polish (select / option / focus)
   - About-page portrait sizing
   - Floating action prompt bubbles
   - Nav testimonials dropdown
   ============================================================ */

/* === Hero service chips ===
   Centred pill row, equal-width pills, tight rhythm. No inter-chip dividers
   (the previous middle-dots produced a scribbled-looking line on wrap). */
.hero__chips-label {
    margin: var(--space-md) auto 0.55rem;
    color: var(--color-champagne);
    font-family: var(--font-heading);
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 2.4px;
    text-transform: uppercase;
    opacity: 0.85;
    text-align: center;
}
.hero__service-chips {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    margin: 0 auto;
    padding: 0;
    list-style: none;
    max-width: 720px;
}
.hero__service-chips > li {
    display: flex;
    flex: 0 1 auto;
}
.hero__chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 132px;
    padding: 0.55rem 1.1rem;
    font-family: var(--font-heading);
    font-size: 0.74rem;
    font-weight: 500;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    color: var(--color-white);
    background: rgba(203, 187, 160, 0.10);
    border: 1px solid rgba(203, 187, 160, 0.36);
    border-radius: 999px;
    text-decoration: none;
    transition: background 0.25s ease, border-color 0.25s ease, transform 0.25s ease, color 0.25s ease;
    white-space: nowrap;
    line-height: 1;
}
.hero__chip:hover,
.hero__chip:focus-visible {
    background: rgba(203, 187, 160, 0.22);
    border-color: var(--color-champagne);
    color: var(--color-champagne);
    transform: translateY(-1px);
}
@media (max-width: 720px) {
    .hero__service-chips { gap: 0.5rem; max-width: 480px; }
    .hero__chip { min-width: 0; padding: 0.5rem 0.95rem; font-size: 0.7rem; letter-spacing: 1.1px; }
    .hero__chips-label { font-size: 0.65rem; letter-spacing: 2px; }
}
@media (max-width: 420px) {
    .hero__service-chips { max-width: 320px; }
}

/* === Services hub grid (page-services.php) === */
.services-hub-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
}
.services-hub-card {
    display: flex;
    flex-direction: column;
    background: var(--color-white);
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 4px;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
.services-hub-card:hover,
.services-hub-card:focus-visible {
    transform: translateY(-4px);
    box-shadow: 0 18px 40px -28px rgba(0, 0, 0, 0.35);
    border-color: rgba(203, 187, 160, 0.6);
}
.services-hub-card__image {
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--color-charcoal, #1a1a1a);
}
.services-hub-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
}
.services-hub-card:hover .services-hub-card__image img {
    transform: scale(1.04);
}
.services-hub-card__body {
    padding: var(--space-md);
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    flex-grow: 1;
}
.services-hub-card__eyebrow {
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 0.65rem;
    color: var(--color-champagne-dark);
    margin: 0;
}
.services-hub-card__title {
    margin: 0;
    font-family: var(--font-heading);
    font-size: 1.25rem;
}
.services-hub-card__intro {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.55;
    color: var(--color-grey-dark);
    flex-grow: 1;
}
.services-hub-card__cta {
    margin-top: 0.4rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-champagne-dark);
    letter-spacing: 0.5px;
}
@media (max-width: 1024px) { .services-hub-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .services-hub-grid { grid-template-columns: 1fr; } }

/* === Service detail related cards === */
.service-related-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.75rem;
}
.service-related-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.85rem 1rem;
    background: var(--color-white);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 4px;
    text-decoration: none;
    color: var(--color-black);
    font-size: 0.85rem;
    transition: border-color 0.25s ease, transform 0.25s ease, color 0.25s ease;
}
.service-related-card:hover,
.service-related-card:focus-visible {
    border-color: var(--color-champagne);
    color: var(--color-champagne-dark);
    transform: translateY(-2px);
}
.service-related-card__title { font-weight: 600; }
.service-related-card__arrow { color: var(--color-champagne); }
@media (max-width: 1024px) { .service-related-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .service-related-grid { grid-template-columns: 1fr; } }

/* === Form polish (select / option / focus) === */
.lead-form select,
.modal__form select,
.intent-selector select,
select {
    background-color: var(--color-white);
    border: 1px solid rgba(0, 0, 0, 0.14);
    color: var(--color-black);
    line-height: 1.4;
    padding: 0.55rem 0.7rem;
}
.lead-form select optgroup,
.modal__form select optgroup,
select optgroup {
    font-weight: 600;
    font-style: normal;
    color: var(--color-charcoal, #1a1a1a);
    padding: 0.25rem 0;
    background: var(--color-white);
}
.lead-form select option,
.modal__form select option,
select option {
    padding: 0.25rem 0.5rem;
    color: var(--color-black);
    background: var(--color-white);
}
.lead-form input:focus,
.lead-form select:focus,
.lead-form textarea:focus,
.modal__form input:focus,
.modal__form select:focus,
.modal__form textarea:focus {
    outline: 2px solid var(--color-champagne);
    outline-offset: 2px;
    border-color: var(--color-champagne);
}

/* === About page portrait sizing === */
.about-image--portrait img {
    max-width: 360px;
    max-height: 460px;
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: top center;
    margin: 0 auto;
    display: block;
    border-radius: 2px;
}

/* === Floating action prompt bubbles ===
   NOTE: do NOT add `position: relative` here — `.floating-actions` is already
   `position: fixed` from earlier in the cascade, which creates its own
   positioning context for the absolutely-positioned bubble below. Earlier
   I overrode that with relative, which broke fixed positioning and clumped
   both wrappers to bottom-left in document flow. */
.floating-bubble {
    position: absolute;
    bottom: 0;
    background: var(--color-black);
    color: var(--color-white);
    padding: 0.7rem 0.95rem;
    font-size: 0.78rem;
    line-height: 1.35;
    width: max-content;
    min-width: 200px;
    max-width: 240px;
    border-radius: 6px;
    border: 1px solid rgba(203, 187, 160, 0.55);
    box-shadow: 0 10px 30px -16px rgba(0, 0, 0, 0.55);
    opacity: 0;
    pointer-events: none;
    transform: translateY(8px);
    transition: opacity 0.35s ease, transform 0.35s ease;
    z-index: 60;
}
.floating-actions--left .floating-bubble {
    left: calc(100% + 14px);
}
.floating-actions--right .floating-bubble {
    right: calc(100% + 14px);
    text-align: right;
}
.floating-bubble.is-visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}
.floating-bubble__close {
    position: absolute;
    top: 4px;
    right: 6px;
    background: transparent;
    border: 0;
    color: var(--color-grey, #aaa);
    font-size: 0.95rem;
    line-height: 1;
    cursor: pointer;
    padding: 2px 4px;
}
.floating-actions--right .floating-bubble__close { right: auto; left: 6px; }
.floating-bubble__text {
    margin: 0;
    padding-right: 14px;
    color: var(--color-white);
}
.floating-actions--right .floating-bubble__text { padding-right: 0; padding-left: 14px; }

@media (max-width: 600px) {
    .floating-bubble { display: none; }
}
@media (prefers-reduced-motion: reduce) {
    .floating-bubble { transition: opacity 0.01s; }
}

/* ─── CTA variant ─── used for the Kaja "Click here for help" prompt.
   Anchored to the chatbot button (top of the right stack), with a
   right-pointing arrow tail and bold copy designed for older / less
   tech-fluent visitors. */
.floating-bubble--cta {
    min-width: 220px;
    max-width: 260px;
    padding: 1rem 1.1rem 0.9rem;
    background: linear-gradient(135deg, #050505 0%, #1a1612 100%);
    border: 1.5px solid var(--color-champagne);
    box-shadow:
        0 14px 36px -10px rgba(0, 0, 0, 0.7),
        0 0 28px rgba(203, 187, 160, 0.18);
    border-radius: 8px;
}

/* Lift the bubble so its vertical centre lines up with the chatbot
   button. Right stack from bottom: email (48px) + gap (0.75rem) +
   chatbot (48px). Setting bottom to (email-height + gap) puts the
   bubble bottom flush with the chatbot bottom. */
.floating-actions--right .floating-bubble--cta {
    bottom: calc(48px + 0.75rem);
    text-align: left;
}

/* Arrow tail — 14px square rotated 45°, painted with the gradient
   background and champagne border on right+top so it reads as a tail
   pointing into the chatbot button on the right. */
.floating-actions--right .floating-bubble--cta::after {
    content: '';
    position: absolute;
    right: -8px;
    top: 50%;
    width: 14px;
    height: 14px;
    transform: translateY(-50%) rotate(45deg);
    background: #1a1612;
    border-right: 1.5px solid var(--color-champagne);
    border-top: 1.5px solid var(--color-champagne);
    z-index: -1;
}

.floating-bubble--cta .floating-bubble__close {
    left: auto;
    right: 6px;
    top: 4px;
    color: rgba(203, 187, 160, 0.55);
}
.floating-bubble--cta .floating-bubble__close:hover { color: var(--color-champagne); }

.floating-bubble--cta .floating-bubble__text {
    padding-left: 0;
    padding-right: 16px;
    text-align: left;
}

.floating-bubble__eyebrow {
    display: block;
    font-family: var(--font-body);
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 2.5px;
    color: var(--color-champagne);
    font-weight: 600;
    margin-bottom: 0.35rem;
}

.floating-bubble__cta {
    display: block;
    font-family: var(--font-body);
    font-weight: 700;
    font-size: 1.0625rem;
    color: var(--color-white);
    line-height: 1.25;
}

.floating-bubble__cta-arrow {
    display: inline-block;
    margin-left: 0.35rem;
    color: var(--color-champagne);
    font-weight: 500;
}

@keyframes celsa-bubble-nudge {
    0%, 100% { transform: translateX(0); }
    50%      { transform: translateX(5px); }
}
.floating-bubble--cta.is-visible .floating-bubble__cta-arrow {
    animation: celsa-bubble-nudge 1.6s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
    .floating-bubble--cta.is-visible .floating-bubble__cta-arrow { animation: none; }
}

@media (max-width: 768px) {
    .floating-actions--right .floating-bubble--cta {
        bottom: calc(42px + 0.75rem);
    }
}

@media (max-width: 600px) {
    .floating-bubble--cta {
        display: block;
        min-width: 180px;
        max-width: 220px;
        padding: 0.85rem 1rem 0.75rem;
    }
    .floating-bubble__cta { font-size: 0.95rem; }
    .floating-bubble__eyebrow { font-size: 0.62rem; letter-spacing: 2px; }
}

/* === Testimonials nav dropdown === */
.nav-has-dropdown { position: relative; }
.nav-dropdown-toggle {
    background: transparent;
    border: 0;
    padding: 0;
    margin: 0;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    /* Match .nav-list a typography exactly so the button reads as part of the row */
    font-family: var(--font-heading);
    font-size: 0.78rem;
    font-weight: 400;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: var(--color-white);
    line-height: 1;
    transition: color var(--transition-fast);
}
.nav-dropdown-toggle:hover,
.nav-has-dropdown[data-open="true"] .nav-dropdown-toggle {
    color: var(--color-champagne);
}
.nav-dropdown-toggle::after {
    content: "";
    width: 6px;
    height: 6px;
    border-right: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    transform: rotate(45deg) translateY(-2px);
    display: inline-block;
    transition: transform 0.25s ease;
}
.nav-has-dropdown[data-open="true"] .nav-dropdown-toggle::after {
    transform: rotate(-135deg) translateY(2px);
}
.nav-dropdown {
    position: absolute;
    top: calc(100% + 12px);
    left: 50%;
    transform: translateX(-50%) translateY(6px);
    width: 360px;
    max-width: 92vw;
    background: var(--color-black);
    border: 1px solid rgba(203, 187, 160, 0.35);
    box-shadow: 0 24px 60px -28px rgba(0, 0, 0, 0.6);
    padding: 1rem;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease, transform 0.25s ease;
    z-index: 75;
}
.nav-has-dropdown:hover .nav-dropdown,
.nav-has-dropdown[data-open="true"] .nav-dropdown,
.nav-has-dropdown:focus-within .nav-dropdown {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}
.nav-dropdown__list {
    list-style: none;
    margin: 0 0 0.75rem;
    padding: 0;
    display: grid;
    gap: 0.6rem;
    max-height: 320px;
    overflow-y: auto;
}
.nav-dropdown__item {
    background: rgba(255, 255, 255, 0.04);
    border-left: 2px solid var(--color-champagne);
    padding: 0.6rem 0.75rem;
}
.nav-dropdown__quote {
    margin: 0 0 0.4rem;
    color: var(--color-white);
    font-size: 0.82rem;
    line-height: 1.5;
}
.nav-dropdown__attribution {
    margin: 0;
    color: var(--color-champagne-dark);
    font-size: 0.7rem;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}
.nav-dropdown__leave-review-cta {
    width: 100%;
    text-align: center;
    justify-content: center;
}
.nav-dropdown__empty {
    color: var(--color-grey, #999);
    font-size: 0.85rem;
    margin: 0 0 0.75rem;
}
.nav-dropdown__stars {
    margin: 0 0 0.3rem;
    color: var(--color-champagne);
    font-size: 0.72rem;
    letter-spacing: 2px;
    line-height: 1;
}
.nav-dropdown__see-all {
    display: block;
    width: 100%;
    text-align: center;
    background: transparent;
    border: 0;
    color: var(--color-champagne);
    font-family: var(--font-heading);
    font-size: 0.72rem;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    padding: 0.4rem;
    margin: 0 0 0.5rem;
    cursor: pointer;
    transition: color var(--transition-fast);
}
.nav-dropdown__see-all:hover { color: var(--color-white); }

/* On mobile (hamburger), the dropdown becomes inline. The open/hover/focus
   selectors are repeated here so their higher specificity does not re-apply the
   desktop translateX(-50%) (which would push the panel off the left edge). */
@media (max-width: 900px) {
    .nav-dropdown,
    .nav-has-dropdown:hover .nav-dropdown,
    .nav-has-dropdown[data-open="true"] .nav-dropdown,
    .nav-has-dropdown:focus-within .nav-dropdown {
        position: static;
        left: auto;
        transform: none;
        width: 100%;
        max-width: none;
        opacity: 1;
        pointer-events: auto;
        background: transparent;
        border: 0;
        box-shadow: none;
        padding: 0.5rem 0 0;
    }
    .nav-dropdown { display: none; }
    .nav-has-dropdown[data-open="true"] .nav-dropdown { display: block; }
}

/* ============================================================
   FLOATING TESTIMONIALS PILL (bottom-left)
   Replaces the lone star icon. Icon + label so non-tech users
   know exactly what it does.
   ============================================================ */
.floating-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.6rem 1.1rem 0.6rem 0.7rem;
    background: var(--color-black);
    color: var(--color-white);
    border: 1px solid rgba(203, 187, 160, 0.55);
    border-radius: 999px;
    font-family: var(--font-heading);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    line-height: 1;
    cursor: pointer;
    text-decoration: none;
    box-shadow: 0 8px 22px -10px rgba(0, 0, 0, 0.45);
    transition: background 0.25s ease, border-color 0.25s ease, transform 0.25s ease, color 0.25s ease, box-shadow 0.25s ease;
}
.floating-pill__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--color-champagne);
    color: var(--color-black);
}
.floating-pill__label { white-space: nowrap; }
.floating-pill:hover,
.floating-pill:focus-visible {
    background: rgba(203, 187, 160, 0.16);
    border-color: var(--color-champagne);
    color: var(--color-champagne);
    transform: translateY(-2px);
    box-shadow: 0 12px 28px -10px rgba(203, 187, 160, 0.35);
}
.floating-pill:hover .floating-pill__icon,
.floating-pill:focus-visible .floating-pill__icon {
    background: var(--color-champagne-dark, var(--color-champagne));
}
@media (max-width: 600px) {
    .floating-pill { padding: 0.55rem 0.95rem 0.55rem 0.6rem; font-size: 0.72rem; letter-spacing: 1.1px; }
    .floating-pill__icon { width: 24px; height: 24px; }
    .floating-pill__icon svg { width: 14px; height: 14px; }
}

/* ============================================================
   TESTIMONIALS FULLSCREEN POPUP
   ============================================================ */
.testimonials-overlay {
    position: fixed;
    inset: 0;
    z-index: 2200;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.32s ease;
}
.testimonials-overlay[hidden] { display: none; }
.testimonials-overlay.is-open {
    opacity: 1;
    pointer-events: auto;
}
.testimonials-overlay__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(8, 8, 10, 0.72);
    backdrop-filter: blur(0px);
    -webkit-backdrop-filter: blur(0px);
    transition: backdrop-filter 0.42s ease 0.05s, -webkit-backdrop-filter 0.42s ease 0.05s, background 0.32s ease;
}
.testimonials-overlay.is-open .testimonials-overlay__backdrop {
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    background: rgba(8, 8, 10, 0.82);
}

.testimonials-modal {
    position: relative;
    width: min(880px, 94vw);
    max-height: 92vh;
    background: linear-gradient(180deg, #0c0c0e 0%, #07070a 100%);
    color: var(--color-white);
    border: 1px solid rgba(203, 187, 160, 0.22);
    border-radius: 16px;
    box-shadow: 0 32px 80px -28px rgba(0, 0, 0, 0.85), 0 0 0 1px rgba(255,255,255,0.02) inset;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    /* Initial state — JS replaces this with GSAP, but kept as a CSS fallback */
    transform: translateY(24px) scale(0.96);
    opacity: 0;
    transition: transform 0.42s cubic-bezier(.2,.8,.2,1) 0.05s, opacity 0.42s ease 0.05s;
}
.testimonials-overlay.is-open .testimonials-modal {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.testimonials-modal__close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--color-white);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.25s ease, color 0.25s ease, transform 0.25s ease;
    z-index: 2;
}
.testimonials-modal__close:hover,
.testimonials-modal__close:focus-visible {
    background: rgba(203, 187, 160, 0.16);
    color: var(--color-champagne);
    transform: scale(1.05);
}

.testimonials-modal__header {
    padding: 2.2rem 2rem 1.4rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    text-align: center;
    background:
        radial-gradient(ellipse at top, rgba(203, 187, 160, 0.12) 0%, transparent 60%),
        transparent;
}
.testimonials-modal__eyebrow {
    margin: 0 0 0.5rem;
    color: var(--color-champagne);
    font-family: var(--font-heading);
    font-size: 0.7rem;
    letter-spacing: 3px;
    text-transform: uppercase;
}
.testimonials-modal__title {
    margin: 0 0 0.85rem;
    color: var(--color-white);
    font-family: var(--font-heading);
    font-size: clamp(1.6rem, 2.4vw, 2.1rem);
    font-weight: 300;
    letter-spacing: 0.5px;
    line-height: 1.15;
}
.testimonials-modal__stats {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0 0 1.05rem;
    padding: 0.45rem 0.85rem;
    background: rgba(203, 187, 160, 0.08);
    border: 1px solid rgba(203, 187, 160, 0.22);
    border-radius: 999px;
}
.testimonials-modal__stars {
    display: inline-flex;
    gap: 1px;
    color: var(--color-champagne);
    line-height: 0;
}
.testimonials-modal__stats-text {
    color: var(--color-white);
    font-size: 0.78rem;
    letter-spacing: 0.4px;
}
.testimonials-modal__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.7rem 1.4rem;
    background: var(--color-champagne);
    color: var(--color-black);
    font-family: var(--font-heading);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    text-decoration: none;
    border: 1px solid var(--color-champagne);
    border-radius: 999px;
    transition: background 0.25s ease, color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
    box-shadow: 0 8px 22px -12px rgba(203, 187, 160, 0.6);
}
.testimonials-modal__cta:hover,
.testimonials-modal__cta:focus-visible {
    background: var(--color-champagne-dark, var(--color-champagne));
    transform: translateY(-1px);
    box-shadow: 0 12px 28px -10px rgba(203, 187, 160, 0.5);
}
.testimonials-modal__cta--ghost {
    background: transparent;
    color: var(--color-champagne);
    box-shadow: none;
}
.testimonials-modal__cta--ghost:hover,
.testimonials-modal__cta--ghost:focus-visible {
    background: rgba(203, 187, 160, 0.1);
    color: var(--color-white);
}

.testimonials-modal__list-wrap {
    flex: 1 1 auto;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 1.6rem 1.6rem 1.2rem;
    /* Subtle scrollbar */
    scrollbar-width: thin;
    scrollbar-color: rgba(203,187,160,0.35) transparent;
}
.testimonials-modal__list-wrap::-webkit-scrollbar { width: 6px; }
.testimonials-modal__list-wrap::-webkit-scrollbar-track { background: transparent; }
.testimonials-modal__list-wrap::-webkit-scrollbar-thumb { background: rgba(203,187,160,0.35); border-radius: 3px; }

.testimonials-modal__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.9rem;
}
.testimonials-modal__item {
    position: relative;
    padding: 1.15rem 1.15rem 1rem 2.1rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-left: 2px solid var(--color-champagne);
    border-radius: 6px;
    transition: background 0.25s ease, border-color 0.25s ease, transform 0.25s ease;
}
.testimonials-modal__item:hover {
    background: rgba(203, 187, 160, 0.06);
    border-color: rgba(203, 187, 160, 0.32);
    transform: translateY(-1px);
}
.testimonials-modal__quote-mark {
    position: absolute;
    top: 4px;
    left: 14px;
    font-family: var(--font-heading);
    font-size: 2.4rem;
    line-height: 1;
    color: var(--color-champagne);
    opacity: 0.6;
}
.testimonials-modal__quote {
    margin: 0 0 0.7rem;
    color: rgba(255, 255, 255, 0.94);
    font-size: 0.88rem;
    line-height: 1.55;
}
.testimonials-modal__rating {
    display: inline-flex;
    gap: 1px;
    color: var(--color-champagne);
    margin-bottom: 0.35rem;
    line-height: 0;
}
.testimonials-modal__attribution {
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    align-items: baseline;
}
.testimonials-modal__name {
    color: var(--color-white);
    font-family: var(--font-heading);
    font-size: 0.78rem;
    letter-spacing: 1px;
    text-transform: uppercase;
}
.testimonials-modal__source {
    color: var(--color-champagne);
    font-size: 0.7rem;
    letter-spacing: 0.5px;
}
.testimonials-modal__source::before { content: "·  "; opacity: 0.6; }
.testimonials-modal__empty {
    text-align: center;
    color: rgba(255, 255, 255, 0.6);
    padding: 2rem 1rem;
}

.testimonials-modal__footer {
    padding: 1.15rem 2rem 1.4rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    text-align: center;
    background: rgba(0, 0, 0, 0.25);
}

@media (max-width: 720px) {
    .testimonials-modal { width: 100vw; height: 100dvh; max-height: 100dvh; border-radius: 0; border-left: 0; border-right: 0; }
    .testimonials-modal__header { padding: 1.6rem 1.2rem 1.1rem; }
    .testimonials-modal__title { font-size: 1.35rem; }
    .testimonials-modal__list { grid-template-columns: 1fr; }
    .testimonials-modal__list-wrap { padding: 1rem 1rem 0.8rem; }
    .testimonials-modal__footer { padding: 1rem 1.2rem 1.4rem; }
}

@media (prefers-reduced-motion: reduce) {
    .testimonials-overlay,
    .testimonials-overlay__backdrop,
    .testimonials-modal,
    .testimonials-modal__item { transition: opacity 0.1s linear; }
    .testimonials-modal { transform: none; }
}

body.has-testimonials-open { overflow: hidden; }

/* ═══════════════════════════════════════════════════════ */
/* LISTING STATUS — Sold / Rented / Under Offer            */
/* ═══════════════════════════════════════════════════════ */

/* Under Offer badge colour (amber) for cards + hero. */
.listing-card__status.is-under-offer,
.listing-hero__status.is-under-offer { background: #b8860b; }

/* Closed (sold/rented) cards must never read as available: desaturate the
   photo and dim it slightly so the red Sold/Rented badge dominates. */
.listing-card.is-closed .listing-card__media img {
    filter: grayscale(55%) brightness(0.82);
}
.listing-card.is-closed .listing-card__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.04), rgba(0,0,0,0.22));
    pointer-events: none;
}
.listing-card.is-closed .listing-card__price { color: var(--color-grey-dark); }

/* Cleaned description bullet list (was raw "•\t" text from the feed). */
.listing-content-list {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
    display: grid;
    gap: 0.5rem;
}
.listing-content-list li {
    position: relative;
    padding-left: 1.4rem;
    line-height: 1.6;
}
.listing-content-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.62em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-champagne);
}

/* ── Single listing: mobile overflow hardening (≤ 480px) ──
   Long property titles, addresses and references must wrap rather than force
   horizontal scroll. Tested at 390px. */
.single-listing { overflow-x: clip; }
.listing-breadcrumb,
.listing-header h1,
.listing-header__address,
.listing-header__price,
.listing-description,
.listing-extras__list,
.single-listing p {
    overflow-wrap: anywhere;
    word-break: break-word;
}
.listing-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    row-gap: 0.15rem;
}
.listing-breadcrumb .is-current {
    min-width: 0;
    overflow-wrap: anywhere;
}
.listing-description img,
.listing-body__main img,
.listing-body img { max-width: 100%; height: auto; }

@media (max-width: 480px) {
    .listing-hero__thumbs {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    .listing-extras__list li { flex-wrap: wrap; gap: 0.25rem; }
    .toast { max-width: calc(100vw - 2rem); }
}

