/* ── ZipEngine Frontend v2 — scoped to override TwentyTwentyFive ── */

/* ── Suppress default WordPress theme chrome ── */
#header[role="banner"], div#header, div#footer[role="contentinfo"],
div#footer, #headerimg, body > #page > hr,
#page > hr, hr + #ze-main-content ~ hr,
.wp-site-blocks > header, .wp-site-blocks > footer,
footer.wp-block-template-part, .wp-block-template-part[class*="footer"],
body > footer:not(#ze-sitefooter), #page > footer,
[class*="wp-block-template"]:not(#ze-sitefooter) footer { display: none !important; }

/* Override TwentyTwentyFive theme body padding which causes left-edge clipping */
body:has(#ze-main-content) {
    --wp--style--root--padding-left: 0px !important;
    --wp--style--root--padding-right: 0px !important;
}
.wp-site-blocks:has(#ze-main-content) {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

#ze-main-content {
    overflow-x: hidden;
    --ze-navy:       #1a2e5a;
    --ze-navy-light: #2a4a82;
    --ze-blue:       #0073aa;
    --ze-green:      #2e7d32;
    --ze-red:        #c62828;
    --ze-amber:      #f5a623;
    --ze-gray-50:    #f8f9fc;
    --ze-gray-100:   #f1f3f8;
    --ze-gray-200:   #dde2ed;
    --ze-gray-400:   #6b7280;
    --ze-gray-600:   #4a5578;
    --ze-gray-900:   #1a1f36;
    --ze-radius:     8px;
    --ze-shadow:     0 1px 4px rgba(0,0,0,.08),0 4px 16px rgba(0,0,0,.06);

    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    font-size: 15px !important;
    font-weight: 400 !important;
    line-height: 1.6 !important;
    letter-spacing: 0 !important;
    color: var(--ze-gray-900) !important;
    background: #f4f6fb !important;
}

#ze-main-content *, #ze-main-content *::before, #ze-main-content *::after {
    box-sizing: border-box !important;
    letter-spacing: 0 !important;
}

#ze-main-content a {
    color: var(--ze-blue) !important;
    text-decoration: none !important;
    text-underline-offset: unset !important;
    text-decoration-thickness: unset !important;
}
#ze-main-content a:hover { text-decoration: underline !important; }

#ze-main-content h1, #ze-main-content h2,
#ze-main-content h3, #ze-main-content h4 {
    font-weight: 700 !important;
    line-height: 1.2 !important;
    letter-spacing: 0 !important;
    margin: 0 !important;
    font-size: inherit !important;
}

#ze-main-content p { margin-top: 0 !important; margin-bottom: 0 !important; }
#ze-main-content .ze-prose p {
    font-size: 14px !important;
    line-height: 1.8 !important;
    color: var(--ze-gray-600) !important;
    margin-bottom: 14px !important;
}
#ze-main-content .ze-prose p:last-child { margin-bottom: 0 !important; }

/* ── Container ── */
#ze-main-content .ze-container {
    max-width: 1160px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    box-sizing: border-box !important;
    width: 100% !important;
}

/* ── Hero ── */
#ze-main-content .ze-hero {
    background: linear-gradient(135deg, var(--ze-navy) 0%, var(--ze-navy-light) 100%) !important;
    color: #fff !important;
    padding: 28px 0 32px !important;
    margin: 0 !important;
}
#ze-main-content .ze-hero-inner {
    display: flex !important;
    flex-direction: column !important;
    gap: 5px !important;
}
#ze-main-content .ze-hero-eyebrow {
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    color: rgba(255,255,255,.6) !important;
}
#ze-main-content .ze-hero-zip {
    font-size: 52px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    color: #fff !important;
    margin: 4px 0 !important;
}
#ze-main-content .ze-hero-title {
    font-size: 22px !important;
    font-weight: 600 !important;
    color: rgba(255,255,255,.95) !important;
}
#ze-main-content .ze-hero-h1 {
    font-size: 32px !important;
    font-weight: 800 !important;
    color: #fff !important;
    margin: 6px 0 4px !important;
}
#ze-main-content .ze-hero-subtitle {
    font-size: 14px !important;
    color: rgba(255,255,255,.65) !important;
}
#ze-main-content .ze-hero-badge {
    display: inline-block !important;
    margin-top: 8px !important;
    padding: 3px 10px !important;
    border-radius: 100px !important;
    background: rgba(255,255,255,.15) !important;
    font-size: 12px !important;
    color: rgba(255,255,255,.85) !important;
    font-weight: 500 !important;
}
#ze-main-content .ze-hero a {
    color: rgba(255,255,255,.72) !important;
    text-decoration: underline !important;
}

/* ── Breadcrumbs ── */
#ze-main-content .ze-breadcrumbs { margin-bottom: 10px !important; }
#ze-main-content .ze-breadcrumbs ol {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 4px !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 12px !important;
}
#ze-main-content .ze-bc-link { color: rgba(255,255,255,.7) !important; }
#ze-main-content .ze-bc-sep { color: rgba(255,255,255,.6) !important; }
#ze-main-content .ze-bc-current { color: rgba(255,255,255,.9) !important; }

/* ── Stat cards ── */
#ze-main-content .ze-stats-row {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(165px, 1fr)) !important;
    gap: 12px !important;
    margin: 24px 0 !important;
}
#ze-main-content .ze-stat-card {
    background: #fff !important;
    border: 1px solid var(--ze-gray-200) !important;
    border-radius: var(--ze-radius) !important;
    padding: 16px !important;
    box-shadow: var(--ze-shadow) !important;
}
#ze-main-content .ze-stat-icon { font-size: 20px !important; margin-bottom: 6px !important; display: block !important; }
#ze-main-content .ze-stat-value { font-size: 20px !important; font-weight: 700 !important; color: var(--ze-gray-900) !important; line-height: 1.2 !important; display: block !important; }
#ze-main-content .ze-stat-label { font-size: 12px !important; color: var(--ze-gray-600) !important; margin-top: 3px !important; display: block !important; }

/* ── Comparison badges ── */
#ze-main-content .ze-cmp { font-size: 11px !important; padding: 1px 6px !important; border-radius: 100px !important; font-weight: 600 !important; white-space: nowrap !important; display: inline-block !important; }
#ze-main-content .ze-cmp-good { background: #e8f5e9 !important; color: var(--ze-green) !important; }
#ze-main-content .ze-cmp-bad  { background: #ffebee !important; color: var(--ze-red) !important; }
#ze-main-content .ze-cmp-neutral { background: var(--ze-gray-100) !important; color: var(--ze-gray-600) !important; }

/* ── Layout ── */
#ze-main-content .ze-layout-2col {
    display: grid !important;
    grid-template-columns: 1fr 320px !important;
    gap: 28px !important;
    align-items: start !important;
}

/* ── Sections ── */
#ze-main-content .ze-section {
    background: #fff !important;
    border: 1px solid var(--ze-gray-200) !important;
    border-radius: var(--ze-radius) !important;
    padding: 20px 24px !important;
    margin-bottom: 20px !important;
    box-shadow: var(--ze-shadow) !important;
}
#ze-main-content .ze-section-heading {
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: .8px !important;
    text-transform: uppercase !important;
    color: var(--ze-gray-600) !important;
    border-bottom: 1px solid var(--ze-gray-200) !important;
    padding-bottom: 10px !important;
    margin-bottom: 16px !important;
}

