/* ═══════════════════════════════════════════════════════════════════════════════
   FloridaLandOffers.com — Main Stylesheet
   /assets/css/style.css
   ═══════════════════════════════════════════════════════════════════════════════ */


/* ── CSS Variables (Design System) ───────────────────────────────────────────── */
:root {
    --forest-dark:  #1e3d2b;
    --forest:       #2d5a3d;
    --forest-light: #4a7c5f;
    --gold:         #c9973a;
    --gold-light:   #e8c97a;
    --gold-dark:    #a87a28;
    --cream:        #f7f4ee;
    --white:        #ffffff;
    --ink:          #0f0e0c;
    --slate:        #3a4a5c;
    --muted:        #6b7280;
    --rule:         #e2ddd6;
    --success:      #2d6a4f;
    --error:        #c62828;
    --warning:      #e65100;

    --font-heading: Georgia, 'Times New Roman', serif;
    --font-body:    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    --font-mono:    'Courier New', Courier, monospace;

    --text-xs:   0.75rem;
    --text-sm:   0.875rem;
    --text-base: 1rem;
    --text-lg:   1.125rem;
    --text-xl:   1.25rem;
    --text-2xl:  1.5rem;
    --text-3xl:  1.875rem;
    --text-4xl:  2.25rem;
    --text-5xl:  3rem;

    --radius:    4px;
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
    --shadow:    0 2px 8px rgba(0,0,0,0.08);
    --shadow-md: 0 4px 16px rgba(0,0,0,0.12);
    --shadow-lg: 0 8px 32px rgba(0,0,0,0.14);

    --transition: 0.2s ease;

    --container-max: 1200px;
    --container-pad: 24px;
}


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

html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }

body {
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--ink);
    background: var(--white);
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
}

img, video { max-width: 100%; height: auto; display: block; }

a { color: var(--forest); text-decoration: underline; transition: color var(--transition); }
a:hover { color: var(--forest-light); }
a:focus-visible { outline: 3px solid var(--gold); outline-offset: 3px; border-radius: var(--radius); }

ul, ol { list-style: none; }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    color: var(--ink);
    line-height: 1.25;
    font-weight: normal;
}

p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }

address { font-style: normal; }


/* ── Skip Navigation (accessibility) ────────────────────────────────────────── */
.skip-nav {
    position: absolute;
    top: -100px;
    left: 16px;
    background: var(--gold);
    color: var(--ink);
    padding: 8px 16px;
    border-radius: 0 0 var(--radius) var(--radius);
    font-weight: 700;
    text-decoration: none;
    z-index: 9999;
    transition: top var(--transition);
}
.skip-nav:focus { top: 0; }


/* ── Container ───────────────────────────────────────────────────────────────── */
.container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-pad);
}


/* ── Buttons ─────────────────────────────────────────────────────────────────── */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 24px;
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: 700;
    border-radius: var(--radius);
    border: 2px solid transparent;
    cursor: pointer;
    text-decoration: none;
    transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
    white-space: nowrap;
    line-height: 1.2;
}
.btn:focus-visible { outline: 3px solid var(--gold); outline-offset: 3px; }
.btn:active { transform: translateY(1px); }

/* Gold (primary CTA) */
.btn--gold { background: var(--gold); color: var(--ink); border-color: var(--gold); }
.btn--gold:hover { background: var(--gold-dark); border-color: var(--gold-dark); color: var(--ink); }

/* Outline */
.btn--outline { background: transparent; color: var(--forest); border-color: var(--forest); }
.btn--outline:hover { background: var(--forest); color: var(--white); }

/* Outline on dark backgrounds */
.btn--outline-light { background: transparent; color: var(--white); border-color: var(--white); }
.btn--outline-light:hover { background: var(--white); color: var(--forest-dark); }

/* Sizes */
.btn--lg { padding: 16px 32px; font-size: var(--text-lg); }
.btn--sm { padding: 8px 16px; font-size: var(--text-sm); }
.btn--full { width: 100%; }

/* Header CTA */
.btn--header-cta { padding: 10px 20px; font-size: var(--text-sm); }
.btn--mobile-cta { width: 100%; margin: 24px 0 16px; padding: 16px; font-size: var(--text-lg); }
.btn--hero { min-width: 260px; }


/* ── Top Bar ─────────────────────────────────────────────────────────────────── */
.top-bar {
    background: var(--forest-dark);
    color: rgba(255,255,255,0.85);
    font-size: var(--text-sm);
    padding: 8px 0;
}
.top-bar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}
.top-bar__message { opacity: 0.8; }
.top-bar__phone {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--gold-light);
    text-decoration: none;
    font-weight: 600;
    transition: color var(--transition);
}
.top-bar__phone:hover { color: var(--white); }


/* ── Site Header ─────────────────────────────────────────────────────────────── */
.site-header {
    background: var(--white);
    border-bottom: 1px solid var(--rule);
    position: sticky;
    top: 0;
    z-index: 100;
    box-shadow: var(--shadow-sm);
}
.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    height: 80px;
}

.site-logo__img--desktop { height: 64px; width: auto; }
.site-logo__img--mobile  { height: 44px; width: auto; }

/* Logo */
.site-logo {
    display: flex;
    align-items: center;
    text-decoration: none;
    flex-shrink: 0;
}
.site-logo__img { display: block; }
.site-logo__img--mobile { display: none; }
.site-logo:hover { opacity: 0.85; transition: opacity var(--transition); }

/* Desktop Nav */
.site-nav { display: flex; align-items: center; }
.site-nav__list { display: flex; align-items: center; gap: 4px; }
.site-nav__link {
    display: block;
    padding: 8px 12px;
    font-size: var(--text-sm);
    color: var(--slate);
    text-decoration: none;
    border-radius: var(--radius);
    font-weight: 500;
    transition: color var(--transition), background var(--transition);
}
.site-nav__link:hover { color: var(--forest-dark); background: var(--cream); }
.site-nav__link--active { color: var(--forest-dark); font-weight: 700; }

/* Mobile toggle */
.mobile-menu-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
}
.hamburger { display: flex; flex-direction: column; gap: 5px; }
.hamburger span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--forest-dark);
    transition: transform var(--transition), opacity var(--transition);
}


/* ── Mobile Menu ─────────────────────────────────────────────────────────────── */
.mobile-menu { position: fixed; inset: 0; z-index: 200; pointer-events: none; }
.mobile-menu.is-open { pointer-events: all; }

.mobile-menu__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0);
    transition: background 0.3s ease;
}
.mobile-menu.is-open .mobile-menu__overlay { background: rgba(0,0,0,0.5); }

.mobile-menu__drawer {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 300px;
    max-width: 90vw;
    background: var(--white);
    padding: 24px;
    transform: translateX(100%);
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
}
.mobile-menu.is-open .mobile-menu__drawer { transform: translateX(0); }

.mobile-menu__close {
    align-self: flex-end;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--slate);
    padding: 4px;
    margin-bottom: 16px;
}
.mobile-menu__logo {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--forest-dark);
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--rule);
}
.mobile-menu__list { flex: 1; }
.mobile-menu__link {
    display: block;
    padding: 14px 0;
    font-size: var(--text-lg);
    color: var(--ink);
    text-decoration: none;
    border-bottom: 1px solid var(--rule);
    transition: color var(--transition);
}
.mobile-menu__link:hover { color: var(--forest); }
.mobile-menu__phone {
    display: block;
    text-align: center;
    color: var(--muted);
    font-size: var(--text-sm);
    text-decoration: none;
}


/* ── Section Base ────────────────────────────────────────────────────────────── */
.section { padding: 80px 0; }
.section--cream { background: var(--cream); }
.section--forest { background: var(--forest-dark); }

.section-header { text-align: center; margin-bottom: 48px; }
.section-title {
    font-size: var(--text-3xl);
    color: var(--forest-dark);
    margin-bottom: 12px;
}
.section--forest .section-title { color: var(--white); }
.section-sub { font-size: var(--text-lg); color: var(--slate); max-width: 580px; margin: 0 auto; }
.section--forest .section-sub { color: rgba(255,255,255,0.75); }

.section-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-top: 48px;
    flex-wrap: wrap;
}


/* ── Quick Answer Box ────────────────────────────────────────────────────────── */
/* Quick Answer Strip (below hero on home page) */
.quick-answer-strip {
    background: var(--white);
    border-top: 1px solid var(--rule);
    border-bottom: 4px solid var(--gold);
    padding: 16px 0;
}
.quick-answer-strip__inner {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}
.quick-answer-strip__label {
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--gold-dark);
    white-space: nowrap;
    background: var(--cream);
    border: 1px solid var(--rule);
    padding: 4px 10px;
    border-radius: 100px;
    flex-shrink: 0;
}
.quick-answer-strip p {
    font-size: var(--text-sm);
    color: var(--slate);
    margin: 0;
    line-height: 1.5;
    text-wrap: balance;
}

/* Quick Answer Box (inner pages) */
.quick-answer {
    display: inline-flex;
    align-items: flex-start;
    gap: 12px;
    background: var(--cream);
    border-left: 4px solid var(--gold);
    border-radius: 0 var(--radius) var(--radius) 0;
    padding: 12px 16px;
    margin-bottom: 24px;
    max-width: 560px;
}
.quick-answer__label {
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--gold-dark);
    white-space: nowrap;
    padding-top: 2px;
}
.quick-answer p { font-size: var(--text-sm); color: var(--ink); margin: 0; line-height: 1.5; }


