/* ============================================================
   WebbDesignz Party Rental V2 Theme — main.css v2.0
   Palette: navy #0F3460 / gold #E2B64A / white / off-white #F5F7FA
   All dynamic images applied via inline style in PHP templates
   Brand colors can be overridden via Theme Settings → Brand Colors
   (injects --color-primary / --color-accent as inline style)
   WebbDesignz | sales@webbdesignz.com | (918) 830-3888
   ============================================================ */

/* ---- TOKENS ---- */
:root {
    /* Brand colors — overridden by wp_add_inline_style() from Theme Settings */
    --color-primary:      #0F3460;   /* navy — default, client-configurable */
    --color-accent:       #E2B64A;   /* gold — default, client-configurable */

    /* Semantic aliases — all old class names still work */
    --color-navy:         var(--color-primary);
    --color-navy-dark:    #0a2444;
    --color-gold:         var(--color-accent);
    --color-gold-dark:    #C49A35;
    --color-red:          var(--color-accent);   /* old "red" CTA slot → now accent gold */
    --color-red-dark:     var(--color-gold-dark);

    /* Neutrals */
    --color-white:        #FFFFFF;
    --color-offwhite:     #F5F7FA;                /* demo alt section bg */
    --color-gray:         var(--color-offwhite);
    --color-gray-dark:    #E5E9F0;
    --color-dark-bg:      #0a1628;                /* footer + deep dark sections */

    /* Text */
    --color-text:         #1a1a2e;
    --color-text-muted:   #4a5568;
    --color-text-light:   #b8c2cc;                /* muted text on dark backgrounds */
    --color-border:       #E5E9F0;
    --color-review-star:  #FBBC04;

    /* Typography — Inter everywhere, weight does the work */
    --font-heading: 'Inter', system-ui, sans-serif;
    --font-body:    'Inter', system-ui, sans-serif;

    --space-xs:  0.5rem;
    --space-sm:  0.75rem;
    --space-md:  1rem;
    --space-lg:  1.5rem;
    --space-xl:  2rem;
    --space-2xl: 3rem;
    --space-3xl: 4.5rem;

    --max-width:  1280px;
    --radius:     0.5rem;
    --radius-lg:  0.875rem;

    /* Shadows now reference primary color for natural brand tinting */
    --shadow:     0 4px 24px rgba(15,52,96,0.10);
    --shadow-lg:  0 12px 40px rgba(15,52,96,0.16);
    --shadow-gold: 0 6px 20px rgba(226,182,74,0.35);

    --transition: 0.2s ease;
}

/* ---- RESET ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { font-family: var(--font-body); font-size: 1rem; line-height: 1.6; color: var(--color-text); background: var(--color-white); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
img { max-width: 100%; height: auto; vertical-align: middle; }
a { color: var(--color-primary); text-underline-offset: 0.2em; }
a:hover { color: var(--color-accent); }
:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }

.skip-link { position: absolute; left: -9999px; top: 0; z-index: 100000; padding: 0.5rem 1rem; background: var(--color-primary); color: var(--color-white); font-weight: 700; text-decoration: none; }
.skip-link:focus { left: 1rem; }

.container { width: 100%; max-width: var(--max-width); margin: 0 auto; padding: 0 var(--space-md); }
.screen-reader-text { position: absolute!important; width: 1px!important; height: 1px!important; overflow: hidden!important; clip: rect(0,0,0,0)!important; white-space: nowrap!important; }

/* ---- TYPOGRAPHY ---- */
h1, h2, h3, h4, h5 { font-family: var(--font-heading); font-weight: 800; line-height: 1.15; color: var(--color-primary); letter-spacing: -0.015em; }
h1 { font-size: clamp(2.25rem, 6vw, 3.5rem); font-weight: 900; letter-spacing: -0.025em; }
h2 { font-size: clamp(1.75rem, 4vw, 2.5rem); letter-spacing: -0.02em; }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.5rem); }

/* Section eyebrow label — "SERVICE AREAS", "WHY CHOOSE US" etc. */
.section-eyebrow { display: block; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-primary); margin-bottom: 0.75rem; }

/* Gold accent word inside headings (e.g. "Inflatable Rentals" in hero) */
.accent-word, .gold-text { color: var(--color-accent); }

/* ---- BUTTONS ---- */
.button, .btn {
    display: inline-flex; align-items: center; justify-content: center;
    min-height: 3rem; padding: 0 var(--space-xl);
    font-family: var(--font-heading); font-weight: 700; font-size: 0.9375rem;
    text-decoration: none; border-radius: var(--radius);
    border: 2px solid transparent; cursor: pointer;
    letter-spacing: 0.01em;
    transition: filter var(--transition), transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition);
}
.button--cta, .btn-primary {
    background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary);
    box-shadow: 0 4px 14px rgba(15,52,96,0.35);
}
.button--cta:hover, .btn-primary:hover {
    filter: brightness(1.08); color: var(--color-white); transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(15,52,96,0.45);
}
.button--accent, .btn-accent {
    background: var(--color-accent); color: var(--color-primary); border-color: var(--color-accent);
    box-shadow: 0 4px 14px rgba(226,182,74,0.35);
}
.button--accent:hover, .btn-accent:hover {
    filter: brightness(1.06); color: var(--color-primary); transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(226,182,74,0.45);
}
.button--outline, .btn-outline {
    background: transparent; color: var(--color-white); border-color: var(--color-white);
}
.button--outline:hover, .btn-outline:hover { background: var(--color-white); color: var(--color-primary); }
.button--browse-inventory {
    background: transparent; color: var(--color-navy); border-color: var(--color-navy);
    box-shadow: none;
}
.button--browse-inventory:hover { background: var(--color-navy); color: var(--color-white); }

/* ---- HEADER ---- */
.site-header {
    background: var(--color-navy); color: var(--color-white);
    position: sticky; top: 0; z-index: 100;
    box-shadow: 0 2px 0 rgba(0,0,0,0.12);
}
.site-header__bar-inner {
    display: flex; align-items: center; gap: var(--space-md);
    min-height: 5.5rem;
}
.site-branding__logo img, .site-branding__logo .custom-logo-link { max-height: 80px; width: auto; display: block; }
.site-branding__text { color: var(--color-white); font-weight: 800; font-size: 1.35rem; text-decoration: none; }

/* Mobile header controls */
.site-header__mobile-book-btn {
    display: none; margin-left: auto;
    padding: 0.5rem var(--space-lg);
    background: var(--color-red); color: var(--color-white)!important;
    font-family: var(--font-heading); font-weight: 700; font-size: 0.9375rem;
    text-decoration: none; border-radius: var(--radius); white-space: nowrap;
}
.site-nav__hamburger {
    display: none; align-items: center; justify-content: center;
    width: 3rem; height: 3rem; background: none; border: none; cursor: pointer; color: var(--color-white); flex-shrink: 0;
}
.site-nav-mobile__bars { width: 1.5rem; height: 2px; background: currentColor; box-shadow: 0 -6px 0 currentColor, 0 6px 0 currentColor; }

/* Nav */
.site-nav--primary { display: none; width: 100%; }
.site-nav--primary.is-open { display: block; padding-bottom: var(--space-md); }
.menu { list-style: none; margin: 0; padding: 0; }
.menu--primary { display: flex; flex-direction: column; }
.menu--primary > .menu-item > a { display: block; padding: var(--space-sm) var(--space-xs); color: var(--color-white); font-family: var(--font-heading); font-weight: 700; text-decoration: none; }
.menu--primary > .menu-item > a:hover { color: var(--color-red); }
.menu--primary .sub-menu { list-style: none; margin: 0; padding: 0 0 var(--space-xs) var(--space-md); display: none; }
.menu--primary .sub-menu a { display: block; padding: var(--space-xs) var(--space-sm); color: rgba(255,255,255,0.85); font-size: 0.9375rem; text-decoration: none; }

.site-nav__book-btn {
    display: none; flex-shrink: 0;
    padding: var(--space-xs) var(--space-xl);
    background: var(--color-red); color: var(--color-white)!important;
    font-family: var(--font-heading); font-weight: 700; font-size: 0.875rem;
    text-decoration: none; border-radius: var(--radius); white-space: nowrap;
    transition: background var(--transition), transform var(--transition);
}
.site-nav__book-btn:hover { background: var(--color-red-dark); color: var(--color-white)!important; }
.site-nav__phone { display: none; align-items: center; gap: var(--space-xs); color: var(--color-white); font-weight: 700; font-size: 0.875rem; text-decoration: none; white-space: nowrap; flex-shrink: 0; margin-left: var(--space-sm); }

/* Desktop nav */
@media (min-width: 60rem) {
    .site-header__bar-inner { min-height: 6rem; gap: 0; flex-wrap: nowrap; }
    .site-branding__logo img, .site-branding__logo .custom-logo-link { max-height: 88px; }
    .site-nav__hamburger { display: none; }
    .site-header__mobile-book-btn { display: none!important; }
    .site-nav--primary { display: flex!important; align-items: center; flex: 1; min-width: 0; padding: 0; gap: var(--space-sm); }
    .menu--primary { flex-direction: row; flex: 1; align-items: center; }
    .menu--primary > .menu-item { position: relative; }
    .menu--primary > .menu-item > a { padding: var(--space-sm) var(--space-md); font-size: 0.9375rem; white-space: nowrap; }
    .menu--primary .sub-menu { display: none; position: absolute; top: 100%; left: 0; min-width: 14rem; background: var(--color-white); border-radius: 0 0 var(--radius) var(--radius); box-shadow: var(--shadow); z-index: 200; padding: var(--space-sm) 0; }
    .menu--primary .sub-menu a { color: var(--color-navy); padding: var(--space-sm) var(--space-md); }
    .menu--primary .sub-menu a:hover { color: var(--color-red); background: rgba(15,52,96,0.04); }
    .menu--primary .menu-item-has-children:hover > .sub-menu,
    .menu--primary .menu-item-has-children:focus-within > .sub-menu { display: block; }
    .site-nav__book-btn { display: inline-flex; }
    .site-nav__phone { display: inline-flex; }
}

/* Mobile nav overlay */
@media (max-width: 59.99rem) {
    .site-header { position: relative; }
    .site-nav__hamburger { display: flex; }
    .site-header__mobile-book-btn { display: inline-flex!important; }
    .site-nav--primary { position: absolute; top: 100%; left: 0; right: 0; z-index: 999; background: var(--color-navy); padding: var(--space-md); box-shadow: 0 8px 24px rgba(0,0,0,0.25); }
    .site-nav--primary.is-open .menu--primary { display: flex; flex-direction: column; }
    .site-nav--primary.is-open .menu--primary .sub-menu { display: block; }
    .nav-desktop-only { display: none!important; }
}

/* ---- HERO ---- */
/* ---- HERO (demo-match: navy bg, gold accent word, checkmark list, right-side illustration) ---- */
.hero, .site-hero {
    position: relative; min-height: 420px;
    display: flex; flex-direction: column; justify-content: center;
    padding: var(--space-xl) 0;
    background-color: #0a1628;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    overflow: hidden;
}
/* Hero background image — applied via --hero-bg CSS var from PHP */
.hero[style*="--hero-bg"],
.site-hero[style*="--hero-bg"] {
    background-image: var(--hero-bg) !important;
}
/* Gradient glow only when NO image set */
.hero:not([style*="--hero-bg"]),
.site-hero:not([style*="--hero-bg"]) {
    background-image:
        radial-gradient(ellipse at 80% 20%, rgba(226,182,74,0.10) 0%, transparent 55%),
        radial-gradient(ellipse at 20% 80%, rgba(226,182,74,0.05) 0%, transparent 55%);
}
/* Kill the old absolute-positioned image layers entirely */
.hero__media, .site-hero::before {
    display: none !important;
}
/* Overlay disabled completely — see line ~1069 */
.hero::after, .site-hero::after {
    content: none;
}
.hero__overlay {
    position: relative !important;
    flex: 1;
    display: flex; align-items: center;
    padding: var(--space-xl) 0 !important;
    z-index: 2;
    background: transparent !important;
    background-color: transparent !important;
}
.hero__content, .site-hero__inner {
    max-width: 640px;
    position: relative;
    z-index: 3;
    background: transparent !important;
    background-color: transparent !important;
}
.hero-headline, .site-hero h1 {
    margin: 0 0 var(--space-md); color: var(--color-white);
    font-size: clamp(1.85rem, 4.5vw, 2.85rem); font-weight: 900; line-height: 1.1;
    letter-spacing: -0.02em;
}
.hero-headline .gold-text, .site-hero h1 .gold-text { color: var(--color-accent); display: inline; }
.hero__subhead, .site-hero__sub {
    margin: 0 0 var(--space-xl); color: rgba(255,255,255,0.92);
    font-size: clamp(1rem, 2.3vw, 1.15rem); line-height: 1.6; font-weight: 400;
}
.hero__cta-wrap, .site-hero__ctas { margin: 0; display: flex; gap: var(--space-md); flex-wrap: wrap; align-items: center; }
.site-hero__badge {
    display: inline-block; margin-bottom: var(--space-md);
    padding: 0.4rem 0.9rem; background: rgba(226,182,74,0.15); color: var(--color-accent);
    font-family: var(--font-heading); font-size: 0.8rem; font-weight: 700;
    letter-spacing: 0.1em; text-transform: uppercase; border-radius: 999px;
    border: 1px solid rgba(226,182,74,0.4);
}

