/*
Theme Name: Starter Child Theme
Theme URI: https://developer.wordpress.org/themes/
Description: A starter child theme for Starter Theme
Author: Developer
Author URI: https://developer.wordpress.org/themes/
Template: starter
Version: 1.0.0
*/

/* =====================================================================
   SLOAN PROPERTIES — CHILD THEME OVERRIDES
   Last updated: Feb 11, 2026
   1. Global Color  2. Header/Nav  3. Heroes  4. Fonts
   5. Cards  6. Phone Button  7. Contact  8. Newsletter
   9. Buttons  10. Mobile
   ===================================================================== */

/* 1. GLOBAL — kill peach */
.elementor-kit-15 {
  --e-global-color-secondary: #FFFFFF !important;
}

/* 2. HEADER / NAV (post 57, container 7d35d6d4) */
.elementor-element-7d35d6d4 {
  border-bottom: none !important;
  --border-bottom-width: 0px !important;
}
.elementor-57 .elementor-nav-menu .elementor-item,
.elementor-57 .elementor-nav-menu a,
.elementor-57 .elementor-widget-nav-menu a,
.elementor-57 .elementor-widget-nav-menu span,
.elementor-element-7d35d6d4 a,
.elementor-element-7d35d6d4 span,
.elementor-element-7d35d6d4 .elementor-item,
.elementor-element-42e90608 a,
.elementor-element-42e90608 .elementor-item {
  font-family: 'Montserrat', sans-serif !important;
}
.elementor-menu-toggle {
  background-color: #FFFFFF !important;
}

/* 3. HERO SECTIONS — ALL PAGES UNIFIED */
/* Outer containers — structure */
.elementor-element-a1hero001,
.elementor-element-s1hero01,
.elementor-element-b1hero01,
.elementor-element-562f3a3d,
.elementor-element-50cd27e8,
.elementor-element-j1hero01 {
  --display: flex !important;
  --min-height: 70vh !important;
  --flex-direction: column !important;
  --justify-content: center !important;
  --align-items: center !important;
  --padding-top: 120px !important;
  --padding-bottom: 80px !important;
  --padding-left: 40px !important;
  --padding-right: 40px !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
  padding: 120px 40px 80px 40px !important;
}

/* Home — kill bg image + overlay, set navy */
.elementor-91 .elementor-element.elementor-element-a1hero001:not(.elementor-motion-effects-element-type-background),
.elementor-91 .elementor-element.elementor-element-a1hero001 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
  background-image: none !important;
  background-color: #1B2A4A !important;
}
.elementor-91 .elementor-element.elementor-element-a1hero001::before,
.elementor-91 .elementor-element.elementor-element-a1hero001 > .elementor-background-overlay,
.elementor-91 .elementor-element.elementor-element-a1hero001 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before {
  display: none !important;
}

/* Sellers — navy */
.elementor-417 .elementor-element.elementor-element-s1hero01:not(.elementor-motion-effects-element-type-background),
.elementor-417 .elementor-element.elementor-element-s1hero01 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
  background-color: #1B2A4A !important;
}
/* Buyers — navy */
.elementor-418 .elementor-element.elementor-element-b1hero01:not(.elementor-motion-effects-element-type-background),
.elementor-418 .elementor-element.elementor-element-b1hero01 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
  background-color: #1B2A4A !important;
}
/* About — navy */
.elementor-72 .elementor-element.elementor-element-562f3a3d:not(.elementor-motion-effects-element-type-background),
.elementor-72 .elementor-element.elementor-element-562f3a3d > .elementor-motion-effects-container > .elementor-motion-effects-layer {
  background-color: #1B2A4A !important;
}
/* Contact — navy */
.elementor-62 .elementor-element.elementor-element-50cd27e8:not(.elementor-motion-effects-element-type-background),
.elementor-62 .elementor-element.elementor-element-50cd27e8 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
  background-color: #1B2A4A !important;
}
/* Join — navy */
.elementor-419 .elementor-element.elementor-element-j1hero01:not(.elementor-motion-effects-element-type-background),
.elementor-419 .elementor-element.elementor-element-j1hero01 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
  background-color: #1B2A4A !important;
}

/* Inner hero containers — column + centered, max-width 900px */
.elementor-element-a1heroinn > .e-con-inner,
.elementor-element-s1inn01, .elementor-element-s1inn01 > .e-con-inner,
.elementor-element-b1inn01, .elementor-element-b1inn01 > .e-con-inner,
.elementor-element-3a200d04, .elementor-element-3a200d04 > .e-con-inner,
.elementor-element-afe5d33, .elementor-element-afe5d33 > .e-con-inner,
.elementor-element-j1inn01, .elementor-element-j1inn01 > .e-con-inner {
  --flex-direction: column !important;
  --align-items: center !important;
  --content-width: 900px !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  max-width: 900px !important;
  margin: 0 auto !important;
  border: none !important;
}
.elementor-element-3a200d04 {
  border: none !important;
  --border-style: none !important;
}

/* Hero text — white, centered */
.elementor-element-a1hero001 h1, .elementor-element-a1hero001 h2, .elementor-element-a1hero001 h3, .elementor-element-a1hero001 p,
.elementor-element-s1hero01 h1, .elementor-element-s1hero01 h2, .elementor-element-s1hero01 h3, .elementor-element-s1hero01 p,
.elementor-element-b1hero01 h1, .elementor-element-b1hero01 h2, .elementor-element-b1hero01 h3, .elementor-element-b1hero01 p,
.elementor-element-562f3a3d h1, .elementor-element-562f3a3d h2, .elementor-element-562f3a3d h3, .elementor-element-562f3a3d p,
.elementor-element-50cd27e8 h1, .elementor-element-50cd27e8 h2, .elementor-element-50cd27e8 h3, .elementor-element-50cd27e8 p,
.elementor-element-j1hero01 h1, .elementor-element-j1hero01 h2, .elementor-element-j1hero01 h3, .elementor-element-j1hero01 p {
  color: #FFFFFF !important;
  text-align: center !important;
}

/* Hero headings — Playfair Display */
.elementor-element-a1hero001 .elementor-heading-title,
.elementor-element-s1hero01 .elementor-heading-title,
.elementor-element-b1hero01 .elementor-heading-title,
.elementor-element-562f3a3d .elementor-heading-title,
.elementor-element-50cd27e8 .elementor-heading-title,
.elementor-element-j1hero01 .elementor-heading-title {
  font-family: 'Playfair Display', serif !important;
  font-weight: 700 !important;
  line-height: 1.2em !important;
  color: #FFFFFF !important;
}

/* Hero body text — Source Sans 3 */
.elementor-element-a1hero001 .elementor-widget-text-editor p,
.elementor-element-s1hero01 .elementor-widget-text-editor p,
.elementor-element-b1hero01 .elementor-widget-text-editor p,
.elementor-element-562f3a3d .elementor-widget-text-editor p,
.elementor-element-50cd27e8 .elementor-widget-text-editor p,
.elementor-element-j1hero01 .elementor-widget-text-editor p {
  font-family: 'Source Sans 3', sans-serif !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  line-height: 1.6em !important;
  color: rgba(255,255,255,0.85) !important;
  text-align: center !important;
}

/* Hero gold subtitle */
.elementor-element-a1hero001 .elementor-widget-text-editor p:first-child,
.elementor-element-562f3a3d .elementor-widget-text-editor p:first-child,
.elementor-element-50cd27e8 .elementor-widget-text-editor p:first-child,
.elementor-element-j1hero01 .elementor-widget-text-editor p:first-child {
  color: #C8A456 !important;
  text-transform: uppercase !important;
  letter-spacing: 3px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
}

