/* ============================================================
   KENYAPERMITS.COM — MASTER STYLESHEET
   Version: Final Consolidated
   
   WHERE TO PASTE:
   Appearance → Customize → Additional CSS
   Select all existing content, delete it, paste this entire file.
   
   WHAT THIS COVERS (complete issue log):
   01. Font loading (Playfair Display + DM Sans)
   02. CSS variables (brand colour tokens)
   03. Global resets (Hello Elementor white border fix)
   04. Full-width sections on all pages
   05. Navigation — height, padding, logo hover, link hover, CTA
   06. Hero section — font sizes, layout, flush with search
   07. Search bar — max-width, no stretch
   08. Stats bar
   09. Section headings (eyebrow, title, subtitle)
   10. County card grid — 2-col, unique cards, hover
   11. Direct Answer box
   12. Article body — headings, lists, location list, pro-tip
   13. Article header (kicker, title, meta chips, breadcrumb)
   14. Sidebar — sticky, sales widget, quick info, portal, related
   15. Nearby Counties widget — clean, no rogue images
   16. "Did You Know" full-width strip
   17. Footer — column spacing, link gaps, no squeezed text
   18. WordPress emoji image fix
   19. Elementor widget container padding reset
   20. Section gap elimination (hero → search → stats)
   21. Button system — uniform gold, teal, ghost hover
   22. Responsive breakpoints
   ============================================================ */


/* ── 01. FONT IMPORT ──────────────────────────────────────────
   Included as fallback. Elementor Global Fonts handles primary
   loading, but this ensures fonts are available inside HTML
   widgets and any context Global Fonts misses.
   ─────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;800;900&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700;9..40,800&display=swap');


/* ── 02. CSS VARIABLES ────────────────────────────────────── */
:root {
  --navy:       #0F172A;
  --navy-800:   #1E293B;
  --navy-700:   #334155;
  --teal:       #0D9488;
  --teal-600:   #0F766E;
  --teal-100:   #CCFBF1;
  --teal-50:    #F0FDFA;
  --gold:       #F59E0B;
  --gold-600:   #D97706;
  --gold-100:   #FEF3C7;
  --gold-50:    #FFFBEB;
  --white:      #FFFFFF;
  --slate-50:   #F8FAFC;
  --slate-100:  #F1F5F9;
  --slate-200:  #E2E8F0;
  --slate-400:  #94A3B8;
  --slate-500:  #64748B;
  --slate-600:  #475569;
  --slate-700:  #334155;
  --serif:      'Playfair Display', Georgia, serif;
  --sans:       'DM Sans', system-ui, sans-serif;
  --sh-sm:      0 1px 3px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.05);
  --sh:         0 4px 16px rgba(15,23,42,.10), 0 2px 6px rgba(15,23,42,.06);
  --sh-lg:      0 12px 40px rgba(15,23,42,.13), 0 4px 16px rgba(15,23,42,.07);
  --sh-xl:      0 24px 64px rgba(15,23,42,.18);
  --r8:  8px;
  --r12: 12px;
  --r16: 16px;
}


/* ── 03. GLOBAL RESETS & HELLO ELEMENTOR WHITE BORDER FIX ──
   Hello Elementor wraps all content in #page > .site >
   .site-content > #content > .site-main. These carry white
   backgrounds and padding that create the white border around
   every page. This targets every layer.
   ─────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html {
  background: var(--slate-50) !important;
  overflow-x: hidden !important;
}

body,
body.elementor-page,
body.page,
body.single {
  font-family: var(--sans) !important;
  background: var(--slate-50) !important;
  color: var(--navy) !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow-x: hidden !important;
  -webkit-font-smoothing: antialiased !important;
}

/* Every Hello Elementor structural wrapper */
#page, .site, .hfeed,
#content, .site-content, .content-area,
.site-main, main#main, main.site-main {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  border: none !important;
  box-shadow: none !important;
}

/* Post/page article wrappers */
article.page, article.post, article.hentry {
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}

/* Entry content wrapper Elementor renders into */
.elementor-page .entry-content,
.page .entry-content,
.single .entry-content {
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
}


/* ── 04. FULL-WIDTH SECTIONS ──────────────────────────────── */

/* Standard Elementor stretched sections */
.elementor-section.elementor-section-stretched {
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
}

/* Elementor Flexbox containers (v3.6+) */
.e-con, .e-con-inner {
  max-width: 100% !important;
}

/* Reset Elementor's default widget container padding —
   the single biggest cause of unintended indentation */
.elementor-widget-container {
  padding: 0 !important;
}

/* Section container max-width */
.elementor-section > .elementor-container {
  max-width: 100% !important;
}


/* ── 05. NAVIGATION ─────────────────────────────────────────
   Fixes: logo hover colour, nav link padding collapse,
   CTA button style, full-width sticky behaviour.
   ─────────────────────────────────────────────────────────── */
.nav {
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  background: rgba(15,23,42,.97) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border-bottom: 1px solid rgba(255,255,255,.06) !important;
  width: 100% !important;
  margin: 0 !important;
}

.nav-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 32px !important;
  height: 66px !important;
  gap: 20px !important;
}

/* Logo — zero hover effect, zero colour change ever */
.nav-logo,
.nav-logo:link, .nav-logo:visited,
.nav-logo:hover, .nav-logo:focus, .nav-logo:active,
a.nav-logo, a.nav-logo:hover {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-family: var(--serif) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #FFFFFF !important;
  text-decoration: none !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  transition: none !important;
  transform: none !important;
  flex-shrink: 0 !important;
}

.nav-logo-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: var(--teal) !important;
  box-shadow: 0 0 10px var(--teal) !important;
  flex-shrink: 0 !important;
  display: inline-block !important;
}

/* Nav links — restored padding (was being collapsed) */
.nav-links {
  display: flex !important;
  align-items: center !important;
  gap: 2px !important;
  flex: 1 !important;
  justify-content: center !important;
}

.nav-link,
a.nav-link, a.nav-link:visited {
  font-family: var(--sans) !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,.62) !important;
  padding: 8px 14px !important;
  border-radius: 7px !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  white-space: nowrap !important;
  transition: color .15s ease, background .15s ease !important;
}
.nav-link:hover, a.nav-link:hover {
  color: #FFFFFF !important;
  background: rgba(255,255,255,.09) !important;
  text-decoration: none !important;
}
.nav-link.active, a.nav-link.active {
  color: var(--teal) !important;
}