/* ── Hero ────────────────────────────────────────────────────────────────────── */
.hero {
    position: relative;
    background-color: var(--forest-dark);
    color: var(--white);
    padding: 80px 0;
    overflow: hidden;
}
.hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url('https://www.floridalandoffers.com/assets/images/hero-bg.webp');
    background-size: cover;
    background-position: center 80%;
    background-repeat: no-repeat;
    filter: brightness(1.15) saturate(1.25) contrast(1.05);
    z-index: 0;
}
.hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(to bottom, rgba(30,61,43,0.95) 0%, rgba(30,61,43,0.45) 35%, rgba(30,61,43,0.2) 100%),
        linear-gradient(to right, rgba(30,61,43,0.7) 25%, rgba(30,61,43,0.1) 100%);
    z-index: 1;
}
.hero__bg { display: none; }
.hero__inner { position: relative; z-index: 2; }
.hero__content { padding-top: 0; }
.hero__inner {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 48px;
    align-items: center;
}
.hero__content {
    padding-top: 40px;
}
.hero__heading {
    font-size: var(--text-4xl);
    color: var(--white);
    margin-bottom: 20px;
    line-height: 1.2;
    text-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.hero__sub {
    font-size: var(--text-lg);
    color: rgba(255,255,255,0.95);
    margin-bottom: 28px;
    max-width: 540px;
    text-shadow: 0 1px 4px rgba(0,0,0,0.3);
}
.hero__trust {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 24px;
    margin-bottom: 32px;
}
.hero__trust li {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--text-sm);
    color: rgba(255,255,255,0.9);
}
.hero__trust li svg { color: var(--gold); flex-shrink: 0; }
.hero__disclaimer { font-size: var(--text-sm); color: rgba(255,255,255,0.92); margin-top: 12px; text-shadow: 0 1px 4px rgba(0,0,0,0.6); font-weight: 500; }

/* Hero Form Card */
.hero__form-card {
    background: var(--white);
    border-radius: var(--radius);
    padding: 32px;
    box-shadow: var(--shadow-lg);
}
.hero__form-heading {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--forest-dark);
    margin-bottom: 20px;
    text-align: center;
}
.hero-form { display: flex; flex-direction: column; gap: 16px; }
.hero__form-note {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: var(--text-xs);
    color: var(--muted);
    margin-top: 12px;
    text-align: center;
    justify-content: center;
}
.hero__form-note svg { color: var(--success); flex-shrink: 0; }


/* ── Trust Bar ───────────────────────────────────────────────────────────────── */
.trust-bar {
    background: var(--forest);
    padding: 32px 0;
}
.trust-bar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}
.trust-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    flex: 1;
    min-width: 120px;
}
.trust-stat__number {
    font-family: var(--font-heading);
    font-size: var(--text-4xl);
    color: var(--gold-light);
    line-height: 1;
    margin-bottom: 6px;
}
.trust-stat__label {
    font-size: var(--text-sm);
    color: rgba(255,255,255,0.8);
    line-height: 1.3;
}
.trust-bar__divider {
    width: 1px;
    height: 48px;
    background: rgba(255,255,255,0.2);
    flex-shrink: 0;
}


/* ── Steps Grid ──────────────────────────────────────────────────────────────── */
.steps-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
.step-card {
    text-align: center;
    padding: 32px 24px;
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    position: relative;
}
.step-card__number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    background: var(--forest-dark);
    color: var(--gold-light);
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    border-radius: 50%;
    margin: 0 auto 20px;
}
.step-card__title {
    font-size: var(--text-xl);
    color: var(--forest-dark);
    margin-bottom: 12px;
}
.step-card__desc { font-size: var(--text-base); color: var(--slate); }


/* ── Benefits Grid ───────────────────────────────────────────────────────────── */
.benefits-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.benefit-card {
    padding: 28px 24px;
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}
.benefit-card__icon {
    color: var(--forest);
    margin-bottom: 16px;
}
.benefit-card__title {
    font-size: var(--text-lg);
    color: var(--forest-dark);
    margin-bottom: 10px;
}
.benefit-card p { font-size: var(--text-sm); color: var(--slate); }


/* ── Land Types ──────────────────────────────────────────────────────────────── */
.land-types__grid {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
}
.land-type-tag {
    padding: 10px 20px;
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: 100px;
    font-size: var(--text-sm);
    color: var(--slate);
    font-weight: 500;
}


/* ── FAQ Section ─────────────────────────────────────────────────────────────── */
.faq-section__inner { max-width: 760px; margin: 0 auto; }
.faq-list { display: flex; flex-direction: column; }
.faq-item {
    border-bottom: 1px solid var(--rule);
    padding: 24px 0;
}
.faq-item:first-child { border-top: 1px solid var(--rule); }
.faq-question {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--forest-dark);
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    user-select: none;
    padding: 0;
}
.faq-question::after {
    content: '+';
    font-size: var(--text-2xl);
    color: var(--gold);
    font-weight: 300;
    flex-shrink: 0;
    transition: transform var(--transition);
}
.faq-item.is-open .faq-question::after { transform: rotate(45deg); }
.faq-answer {
    font-size: var(--text-base);
    color: var(--slate);
    line-height: 1.7;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
}
.faq-item.is-open .faq-answer { max-height: 400px; padding-top: 16px; }
.faq-answer p { margin-bottom: 0; }


/* ── About Preview ───────────────────────────────────────────────────────────── */
.about-preview__inner {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 64px;
    align-items: center;
}
.about-preview__text .btn { margin-top: 8px; }
.about-preview__credentials {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.credential-card {
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 20px 24px;
    text-align: center;
}
.credential-card__year,
.credential-card__number {
    font-family: var(--font-heading);
    font-size: var(--text-3xl);
    color: var(--forest-dark);
    line-height: 1;
    margin-bottom: 6px;
}
.credential-card__icon { color: var(--forest); margin: 0 auto 8px; }
.credential-card p { font-size: var(--text-sm); color: var(--slate); margin: 0; }


/* ── Final CTA ───────────────────────────────────────────────────────────────── */
.final-cta { text-align: center; }
.final-cta__inner { max-width: 640px; margin: 0 auto; }
.final-cta__heading {
    font-size: var(--text-3xl);
    color: var(--white);
    margin-bottom: 16px;
}
.final-cta__sub { color: rgba(255,255,255,0.8); margin-bottom: 32px; font-size: var(--text-lg); }
.final-cta__phone { margin-top: 20px; font-size: var(--text-sm); color: rgba(255,255,255,0.6); }
.final-cta__phone a { color: var(--gold-light); }


/* ── Footer CTA Band ─────────────────────────────────────────────────────────── */
.footer-cta-band {
    background: var(--forest);
    padding: 48px 0;
}
.footer-cta-band__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    flex-wrap: wrap;
}
.footer-cta-band__heading {
    font-size: var(--text-2xl);
    color: var(--white);
    margin-bottom: 8px;
}
.footer-cta-band__sub { color: rgba(255,255,255,0.75); }


/* ── Footer Main ─────────────────────────────────────────────────────────────── */
.footer-main { background: #0f2318; padding: 64px 0; }
.footer-main__grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 48px;
}
.footer-logo {
    display: inline-block;
    text-decoration: none;
    margin-bottom: 20px;
    background: var(--white);
    padding: 10px 16px;
    border-radius: var(--radius);
    transition: opacity var(--transition);
}
.footer-logo:hover { opacity: 0.9; }
.footer-logo img { height: 40px; width: auto; display: block; }
.footer-col__desc { font-size: var(--text-sm); color: rgba(255,255,255,0.65); line-height: 1.7; margin-bottom: 16px; }
.footer-address { font-size: var(--text-sm); color: rgba(255,255,255,0.65); line-height: 1.8; }
.footer-address a { color: var(--gold-light); text-decoration: none; }
.footer-address a:hover { text-decoration: underline; }
.footer-col__heading {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255,255,255,0.4);
    margin-bottom: 16px;
}
.footer-nav { display: flex; flex-direction: column; gap: 8px; }
.footer-nav li { font-size: var(--text-sm); color: rgba(255,255,255,0.6); }
.footer-nav a { color: rgba(255,255,255,0.75); text-decoration: none; transition: color var(--transition); }
.footer-nav a:hover { color: var(--gold-light); }


/* ── Footer Bottom ───────────────────────────────────────────────────────────── */
.footer-bottom {
    background: #0a1a10;
    padding: 20px 0;
    border-top: 1px solid rgba(255,255,255,0.08);
}
.footer-bottom__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.footer-bottom__copy { font-size: var(--text-xs); color: rgba(255,255,255,0.4); }
.footer-bottom__links {
    display: flex;
    align-items: center;
    gap: 16px;
}
.footer-bottom__links a { font-size: var(--text-xs); color: rgba(255,255,255,0.4); text-decoration: none; }
.footer-bottom__links a:hover { color: rgba(255,255,255,0.7); }


/* ── Form Elements ───────────────────────────────────────────────────────────── */
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-label { font-size: var(--text-sm); font-weight: 600; color: var(--slate); }
.form-input,
.form-select,
.form-textarea {
    width: 100%;
    padding: 12px 14px;
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--ink);
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    transition: border-color var(--transition), box-shadow var(--transition);
    appearance: none;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    outline: none;
    border-color: var(--forest);
    box-shadow: 0 0 0 3px rgba(45,90,61,0.1);
}
.form-input::placeholder,
.form-textarea::placeholder { color: var(--muted); }
.form-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 40px;
    cursor: pointer;
}
.form-textarea { min-height: 120px; resize: vertical; }

.form-error { font-size: var(--text-sm); color: var(--error); }
.form-input.has-error, .form-select.has-error { border-color: var(--error); }