/* Hero widget containers — full width + centered */
.elementor-element-a1hero001 .elementor-widget-text-editor,
.elementor-element-s1hero01 .elementor-widget-text-editor,
.elementor-element-b1hero01 .elementor-widget-text-editor,
.elementor-element-562f3a3d .elementor-widget-text-editor,
.elementor-element-50cd27e8 .elementor-widget-text-editor,
.elementor-element-j1hero01 .elementor-widget-text-editor,
.elementor-element-562f3a3d .elementor-widget-container,
.elementor-element-50cd27e8 .elementor-widget-container,
.elementor-element-j1hero01 .elementor-widget-container {
  text-align: center !important;
  width: 100% !important;
}

/* 4. PAGE-LEVEL FONT OVERRIDES (About 72, Contact 62, Join 419) */
/* Headings -> Playfair Display */
.elementor-72 .elementor-widget-heading .elementor-heading-title,
.elementor-72 h1, .elementor-72 h2, .elementor-72 h3,
.elementor-72 h4, .elementor-72 h5, .elementor-72 h6,
.elementor-62 .elementor-widget-heading .elementor-heading-title,
.elementor-62 h1, .elementor-62 h2, .elementor-62 h3,
.elementor-62 h4, .elementor-62 h5, .elementor-62 h6,
.elementor-419 .elementor-widget-heading .elementor-heading-title,
.elementor-419 h1, .elementor-419 h2, .elementor-419 h3,
.elementor-419 h4, .elementor-419 h5, .elementor-419 h6 {
  font-family: 'Playfair Display', serif !important;
}

/* Body text -> Source Sans 3 */
.elementor-72 .elementor-widget-text-editor p,
.elementor-72 .elementor-widget-text-editor span,
.elementor-72 .elementor-widget-text-editor li,
.elementor-72 .elementor-widget-text-editor a,
.elementor-72 .elementor-text-editor,
.elementor-72 .elementor-icon-list-text,
.elementor-72 .elementor-icon-box-description,
.elementor-72 .elementor-icon-box-title,
.elementor-72 .elementor-tab-title,
.elementor-72 .elementor-tab-content,
.elementor-72 label, .elementor-72 input, .elementor-72 textarea,
.elementor-62 .elementor-widget-text-editor p,
.elementor-62 .elementor-widget-text-editor span,
.elementor-62 .elementor-widget-text-editor li,
.elementor-62 .elementor-widget-text-editor a,
.elementor-62 .elementor-text-editor,
.elementor-62 .elementor-icon-list-text,
.elementor-62 .elementor-icon-box-description,
.elementor-62 .elementor-icon-box-title,
.elementor-62 .elementor-tab-title,
.elementor-62 .elementor-tab-content,
.elementor-62 label, .elementor-62 input, .elementor-62 textarea,
.elementor-419 .elementor-widget-text-editor p,
.elementor-419 .elementor-widget-text-editor span,
.elementor-419 .elementor-widget-text-editor li,
.elementor-419 .elementor-widget-text-editor a,
.elementor-419 .elementor-text-editor,
.elementor-419 .elementor-icon-list-text,
.elementor-419 .elementor-icon-box-description,
.elementor-419 label, .elementor-419 input, .elementor-419 textarea {
  font-family: 'Source Sans 3', sans-serif !important;
}

/* RE-PROTECT NAV — MUST come after page font overrides */
.elementor-57 a, .elementor-57 span,
.elementor-57 .elementor-item,
.elementor-57 .elementor-nav-menu a,
.elementor-57 .elementor-widget-nav-menu a,
.elementor-57 .elementor-widget-nav-menu span,
.elementor-element-42e90608 a,
.elementor-element-42e90608 span,
.elementor-element-42e90608 .elementor-item {
  font-family: 'Montserrat', sans-serif !important;
}

/* 5. SELLERS/BUYERS CARD LAYOUT */
.elementor-element-s3r1 > .e-con-inner > .e-con,
.elementor-element-s3r2 > .e-con-inner > .e-con,
.elementor-element-b3r1 > .e-con-inner > .e-con,
.elementor-element-b3r2 > .e-con-inner > .e-con {
  flex-shrink: 1 !important;
  flex-basis: 50% !important;
  max-width: 50% !important;
}

/* 6. PHONE BUTTON (header) */
.elementor-element-6443ad29 .elementor-button {
  font-size: 15px !important;
  padding: 12px 18px !important;
  border-radius: 6px !important;
}
.elementor-element-6443ad29 .elementor-button:hover {
  background-color: #C8A456 !important;
  color: #FFFFFF !important;
}

/* 7. CONTACT PAGE */
.elementor-element-55d3ba35 p,
.elementor-element-55d3ba35 a {
  color: #C8A456 !important;
}
.elementor-element-55d3ba35,
.elementor-element-55d3ba35 .elementor-widget-container {
  text-align: center !important;
}

/* 8. NEWSLETTER */
.elementor-element-2597be1 {
  background-color: #FFFFFF !important;
}

/* 9. GLOBAL BUTTON STYLING */
/* Normal: navy bg, gold text/icons, rounded, shadow */
.elementor-button,
.elementor-widget-button .elementor-button,
a.elementor-button,
.elementor-button-wrapper .elementor-button {
  background-color: #1B2A4A !important;
  color: #C8A456 !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
  border: 2px solid #1B2A4A !important;
  transition: all 0.3s ease !important;
}
.elementor-button .elementor-button-text,
.elementor-button .elementor-button-icon,
.elementor-button .elementor-button-icon i,
.elementor-button .elementor-button-icon svg,
.elementor-button span {
  color: #C8A456 !important;
  fill: #C8A456 !important;
  transition: all 0.3s ease !important;
}

/* Hover/Active: gold bg, navy text/icons */
.elementor-button:hover,
.elementor-widget-button .elementor-button:hover,
a.elementor-button:hover,
.elementor-button:active, .elementor-button:focus {
  background-color: #C8A456 !important;
  color: #1B2A4A !important;
  border-color: #C8A456 !important;
  box-shadow: 0 6px 16px rgba(0,0,0,0.2) !important;
}
.elementor-button:hover .elementor-button-text,
.elementor-button:hover .elementor-button-icon,
.elementor-button:hover .elementor-button-icon i,
.elementor-button:hover .elementor-button-icon svg,
.elementor-button:hover span,
.elementor-button:active .elementor-button-text,
.elementor-button:active span {
  color: #1B2A4A !important;
  fill: #1B2A4A !important;
}

/* Phone button exception — outlined style */
.elementor-element-6443ad29 .elementor-button {
  background-color: #1B2A4A !important;
  border: 2px solid #1B2A4A !important;
  color: #C8A456 !important;
  box-shadow: none !important;
}
.elementor-element-6443ad29 .elementor-button span {
  color: #C8A456 !important;
}
.elementor-element-6443ad29 .elementor-button:hover {
  background-color: #C8A456 !important;
  border-color: #C8A456 !important;
  color: #FFFFFF !important;
}
.elementor-element-6443ad29 .elementor-button:hover span {
  color: #FFFFFF !important;
}

/* 10. MOBILE */
@media (max-width: 767px) {
  .elementor-element-a1hero001,
  .elementor-element-s1hero01,
  .elementor-element-b1hero01,
  .elementor-element-562f3a3d,
  .elementor-element-50cd27e8,
  .elementor-element-j1hero01 {
    --padding-top: 100px !important;
    --padding-bottom: 60px !important;
    --padding-left: 20px !important;
    --padding-right: 20px !important;
    padding: 100px 20px 60px 20px !important;
  }
  .elementor-element-s3r1 > .e-con-inner > .e-con,
  .elementor-element-s3r2 > .e-con-inner > .e-con,
  .elementor-element-b3r1 > .e-con-inner > .e-con,
  .elementor-element-b3r2 > .e-con-inner > .e-con {
    flex-basis: 100% !important;
    max-width: 100% !important;
  }
}