/* Nav CTA */
.nav-cta, a.nav-cta,
a.nav-cta:link, a.nav-cta:visited {
  background: var(--gold) !important;
  color: var(--navy) !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  padding: 9px 18px !important;
  border-radius: 8px !important;
  text-decoration: none !important;
  border: none !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  box-shadow: 0 2px 12px rgba(245,158,11,.22) !important;
  transition: background .15s ease, transform .12s ease !important;
}
.nav-cta:hover, a.nav-cta:hover {
  background: var(--gold-600) !important;
  color: var(--navy) !important;
  transform: translateY(-1px) !important;
  text-decoration: none !important;
}

/* Kill Elementor padding inside the nav widget */
.nav .elementor-widget-container,
.nav .elementor-column-wrap,
.nav .elementor-widget-wrap,
.elementor-location-header .elementor-widget-container {
  padding: 0 !important;
}


/* ── 06. HERO SECTION ───────────────────────────────────────
   Fixes: large title font size, flush bottom edge,
   proper padding, grid pattern preserved.
   ─────────────────────────────────────────────────────────── */
.hero, .kp-hero {
  background: var(--navy) !important;
  position: relative !important;
  overflow: hidden !important;
  padding: 78px 40px 68px !important;
  width: 100% !important;
  margin: 0 !important;
}

/* Hero title — was rendering at ~18px because Elementor
   global H1 size was overriding. This forces correct size. */
.hero-title, .kp-hero-title {
  font-family: var(--serif) !important;
  font-size: clamp(40px, 5.2vw, 62px) !important;
  font-weight: 900 !important;
  line-height: 1.08 !important;
  letter-spacing: -1px !important;
  color: #FFFFFF !important;
  margin: 0 0 20px 0 !important;
  max-width: 640px !important;
}

.hero-title em, .kp-hero-title em {
  font-style: normal !important;
  color: var(--teal) !important;
}

.hero-subtitle, .kp-hero-subtitle {
  font-family: var(--sans) !important;
  font-size: 17px !important;
  line-height: 1.75 !important;
  color: rgba(255,255,255,.62) !important;
  max-width: 500px !important;
  margin: 0 0 36px 0 !important;
}

.hero-inner, .kp-hero-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  position: relative !important;
  z-index: 1 !important;
}

.hero-kicker, .kp-hero-kicker {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: rgba(13,148,136,.14) !important;
  border: 1px solid rgba(13,148,136,.32) !important;
  color: var(--teal-100) !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 5px 14px !important;
  border-radius: 20px !important;
  margin-bottom: 22px !important;
}

.hero-actions, .kp-hero-actions {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
  margin-bottom: 0 !important;
}

/* Hero section flush — no gap below */
.elementor-section:has(.hero),
.elementor-section:has(.kp-hero),
.e-con:has(.hero),
.e-con:has(.kp-hero) {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}


/* ── 07. SEARCH BAR ─────────────────────────────────────────
   Fixes: was stretching 100% of viewport. Max-width 680px.
   ─────────────────────────────────────────────────────────── */
.search-wrap {
  background: var(--navy) !important;
  padding: 0 40px 44px !important;
  margin: 0 !important;
  border: none !important;
  width: 100% !important;
}
.search-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
}
.search-box {
  display: flex !important;
  align-items: center !important;
  background: #FFFFFF !important;
  border: 2px solid var(--slate-200) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  max-width: 680px !important;
  width: 100% !important;
  box-shadow: var(--sh-lg) !important;
}
.search-box input[type="text"],
.search-box input[type="search"],
.search-box input {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  font-family: var(--sans) !important;
  font-size: 15px !important;
  padding: 16px 20px !important;
  color: var(--navy) !important;
  background: transparent !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  width: auto !important;
}
.search-box input::placeholder { color: var(--slate-400) !important; }
.search-btn {
  flex-shrink: 0 !important;
  background: var(--teal) !important;
  color: #FFFFFF !important;
  border: none !important;
  cursor: pointer !important;
  padding: 11px 22px !important;
  font-family: var(--sans) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 4px !important;
  border-radius: 9px !important;
  width: auto !important;
  height: auto !important;
  transition: background .15s ease !important;
}
.search-btn:hover { background: var(--teal-600) !important; }
.search-btn svg { width: 15px !important; height: 15px !important; fill: white !important; }

/* Search section — flush to hero above */
.elementor-section:has(.search-wrap),
.e-con:has(.search-wrap) {
  padding-top: 0 !important;
  margin-top: 0 !important;
}


/* ── 08. STATS BAR ─────────────────────────────────────────── */
.stats-bar {
  background: #FFFFFF !important;
  border-bottom: 1px solid var(--slate-200) !important;
  box-shadow: var(--sh-sm) !important;
  width: 100% !important;
  margin: 0 !important;
}
.stats-bar-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  padding: 0 32px !important;
}
.stat-item {
  padding: 20px 22px !important;
  border-right: 1px solid var(--slate-200) !important;
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
}
.stat-item:last-child { border-right: none !important; }
.stat-icon {
  width: 40px !important;
  height: 40px !important;
  border-radius: 10px !important;
  background: var(--teal-50) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
.stat-icon svg { width: 20px !important; height: 20px !important; fill: var(--teal) !important; }
.stat-num {
  font-family: var(--serif) !important;
  font-size: 23px !important;
  font-weight: 800 !important;
  color: var(--navy) !important;
  line-height: 1 !important;
}
.stat-label {
  font-family: var(--sans) !important;
  font-size: 12px !important;
  color: var(--slate-500) !important;
  margin-top: 3px !important;
}


/* ── 09. SECTION HEADINGS ───────────────────────────────────── */
.section-eyebrow {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--teal) !important;
  margin-bottom: 10px !important;
}
.section-eyebrow::after {
  content: '' !important;
  flex: 1 !important;
  height: 1px !important;
  background: linear-gradient(90deg, var(--teal-100), transparent) !important;
}
.section-title {
  font-family: var(--serif) !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  color: var(--navy) !important;
  margin-bottom: 8px !important;
  line-height: 1.2 !important;
}
.section-sub {
  font-family: var(--sans) !important;
  font-size: 14px !important;
  color: var(--slate-500) !important;
  margin-bottom: 28px !important;
  line-height: 1.65 !important;
}


/* ── 10. COUNTY CARD GRID ───────────────────────────────────── */
.main-wrap {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 48px 32px !important;
}