/* ── Breadcrumbs ─────────────────────────────────────────────────────────────── */
.breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    font-size: var(--text-sm);
    color: var(--muted);
    padding: 12px 0;
}
.breadcrumb a { color: var(--forest); text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb__sep { color: var(--rule); }


/* ── Page Hero (inner pages) ─────────────────────────────────────────────────── */
.page-hero {
    position: relative;
    background-color: var(--forest-dark);
    background-image:
        linear-gradient(to right, rgba(30,61,43,0.72) 30%, rgba(30,61,43,0.45) 100%),
        url('https://www.floridalandoffers.com/assets/images/hero-bg.webp');
    background-size: cover;
    background-position: center 70%;
    padding: 56px 0;
    color: var(--white);
    overflow: visible;
}
.page-hero::before { display: none; }
.page-hero::after  { display: none; }
.page-hero .container { position: relative; z-index: 2; }
.page-hero .breadcrumb a { color: rgba(255,255,255,0.7); }
.page-hero .breadcrumb a:hover { color: var(--gold-light); }
.page-hero .breadcrumb { color: rgba(255,255,255,0.5); }
.page-hero .breadcrumb__sep { color: rgba(255,255,255,0.3); }
.page-hero__heading {
    font-size: var(--text-4xl);
    color: var(--white);
    margin-bottom: 12px;
    text-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.page-hero__sub {
    font-size: var(--text-lg);
    color: rgba(255,255,255,0.85);
    max-width: 580px;
    text-shadow: 0 1px 4px rgba(0,0,0,0.3);
}


/* ── Prose Content ───────────────────────────────────────────────────────────── */
.prose h2 { font-size: var(--text-2xl); color: var(--forest-dark); margin: 32px 0 12px; }
.prose h3 { font-size: var(--text-xl); color: var(--forest-dark); margin: 24px 0 10px; }
.prose p  { color: var(--slate); margin-bottom: 16px; }
.prose ul, .prose ol { padding-left: 24px; margin-bottom: 16px; color: var(--slate); }
.prose li { margin-bottom: 8px; list-style: disc; }
.prose ol li { list-style: decimal; }
.prose a { color: var(--forest); }


/* ── Utility Classes ─────────────────────────────────────────────────────────── */
.text-center { text-align: center; }
.text-muted   { color: var(--muted); }
.text-sm      { font-size: var(--text-sm); }
.mt-0  { margin-top: 0; }
.mb-0  { margin-bottom: 0; }
.mb-4  { margin-bottom: 4px; }
.mb-8  { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.mb-32 { margin-bottom: 32px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }


/* ── How It Works Page ───────────────────────────────────────────────────────── */
.hiw-steps {
    display: flex;
    flex-direction: column;
    gap: 0;
    max-width: 860px;
    margin: 0 auto;
}

.hiw-step {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 40px;
    align-items: flex-start;
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 40px 40px 40px 32px;
    box-shadow: var(--shadow);
    position: relative;
}
.hiw-step + .hiw-step { margin-top: 0; }

/* Gold left accent bar on each step */
.hiw-step::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--gold);
    border-radius: var(--radius) 0 0 var(--radius);
}

.hiw-step__number {
    width: 64px;
    height: 64px;
    background: var(--forest-dark);
    color: var(--gold-light);
    font-family: var(--font-heading);
    font-size: var(--text-3xl);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: var(--shadow-md);
    position: relative;
    z-index: 1;
    margin-top: 4px;
}
.hiw-step__title {
    font-size: var(--text-2xl);
    color: var(--forest-dark);
    margin-bottom: 12px;
}
.hiw-step__intro {
    font-size: var(--text-lg);
    color: var(--forest);
    font-weight: 600;
    margin-bottom: 16px;
    line-height: 1.5;
}
.hiw-step__content p { color: var(--slate); margin-bottom: 16px; }
.hiw-step__details {
    background: var(--cream);
    border: 1px solid var(--rule);
    border-left: 3px solid var(--forest-light);
    border-radius: 0 var(--radius) var(--radius) 0;
    padding: 20px 24px;
    margin-top: 16px;
}
.hiw-step__details h3 {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--forest-dark);
    margin-bottom: 12px;
}
.hiw-checklist { display: flex; flex-direction: column; gap: 8px; }
.hiw-checklist li {
    font-size: var(--text-sm);
    color: var(--slate);
    padding-left: 22px;
    position: relative;
    line-height: 1.5;
}
.hiw-checklist li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--success);
    font-weight: 700;
}

/* Connector between steps */
.hiw-connector {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding-left: 47px;
    height: 40px;
}
.hiw-connector::before {
    content: '';
    display: block;
    width: 2px;
    height: 100%;
    background: linear-gradient(to bottom, var(--gold), var(--rule));
}

/* Land banner image strip */
.land-banner {
    width: 100%;
    height: 240px;
    object-fit: cover;
    object-position: center 60%;
    display: block;
}
.land-banner-wrap {
    overflow: hidden;
    position: relative;
    min-height: 240px;
    background: var(--forest-dark);
}
.land-banner-wrap::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to right,
        rgba(30,61,43,0.5) 0%,
        rgba(30,61,43,0.1) 40%,
        rgba(30,61,43,0.1) 60%,
        rgba(30,61,43,0.5) 100%);
}
.land-banner-caption {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
    text-align: center;
    color: var(--white);
    width: 90%;
    max-width: 600px;
}
.land-banner-caption h2 {
    font-size: var(--text-3xl);
    color: var(--white);
    text-shadow: 0 2px 8px rgba(0,0,0,0.4);
    margin-bottom: 8px;
    white-space: normal;
    line-height: 1.2;
}
.land-banner-caption p {
    font-size: var(--text-lg);
    color: rgba(255,255,255,0.9);
    text-shadow: 0 1px 4px rgba(0,0,0,0.4);
    margin: 0;
}
@media (max-width: 768px) {
    .land-banner-caption h2 { font-size: var(--text-2xl); }
    .land-banner-caption p  { font-size: var(--text-base); }
}

/* Comparison Table */
.comparison-table-wrap {
    overflow-x: auto;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    border: 1px solid var(--rule);
}
.comparison-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
}
.comparison-table th,
.comparison-table td {
    padding: 14px 20px;
    text-align: left;
    border-bottom: 1px solid var(--rule);
    vertical-align: middle;
}
.comparison-table thead th {
    font-size: var(--text-base);
    font-weight: 700;
    padding: 20px;
    border-bottom: 2px solid var(--rule);
    background: var(--cream);
}
.comparison-table thead th:first-child { background: var(--cream); }
.comparison-table thead .comparison-table__us { background: rgba(45,90,61,0.08); color: var(--forest-dark); }
.comparison-table thead .comparison-table__them { background: var(--cream); }
.comparison-table tbody tr:last-child td { border-bottom: none; }
.comparison-table tbody tr:hover td { background: var(--cream); }
.comparison-table tbody td:first-child { color: var(--slate); font-weight: 500; }
.comparison-table__us { background: rgba(45,90,61,0.04); }
.comp-good {
    color: var(--success);
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 6px;
}
.comp-good::before { content: '✓'; }
.comp-bad {
    color: var(--muted);
    display: flex;
    align-items: center;
    gap: 6px;
}
.comp-bad::before { content: '✗'; color: var(--error); }


/* ── Why Us Page ─────────────────────────────────────────────────────────────── */
.problem-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
}
.problem-card {
    background: var(--white);
    border: 1px solid var(--rule);
    border-top: 3px solid var(--error);
    border-radius: var(--radius);
    padding: 28px 24px;
    box-shadow: var(--shadow);
}
.problem-card__icon { color: var(--error); margin-bottom: 16px; opacity: 0.8; }
.problem-card__title { font-size: var(--text-lg); color: var(--ink); margin-bottom: 10px; }
.problem-card p { font-size: var(--text-sm); color: var(--slate); margin: 0; }

.solution-list { display: flex; flex-direction: column; gap: 0; max-width: 800px; margin: 0 auto; }
.solution-item {
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: 24px;
    align-items: flex-start;
    padding: 28px 0;
    border-bottom: 1px solid var(--rule);
}
.solution-item:first-child { border-top: 1px solid var(--rule); }
.solution-item__check {
    width: 40px;
    height: 40px;
    background: var(--success);
    color: var(--white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-lg);
    font-weight: 700;
    flex-shrink: 0;
    margin-top: 2px;
}
.solution-item__content h3 {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--forest-dark);
    margin-bottom: 8px;
}
.solution-item__content p { font-size: var(--text-base); color: var(--slate); margin: 0; }

.who-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.who-card {
    background: var(--white);
    border: 1px solid var(--rule);
    border-left: 4px solid var(--gold);
    border-radius: 0 var(--radius) var(--radius) 0;
    padding: 24px;
    box-shadow: var(--shadow);
}
.who-card__title { font-size: var(--text-lg); color: var(--forest-dark); margin-bottom: 10px; }
.who-card p { font-size: var(--text-sm); color: var(--slate); margin: 0; }

/* ── About Page ──────────────────────────────────────────────────────────────── */
.about-mission {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 64px;
    align-items: flex-start;
}
.about-lead {
    font-size: var(--text-xl);
    color: var(--forest-dark);
    font-family: var(--font-heading);
    margin-bottom: 20px;
    line-height: 1.5;
}
.about-mission__text p { color: var(--slate); margin-bottom: 16px; }
.about-mission__values {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.value-card {
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 20px;
    text-align: center;
}
.value-card__icon { color: var(--forest); margin: 0 auto 12px; }
.value-card h3 { font-family: var(--font-body); font-size: var(--text-base); font-weight: 700; color: var(--forest-dark); margin-bottom: 8px; }
.value-card p { font-size: var(--text-sm); color: var(--slate); margin: 0; }

.about-mike {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 64px;
    align-items: flex-start;
}
.about-mike__content p { color: var(--slate); margin-bottom: 16px; }
.podcast-list { list-style: none; padding: 0; margin: 0 0 16px; display: flex; flex-direction: column; gap: 12px; }
.podcast-list li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: var(--text-sm);
    color: var(--slate);
    padding: 12px 16px;
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
}
.podcast-list li svg { color: var(--gold); flex-shrink: 0; margin-top: 2px; }
.podcast-list li strong { color: var(--forest-dark); }