/* =====================================================================
   11. DARK SECTION FIX — #0a1628 → #1B2A4A everywhere
   These body sections use near-black instead of brand navy
   ===================================================================== */

/* Home dark sections */
.elementor-91 .elementor-element.elementor-element-a2bt1:not(.elementor-motion-effects-element-type-background),
.elementor-91 .elementor-element.elementor-element-a2bt1 > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.elementor-91 .elementor-element.elementor-element-a4val01:not(.elementor-motion-effects-element-type-background),
.elementor-91 .elementor-element.elementor-element-a4val01 > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.elementor-91 .elementor-element.elementor-element-a5b1:not(.elementor-motion-effects-element-type-background),
.elementor-91 .elementor-element.elementor-element-a5b1 > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.elementor-91 .elementor-element.elementor-element-a5b2:not(.elementor-motion-effects-element-type-background),
.elementor-91 .elementor-element.elementor-element-a5b2 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
  background-color: #1B2A4A !important;
}

/* Sellers dark sections */
.elementor-417 .elementor-element.elementor-element-s4b1:not(.elementor-motion-effects-element-type-background),
.elementor-417 .elementor-element.elementor-element-s4b1 > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.elementor-417 .elementor-element.elementor-element-s4b2:not(.elementor-motion-effects-element-type-background),
.elementor-417 .elementor-element.elementor-element-s4b2 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
  background-color: #1B2A4A !important;
}

/* Buyers dark sections */
.elementor-418 .elementor-element.elementor-element-b4b1:not(.elementor-motion-effects-element-type-background),
.elementor-418 .elementor-element.elementor-element-b4b1 > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.elementor-418 .elementor-element.elementor-element-b4b2:not(.elementor-motion-effects-element-type-background),
.elementor-418 .elementor-element.elementor-element-b4b2 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
  background-color: #1B2A4A !important;
}

/* Join dark section */
.elementor-419 .elementor-element.elementor-element-j3form01:not(.elementor-motion-effects-element-type-background),
.elementor-419 .elementor-element.elementor-element-j3form01 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
  background-color: #F5F5F5 !important;
}

/* =====================================================================
   12. HERO GOLD LABELS — match Sellers s1lb01 pattern
   About (523c98cb), Contact (47577666) need explicit gold styling.
   Join (j1lb01) already follows Sellers naming but uses Kit variables.
   Pattern: Source Sans 3, 14px, 600, uppercase, 3px spacing, gold
   ===================================================================== */

/* Gold label headings — About, Contact, Join */
.elementor-72 .elementor-element.elementor-element-523c98cb .elementor-heading-title,
.elementor-62 .elementor-element.elementor-element-47577666 .elementor-heading-title,
.elementor-419 .elementor-element.elementor-element-j1lb01 .elementor-heading-title {
  font-family: 'Source Sans 3', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 3px !important;
  color: #c9a96e !important;
  text-align: center !important;
}
.elementor-element-523c98cb,
.elementor-element-47577666,
.elementor-element-j1lb01 {
  text-align: center !important;
  width: 100% !important;
}

/* Main headings — force center on About/Contact */
.elementor-72 .elementor-element.elementor-element-556fe089 .elementor-heading-title,
.elementor-62 .elementor-element.elementor-element-cb16d7b .elementor-heading-title,
.elementor-419 .elementor-element.elementor-element-j1hd01 .elementor-heading-title {
  font-family: 'Playfair Display', serif !important;
  font-size: 56px !important;
  font-weight: 700 !important;
  line-height: 1.2em !important;
  color: #FFFFFF !important;
  text-align: center !important;
}
.elementor-element-556fe089,
.elementor-element-cb16d7b,
.elementor-element-j1hd01 {
  text-align: center !important;
  width: 100% !important;
}

/* =====================================================================
   13. ABOUT/CONTACT HERO TEXT CONTAINERS — fix alignment + borders
   About 237162bd has borders and left padding. Contact 7eb91ff1 similar.
   ===================================================================== */

/* About text editor container — remove borders, center */
.elementor-element-237162bd {
  border: none !important;
  --border-style: none !important;
  --border-top-width: 0px !important;
  --border-right-width: 0px !important;
  --border-bottom-width: 0px !important;
  --border-left-width: 0px !important;
  --padding-left: 0% !important;
  --padding-right: 0% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  --justify-content: center !important;
  justify-content: center !important;
  text-align: center !important;
  width: 100% !important;
}
.elementor-element-237162bd .elementor-widget-container {
  text-align: center !important;
}

/* Contact text editor container */
.elementor-element-7eb91ff1 {
  border: none !important;
  --border-style: none !important;
  --border-top-width: 0px !important;
  --border-right-width: 0px !important;
  --border-bottom-width: 0px !important;
  --border-left-width: 0px !important;
  --padding-left: 0% !important;
  --padding-right: 0% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  --justify-content: center !important;
  justify-content: center !important;
  text-align: center !important;
  width: 100% !important;
}
.elementor-element-7eb91ff1 .elementor-widget-container {
  text-align: center !important;
}

/* Subtitle text in About/Contact/Join heroes — match Sellers s1tx01 */
.elementor-element-237162bd .elementor-widget-text-editor p,
.elementor-element-7eb91ff1 .elementor-widget-text-editor p {
  font-family: 'Source Sans 3', sans-serif !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  line-height: 1.6em !important;
  color: rgba(255,255,255,0.85) !important;
  text-align: center !important;
}

/* =====================================================================
   14. CARD ALIGNMENT FIX — correct selectors
   Previous rule targeted .e-con-inner > .e-con which doesn't exist.
   Cards are direct children of row containers.
   Sellers: s3r1→s3s1,s3s2 | s3r2→s3s3,s3s4
   Buyers:  b3r1→b3s1,b3s2 | b3r2→b3s3,b3s4
   ===================================================================== */

/* Desktop: 2-column, equal width, allow shrink */
.elementor-element-s3s1, .elementor-element-s3s2,
.elementor-element-s3s3, .elementor-element-s3s4,
.elementor-element-b3s1, .elementor-element-b3s2,
.elementor-element-b3s3, .elementor-element-b3s4 {
  --flex-grow: 1 !important;
  --flex-shrink: 1 !important;
  flex-grow: 1 !important;
  flex-shrink: 1 !important;
  flex-basis: 50% !important;
  max-width: 50% !important;
  min-width: 0 !important;
}

/* High-specificity override for the .elementor-element inline flex */
.elementor-417 .elementor-element.elementor-element-s3s1.elementor-element,
.elementor-417 .elementor-element.elementor-element-s3s2.elementor-element,
.elementor-417 .elementor-element.elementor-element-s3s3.elementor-element,
.elementor-417 .elementor-element.elementor-element-s3s4.elementor-element,
.elementor-418 .elementor-element.elementor-element-b3s1.elementor-element,
.elementor-418 .elementor-element.elementor-element-b3s2.elementor-element,
.elementor-418 .elementor-element.elementor-element-b3s3.elementor-element,
.elementor-418 .elementor-element.elementor-element-b3s4.elementor-element {
  --flex-grow: 1 !important;
  --flex-shrink: 1 !important;
}

/* Mobile: single column, full width */
@media (max-width: 767px) {
  .elementor-element-s3s1, .elementor-element-s3s2,
  .elementor-element-s3s3, .elementor-element-s3s4,
  .elementor-element-b3s1, .elementor-element-b3s2,
  .elementor-element-b3s3, .elementor-element-b3s4 {
    flex-basis: 100% !important;
    max-width: 100% !important;
  }
}