.county-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 16px !important;
  margin-bottom: 40px !important;
}

.county-card {
  background: #FFFFFF !important;
  border: 1px solid var(--slate-200) !important;
  border-radius: var(--r12) !important;
  padding: 20px !important;
  cursor: pointer !important;
  position: relative !important;
  overflow: hidden !important;
  display: block !important;
  text-decoration: none !important;
  color: inherit !important;
  transition: border-color .2s ease, box-shadow .2s ease, transform .15s ease !important;
}
.county-card::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 3px !important;
  background: var(--teal) !important;
  transform: scaleY(0) !important;
  transform-origin: bottom !important;
  transition: transform .2s ease !important;
}
.county-card:hover {
  border-color: var(--teal-100) !important;
  box-shadow: var(--sh) !important;
  transform: translateY(-3px) !important;
  text-decoration: none !important;
  color: inherit !important;
}
.county-card:hover::before { transform: scaleY(1) !important; }

.county-card-top {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  margin-bottom: 12px !important;
}
.county-name {
  font-family: var(--serif) !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--navy) !important;
}
.county-badge {
  font-family: var(--sans) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: .8px !important;
  text-transform: uppercase !important;
  padding: 3px 10px !important;
  border-radius: 20px !important;
  white-space: nowrap !important;
}
.badge-hot  { background: rgba(245,158,11,.12) !important; color: var(--gold-600) !important; }
.badge-new  { background: var(--teal-50) !important; color: var(--teal) !important; }
.badge-fast { background: rgba(15,23,42,.06) !important; color: var(--slate-600) !important; }

.county-meta {
  display: flex !important;
  gap: 14px !important;
  margin-bottom: 10px !important;
}
.county-meta-item {
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  color: var(--slate-500) !important;
}
.county-meta-item strong { color: var(--navy) !important; font-weight: 600 !important; }
.county-meta-item svg { width: 13px !important; height: 13px !important; fill: var(--slate-400) !important; }

.county-hook {
  font-family: var(--sans) !important;
  font-size: 13px !important;
  color: var(--slate-600) !important;
  line-height: 1.65 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}
.county-link {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--teal) !important;
  text-decoration: none !important;
  margin-top: 12px !important;
}
.county-link:hover { color: var(--teal-600) !important; text-decoration: none !important; }
.county-link svg { width: 13px !important; height: 13px !important; fill: var(--teal) !important; }


/* ── 11. DIRECT ANSWER BOX ──────────────────────────────────── */
.direct-answer {
  background: #FFFFFF !important;
  border: 1px solid var(--teal-100) !important;
  border-left: 5px solid var(--teal) !important;
  border-radius: var(--r12) !important;
  padding: 28px 30px !important;
  margin-bottom: 28px !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: var(--sh) !important;
}
.direct-answer::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  width: 180px !important;
  height: 180px !important;
  background: radial-gradient(circle at top right, var(--teal-50), transparent 70%) !important;
  pointer-events: none !important;
}
.da-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: var(--teal) !important;
  color: white !important;
  font-family: var(--sans) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 4px 12px !important;
  border-radius: 20px !important;
  margin-bottom: 14px !important;
}
.da-badge svg { width: 12px !important; height: 12px !important; fill: white !important; }
.da-title {
  font-family: var(--serif) !important;
  font-size: 19px !important;
  font-weight: 700 !important;
  color: var(--navy) !important;
  margin-bottom: 10px !important;
  line-height: 1.35 !important;
}
.da-body {
  font-family: var(--sans) !important;
  font-size: 14px !important;
  line-height: 1.8 !important;
  color: var(--slate-600) !important;
  margin-bottom: 20px !important;
}
.da-body strong { color: var(--navy) !important; }
.da-meta {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 10px !important;
  margin-bottom: 18px !important;
}
.da-meta-card {
  background: var(--slate-50) !important;
  border: 1px solid var(--slate-200) !important;
  border-radius: var(--r8) !important;
  padding: 12px 14px !important;
}
.da-meta-label {
  font-family: var(--sans) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  color: var(--slate-400) !important;
  margin-bottom: 4px !important;
}
.da-meta-val {
  font-family: var(--sans) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--navy) !important;
}
.da-meta-val.teal { color: var(--teal) !important; }
.da-meta-val.gold { color: var(--gold-600) !important; }


/* ── 12. ARTICLE BODY ──────────────────────────────────────── */
.article-body {
  background: #FFFFFF !important;
  border: 1px solid var(--slate-200) !important;
  border-radius: var(--r12) !important;
  padding: 32px !important;
  box-shadow: var(--sh-sm) !important;
  margin-bottom: 28px !important;
}
.article-body h2 {
  font-family: var(--serif) !important;
  font-size: 20px !important;
  font-weight: 800 !important;
  color: var(--navy) !important;
  margin: 28px 0 14px !important;
  padding-top: 28px !important;
  border-top: 1px solid var(--slate-100) !important;
  line-height: 1.3 !important;
}
.article-body h2:first-child {
  margin-top: 0 !important;
  padding-top: 0 !important;
  border-top: none !important;
}
.article-body ol { list-style: decimal !important; }
.article-body ul:not(.location-list) { list-style: disc !important; }
.article-body ol,
.article-body ul:not(.location-list) {
  padding-left: 22px !important;
  margin: 0 !important;
}
.article-body li {
  font-family: var(--sans) !important;
  font-size: 14px !important;
  line-height: 1.8 !important;
  color: var(--slate-700) !important;
  margin-bottom: 10px !important;
}
.article-body li strong { color: var(--navy) !important; font-weight: 600 !important; }
.article-body p {
  font-family: var(--sans) !important;
  font-size: 14px !important;
  line-height: 1.8 !important;
  color: var(--slate-600) !important;
  margin-bottom: 14px !important;
}

/* Location list */
.location-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.location-list li {
  list-style: none !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  padding: 10px 0 !important;
  border-bottom: 1px solid var(--slate-100) !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  color: var(--slate-600) !important;
  padding-left: 0 !important;
  margin-bottom: 0 !important;
}
.location-list li:last-child { border-bottom: none !important; }
.location-list li strong {
  color: var(--navy) !important;
  display: block !important;
  font-size: 13px !important;
}
.location-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: 7px !important;
  background: var(--teal-50) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  margin-top: 1px !important;
}
.location-icon svg { width: 14px !important; height: 14px !important; fill: var(--teal) !important; }