/* ── Data table ── */
#ze-main-content .ze-data-table { width: 100% !important; border-collapse: collapse !important; font-size: 14px !important; }
#ze-main-content .ze-data-table th { text-align: left !important; font-weight: 500 !important; color: var(--ze-gray-600) !important; padding: 7px 10px 7px 0 !important; width: 50% !important; vertical-align: top !important; border-bottom: 1px solid var(--ze-gray-100) !important; }
#ze-main-content .ze-data-table td { padding: 7px 0 !important; color: var(--ze-gray-900) !important; vertical-align: top !important; border-bottom: 1px solid var(--ze-gray-100) !important; font-size: 14px !important; }
#ze-main-content .ze-data-table tr:last-child th,
#ze-main-content .ze-data-table tr:last-child td { border-bottom: none !important; }
#ze-main-content .ze-two-col-table { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 0 20px !important; }
#ze-main-content .ze-mono { font-family: monospace !important; font-size: 13px !important; }
#ze-main-content .ze-badge { display: inline-block !important; padding: 2px 8px !important; border-radius: 100px !important; font-size: 11px !important; font-weight: 600 !important; }
#ze-main-content .ze-badge-active { background: #e8f5e9 !important; color: var(--ze-green) !important; }

/* ── Demo grid & bars ── */
#ze-main-content .ze-demo-grid { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 24px !important; }
#ze-main-content .ze-demo-sub-heading { font-size: 12px !important; font-weight: 600 !important; text-transform: uppercase !important; letter-spacing: .6px !important; color: var(--ze-gray-600) !important; margin: 0 0 12px !important; }
#ze-main-content .ze-demo-bars { display: flex !important; flex-direction: column !important; gap: 8px !important; }
#ze-main-content .ze-bar-row { display: flex !important; align-items: center !important; gap: 8px !important; }
#ze-main-content .ze-bar-label { width: 80px !important; color: var(--ze-gray-600) !important; font-size: 12px !important; flex-shrink: 0 !important; }
#ze-main-content .ze-bar-track { flex: 1 !important; height: 8px !important; background: var(--ze-gray-100) !important; border-radius: 100px !important; overflow: hidden !important; }
#ze-main-content .ze-bar-fill { height: 100% !important; background: var(--ze-navy-light) !important; border-radius: 100px !important; min-width: 2px !important; }
#ze-main-content .ze-bar-val { width: 44px !important; text-align: right !important; font-size: 12px !important; font-weight: 600 !important; color: var(--ze-gray-900) !important; flex-shrink: 0 !important; }

/* ── Map ── */
#ze-main-content .ze-map-container { border-radius: var(--ze-radius) !important; overflow: hidden !important; border: 1px solid var(--ze-gray-200) !important; margin-bottom: 20px !important; box-shadow: var(--ze-shadow) !important; }

/* ── FAQ ── */
#ze-main-content .ze-faq { display: flex !important; flex-direction: column !important; gap: 6px !important; }
#ze-main-content .ze-faq-item { border: 1px solid var(--ze-gray-200) !important; border-radius: 6px !important; overflow: hidden !important; }
#ze-main-content .ze-faq-q {
    width: 100% !important; text-align: left !important;
    background: var(--ze-gray-50) !important; border: none !important;
    padding: 12px 16px !important; font-size: 14px !important;
    font-weight: 500 !important; cursor: pointer !important;
    display: flex !important; justify-content: space-between !important;
    align-items: center !important; color: var(--ze-gray-900) !important;
    font-family: inherit !important;
}
#ze-main-content .ze-faq-q:hover { background: var(--ze-gray-100) !important; }
#ze-main-content .ze-faq-icon { font-size: 18px !important; color: var(--ze-blue) !important; transition: transform .2s !important; flex-shrink: 0 !important; }
#ze-main-content .ze-faq-q[aria-expanded="true"] .ze-faq-icon { transform: rotate(45deg) !important; }
#ze-main-content .ze-faq-a { display: none !important; padding: 12px 16px !important; font-size: 14px !important; color: var(--ze-gray-600) !important; border-top: 1px solid var(--ze-gray-200) !important; }
#ze-main-content .ze-faq-a.open { display: block !important; }

/* ── ZIP chips ── */
#ze-main-content .ze-zip-grid { display: flex !important; flex-wrap: wrap !important; gap: 8px !important; }
#ze-main-content .ze-zip-chip {
    display: flex !important; flex-direction: column !important;
    padding: 8px 12px !important; background: var(--ze-gray-50) !important;
    border: 1px solid var(--ze-gray-200) !important; border-radius: 6px !important;
    text-decoration: none !important; min-width: 88px !important;
    transition: border-color .15s, box-shadow .15s !important;
}
#ze-main-content .ze-zip-chip:hover { border-color: var(--ze-blue) !important; box-shadow: 0 2px 8px rgba(0,115,170,.12) !important; text-decoration: none !important; }
#ze-main-content .ze-zip-num { font-size: 14px !important; font-weight: 700 !important; color: var(--ze-gray-900) !important; }
#ze-main-content .ze-zip-city { font-size: 11px !important; color: var(--ze-gray-600) !important; margin-top: 2px !important; }

/* ── Sidebar ── */
#ze-main-content .ze-sidebar { display: flex !important; flex-direction: column !important; gap: 16px !important; }
#ze-main-content .ze-inline-lookup {
    background: var(--ze-navy) !important; color: #fff !important;
    border-radius: var(--ze-radius) !important; padding: 20px !important;
}
#ze-main-content .ze-inline-lookup h3 { font-size: 15px !important; font-weight: 700 !important; color: #fff !important; margin: 0 0 4px !important; }
#ze-main-content .ze-inline-lookup p { font-size: 12px !important; color: rgba(255,255,255,.65) !important; margin: 0 0 12px !important; }
#ze-main-content .ze-lookup-row { display: flex !important; gap: 8px !important; }
#ze-main-content .ze-inline-zip {
    flex: 1 !important; padding: 9px 12px !important;
    border: 1px solid rgba(255,255,255,.2) !important;
    border-radius: 6px !important; background: rgba(255,255,255,.1) !important;
    color: #fff !important; font-size: 15px !important; min-width: 0 !important;
    font-family: inherit !important;
}
#ze-main-content .ze-inline-zip::placeholder { color: rgba(255,255,255,.65) !important; }
#ze-main-content .ze-btn { padding: 9px 16px !important; border: none !important; border-radius: 6px !important; cursor: pointer !important; font-size: 14px !important; font-weight: 600 !important; font-family: inherit !important; }
#ze-main-content .ze-inline-lookup-btn { background: var(--ze-amber) !important; color: #fff !important; }
#ze-main-content .ze-inline-lookup-btn:hover { background: #e09418 !important; }

/* ── Index list ── */
#ze-main-content .ze-index-list { list-style: none !important; margin: 0 !important; padding: 0 !important; }
#ze-main-content .ze-index-list li a {
    display: flex !important; justify-content: space-between !important;
    align-items: center !important; padding: 8px 0 !important;
    font-size: 14px !important; border-bottom: 1px solid var(--ze-gray-100) !important;
    color: var(--ze-gray-900) !important; text-decoration: none !important;
}
#ze-main-content .ze-index-list li:last-child a { border-bottom: none !important; }
#ze-main-content .ze-index-list li a:hover { color: var(--ze-blue) !important; }
#ze-main-content .ze-index-list li a span { color: var(--ze-gray-400) !important; }