/* Hero feature checklist (demo: "Bounce Houses, Water Slides & More" w/ checkmarks) */
.hero__features { list-style: none; margin: 0 0 var(--space-xl); padding: 0; display: flex; flex-direction: column; gap: 0.65rem; }
.hero__features li { display: flex; align-items: center; gap: 0.75rem; color: var(--color-white); font-size: 1rem; font-weight: 600; }
.hero__features li::before {
    content: ''; flex-shrink: 0;
    width: 22px; height: 22px; border-radius: 50%;
    background: var(--color-primary) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/60% no-repeat;
    border: 2px solid var(--color-accent);
}

/* Hero rating bar */
.hero__rating { display: flex; align-items: center; gap: 0.6rem; margin-top: var(--space-lg); }
.hero__rating-stars { color: var(--color-accent); font-size: 1.1rem; letter-spacing: 0.08em; }
.hero__rating-text { color: rgba(255,255,255,0.85); font-size: 0.95rem; font-weight: 500; }

/* ---- SECTIONS ---- */
.section { padding: var(--space-3xl) 0; }
.section--offwhite, .section--gray { background: var(--color-offwhite); }
.section--dark { background: var(--color-primary); color: var(--color-white); }
.section--dark h2, .section--dark h3 { color: var(--color-white); }
.section__title { margin: 0 0 var(--space-lg); font-size: clamp(1.75rem, 4vw, 2.5rem); color: var(--color-primary); font-weight: 800; letter-spacing: -0.02em; }
.section__title--center { text-align: center; }
.section-header { text-align: center; margin-bottom: var(--space-2xl); }
.section-header h2 { margin-bottom: var(--space-sm); }
.section-header p { color: var(--color-text-muted); font-size: 1.05rem; max-width: 620px; margin: 0 auto; line-height: 1.6; }
.section-divider { width: 48px; height: 3px; background: var(--color-accent); margin: var(--space-sm) auto 0; border-radius: 2px; }

/* ---- INVENTORY / RENTAL CATEGORY GRID (demo-style: gradient hero image, info card below) ---- */
.rental-sections { max-width: var(--max-width); margin: 0 auto; width: 100%; }
.rental-cat-grid {
    list-style: none; margin: 0; padding: 0;
    display: grid; gap: var(--space-lg);
    grid-template-columns: repeat(1, minmax(0,1fr));
}
@media (min-width: 48rem) { .rental-cat-grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width: 72rem) { .rental-cat-grid { grid-template-columns: repeat(3, minmax(0,1fr)); } }
.rental-cat-item { margin: 0; min-width: 0; }

/* Card wrapper — full card is clickable feel, info below the gradient */
.rental-cat-card {
    display: flex; flex-direction: column;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition);
    box-shadow: 0 2px 8px rgba(15,52,96,0.06);
}
.rental-cat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 40px rgba(15,52,96,0.14);
}