/* Pro tip */
.pro-tip {
  background: var(--gold-50) !important;
  border: 1px solid var(--gold-100) !important;
  border-left: 4px solid var(--gold) !important;
  border-radius: var(--r8) !important;
  padding: 16px 18px !important;
  margin-top: 24px !important;
}
.pro-tip-label {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  color: var(--gold-600) !important;
  margin-bottom: 6px !important;
}
.pro-tip-label svg { width: 14px !important; height: 14px !important; fill: var(--gold) !important; }
.pro-tip p {
  font-family: var(--sans) !important;
  font-size: 13px !important;
  line-height: 1.7 !important;
  color: var(--slate-700) !important;
  margin: 0 !important;
}


/* ── 13. ARTICLE HEADER ─────────────────────────────────────── */
.article-header { margin-bottom: 24px !important; }

.article-kicker,
.article-kicker:hover {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: var(--teal-50) !important;
  border: 1px solid var(--teal-100) !important;
  color: var(--teal) !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  padding: 4px 12px !important;
  border-radius: 20px !important;
  margin-bottom: 12px !important;
  text-decoration: none !important;
}

.article-title {
  font-family: var(--serif) !important;
  font-size: clamp(24px, 3vw, 36px) !important;
  font-weight: 900 !important;
  color: var(--navy) !important;
  line-height: 1.18 !important;
  letter-spacing: -.4px !important;
  margin-bottom: 12px !important;
}

.article-meta {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  flex-wrap: wrap !important;
  padding-bottom: 16px !important;
  border-bottom: 1px solid var(--slate-200) !important;
}
.meta-chip {
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  color: var(--slate-500) !important;
  text-decoration: none !important;
}
.meta-chip svg { width: 13px !important; height: 13px !important; fill: var(--slate-400) !important; }

/* Breadcrumb */
.breadcrumb {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  color: var(--slate-400) !important;
  margin-bottom: 20px !important;
  flex-wrap: wrap !important;
}
.breadcrumb a, .breadcrumb a:visited {
  color: var(--teal) !important;
  text-decoration: none !important;
}
.breadcrumb a:hover { color: var(--teal-600) !important; text-decoration: none !important; }
.breadcrumb svg {
  width: 12px !important;
  height: 12px !important;
  fill: var(--slate-300) !important;
  vertical-align: middle !important;
  flex-shrink: 0 !important;
}


/* ── 14. CONTENT GRID + SIDEBAR ─────────────────────────────── */
.content-grid {
  display: grid !important;
  grid-template-columns: 1fr 340px !important;
  gap: 32px !important;
  align-items: start !important;
  width: 100% !important;
}

.sidebar {
  display: flex !important;
  flex-direction: column !important;
  gap: 20px !important;
  position: sticky !important;
  top: 84px !important;
  align-self: flex-start !important;
}

/* Sales widget */
.sales-widget {
  background: var(--navy) !important;
  border-radius: var(--r16) !important;
  padding: 28px 24px !important;
  box-shadow: var(--sh-xl) !important;
  position: relative !important;
  overflow: hidden !important;
}
.sales-widget::before {
  content: '' !important;
  position: absolute !important;
  top: -80px !important; right: -80px !important;
  width: 240px !important; height: 240px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle, rgba(13,148,136,.22) 0%, transparent 65%) !important;
  pointer-events: none !important;
}
.sales-widget::after {
  content: '' !important;
  position: absolute !important;
  bottom: -60px !important; left: -40px !important;
  width: 180px !important; height: 180px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle, rgba(245,158,11,.12) 0%, transparent 65%) !important;
  pointer-events: none !important;
}
.sw-tag {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: rgba(245,158,11,.14) !important;
  border: 1px solid rgba(245,158,11,.28) !important;
  color: var(--gold) !important;
  font-family: var(--sans) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 4px 12px !important;
  border-radius: 20px !important;
  margin-bottom: 14px !important;
}
.sw-headline {
  font-family: var(--serif) !important;
  font-size: 20px !important;
  font-weight: 800 !important;
  color: white !important;
  line-height: 1.25 !important;
  margin-bottom: 8px !important;
}
.sw-headline span { color: var(--gold) !important; }
.sw-sub {
  font-family: var(--sans) !important;
  font-size: 13px !important;
  color: rgba(255,255,255,.55) !important;
  line-height: 1.6 !important;
  margin-bottom: 18px !important;
}
.sw-benefits {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 20px 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 9px !important;
}
.sw-benefit {
  display: flex !important;
  align-items: flex-start !important;
  gap: 9px !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  color: rgba(255,255,255,.8) !important;
  line-height: 1.5 !important;
}
.sw-check {
  width: 20px !important; height: 20px !important;
  border-radius: 50% !important;
  background: var(--teal) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  margin-top: 1px !important;
}
.sw-check svg { width: 11px !important; height: 11px !important; fill: white !important; }
.sw-divider {
  border: none !important;
  border-top: 1px solid rgba(255,255,255,.09) !important;
  margin: 16px 0 !important;
}
.sw-price-row {
  display: flex !important;
  align-items: baseline !important;
  gap: 8px !important;
  margin-bottom: 16px !important;
}
.sw-price {
  font-family: var(--serif) !important;
  font-size: 32px !important;
  font-weight: 700 !important;
  color: var(--gold) !important;
  line-height: 1 !important;
}
.sw-currency {
  font-family: var(--sans) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--gold) !important;
}
.sw-note {
  font-family: var(--sans) !important;
  font-size: 11px !important;
  color: rgba(255,255,255,.38) !important;
  line-height: 1.4 !important;
}
.sw-trust {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  color: rgba(255,255,255,.38) !important;
  text-align: center !important;
}
.sw-trust svg { width: 13px !important; height: 13px !important; fill: var(--teal) !important; }
.sw-trust strong { color: rgba(255,255,255,.65) !important; }

/* Quick info widget */
.quick-info {
  background: #FFFFFF !important;
  border: 1px solid var(--slate-200) !important;
  border-radius: var(--r12) !important;
  overflow: hidden !important;
  box-shadow: var(--sh-sm) !important;
}
.qi-header {
  background: var(--navy) !important;
  padding: 14px 18px !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .8px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,.7) !important;
}
.qi-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 11px 18px !important;
  border-bottom: 1px solid var(--slate-100) !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
}
.qi-row:last-child { border-bottom: none !important; }
.qi-label { color: var(--slate-500) !important; }
.qi-value { font-weight: 600 !important; color: var(--navy) !important; }
.qi-value.teal { color: var(--teal) !important; }
.qi-value.gold { color: var(--gold-600) !important; }