.elementor-element-j4emb01 .calendly-inline-widget iframe {
  height: 400px !important;
}

/* ===== 16. Homepage icons — gold on dark sections ===== */
.elementor-element-a4v1 .elementor-icon svg,
.elementor-element-a4v2 .elementor-icon svg,
.elementor-element-a4v3 .elementor-icon svg {
  fill: #C8A456 !important;
  color: #C8A456 !important;
}
.elementor-element-a4v1 .elementor-icon,
.elementor-element-a4v2 .elementor-icon,
.elementor-element-a4v3 .elementor-icon {
  color: #C8A456 !important;
}

/* ===== 17. Hero + section gold labels — Montserrat ===== */
/* Homepage hero label */
.elementor-element-a1sub1 .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
}
/* Sellers hero label */
.elementor-element-s1lb01 .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
}
/* Buyers hero label */
.elementor-element-b1lb01 .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
}
/* About hero label */
.elementor-element-523c98cb .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
}
/* Contact hero label */
.elementor-element-47577666 .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
}
/* Join hero label */
.elementor-element-j1lb01 .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
}


/* ===== 15c. Calendly — tighter iframe + overflow clip ===== */
.elementor-element-j4emb01 .calendly-inline-widget {
  max-height: 380px !important;
  overflow: hidden !important;
}
.elementor-element-j4emb01 .calendly-inline-widget iframe {
  height: 370px !important;
}

/* ===== 15c. Calendly — tighter iframe ===== */
.elementor-element-j4emb01 .calendly-inline-widget {
  height: auto !important;
  min-height: 300px !important;
  max-height: 350px !important;
  overflow: hidden !important;
}
.elementor-element-j4emb01 .calendly-inline-widget iframe {
  height: 350px !important;
}

/* ===== 15d. Calendly section — reduce container padding ===== */
.elementor-419 .elementor-element.elementor-element-j4cal01 .e-con-inner {
  padding-top: 40px !important;
  padding-bottom: 20px !important;
}

/* ===== 18. Hero subtitles — Montserrat gold (all 4 pages) ===== */
.elementor-element-a1tag1 .elementor-heading-title,
.elementor-element-s1tx01 .elementor-heading-title,
.elementor-element-b1tx01 .elementor-heading-title,
.elementor-element-j1tx01 .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  color: #C8A456 !important;
}

/* ===== 19. Hero subtitles — remove bold ===== */
.elementor-element-a1tag1 .elementor-heading-title,
.elementor-element-s1tx01 .elementor-heading-title,
.elementor-element-b1tx01 .elementor-heading-title,
.elementor-element-j1tx01 .elementor-heading-title {
  font-weight: 400 !important;
}

/* ===== 20. Navy button bar containers — rounded corners ===== */
.elementor-element.elementor-element-a2bt1,
.elementor-element.elementor-element-s4b1,
.elementor-element.elementor-element-s4b2,
.elementor-element.elementor-element-b4b1,
.elementor-element.elementor-element-b4b2 {
  border-radius: 8px !important;
  overflow: hidden !important;
}

/* ===== 21. Contact page — email + hours to gold ===== */
.elementor-element-5936e9b p,
.elementor-element-5936e9b a,
.elementor-element-7e8717f p,
.elementor-element-7e8717f span {
  color: #C8A456 !important;
}

/* ===== 19. Hero subtitles — remove bold ===== */
.elementor-element-a1tag1 .elementor-heading-title,
.elementor-element-s1tx01 .elementor-heading-title,
.elementor-element-b1tx01 .elementor-heading-title,
.elementor-element-j1tx01 .elementor-heading-title {
  font-weight: 400 !important;
}

/* ===== 20. CTA navy bars — rounded corners ===== */
.elementor-element.elementor-element-a2bt1,
.elementor-element.elementor-element-s4b1,
.elementor-element.elementor-element-s4b2,
.elementor-element.elementor-element-b4b1,
.elementor-element.elementor-element-b4b2 {
  border-radius: 8px !important;
  overflow: hidden !important;
}

/* ===== 21. Contact page — email + hours to gold ===== */
.elementor-element-5936e9b p,
.elementor-element-5936e9b a,
.elementor-element-7e8717f p,
.elementor-element-7e8717f span {
  color: #C8A456 !important;
}

/* ===== 20b. Homepage bottom CTA bars — rounded ===== */
.elementor-element.elementor-element-a5b1,
.elementor-element.elementor-element-a5b2 {
  border-radius: 8px !important;
  overflow: hidden !important;
}

/* ===== 23b. Contact page — center ALL three info columns ===== */
.elementor-62 .elementor-element-4b784174 .elementor-widget-container,
.elementor-62 .elementor-element-4b784174 .elementor-heading-title,
.elementor-62 .elementor-element-4b784174 p,
.elementor-62 .elementor-element-4b784174 a,
.elementor-62 .elementor-element-4b784174 span {
  text-align: center !important;
}

/* ===== 22. Mobile hero — reduce blank space on Contact + About ===== */
@media (max-width: 1024px) {
  .elementor-62 .elementor-element.elementor-element-50cd27e8,
  .elementor-72 .elementor-element.elementor-element-562f3a3d {
    --min-height: auto !important;
    min-height: auto !important;
    height: auto !important;
  }
}
@media (max-width: 767px) {
  .elementor-62 .elementor-element.elementor-element-50cd27e8,
  .elementor-72 .elementor-element.elementor-element-562f3a3d {
    --min-height: auto !important;
    min-height: auto !important;
    height: auto !important;
    --padding-top: 0px !important;
    --padding-bottom: 0px !important;
    --padding-left: 20px !important;
    --padding-right: 20px !important;
    padding: 0 !important;
  }
  .elementor-62 .elementor-element.elementor-element-50cd27e8 > .e-con-inner,
  .elementor-72 .elementor-element.elementor-element-562f3a3d > .e-con-inner {
    padding: 40px 0 20px 0 !important;
    --padding-top: 40px !important;
    --padding-bottom: 20px !important;
    min-height: auto !important;
    height: auto !important;
  }
}
/* ===== 23c. Contact page — Phone column stretch fix ===== */
.elementor-62 .elementor-element.elementor-element-63cecc10 {
  --align-items: stretch !important;
  align-items: stretch !important;
}

/* ===== 25. Join Our Team — form submit button gold text ===== */
.elementor-419 .elementor-element-j3form01 .elementor-button {
  color: #C8A456 !important;
}
.elementor-419 .elementor-element-j3form01 .elementor-button span,
.elementor-419 .elementor-element-j3form01 .elementor-button .elementor-button-text,
.elementor-419 .elementor-element-j3form01 .elementor-button .elementor-button-content-wrapper {
  color: #C8A456 !important;
}
.elementor-419 .elementor-element-j3form01 .elementor-button:hover {
  background-color: #C8A456 !important;
  color: #1B2A4A !important;
}

.elementor-419 .elementor-element-j3form01 .elementor-button:hover span,
.elementor-419 .elementor-element-j3form01 .elementor-button:hover .elementor-button-text,
.elementor-419 .elementor-element-j3form01 .elementor-button:hover .elementor-button-content-wrapper {
  color: #1B2A4A !important;
}
/* ===== 26. Join Our Team — form section text colors for light bg ===== */
.elementor-419 .elementor-element-j3form01 h1,
.elementor-419 .elementor-element-j3form01 h2,
.elementor-419 .elementor-element-j3form01 h3,
.elementor-419 .elementor-element-j3form01 .elementor-heading-title {
  color: #FFFFFF !important;
}
.elementor-419 .elementor-element-j3form01 p,
.elementor-419 .elementor-element-j3form01 span,
.elementor-419 .elementor-element-j3form01 .elementor-text-editor {
  color: rgba(255,255,255,0.85) !important;
}