.about-mike__photo {
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    margin-bottom: 20px;
}
.about-mike__photo picture { display: block; }
.about-mike__photo img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}
.about-mike__photo-caption {
    background: var(--forest-dark);
    padding: 14px 20px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.about-mike__photo-caption strong { color: var(--white); font-size: var(--text-base); }
.about-mike__photo-caption span   { color: var(--gold-light); font-size: var(--text-sm); }

.about-mike__photo-placeholder {
    background: var(--cream);
    border: 2px dashed var(--rule);
    border-radius: var(--radius);
    padding: 40px 24px;
    text-align: center;
    margin-bottom: 20px;
    color: var(--muted);
}
.about-mike__photo-placeholder svg { margin: 0 auto 12px; opacity: 0.4; }
.about-mike__photo-placeholder p { font-family: var(--font-heading); font-size: var(--text-lg); color: var(--forest-dark); margin: 0 0 4px; }
.about-mike__photo-placeholder span { font-size: var(--text-sm); color: var(--muted); }

.about-mike__credentials { display: flex; flex-direction: column; gap: 1px; border: 1px solid var(--rule); border-radius: var(--radius); overflow: hidden; }
.cred-item { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; background: var(--white); border-bottom: 1px solid var(--rule); }
.cred-item:last-child { border-bottom: none; }
.cred-item__label { font-size: var(--text-xs); color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; }
.cred-item__value { font-size: var(--text-sm); font-weight: 700; color: var(--forest-dark); }

.network-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
.network-card {
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 28px 24px;
    box-shadow: var(--shadow);
    position: relative;
}
.network-card__number {
    font-family: var(--font-heading);
    font-size: var(--text-4xl);
    color: var(--rule);
    line-height: 1;
    margin-bottom: 12px;
}
.network-card h3 { font-family: var(--font-body); font-size: var(--text-lg); font-weight: 700; color: var(--forest-dark); margin-bottom: 10px; }
.network-card p { font-size: var(--text-sm); color: var(--slate); margin: 0; }

.florida-regions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-bottom: 8px;
}
.region-card {
    background: var(--white);
    border: 1px solid var(--rule);
    border-top: 3px solid var(--forest);
    border-radius: var(--radius);
    padding: 20px;
    box-shadow: var(--shadow-sm);
}
.region-card__name { font-family: var(--font-body); font-size: var(--text-base); font-weight: 700; color: var(--forest-dark); margin-bottom: 8px; }
.region-card p { font-size: var(--text-xs); color: var(--muted); margin: 0; line-height: 1.6; }

/* ── Contact Page ────────────────────────────────────────────────────────────── */
.contact-layout {
    display: grid;
    grid-template-columns: 380px 1fr;
    gap: 64px;
    align-items: flex-start;
}
.contact-info__title { font-size: var(--text-2xl); color: var(--forest-dark); margin-bottom: 32px; }
.contact-method { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 28px; }
.contact-method__icon {
    width: 44px; height: 44px;
    background: var(--forest-dark); color: var(--gold-light);
    border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.contact-method__content { display: flex; flex-direction: column; gap: 3px; padding-top: 4px; }
.contact-method__label { font-size: var(--text-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); }
.contact-method__value { font-size: var(--text-lg); font-weight: 600; color: var(--forest-dark); text-decoration: none; }
.contact-method__value:hover { color: var(--forest); text-decoration: underline; }
.contact-method__note { font-size: var(--text-sm); color: var(--muted); }
.contact-info__divider { border: none; border-top: 1px solid var(--rule); margin: 32px 0; }
.contact-sell-cta h3 { font-family: var(--font-body); font-size: var(--text-lg); font-weight: 700; color: var(--forest-dark); margin-bottom: 8px; }
.contact-sell-cta p { font-size: var(--text-sm); color: var(--slate); margin-bottom: 16px; }

.contact-form-card {
    background: var(--white); border: 1px solid var(--rule);
    border-radius: var(--radius); padding: 40px; box-shadow: var(--shadow);
}
.contact-form-card__title { font-size: var(--text-2xl); color: var(--forest-dark); margin-bottom: 8px; }
.contact-form-card__sub { font-size: var(--text-sm); color: var(--muted); margin-bottom: 28px; }
.contact-form { display: flex; flex-direction: column; gap: 20px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-required { color: var(--error); }
.form-optional { color: var(--muted); font-size: var(--text-xs); font-weight: normal; }
.contact-form__privacy {
    display: flex; align-items: center; gap: 6px;
    font-size: var(--text-xs); color: var(--muted); margin-top: 4px; justify-content: center;
}
.contact-form__privacy svg { flex-shrink: 0; color: var(--success); }

.form-success-message,
.form-error-message {
    display: flex; align-items: flex-start; gap: 16px;
    padding: 20px 24px; border-radius: var(--radius); margin-bottom: 24px;
}
.form-success-message { background: rgba(45,106,79,0.1); border: 1px solid var(--success); color: var(--success); }
.form-error-message { background: rgba(198,40,40,0.08); border: 1px solid var(--error); color: var(--error); }
.form-success-message strong, .form-error-message strong { display: block; margin-bottom: 4px; }
.form-success-message p, .form-error-message p { margin: 0; font-size: var(--text-sm); opacity: 0.85; }


/* ── FAQ Page ────────────────────────────────────────────────────────────────── */
.faq-page { max-width: 860px; margin: 0 auto; }

.faq-jump-links {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    padding: 16px 20px;
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    margin-bottom: 48px;
}
.faq-jump-links__label {
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--muted);
    margin-right: 4px;
}
.faq-jump-links a {
    font-size: var(--text-sm);
    color: var(--forest);
    text-decoration: none;
    padding: 4px 12px;
    border-radius: 100px;
    border: 1px solid var(--rule);
    background: var(--white);
    transition: all var(--transition);
    white-space: nowrap;
}
.faq-jump-links a:hover {
    background: var(--forest);
    color: var(--white);
    border-color: var(--forest);
}

.faq-category { margin-bottom: 56px; }
.faq-category__title {
    font-size: var(--text-xl);
    color: var(--forest-dark);
    padding-bottom: 12px;
    border-bottom: 2px solid var(--gold);
    margin-bottom: 0;
    display: inline-block;
}

.faq-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 48px;
    padding-bottom: 32px;
    border-bottom: 1px solid var(--rule);
    justify-content: center;
}
.faq-nav__link {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 10px 20px;
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: 100px;
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--forest-dark);
    text-decoration: none;
    transition: background var(--transition), border-color var(--transition), color var(--transition);
    flex: 0 0 calc(33.333% - 6px);
    text-align: left;
}
.faq-nav__link {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 10px 20px;
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: 100px;
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--forest-dark);
    text-decoration: none;
    transition: background var(--transition), border-color var(--transition), color var(--transition);
    text-align: left;
}
.faq-nav__link:hover { background: var(--forest-dark); color: var(--white); border-color: var(--forest-dark); }
.faq-nav__count {
    background: var(--forest-dark);
    color: var(--gold-light);
    font-size: var(--text-xs);
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 100px;
    min-width: 20px;
    text-align: center;
}
.faq-nav__link:hover .faq-nav__count { background: var(--gold); color: var(--ink); }

.faq-contact-box {
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 40px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    margin-top: 48px;
    flex-wrap: wrap;
}
.faq-contact-box__text h2 { font-size: var(--text-2xl); color: var(--forest-dark); margin-bottom: 8px; }
.faq-contact-box__text p { color: var(--slate); margin: 0; }
.faq-contact-box__actions { display: flex; gap: 12px; flex-wrap: wrap; flex-shrink: 0; }

.faq-contact-cta {
    text-align: center;
    padding: 48px;
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    margin-top: 48px;
}
.faq-contact-cta h2 {
    font-size: var(--text-2xl);
    color: var(--forest-dark);
    margin-bottom: 12px;
}
.faq-contact-cta p {
    color: var(--slate);
    margin-bottom: 28px;
    font-size: var(--text-lg);
}
.faq-contact-cta__buttons {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    flex-wrap: wrap;
}

/* ── FAQ Page — Mobile ───────────────────────────────────────────────────────── */


@media (max-width: 768px) {

    :root { --container-pad: 16px; }
    .section { padding: 48px 0; }

    /* Header — hide desktop logo and nav, show mobile logo and hamburger */
    .site-nav, .btn--header-cta { display: none; }
    .mobile-menu-toggle { display: flex; }
    .site-logo__img--desktop { display: none !important; }
    .site-logo__img--mobile { display: block !important; }

    /* Hero */
    .hero { padding: 48px 0; }
    .hero__inner { grid-template-columns: 1fr; gap: 32px; }
    .hero__heading { font-size: var(--text-3xl); }
    .hero__form-card { max-width: 480px; }
    .hero__trust { gap: 10px 16px; }

    /* Quick Answer Strip */
    .quick-answer-strip__inner { flex-direction: column; align-items: flex-start; gap: 8px; }

    /* Trust bar — 2 columns */
    .trust-bar__inner { gap: 16px; flex-wrap: wrap; }
    .trust-bar__divider { display: none; }
    .trust-stat { flex: 0 0 calc(50% - 8px); }
    .trust-stat__number { font-size: var(--text-3xl); }

    /* About */
    .about-mission { grid-template-columns: 1fr; gap: 40px; }
    .about-mike { grid-template-columns: 1fr; gap: 40px; }
    .network-grid { grid-template-columns: repeat(2, 1fr); }
    .florida-regions { grid-template-columns: repeat(2, 1fr); }

    /* Contact */
    .contact-layout { grid-template-columns: 1fr; gap: 40px; }
    .form-row { grid-template-columns: 1fr; }
    .contact-form-card { padding: 28px; }
    .problem-grid { grid-template-columns: 1fr; }
    .who-grid { grid-template-columns: repeat(2, 1fr); }

    /* How It Works */
    .hiw-step { grid-template-columns: 56px 1fr; gap: 20px; }
    .hiw-step__number { width: 48px; height: 48px; font-size: var(--text-xl); }
    .hiw-connector { margin-left: 23px; }
    .hiw-step__title { font-size: var(--text-xl); }

    /* Comparison table — make scrollable on mobile */
    .comparison-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .comparison-table { min-width: 480px; }
    .comparison-table th, .comparison-table td { padding: 10px 12px; font-size: var(--text-xs); }

    /* Steps */
    .steps-grid { grid-template-columns: 1fr; gap: 16px; }

    /* Benefits */
    .benefits-grid { grid-template-columns: repeat(2, 1fr); }

    /* About preview */
    .about-preview__inner { grid-template-columns: 1fr; gap: 32px; }
    .about-preview__credentials { flex-direction: row; flex-wrap: wrap; }
    .credential-card { flex: 1; min-width: 120px; }

    /* Get Offer form — stack sidebar below form on mobile */
    .offer-layout { display: block !important; }
    .offer-sidebar { display: flex !important; position: static !important; margin-top: 32px; width: 100%; }
    .offer-form-wrap { width: 100%; }

    /* FAQ nav pills */
    .faq-nav { grid-template-columns: 1fr 1fr; }
    .faq-nav__link { font-size: var(--text-xs); padding: 8px 12px; }

/* County pages */
    .county-layout { display: block !important; }
    .county-sidebar { position: static !important; width: 100%; margin-bottom: 24px; }
    .county-sidebar__fact { flex-direction: column; align-items: flex-start; gap: 2px; padding: 10px 16px; }
    .county-sidebar__fact span { font-size: var(--text-xs); }
    .county-sidebar__fact strong { font-size: var(--text-base); }
    .county-land-types { grid-template-columns: 1fr; }
    .county-grid { grid-template-columns: repeat(2, 1fr); }
    .county-direct-answer__inner { flex-direction: column; gap: 8px; }

    /* Footer */
    .footer-cta-band__inner { flex-direction: column; text-align: center; }
    .footer-main__grid { grid-template-columns: 1fr 1fr; gap: 32px; }
    .footer-col--brand { grid-column: 1 / -1; }
    .footer-bottom__inner { flex-direction: column; text-align: center; gap: 12px; }

    /* Sections */
    .section-title { font-size: var(--text-2xl); }
    .page-hero__heading { font-size: var(--text-3xl); }
    .page-hero { padding: 40px 0; }

    /* Thank you */
    .thankyou-layout { grid-template-columns: 1fr; gap: 32px; }
    .thankyou-actions { flex-direction: column; }

    /* Admin */
    .lead-detail-layout { grid-template-columns: 1fr; }
    .lead-detail-actions { position: static; }
    .admin-data-grid { grid-template-columns: 1fr; }
}