/* Gradient image area — 6 preset gradients cycle via :nth-child */
.rental-cat-card__img-link {
    display: flex; align-items: center; justify-content: center;
    width: 100%; aspect-ratio: 16/9; position: relative; overflow: hidden;
    text-decoration: none;
    background: linear-gradient(135deg, #1e3a8a 0%, #3b5ba8 100%);  /* default navy */
    background-size: cover; background-position: center;
}
/* Demo-matched color gradients on each card */
.rental-cat-item:nth-child(6n+1) .rental-cat-card__img-link { background: linear-gradient(135deg, #1e3a8a 0%, #3b5ba8 100%); } /* blue */
.rental-cat-item:nth-child(6n+2) .rental-cat-card__img-link { background: linear-gradient(135deg, #0e6b5e 0%, #4e9a82 100%); } /* teal */
.rental-cat-item:nth-child(6n+3) .rental-cat-card__img-link { background: linear-gradient(135deg, #2c3e8e 0%, #5b7ec9 100%); } /* indigo */
.rental-cat-item:nth-child(6n+4) .rental-cat-card__img-link { background: linear-gradient(135deg, #6b21a8 0%, #a855f7 100%); } /* purple */
.rental-cat-item:nth-child(6n+5) .rental-cat-card__img-link { background: linear-gradient(135deg, #d97706 0%, #fbbf24 100%); } /* amber */
.rental-cat-item:nth-child(6n+6) .rental-cat-card__img-link { background: linear-gradient(135deg, #b91c1c 0%, #ef4444 100%); } /* red */

/* Icon/emoji sits on top of the gradient */
.rental-cat-card__img-link::before {
    content: ''; position: absolute; inset: 0;
    background: var(--cat-icon, none) center/25% no-repeat;
}
.rental-cat-card__img {
    position: absolute; inset: 0; width: 100%; height: 100%;
    object-fit: cover; display: block;
}

/* Info card body below the gradient */
.rental-cat-card__body {
    display: flex; flex-direction: column; gap: 0.75rem;
    padding: var(--space-lg);
}
.rental-cat-card__phone-pill {
    display: inline-flex; align-self: flex-start;
    padding: 0.3rem 0.75rem; font-size: 0.8125rem; font-weight: 600;
    color: var(--color-text-muted); background: var(--color-white);
    border: 1px solid var(--color-border); border-radius: 999px;
}
.rental-cat-card__title {
    margin: 0;
    padding: 0;
    font-size: inherit;
    font-weight: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: inherit;
}
.rental-cat-card__title-link {
    display: block; font-family: var(--font-heading);
    font-size: 1.1rem; font-weight: 800; color: var(--color-primary);
    text-decoration: none; line-height: 1.3; letter-spacing: -0.01em;
    transition: color var(--transition);
}
.rental-cat-card__title-link:hover { color: var(--color-accent); }
.rental-cat-card__desc { font-size: 0.9rem; color: var(--color-text-muted); line-height: 1.5; }
.rental-cat-card__meta { display: flex; flex-direction: column; gap: 0.35rem; margin: 0.25rem 0 0.75rem; font-size: 0.875rem; color: var(--color-text-muted); }
.rental-cat-card__meta-item { display: flex; align-items: center; gap: 0.4rem; }
.rental-cat-card__cta {
    display: flex; align-items: center; justify-content: center;
    padding: 0.85rem var(--space-md); margin-top: auto;
    background: var(--color-primary); color: var(--color-white);
    font-family: var(--font-heading); font-size: 0.8125rem; font-weight: 700;
    letter-spacing: 0.1em; text-transform: uppercase; text-decoration: none;
    border-radius: var(--radius); transition: background var(--transition), transform var(--transition);
}
.rental-cat-card__cta:hover { background: var(--color-navy-dark); color: var(--color-white); transform: translateY(-1px); }

/* ---- TRUST BADGES (top trust row — demo style: clean, colored accent word + plain text) ---- */
.section--front-trust-badges {
    padding: var(--space-lg) 0; background: var(--color-white);
    border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border);
}
.front-trust-badges__title { margin: 0 0 var(--space-md); text-align: center; font-size: 1rem; font-weight: 700; color: var(--color-primary); letter-spacing: 0.03em; }
.front-trust-badges__row {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-wrap: wrap; justify-content: center; align-items: center;
    gap: var(--space-md) var(--space-xl);
}
.front-trust-badge {
    display: inline-flex; align-items: center; gap: 0.5rem;
    padding: 0; background: transparent; border: none;
    color: var(--color-text); font-size: 0.875rem; font-weight: 500;
}
.front-trust-badge__icon { flex-shrink: 0; color: var(--color-primary); display: flex; width: 18px; height: 18px; }
.front-trust-badge__label { color: var(--color-primary); font-weight: 700; }

/* Trust bar (dark) */
.trust-bar { background: var(--color-primary); color: var(--color-white); padding: var(--space-xl) 0; }
.trust-bar__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: var(--space-lg); text-align: center; }
.trust-item__icon { font-size: 2rem; margin-bottom: 0.5rem; color: var(--color-accent); }
.trust-item__title { font-family: var(--font-heading); font-size: 0.95rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 0.25rem; color: var(--color-accent); }
.trust-item__desc { font-size: 0.9rem; opacity: 0.85; line-height: 1.5; }

/* ---- CTA BANNER ---- */
.cta-banner { background: var(--color-navy); color: var(--color-white); padding: var(--space-xl) var(--space-md); }
.cta-banner__inner { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-lg); }
.cta-banner__title { margin: 0; font-size: clamp(1.25rem,3vw,1.75rem); font-weight: 800; line-height: 1.3; color: var(--color-white); }
.cta-banner__tagline { margin: 0; font-size: 1.05rem; color: rgba(255,255,255,0.92); }
.cta-banner__action { margin: 0; }
.cta-banner__action--dual { display: flex; flex-wrap: wrap; gap: var(--space-md); justify-content: center; }

/* ---- REVIEWS CAROUSEL ---- */
.section--reviews { background: var(--color-white); padding-bottom: var(--space-2xl); }
.reviews-carousel { margin-top: var(--space-lg); }
.reviews-carousel__bar { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-md); margin-bottom: var(--space-xl); padding: var(--space-md) var(--space-lg); background: var(--color-gray); border: 1px solid rgba(15,52,96,0.1); border-radius: var(--radius); }
.reviews-carousel__stars { color: var(--color-review-star); font-size: 1rem; }
.reviews-carousel__score { font-weight: 800; color: var(--color-navy); }
.reviews-carousel__count { font-size: 0.9375rem; font-weight: 600; color: var(--color-text-muted); }
.reviews-carousel__review-btn { display: inline-flex; align-items: center; padding: var(--space-sm) var(--space-lg); background: var(--color-navy); color: var(--color-white); font-weight: 700; border-radius: var(--radius); text-decoration: none; transition: background var(--transition); }
.reviews-carousel__review-btn:hover { background: var(--color-navy-dark); color: var(--color-white); }
.reviews-carousel__viewport { overflow: hidden; }
.reviews-carousel__track { display: flex; gap: var(--space-md); transition: transform 0.35s ease; }
.reviews-carousel__slide { flex: 0 0 100%; min-width: 0; box-sizing: border-box; }
@media (min-width: 40rem) { .reviews-carousel__slide { flex-basis: 50%; } }
@media (min-width: 64rem) { .reviews-carousel__slide { flex-basis: 25%; } }
.reviews-carousel__card { height: 100%; background: var(--color-white); border-radius: var(--radius); border: 1px solid rgba(15,52,96,0.08); box-shadow: 0 4px 20px rgba(15,52,96,0.08); padding: var(--space-lg); display: flex; flex-direction: column; gap: var(--space-sm); }
.reviews-carousel__card-top { display: flex; align-items: flex-start; gap: var(--space-sm); }
.reviews-carousel__avatar { flex-shrink: 0; width: 2.75rem; height: 2.75rem; border-radius: 50%; background: var(--color-navy); color: var(--color-white); font-weight: 800; font-size: 0.95rem; display: flex; align-items: center; justify-content: center; }
.reviews-carousel__author { font-weight: 700; color: var(--color-text); font-size: 0.9375rem; }
.reviews-carousel__ago { margin: 0.15rem 0 0; font-size: 0.8125rem; color: var(--color-text-muted); }
.reviews-carousel__stars-row { margin: 0; color: var(--color-review-star); font-size: 0.95rem; }
.reviews-carousel__excerpt { margin: 0; font-size: 0.875rem; line-height: 1.55; color: var(--color-text); }
.reviews-carousel__controls { display: flex; align-items: center; justify-content: center; gap: var(--space-lg); margin-top: var(--space-xl); }
.reviews-carousel__arrow { width: 2.75rem; height: 2.75rem; border-radius: 50%; border: 1px solid rgba(15,52,96,0.2); background: var(--color-white); color: var(--color-navy); font-size: 1.35rem; font-weight: 700; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background var(--transition); }
.reviews-carousel__arrow:hover { background: var(--color-gray); }
.reviews-carousel__arrow:disabled { opacity: 0.35; cursor: not-allowed; }
.reviews-carousel__dots { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-xs); }
.reviews-carousel__dot { width: 0.55rem; height: 0.55rem; padding: 0; border: none; border-radius: 50%; background: rgba(15,52,96,0.25); cursor: pointer; transition: background var(--transition); }
.reviews-carousel__dot.is-active { background: var(--color-navy); }

/* Manual review cards */
.reviews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: var(--space-md); }
.review-card { background: var(--color-white); border-radius: var(--radius); padding: var(--space-md); box-shadow: var(--shadow); border-left: 4px solid var(--color-red); }
.review-card__stars { color: var(--color-review-star); font-size: 1.1rem; margin-bottom: 0.5rem; }
.review-card__text { font-size: 0.95rem; color: var(--color-text-muted); font-style: italic; margin-bottom: var(--space-sm); }
.review-card__author { font-family: var(--font-heading); font-size: 0.9rem; font-weight: 600; color: var(--color-navy); }

/* ---- MAP / CONTACT ---- */
.section--map-contact { background: #e8ecf1; padding: var(--space-2xl) 0; }
.map-contact-grid { display: grid; gap: var(--space-xl); }
@media (min-width: 56rem) { .map-contact-grid { grid-template-columns: minmax(280px,420px) 1fr; align-items: start; } }
.map-contact-card { background: var(--color-white); padding: var(--space-xl); border-radius: var(--radius); border: 1px solid rgba(15,52,96,0.08); box-shadow: 0 8px 32px rgba(15,52,96,0.1); display: flex; flex-direction: column; gap: var(--space-md); }
.map-contact-card__title { margin: 0; font-size: 1.5rem; font-weight: 900; color: var(--color-navy); }
.map-contact-card__subtitle { margin: 0; font-size: 0.875rem; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.04em; }
.map-contact-card__row { display: flex; align-items: flex-start; gap: var(--space-md); padding: var(--space-sm) 0; border-bottom: 1px solid rgba(15,52,96,0.08); }
.map-contact-card__row:last-of-type { border-bottom: none; }
.map-contact-card__row-icon { flex-shrink: 0; width: 2.25rem; height: 2.25rem; display: flex; align-items: center; justify-content: center; color: var(--color-red); }
.map-contact-card__row-label { font-size: 0.7rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-text-muted); }
.map-contact-card__row-value { font-size: 1rem; font-weight: 700; color: var(--color-navy); line-height: 1.4; }
.map-contact-card__phone-link { font-size: 1rem; font-weight: 700; color: var(--color-navy); text-decoration: none; }
.map-contact-card__phone-link:hover { color: var(--color-red); }
.map-contact-card__zip { display: flex; flex-wrap: wrap; align-items: stretch; gap: var(--space-sm); margin-top: var(--space-sm); }
.map-contact-card__zip-input { flex: 1 1 120px; min-width: 0; padding: var(--space-sm) var(--space-md); font: inherit; font-weight: 600; border: 1px solid rgba(15,52,96,0.2); border-radius: var(--radius); }
.map-contact-card__zip-btn { flex: 0 0 auto; padding: var(--space-sm) var(--space-lg); font: inherit; font-weight: 800; color: var(--color-white); background: var(--color-red); border: none; border-radius: var(--radius); cursor: pointer; transition: background var(--transition); }
.map-contact-card__zip-btn:hover { background: var(--color-red-dark); }
.map-contact-card__zip-msg { flex: 1 0 100%; margin: 0; font-size: 0.875rem; font-weight: 600; color: var(--color-text-muted); min-height: 1.25em; }
.map-contact-card__zip-msg.is-success { color: #1a7f3c; }
.map-contact-card__zip-msg.is-error { color: var(--color-red); }
.map-contact-card__book-btn { display: block; width: 100%; margin-top: var(--space-md); padding: var(--space-md) var(--space-lg); font: inherit; font-size: 1.05rem; font-weight: 800; text-align: center; text-decoration: none; color: var(--color-white); background: var(--color-red); border-radius: var(--radius); box-shadow: 0 4px 16px rgba(226,182,74,0.35); transition: background var(--transition); }
.map-contact-card__book-btn:hover { background: var(--color-red-dark); color: var(--color-white); }
.map-contact-map__frame { position: relative; width: 100%; height: 420px; border-radius: var(--radius); border: 1px solid rgba(15,52,96,0.12); box-shadow: var(--shadow); overflow: hidden; }
.map-contact-map__frame iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; }
.map-contact-map__placeholder { min-height: 280px; display: flex; align-items: center; justify-content: center; padding: var(--space-xl); background: var(--color-white); border: 2px dashed rgba(15,52,96,0.2); border-radius: var(--radius); color: var(--color-text-muted); text-align: center; }

/* ---- FAQ ACCORDION ---- */
.section--faq-accordion { background: #e8ecf1; padding: var(--space-2xl) 0; }
.accordion { max-width: none; display: grid; grid-template-columns: 1fr; gap: var(--space-lg); }
@media (min-width: 52rem) { .accordion { grid-template-columns: 1fr 1fr; } }
.accordion__item { background: var(--color-white); border-radius: var(--radius); overflow: hidden; box-shadow: 0 4px 20px rgba(15,52,96,0.08); }
.accordion__trigger { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); padding: var(--space-md) var(--space-lg); background: var(--color-white); border: 0; cursor: pointer; font: inherit; font-weight: 800; font-size: 1rem; text-align: left; color: var(--color-navy); transition: background var(--transition); }
.accordion__trigger:hover { background: #fafbfd; }
.accordion__icon { position: relative; flex-shrink: 0; width: 1.25rem; height: 1.25rem; }
.accordion__icon-line { position: absolute; background: var(--color-navy); border-radius: 1px; transition: transform 0.3s cubic-bezier(0.4,0,0.2,1), opacity 0.25s ease; }
.accordion__icon-line--h { top: 50%; left: 0; width: 100%; height: 2px; margin-top: -1px; }
.accordion__icon-line--v { left: 50%; top: 0; width: 2px; height: 100%; margin-left: -1px; }
.accordion__item.is-open .accordion__icon-line--v { transform: rotate(90deg); opacity: 0; }
.accordion__panel { background: var(--color-white); border-top: 1px solid rgba(15,52,96,0.08); }
.accordion__panel-inner { padding: 0 var(--space-lg) var(--space-lg); font-size: 0.9375rem; color: var(--color-text-muted); line-height: 1.65; }

/* ---- CITY PAGE ---- */
.city-nearby-pills__list { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-sm); }
.city-nearby-pills__list a { display: inline-block; padding: var(--space-xs) var(--space-md); background: var(--color-white); border: 2px solid var(--color-navy); border-radius: 999px; font-weight: 700; font-size: 0.875rem; color: var(--color-navy); text-decoration: none; }
.city-nearby-pills__list a:hover { background: var(--color-navy); color: var(--color-white); }
.trust-badges { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-sm) var(--space-lg); }
.trust-badges__item { padding: var(--space-sm) var(--space-md); font-size: 0.875rem; font-weight: 700; color: var(--color-navy); background: var(--color-white); border-radius: 999px; border: 1px solid rgba(15,52,96,0.12); box-shadow: var(--shadow); }

/* ---- DELIVERY AREA PILLS (footer/map) ---- */
.delivery-areas-pills { text-align: center; }
.delivery-areas-pills__heading { margin: 0 0 var(--space-lg); font-size: clamp(1rem,2.5vw,1.2rem); font-weight: 800; color: var(--color-navy); }
.delivery-areas-pills__list { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: var(--space-sm) var(--space-md); justify-content: center; }
.delivery-areas-pills__pill { display: inline-block; padding: var(--space-sm) var(--space-lg); font-weight: 700; font-size: 0.9375rem; color: var(--color-navy); background: var(--color-white); border: 1px solid rgba(15,52,96,0.22); border-radius: 999px; text-decoration: none; transition: background var(--transition), color var(--transition); }
.delivery-areas-pills__pill:hover { background: var(--color-red); border-color: var(--color-red); color: var(--color-white); }
.delivery-areas-pills--dark .delivery-areas-pills__heading { color: var(--color-white); }
.delivery-areas-pills--dark .delivery-areas-pills__pill { color: var(--color-white); background: transparent; border-color: rgba(255,255,255,0.85); }
.delivery-areas-pills--dark .delivery-areas-pills__pill:hover { background: rgba(255,255,255,0.12); border-color: var(--color-white); }

/* ---- RESOURCE ACCORDIONS ---- */
.section--resource-accordions { padding: var(--space-2xl) 0; background: var(--color-gray); }
.resource-accordions { display: flex; flex-direction: column; gap: var(--space-sm); max-width: 52rem; margin: 0 auto; }
.resource-accordion { background: var(--color-white); border: 1px solid rgba(15,52,96,0.12); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; }
.resource-accordion__trigger { width: 100%; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: var(--space-md); padding: var(--space-md) var(--space-lg); background: var(--color-white); border: 0; cursor: pointer; text-align: left; font: inherit; color: var(--color-text); transition: background var(--transition); }
.resource-accordion__trigger:hover { background: rgba(15,52,96,0.04); }
.resource-accordion__pill { display: inline-block; padding: 0.2rem 0.65rem; font-size: 0.6875rem; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-white); background: var(--color-red); border-radius: 999px; white-space: nowrap; }
.resource-accordion__title { font-size: 1.0625rem; font-weight: 800; color: var(--color-navy); line-height: 1.3; }
.resource-accordion__subtitle { font-size: 0.875rem; color: var(--color-text-muted); }
.resource-accordion__chevron { display: flex; color: var(--color-navy); flex-shrink: 0; transition: transform 0.3s ease; }
.resource-accordion.is-open .resource-accordion__chevron { transform: rotate(180deg); }
.resource-accordion__panel { max-height: 0; overflow: hidden; transition: max-height 0.45s ease; border-top: 1px solid transparent; }
.resource-accordion.is-open .resource-accordion__panel { max-height: 100rem; border-top-color: rgba(15,52,96,0.08); }
.resource-accordion__inner { padding: var(--space-lg) var(--space-lg) var(--space-xl); }
.resource-accordion__bullets, .resource-accordion__steps { margin: 0; padding-left: 1.25rem; line-height: 1.65; color: var(--color-text); }
.resource-accordions__ctas { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-md); margin-top: var(--space-2xl); }

/* ---- INTERIOR PAGES ---- */
.page-header--interior { padding: var(--space-xl) 0; background: var(--color-gray); }
.page-header--accent { background: var(--color-navy); color: var(--color-white); border-bottom: 4px solid var(--color-red); }
.page-header--accent .page-title { color: var(--color-white); }
.page-header--accent .page-header__tagline { color: rgba(255,255,255,0.9); }
.page-title { margin: 0; font-size: clamp(1.75rem,4vw,2.25rem); font-weight: 900; color: var(--color-navy); }
.page-header__tagline { margin: var(--space-sm) 0 0; font-size: 1.05rem; }
.entry-content h2 { color: var(--color-navy); margin: 2rem 0 1rem; }
.entry-content p { line-height: 1.75; margin: 0 0 1.5rem; color: #333; }
.entry-content ul, .entry-content ol { line-height: 1.7; margin: 0 0 1.5rem; padding-left: 1.5rem; color: #333; }
.entry-content a { color: var(--color-red); font-weight: 700; }

/* ---- VERIFIED & TRUSTED ---- */
.verified-trusted-section { background: #1a1a2e; color: var(--color-white); padding: var(--space-2xl) var(--space-md); border-top: 1px solid rgba(255,255,255,0.06); }
.verified-trusted-section__label { margin: 0 0 var(--space-xl); font-size: 0.75rem; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.92); text-align: center; }
.verified-trusted-section__row { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-md); }
.verified-trusted-card { display: flex; align-items: flex-start; gap: var(--space-sm); padding: var(--space-md); background: #0a2444; border-radius: var(--radius); border: 1px solid rgba(255,255,255,0.08); flex: 1 1 14rem; max-width: 20rem; }
.verified-trusted-card__title { font-size: 0.8125rem; font-weight: 800; color: var(--color-white); }
.verified-trusted-card__sub { font-size: 0.75rem; color: rgba(255,255,255,0.62); }

/* ---- FOOTER ---- */
/* ---- SITE FOOTER (demo-match: deep navy, 4-col, gold phone accent) ---- */
.site-footer { background: var(--color-dark-bg); color: var(--color-white); }
.site-footer__main { padding: var(--space-3xl) 0 var(--space-xl); }
.site-footer__columns { display: grid; grid-template-columns: 1fr; gap: var(--space-2xl); align-items: start; }
@media (min-width: 52rem) { .site-footer__columns { grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--space-xl); } }
.site-footer a { color: rgba(255,255,255,0.75); font-weight: 400; text-decoration: none; transition: color var(--transition); }
.site-footer a:hover { color: var(--color-accent); text-decoration: none; }
.site-footer__heading { margin: 0 0 var(--space-md); font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; color: var(--color-text-light); }
.site-footer__logo img, .site-footer__logo .custom-logo-link { max-height: 52px; width: auto; display: block; }
.site-footer__brand-name { font-size: 1.5rem; font-weight: 900; color: var(--color-white); letter-spacing: -0.02em; margin: 0; }
.site-footer__brand-sub { font-size: 0.75rem; font-weight: 600; color: var(--color-text-light); letter-spacing: 0.15em; text-transform: uppercase; margin: 0.25rem 0 0; }
.site-footer__tagline { margin: var(--space-md) 0; font-size: 0.9375rem; color: rgba(255,255,255,0.75); line-height: 1.6; max-width: 340px; }
.site-footer__contact-line { margin: 0; font-size: 1.375rem; font-weight: 800; color: var(--color-accent); letter-spacing: -0.01em; }
.site-footer__contact-line a { color: var(--color-accent); }
.site-footer__contact-line a:hover { color: var(--color-accent); filter: brightness(1.15); }
.site-footer__link-list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr; gap: 0.65rem; font-size: 0.9375rem; }
.site-footer__social { display: flex; flex-wrap: wrap; gap: var(--space-sm); list-style: none; margin: var(--space-lg) 0 0; padding: 0; }
.site-footer__social-link { display: flex; align-items: center; justify-content: center; width: 2.25rem; height: 2.25rem; border-radius: 50%; background: rgba(255,255,255,0.08); color: var(--color-white); transition: background var(--transition), color var(--transition); }
.site-footer__social-link:hover { background: var(--color-accent); color: var(--color-primary); }
.site-footer__city-strip { background: rgba(0,0,0,0.3); border-top: 1px solid rgba(255,255,255,0.08); padding: var(--space-xl) var(--space-md); }
.site-footer__bottom { border-top: 1px solid rgba(255,255,255,0.08); padding: var(--space-lg) 0; background: transparent; }
.site-footer__bottom-inner { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-md) var(--space-xl); }
.site-footer__copy, .site-footer__powered { margin: 0; font-size: 0.8125rem; color: rgba(255,255,255,0.5); }
.site-footer__copy strong, .site-footer__powered strong { color: var(--color-text-light); font-weight: 600; }
.site-footer__legal { display: flex; gap: var(--space-lg); font-size: 0.8125rem; }
.site-footer__legal a { color: rgba(255,255,255,0.5); }
.site-footer__legal a:hover { color: var(--color-accent); }

/* ---- FLOATING BOOK CART ---- */
.floating-book-cart { position: fixed; right: 1.25rem; bottom: 1.25rem; z-index: 9999; width: 3.75rem; height: 3.75rem; border-radius: 50%; background: var(--color-red); color: var(--color-white); display: flex; align-items: center; justify-content: center; box-shadow: 0 6px 28px rgba(0,0,0,0.22); text-decoration: none; opacity: 0; visibility: hidden; transform: translateY(16px) scale(0.92); transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease; }
.floating-book-cart.is-visible { opacity: 1; visibility: visible; transform: translateY(0) scale(1); }
.floating-book-cart:hover { color: var(--color-white); outline: 2px solid var(--color-navy); outline-offset: 2px; }
.floating-book-cart svg { width: 1.65rem; height: 1.65rem; stroke: var(--color-white); }

/* ---- SEO CONTENT BLOCK ---- */
.section--seo-content { background: var(--color-white); padding: var(--space-2xl) 0; }
.seo-content { max-width: 56.25rem; margin: 0 auto; padding: var(--space-xl); }
.seo-content__h2 { margin: 0 0 var(--space-md); font-size: clamp(1.25rem,2.5vw,1.5rem); font-weight: 800; color: var(--color-navy); }
.seo-content__h2:not(:first-child) { margin-top: var(--space-2xl); }
.seo-content__p { margin: 0 0 var(--space-lg); font-size: 1.0625rem; line-height: 1.75; color: var(--color-text-muted); }
.seo-content__p a { font-weight: 700; }

/* ---- INVENTORY SECTION ---- */
.inventory-section-shell { max-width: 1200px; margin: 0 auto; width: 100%; }
.inventory-section-header { text-align: center; margin: 0 auto var(--space-xl); max-width: 50rem; display: flex; flex-direction: column; align-items: center; gap: var(--space-md); }
.inventory-section-header__company { margin: 0; font-size: 0.75rem; font-weight: 800; color: var(--color-red); letter-spacing: 0.12em; text-transform: uppercase; }
.inventory-section-header__title { margin: 0; font-size: clamp(2rem,5vw,2.75rem); font-weight: 900; color: var(--color-navy); }
.inventory-section-header__intro { margin: 0; font-size: 1rem; line-height: 1.65; color: var(--color-text); }

/* ============================================================
   V2 DEMO-MATCH COMPONENTS
   Header banner, stat cards, why-choose-us, reviews, service pills,
   FAQ CTA card, section eyebrow, theme image overlay.
   ============================================================ */

/* ---- HEADER TOP BANNER STRIP (navy bar above white nav card — demo image 1) ---- */
.site-header__top-strip {
    background: var(--color-primary); color: var(--color-white);
    padding: 0.5rem 0; font-size: 0.8125rem;
}
.site-header__top-strip .container {
    display: flex; justify-content: space-between; align-items: center;
    gap: var(--space-md); flex-wrap: wrap;
}
.site-header__top-serving { display: flex; align-items: center; gap: 0.4rem; }
.site-header__top-serving::before { content: '🏡'; font-size: 0.95rem; }
.site-header__top-links { display: flex; gap: var(--space-md); }
.site-header__top-link {
    color: rgba(255,255,255,0.92); text-decoration: none; font-weight: 500;
    display: inline-flex; align-items: center; gap: 0.35rem;
}
.site-header__top-link:hover { color: var(--color-accent); }

/* White card nav sits inside the top strip area, overlaps visually */
.site-header__nav-card {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    padding: var(--space-md) var(--space-lg);
    box-shadow: 0 8px 32px rgba(15,52,96,0.12);
    display: flex; align-items: center; justify-content: space-between;
    gap: var(--space-lg);
}
.site-header__nav-card .site-header__brand-wrap { display: flex; align-items: center; gap: var(--space-sm); }
.site-header__call-block { text-align: right; }
.site-header__call-label {
    display: block; font-size: 0.7rem; font-weight: 700;
    letter-spacing: 0.15em; text-transform: uppercase;
    color: var(--color-text-muted); margin-bottom: 0.15rem;
}
.site-header__call-number {
    display: block; font-size: 1.25rem; font-weight: 800;
    color: var(--color-primary); text-decoration: none;
}
.site-header__call-number:hover { color: var(--color-accent); }

/* ---- STAT CARDS (demo image 3: dark navy 2×2 grid, 1 cell gold-highlighted) ---- */
.stat-cards {
    display: grid; grid-template-columns: 1fr 1fr;
    background: #0a1628; color: var(--color-white);
    border-radius: var(--radius-lg); overflow: hidden;
    box-shadow: 0 12px 40px rgba(15,52,96,0.15);
}
.stat-card {
    padding: var(--space-xl) var(--space-lg);
    border-right: 1px solid rgba(255,255,255,0.06);
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.stat-card:nth-child(2n) { border-right: 0; }
.stat-card:nth-last-child(-n+2) { border-bottom: 0; }
.stat-card--highlight { background: var(--color-accent); color: var(--color-primary); }
.stat-card__number {
    display: block; font-size: clamp(2rem, 4vw, 2.75rem); font-weight: 900;
    line-height: 1; letter-spacing: -0.03em; margin-bottom: 0.5rem;
}
.stat-card__label { font-size: 0.875rem; opacity: 0.85; font-weight: 500; }
.stat-card--highlight .stat-card__label { opacity: 1; font-weight: 700; }

/* ---- WHY CHOOSE US FEATURE GRID (demo image 3: 4 small card blocks) ---- */
.why-us { display: grid; grid-template-columns: 1fr; gap: var(--space-2xl); align-items: start; }
@media (min-width: 52rem) { .why-us { grid-template-columns: 1fr 1fr; gap: var(--space-3xl); } }
.why-us__intro { font-size: 1.05rem; color: var(--color-text-muted); line-height: 1.65; margin-bottom: var(--space-xl); }
.why-us__features { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); }
.why-feature {
    padding: var(--space-lg);
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    transition: border-color var(--transition), transform var(--transition);
}
.why-feature:hover { border-color: var(--color-accent); transform: translateY(-2px); }
.why-feature__icon {
    display: flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; margin-bottom: 0.75rem;
    background: rgba(15,52,96,0.06); border-radius: var(--radius);
    color: var(--color-primary);
}
.why-feature__title { font-size: 1rem; font-weight: 800; color: var(--color-primary); margin-bottom: 0.35rem; }
.why-feature__desc { font-size: 0.875rem; color: var(--color-text-muted); line-height: 1.5; }

/* ---- SERVICE AREA PILLS (demo image 4: "[City]", "[Suburb 1]"…) ---- */
.area-pills { display: flex; flex-wrap: wrap; gap: 0.65rem; }
.area-pill {
    display: inline-flex; align-items: center; padding: 0.5rem 1rem;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    font-size: 0.875rem; font-weight: 500; color: var(--color-primary);
    text-decoration: none; transition: all var(--transition);
}
.area-pill:hover {
    background: var(--color-primary); color: var(--color-white);
    border-color: var(--color-primary); transform: translateY(-1px);
}
.area-pill--more {
    background: transparent; border-color: transparent;
    color: var(--color-primary); font-weight: 700;
}
.area-pill--more:hover { background: transparent; color: var(--color-accent); }

/* ---- REVIEW CARDS (demo image 4: 3-up, stars, avatar+name+date+verified) ---- */
.reviews-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); }
@media (min-width: 52rem) { .reviews-grid { grid-template-columns: repeat(3, 1fr); } }
.review-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--space-lg);
    display: flex; flex-direction: column; gap: var(--space-md);
}
.review-card__stars { color: var(--color-review-star); font-size: 1rem; letter-spacing: 0.05em; }
.review-card__quote { font-size: 0.9375rem; line-height: 1.65; color: var(--color-text); font-style: italic; margin: 0; }
.review-card__attribution { display: flex; align-items: center; gap: 0.75rem; margin-top: auto; padding-top: var(--space-sm); border-top: 1px solid var(--color-border); }
.review-card__avatar {
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--color-primary); color: var(--color-white);
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 0.8125rem; flex-shrink: 0;
}
.review-card__meta { display: flex; flex-direction: column; gap: 0.1rem; }
.review-card__name { font-weight: 700; font-size: 0.9375rem; color: var(--color-primary); }
.review-card__date { font-size: 0.75rem; color: var(--color-text-muted); }
.review-card__verified { font-size: 0.75rem; color: #16A596; font-weight: 600; display: inline-flex; align-items: center; gap: 0.25rem; }
.review-card__verified::before { content: '✓'; }

/* Review summary bar (demo: "4.9 ★★★★★ Based on 320+ Google Reviews") */
.reviews-summary { display: flex; align-items: center; gap: 0.75rem; }
.reviews-summary__score { font-size: 2.5rem; font-weight: 900; color: var(--color-primary); line-height: 1; letter-spacing: -0.03em; }
.reviews-summary__stars { color: var(--color-review-star); font-size: 1.15rem; display: block; margin-bottom: 0.25rem; }
.reviews-summary__count { font-size: 0.8125rem; color: var(--color-text-muted); }

/* ---- FAQ CTA CARD (demo image 5: blue card next to FAQ with "Let's Make Your Event Unforgettable") ---- */
.faq-cta-card {
    background: var(--color-primary);
    color: var(--color-white);
    border-radius: var(--radius-lg);
    padding: var(--space-2xl);
    display: flex; flex-direction: column; gap: var(--space-lg);
}
.faq-cta-card__eyebrow { font-size: 0.75rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(255,255,255,0.75); }
.faq-cta-card__title { font-size: clamp(1.5rem, 3vw, 2rem); font-weight: 900; line-height: 1.15; color: var(--color-white); letter-spacing: -0.02em; margin: 0; }
.faq-cta-card__title .gold-text, .faq-cta-card__title .accent-word { color: var(--color-accent); }
.faq-cta-card__sub { font-size: 0.95rem; color: rgba(255,255,255,0.85); line-height: 1.55; margin: 0; }
.faq-cta-card__phone {
    display: inline-block; font-size: 1.75rem; font-weight: 900;
    color: var(--color-accent); text-decoration: none; letter-spacing: -0.01em;
    margin: 0.25rem 0;
}
.faq-cta-card__phone:hover { color: var(--color-accent); filter: brightness(1.15); }
.faq-cta-card__buttons { display: flex; flex-direction: column; gap: 0.65rem; }
.faq-cta-card__btn {
    display: flex; align-items: center; justify-content: center;
    padding: 0.9rem var(--space-lg);
    font-weight: 700; font-size: 0.9375rem;
    border-radius: var(--radius); text-decoration: none;
    transition: all var(--transition);
}
.faq-cta-card__btn--primary { background: var(--color-white); color: var(--color-primary); }
.faq-cta-card__btn--primary:hover { background: var(--color-accent); color: var(--color-primary); }
.faq-cta-card__btn--outline { background: transparent; color: var(--color-white); border: 1.5px solid rgba(255,255,255,0.5); }
.faq-cta-card__btn--outline:hover { background: rgba(255,255,255,0.1); color: var(--color-white); border-color: var(--color-white); }

/* FAQ section grid: accordion left, CTA card right */
.faq-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-xl); align-items: start; }
@media (min-width: 52rem) { .faq-grid { grid-template-columns: 1fr 1fr; gap: var(--space-2xl); } }