/* ===== 26. Mobile hero spacing fix — About + Contact inner containers ===== */
/* Elementor sets --padding-top: 60% on mobile for these inner containers, creating massive blank space above text */
@media (max-width: 767px) {
  .elementor-72 .elementor-element.elementor-element-3a200d04,
  .elementor-62 .elementor-element.elementor-element-afe5d33 {
    --padding-top: 40px !important;
    --padding-bottom: 20px !important;
    --padding-left: 20px !important;
    --padding-right: 20px !important;
    padding: 40px 20px 20px 20px !important;
  }
}

/* ===== 27. About + Contact hero — zero inner container padding (DESKTOP only) ===== */
/* Sellers inner (s1inn01) naturally has 0px inner padding from Elementor.
   About (3a200d04) and Contact (afe5d33) inner containers get 120px/80px
   from Elementor inline styles, doubling the outer container's padding.
   This zeroes the inner to match Sellers behavior. */
@media (min-width: 768px) {
  .elementor-72 .elementor-element.elementor-element-562f3a3d > .e-con-inner,
  .elementor-62 .elementor-element.elementor-element-50cd27e8 > .e-con-inner {
    --padding-top: 0px !important;
    --padding-bottom: 0px !important;
    --padding-left: 0px !important;
    --padding-right: 0px !important;
    padding: 0 !important;
  }
}

/* ===== 28. About + Contact hero text fixes ===== */
/* Fix 1: Main headings — remove forced uppercase (match Sellers title case) */
.elementor-72 .elementor-element.elementor-element-556fe089 .elementor-heading-title,
.elementor-62 .elementor-element.elementor-element-cb16d7b .elementor-heading-title {
  text-transform: none !important;
}

/* Fix 2: Subtitle text — override the label styling from Section 3 */
/* These are paragraph subtitles, not labels. Match Sellers subtitle: 18px Montserrat gold, normal case, 400 weight */
.elementor-element-562f3a3d .elementor-widget-text-editor p:first-child,
.elementor-element-50cd27e8 .elementor-widget-text-editor p:first-child {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  color: #C8A456 !important;
}

/* Fix 3: Gold labels — Montserrat with matching specificity to beat Section 12 */
.elementor-72 .elementor-element.elementor-element-523c98cb .elementor-heading-title,
.elementor-62 .elementor-element.elementor-element-47577666 .elementor-heading-title,
.elementor-419 .elementor-element.elementor-element-j1lb01 .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
}

/* ===== 29. About + Contact hero bg fix (rebuilt pages, new data-ids) ===== */
.elementor-element.elementor-element-x89ckl5,
.elementor-element.elementor-element-104fsf2 {
  background-color: #1B2A4A !important;
}

/* ===== 30. FAQ Page (post 445) ===== */

/* Hero */
.page-id-445 .faq-hero {
  background-color: #1B2A4A;
  min-height: 50vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 120px 40px 80px;
  text-align: center;
}
.page-id-445 .faq-hero-inner {
  max-width: 900px;
  margin: 0 auto;
}
.page-id-445 .faq-gold-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #C8A456;
  margin-bottom: 20px;
}
.page-id-445 .faq-main-heading {
  font-family: 'Playfair Display', serif;
  font-size: 56px;
  font-weight: 700;
  line-height: 1.2em;
  color: #FFFFFF;
  margin-bottom: 20px;
}
.page-id-445 .faq-subtitle {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 400;
  color: #C8A456;
  max-width: 700px;
  margin: 0 auto;
}

/* Content area */
.page-id-445 .faq-content {
  max-width: 900px;
  margin: 0 auto;
  padding: 60px 40px 80px;
}

/* Section headings */
.page-id-445 .faq-section {
  margin-bottom: 50px;
}
.page-id-445 .faq-section-heading {
  font-family: 'Playfair Display', serif;
  font-size: 36px;
  font-weight: 700;
  color: #1B2A4A;
  margin-bottom: 30px;
  padding-bottom: 15px;
  border-bottom: 2px solid #C8A456;
}

/* Accordion items */
.page-id-445 .faq-item {
  border-bottom: 1px solid #e0e0e0;
  margin-bottom: 0;
}
.page-id-445 .faq-item summary {
  font-family: 'Source Sans 3', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: #1B2A4A;
  padding: 20px 40px 20px 0;
  cursor: pointer;
  list-style: none;
  position: relative;
  line-height: 1.4;
}
.page-id-445 .faq-item summary::-webkit-details-marker {
  display: none;
}
.page-id-445 .faq-item summary::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 24px;
  font-weight: 300;
  color: #C8A456;
  transition: transform 0.2s ease;
}
.page-id-445 .faq-item[open] summary::after {
  content: '−';
}
.page-id-445 .faq-item summary:hover {
  color: #C8A456;
}
.page-id-445 .faq-answer {
  font-family: 'Source Sans 3', sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.7;
  color: #555;
  padding: 0 0 20px 0;
}
.page-id-445 .faq-answer a {
  color: #C8A456;
  text-decoration: underline;
}
.page-id-445 .faq-answer a:hover {
  color: #1B2A4A;
}

/* Mobile */
@media (max-width: 767px) {
  .page-id-445 .faq-hero {
    padding: 100px 20px 60px;
    min-height: auto;
  }
  .page-id-445 .faq-main-heading {
    font-size: 36px;
  }
  .page-id-445 .faq-subtitle {
    font-size: 16px;
  }
  .page-id-445 .faq-content {
    padding: 40px 20px 60px;
  }
  .page-id-445 .faq-section-heading {
    font-size: 28px;
  }
  .page-id-445 .faq-item summary {
    font-size: 16px;
    padding: 16px 30px 16px 0;
  }
}

/* ===== SECTION 22: Single Blog Post Cleanup ===== */
/* Hide property-specific sections on blog posts */
body.single-post .elementor-element-77ce0f0e,
body.single-post .elementor-element-ae44146,
body.single-post .elementor-element-59c3263b,
body.single-post .elementor-element-12d3088a,
body.single-post .elementor-element-3b5c7f6 {
    display: none !important;
}

/* Blog post content area — add top padding and max-width */
body.single-post .elementor-element-6e789a3e {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
    max-width: 800px !important;
    margin: 0 auto !important;
}

/* Blog post headings */
body.single-post .elementor-element-6e789a3e h2,
body.single-post .elementor-element-6e789a3e h3,
body.single-post .elementor-element-6e789a3e h4 {
    font-family: 'Playfair Display', serif !important;
    color: #1B2A4A !important;
}

body.single-post .elementor-element-6e789a3e h2 {
    font-size: 32px !important;
    margin-bottom: 20px !important;
}

body.single-post .elementor-element-6e789a3e h3 {
    font-size: 26px !important;
    margin-bottom: 16px !important;
}

/* Blog post body text */
body.single-post .elementor-element-6e789a3e p,
body.single-post .elementor-element-6e789a3e li {
    font-family: 'Source Sans 3', sans-serif !important;
    font-size: 17px !important;
    line-height: 1.7 !important;
    color: #333 !important;
}

/* Blog post links */
body.single-post .elementor-element-6e789a3e a {
    color: #C8A456 !important;
    text-decoration: underline !important;
}

body.single-post .elementor-element-6e789a3e a:hover {
    color: #1B2A4A !important;
}

/* ===== SECTION 22b: Blog Post Title Header ===== */
/* Style the post title that Houzez renders in content */
body.single-post .entry-title,
body.single-post .elementor-element-6e789a3e > .e-con-inner > .e-con:first-child h2:first-child {
    font-family: 'Playfair Display', serif !important;
    font-size: 42px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    color: #1B2A4A !important;
    margin-bottom: 30px !important;
    padding-bottom: 20px !important;
    border-bottom: 2px solid #C8A456 !important;
}