/* Portal widget */
.portal-widget {
  background: var(--teal) !important;
  border-radius: var(--r12) !important;
  padding: 18px 20px !important;
  text-align: center !important;
  box-shadow: 0 4px 20px rgba(13,148,136,.25) !important;
}
.portal-widget p {
  font-family: var(--sans) !important;
  font-size: 12px !important;
  color: rgba(255,255,255,.7) !important;
  margin-bottom: 10px !important;
}


/* ── 15. NEARBY COUNTIES WIDGET ─────────────────────────────── */
.related-widget {
  background: #FFFFFF !important;
  border: 1px solid var(--slate-200) !important;
  border-radius: var(--r12) !important;
  overflow: hidden !important;
  box-shadow: var(--sh-sm) !important;
}
.rw-header {
  padding: 14px 18px !important;
  border-bottom: 1px solid var(--slate-100) !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--navy) !important;
}
.rw-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.rw-item {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 11px 18px !important;
  border-bottom: 1px solid var(--slate-100) !important;
  transition: background .15s ease !important;
  text-decoration: none !important;
}
.rw-item:last-child { border-bottom: none !important; }
.rw-item:hover { background: var(--slate-50) !important; }

.rw-county {
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--navy) !important;
  text-decoration: none !important;
}
.rw-fee {
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--teal) !important;
  text-decoration: none !important;
}

/* Kill any rogue image widget that appears near the sidebar */
.related-widget img:not(.emoji),
.sidebar > .elementor-widget-image,
.sidebar .wp-block-image,
.sidebar .elementor-image {
  display: none !important;
}


/* ── 16. "DID YOU KNOW" FULL-WIDTH STRIP ────────────────────── */
.kp-did-you-know {
  background: var(--navy) !important;
  width: 100% !important;
  padding: 52px 40px !important;
  position: relative !important;
  overflow: hidden !important;
}
.kp-did-you-know::before {
  content: '' !important;
  position: absolute !important;
  top: -80px !important; right: -80px !important;
  width: 400px !important; height: 400px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle, rgba(13,148,136,.14) 0%, transparent 60%) !important;
  pointer-events: none !important;
}
.kp-did-you-know::after {
  content: '' !important;
  position: absolute !important;
  bottom: -60px !important; left: -40px !important;
  width: 300px !important; height: 300px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle, rgba(245,158,11,.09) 0%, transparent 60%) !important;
  pointer-events: none !important;
}
.kp-dyk-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  display: flex !important;
  align-items: center !important;
  gap: 32px !important;
  position: relative !important;
  z-index: 1 !important;
}
.kp-dyk-icon-wrap {
  flex-shrink: 0 !important;
  width: 60px !important; height: 60px !important;
  border-radius: 16px !important;
  background: rgba(13,148,136,.18) !important;
  border: 1px solid rgba(13,148,136,.3) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 28px !important;
}
.kp-dyk-label {
  font-family: var(--sans) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--teal) !important;
  margin-bottom: 8px !important;
}
.kp-dyk-headline {
  font-family: var(--serif) !important;
  font-size: clamp(18px, 2.2vw, 26px) !important;
  font-weight: 800 !important;
  color: #FFFFFF !important;
  line-height: 1.28 !important;
  letter-spacing: -.2px !important;
  margin-bottom: 10px !important;
}
.kp-dyk-headline em { font-style: normal !important; color: var(--gold) !important; }
.kp-dyk-body {
  font-family: var(--sans) !important;
  font-size: 14px !important;
  color: rgba(255,255,255,.6) !important;
  line-height: 1.75 !important;
  max-width: 640px !important;
  margin: 0 !important;
}
.kp-dyk-body strong { color: rgba(255,255,255,.88) !important; }
.kp-dyk-right { margin-left: auto !important; flex-shrink: 0 !important; }


/* ── 17. FOOTER ─────────────────────────────────────────────── */
.footer {
  background: var(--navy) !important;
  padding: 60px 32px 32px !important;
  margin-top: 0 !important;
  width: 100% !important;
}
.footer-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
}
.footer-grid {
  display: grid !important;
  grid-template-columns: 2.2fr 1fr 1fr 1fr !important;
  gap: 48px !important;
  margin-bottom: 48px !important;
}
.footer-brand-name,
.footer-brand-name:hover {
  font-family: var(--serif) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #FFFFFF !important;
  margin-bottom: 12px !important;
  text-decoration: none !important;
  display: block !important;
}
.footer-brand-desc {
  font-family: var(--sans) !important;
  font-size: 13px !important;
  color: rgba(255,255,255,.42) !important;
  line-height: 1.75 !important;
  max-width: 280px !important;
  margin-bottom: 18px !important;
}
.footer-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: rgba(13,148,136,.14) !important;
  border: 1px solid rgba(13,148,136,.24) !important;
  color: var(--teal-100) !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  padding: 5px 12px !important;
  border-radius: 6px !important;
}
.footer-col-title {
  font-family: var(--sans) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1.8px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,.32) !important;
  margin-bottom: 16px !important;
}
.footer-links {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 11px !important;
}
.footer-links a, .footer-links a:visited {
  font-family: var(--sans) !important;
  font-size: 13.5px !important;
  color: rgba(255,255,255,.52) !important;
  text-decoration: none !important;
  line-height: 1.4 !important;
  transition: color .15s ease !important;
}
.footer-links a:hover { color: #FFFFFF !important; text-decoration: none !important; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.07) !important;
  padding-top: 22px !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
}
.footer-copy {
  font-family: var(--sans) !important;
  font-size: 12px !important;
  color: rgba(255,255,255,.28) !important;
  line-height: 1.5 !important;
}
.footer-legal { display: flex !important; gap: 18px !important; }
.footer-legal a, .footer-legal a:visited {
  font-family: var(--sans) !important;
  font-size: 12px !important;
  color: rgba(255,255,255,.28) !important;
  text-decoration: none !important;
  transition: color .15s ease !important;
}
.footer-legal a:hover { color: rgba(255,255,255,.65) !important; text-decoration: none !important; }