/* ---- SERVICE AREA SECTION (demo image 4: left intro + pills, right map card) ---- */
.service-area-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-xl); align-items: start; }
@media (min-width: 52rem) { .service-area-grid { grid-template-columns: 1fr 1fr; gap: var(--space-2xl); } }
.service-area-intro { font-size: 1.05rem; line-height: 1.65; color: var(--color-text-muted); margin: 0 0 var(--space-lg); }
.service-area-map {
    aspect-ratio: 4/3; width: 100%; background: var(--color-white);
    border: 1px solid var(--color-border); border-radius: var(--radius-lg);
    overflow: hidden; box-shadow: 0 8px 32px rgba(15,52,96,0.08);
    display: flex; align-items: center; justify-content: center;
    color: var(--color-text-muted); font-size: 0.9375rem;
}
.service-area-map iframe { width: 100%; height: 100%; border: 0; }

/* ---- THEME-LEVEL UTILITIES ---- */
.eyebrow {
    display: block; font-size: 0.75rem; font-weight: 700;
    letter-spacing: 0.15em; text-transform: uppercase;
    color: var(--color-primary); margin-bottom: 0.75rem;
}
.gold-text, .accent-word { color: var(--color-accent); }
.text-muted { color: var(--color-text-muted); }
.lead { font-size: 1.125rem; line-height: 1.6; color: var(--color-text-muted); }