/* ── State grid ── */
#ze-main-content .ze-state-grid { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)) !important; gap: 10px !important; }
#ze-main-content .ze-state-card {
    display: flex !important; flex-direction: column !important; align-items: center !important;
    padding: 14px 10px !important; background: #fff !important;
    border: 1px solid var(--ze-gray-200) !important; border-radius: var(--ze-radius) !important;
    text-decoration: none !important; text-align: center !important;
}
#ze-main-content .ze-state-card:hover { border-color: var(--ze-blue) !important; box-shadow: 0 2px 8px rgba(0,115,170,.12) !important; text-decoration: none !important; }
#ze-main-content .ze-state-abbr { font-size: 18px !important; font-weight: 800 !important; color: var(--ze-gray-900) !important; }
#ze-main-content .ze-state-count { font-size: 11px !important; color: var(--ze-gray-600) !important; margin-top: 3px !important; }

/* ── City/county table ── */
#ze-main-content .ze-city-table { width: 100% !important; border-collapse: collapse !important; font-size: 14px !important; }
#ze-main-content .ze-city-table th { text-align: left !important; padding: 8px 12px !important; background: var(--ze-gray-50) !important; border-bottom: 2px solid var(--ze-gray-200) !important; font-size: 12px !important; font-weight: 600 !important; text-transform: uppercase !important; letter-spacing: .5px !important; color: var(--ze-gray-600) !important; }
#ze-main-content .ze-city-table td { padding: 9px 12px !important; border-bottom: 1px solid var(--ze-gray-100) !important; color: var(--ze-gray-900) !important; vertical-align: middle !important; }
#ze-main-content .ze-city-table tr:hover td { background: var(--ze-gray-50) !important; }
#ze-main-content .ze-city-table a { color: var(--ze-blue) !important; font-weight: 600 !important; text-decoration: none !important; }

/* ── Buttons ── */
#ze-main-content .ze-search-btn {
    padding: 10px 24px !important; background: var(--ze-navy) !important;
    color: #fff !important; border: none !important; border-radius: 6px !important;
    font-size: 15px !important; font-weight: 600 !important; cursor: pointer !important;
    font-family: inherit !important;
}
#ze-main-content .ze-search-btn:hover { background: var(--ze-navy-light) !important; }

/* ── Radius form ── */
#ze-main-content .ze-radius-form { display: flex !important; flex-wrap: wrap !important; gap: 10px !important; align-items: flex-end !important; }
#ze-main-content .ze-radius-form label { display: flex !important; flex-direction: column !important; gap: 4px !important; font-size: 13px !important; font-weight: 600 !important; color: var(--ze-gray-600) !important; }
#ze-main-content .ze-radius-form input[type=text],
#ze-main-content .ze-radius-form input[type=number] {
    padding: 9px 12px !important; border: 1px solid var(--ze-gray-200) !important;
    border-radius: 6px !important; font-size: 15px !important; width: 120px !important;
    font-family: inherit !important; color: var(--ze-gray-900) !important;
    background: #fff !important;
}

/* ── Hub search ── */
#ze-main-content .ze-hub-search { display: flex !important; gap: 8px !important; max-width: 400px !important; margin: 20px 0 32px !important; }
#ze-main-content .ze-hub-search input {
    flex: 1 !important; padding: 11px 16px !important;
    border: 1px solid var(--ze-gray-200) !important;
    border-radius: 6px !important; font-size: 16px !important;
    font-family: inherit !important; color: var(--ze-gray-900) !important;
    background: #fff !important;
}
#ze-main-content .ze-hub-search button {
    padding: 11px 24px !important; background: var(--ze-navy) !important;
    color: #fff !important; border: none !important; border-radius: 6px !important;
    font-size: 15px !important; font-weight: 600 !important; cursor: pointer !important;
    font-family: inherit !important;
}

/* ── What's my zip ── */
#ze-main-content .ze-wmz-wrap { text-align: center !important; padding: 40px 20px !important; }
#ze-main-content .ze-wmz-icon { font-size: 48px !important; margin-bottom: 16px !important; display: block !important; }
#ze-main-content .ze-wmz-zip { font-size: 64px !important; font-weight: 800 !important; color: var(--ze-navy) !important; line-height: 1 !important; }
#ze-main-content .ze-wmz-city { font-size: 20px !important; color: var(--ze-gray-600) !important; margin-top: 8px !important; }

/* ── Error / loading ── */
#ze-main-content .ze-loading { text-align: center !important; padding: 40px !important; color: var(--ze-gray-600) !important; font-size: 14px !important; }
#ze-main-content .ze-error { background: #ffebee !important; color: var(--ze-red) !important; padding: 12px 16px !important; border-radius: 6px !important; font-size: 14px !important; }

/* ── Responsive ── */
@media (max-width: 860px) {
    #ze-main-content .ze-layout-2col { grid-template-columns: 1fr !important; }
    #ze-main-content .ze-sidebar { min-width: 0 !important; width: 100% !important; box-sizing: border-box !important; }
}
@media (max-width: 640px) {
    #ze-main-content .ze-hero-zip { font-size: 40px !important; }
    #ze-main-content .ze-stats-row { grid-template-columns: repeat(2,1fr) !important; }
    #ze-main-content .ze-demo-grid { grid-template-columns: 1fr !important; }
    #ze-main-content .ze-two-col-table { grid-template-columns: 1fr !important; }
    #ze-main-content .ze-data-table td { word-break: break-word !important; }
}

/* ══════════════════════════════════════════════════════════
   ZipEngine Site Nav
   ══════════════════════════════════════════════════════════ */

#ze-topnav {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: #1a2e5a;
    box-shadow: 0 1px 0 rgba(255,255,255,.06), 0 2px 12px rgba(0,0,0,.25);
}

.ze-topnav-inner {
    max-width: 1160px;
    margin: 0 auto;
    padding: 0 20px;
    height: 52px;
    display: flex;
    align-items: center;
    gap: 20px;
}