/* ═══════════════════════════════════════════════════════════════════════════════
   RESPONSIVE — Mobile (480px)
   ═══════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {

    /* Header */
    .top-bar__message { display: none; }
    .site-logo__img--desktop { display: none !important; }
    .site-logo__img--mobile { display: block !important; }

    /* Hero */
    .hero { background-position: center center; }
    .hero__heading { font-size: var(--text-2xl); }
    .hero__trust { flex-direction: column; gap: 8px; }
    .btn--hero { width: 100%; }
    .hero__content { padding-top: 0; }

    /* Trust bar */
    .trust-stat { flex: 0 0 100%; }
    .trust-stat__number { font-size: var(--text-3xl); }

    /* Quick Answer Strip */
    .quick-answer-strip { padding: 12px 0; }
    .quick-answer-strip__inner { flex-direction: column; align-items: flex-start; gap: 6px; }

    /* Benefits */
    .benefits-grid { grid-template-columns: 1fr; }

    /* About */
    .about-mission__values { grid-template-columns: 1fr; }
    .network-grid { grid-template-columns: 1fr; }
    .florida-regions { grid-template-columns: 1fr; }

    /* Why Us */
    .who-grid { grid-template-columns: 1fr; }
    .solution-item { grid-template-columns: 40px 1fr; gap: 16px; }

    /* FAQ nav — single column on small phones */
    .faq-nav { grid-template-columns: 1fr; }

    /* County directory */
    .county-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
    .county-card { padding: 12px; }
    .county-card__name { font-size: var(--text-sm); }

    /* Get offer form */
    .step-progress__item span { display: none; }
    .offer-trust-bar__inner { gap: 12px; }
    .offer-trust-item { font-size: var(--text-xs); }

    /* Page hero */
    .page-hero__heading { font-size: var(--text-2xl); }
    .page-hero { padding: 32px 0; }
    .page-hero__sub { font-size: var(--text-base); }

    /* Footer */
    .footer-main__grid { grid-template-columns: 1fr; }
    .footer-bottom__links { flex-wrap: wrap; justify-content: center; }
    .footer-logo-wrap { justify-content: center; }

    /* Section CTA */
    .section-cta { flex-direction: column; align-items: stretch; }
    .section-cta .btn { text-align: center; }

    /* Legal pages */
    .legal-content { font-size: var(--text-sm); }

    /* FAQ contact box */
    .faq-contact-box { flex-direction: column; }
    .faq-contact-box__actions { flex-direction: column; width: 100%; }
    .faq-contact-box__actions .btn { width: 100%; text-align: center; }
}

/* ── Get Offer Page ───────────────────────────────────────────────────────────── */
.page-hero--compact { padding: 36px 0; }

.offer-trust-bar { background: var(--forest); padding: 12px 0; }
.offer-trust-bar__inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    flex-wrap: wrap;
}
.offer-trust-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: var(--text-sm);
    color: rgba(255,255,255,0.9);
}
.offer-trust-item svg { color: var(--gold-light); flex-shrink: 0; }

.offer-section { padding-top: 48px; }
.offer-layout {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 48px;
    align-items: flex-start;
}

/* Step Progress */
.step-progress {
    display: flex;
    align-items: center;
    margin-bottom: 40px;
}
.step-progress__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}
.step-progress__item span {
    font-size: var(--text-xs);
    color: var(--muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.step-progress__dot {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--rule);
    color: var(--muted);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: var(--text-sm);
    transition: background var(--transition), color var(--transition);
}
.step-progress__item--active .step-progress__dot {
    background: var(--forest-dark);
    color: var(--gold-light);
}
.step-progress__item--active span { color: var(--forest-dark); }
.step-progress__item--complete .step-progress__dot {
    background: var(--success);
    color: var(--white);
}
.step-progress__item--complete .step-progress__dot::before { content: '✓'; }
.step-progress__line {
    flex: 1;
    height: 2px;
    background: var(--rule);
    margin: 0 8px;
    margin-bottom: 22px;
}

/* Form Steps */
/* First step visible by default — JS will manage after load */
/* Form steps — use position absolute so page height stays constant */
.offer-form { position: relative; }
.form-step {
    display: none;
    animation: fadeIn 0.2s ease;
}
.form-step--active { display: block; }
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}
.form-step__header { margin-bottom: 32px; }
.form-step__title { font-size: var(--text-2xl); color: var(--forest-dark); margin-bottom: 8px; }
.form-step__sub { font-size: var(--text-base); color: var(--slate); }
.form-step__nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid var(--rule);
}

/* Radio & Checkbox groups */
.form-radio-group,
.form-checkbox-group {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 8px;
}
.form-radio,
.form-checkbox {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: var(--text-base);
    color: var(--slate);
    cursor: pointer;
    padding: 10px 14px;
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    transition: border-color var(--transition), background var(--transition);
}
.form-radio:hover,
.form-checkbox:hover { border-color: var(--forest); background: var(--cream); }
.form-radio input,
.form-checkbox input { flex-shrink: 0; width: 16px; height: 16px; accent-color: var(--forest-dark); cursor: pointer; }

.form-hint { font-size: var(--text-xs); color: var(--muted); margin-top: 6px; }

/* Privacy notice */
.offer-privacy-notice {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: var(--text-xs);
    color: var(--muted);
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 12px 16px;
}
.offer-privacy-notice svg { color: var(--success); flex-shrink: 0; margin-top: 1px; }
.offer-privacy-notice p { margin: 0; line-height: 1.5; }
.offer-privacy-notice a { color: var(--forest); }

/* Submit button */
.offer-submit-btn { gap: 10px; min-width: 240px; }

/* Sidebar */
.offer-sidebar { display: flex; flex-direction: column; gap: 20px; }
.offer-sidebar__card {
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 28px 24px;
    box-shadow: var(--shadow);
}
.offer-sidebar__card--cream { background: var(--cream); }
.offer-sidebar__title { font-family: var(--font-body); font-size: var(--text-base); font-weight: 700; color: var(--forest-dark); margin-bottom: 20px; text-transform: uppercase; letter-spacing: 0.06em; font-size: var(--text-xs); }
.offer-sidebar__steps { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 20px; }
.offer-sidebar__steps li { display: flex; align-items: flex-start; gap: 14px; }
.offer-sidebar__num {
    width: 28px; height: 28px;
    background: var(--forest-dark); color: var(--gold-light);
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    font-size: var(--text-xs); font-weight: 700; flex-shrink: 0;
}
.offer-sidebar__steps strong { display: block; font-size: var(--text-sm); color: var(--ink); margin-bottom: 2px; }
.offer-sidebar__steps p { font-size: var(--text-xs); color: var(--muted); margin: 0; line-height: 1.5; }
.offer-sidebar__list { display: flex; flex-direction: column; gap: 8px; }
.offer-sidebar__list li {
    font-size: var(--text-sm); color: var(--slate);
    padding-left: 18px; position: relative;
}
.offer-sidebar__list li::before { content: '✓'; position: absolute; left: 0; color: var(--success); font-weight: 700; font-size: var(--text-xs); }
.offer-sidebar__phone { text-align: center; padding: 20px; background: var(--forest-dark); border-radius: var(--radius); }
.offer-sidebar__phone p { font-size: var(--text-sm); color: rgba(255,255,255,0.7); margin-bottom: 8px; }
.offer-sidebar__phone-link {
    display: inline-flex; align-items: center; gap: 8px;
    color: var(--gold-light); font-size: var(--text-lg); font-weight: 700; text-decoration: none;
}
.offer-sidebar__phone-link:hover { color: var(--white); }


/* ── Thank You Page ───────────────────────────────────────────────────────────── */
.thankyou-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 48px;
    align-items: flex-start;
}
.thankyou-icon {
    color: var(--success);
    margin-bottom: 24px;
}
.thankyou-main h2 { font-size: var(--text-2xl); color: var(--forest-dark); margin-bottom: 16px; }
.thankyou-main > p { font-size: var(--text-lg); color: var(--slate); margin-bottom: 32px; }
.thankyou-steps { display: flex; flex-direction: column; gap: 20px; margin-bottom: 40px; }
.thankyou-step { display: flex; gap: 16px; align-items: flex-start; }
.thankyou-step__num {
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--forest-dark); color: var(--gold-light);
    display: flex; align-items: center; justify-content: center;
    font-size: var(--text-sm); font-weight: 700; flex-shrink: 0;
}
.thankyou-step__content strong { display: block; color: var(--ink); margin-bottom: 4px; }
.thankyou-step__content p { font-size: var(--text-sm); color: var(--slate); margin: 0; }
.thankyou-actions { display: flex; gap: 16px; flex-wrap: wrap; }
.thankyou-sidebar__card {
    background: var(--white); border: 1px solid var(--rule);
    border-radius: var(--radius); padding: 28px 24px;
    box-shadow: var(--shadow); margin-bottom: 20px;
}
.thankyou-sidebar__card h3 { font-family: var(--font-body); font-size: var(--text-base); font-weight: 700; color: var(--forest-dark); margin-bottom: 12px; }
.thankyou-sidebar__card p  { font-size: var(--text-sm); color: var(--slate); margin-bottom: 16px; }
.thankyou-sidebar__card--cream { background: var(--cream); }
.thankyou-phone {
    display: flex; align-items: center; gap: 10px;
    color: var(--forest-dark); font-size: var(--text-xl); font-weight: 700; text-decoration: none;
    margin-bottom: 8px;
}
.thankyou-phone:hover { color: var(--forest); }
.thankyou-hours { font-size: var(--text-xs); color: var(--muted); margin: 0 !important; }
.thankyou-promise-list { display: flex; flex-direction: column; gap: 8px; }
.thankyou-promise-list li {
    font-size: var(--text-sm); color: var(--slate);
    padding-left: 20px; position: relative;
}
.thankyou-promise-list li::before { content: '✓'; position: absolute; left: 0; color: var(--success); font-weight: 700; }