/* Blog post meta (date, category, author) */
body.single-post .blog-post-meta,
body.single-post .post-meta {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    color: #888 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    margin-bottom: 30px !important;
}

/* ===== SECTION 22c: Blog Grid Page Styling ===== */
/* Blog grid cards - consistent font treatment */
body.page-id-448 .blog-wrap h2 a,
body.page-id-448 .blog-wrap .entry-title a {
    font-family: 'Playfair Display', serif !important;
    color: #1B2A4A !important;
}

body.page-id-448 .blog-wrap p {
    font-family: 'Source Sans 3', sans-serif !important;
}

body.page-id-448 .blog-wrap .blog-masonry-post .category-label a {
    color: #C8A456 !important;
}

/* Mobile adjustments for single blog posts */
@media (max-width: 768px) {
    body.single-post .elementor-element-6e789a3e {
        padding-top: 30px !important;
        padding-bottom: 30px !important;
        padding-left: 20px !important;
        padding-right: 20px !important;
    }
    body.single-post .entry-title,
    body.single-post .elementor-element-6e789a3e > .e-con-inner > .e-con:first-child h2:first-child {
        font-size: 28px !important;
    }
    body.single-post .elementor-element-6e789a3e h2 {
        font-size: 24px !important;
    }
    body.single-post .elementor-element-6e789a3e p,
    body.single-post .elementor-element-6e789a3e li {
        font-size: 16px !important;
    }
}