/* Logo */
.ze-topnav-logo {
    display: flex;
    align-items: center;
    gap: 8px;
    text-decoration: none !important;
    flex-shrink: 0;
}
.ze-logo-mark {
    width: 28px;
    height: 28px;
    background: #f5a623;
    color: #1a2e5a;
    font-size: 15px;
    font-weight: 900;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    letter-spacing: -0.5px;
}
.ze-logo-text {
    font-size: 16px;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.3px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* Search */
.ze-topnav-search {
    flex: 1;
    max-width: 320px;
    position: relative;
    z-index: 1001;
}
.ze-nav-searchform {
    display: flex;
    align-items: center;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 6px;
    overflow: visible;
    transition: border-color .15s, background .15s;
}
.ze-nav-searchform:focus-within {
    background: rgba(255,255,255,.15);
    border-color: rgba(255,255,255,.35);
}
.ze-nav-zipinput {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    padding: 0 12px;
    height: 34px;
    font-size: 13px;
    color: #fff;
    font-family: inherit;
    min-width: 0;
}
.ze-nav-zipinput::placeholder { color: rgba(255,255,255,.7); }
.ze-nav-searchbtn {
    width: 36px;
    height: 34px;
    background: transparent;
    border: none;
    border-left: 1px solid rgba(255,255,255,.12);
    color: rgba(255,255,255,.7);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: color .15s, background .15s;
}
.ze-nav-searchbtn:hover { color: #fff; background: rgba(255,255,255,.08); }

/* Nav links */
.ze-topnav-links {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}
.ze-topnav-links a {
    color: rgba(255,255,255,.75) !important;
    text-decoration: none !important;
    font-size: 13px;
    font-weight: 500;
    padding: 6px 10px;
    border-radius: 5px;
    transition: color .15s, background .15s;
    white-space: nowrap;
}
.ze-topnav-links a:hover {
    color: #fff !important;
    background: rgba(255,255,255,.1);
}

/* Hamburger */
.ze-nav-hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 36px;
    height: 36px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 6px;
    border-radius: 5px;
    flex-shrink: 0;
    margin-left: auto;
}
.ze-nav-hamburger span {
    display: block;
    height: 2px;
    background: rgba(255,255,255,.8);
    border-radius: 2px;
    transition: .2s;
}
.ze-nav-hamburger:hover { background: rgba(255,255,255,.1); }

/* Mobile menu */
.ze-nav-mobile {
    background: #152348;
    border-top: 1px solid rgba(255,255,255,.08);
}
.ze-nav-mobile a {
    display: block;
    padding: 13px 20px;
    color: rgba(255,255,255,.8) !important;
    text-decoration: none !important;
    font-size: 14px;
    font-weight: 500;
    border-bottom: 1px solid rgba(255,255,255,.05);
    transition: background .15s, color .15s;
}
.ze-nav-mobile a:hover { background: rgba(255,255,255,.06); color: #fff !important; }

@media (max-width: 680px) {
    .ze-topnav-links { display: none; }
    .ze-nav-hamburger { display: flex; }
    .ze-topnav-search { max-width: none; }
}

/* ══════════════════════════════════════════════════════════
   ZipEngine Site Footer
   ══════════════════════════════════════════════════════════ */

#ze-sitefooter {
    background: #1a2e5a;
    color: rgba(255,255,255,.7);
    margin-top: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    overflow: hidden;
}

.ze-footer-inner {
    max-width: 1160px;
    margin: 0 auto;
    padding: 20px 20px 0;
    display: flex;
    align-items: flex-start;
    gap: 24px;
    flex-wrap: wrap;
    box-sizing: border-box;
    width: 100%;
}

.ze-footer-logo {
    display: flex;
    align-items: center;
    gap: 8px;
}
.ze-footer-logo .ze-logo-text {
    font-size: 15px;
    font-weight: 700;
    color: #fff;
}

.ze-footer-tagline {
    font-size: 12px;
    line-height: 1.4;
    color: rgba(255,255,255,.7);
    margin: 0;
}

.ze-footer-attr { display: none; }

.ze-footer-heading {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: rgba(255,255,255,.65);
    margin-bottom: 6px;
}

.ze-footer-col {
    min-width: 0;
    flex: 1 1 140px;
}

.ze-footer-col:first-child {
    flex: 1 1 200px;
}

.ze-footer-col ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 4px 12px;
}
.ze-footer-col ul li { margin-bottom: 0; }
.ze-footer-col ul li a {
    color: rgba(255,255,255,.6) !important;
    text-decoration: none !important;
    font-size: 12px;
    transition: color .15s;
    white-space: normal;
    word-break: break-word;
}
.ze-footer-col ul li a:hover { color: #fff !important; }

.ze-footer-bottom {
    max-width: 1160px;
    margin: 16px auto 0;
    padding: 12px 20px;
    border-top: 1px solid rgba(255,255,255,.08);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    color: rgba(255,255,255,.55);
    flex-wrap: wrap;
    box-sizing: border-box;
    width: 100%;
}

@media (max-width: 600px) {
    .ze-footer-inner {
        padding: 16px 16px 0;
        gap: 16px;
    }
    .ze-footer-col { flex: 1 1 100%; }
    .ze-footer-bottom {
        padding: 10px 16px;
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }
}

/* Push footer to bottom — ensure #ze-main-content fills space */
html, body { min-height: 100vh; }
body { display: flex; flex-direction: column; }
#page { flex: 1; display: flex; flex-direction: column; }
#ze-main-content { flex: 1; }

/* ══════════════════════════════════════════════════════════
   Homepage
   ══════════════════════════════════════════════════════════ */

.ze-home-hero {
    background: linear-gradient(135deg, #0f1f40 0%, #1a2e5a 50%, #1e3a6e 100%);
    color: #fff;
    padding: 72px 0 64px;
    position: relative;
    overflow: visible;
}
.ze-home-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 70% 50%, rgba(245,166,35,.08) 0%, transparent 60%);
    pointer-events: none;
}

.ze-home-hero-inner {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 60px;
    align-items: center;
    position: relative;
}

.ze-home-eyebrow {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: #f5a623;
    margin-bottom: 16px;
}
.ze-home-h1 {
    font-size: clamp(28px, 4vw, 44px) !important;
    font-weight: 800 !important;
    line-height: 1.1 !important;
    color: #fff !important;
    margin: 0 0 16px !important;
}
.ze-home-subtitle {
    font-size: 16px;
    color: rgba(255,255,255,.7);
    line-height: 1.6;
    margin: 0 0 28px;
    max-width: 520px;
}

.ze-home-searchbox {
    display: flex;
    align-items: center;
    background: #fff;
    border-radius: 10px;
    overflow: visible;
    max-width: 480px;
    box-shadow: 0 4px 24px rgba(0,0,0,.25);
    position: relative;
}
.ze-home-search-icon {
    color: var(--ze-gray-400);
    margin-left: 16px;
    flex-shrink: 0;
}
.ze-home-zipinput {
    flex: 1;
    border: none;
    outline: none;
    padding: 0 16px;
    height: 52px;
    font-size: 16px;
    color: var(--ze-gray-900);
    font-family: inherit;
}
.ze-home-zipinput::placeholder { color: var(--ze-gray-400); }
.ze-home-searchbtn {
    height: 52px;
    padding: 0 24px;
    background: var(--ze-navy);
    color: #fff;
    border: none;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: background .15s;
    font-family: inherit;
}
.ze-home-searchbtn:hover { background: var(--ze-navy-light); }

.ze-home-hero-stats {
    display: flex;
    gap: 28px;
    margin-top: 28px;
    flex-wrap: wrap;
}
.ze-home-hero-stat strong {
    display: block;
    font-size: 22px;
    font-weight: 800;
    color: #fff;
    line-height: 1;
}
.ze-home-hero-stat span {
    font-size: 12px;
    color: rgba(255,255,255,.5);
    margin-top: 3px;
    display: block;
}

/* Sample card */
.ze-home-sample-card {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 14px;
    padding: 24px;
    backdrop-filter: blur(8px);
}
.ze-home-sample-zip {
    font-size: 40px;
    font-weight: 800;
    color: #f5a623;
    line-height: 1;
    margin-bottom: 4px;
}
.ze-home-sample-city {
    font-size: 14px;
    color: rgba(255,255,255,.6);
    margin-bottom: 20px;
}
.ze-home-sample-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.ze-home-sample-stats > div span {
    display: block;
    font-size: 11px;
    color: rgba(255,255,255,.7);
    margin-bottom: 3px;
}
.ze-home-sample-stats > div strong {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
}