/* ── Legal Pages (Privacy Policy, Terms) ─────────────────────────────────────── */
.legal-content {
    max-width: 800px;
    margin: 0 auto;
}
.legal-intro {
    background: var(--cream);
    border-left: 4px solid var(--gold);
    border-radius: 0 var(--radius) var(--radius) 0;
    padding: 20px 24px;
    margin-bottom: 40px;
}
.legal-intro p { color: var(--slate); margin-bottom: 8px; }
.legal-intro p:last-child { margin-bottom: 0; }
.legal-content h2 {
    font-size: var(--text-xl);
    color: var(--forest-dark);
    margin: 40px 0 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--rule);
}
.legal-content h3 {
    font-size: var(--text-lg);
    color: var(--forest-dark);
    margin: 24px 0 8px;
    font-family: var(--font-body);
    font-weight: 700;
}
.legal-content p { color: var(--slate); margin-bottom: 16px; line-height: 1.8; }
.legal-content ul { padding-left: 24px; margin-bottom: 16px; }
.legal-content ul li { color: var(--slate); margin-bottom: 8px; list-style: disc; line-height: 1.7; }
.legal-contact {
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 20px 24px;
    margin-top: 8px;
}
.legal-contact p { margin: 0; color: var(--slate); line-height: 1.8; }
.legal-contact a { color: var(--forest); }

/* ── County Directory Page ───────────────────────────────────────────────────── */
.county-region { margin-bottom: 48px; }
.county-region__title {
    font-size: var(--text-xl);
    color: var(--forest-dark);
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--gold);
    display: inline-block;
}
.county-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}
.county-card {
    display: flex;
    flex-direction: column;
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 16px;
    text-decoration: none;
    transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
    box-shadow: var(--shadow-sm);
}
.county-card:hover {
    border-color: var(--forest);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
    text-decoration: none;
}
.county-card__name { font-weight: 700; color: var(--forest-dark); font-size: var(--text-base); margin-bottom: 4px; }
.county-card__seat { font-size: var(--text-xs); color: var(--muted); margin-bottom: 10px; flex: 1; }
.county-card__cta { font-size: var(--text-xs); color: var(--forest); font-weight: 600; }
.county-card:hover .county-card__cta { color: var(--gold); }

/* ── County Individual Page ──────────────────────────────────────────────────── */
.county-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 56px;
    align-items: flex-start;
}
.county-content h2 {
    font-size: var(--text-2xl);
    color: var(--forest-dark);
    margin: 40px 0 16px;
}
.county-content h2:first-child { margin-top: 0; }
.county-content p { color: var(--slate); margin-bottom: 16px; line-height: 1.7; }
.county-intro__lead {
    font-size: var(--text-lg);
    color: var(--forest-dark);
    font-family: var(--font-heading);
    line-height: 1.6;
    margin-bottom: 40px;
}
.county-benefits { display: flex; flex-direction: column; gap: 16px; margin-bottom: 40px; }
.county-benefit {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    padding: 16px 20px;
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
}
.county-benefit__icon { font-size: 24px; flex-shrink: 0; }
.county-benefit strong { display: block; color: var(--forest-dark); margin-bottom: 2px; }
.county-benefit p { font-size: var(--text-sm); color: var(--muted); margin: 0; }
.county-land-types {
    padding-left: 20px;
    margin-bottom: 40px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.county-land-types li { color: var(--slate); font-size: var(--text-sm); list-style: disc; }
.county-situations { display: flex; flex-direction: column; gap: 12px; margin-bottom: 40px; }
.county-situation {
    padding: 14px 16px;
    background: var(--white);
    border: 1px solid var(--rule);
    border-left: 3px solid var(--forest);
    border-radius: 0 var(--radius) var(--radius) 0;
    font-size: var(--text-sm);
    color: var(--slate);
}
.county-situation strong { color: var(--forest-dark); display: block; margin-bottom: 2px; }
.county-pa-link {
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 24px;
    margin-top: 40px;
}
.county-pa-link h3 { font-family: var(--font-body); font-size: var(--text-lg); font-weight: 700; color: var(--forest-dark); margin-bottom: 8px; }
.county-pa-link p { font-size: var(--text-sm); color: var(--slate); margin-bottom: 16px; }

/* County Sidebar */
.county-sidebar { display: flex; flex-direction: column; gap: 20px; }
.county-sidebar__card {
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 24px;
    box-shadow: var(--shadow);
}
.county-sidebar__card--featured { border-top: 3px solid var(--gold); }
.county-sidebar__card h3 { font-family: var(--font-body); font-size: var(--text-base); font-weight: 700; color: var(--forest-dark); margin-bottom: 8px; }
.county-sidebar__card p { font-size: var(--text-sm); color: var(--slate); margin-bottom: 16px; }
.county-sidebar__phone {
    display: flex; align-items: center; gap: 8px;
    color: var(--forest-dark); font-size: var(--text-base); font-weight: 600; text-decoration: none;
}
.county-sidebar__phone:hover { color: var(--forest); }
.county-sidebar__facts { display: flex; flex-direction: column; gap: 1px; }
.county-sidebar__fact {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 0; border-bottom: 1px solid var(--rule); font-size: var(--text-sm);
}
.county-sidebar__fact:last-child { border-bottom: none; }
.county-sidebar__fact span { color: var(--muted); }
.county-sidebar__fact strong { color: var(--forest-dark); }

/* County — Mobile */
@media (max-width: 768px) {
    .county-grid { grid-template-columns: repeat(2, 1fr); }
    .county-layout { display: block !important; }
    .county-sidebar { position: static !important; order: -1; width: 100%; margin-bottom: 24px; }
    .county-land-types { grid-template-columns: 1fr; }
    .county-sidebar__fact { flex-direction: column; align-items: flex-start; gap: 2px; }
    .county-sidebar__fact span { font-size: var(--text-xs); }
    .county-sidebar__fact strong { font-size: var(--text-base); }
    .county-content { width: 100%; }
}
@media (max-width: 480px) {
    .county-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
    .county-direct-answer__inner { flex-direction: column; gap: 8px; }
}

/* About page photo — mobile */
@media (max-width: 768px) {
    .about-mike__sidebar {
        max-width: 320px;
        margin: 0 auto;
        width: 100%;
    }
    .about-mike__photo img {
        max-height: 360px;
        object-fit: cover;
        object-position: center top;
    }
}

/* ── County Cities & Zips ─────────────────────────────────────────────────────── */
.county-cities-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 16px 0 32px;
}
.county-city-tag {
    display: inline-block;
    padding: 5px 14px;
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: 100px;
    font-size: var(--text-sm);
    color: var(--forest-dark);
    font-weight: 500;
    text-decoration: none;
}
a.county-city-tag {
    cursor: pointer;
    transition: all var(--transition);
}
a.county-city-tag:hover {
    background: var(--forest-dark);
    color: var(--white);
    border-color: var(--forest-dark);
    text-decoration: none;
}
.county-zips {
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 16px 20px;
    margin-bottom: 32px;
}
.county-zips h3 {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
    margin-bottom: 8px;
}
.county-zips__list {
    font-size: var(--text-sm);
    color: var(--muted);
    line-height: 1.8;
    margin: 0;
}

/* ── County Cities & ZIP Sections ────────────────────────────────────────────── */
.county-cities-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 24px;
}
.county-zip-list {
    font-size: var(--text-sm);
    color: var(--muted);
    line-height: 2;
    letter-spacing: 0.02em;
    margin-bottom: 24px;
}

/* ── County Direct Answer Box (AEO/GEO) ─────────────────────────────────────── */
.county-direct-answer {
    background: #f0f7f2;
    border-top: 3px solid var(--forest);
    border-bottom: 1px solid #cce0d4;
    padding: 16px 0;
}
.county-direct-answer__inner {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}
.county-direct-answer__label {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: var(--forest-dark);
    color: var(--gold-light);
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 4px 10px;
    border-radius: 100px;
    white-space: nowrap;
    flex-shrink: 0;
    margin-top: 2px;
}
.county-direct-answer p {
    font-size: var(--text-base);
    color: var(--slate);
    margin: 0;
    line-height: 1.6;
}
.county-direct-answer strong { color: var(--forest-dark); }

/* ── County Nearby Counties ──────────────────────────────────────────────────── */
.county-nearby {
    background: var(--cream);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    padding: 20px 24px;
    margin-top: 32px;
}
.county-nearby h3 { font-family: var(--font-body); font-size: var(--text-base); font-weight: 700; color: var(--forest-dark); margin-bottom: 8px; }
.county-nearby p { font-size: var(--text-sm); color: var(--slate); margin-bottom: 12px; }
.county-nearby__list { display: flex; flex-wrap: wrap; gap: 8px; }
.county-nearby__link {
    display: inline-block;
    padding: 5px 14px;
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: 100px;
    font-size: var(--text-sm);
    color: var(--forest);
    text-decoration: none;
    transition: all var(--transition);
}
.county-nearby__link:hover { background: var(--forest-dark); color: var(--white); border-color: var(--forest-dark); }
.county-nearby__link--all { background: var(--forest-dark); color: var(--white); border-color: var(--forest-dark); font-weight: 600; }
.county-nearby__link--all:hover { background: var(--forest); }