/* ── 18. WORDPRESS EMOJI IMAGE FIX ─────────────────────────── */
img.emoji, img.wp-smiley {
  display: inline !important;
  width: 1em !important;
  height: 1em !important;
  vertical-align: -0.1em !important;
  margin: 0 0.05em !important;
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
  background: none !important;
  border-radius: 0 !important;
  max-width: none !important;
}
/* Specific elements where emoji sit inside badge/pill layouts */
.article-kicker img.emoji,
.da-badge img.emoji,
.county-badge img.emoji,
.hero-kicker img.emoji,
.kp-hero-kicker img.emoji,
.sw-tag img.emoji,
.qi-header img.emoji,
.rw-header img.emoji,
.pro-tip-label img.emoji,
.kp-dyk-icon-wrap img.emoji,
.section-eyebrow img.emoji,
.county-name img.emoji {
  width: 1em !important;
  height: 1em !important;
  display: inline-flex !important;
  vertical-align: middle !important;
  margin: 0 2px !important;
}


/* ── 19. BUTTON SYSTEM ─────────────────────────────────────── */

/* Shared base for all buttons */
.btn-primary, a.btn-primary,
.btn-secondary, a.btn-secondary,
.da-portal-btn, a.da-portal-btn,
.sw-cta,
.nav-cta, a.nav-cta,
.kp-btn-gold, a.kp-btn-gold,
.kp-btn-ghost, a.kp-btn-ghost,
.kp-dyk-cta, a.kp-dyk-cta,
.portal-widget a {
  -webkit-appearance: none !important;
  appearance: none !important;
  text-shadow: none !important;
  cursor: pointer !important;
  font-family: var(--sans) !important;
  text-decoration: none !important;
  border-radius: 9px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  transition: background .15s ease, transform .15s ease, box-shadow .15s ease !important;
}

/* GOLD — Primary CTA (hero, nav, sales widget, Did You Know) */
.btn-primary, a.btn-primary,
.kp-btn-gold, a.kp-btn-gold,
.kp-dyk-cta, a.kp-dyk-cta {
  background: var(--gold) !important;
  color: var(--navy) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  padding: 14px 28px !important;
  gap: 8px !important;
  box-shadow: 0 4px 18px rgba(245,158,11,.34) !important;
  border: none !important;
}
.btn-primary:hover, a.btn-primary:hover,
.kp-btn-gold:hover, a.kp-btn-gold:hover,
.kp-dyk-cta:hover, a.kp-dyk-cta:hover {
  background: var(--gold-600) !important;
  color: var(--navy) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 26px rgba(245,158,11,.44) !important;
  text-decoration: none !important;
}

/* GOLD — Sales widget CTA (full width) */
.sw-cta {
  background: var(--gold) !important;
  color: var(--navy) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  padding: 14px 20px !important;
  border-radius: 9px !important;
  border: none !important;
  display: block !important;
  width: 100% !important;
  text-align: center !important;
  box-shadow: 0 4px 16px rgba(245,158,11,.28) !important;
  margin-bottom: 12px !important;
}
.sw-cta:hover {
  background: var(--gold-600) !important;
  color: var(--navy) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 22px rgba(245,158,11,.38) !important;
  text-decoration: none !important;
}

/* TEAL — Portal buttons, apply buttons */
.da-portal-btn, a.da-portal-btn {
  background: var(--teal) !important;
  color: #FFFFFF !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  padding: 11px 22px !important;
  gap: 8px !important;
  border: none !important;
  box-shadow: 0 3px 12px rgba(13,148,136,.2) !important;
}
.da-portal-btn:hover, a.da-portal-btn:hover {
  background: var(--teal-600) !important;
  color: #FFFFFF !important;
  transform: translateY(-1px) !important;
  text-decoration: none !important;
}

/* WHITE on TEAL — portal widget button */
.portal-widget a {
  background: #FFFFFF !important;
  color: var(--teal-600) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  padding: 11px 22px !important;
  gap: 7px !important;
  border-radius: 8px !important;
  box-shadow: none !important;
  border: none !important;
}
.portal-widget a:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,.16) !important;
  transform: translateY(-1px) !important;
  color: var(--teal-600) !important;
  text-decoration: none !important;
}

/* GHOST — Secondary hero button */
.btn-secondary, a.btn-secondary,
.kp-btn-ghost, a.kp-btn-ghost {
  background: rgba(255,255,255,.07) !important;
  color: rgba(255,255,255,.82) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  padding: 14px 24px !important;
  gap: 8px !important;
  box-shadow: none !important;
}
.btn-secondary:hover, a.btn-secondary:hover,
.kp-btn-ghost:hover, a.kp-btn-ghost:hover {
  background: rgba(255,255,255,.13) !important;
  color: #FFFFFF !important;
  border-color: rgba(255,255,255,.28) !important;
  text-decoration: none !important;
  transform: none !important;
}


/* ── 20. SECTION GAP ELIMINATION ────────────────────────────── */

/* Add CSS class "kp-flush" in Elementor Advanced → CSS Classes
   to any section that should have zero top/bottom gap.
   Apply to: Hero section, Search section, Stats section. */
.kp-flush,
.elementor-section.kp-flush,
.e-con.kp-flush {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
.kp-flush .elementor-column-wrap,
.kp-flush .elementor-widget-wrap {
  padding: 0 !important;
}


/* ── 21. RESPONSIVE ─────────────────────────────────────────── */
@media (max-width: 960px) {
  .content-grid {
    grid-template-columns: 1fr !important;
  }
  .sidebar {
    position: static !important;
  }
  .footer-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 32px !important;
  }
}

@media (max-width: 768px) {
  .nav-links { display: none !important; }
  .nav-inner { padding: 0 20px !important; }
  .hero, .kp-hero { padding: 52px 20px 44px !important; }
  .search-wrap { padding: 0 20px 36px !important; }
  .main-wrap { padding: 28px 20px !important; }
  .stats-bar-inner {
    grid-template-columns: 1fr 1fr !important;
    padding: 0 20px !important;
  }
  .county-grid { grid-template-columns: 1fr !important; }
  .da-meta { grid-template-columns: 1fr 1fr !important; }
  .footer { padding: 40px 20px 24px !important; }
  .footer-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
  .footer-brand-desc { max-width: 100% !important; }
  .kp-dyk-inner { flex-direction: column !important; align-items: flex-start !important; gap: 20px !important; }
  .kp-dyk-right { margin-left: 0 !important; }
  .kp-did-you-know { padding: 36px 20px !important; }
}