/* Features strip */
.ze-home-features {
    background: #fff;
    border-bottom: 1px solid var(--ze-gray-200);
    padding: 24px 0;
}
.ze-home-features-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
.ze-home-feature {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}
.ze-home-feature-icon { font-size: 20px; flex-shrink: 0; }
.ze-home-feature-text strong {
    display: block;
    font-size: 13px;
    font-weight: 700;
    color: var(--ze-gray-900);
    margin-bottom: 2px;
}
.ze-home-feature-text span {
    font-size: 12px;
    color: var(--ze-gray-600);
    line-height: 1.5;
}

/* State grid */
.ze-home-section-h2 {
    font-size: 22px !important;
    font-weight: 800 !important;
    color: var(--ze-gray-900) !important;
    margin: 0 0 6px !important;
}
.ze-home-section-sub {
    font-size: 14px;
    color: var(--ze-gray-600);
    margin: 0 0 24px;
}
.ze-state-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 10px;
}
.ze-state-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 14px 10px 12px;
    background: #fff;
    border: 1px solid var(--ze-gray-200);
    border-radius: 8px;
    text-decoration: none !important;
    transition: border-color .15s, box-shadow .15s, transform .1s;
    text-align: center;
    gap: 2px;
}
.ze-state-card:hover {
    border-color: var(--ze-navy-light);
    box-shadow: 0 2px 12px rgba(26,46,90,.1);
    transform: translateY(-1px);
}
.ze-state-abbr {
    font-size: 18px;
    font-weight: 800;
    color: var(--ze-navy);
    line-height: 1;
}
.ze-state-name {
    font-size: 11px;
    color: var(--ze-gray-600);
    line-height: 1.3;
}
.ze-state-pop {
    font-size: 10px;
    color: var(--ze-gray-400);
}
.ze-state-card-all .ze-state-abbr { font-size: 22px; color: var(--ze-amber); }
.ze-state-card-all { border-style: dashed; }

/* Bottom section */
.ze-home-bottom-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 48px;
    align-items: start;
}
.ze-home-cta-box {
    background: var(--ze-navy);
    color: #fff;
    border-radius: 12px;
    padding: 28px;
    text-align: center;
}
.ze-home-cta-icon { font-size: 32px; margin-bottom: 12px; }
.ze-home-cta-box h3 {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #fff !important;
    margin: 0 0 8px !important;
}
.ze-home-cta-box p {
    font-size: 13px;
    color: rgba(255,255,255,.7);
    line-height: 1.6;
    margin: 0 0 20px !important;
}
.ze-home-cta-btn {
    display: inline-block;
    background: #f5a623;
    color: #1a2e5a !important;
    font-weight: 700;
    font-size: 14px;
    padding: 10px 24px;
    border-radius: 6px;
    text-decoration: none !important;
    transition: background .15s;
}
.ze-home-cta-btn:hover { background: #e09615 !important; }

/* Responsive */
@media (max-width: 900px) {
    .ze-home-hero-inner { grid-template-columns: 1fr; }
    .ze-home-hero-visual { display: none; }
    .ze-home-features-grid { grid-template-columns: repeat(2, 1fr); }
    .ze-home-bottom-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
    .ze-home-hero { padding: 48px 0 40px; }
    .ze-home-features-grid { grid-template-columns: 1fr; }
    .ze-state-grid { grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); }
}

/* ── Compare page ──────────────────────────────────────────────────────────── */
#ze-main-content .ze-cmp-zip-header {
    background: #fff !important;
    border: 1px solid var(--ze-gray-200) !important;
    border-bottom: none !important;
    border-top: 3px solid var(--ze-navy-light) !important;
    padding: 16px !important;
    text-align: center !important;
}
#ze-main-content .ze-cmp-zip-num {
    font-size: 22px !important;
    font-weight: 800 !important;
    color: var(--ze-gray-900) !important;
    text-decoration: none !important;
    display: block !important;
    letter-spacing: 1px !important;
}
#ze-main-content .ze-cmp-zip-num:hover { color: var(--ze-blue) !important; }
#ze-main-content .ze-cmp-zip-city {
    font-size: 13px !important;
    color: var(--ze-gray-600) !important;
    margin-top: 4px !important;
}
#ze-main-content .ze-cmp-table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 14px !important;
}
#ze-main-content .ze-cmp-th-label,
#ze-main-content .ze-cmp-th-zip {
    padding: 12px 14px !important;
    background: var(--ze-gray-50) !important;
    border-bottom: 2px solid var(--ze-gray-200) !important;
    text-align: center !important;
    font-weight: 700 !important;
    color: var(--ze-gray-900) !important;
    font-size: 13px !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 2 !important;
}
#ze-main-content .ze-cmp-th-label { text-align: left !important; width: 180px !important; }
#ze-main-content .ze-cmp-group-row td {
    background: var(--ze-gray-100) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .7px !important;
    color: var(--ze-gray-600) !important;
    padding: 8px 14px !important;
    border-top: 1px solid var(--ze-gray-200) !important;
}
#ze-main-content .ze-cmp-data-row td {
    padding: 10px 14px !important;
    border-bottom: 1px solid var(--ze-gray-100) !important;
    vertical-align: middle !important;
    text-align: center !important;
}
#ze-main-content .ze-cmp-data-row:last-child td { border-bottom: none !important; }
#ze-main-content .ze-cmp-data-row:hover td { background: var(--ze-gray-50) !important; }
#ze-main-content .ze-cmp-row-label {
    text-align: left !important;
    color: var(--ze-gray-600) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    width: 180px !important;
    white-space: nowrap !important;
}
#ze-main-content .ze-cmp-cell {
    color: var(--ze-gray-900) !important;
    font-variant-numeric: tabular-nums !important;
}
#ze-main-content .ze-cmp-cell-best {
    background: #f0fdf4 !important;
    font-weight: 700 !important;
    color: var(--ze-green) !important;
}
#ze-main-content .ze-cmp-null { color: var(--ze-gray-400) !important; }
#ze-main-content .ze-best-badge {
    display: inline-block !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .4px !important;
    background: var(--ze-green) !important;
    color: #fff !important;
    border-radius: 3px !important;
    padding: 1px 4px !important;
    margin-left: 5px !important;
    vertical-align: middle !important;
}
@media (max-width: 700px) {
    #ze-main-content .ze-cmp-table { font-size: 12px !important; }
    #ze-main-content .ze-cmp-row-label,
    #ze-main-content .ze-cmp-th-label { width: 110px !important; white-space: normal !important; }
    #ze-main-content .ze-cmp-data-row td,
    #ze-main-content .ze-cmp-th-zip { padding: 8px 8px !important; }
}