/* ── County Authority Box ────────────────────────────────────────────────────── */
.county-authority {
    background: var(--cream);
    border-left: 4px solid var(--gold);
    border-radius: 0 var(--radius) var(--radius) 0;
    padding: 20px 24px;
    margin-top: 32px;
}
.county-authority h3 { font-family: var(--font-body); font-size: var(--text-base); font-weight: 700; color: var(--forest-dark); margin-bottom: 8px; }
.county-authority p { font-size: var(--text-sm); color: var(--slate); margin: 0; line-height: 1.7; }

/* ── County Zip inline ───────────────────────────────────────────────────────── */
.county-zips { margin-top: 24px; margin-bottom: 8px; }
.county-zips h3 { font-family: var(--font-body); font-size: var(--text-base); font-weight: 700; color: var(--forest-dark); margin-bottom: 8px; }
.county-zips p { font-size: var(--text-sm); color: var(--slate); margin: 0; line-height: 1.8; }
.county-zip-list { color: var(--muted); }

@media (max-width: 768px) {
    .county-direct-answer__inner { flex-direction: column; gap: 8px; }
}

/* ── Mobile Comparison Cards ─────────────────────────────────────────────────── */
.comparison-table--desktop { display: block; }
.comparison-mobile { display: none; }

@media (max-width: 640px) {
    .comparison-table--desktop { display: none; }
    .comparison-mobile { display: flex; flex-direction: column; gap: 10px; }
    .comparison-mobile__row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto auto;
        gap: 0;
        background: var(--white);
        border: 1px solid var(--rule);
        border-radius: var(--radius);
        overflow: hidden;
    }
    .comparison-mobile__label {
        grid-column: 1 / -1;
        background: var(--cream);
        padding: 8px 14px;
        font-size: var(--text-xs);
        font-weight: 700;
        color: var(--slate);
        text-transform: uppercase;
        letter-spacing: 0.06em;
        border-bottom: 1px solid var(--rule);
    }
    .comparison-mobile__us,
    .comparison-mobile__them {
        padding: 12px 14px;
        font-size: var(--text-sm);
    }
    .comparison-mobile__us { border-right: 1px solid var(--rule); background: rgba(45,90,61,0.04); }
    .comparison-mobile__col-head {
        font-size: var(--text-xs);
        font-weight: 700;
        color: var(--muted);
        text-transform: uppercase;
        letter-spacing: 0.06em;
        margin-bottom: 4px;
    }
    .comparison-mobile__us .comparison-mobile__col-head { color: var(--forest-dark); }
    .comp-good, .comp-bad { display: block; }
    .comp-good::before, .comp-bad::before { display: none; }
    .comp-good { color: var(--success); font-weight: 600; }
    .comp-bad  { color: var(--muted); }
}

/* ── City Direct Answer Box ──────────────────────────────────────────────────── */
.city-direct-answer {
    background: #f0f7f2;
    border-top: 3px solid var(--forest);
    border-bottom: 1px solid #cce0d4;
    padding: 16px 0;
}
.city-direct-answer__inner {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}
.city-direct-answer__label {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: var(--forest-dark);
    color: var(--gold-light);
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 4px 10px;
    border-radius: 100px;
    white-space: nowrap;
    flex-shrink: 0;
    margin-top: 2px;
}
.city-direct-answer p { font-size: var(--text-base); color: var(--slate); margin: 0; line-height: 1.6; }
.city-direct-answer strong { color: var(--forest-dark); }
@media (max-width: 768px) {
    .city-direct-answer__inner { flex-direction: column; gap: 8px; }
}

/* ── City tag links on county pages ─────────────────────────────────────────── */
.county-city-tag--link {
    text-decoration: none;
    transition: all var(--transition);
    cursor: pointer;
}
.county-city-tag--link:hover {
    background: var(--forest-dark);
    color: var(--white);
    border-color: var(--forest-dark);
}

/* ── Nav Dropdown ────────────────────────────────────────────────────────────── */
.site-nav__has-dropdown { position: relative; }
.site-nav__dropdown {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    min-width: 180px;
    list-style: none;
    padding: 8px 0;
    z-index: 100;
    margin-top: 0;
}
.site-nav__has-dropdown::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    height: 12px;
}
.site-nav__has-dropdown:hover .site-nav__dropdown,
.site-nav__has-dropdown:focus-within .site-nav__dropdown { display: block; }
.site-nav__dropdown li a {
    display: block;
    padding: 10px 18px;
    font-size: var(--text-sm);
    color: var(--slate);
    text-decoration: none;
    white-space: nowrap;
    transition: background var(--transition);
}
.site-nav__dropdown li a:hover { background: var(--cream); color: var(--forest-dark); }