/* ---- HEADER NAV CARD GLUE (Stage 3) ---- */
.site-header { background: transparent; }
.site-header__nav-wrap { background: var(--color-primary); padding: 0 0 var(--space-lg); }
@media (min-width: 960px) { .site-header__nav-wrap { padding: var(--space-sm) 0 var(--space-lg); } }

.site-header__nav-card {
    display: grid; align-items: center;
    grid-template-columns: auto 1fr auto auto;
    gap: var(--space-md) var(--space-lg);
    padding: var(--space-sm) var(--space-lg);
    background: var(--color-white);
    border-radius: var(--radius-lg);
    box-shadow: 0 8px 32px rgba(15,52,96,0.15);
}
@media (max-width: 959px) {
    .site-header__nav-card {
        grid-template-columns: 1fr auto auto;
        padding: var(--space-sm) var(--space-md);
    }
}

/* Primary nav inside card */
.site-nav--primary { display: flex; align-items: center; justify-content: center; }
.site-nav--primary .menu--primary {
    list-style: none; margin: 0; padding: 0;
    display: flex; gap: var(--space-lg); align-items: center;
}
.site-nav--primary .menu-item { position: relative; }
.site-nav--primary .menu-item > a {
    color: var(--color-text); font-weight: 600; font-size: 0.95rem;
    text-decoration: none; padding: 0.5rem 0; display: inline-block;
    transition: color var(--transition);
}
.site-nav--primary .menu-item > a:hover { color: var(--color-accent); }
.site-nav--primary .menu-item-has-children > a::after {
    content: ' ▾'; font-size: 0.75rem; opacity: 0.6;
}
.site-nav--primary .sub-menu {
    position: absolute; top: 100%; left: 0; min-width: 220px;
    background: var(--color-white); border: 1px solid var(--color-border);
    border-radius: var(--radius); box-shadow: 0 8px 24px rgba(15,52,96,0.12);
    padding: 0.5rem 0; list-style: none; margin: 0.5rem 0 0;
    display: none; z-index: 100;
}
.site-nav--primary .menu-item:hover .sub-menu,
.site-nav--primary .menu-item:focus-within .sub-menu { display: block; }
.site-nav--primary .sub-menu .menu-item > a {
    display: block; padding: 0.5rem 1rem; font-size: 0.875rem; color: var(--color-text);
}
.site-nav--primary .sub-menu .menu-item > a:hover { background: var(--color-offwhite); color: var(--color-primary); }

/* Header call block */
.site-header__call-block { text-align: right; display: none; }
@media (min-width: 960px) { .site-header__call-block { display: block; } }

.site-header__book-btn { display: none; white-space: nowrap; min-height: 2.5rem; padding: 0 var(--space-md); font-size: 0.8125rem; }
@media (min-width: 960px) { .site-header__book-btn { display: inline-flex; } }

/* Mobile book + hamburger */
.site-header__mobile-book-btn {
    display: inline-flex; align-items: center; padding: 0.5rem 0.9rem;
    background: var(--color-accent); color: var(--color-primary);
    font-weight: 700; border-radius: var(--radius); text-decoration: none; font-size: 0.8125rem;
}
@media (min-width: 960px) { .site-header__mobile-book-btn { display: none; } }

.site-nav__hamburger {
    width: 36px; height: 36px; border: 0; background: transparent; cursor: pointer;
    display: flex; align-items: center; justify-content: center; padding: 0;
}
@media (min-width: 960px) { .site-nav__hamburger { display: none; } }
.site-nav-mobile__bars, .site-nav-mobile__bars::before, .site-nav-mobile__bars::after {
    display: block; width: 22px; height: 2px; background: var(--color-primary); border-radius: 2px;
    position: relative; transition: transform 0.2s;
}
.site-nav-mobile__bars::before, .site-nav-mobile__bars::after {
    content: ''; position: absolute; left: 0;
}
.site-nav-mobile__bars::before { top: -7px; }
.site-nav-mobile__bars::after  { top: 7px; }

/* Mobile: hide desktop nav by default, toggle with .is-open */
@media (max-width: 959px) {
    .site-nav--primary {
        display: none; position: absolute;
        top: 100%; left: 0; right: 0;
        background: var(--color-white);
        padding: var(--space-md);
        border-radius: var(--radius);
        box-shadow: 0 12px 32px rgba(15,52,96,0.18);
        z-index: 100;
    }
    .site-nav--primary.is-open { display: block; }
    .site-nav--primary .menu--primary { flex-direction: column; align-items: stretch; gap: 0; }
    .site-nav--primary .menu-item > a { padding: 0.75rem; border-bottom: 1px solid var(--color-border); }
    .site-nav--primary .sub-menu {
        position: static; box-shadow: none; border: 0; margin: 0;
        padding-left: var(--space-md);
    }
}

/* Hide mobile-only selectively */
.nav-desktop-only { display: none; }
@media (min-width: 960px) { .nav-desktop-only { display: inline-flex; } }


/* ============================================================
   V2.1 STAGE-3 FIXES
   - Bigger logo (56px → 72px)
   - Top strip link polish (Facebook/Reviews pill style)
   - Hero overlay contrast fix (text was getting dimmed by ::after)
   - Hero headline legibility
   ============================================================ */

/* Logo: bigger, cleaner */
.site-header__logo-link img,
.site-header__brand-wrap img,
.custom-logo-link img {
    max-height: 110px !important;
    max-width: 340px !important;
    width: auto !important;
    height: auto !important;
    display: block;
    object-fit: contain;
}

/* Nav card: give logo room to breathe */
.site-header__nav-card {
    padding: var(--space-sm) var(--space-lg);
    min-height: 96px;
}

/* Top strip links: pill style matching the demo */
.site-header__top-link {
    display: inline-flex; align-items: center; gap: 0.4rem;
    padding: 0.25rem 0.7rem;
    border: 1px solid rgba(255,255,255,0.25);
    border-radius: 999px;
    font-size: 0.8125rem; font-weight: 500;
    color: rgba(255,255,255,0.92) !important;
    text-decoration: none;
    transition: all var(--transition);
}
.site-header__top-link:hover {
    background: rgba(255,255,255,0.12);
    border-color: rgba(255,255,255,0.4);
    color: var(--color-white) !important;
}
.site-header__top-link svg { opacity: 0.9; }

/* Top strip itself: ensure crisp navy, no washed-out overlay */
.site-header__top-strip {
    background: var(--color-primary) !important;
    padding: 0.55rem 0;
    font-size: 0.8125rem;
    position: relative;
    z-index: 10;
}
.site-header__top-serving {
    color: rgba(255,255,255,0.92);
    font-weight: 500;
}
.site-header__top-serving strong {
    color: var(--color-white);
    font-weight: 700;
}

/* Nav wrap: remove extra padding that was creating visual gap */
.site-header__nav-wrap {
    background: var(--color-primary);
    padding-bottom: var(--space-md);
    padding-top: 0;
}


/* ============================================================
   HERO TEXT POLISH (base hero rules are at top of file, lines ~205-265)
   ============================================================ */
.hero-headline,
.site-hero h1 {
    color: var(--color-white) !important;
    text-shadow: 0 2px 12px rgba(0,0,0,0.55), 0 0 28px rgba(0,0,0,0.35);
}
.hero-headline .gold-text,
.site-hero h1 .gold-text,
.hero-headline span[class*="gold"],
.site-hero h1 span[class*="gold"] {
    color: var(--color-accent) !important;
    text-shadow: 0 2px 12px rgba(0,0,0,0.55), 0 0 28px rgba(0,0,0,0.35);
}
.hero__subhead, .site-hero__sub,
.hero__features li {
    text-shadow: 0 1px 8px rgba(0,0,0,0.55);
}

/* Hero badge: match demo's pill style */
.site-hero__badge {
    background: rgba(226,182,74,0.15);
    border: 1px solid rgba(226,182,74,0.5);
    color: var(--color-accent);
    padding: 0.35rem 1rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    display: inline-block;
    margin-bottom: var(--space-lg);
}

/* ============================================================
   V2.3 NUCLEAR HERO FIX
   Force transparent on every possible hero child.
   If anything was painting a bg color between the image and the text,
   this strips it. Uses max specificity + !important.
   ============================================================ */
section.hero,
section.site-hero,
.hero .hero__overlay,
.site-hero .hero__overlay,
.hero__overlay,
.hero__content,
.site-hero__inner,
.hero .container,
.site-hero .container,
.hero .hero__content,
.site-hero .site-hero__inner {
    background: transparent !important;
    background-color: transparent !important;
}

/* But the section itself needs the image */
section.hero[style*="--hero-bg"],
section.site-hero[style*="--hero-bg"] {
    background-image: var(--hero-bg) !important;
    background-color: #0a1628 !important;  /* neutral dark fallback, NOT brand primary */
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
}

/* Kill the .hero__media div completely — multiple selectors for specificity */
.hero .hero__media,
.site-hero .hero__media,
section .hero__media,
div.hero__media {
    display: none !important;
    visibility: hidden !important;
    background: none !important;
    opacity: 0 !important;
}


/* ============================================================
   V2.4 FINAL CATCH-ALL — no block ever
   Applied after all other rules; targets everything inside hero section.
   ============================================================ */
.hero > *, .site-hero > *,
.hero > * > *, .site-hero > * > *,
.hero .hero__overlay, .site-hero .hero__overlay,
.hero .hero__content, .site-hero .hero__content,
.hero .site-hero__inner, .site-hero .site-hero__inner,
.hero .container, .site-hero .container {
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
}

/* OVERLAY COMPLETELY DISABLED */
.hero::after, .site-hero::after {
    content: none !important;
    background: none !important;
    display: none !important;
}

/* Smaller hero height */
.hero, .site-hero {
    min-height: 420px !important;
    max-height: 560px;
}
.hero__overlay {
    padding: var(--space-xl) 0 !important;
}


/* ============================================================
   V2.5 HERO POLISH
   1. Subtle full-image overlay for text contrast
   2. Center hero content horizontally
   3. Ensure badge shows (it was gone because flex alignment was off)
   4. Tighten vertical spacing to pull CTA+rating up into view
   ============================================================ */

/* NO overlay — image shows 100% clean, text legibility via shadow only */
.hero::after, .site-hero::after {
    content: none !important;
    display: none !important;
    background: none !important;
}

/* CENTER the content horizontally in the hero */
.hero, .site-hero {
    align-items: center;
    text-align: center;
}

/* Center inner content block */
.hero__content, .site-hero__inner {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    max-width: 720px;
    padding-left: var(--space-lg);
    padding-right: var(--space-lg);
}

/* Badge: force visible and centered above headline */
.site-hero__badge {
    display: inline-block !important;
    margin: 0 auto var(--space-md) !important;
}