/* ── Search autocomplete dropdown ─────────────────────────────────────────── */
#ze-main-content .ze-ac-dropdown,
.ze-ac-dropdown {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 9999 !important;
    background: #fff !important;
    border: 1px solid var(--ze-gray-200, #e5e7eb) !important;
    border-top: none !important;
    border-radius: 0 0 10px 10px !important;
    box-shadow: 0 8px 24px rgba(0,0,0,.10) !important;
    overflow: hidden !important;
    max-height: 360px !important;
    overflow-y: auto !important;
}
.ze-ac-item {
    display: flex !important;
    align-items: baseline !important;
    gap: 8px !important;
    padding: 10px 14px !important;
    text-decoration: none !important;
    color: var(--ze-gray-900, #111827) !important;
    border-bottom: 1px solid var(--ze-gray-100, #f3f4f6) !important;
    cursor: pointer !important;
    transition: background .1s !important;
    font-size: 14px !important;
}
.ze-ac-item:last-child { border-bottom: none !important; }
.ze-ac-item:hover,
.ze-ac-item.ze-ac-hover {
    background: var(--ze-blue-50, #eff6ff) !important;
}
.ze-ac-zip {
    font-weight: 700 !important;
    font-size: 14px !important;
    color: var(--ze-navy, #1a2e5a) !important;
    min-width: 48px !important;
    font-variant-numeric: tabular-nums !important;
}
.ze-ac-city {
    flex: 1 !important;
    font-size: 14px !important;
    color: var(--ze-gray-700, #374151) !important;
}
.ze-ac-county {
    font-size: 12px !important;
    color: var(--ze-gray-400, #9ca3af) !important;
    white-space: nowrap !important;
}
.ze-ac-item mark {
    background: #fef08a !important;
    color: inherit !important;
    border-radius: 2px !important;
    padding: 0 1px !important;
}
.ze-search-wrap { position: relative !important; }

/* ══════════════════════════════════════════════════════════
   Homepage v2 — new sections
   ══════════════════════════════════════════════════════════ */

/* Hero card shell */
.ze-home-card-shell {
    position: relative;
}
.ze-home-card-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(255,255,255,.35);
    margin-bottom: 10px;
    text-align: center;
}
.ze-home-sample-divider {
    height: 1px;
    background: rgba(255,255,255,.1);
    margin: 16px 0;
}
#ze-main-content .ze-hp-link {
    font-size: 12px !important;
    font-weight: 700 !important;
    color: #f5a623 !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    background: rgba(245,166,35,.15) !important;
    padding: 3px 10px !important;
    border-radius: 4px !important;
    border: 1px solid rgba(245,166,35,.4) !important;
}
#ze-main-content .ze-hp-link:hover {
    background: rgba(245,166,35,.25) !important;
    text-decoration: none !important;
}
#ze-main-content .ze-home-card-cta {
    display: block !important;
    margin-top: 18px !important;
    text-align: center !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #f5a623 !important;
    text-decoration: none !important;
    letter-spacing: .3px !important;
    padding: 8px !important;
    border: 1px solid rgba(245,166,35,.3) !important;
    border-radius: 6px !important;
    transition: background .15s !important;
}
#ze-main-content .ze-home-card-cta:hover {
    background: rgba(245,166,35,.12) !important;
    text-decoration: none !important;
}

/* Live preview panel */
.ze-home-preview {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 10px;
    padding: 14px 16px;
    margin-top: 12px;
    max-width: 480px;
    animation: ze-fadein .2s ease;
}
@keyframes ze-fadein { from { opacity:0; transform:translateY(-4px); } to { opacity:1; transform:none; } }
.ze-hp-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
    gap: 10px;
}
.ze-hp-loc {
    font-size: 13px;
    color: rgba(255,255,255,.8);
}
.ze-hp-link:hover { text-decoration: none !important; }
.ze-hp-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
}
.ze-hp-stats > div span {
    display: block;
    font-size: 10px;
    color: rgba(255,255,255,.7);
    margin-bottom: 2px;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.ze-hp-stats > div strong {
    font-size: 13px;
    font-weight: 700;
    color: #fff;
}

/* Use cases */
.ze-home-usecases {
    background: #fff;
    border-bottom: 1px solid var(--ze-gray-200);
    padding: 48px 0;
}
.ze-home-usecases-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
.ze-home-usecase {
    padding: 24px;
    border: 1px solid var(--ze-gray-200);
    border-radius: 12px;
    transition: box-shadow .15s, border-color .15s;
}
.ze-home-usecase:hover {
    border-color: var(--ze-navy-light);
    box-shadow: 0 4px 20px rgba(26,46,90,.08);
}
.ze-home-usecase-icon { font-size: 28px; margin-bottom: 12px; }
.ze-home-usecase h3 {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--ze-gray-900) !important;
    margin: 0 0 8px !important;
}
.ze-home-usecase p {
    font-size: 14px;
    color: var(--ze-gray-600);
    line-height: 1.6;
    margin: 0 0 16px !important;
}
.ze-home-usecase a {
    font-size: 13px;
    font-weight: 600;
    color: var(--ze-blue) !important;
}

/* What you get */
.ze-home-whatyouget {
    background: var(--ze-gray-50);
    border-bottom: 1px solid var(--ze-gray-200);
    padding: 56px 0;
}
.ze-home-wg-header {
    text-align: center;
    margin-bottom: 36px;
}
.ze-home-wg-header h2 {
    font-size: 26px !important;
    font-weight: 800 !important;
    color: var(--ze-gray-900) !important;
    margin: 0 0 8px !important;
}
.ze-home-wg-header p {
    font-size: 15px;
    color: var(--ze-gray-600);
    max-width: 540px;
    margin: 0 auto !important;
}
.ze-home-wg-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.ze-home-wg-card {
    background: #fff;
    border: 1px solid var(--ze-gray-200);
    border-radius: 12px;
    padding: 22px 20px;
}
.ze-home-wg-icon { font-size: 24px; margin-bottom: 10px; }
.ze-home-wg-card h4 {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--ze-gray-900) !important;
    margin: 0 0 10px !important;
}
.ze-home-wg-card ul {
    margin: 0 !important;
    padding: 0 0 0 16px !important;
    list-style: disc !important;
}
.ze-home-wg-card ul li {
    font-size: 13px;
    color: var(--ze-gray-600);
    line-height: 1.7;
    padding: 0 !important;
    margin: 0 !important;
}
.ze-home-outline-btn {
    display: inline-block;
    padding: 11px 28px;
    border: 2px solid var(--ze-navy);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--ze-navy) !important;
    text-decoration: none !important;
    transition: background .15s, color .15s;
}
.ze-home-outline-btn:hover {
    background: var(--ze-navy);
    color: #fff !important;
    text-decoration: none !important;
}

/* Tools */
.ze-home-tools {
    background: #fff;
    border-bottom: 1px solid var(--ze-gray-200);
    padding: 48px 0;
}
.ze-home-tools-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
    margin-top: 20px;
}
.ze-home-tool-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 18px 20px;
    background: var(--ze-gray-50);
    border: 1px solid var(--ze-gray-200);
    border-radius: 10px;
    text-decoration: none !important;
    transition: border-color .15s, box-shadow .15s, background .15s;
}
.ze-home-tool-card:hover {
    border-color: var(--ze-navy-light);
    background: #fff;
    box-shadow: 0 2px 12px rgba(26,46,90,.08);
    text-decoration: none !important;
}
.ze-home-tool-icon { font-size: 24px; flex-shrink: 0; }
.ze-home-tool-text { flex: 1; }
.ze-home-tool-text strong {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: var(--ze-gray-900);
    margin-bottom: 2px;
}
.ze-home-tool-text span {
    font-size: 12px;
    color: var(--ze-gray-600);
    line-height: 1.4;
}
.ze-home-tool-arrow {
    font-size: 18px;
    color: var(--ze-gray-400);
    flex-shrink: 0;
    transition: color .15s, transform .15s;
}
.ze-home-tool-card:hover .ze-home-tool-arrow {
    color: var(--ze-navy);
    transform: translateX(3px);
}