@media (max-width: 480px) {
  .nav-cta { font-size: 11px !important; padding: 8px 12px !important; }
  .hero-title, .kp-hero-title { font-size: 34px !important; letter-spacing: -.5px !important; }
  .hero-actions, .kp-hero-actions { flex-direction: column !important; align-items: stretch !important; gap: 10px !important; }
  .btn-primary, .btn-secondary,
  .kp-btn-gold, .kp-btn-ghost { width: 100% !important; }
}

/* ── 22. MOBILE RESPONSIVE FIXES (Apr 2026) ──────────────────
   Targets: header CTA overlap, hero kicker overlap, stats
   bar overlap, hero illustration stacking. Desktop-safe —
   all rules scoped inside mobile media queries.
   ─────────────────────────────────────────────────────────── */

/* Royal Addons mobile breakpoint is 1024px — not 768 */
@media (max-width: 1024px) {

@media (max-width: 768px) {

  /* 22.4 — Hero kicker pill: stop "UPDATED FOR / FINANCE 2026"
     from overlapping. Force single line with proper line-height. */
  .hero-kicker, .kp-hero-kicker {
    white-space: nowrap !important;
    line-height: 1.4 !important;
    font-size: 10px !important;
    padding: 5px 12px !important;
    letter-spacing: 1px !important;
    max-width: calc(100vw - 40px) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  /* 22.5 — Force hero content to single column. Illustration
     stacks BELOW text on mobile instead of bleeding into it. */
  .hero-inner, .kp-hero-inner {
    display: block !important;
  }
  .hero-image, .kp-hero-image,
  .hero-illustration, .kp-hero-illustration,
  .hero-visual, .kp-hero-visual,
  .hero-inner > svg, .kp-hero-inner > svg,
  .hero-inner > img, .kp-hero-inner > img {
    position: static !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    margin: 28px 0 0 0 !important;
    display: block !important;
    float: none !important;
  }

  /* 22.6 — Stats bar: force number + label to stack vertically
     inside each stat item. Was rendering side-by-side/overlapped. */
  .stat-item {
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 16px 14px !important;
  }
  .stat-item > .stat-icon { flex-shrink: 0 !important; }
  .stat-item .stat-num,
  .stat-item .stat-label {
    display: block !important;
    width: 100% !important;
    flex-basis: 100% !important;
  }
  .stat-item .stat-num {
    line-height: 1.1 !important;
    margin: 0 !important;
    font-size: 22px !important;
  }
  .stat-item .stat-label {
    line-height: 1.3 !important;
    margin-top: 2px !important;
  }
  /* If icon + text should sit side-by-side with text stacked: */
  .stat-item {
    display: grid !important;
    grid-template-columns: 40px 1fr !important;
    align-items: center !important;
  }
}

@media (max-width: 480px) {

  /* 22.7 — Hero actions: enforce single column, full-width buttons.
     Rule 21 already does this but we reinforce in case of Elementor
     inline style conflicts. */
  .hero-actions, .kp-hero-actions {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    width: 100% !important;
    gap: 12px !important;
    margin-top: 20px !important;
  }
  .hero-actions > *, .kp-hero-actions > *,
  .btn-primary, .btn-secondary,
  .kp-btn-gold, .kp-btn-ghost {
    width: 100% !important;
    max-width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* 22.8 — Search input placeholder truncation fix */
  .search-box input {
    font-size: 14px !important;
    padding: 14px 14px !important;
  }
  .search-btn {
    padding: 10px 14px !important;
    font-size: 13px !important;
  }
}

/* ── 23. HERO BUTTON CLASS ALIGNMENT (Apr 2026) ──────────────
   The hero HTML uses .btn-gold / .btn-ghost, but section 19's
   button system targets .kp-btn-gold / .kp-btn-ghost. Adding
   the missing class variants so hero buttons inherit the full
   button-system styling (nowrap, flex alignment, padding).
   ─────────────────────────────────────────────────────────── */

/* Shared base — matches section 19 base */
.btn-gold, a.btn-gold,
.btn-ghost, a.btn-ghost {
  -webkit-appearance: none !important;
  appearance: none !important;
  text-shadow: none !important;
  cursor: pointer !important;
  font-family: var(--sans) !important;
  text-decoration: none !important;
  border-radius: 9px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  transition: background .15s ease, transform .15s ease, box-shadow .15s ease !important;
}

/* GOLD primary */
.btn-gold, a.btn-gold,
a.btn-gold:link, a.btn-gold:visited {
  background: var(--gold) !important;
  color: var(--navy) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  padding: 14px 28px !important;
  gap: 8px !important;
  box-shadow: 0 4px 18px rgba(245,158,11,.34) !important;
  border: none !important;
}
.btn-gold:hover, a.btn-gold:hover {
  background: var(--gold-600) !important;
  color: var(--navy) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 26px rgba(245,158,11,.44) !important;
  text-decoration: none !important;
}
.btn-gold svg, a.btn-gold svg {
  width: 15px !important;
  height: 15px !important;
  fill: currentColor !important;
  flex-shrink: 0 !important;
}

/* GHOST secondary */
.btn-ghost, a.btn-ghost,
a.btn-ghost:link, a.btn-ghost:visited {
  background: rgba(255,255,255,.07) !important;
  color: rgba(255,255,255,.82) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  padding: 14px 24px !important;
  gap: 8px !important;
  box-shadow: none !important;
}
.btn-ghost:hover, a.btn-ghost:hover {
  background: rgba(255,255,255,.13) !important;
  color: #FFFFFF !important;
  border-color: rgba(255,255,255,.28) !important;
  text-decoration: none !important;
  transform: none !important;
}
.btn-ghost svg, a.btn-ghost svg {
  width: 15px !important;
  height: 15px !important;
  fill: rgba(255,255,255,.65) !important;
  flex-shrink: 0 !important;
}

/* Mobile: force full-width for hero buttons regardless of class name */
@media (max-width: 480px) {
  .hero-actions .btn-gold, .hero-actions .btn-ghost,
  .kp-hero-actions .btn-gold, .kp-hero-actions .btn-ghost {
    width: 100% !important;
    max-width: 100% !important;
    justify-content: center !important;
  }
}

	/* ── 25. HEADER — FINAL CONSOLIDATED FIXES ──────────────────
   2-column layout (logo + nav only). No button.
   Handles: 1200px alignment, teal hamburger, mobile menu.
   ─────────────────────────────────────────────────────────── */

/* Align header inner content with body (1200px) */
.elementor-location-header .elementor-container,
.elementor-location-header .elementor-section > .elementor-container,
.elementor-location-header .e-con-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  width: 100% !important;
}

@media (max-width: 1024px) {

  /* Hamburger: purple → teal */
  .wpr-mobile-toggle-wrap *,
  .wpr-mobile-toggle-wrap i,
  .wpr-mobile-toggle-wrap i::before,
  .wpr-mobile-toggle-wrap svg,
  .wpr-mobile-toggle-wrap svg *,
  .wpr-mobile-toggle-btn,
  .wpr-mobile-toggle-btn * {
    color: #0D9488 !important;
    fill: #0D9488 !important;
    stroke: #0D9488 !important;
    border-color: #0D9488 !important;
  }

  /* Mobile dropdown: navy bg, white links */
  .wpr-mobile-nav-menu-container,
  .wpr-mobile-nav-menu,
  nav.wpr-mobile-nav-menu-container {
    background: #0F172A !important;
    border-top: 1px solid rgba(255,255,255,.07) !important;
  }
  .wpr-mobile-nav-menu a,
  .wpr-mobile-nav-menu-container a {
    color: rgba(255,255,255,.85) !important;
    background: transparent !important;
    padding: 14px 24px !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border-bottom: 1px solid rgba(255,255,255,.06) !important;
  }
  .wpr-mobile-nav-menu a:hover,
  .wpr-mobile-nav-menu-container a:hover {
    background: rgba(13,148,136,.12) !important;
    color: #CCFBF1 !important;
  }
}
	
	/* ── 27. SEARCH RESULTS PAGE — ID-SCOPED (Apr 2026) ──────────
   Uses #content ID selector (specificity 100) to beat
   Hello Elementor parent theme's #content main rules.
   ─────────────────────────────────────────────────────────── */

/* Body padding reset (unchanged from before — still needed) */
body, body.home, body.page, body.single, body.search {
  padding-top: 0 !important;
}

/* Layout container — use #content ID for high specificity */
main#content.kp-search-main {
  background: #F8FAFC !important;
  min-height: 60vh !important;
  padding: 56px 40px 88px !important;
  max-width: none !important;
  width: 100% !important;
  box-sizing: border-box !important;
  display: block !important;
  margin: 0 !important;
}
main#content .kp-search-inner {
  max-width: 1200px !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  display: block !important;
}