/* ── City CTA Strip (immediately after hero) ─────────────────────────────────── */
.city-cta-strip {
    background: var(--forest-dark);
    padding: 16px 0;
    border-bottom: 3px solid var(--gold);
}
.city-cta-strip__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: wrap;
}
.city-cta-strip__text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.city-cta-strip__text strong {
    color: var(--white);
    font-size: var(--text-base);
}
.city-cta-strip__text span {
    color: var(--gold-light, #e8c87a);
    font-size: var(--text-sm);
}
.city-cta-strip__actions {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-shrink: 0;
}
.city-cta-strip__phone {
    color: var(--white);
    font-weight: 600;
    font-size: var(--text-sm);
    text-decoration: none;
    white-space: nowrap;
}
.city-cta-strip__phone:hover { color: var(--gold-light, #e8c87a); }
@media (max-width: 640px) {
    .city-cta-strip__inner { flex-direction: column; align-items: flex-start; }
    .city-cta-strip__actions { width: 100%; flex-direction: column; align-items: stretch; }
    .city-cta-strip__phone { text-align: center; padding: 8px 0; }
}

/* ── City Mid-page CTA Band ──────────────────────────────────────────────────── */
.city-mid-cta {
    background: var(--cream);
    border-top: 1px solid var(--rule);
    border-bottom: 1px solid var(--rule);
    padding: 28px 0;
}
.city-mid-cta__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}
.city-mid-cta__inner > div:first-child strong {
    display: block;
    font-size: var(--text-lg);
    color: var(--forest-dark);
    margin-bottom: 4px;
}
.city-mid-cta__inner > div:first-child p {
    font-size: var(--text-sm);
    color: var(--muted);
    margin: 0;
}
.city-mid-cta__actions {
    display: flex;
    gap: 12px;
    flex-shrink: 0;
    flex-wrap: wrap;
}
@media (max-width: 640px) {
    .city-mid-cta__inner { flex-direction: column; }
    .city-mid-cta__actions { width: 100%; flex-direction: column; }
    .city-mid-cta__actions .btn { width: 100%; text-align: center; }
}

/* ── City Subdivision Tags ───────────────────────────────────────────────────── */
.city-subdivisions {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin: 16px 0 12px;
}
.city-subdivision-tag {
    display: inline-block;
    padding: 4px 12px;
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: 100px;
    font-size: var(--text-xs);
    color: var(--slate);
    line-height: 1.5;
}
.city-subdivisions__note {
    font-size: var(--text-sm);
    color: var(--muted);
    margin-top: 8px;
}
.city-subdivisions__note a { color: var(--forest); }

/* ── Homepage Service Areas Section ─────────────────────────────────────────── */
.homepage-areas__heading {
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--forest-dark);
    margin: 0 0 16px;
}
.homepage-counties {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}
.homepage-county-tag {
    display: inline-block;
    padding: 5px 14px;
    background: var(--white);
    border: 1px solid var(--rule);
    border-radius: 100px;
    font-size: var(--text-sm);
    color: var(--forest-dark);
    font-weight: 500;
    text-decoration: none;
    transition: all var(--transition);
}
.homepage-county-tag:hover {
    background: var(--forest-dark);
    color: var(--white);
    border-color: var(--forest-dark);
}
.homepage-regions {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 20px;
}
.homepage-region__label {
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--muted);
    margin-bottom: 8px;
}
.homepage-region__cities {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.homepage-region__city {
    font-size: var(--text-sm);
    color: var(--forest);
    text-decoration: none;
    padding: 2px 0;
}
.homepage-region__city:hover {
    color: var(--forest-dark);
    text-decoration: underline;
}
@media (max-width: 640px) {
    .homepage-regions {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ── Community Lot Owner Callout ─────────────────────────────────────────────── */
.community-lot-owner-note {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    background: #fffbf0;
    border: 1px solid #e8c87a;
    border-left: 4px solid var(--gold);
    border-radius: var(--radius);
    padding: 20px;
    margin: 24px 0 32px;
}
.community-lot-owner-note__icon {
    font-size: 28px;
    flex-shrink: 0;
    line-height: 1;
}
.community-lot-owner-note strong {
    display: block;
    font-size: var(--text-base);
    color: var(--forest-dark);
    margin-bottom: 6px;
}
.community-lot-owner-note p {
    font-size: var(--text-sm);
    color: var(--slate);
    margin: 0;
    line-height: 1.6;
}
@media (max-width: 480px) {
    .community-lot-owner-note { flex-direction: column; gap: 10px; }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   ACCESSIBILITY & PERFORMANCE ENHANCEMENTS
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ── Focus Styles (WCAG 2.1 AA — visible focus for keyboard navigation) ─────── */
:focus-visible {
    outline: 3px solid var(--gold);
    outline-offset: 3px;
    border-radius: 2px;
}
:focus:not(:focus-visible) {
    outline: none;
}

/* High contrast mode support */
@media (forced-colors: active) {
    :focus-visible {
        outline: 3px solid ButtonText;
    }
    .btn {
        border: 2px solid ButtonText;
    }
}

/* ── Reduced Motion (respects user OS preference) ───────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

/* ── Skip Navigation Link ────────────────────────────────────────────────────── */
.skip-nav {
    position: absolute;
    top: -100%;
    left: 0;
    background: var(--gold);
    color: #fff;
    padding: 12px 20px;
    font-weight: 700;
    font-size: var(--text-base);
    z-index: 9999;
    text-decoration: none;
    border-radius: 0 0 4px 0;
    transition: top 0.2s;
}
.skip-nav:focus {
    top: 0;
}

/* ── Color Contrast Improvements ────────────────────────────────────────────── */
/* Ensure all text meets WCAG AA 4.5:1 ratio */
.form-hint,
.form-optional,
.breadcrumb__sep {
    color: #595959; /* Was #888 — improved contrast ratio */
}
.footer-bottom__copy {
    color: #d4d4d4; /* Improved on dark background */
}

/* ── Image Optimization ──────────────────────────────────────────────────────── */
img {
    max-width: 100%;
    height: auto;
}
/* Prevent layout shift while images load */
img[width][height] {
    aspect-ratio: attr(width) / attr(height);
}

/* ── Content Visibility — defer off-screen rendering ────────────────────────── */
/* Applied to sections below the fold to improve initial paint */
.section:not(:first-of-type),
.trust-bar,
.footer-main {
    content-visibility: auto;
    contain-intrinsic-size: 0 500px;
}

/* ── Print Styles ────────────────────────────────────────────────────────────── */
@media print {
    .site-header,
    .top-bar,
    .mobile-menu,
    .footer-cta-band,
    .site-footer,
    .btn,
    nav {
        display: none !important;
    }
    body {
        font-size: 12pt;
        color: #000;
        background: #fff;
    }
    a[href]::after {
        content: " (" attr(href) ")";
        font-size: 10pt;
        color: #555;
    }
    h1, h2, h3 {
        page-break-after: avoid;
    }
    p, blockquote {
        orphans: 3;
        widows: 3;
    }
}

/* ── Improved Touch Targets (mobile accessibility) ───────────────────────────── */
@media (max-width: 768px) {
    .site-nav__link,
    .mobile-menu__link,
    .footer-nav a,
    .footer-bottom__links a {
        min-height: 44px; /* Apple/Google recommended minimum touch target */
        display: flex;
        align-items: center;
    }
    .mobile-menu__link {
        padding: 12px 24px;
    }
}

/* ── Smooth Scrolling (respects reduced motion) ──────────────────────────────── */
@media (prefers-reduced-motion: no-preference) {
    html {
        scroll-behavior: smooth;
    }
}

/* ── Selection Color ─────────────────────────────────────────────────────────── */
::selection {
    background-color: var(--gold);
    color: #fff;
}
::-moz-selection {
    background-color: var(--gold);
    color: #fff;
}

/* ── Scrollbar Styling (Webkit) ──────────────────────────────────────────────── */
::-webkit-scrollbar {
    width: 8px;
}
::-webkit-scrollbar-track {
    background: var(--cream);
}
::-webkit-scrollbar-thumb {
    background: var(--forest);
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
    background: var(--forest-dark);
}

/* ── Footer Trust Items ──────────────────────────────────────────────────────── */
.footer-trust {
    margin-top: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.footer-trust__item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--text-sm);
    color: var(--slate);
}
.footer-trust__item svg {
    color: var(--forest);
    flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   AS SEEN IN — PRESS LOGO CAROUSEL
   Infinite auto-scroll, pauses on hover, respects reduced motion
   ═══════════════════════════════════════════════════════════════════════════════ */

.press-section {
    background: #fff;
    border-top: none;
    border-bottom: none;
    padding: 14px 0 12px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0,0,0,0.06);
    position: relative;
    z-index: 1;
}
.press-section__inner {
    text-align: center;
}
.press-section__label {
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #9ca3af;
    margin: 0 0 8px;
}

/* ── Scrolling track ────────────────────────────────────────────────── */
.press-track-wrapper {
    position: relative;
    overflow: hidden;
    /* Fade edges */
    mask-image: linear-gradient(
        to right,
        transparent 0%,
        #fff 8%,
        #fff 92%,
        transparent 100%
    );
    -webkit-mask-image: linear-gradient(
        to right,
        transparent 0%,
        #fff 8%,
        #fff 92%,
        transparent 100%
    );
}
.press-track {
    display: flex;
    align-items: center;
    gap: 48px;
    width: max-content;
    animation: pressScroll 45s linear infinite;
    animation-delay: 0s;
    will-change: transform;
    transform: translateX(0); /* Explicit start position — always begins at first logo */
}
.press-track:hover {
    animation-play-state: paused;
}
@keyframes pressScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

.press-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding: 4px 8px;
    opacity: 0.65;
    filter: grayscale(100%);
    transition: opacity 0.2s, filter 0.2s;
}
.press-logo:hover {
    opacity: 1;
    filter: grayscale(0%);
}
.press-logo img {
    height: 32px;
    width: auto;
    max-width: 120px;
    object-fit: contain;
}

/* ── Screen reader / accessible list (visually hidden) ──────────────── */
.press-list-accessible {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
    list-style: none;
}

/* ── Reduced motion — show static grid instead of scrolling ─────────── */
@media (prefers-reduced-motion: reduce) {
    .press-track {
        animation: none;
        flex-wrap: wrap;
        justify-content: center;
        width: auto;
        gap: 24px;
    }
    /* Hide the duplicate set */
    .press-track .press-logo:nth-child(n+19) {
        display: none;
    }
    .press-track-wrapper {
        mask-image: none;
        -webkit-mask-image: none;
    }
}

/* ── Mobile: tighter spacing ────────────────────────────────────────── */
@media (max-width: 640px) {
    .press-track {
        gap: 32px;
        animation-duration: 30s;
    }
    .press-logo img {
        height: 26px;
        max-width: 90px;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   GLOSSARY PAGE
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ── Intro band ─────────────────────────────────────────────────────────────── */
.glossary-intro-band {
    background: var(--cream);
    border-bottom: 1px solid var(--border);
    padding: 20px 0;
}
.glossary-intro-band__inner {
    display: flex;
    align-items: center;
    gap: 24px;
    justify-content: space-between;
    flex-wrap: wrap;
}
.glossary-intro-band__inner p {
    margin: 0;
    font-size: var(--text-sm);
    color: var(--slate);
    max-width: 700px;
    line-height: 1.6;
}
.glossary-intro-band__inner a:not(.btn) {
    color: var(--forest);
}

/* ── Letter nav bar ─────────────────────────────────────────────────────────── */
.glossary-nav-bar {
    background: var(--forest-dark);
    padding: 10px 0;
    position: sticky;
    top: 0;
    z-index: 50;
}
.glossary-nav-bar__inner {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    justify-content: center;
}
.glossary-nav-bar__letter {
    color: rgba(255,255,255,0.7);
    font-size: 13px;
    font-weight: 700;
    padding: 4px 8px;
    border-radius: 4px;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
    min-width: 28px;
    text-align: center;
}
.glossary-nav-bar__letter:hover {
    background: rgba(255,255,255,0.15);
    color: #fff;
}

/* ── Layout ─────────────────────────────────────────────────────────────────── */
.glossary-section {
    padding-top: 40px;
}
.glossary-layout {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 40px;
    align-items: start;
}
.glossary-sidebar {
    position: sticky;
    top: 56px; /* below sticky nav bar */
}

/* ── Letter anchor ──────────────────────────────────────────────────────────── */
.glossary-letter-anchor {
    display: flex;
    align-items: center;
    gap: 16px;
    margin: 40px 0 20px;
    scroll-margin-top: 60px;
}
.glossary-letter-anchor:first-child {
    margin-top: 0;
}
.glossary-letter-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background: var(--forest-dark);
    color: var(--gold);
    font-family: Georgia, serif;
    font-size: 24px;
    font-weight: 700;
    border-radius: 8px;
    flex-shrink: 0;
}

/* ── Individual term ────────────────────────────────────────────────────────── */
.glossary-entry {
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 20px 24px;
    margin-bottom: 12px;
    background: #fff;
    scroll-margin-top: 60px;
    transition: box-shadow 0.2s;
}
.glossary-entry:hover {
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.glossary-entry:target {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(201,151,58,0.15);
}
.glossary-entry__term {
    font-family: Georgia, serif;
    font-size: var(--text-lg);
    color: var(--forest-dark);
    margin: 0 0 10px;
    line-height: 1.3;
}
.glossary-entry__def p {
    color: var(--slate);
    font-size: var(--text-sm);
    line-height: 1.7;
    margin: 0 0 12px;
}
.glossary-entry__def p:last-child {
    margin-bottom: 0;
}

/* ── Florida context box ────────────────────────────────────────────────────── */
.glossary-entry__florida {
    background: #f0faf5;
    border-left: 3px solid var(--forest);
    border-radius: 0 6px 6px 0;
    padding: 12px 16px;
    margin: 12px 0;
}
.glossary-entry__florida-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--forest);
    margin-bottom: 6px;
}
.glossary-entry__florida p {
    font-size: 13px;
    color: var(--slate);
    margin: 0;
}

/* ── Related terms ──────────────────────────────────────────────────────────── */
.glossary-entry__related {
    font-size: 12px;
    color: #9ca3af;
    margin: 8px 0 0 !important;
}
.glossary-entry__related span {
    font-weight: 600;
    margin-right: 4px;
}
.glossary-entry__related a {
    color: var(--forest);
    text-decoration: none;
}
.glossary-entry__related a:hover {
    text-decoration: underline;
}

/* ── Sidebar letter grid ────────────────────────────────────────────────────── */
.glossary-sidebar__letters {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}
.glossary-sidebar__letter {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: var(--cream);
    color: var(--forest-dark);
    font-weight: 700;
    font-size: 13px;
    border-radius: 4px;
    text-decoration: none;
    border: 1px solid var(--border);
    transition: background 0.15s, color 0.15s;
}
.glossary-sidebar__letter:hover {
    background: var(--forest-dark);
    color: var(--gold);
    border-color: var(--forest-dark);
}

/* ── Mobile ─────────────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .glossary-layout {
        grid-template-columns: 1fr;
    }
    .glossary-sidebar {
        position: static;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 16px;
    }
}
@media (max-width: 600px) {
    .glossary-sidebar {
        grid-template-columns: 1fr;
    }
    .glossary-intro-band__inner {
        flex-direction: column;
        align-items: flex-start;
    }
    .glossary-entry {
        padding: 16px;
    }
}