/* Browse by state */
.ze-home-states {
    background: var(--ze-gray-50);
    border-bottom: 1px solid var(--ze-gray-200);
    padding: 48px 0;
}

/* Popular ZIPs */
.ze-home-trending {
    background: #fff;
    border-bottom: 1px solid var(--ze-gray-200);
    padding: 48px 0;
}
.ze-home-trending-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 12px;
    margin-top: 20px;
}
.ze-home-trending-card {
    display: block;
    padding: 16px;
    background: var(--ze-gray-50);
    border: 1px solid var(--ze-gray-200);
    border-radius: 10px;
    text-decoration: none !important;
    transition: border-color .15s, box-shadow .15s, transform .1s;
}
.ze-home-trending-card:hover {
    border-color: var(--ze-navy-light);
    box-shadow: 0 2px 12px rgba(26,46,90,.08);
    transform: translateY(-2px);
    text-decoration: none !important;
}
.ze-home-trending-zip {
    font-size: 20px;
    font-weight: 800;
    color: var(--ze-navy);
    line-height: 1;
    margin-bottom: 4px;
    font-variant-numeric: tabular-nums;
}
.ze-home-trending-city {
    font-size: 12px;
    color: var(--ze-gray-600);
    margin-bottom: 10px;
    line-height: 1.3;
}
.ze-home-trending-meta {
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.ze-home-trending-meta span {
    font-size: 11px;
    color: var(--ze-gray-600);
}

/* Data source footer band */
.ze-home-datasource {
    background: var(--ze-gray-100);
    border-top: 1px solid var(--ze-gray-200);
    padding: 20px 0;
}
.ze-home-ds-inner {
    display: flex;
    align-items: center;
    gap: 14px;
}
.ze-home-ds-badge { font-size: 22px; flex-shrink: 0; }
.ze-home-ds-inner strong {
    display: block;
    font-size: 13px;
    font-weight: 700;
    color: var(--ze-gray-900);
    margin-bottom: 2px;
}
.ze-home-ds-inner span {
    font-size: 12px;
    color: var(--ze-gray-600);
}

/* Responsive */
@media (max-width: 900px) {
    .ze-home-usecases-grid  { grid-template-columns: 1fr; gap: 16px; }
    .ze-home-wg-grid        { grid-template-columns: repeat(2, 1fr); }
    .ze-home-tools-grid     { grid-template-columns: 1fr; }
    .ze-hp-stats            { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .ze-home-wg-grid        { grid-template-columns: 1fr; }
    .ze-home-trending-grid  { grid-template-columns: repeat(2, 1fr); }
    .ze-home-usecases       { padding: 32px 0; }
    .ze-home-whatyouget     { padding: 36px 0; }
    .ze-home-tools          { padding: 32px 0; }
}

/* ── Autocomplete v2 — city groups & drill-in ─────────────────────────────── */
.ze-ac-back {
    padding: 8px 14px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--ze-blue, #0073aa) !important;
    cursor: pointer !important;
    border-bottom: 1px solid var(--ze-gray-100, #f3f4f6) !important;
    background: var(--ze-gray-50, #f8f9fc) !important;
}
.ze-ac-back:hover { background: var(--ze-gray-100, #f1f3f8) !important; }
.ze-ac-city-row {
    cursor: pointer !important;
    justify-content: space-between !important;
}
.ze-ac-city-name {
    font-size: 14px !important;
    color: var(--ze-gray-900, #1a1f36) !important;
    flex: 1 !important;
}
.ze-ac-zip-count {
    font-size: 12px !important;
    color: var(--ze-gray-400, #9ca3af) !important;
    white-space: nowrap !important;
    margin-left: 8px !important;
}
.ze-ac-city-row:hover .ze-ac-zip-count,
.ze-ac-city-row.ze-ac-hover .ze-ac-zip-count { color: var(--ze-blue, #0073aa) !important; }

/* ── No-data notice ────────────────────────────────────────────────────────── */
#ze-main-content .ze-no-data-notice {
    display: flex !important;
    align-items: flex-start !important;
    gap: 16px !important;
    background: var(--ze-gray-50) !important;
    border: 1px solid var(--ze-gray-200) !important;
    border-radius: 10px !important;
    padding: 20px !important;
}
#ze-main-content .ze-no-data-icon { font-size: 28px !important; flex-shrink: 0 !important; }
#ze-main-content .ze-no-data-notice strong {
    display: block !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--ze-gray-900) !important;
    margin-bottom: 6px !important;
}
#ze-main-content .ze-no-data-notice p {
    font-size: 13px !important;
    color: var(--ze-gray-600) !important;
    line-height: 1.6 !important;
    margin: 0 !important;
}

/* ── Rankings page ─────────────────────────────────────────────────────────── */
#ze-main-content .ze-rank-table {
    width: 100% !important;
    min-width: 0 !important;
    border-collapse: collapse !important;
    font-size: 14px !important;
}
#ze-main-content .ze-rank-table thead th {
    background: var(--ze-gray-50) !important;
    border-bottom: 2px solid var(--ze-gray-200) !important;
    padding: 10px 14px !important;
    text-align: left !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    color: var(--ze-gray-600) !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
    white-space: nowrap !important;
}
#ze-main-content .ze-rank-th-num  { width: 52px !important; text-align: center !important; }
#ze-main-content .ze-rank-th-zip  { width: 80px !important; }
#ze-main-content .ze-rank-th-state{ width: 60px !important; }
#ze-main-content .ze-rank-th-pop  { width: 100px !important; text-align: right !important; }
#ze-main-content .ze-rank-th-val  { text-align: right !important; }
#ze-main-content .ze-rank-row td {
    padding: 10px 14px !important;
    border-bottom: 1px solid var(--ze-gray-100) !important;
    vertical-align: middle !important;
}
#ze-main-content .ze-rank-row:last-child td { border-bottom: none !important; }
#ze-main-content .ze-rank-row:hover td { background: var(--ze-gray-50) !important; }
#ze-main-content .ze-rank-top3 td { background: #fffbeb !important; }
#ze-main-content .ze-rank-top3:hover td { background: #fef3c7 !important; }
#ze-main-content .ze-rank-num  { text-align: center !important; font-size: 13px !important; }
#ze-main-content .ze-rank-medal { font-size: 18px !important; }
#ze-main-content .ze-rank-zip a {
    font-weight: 700 !important;
    color: var(--ze-navy) !important;
    font-size: 14px !important;
    font-variant-numeric: tabular-nums !important;
}
#ze-main-content .ze-rank-zip a:hover { color: var(--ze-blue) !important; }
#ze-main-content .ze-rank-city { color: var(--ze-gray-700) !important; }
#ze-main-content .ze-rank-val  {
    font-weight: 700 !important;
    color: var(--ze-gray-900) !important;
    text-align: right !important;
    font-variant-numeric: tabular-nums !important;
}
#ze-main-content .ze-rank-pop  { text-align: right !important; font-size: 13px !important; }
.ze-rank-val-label-short { display: none !important; }
@media (max-width: 600px) {
    .ze-rank-val-label-full  { display: none !important; }
    .ze-rank-val-label-short { display: inline !important; }
}
@media (max-width: 600px) {
    #ze-main-content .ze-rank-th-pop,
    #ze-main-content .ze-rank-pop { display: none !important; }
    #ze-main-content .ze-rank-table { font-size: 13px !important; }
    #ze-main-content .ze-rank-row td { padding: 8px 10px !important; }
}

/* ── Mobile fixes (≤480px) ──────────────────────────────────────────────── */
@media (max-width: 480px) {
    /* Stats cards — single column on very small screens */
    #ze-main-content .ze-stats-row {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }
    #ze-main-content .ze-stat-card { padding: 12px !important; }
    #ze-main-content .ze-stat-value { font-size: 17px !important; }
    #ze-main-content .ze-cmp { font-size: 10px !important; padding: 1px 5px !important; }

    /* Hero */
    #ze-main-content .ze-hero-zip  { font-size: 36px !important; }
    #ze-main-content .ze-hero-h1   { font-size: 22px !important; }
    #ze-main-content .ze-hero-subtitle { font-size: 13px !important; }
    #ze-main-content .ze-container { padding-left: 14px !important; padding-right: 14px !important; }

    /* Data tables — tighter */
    #ze-main-content .ze-data-table th,
    #ze-main-content .ze-data-table td { font-size: 13px !important; padding: 5px 8px 5px 0 !important; }

    /* Demo grid — force single col */
    #ze-main-content .ze-demo-grid { grid-template-columns: 1fr !important; }

    /* Bar labels */
    #ze-main-content .ze-bar-label { width: 70px !important; font-size: 11px !important; }

    /* Section padding */
    #ze-main-content .ze-section { padding: 14px 16px !important; }
}

/* ── Compare table — horizontal scroll on mobile ───────────────────────── */
.ze-compare-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
@media (max-width: 700px) {
    .ze-cmp-table { min-width: 480px; }
    .ze-compare-scroll { overflow-x: auto; }
}

/* ── Topnav — tighter on small screens ─────────────────────────────────── */
@media (max-width: 400px) {
    .ze-topnav-inner { padding: 0 12px !important; gap: 8px !important; }
    .ze-topnav-search input { font-size: 14px !important; }
    .ze-logo-text { display: none !important; }
}

/* ── Home page — stack on mobile ───────────────────────────────────────── */
@media (max-width: 600px) {
    #ze-main-content .ze-home-tools { grid-template-columns: 1fr !important; }
    #ze-main-content .ze-home-states { grid-template-columns: repeat(3, 1fr) !important; }
    #ze-main-content .ze-hero-search-row { flex-direction: column !important; gap: 8px !important; }
    #ze-main-content .ze-hero-search-row input,
    #ze-main-content .ze-hero-search-row button { width: 100% !important; }
}

/* ── Rankings table — more columns hidden on mobile ────────────────────── */
@media (max-width: 480px) {
    #ze-main-content .ze-rank-th-city,
    #ze-main-content .ze-rank-city { display: none !important; }
    #ze-main-content .ze-rank-table { font-size: 13px !important; }
}

/* ── Footer — stack on mobile ──────────────────────────────────────────── */
@media (max-width: 600px) {
}

/* ── Use case headings (accessibility fix — h2 styled as h3) ── */
#ze-main-content .ze-use-case-h {
    font-size: 16px !important;
    font-weight: 700 !important;
    margin: 0 0 8px !important;
    color: var(--ze-gray-900) !important;
}