/* Headline + subheadline both centered */
.hero-headline,
.site-hero h1,
.hero__subhead,
.site-hero__sub {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

/* Tighten vertical spacing — pull CTA and rating up */
.hero-headline, .site-hero h1 {
    margin: 0 auto var(--space-sm) !important;
}
.hero__subhead, .site-hero__sub {
    margin: 0 auto var(--space-md) !important;
    max-width: 580px;
}

/* CTAs centered */
.hero__cta-wrap, .site-hero__ctas {
    justify-content: center;
    margin: 0 auto var(--space-sm) !important;
}

/* Rating centered and tight */
.hero__rating {
    justify-content: center;
    margin-top: 0 !important;
}

/* Reduce hero vertical padding so everything sits higher in view */
.hero__overlay {
    padding: var(--space-lg) 0 !important;
}
.hero, .site-hero {
    padding: var(--space-lg) 0 !important;
    min-height: 460px !important;
    max-height: 560px;
}


/* ============================================================
   V2.6 FINAL HERO CLEANUP
   - No overlay at all (see overlay rule above)
   - Strong text-shadow for legibility over any image
   - Headline shrunk and tightened to fit 2 lines
   - Content moved higher in viewport
   ============================================================ */

/* Strong text shadow on ALL hero text — replaces the overlay for legibility */
.hero-headline, .site-hero h1,
.hero-headline *, .site-hero h1 * {
    text-shadow: 0 2px 6px rgba(0,0,0,0.75), 0 2px 16px rgba(0,0,0,0.55), 0 0 2px rgba(0,0,0,0.9) !important;
}
.hero__subhead, .site-hero__sub,
.hero__rating-text, .hero__rating-stars {
    text-shadow: 0 1px 4px rgba(0,0,0,0.8), 0 1px 12px rgba(0,0,0,0.6) !important;
}
.site-hero__badge {
    text-shadow: 0 1px 3px rgba(0,0,0,0.5) !important;
    background: rgba(226,182,74,0.2) !important;
    border: 1px solid rgba(226,182,74,0.7) !important;
}

/* Headline: a bit smaller + tighter to fit 2 lines cleanly */
.hero-headline, .site-hero h1 {
    font-size: clamp(1.6rem, 3.6vw, 2.4rem) !important;
    line-height: 1.15 !important;
    letter-spacing: -0.015em !important;
    margin: 0 auto var(--space-xs) !important;
    max-width: 680px;
}

/* Content wrapper: move UP + keep hero compact so all content fits in view */
.hero, .site-hero {
    justify-content: center !important;
    padding-top: var(--space-lg) !important;
    padding-bottom: var(--space-lg) !important;
    min-height: 0 !important;
    height: auto !important;
    max-height: none !important;
}

/* Tighten everything's vertical spacing */
.site-hero__badge { margin-bottom: var(--space-sm) !important; }
.hero__subhead, .site-hero__sub { margin: 0 auto var(--space-sm) !important; max-width: 560px; }
.hero__cta-wrap, .site-hero__ctas { margin: 0 auto var(--space-xs) !important; }
.hero__rating { margin-top: var(--space-xs) !important; }


/* ============================================================
   V2.7 FULL IMAGE TINT — subtle dark overlay on whole hero image
   No panel around text, no blur — just a soft universal tint
   ============================================================ */
.hero__content, .site-hero__inner {
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    max-width: 720px !important;
}

/* Subtle dark tint on the entire hero image via ::after */
.hero::after, .site-hero::after {
    content: none !important;
    display: none !important;
    background: none !important;
}

/* Content sits above the tint */
.hero__content, .site-hero__inner {
    position: relative !important;
    z-index: 3 !important;
}

/* Strong text shadow — no overlay, text needs heavy shadow for legibility */
.hero-headline, .site-hero h1,
.hero-headline *, .site-hero h1 *,
.hero__subhead, .site-hero__sub,
.hero__rating-text, .hero__rating-stars {
    text-shadow: 0 2px 8px rgba(0,0,0,0.85), 0 0 2px rgba(0,0,0,1), 0 4px 20px rgba(0,0,0,0.6) !important;
}


/* ============================================================
   V2.8 BADGE — solid yellow/gold, white text
   ============================================================ */
.site-hero__badge,
.hero .site-hero__badge,
.site-hero .site-hero__badge {
    background: var(--color-accent) !important;
    background-color: var(--color-accent) !important;
    color: var(--color-white) !important;
    border: none !important;
    text-shadow: none !important;
    padding: 0.5rem 1.1rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.08em !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.25);
}

/* ============================================================
   BUSINESS INFO CARD (replaces stat cards in Why Us section)
   Styled after Party Right Rentals info card
   ============================================================ */
.biz-info-card {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    box-shadow: 0 4px 20px rgba(15, 52, 96, 0.1);
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    height: fit-content;
}

.biz-info-card__name {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--color-primary);
    line-height: 1.2;
}

.biz-info-card__tagline {
    margin: 0.25rem 0 var(--space-sm);
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
}

/* Rating pill box */
.biz-info-card__rating {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    text-decoration: none;
    color: inherit;
    transition: border-color var(--transition), transform var(--transition);
}
.biz-info-card__rating:hover {
    border-color: var(--color-accent);
    transform: translateY(-1px);
}
.biz-info-card__stars {
    color: var(--color-review-star);
    font-size: 1rem;
    letter-spacing: 0.05em;
}
.biz-info-card__rating-num {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--color-primary);
}
.biz-info-card__rating-count {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    flex: 1;
}
.biz-info-card__rating-source {
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    color: var(--color-primary);
}

/* Info rows (service area, phone, hours) */
.biz-info-card__row {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    padding: 0.65rem 0;
    border-bottom: 1px solid var(--color-border);
}
.biz-info-card__row:last-of-type {
    border-bottom: none;
}
.biz-info-card__row--link {
    text-decoration: none;
    color: inherit;
    transition: transform var(--transition);
}
.biz-info-card__row--link:hover {
    transform: translateX(2px);
}
.biz-info-card__row-icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(226, 182, 74, 0.12);
    color: var(--color-accent);
    border-radius: 50%;
}
.biz-info-card__row > div:last-child {
    flex: 1;
    min-width: 0;
}
.biz-info-card__row-label {
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.15rem;
}
.biz-info-card__row-value {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-primary);
    line-height: 1.3;
    word-break: break-word;
}

/* OPEN NOW badge */
.biz-info-card__open-badge {
    display: none;
    padding: 0.15rem 0.5rem;
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    border-radius: 999px;
    line-height: 1;
}
.biz-info-card__open-badge[data-status="open"] {
    display: inline-block;
    background: #16A34A;
    color: var(--color-white);
}
.biz-info-card__open-badge[data-status="closed"] {
    display: inline-block;
    background: #DC2626;
    color: var(--color-white);
}

/* ZIP check form */
.biz-info-card__zip-form {
    display: flex;
    gap: 0.5rem;
    margin-top: var(--space-xs);
}
.biz-info-card__zip-input {
    flex: 1;
    min-width: 0;
    padding: 0.75rem 0.85rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: 0.9375rem;
    font-family: inherit;
    color: var(--color-primary);
    background: var(--color-white);
    transition: border-color var(--transition);
}
.biz-info-card__zip-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(226, 182, 74, 0.15);
}
.biz-info-card__zip-btn {
    padding: 0.75rem 1.1rem;
    background: var(--color-primary);
    color: var(--color-white);
    border: none;
    border-radius: var(--radius);
    font-size: 0.9375rem;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    white-space: nowrap;
    transition: background var(--transition), transform var(--transition);
}
.biz-info-card__zip-btn:hover {
    background: var(--color-primary);
    filter: brightness(0.92);
    transform: translateY(-1px);
}

/* Book Now button */
.biz-info-card__book-btn {
    display: block;
    padding: 0.95rem;
    background: var(--color-primary);
    color: var(--color-white);
    text-align: center;
    text-decoration: none;
    border-radius: var(--radius);
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    margin-top: var(--space-xs);
    transition: filter var(--transition), transform var(--transition);
    box-shadow: 0 3px 12px rgba(15, 52, 96, 0.2);
}
.biz-info-card__book-btn:hover {
    filter: brightness(1.1);
    transform: translateY(-2px);
    color: var(--color-white);
}

/* Override — when biz-info-card is in .why-us grid, it replaces the stat-cards cell */
.why-us .biz-info-card {
    margin: 0;
}


/* ============================================================
   V2.9 WHY-FEATURE CARDS — SOLID BLUE, WHITE TEXT
   Uses brand primary so color-picker changes auto-apply
   ============================================================ */
.why-feature {
    background: var(--color-primary) !important;
    border: 1px solid var(--color-primary) !important;
    border-radius: var(--radius) !important;
    padding: var(--space-lg) !important;
    color: var(--color-white) !important;
    transition: background-color var(--transition), transform var(--transition), box-shadow var(--transition) !important;
}
.why-feature:hover {
    background: color-mix(in srgb, var(--color-primary) 88%, black) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px color-mix(in srgb, var(--color-primary) 30%, transparent) !important;
}
.why-feature__title {
    color: var(--color-white) !important;
}
.why-feature__desc {
    color: rgba(255, 255, 255, 0.88) !important;
}
/* Icon circle: light translucent white tint on solid blue bg */
.why-feature__icon {
    background: rgba(255, 255, 255, 0.15) !important;
    color: var(--color-white) !important;
}
/* Fallback for browsers without color-mix */
@supports not (background: color-mix(in srgb, red, blue)) {
    .why-feature:hover {
        background: #0a2244 !important;
        box-shadow: 0 8px 24px rgba(15, 52, 96, 0.3) !important;
    }
}

/* ============================================================
   BIZ INFO CARD — solid blue border + stronger shadow
   ============================================================ */
.biz-info-card {
    border: 2px solid var(--color-primary) !important;
    box-shadow: 0 8px 32px color-mix(in srgb, var(--color-primary) 18%, transparent),
                0 2px 8px rgba(0, 0, 0, 0.06) !important;
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .biz-info-card {
        box-shadow: 0 8px 32px rgba(15, 52, 96, 0.18),
                    0 2px 8px rgba(0, 0, 0, 0.06) !important;
    }
}


/* ============================================================
   V3.0 — Area pills, map border, footer polish
   ============================================================ */

/* Service-area pills: SOLID BLUE with white text */
.area-pill {
    background: var(--color-primary) !important;
    border: 1px solid var(--color-primary) !important;
    color: var(--color-white) !important;
    font-weight: 700 !important;
    transition: filter var(--transition), transform var(--transition) !important;
}
.area-pill:hover {
    background: var(--color-primary) !important;
    filter: brightness(0.88) !important;
    transform: translateY(-1px) !important;
    color: var(--color-white) !important;
}
.area-pill--more {
    background: transparent !important;
    border-color: var(--color-primary) !important;
    color: var(--color-primary) !important;
}
.area-pill--more:hover {
    background: var(--color-primary) !important;
    color: var(--color-white) !important;
}

/* Service area map: blue border + subtle shadow */
.service-area-map {
    border: 2px solid var(--color-primary) !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden;
    box-shadow: 0 8px 32px color-mix(in srgb, var(--color-primary) 18%, transparent),
                0 2px 8px rgba(0, 0, 0, 0.06) !important;
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .service-area-map {
        box-shadow: 0 8px 32px rgba(15, 52, 96, 0.18),
                    0 2px 8px rgba(0, 0, 0, 0.06) !important;
    }
}

/* ============================================================
   FOOTER — make dark bg use brand primary, bigger logo, inverted pills
   ============================================================ */
.site-footer {
    background: var(--color-primary) !important;
    color: var(--color-white) !important;
}
.site-footer *:not(.area-pill--footer):not(.area-pill--footer *) {
    /* Reset inherited colors inside footer except for pills (handled below) */
}

/* Bigger logo in footer brand column */
.site-footer__logo img,
.site-footer__col--brand img {
    max-height: 160px !important;
    max-width: 380px !important;
    width: auto !important;
    height: auto !important;
    display: block;
    object-fit: contain;
}

/* Footer headings, links, text contrast tweaks for brand-primary bg */
.site-footer__heading {
    color: var(--color-white) !important;
    opacity: 0.95;
}
.site-footer a:not(.area-pill--footer):not(.site-footer__social-link) {
    color: rgba(255, 255, 255, 0.88) !important;
}
.site-footer a:not(.area-pill--footer):not(.site-footer__social-link):hover {
    color: var(--color-accent) !important;
}
.site-footer__tagline, .site-footer__copy,
.site-footer__brand-name, .site-footer__brand-sub,
.site-footer__contact-line {
    color: rgba(255, 255, 255, 0.85) !important;
}
.site-footer__contact-line a {
    color: var(--color-accent) !important;
    font-weight: 800;
}
.site-footer__contact-line a:hover {
    filter: brightness(1.15);
}

/* Social icons on brand-primary bg */
.site-footer__social-link {
    background: rgba(255, 255, 255, 0.12) !important;
    color: var(--color-white) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
}
.site-footer__social-link:hover {
    background: var(--color-accent) !important;
    color: var(--color-white) !important;
    border-color: var(--color-accent) !important;
}