/* ===== SECTION 23: Blog Category Archive Template ===== */
.sloan-blog-archive {
    padding: 130px 0 60px;
}
.sloan-blog-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}
.sloan-breadcrumb {
    padding: 20px 0;
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    color: #888;
}
.sloan-breadcrumb a {
    color: #888;
    text-decoration: none;
}
.sloan-breadcrumb a:hover {
    color: #C8A456;
}
.sloan-archive-title {
    font-family: 'Playfair Display', serif;
    font-size: 42px;
    font-weight: 700;
    color: #1B2A4A;
    margin: 10px 0 15px;
}
.sloan-archive-desc {
    font-family: 'Source Sans 3', sans-serif;
    font-size: 17px;
    color: #666;
    margin-bottom: 40px;
    max-width: 700px;
}
.sloan-blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin-top: 30px;
}
.sloan-blog-card {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 8px;
    overflow: hidden;
    transition: box-shadow 0.3s ease;
}
.sloan-blog-card:hover {
    box-shadow: 0 8px 24px rgba(0,0,0,0.1);
}
.sloan-card-image img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    display: block;
}
.sloan-card-placeholder .sloan-placeholder-inner {
    width: 100%;
    height: 200px;
    background: linear-gradient(135deg, #1B2A4A 0%, #2a3f6b 100%);
}
.sloan-card-body {
    padding: 20px;
}
.sloan-card-meta {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 10px;
}
.sloan-card-title {
    font-family: 'Playfair Display', serif;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 12px;
}
.sloan-card-title a {
    color: #1B2A4A;
    text-decoration: none;
}
.sloan-card-title a:hover {
    color: #C8A456;
}
.sloan-card-excerpt {
    font-family: 'Source Sans 3', sans-serif;
    font-size: 15px;
    line-height: 1.6;
    color: #666;
    margin-bottom: 15px;
}
.sloan-read-more {
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    font-weight: 600;
    color: #C8A456;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.sloan-read-more:hover {
    color: #1B2A4A;
}
.sloan-pagination {
    margin-top: 50px;
    text-align: center;
}
.sloan-pagination .nav-links a,
.sloan-pagination .nav-links span {
    display: inline-block;
    padding: 8px 16px;
    margin: 0 4px;
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    border-radius: 6px;
}
.sloan-pagination .nav-links a {
    color: #1B2A4A;
    border: 1px solid #ddd;
    text-decoration: none;
}
.sloan-pagination .nav-links a:hover {
    background: #C8A456;
    color: #fff;
    border-color: #C8A456;
}
.sloan-pagination .nav-links .current {
    background: #1B2A4A;
    color: #fff;
    border: 1px solid #1B2A4A;
}

/* Mobile: blog grid */
@media (max-width: 768px) {
    .sloan-blog-grid {
        grid-template-columns: 1fr;
    }
    .sloan-archive-title {
        font-size: 28px;
    }
}
@media (min-width: 769px) and (max-width: 1024px) {
    .sloan-blog-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ===== SECTION 24: Blog Page Styling (Houzez PHP Templates) ===== */

/* --- 24a: Blog Grid Page (page-id-448) — Page Title Hero --- */
body.page-id-448 .page-title-wrap {
    background-color: #1B2A4A !important;
    padding: 140px 40px 60px !important;
    margin-bottom: 40px !important;
    text-align: center !important;
}
body.page-id-448 .page-title-wrap h1 {
    font-family: 'Playfair Display', serif !important;
    font-size: 48px !important;
    font-weight: 700 !important;
    color: #FFFFFF !important;
    margin: 0 !important;
}
body.page-id-448 .page-title-wrap .breadcrumb,
body.page-id-448 .page-title-wrap .breadcrumb a,
body.page-id-448 .page-title-wrap .breadcrumb li,
body.page-id-448 .page-title-wrap .breadcrumb-item+.breadcrumb-item::before {
    color: rgba(255,255,255,0.7) !important;
}
body.page-id-448 .page-title-wrap .breadcrumb a:hover {
    color: #C8A456 !important;
}

/* --- 24b: Blog Grid Cards — Fonts --- */
body.page-id-448 .blog-post-title,
body.page-id-448 .blog-post-title a {
    font-family: 'Playfair Display', serif !important;
    color: #1B2A4A !important;
}
body.page-id-448 .blog-post-body,
body.page-id-448 .blog-post-body p {
    font-family: 'Source Sans 3', 'Source Sans Pro', sans-serif !important;
    color: #555 !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
}
body.page-id-448 .blog-post-meta,
body.page-id-448 .blog-post-meta li,
body.page-id-448 .blog-post-author,
body.page-id-448 .blog-post-author span {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
}

/* --- 24c: Blog Grid Cards — Links & Colors --- */
body.page-id-448 .blog-post-meta a {
    color: #C8A456 !important;
}
body.page-id-448 .blog-post-meta a:hover {
    color: #1B2A4A !important;
}
body.page-id-448 .blog-post-link a {
    color: #C8A456 !important;
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    text-decoration: none !important;
}
body.page-id-448 .blog-post-link a:hover {
    color: #1B2A4A !important;
}

/* --- 24d: Blog Grid Cards — Visual Polish --- */
body.page-id-448 .blog-post-item {
    border-radius: 8px !important;
    overflow: hidden !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.08) !important;
    transition: box-shadow 0.3s ease, transform 0.3s ease !important;
    border: 1px solid #eee !important;
}
body.page-id-448 .blog-post-item:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,0.12) !important;
    transform: translateY(-2px) !important;
}
body.page-id-448 .blog-post-thumb {
    min-height: 200px !important;
    background-color: #1B2A4A !important;
}
body.page-id-448 .blog-post-thumb .image-wrap {
    min-height: 200px !important;
    display: block !important;
    background: linear-gradient(135deg, #1B2A4A 0%, #2d4470 100%) !important;
}

/* --- 24e: Single Post Page — Page Title Hero --- */
body.single-post .page-title-wrap {
    background-color: #1B2A4A !important;
    padding: 140px 40px 30px !important;
    margin-bottom: 0 !important;
}
body.single-post .page-title-wrap .breadcrumb,
body.single-post .page-title-wrap .breadcrumb a,
body.single-post .page-title-wrap .breadcrumb li,
body.single-post .page-title-wrap .breadcrumb-item+.breadcrumb-item::before {
    color: rgba(255,255,255,0.7) !important;
}
body.single-post .page-title-wrap .breadcrumb a:hover {
    color: #C8A456 !important;
}

/* --- 24f: Single Post — Title & Header --- */
body.single-post .post-header-wrap {
    padding: 30px 0 20px !important;
    border-bottom: 1px solid #eee !important;
    margin-bottom: 30px !important;
}
body.single-post .post-title-wrap h1 {
    font-family: 'Playfair Display', serif !important;
    font-size: 42px !important;
    font-weight: 700 !important;
    color: #1B2A4A !important;
    line-height: 1.2 !important;
    margin-bottom: 15px !important;
}

/* --- 24g: Single Post — Meta (date, category, comments) --- */
body.single-post .author-meta,
body.single-post .author-meta li,
body.single-post .author-meta a {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    color: #888 !important;
}
body.single-post .author-meta a {
    color: #C8A456 !important;
}
body.single-post .author-meta a:hover {
    color: #1B2A4A !important;
}

/* --- 24h: Single Post — Content Body --- */
body.single-post .post-content-wrap {
    max-width: 100% !important;
}
body.single-post .post-content-wrap h2 {
    font-family: 'Playfair Display', serif !important;
    font-size: 30px !important;
    font-weight: 700 !important;
    color: #1B2A4A !important;
    margin-top: 35px !important;
    margin-bottom: 15px !important;
    line-height: 1.3 !important;
}
body.single-post .post-content-wrap h3 {
    font-family: 'Playfair Display', serif !important;
    font-size: 24px !important;
    font-weight: 700 !important;
    color: #1B2A4A !important;
    margin-top: 30px !important;
    margin-bottom: 12px !important;
}
body.single-post .post-content-wrap h4 {
    font-family: 'Playfair Display', serif !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: #1B2A4A !important;
}
body.single-post .post-content-wrap p,
body.single-post .post-content-wrap li {
    font-family: 'Source Sans 3', 'Source Sans Pro', sans-serif !important;
    font-size: 17px !important;
    line-height: 1.7 !important;
    color: #333 !important;
}
body.single-post .post-content-wrap a {
    color: #C8A456 !important;
    text-decoration: none !important;
}
body.single-post .post-content-wrap a:hover {
    color: #1B2A4A !important;
    text-decoration: underline !important;
}
body.single-post .post-content-wrap strong {
    font-weight: 700 !important;
    color: #1B2A4A !important;
}

/* --- 24i: Single Post — Prev/Next Navigation --- */
body.single-post .prev-next-wrap a,
body.single-post .houzez-prev-next a {
    font-family: 'Source Sans 3', 'Source Sans Pro', sans-serif !important;
    color: #1B2A4A !important;
    font-weight: 600 !important;
}
body.single-post .prev-next-wrap a:hover,
body.single-post .houzez-prev-next a:hover {
    color: #C8A456 !important;
}

/* --- 24j: Single Post — Author Box --- */
body.single-post .author-wrap,
body.single-post .houzez-author-box {
    font-family: 'Source Sans 3', 'Source Sans Pro', sans-serif !important;
}
body.single-post .author-wrap .author-name,
body.single-post .houzez-author-box .author-name {
    font-family: 'Playfair Display', serif !important;
    font-weight: 700 !important;
    color: #1B2A4A !important;
}

/* --- 24k: Single Post — Related Posts --- */
body.single-post .related-posts h3,
body.single-post .houzez-related-posts h3 {
    font-family: 'Playfair Display', serif !important;
    color: #1B2A4A !important;
}

/* --- 24l: Category Archive Pages --- */
body.category .page-title-wrap {
    background-color: #1B2A4A !important;
    padding: 140px 40px 60px !important;
    margin-bottom: 40px !important;
    text-align: center !important;
}
body.category .page-title-wrap h1 {
    font-family: 'Playfair Display', serif !important;
    font-size: 42px !important;
    font-weight: 700 !important;
    color: #FFFFFF !important;
}
body.category .page-title-wrap .breadcrumb,
body.category .page-title-wrap .breadcrumb a,
body.category .page-title-wrap .breadcrumb li,
body.category .page-title-wrap .breadcrumb-item+.breadcrumb-item::before {
    color: rgba(255,255,255,0.7) !important;
}
body.category .page-title-wrap .breadcrumb a:hover {
    color: #C8A456 !important;
}
/* Category archive card fonts */
body.category .blog-post-title,
body.category .blog-post-title a {
    font-family: 'Playfair Display', serif !important;
}
body.category .blog-post-body,
body.category .blog-post-body p {
    font-family: 'Source Sans 3', 'Source Sans Pro', sans-serif !important;
}
body.category .blog-post-link a {
    color: #C8A456 !important;
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    font-size: 13px !important;
}
body.category .blog-post-meta a {
    color: #C8A456 !important;
}

/* --- 24m: Hide sidebar on single posts for cleaner layout --- */
body.single-post .sidebar {
    display: none !important;
}
body.single-post .content-area {
    width: 100% !important;
    max-width: 800px !important;
    margin: 0 auto !important;
}
body.single-post .main-wrap {
    max-width: none !important;
    width: 100% !important;
    margin: 0 auto !important;
}
body.single-post .blog-wrap {
    max-width: 900px !important;
    margin: 0 auto !important;
}





/* --- 24n: Blog Mobile Overrides --- */
@media (max-width: 768px) {
    body.page-id-448 .page-title-wrap,
    body.single-post .page-title-wrap,
    body.category .page-title-wrap {
        padding: 80px 20px 40px !important;
    }
    body.page-id-448 .page-title-wrap h1 {
        font-size: 32px !important;
    }
    body.single-post .post-title-wrap h1 {
        font-size: 28px !important;
    }
    body.single-post .post-content-wrap h2 {
        font-size: 24px !important;
    }
    body.single-post .post-content-wrap p,
    body.single-post .post-content-wrap li {
        font-size: 16px !important;
    }
    body.category .page-title-wrap h1 {
        font-size: 28px !important;
    }
}


/* ===== SECTION 22: Blog & Single Post Styling ===== */

/* Single post: full-width content, hide empty sidebar */
.single-post .bt-content-wrap {
  flex: 0 0 100% !important;
  max-width: 100% !important;
}
.single-post .bt-sidebar-wrap {
  display: none !important;
}

/* Single post: constrain content width for readability */
.single-post .entry-content,
.single-post .blog-post-content {
  max-width: 800px;
}

/* Single post: heading colors */
.single-post .entry-title,
.single-post .post-title {
  color: #1B2A4A !important;
  font-family: 'Playfair Display', serif !important;
}

.single-post .entry-content h2,
.single-post .entry-content h3,
.single-post .entry-content h4 {
  color: #1B2A4A !important;
  font-family: 'Playfair Display', serif !important;
}

/* Single post: body text */
.single-post .entry-content p,
.single-post .entry-content li {
  font-family: 'Source Sans 3', 'Source Sans Pro', sans-serif !important;
  font-size: 17px;
  line-height: 1.7;
  color: #333;
}

/* Single post: category link gold */
.single-post .blog-category a,
.single-post .post-meta .cat-links a,
.single-post .blog-post-meta a {
  color: #C8A456 !important;
}

/* Blog grid: card title font */
.blog-wrap .blog-title a,
.blog-wrap .masonry-post-title a,
.blog-wrap h3 a {
  font-family: 'Playfair Display', serif !important;
  color: #1B2A4A !important;
}
.blog-wrap .blog-title a:hover,
.blog-wrap .masonry-post-title a:hover,
.blog-wrap h3 a:hover {
  color: #C8A456 !important;
}

/* Blog grid: category links gold */
.blog-wrap .post-category a,
.blog-wrap .category-tag a {
  color: #C8A456 !important;
}

/* Blog grid: continue reading link gold */
.blog-wrap .read-more a,
.blog-wrap .continue-reading a,
.blog-wrap a.read-more-btn {
  color: #C8A456 !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: 1px;
}

/* Category archive: full-width content, hide empty sidebar */
.category .bt-content-wrap {
  flex: 0 0 100% !important;
  max-width: 100% !important;
}
.category .bt-sidebar-wrap {
  display: none !important;
}

/* Fix nav wrapping on non-Elementor pages (single posts, category archives) */
.single-post .elementor-nav-menu,
.category .elementor-nav-menu,
.blog .elementor-nav-menu {
  flex-wrap: nowrap !important;
}
.single-post .elementor-nav-menu .elementor-item,
.category .elementor-nav-menu .elementor-item,
.blog .elementor-nav-menu .elementor-item {
  white-space: nowrap !important;
  font-size: 14px !important;
  padding: 0 10px !important;
}

/* Single post: prev/next post links */
.single-post .post-prev-next a {
  color: #1B2A4A !important;
}
.single-post .post-prev-next a:hover {
  color: #C8A456 !important;
}

/* Single post: related posts headings */
.single-post .related-posts h3 a {
  font-family: 'Playfair Display', serif !important;
  color: #1B2A4A !important;
}
.single-post .related-posts h3 a:hover {
  color: #C8A456 !important;
}

/* Author box styling */
.single-post .author-name,
.single-post .author-name a {
  font-family: 'Playfair Display', serif !important;
  color: #1B2A4A !important;
}

/* Blog page title */
.blog .page-title h1,
.blog .page-title-wrap h1 {
  font-family: 'Playfair Display', serif !important;
  color: #1B2A4A !important;
}



/* ===================== */
/* SECTION 22: Blog Styling — Brand Consistency */
/* ===================== */

/* 22a: Blog grid — post titles → Playfair Display */
.blog-wrap .post-title a,
.blog-wrap h2.post-title a,
.blog-wrap .blog-post-title a,
.masonry-post-grid .post-title a,
.houzez-masonry .entry-title a,
.blog-wrap .entry-title a,
.blog-wrap h2 a {
  font-family: 'Playfair Display', serif !important;
  color: #1B2A4A !important;
}
.blog-wrap .post-title a:hover,
.blog-wrap h2 a:hover,
.blog-wrap .entry-title a:hover {
  color: #C8A456 !important;
}

/* 22b: Blog grid — "Continue Reading" links → gold */
.blog-wrap .read-more a,
.blog-wrap .continue-reading a,
.blog-wrap a.read-more,
.masonry-post-grid .read-more a,
.houzez-masonry .read-more a,
.blog-wrap .entry-footer a,
.blog-wrap a[href*="continue"],
.blog-wrap .post-content a.read-more,
.blog-wrap .btn-read-more,
a.btn-read-more,
.read-more-btn,
.masonry-blog .read-more a {
  color: #C8A456 !important;
  text-decoration: none !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  letter-spacing: 1px !important;
}
.blog-wrap .read-more a:hover,
a.btn-read-more:hover,
.masonry-blog .read-more a:hover {
  color: #1B2A4A !important;
}

/* 22c: Single post — headings → Playfair Display */
.single-post .entry-content h1,
.single-post .entry-content h2,
.single-post .entry-content h3,
.single-post .entry-content h4,
.single-post .entry-content h5,
.single-post .entry-content h6,
.single-post .entry-title,
.single-post .post-title,
body.single-post article h2,
body.single-post article h3 {
  font-family: 'Playfair Display', serif !important;
  color: #1B2A4A !important;
}

/* 22d: Single post — body text → Source Sans 3 */
.single-post .entry-content p,
.single-post .entry-content li,
.single-post .entry-content span,
.single-post .entry-content a,
body.single-post article p {
  font-family: 'Source Sans 3', 'Source Sans Pro', sans-serif !important;
}

/* 22e: Author box — hide broken Gravatar image */
.author-avatar img[src*="gravatar"],
.about-author img.avatar,
.author-bio img.avatar,
.post-author-box img.avatar,
img.avatar.photo {
  display: none !important;
}

/* 22f: Author name styling */
.about-author h4,
.author-bio h4,
.post-author-box h4,
.about-author .author-name,
.author-box-title {
  font-family: 'Montserrat', sans-serif !important;
  color: #1B2A4A !important;
  font-weight: 600 !important;
}

/* 22g: Related posts headings → Playfair Display */
.related-posts h3,
.related-posts .related-title,
.related-posts .post-title a,
.related-posts h2 {
  font-family: 'Playfair Display', serif !important;
  color: #1B2A4A !important;
}

/* 22h: Category archive page — same title treatment */
.archive .page-title,
.category .page-title {
  font-family: 'Playfair Display', serif !important;
  color: #1B2A4A !important;
}

/* 22i: Blog page hero title */
.blog-wrap .page-title,
.page-title-wrap h1 {
  font-family: 'Playfair Display', serif !important;
}

/* 22j: Category tags in blog grid → gold */
.blog-wrap .post-meta a,
.blog-wrap .category-tag a,
.masonry-post-grid .cat-name a {
  color: #C8A456 !important;
}

/* 22k: Prev/Next post navigation links */
.post-navigation a,
.single-post .post-nav a,
.prev-next-nav a {
  color: #1B2A4A !important;
  font-family: 'Source Sans 3', 'Source Sans Pro', sans-serif !important;
}
.post-navigation a:hover,
.single-post .post-nav a:hover {
  color: #C8A456 !important;
}

/* 22l: Fix nav font-size/padding on archive/category/single-post pages */
/* These pages render the Elementor header (post 57) but Houzez theme */
/* overrides nav item sizing to 14px/10px. Force homepage standard. */
.elementor-57 .elementor-element.elementor-element-42e90608 .elementor-nav-menu .elementor-item {
  font-size: 16px !important;
  padding: 13px 20px !important;
}

/* ===== 31. Center nav menu items ===== */
.elementor-element-42e90608 .elementor-nav-menu--main {
  justify-content: center !important;
  width: 100% !important;
}
.elementor-element-42e90608 .elementor-nav-menu__container {
  justify-content: center !important;
}
.elementor-element-42e90608 .elementor-nav-menu {
  justify-content: center !important;
}

/* 31b. Center nav widget container */
.elementor-57 .elementor-element.elementor-element-7fbab13e {
  justify-content: center !important;
}

/* ===== 32. Header horizontal padding ===== */
.elementor-57 .elementor-element.elementor-element-7d35d6d4 > .e-con-inner {
  padding-left: 24px !important;
  padding-right: 24px !important;
}

/* ===== 33. Mobile dropdown menu fix ===== */
@media (max-width: 1024px) {
  .elementor-element-42e90608 .elementor-nav-menu--dropdown.elementor-nav-menu__container {
    min-width: 250px !important;
    background: #FFFFFF !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.12) !important;
    border-radius: 0 0 8px 8px !important;
    padding: 8px 0 !important;
    overflow: visible !important;
  }
  .elementor-element-42e90608 .elementor-nav-menu--dropdown .elementor-item {
    text-align: left !important;
    padding: 14px 28px !important;
    font-family: Montserrat, sans-serif !important;
    font-size: 16px !important;
    color: #1B2A4A !important;
    display: block !important;
  }
  .elementor-element-42e90608 .elementor-nav-menu--dropdown .elementor-item:hover,
  .elementor-element-42e90608 .elementor-nav-menu--dropdown .elementor-item.elementor-item-active {
    color: #C8A456 !important;
    background: #f8f8f8 !important;
  }
}