/* ── Data field category headings (accessibility fix) ── */
#ze-main-content .ze-data-field-h {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--ze-gray-700) !important;
    margin: 0 0 6px !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
}


/* ── Insights post wrapper ───────────────────────────────────────── */
.ze-insights-post {
    --ink:         #1a1612;
    --ink-mid:     #3d3830;
    --ink-light:   #7a7570;
    --ink-faint:   #b0aca8;
    --page:        #faf8f5;
    --surface:     #ffffff;
    --border:      #e8e4de;
    --accent:      #c0392b;
    --accent-light:#fdf0ee;
    --accent-mid:  #e8c4bf;
    --gold:        #9a6f00;
    --gold-light:  #fdf8ed;
    --green:       #1a6644;
    --green-light: #edf6f1;
    --blue:        #1a3a6b;
    --blue-light:  #edf2fb;
    --blue-mid:    #4a7ab5;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif !important;
    font-size: 17px;
    line-height: 1.75;
    color: #3d3830;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
}
.ze-insights-post p {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif !important;
    font-size: 17px !important;
    line-height: 1.75 !important;
    color: #3d3830 !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
    margin: 0 0 22px !important;
}
.ze-insights-post h1,
.ze-insights-post h2,
.ze-insights-post h3 {
    font-family: Georgia, 'Times New Roman', serif !important;
    font-weight: 600 !important;
    color: #1a1612 !important;
    letter-spacing: -0.3px !important;
    line-height: 1.2 !important;
}
.ze-insights-post h1 { font-size: 38px !important; margin: 0 0 20px !important; }
.ze-insights-post h2 { font-size: 24px !important; margin: 48px 0 14px !important; }
.ze-insights-post h3 { font-size: 18px !important; margin: 32px 0 10px !important; }
.ze-insights-post a { color: #c0392b !important; text-decoration: none !important; }
.ze-insights-post a:hover { text-decoration: underline !important; }
.ze-insights-post strong { color: #1a1612 !important; font-weight: 600 !important; }
.ze-insights-post hr {
    border: none !important;
    border-top: 1px solid #e8e4de !important;
    margin: 44px 0 !important;
}

/* Article component resets so theme CSS doesn't bleed */
.ze-insights-post .ze-article { background: transparent; }
.ze-insights-post .wrap { padding: 0; }
.ze-insights-post table {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif !important;
    font-size: 13px !important;
    font-weight: 400 !important;
}
.ze-insights-post thead th {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif !important;
    font-weight: 500 !important;
    letter-spacing: 0.8px !important;
}
.ze-insights-post .eyebrow,
.ze-insights-post .meta,
.ze-insights-post .deck,
.ze-insights-post .stat-card,
.ze-insights-post .callout,
.ze-insights-post .cluster-card,
.ze-insights-post .chart-wrap,
.ze-insights-post .spotlight,
.ze-insights-post .series-footer,
.ze-insights-post .pull-stat,
.ze-insights-post .data-note,
.ze-insights-post .related {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif !important;
    letter-spacing: 0 !important;
    font-weight: 400 !important;
}
.ze-insights-post .stat-card .sv,
.ze-insights-post .pull-stat .ps-val,
.ze-insights-post .cluster-card .cc-n,
.ze-insights-post .sp-badge {
    font-family: Georgia, 'Times New Roman', serif !important;
}

.ze-insights-post .sp-head h3 {
    color: #ffffff !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    margin: 0 0 3px !important;
}
.ze-insights-post .sp-head p {
    color: rgba(255,255,255,0.6) !important;
    font-size: 13px !important;
    margin: 0 !important;
}
.ze-insights-post .sp-head {
    color: #ffffff !important;
}