/* City pills in footer: INVERTED — white bg, blue text */
.area-pill--footer {
    background: var(--color-white) !important;
    border: 1px solid var(--color-white) !important;
    color: var(--color-primary) !important;
    font-weight: 700 !important;
    transition: filter var(--transition), transform var(--transition) !important;
}
.area-pill--footer:hover {
    background: var(--color-accent) !important;
    border-color: var(--color-accent) !important;
    color: var(--color-white) !important;
    transform: translateY(-1px) !important;
}

/* Footer city strip: tone down separator and eyebrow text */
.site-footer__city-strip {
    background: rgba(0, 0, 0, 0.08) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.site-footer__city-strip p {
    color: rgba(255, 255, 255, 0.75) !important;
}

/* Bottom copyright strip — slightly darker than main footer */
.site-footer__bottom {
    background: rgba(0, 0, 0, 0.12) !important;
    color: rgba(255, 255, 255, 0.7) !important;
}

/* ============================================================
   V3.1 — Category card consistency
   Force description to reserve 3 lines even if content is shorter
   ============================================================ */
.rental-cat-card__desc {
    font-size: 0.9rem !important;
    color: var(--color-text-muted) !important;
    line-height: 1.5 !important;
    min-height: calc(1.5em * 3);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Ensure card body fills remaining space so CTAs align at bottom */
.rental-cat-card {
    display: flex;
    flex-direction: column;
    height: 100%;
}
.rental-cat-card__body {
    display: flex;
    flex-direction: column;
    flex: 1;
}
.rental-cat-card__cta {
    margin-top: auto;
}


/* ============================================================
   V4.0 PHASE 3 — HOW IT WORKS, PRICING GUIDE, ABOUT + E-E-A-T
   Each section styled to match existing design system
   Uses color-mix() with brand primary — re-themes with color picker
   ============================================================ */

/* ============================================================
   HOW IT WORKS — 4-step timeline
   ============================================================ */
.hiw-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-lg);
    counter-reset: hiw-counter;
}
.hiw-step {
    position: relative;
    padding: var(--space-xl) var(--space-lg);
    background: var(--color-white);
    border: 2px solid color-mix(in srgb, var(--color-primary) 15%, var(--color-white));
    border-radius: var(--radius-lg);
    transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .hiw-step {
        border-color: rgba(15, 52, 96, 0.2);
    }
}
.hiw-step:hover {
    border-color: var(--color-primary);
    transform: translateY(-4px);
    box-shadow: 0 12px 32px color-mix(in srgb, var(--color-primary) 18%, transparent);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .hiw-step:hover {
        box-shadow: 0 12px 32px rgba(15, 52, 96, 0.18);
    }
}
.hiw-step__number-wrap {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: var(--space-md);
}
.hiw-step__number {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-primary);
    color: var(--color-white);
    border-radius: 50%;
    font-size: 1.35rem;
    font-weight: 800;
    font-family: var(--font-heading);
    line-height: 1;
}
.hiw-step__icon {
    font-size: 1.75rem;
    line-height: 1;
}
.hiw-step__title {
    margin: 0 0 var(--space-sm);
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--color-primary);
    line-height: 1.3;
}
.hiw-step__desc {
    margin: 0;
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--color-text-muted);
}

/* Connector arrow between steps (desktop) */
.hiw-step:not(:last-child)::after {
    content: '';
    position: absolute;
    top: calc(var(--space-xl) + 24px);
    right: -22px;
    width: 24px;
    height: 2px;
    background: color-mix(in srgb, var(--color-primary) 25%, transparent);
    z-index: 1;
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .hiw-step:not(:last-child)::after {
        background: rgba(15, 52, 96, 0.25);
    }
}

@media (max-width: 960px) {
    .hiw-grid { grid-template-columns: repeat(2, 1fr); }
    .hiw-step:not(:last-child)::after,
    .hiw-step:nth-child(2)::after { display: none; }
}
@media (max-width: 560px) {
    .hiw-grid { grid-template-columns: 1fr; }
    .hiw-step::after { display: none !important; }
}

/* ============================================================
   PRICING GUIDE — table + factors grid
   ============================================================ */
.pricing-table-wrap {
    max-width: 960px;
    margin: 0 auto;
    background: var(--color-white);
    border: 2px solid color-mix(in srgb, var(--color-primary) 15%, var(--color-white));
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 6px 24px color-mix(in srgb, var(--color-primary) 12%, transparent);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .pricing-table-wrap {
        border-color: rgba(15, 52, 96, 0.2);
        box-shadow: 0 6px 24px rgba(15, 52, 96, 0.12);
    }
}

.pricing-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 1rem;
}
.pricing-table thead {
    background: var(--color-primary);
    color: var(--color-white);
}
.pricing-table th {
    padding: var(--space-md) var(--space-lg);
    text-align: left;
    font-size: 0.8125rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-white);
}
.pricing-table th.pricing-table__price-col {
    text-align: right;
}
.pricing-table td {
    padding: var(--space-md) var(--space-lg);
    border-top: 1px solid color-mix(in srgb, var(--color-primary) 10%, var(--color-white));
    color: var(--color-text);
    vertical-align: middle;
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .pricing-table td {
        border-top-color: rgba(15, 52, 96, 0.1);
    }
}
.pricing-table tbody tr:hover {
    background: color-mix(in srgb, var(--color-primary) 4%, var(--color-white));
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .pricing-table tbody tr:hover {
        background: rgba(15, 52, 96, 0.04);
    }
}
.pricing-table__cat {
    font-weight: 700;
    color: var(--color-primary);
}
.pricing-table__price {
    text-align: right;
    font-weight: 800;
    color: var(--color-primary);
    font-size: 1.25rem;
    white-space: nowrap;
}
.pricing-table__price-unit {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-text-muted);
    margin-left: 0.15rem;
}

/* Pricing table mobile: card layout */
@media (max-width: 720px) {
    .pricing-table thead { display: none; }
    .pricing-table,
    .pricing-table tbody,
    .pricing-table tr,
    .pricing-table td { display: block; width: 100%; }
    .pricing-table tr {
        padding: var(--space-md) var(--space-lg);
        border-top: 1px solid color-mix(in srgb, var(--color-primary) 12%, var(--color-white));
    }
    .pricing-table td {
        padding: 0.35rem 0;
        border: none;
        display: flex;
        justify-content: space-between;
        align-items: center;
        gap: 1rem;
    }
    .pricing-table td::before {
        content: attr(data-label);
        font-size: 0.7rem;
        font-weight: 800;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: var(--color-text-muted);
        flex-shrink: 0;
    }
    .pricing-table__cat { font-size: 1.1rem; padding-bottom: 0.5rem !important; border-bottom: 1px solid color-mix(in srgb, var(--color-primary) 10%, transparent) !important; margin-bottom: 0.5rem; }
    .pricing-table__cat::before { display: none; }
    .pricing-table__price { font-size: 1.35rem; text-align: right; }
}

/* Pricing factors grid */
.pricing-factors {
    margin-top: var(--space-3xl);
    max-width: 1080px;
    margin-left: auto;
    margin-right: auto;
}
.pricing-factors__title {
    text-align: center;
    margin: 0 0 var(--space-xl);
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--color-primary);
}
.pricing-factors__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
}
.pricing-factor {
    padding: var(--space-lg);
    background: var(--color-white);
    border-left: 4px solid var(--color-accent);
    border-radius: 0 var(--radius) var(--radius) 0;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}
.pricing-factor__label {
    font-size: 1rem;
    font-weight: 800;
    color: var(--color-primary);
    margin-bottom: 0.5rem;
}
.pricing-factor p {
    margin: 0;
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--color-text-muted);
}

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

/* ============================================================
   ABOUT + E-E-A-T TRUST SIGNALS
   ============================================================ */
.about-layout {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: var(--space-2xl);
    align-items: start;
}
@media (max-width: 960px) {
    .about-layout { grid-template-columns: 1fr; gap: var(--space-xl); }
}

.about-content__text p {
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--color-text);
    margin: 0 0 var(--space-md);
}
.about-content__text p:last-child {
    margin-bottom: 0;
}

/* Owner block */
.about-owner {
    display: flex;
    gap: var(--space-lg);
    align-items: flex-start;
    margin-top: var(--space-xl);
    padding: var(--space-lg);
    background: color-mix(in srgb, var(--color-primary) 4%, var(--color-white));
    border-left: 4px solid var(--color-accent);
    border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .about-owner { background: rgba(15, 52, 96, 0.04); }
}
.about-owner__img {
    flex-shrink: 0;
    width: 88px;
    height: 88px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--color-white);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}
.about-owner__body { flex: 1; min-width: 0; }
.about-owner__label {
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin-bottom: 0.25rem;
}
.about-owner__name {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--color-primary);
    margin-bottom: 0.5rem;
    line-height: 1.2;
}
.about-owner__bio {
    margin: 0;
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--color-text-muted);
}

.about-certifications {
    margin-top: var(--space-lg);
    padding: var(--space-md) var(--space-lg);
    background: color-mix(in srgb, var(--color-accent) 10%, var(--color-white));
    border-radius: var(--radius);
    font-size: 0.9375rem;
    line-height: 1.55;
    color: var(--color-text);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .about-certifications { background: rgba(226, 182, 74, 0.1); }
}
.about-certifications strong {
    color: var(--color-primary);
}

/* Trust signals grid (right column) */
.about-signals {
    position: sticky;
    top: 100px;
}
.about-signals__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm);
    margin-bottom: var(--space-lg);
}
@media (max-width: 560px) {
    .about-signals__grid { grid-template-columns: repeat(2, 1fr); }
}

.trust-signal {
    padding: var(--space-lg) var(--space-md);
    background: var(--color-white);
    border: 2px solid color-mix(in srgb, var(--color-primary) 15%, var(--color-white));
    border-radius: var(--radius-lg);
    text-align: center;
    transition: border-color var(--transition), transform var(--transition);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .trust-signal { border-color: rgba(15, 52, 96, 0.2); }
}
.trust-signal:hover {
    border-color: var(--color-accent);
    transform: translateY(-2px);
}
.trust-signal__icon {
    display: block;
    font-size: 1.65rem;
    margin-bottom: 0.5rem;
    line-height: 1;
}
.trust-signal__value {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--color-primary);
    line-height: 1.1;
    margin-bottom: 0.25rem;
    word-break: break-word;
}
.trust-signal__label {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text-muted);
}

/* Award badge */
.about-award {
    display: flex;
    gap: var(--space-md);
    align-items: center;
    padding: var(--space-md) var(--space-lg);
    background: var(--color-primary);
    border-radius: var(--radius-lg);
    color: var(--color-white);
    box-shadow: 0 4px 16px color-mix(in srgb, var(--color-primary) 25%, transparent);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .about-award { box-shadow: 0 4px 16px rgba(15, 52, 96, 0.25); }
}
.about-award__img {
    flex-shrink: 0;
    width: 60px;
    height: 60px;
    object-fit: contain;
}
.about-award__body { flex: 1; min-width: 0; }
.about-award__label {
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    opacity: 0.85;
    margin-bottom: 0.25rem;
}
.about-award__name {
    font-size: 1rem;
    font-weight: 800;
    color: var(--color-accent);
    line-height: 1.3;
}
.about-award__year {
    font-size: 0.875rem;
    opacity: 0.85;
    margin-top: 0.15rem;
}

/* ============================================================
   V4.1 — Phone pill restyle + sidebar owner + Book Now CTA
   ============================================================ */

/* Phone pill on category cards: GOLD background, NAVY text */
.rental-cat-card__phone-pill {
    background: var(--color-accent) !important;
    color: var(--color-primary) !important;
    border: 1px solid var(--color-accent) !important;
    font-weight: 800 !important;
    letter-spacing: 0.02em;
}

/* Sidebar Meet the Owner — blue bordered card under the award */
.about-owner--sidebar {
    margin-top: var(--space-md);
    background: var(--color-white);
    border: 2px solid var(--color-primary);
    border-left: 4px solid var(--color-primary);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    box-shadow: 0 4px 16px color-mix(in srgb, var(--color-primary) 12%, transparent);
    flex-direction: column;
    text-align: left;
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .about-owner--sidebar { box-shadow: 0 4px 16px rgba(15, 52, 96, 0.12); }
}
.about-owner--sidebar .about-owner__img {
    width: 72px;
    height: 72px;
    margin-bottom: var(--space-sm);
    border: 3px solid var(--color-accent);
}
.about-owner--sidebar .about-owner__body {
    width: 100%;
}
.about-owner--sidebar .about-owner__label {
    font-size: 0.7rem;
    color: var(--color-accent);
}
.about-owner--sidebar .about-owner__name {
    font-size: 1.15rem;
}


/* ============================================================
   V4.2 — About pillars (fills left column with SEO content)
   ============================================================ */