/* Header */
main#content .kp-search-header {
  margin: 0 0 36px !important;
  padding: 0 !important;
  display: block !important;
  max-width: none !important;
}
main#content .kp-search-title {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 34px !important;
  font-weight: 800 !important;
  color: #0F172A !important;
  line-height: 1.2 !important;
  letter-spacing: -.5px !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
  display: block !important;
  max-width: none !important;
}
main#content .kp-search-sub {
  font-family: 'DM Sans', system-ui, sans-serif !important;
  font-size: 15px !important;
  color: #64748B !important;
  line-height: 1.55 !important;
  margin: 0 !important;
  padding: 0 !important;
  max-width: 640px !important;
  display: block !important;
}

/* Grid */
main#content .kp-search-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  gap: 20px !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

/* Card */
main#content a.kp-search-card,
main#content a.kp-search-card:link,
main#content a.kp-search-card:visited {
  display: block !important;
  position: relative !important;
  width: 100% !important;
  min-height: 140px !important;
  background: #FFFFFF !important;
  border: 1px solid #E2E8F0 !important;
  border-radius: 12px !important;
  padding: 22px 20px !important;
  box-sizing: border-box !important;
  color: #0F172A !important;
  text-decoration: none !important;
  transition: border-color .15s, box-shadow .15s, transform .15s !important;
  overflow: hidden !important;
}
main#content a.kp-search-card:hover {
  border-color: #0D9488 !important;
  box-shadow: 0 10px 30px rgba(13,148,136,.14) !important;
  transform: translateY(-2px) !important;
}
main#content a.kp-search-card h3,
main#content a.kp-search-card h3.kp-search-card-title {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: #0F172A !important;
  line-height: 1.25 !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
  display: block !important;
  position: static !important;
}
main#content a.kp-search-card .kp-search-card-meta {
  font-family: 'DM Sans', system-ui, sans-serif !important;
  font-size: 13px !important;
  color: #475569 !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
  display: block !important;
  position: static !important;
}
main#content a.kp-search-card .kp-search-card-meta strong {
  color: #0D9488 !important;
  font-weight: 700 !important;
}
main#content a.kp-search-card .kp-search-card-hook {
  font-family: 'DM Sans', system-ui, sans-serif !important;
  font-size: 14px !important;
  color: #64748B !important;
  line-height: 1.5 !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
  display: block !important;
  position: static !important;
}
main#content a.kp-search-card .kp-search-card-link {
  font-family: 'DM Sans', system-ui, sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #0D9488 !important;
  display: block !important;
  position: static !important;
}

/* Mobile */
@media (max-width: 768px) {
  main#content.kp-search-main {
    padding: 36px 20px 64px !important;
  }
  main#content .kp-search-title {
    font-size: 26px !important;
  }
  main#content .kp-search-grid {
    grid-template-columns: 1fr !important;
  }
}
	
	/* ── 28. PORTAL CTA TEXT WRAP FIX (Apr 2026) ─────────────────
   Allows headline text to wrap properly when county names
   like "Uasin Gishu" or "Trans Nzoia" make the line too long.
   ─────────────────────────────────────────────────────────── */

/* Targets the green CTA banner above the portal button */
.single-county [class*="portal-cta"],
.single-county [class*="cta-banner"],
.single-county .kp-portal-wrap > div:first-child {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  padding: 20px 24px !important;
  min-height: auto !important;
  line-height: 1.5 !important;
  gap: 14px !important;
}

/* Headline text inside the CTA */
.single-county [class*="portal-cta"] p,
.single-county [class*="portal-cta"] span,
.single-county [class*="cta-banner"] p,
.single-county [class*="cta-banner"] span {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  white-space: normal !important;
  position: relative !important;
  top: auto !important;
  left: auto !important;
}

/* Mobile */
@media (max-width: 640px) {
  .single-county [class*="portal-cta"],
  .single-county [class*="cta-banner"] {
    padding: 16px 18px !important;
  }
  .single-county [class*="portal-cta"] p,
  .single-county [class*="cta-banner"] p {
    font-size: 14px !important;
  }
}