.about-pillars {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-lg);
    margin-top: var(--space-xl);
}
@media (max-width: 720px) {
    .about-pillars { grid-template-columns: 1fr; }
}
.about-pillar {
    display: flex;
    gap: var(--space-md);
    align-items: flex-start;
    padding: var(--space-md);
    background: color-mix(in srgb, var(--color-primary) 3%, var(--color-white));
    border-radius: var(--radius);
    border-left: 3px solid var(--color-accent);
    transition: background-color var(--transition), transform var(--transition);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .about-pillar { background: rgba(15, 52, 96, 0.03); }
}
.about-pillar:hover {
    background: color-mix(in srgb, var(--color-primary) 6%, var(--color-white));
    transform: translateX(2px);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .about-pillar:hover { background: rgba(15, 52, 96, 0.06); }
}
.about-pillar__icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-primary);
    color: var(--color-white);
    border-radius: 50%;
}
.about-pillar__body { flex: 1; min-width: 0; }
.about-pillar__title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--color-primary);
    margin-bottom: 0.35rem;
    line-height: 1.3;
}
.about-pillar__body p {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.55;
    color: var(--color-text-muted);
}


/* ============================================================
   V4.3 — Mobile footer padding fix
   Ensure footer content has breathing room on phones
   ============================================================ */
@media (max-width: 720px) {
    /* More generous horizontal padding on mobile containers in footer */
    .site-footer .container {
        padding-left: var(--space-lg) !important;
        padding-right: var(--space-lg) !important;
    }

    /* Logo should not be flush-left on mobile */
    .site-footer__col--brand .site-footer__logo img,
    .site-footer__col--brand img {
        max-width: 220px !important;
    }

    /* Footer columns — better vertical rhythm and spacing on small screens */
    .site-footer__columns {
        gap: var(--space-2xl) !important;
    }

    /* Bottom bar inherits same padding */
    .site-footer__bottom .container,
    .site-footer__bottom-inner {
        padding-left: var(--space-lg) !important;
        padding-right: var(--space-lg) !important;
    }

    /* City strip on mobile — tighter pill spacing, proper edges */
    .site-footer__city-strip .container {
        padding-left: var(--space-lg) !important;
        padding-right: var(--space-lg) !important;
    }
}


/* ============================================================
   V4.4 — CONTACT PAGE styling
   ============================================================ */
.contact-info-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-lg);
}
@media (max-width: 960px) { .contact-info-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .contact-info-grid { grid-template-columns: 1fr; } }

.contact-info-card {
    display: block;
    padding: var(--space-xl);
    background: var(--color-white);
    border: 2px solid color-mix(in srgb, var(--color-primary) 15%, var(--color-white));
    border-radius: var(--radius-lg);
    text-align: center;
    text-decoration: none;
    color: var(--color-text);
    transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .contact-info-card { border-color: rgba(15, 52, 96, 0.15); }
}
.contact-info-card:hover:not(.contact-info-card--static) {
    border-color: var(--color-primary);
    transform: translateY(-4px);
    box-shadow: 0 12px 32px color-mix(in srgb, var(--color-primary) 18%, transparent);
    color: var(--color-text);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .contact-info-card:hover:not(.contact-info-card--static) { box-shadow: 0 12px 32px rgba(15, 52, 96, 0.18); }
}
.contact-info-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background: var(--color-primary);
    color: var(--color-white);
    border-radius: 50%;
    margin-bottom: var(--space-md);
}
.contact-info-card__label {
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    margin-bottom: 0.5rem;
}
.contact-info-card__value {
    font-size: 1.125rem;
    font-weight: 800;
    color: var(--color-primary);
    line-height: 1.3;
    margin-bottom: 0.35rem;
    word-break: break-word;
}
.contact-info-card__sub {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

/* Contact form + map grid */
.contact-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2xl);
    align-items: start;
}
@media (max-width: 960px) { .contact-form-grid { grid-template-columns: 1fr; } }

.contact-form__row {
    margin-bottom: var(--space-md);
}
.contact-form__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
}
@media (max-width: 500px) { .contact-form__grid { grid-template-columns: 1fr; } }

.contact-form__label {
    display: block;
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: 0.35rem;
}
.contact-form__input {
    width: 100%;
    padding: 0.85rem 1rem;
    border: 2px solid color-mix(in srgb, var(--color-primary) 15%, var(--color-white));
    border-radius: var(--radius);
    font-size: 1rem;
    font-family: inherit;
    color: var(--color-text);
    background: var(--color-white);
    transition: border-color var(--transition), box-shadow var(--transition);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .contact-form__input { border-color: rgba(15, 52, 96, 0.15); }
}
.contact-form__input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(226, 182, 74, 0.15);
}
.contact-form__textarea { resize: vertical; min-height: 120px; font-family: inherit; }


/* ============================================================
   V4.5 — SERVICE AREAS HUB — city card grid
   ============================================================ */
.service-area-card-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-lg);
    list-style: none;
    margin: 0;
    padding: 0;
}
@media (max-width: 960px) { .service-area-card-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px) { .service-area-card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 440px) { .service-area-card-grid { grid-template-columns: 1fr; } }

.service-area-card-item { list-style: none; }
.service-area-card {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-lg);
    background: var(--color-white);
    border: 2px solid color-mix(in srgb, var(--color-primary) 15%, var(--color-white));
    border-radius: var(--radius-lg);
    text-decoration: none;
    color: var(--color-text);
    transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .service-area-card { border-color: rgba(15, 52, 96, 0.15); }
}
.service-area-card:hover {
    border-color: var(--color-primary);
    transform: translateY(-3px);
    box-shadow: 0 10px 28px color-mix(in srgb, var(--color-primary) 16%, transparent);
    color: var(--color-text);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .service-area-card:hover { box-shadow: 0 10px 28px rgba(15, 52, 96, 0.16); }
}
.service-area-card__icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-accent);
    color: var(--color-primary);
    border-radius: 50%;
}
.service-area-card__body { flex: 1; min-width: 0; }
.service-area-card__name {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--color-primary);
    line-height: 1.2;
    margin-bottom: 0.15rem;
}
.service-area-card__state {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}
.service-area-card__cta {
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--color-primary);
}


/* ============================================================
   V4.6 — ABOUT PAGE polish
   - Darker overlay on About hero for readability
   - Styled body content with better typography
   ============================================================ */

/* About/Contact/Rentals/Service-Area hub hero — stronger dark overlay for readability */
.page-about .site-hero::after,
.page-contact .site-hero::after,
.page-rentals .site-hero::after,
.page-service-areas .site-hero::after,
.page-template-page-about .site-hero::after,
.page-template-page-contact .site-hero::after,
.page-template-page-rentals-hub .site-hero::after,
.page-template-page-service-areas-hub .site-hero::after {
    background: linear-gradient(180deg,
        rgba(0, 0, 0, 0.55) 0%,
        rgba(0, 0, 0, 0.70) 100%) !important;
}

/* Hero text shadow for extra readability on busy images */
.page-template-page-about .hero__title,
.page-template-page-contact .hero__title,
.page-template-page-rentals-hub .hero__title,
.page-template-page-service-areas-hub .hero__title {
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.65),
                 0 1px 3px rgba(0, 0, 0, 0.5) !important;
}
.page-template-page-about .hero__subtitle,
.page-template-page-contact .hero__subtitle,
.page-template-page-rentals-hub .hero__subtitle,
.page-template-page-service-areas-hub .hero__subtitle {
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.7) !important;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}
.page-template-page-about .hero__eyebrow,
.page-template-page-contact .hero__eyebrow,
.page-template-page-rentals-hub .hero__eyebrow,
.page-template-page-service-areas-hub .hero__eyebrow {
    background: var(--color-accent);
    color: var(--color-primary);
    padding: 0.4rem 1.1rem;
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: 0.12em;
    display: inline-block;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.3);
}

/* About page main content — styled typography */
.about-page-content {
    max-width: 720px;
    margin: 0 auto;
}
.about-page-content p {
    font-size: 1.075rem;
    line-height: 1.85;
    color: var(--color-text);
    margin: 0 0 var(--space-lg);
}
.about-page-content p:first-child {
    font-size: 1.35rem;
    line-height: 1.55;
    font-weight: 500;
    color: var(--color-primary);
    margin-bottom: var(--space-xl);
    padding-bottom: var(--space-lg);
    border-bottom: 2px solid color-mix(in srgb, var(--color-accent) 50%, transparent);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .about-page-content p:first-child {
        border-bottom-color: rgba(226, 182, 74, 0.5);
    }
}
.about-page-content p:first-child::first-letter {
    font-size: 3.5rem;
    font-weight: 800;
    float: left;
    line-height: 1;
    padding: 0.25rem 0.75rem 0 0;
    color: var(--color-accent);
}
.about-page-content p strong {
    color: var(--color-primary);
    font-weight: 700;
}
.about-page-content h2,
.about-page-content h3 {
    color: var(--color-primary);
    margin: var(--space-2xl) 0 var(--space-md);
    font-weight: 800;
}
.about-page-content h2 {
    font-size: 1.75rem;
    padding-bottom: var(--space-sm);
    border-bottom: 3px solid var(--color-accent);
    display: inline-block;
}
.about-page-content h3 {
    font-size: 1.3rem;
}


/* ============================================================
   V4.7 — FINAL HERO OVERLAY FIX FOR UTILITY PAGES
   Homepage keeps clean image (user requested no overlay there).
   Utility/hub pages get strong overlay for readability:
   About, Contact, Rentals, Service Areas, Event Types, City pages
   ============================================================ */

/* Re-enable overlay pseudo-element ONLY on non-front pages */
body:not(.home) .hero::after,
body:not(.home) .site-hero::after {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(180deg,
        rgba(0, 0, 0, 0.50) 0%,
        rgba(0, 0, 0, 0.72) 100%) !important;
    z-index: 1 !important;
    pointer-events: none;
}

/* Make sure container content sits ABOVE overlay */
body:not(.home) .hero > .container,
body:not(.home) .site-hero > .container {
    position: relative;
    z-index: 2;
}

/* BOLD WHITE hero text — readable over any photo */
body:not(.home) .hero__title,
body:not(.home) .site-hero__heading {
    color: #ffffff !important;
    font-weight: 900 !important;
    text-shadow:
        0 2px 4px rgba(0, 0, 0, 0.6),
        0 4px 16px rgba(0, 0, 0, 0.5) !important;
    letter-spacing: -0.01em;
}

body:not(.home) .hero__subtitle,
body:not(.home) .site-hero__sub {
    color: rgba(255, 255, 255, 0.95) !important;
    font-weight: 500 !important;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.75) !important;
    max-width: 640px;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Eyebrow — gold pill so it stands out on any background */
body:not(.home) .hero__eyebrow {
    background: var(--color-accent);
    color: var(--color-primary);
    padding: 0.4rem 1.1rem;
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: 0.12em;
    font-size: 0.8125rem;
    display: inline-block;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.4);
    margin-bottom: var(--space-md);
}

/* Hero rating text white */
body:not(.home) .hero__rating-text {
    color: rgba(255, 255, 255, 0.95) !important;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.6);
}

/* ============================================================
   V4.8 — EVENT TYPE / CITY PAGE CONTENT STRUCTURE
   Make AI-generated content render with proper typography
   so it doesn't look like a wall of text
   ============================================================ */

.event-intro-content,
.about-page-content {
    max-width: 760px;
    margin: 0 auto;
}

.event-intro-content p,
.about-page-content p {
    font-size: 1.0625rem;
    line-height: 1.85;
    color: var(--color-text);
    margin: 0 0 var(--space-lg);
}

/* First paragraph = lead-in style */
.event-intro-content > p:first-of-type,
.about-page-content > p:first-of-type {
    font-size: 1.25rem;
    line-height: 1.6;
    font-weight: 500;
    color: var(--color-primary);
    margin-bottom: var(--space-xl);
    padding-bottom: var(--space-lg);
    border-bottom: 2px solid color-mix(in srgb, var(--color-accent) 60%, transparent);
}
@supports not (background: color-mix(in srgb, red, blue)) {
    .event-intro-content > p:first-of-type,
    .about-page-content > p:first-of-type {
        border-bottom-color: rgba(226, 182, 74, 0.6);
    }
}

/* Styled headings if AI content includes them */
.event-intro-content h2,
.about-page-content h2 {
    font-size: 1.75rem;
    font-weight: 800;
    color: var(--color-primary);
    margin: var(--space-2xl) 0 var(--space-md);
    padding-bottom: var(--space-xs);
    border-bottom: 3px solid var(--color-accent);
    display: inline-block;
}
.event-intro-content h3,
.about-page-content h3 {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--color-primary);
    margin: var(--space-xl) 0 var(--space-sm);
}
.event-intro-content ul,
.event-intro-content ol,
.about-page-content ul,
.about-page-content ol {
    margin: 0 0 var(--space-lg);
    padding-left: 1.5rem;
}
.event-intro-content li,
.about-page-content li {
    font-size: 1.0625rem;
    line-height: 1.75;
    margin-bottom: 0.5rem;
}
.event-intro-content strong,
.about-page-content strong {
    color: var(--color-primary);
    font-weight: 700;
}