/* =========================================
   ME Foundation
   Tokens, wrapper, typography, links, buttons, header and nav polish
   No sections
   No cards
   No page kits
   ========================================= */

:root{
  /* Palette */
  --me-bg:#ffffff;
  --me-surface:#F1ECE6;
  --me-ink:#2B0E0E;
  --me-text:#2F2F2F;
  --me-muted:#6B6B6B;

  /* CTA */
  --me-cta:#C93737;

  /* GeneratePress token override for buttons and accents */
  --primary-action:#C93737 !important;

  /* Borders and depth */
  --me-border:rgba(43,14,14,0.10);
  --me-border-soft:rgba(43,14,14,0.07);

  --me-shadow:0 10px 22px rgba(43,14,14,0.06);
  --me-shadow-soft:0 6px 16px rgba(43,14,14,0.04);

  /* Radius */
  --me-radius:12px;

  /* Layout */
  --me-wrap:1100px;
}

/* Wrapper */
.me-wrap{
  max-width:var(--me-wrap);
  margin:0 auto;
  padding-left:18px;
  padding-right:18px;
}

/* Typography utilities */
.me-kicker{
  margin:0 0 10px;
  font-size:12px;
  letter-spacing:0.10em;
  text-transform:uppercase;
  color:var(--me-muted);
}

.me-h1{
  margin:0 0 14px;
  color:var(--me-ink);
  line-height:1.08;
  letter-spacing:-0.01em;
  font-weight:700;
  font-size:clamp(34px,4.2vw,52px);
}

.me-h2{
  margin:0 0 12px;
  color:var(--me-ink);
  line-height:1.18;
  letter-spacing:-0.01em;
}

.me-h3{
  margin:0 0 8px;
  color:var(--me-ink);
  line-height:1.2;
}

.me-lede{
  margin:0 0 18px;
  color:var(--me-text);
  font-size:18px;
  line-height:1.55;
  max-width:62ch;
}

@media (max-width:768px){
  .me-lede{ font-size:16px; }
}

/* Small text utilities */
.me-muted,
.me-note,
.me-mini{
  margin:10px 0 0;
  color:var(--me-muted);
  font-size:14px;
  line-height:1.55;
}

/* Screen reader only utility */
.me-sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* Links */
.me-link{
  color:var(--me-ink);
  text-decoration:underline;
  text-underline-offset:3px;
}

.me-link:hover{
  text-decoration-thickness:2px;
}

/* Buttons */
.me-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  text-decoration:none;
  border-radius:999px;
  padding:12px 18px;
  font-weight:650;
  line-height:1;
  border:1px solid transparent;
  transition:transform 0.15s ease, box-shadow 0.15s ease, filter 0.15s ease, background-color 0.15s ease, border-color 0.15s ease;
}

.me-btn:focus{
  outline:none;
}

/* Primary */
.me-btn-primary,
.me-btn--primary,
.me-btn.primary{
  background:var(--me-cta);
  border-color:var(--me-cta);
  color:#ffffff;
  box-shadow:0 10px 20px rgba(201,55,55,0.18);
}

.me-btn-primary:hover,
.me-btn--primary:hover,
.me-btn.primary:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 26px rgba(201,55,55,0.22);
  filter:brightness(0.98);
}

/* Ghost */
.me-btn-ghost,
.me-btn--ghost,
.me-btn.ghost{
  background:transparent;
  border-color:var(--me-border);
  color:var(--me-ink);
}

.me-btn-ghost:hover,
.me-btn--ghost:hover,
.me-btn.ghost:hover{
  transform:translateY(-1px);
  border-color:rgba(43,14,14,0.20);
}

/* Force white text on primary ME buttons */
.me-btn-primary,
.me-btn-primary:visited,
.me-btn-primary:hover,
.me-btn-primary:focus,
.me-btn-primary:active,
.me-btn--primary,
.me-btn--primary:visited,
.me-btn--primary:hover,
.me-btn--primary:focus,
.me-btn--primary:active,
.me-btn.primary,
.me-btn.primary:visited,
.me-btn.primary:hover,
.me-btn.primary:focus,
.me-btn.primary:active{
  color:#ffffff !important;
}

/* Gutenberg filled buttons keep white text */
.me-wrap .wp-block-button:not(.is-style-outline) > .wp-block-button__link,
.me-wrap .wp-block-button:not(.is-style-outline) > .wp-block-button__link:visited,
.me-wrap .wp-block-button:not(.is-style-outline) > .wp-block-button__link:hover,
.me-wrap .wp-block-button:not(.is-style-outline) > .wp-block-button__link:focus{
  color:#ffffff !important;
}

/* Mobile readability baseline */
@media (max-width:768px){
  body{
    font-size:17px;
    line-height:1.65;
  }
}

/* =========================================
   Header spacing
   ========================================= */

.site-header{
  padding-top:8px;
  padding-bottom:8px;
}

@media (max-width:768px){
  .site-header{
    padding-top:6px;
    padding-bottom:6px;
  }
}

/* Reduce dead space between header and content */
.site-content{
  padding-top:0;
}

/* Reduce header inner padding slightly */
.site-header .inside-header{
  padding-top:12px;
  padding-bottom:12px;
}

/* =========================================
   Nav CTA styling only
   Requires menu item class: me-nav-cta
   ========================================= */

.main-navigation .main-nav ul li.me-nav-cta > a{
  background:var(--me-cta);
  border:1px solid var(--me-cta);
  color:#ffffff;
  border-radius:999px;
  padding:9px 14px;
  line-height:1;
  display:inline-flex;
  align-items:center;
  text-decoration:none;
  transition:filter 0.15s ease, transform 0.15s ease;
}

.main-navigation .main-nav ul li.me-nav-cta > a:hover{
  filter:brightness(0.98);
  transform:translateY(-1px);
}

/* =========================================
   Dropdown
   Hard reset plus scroll so items never float or space out
   ========================================= */

.main-navigation .main-nav ul ul{
  background:#ffffff;
  border:1px solid rgba(0,0,0,0.08);
  border-radius:12px;
  box-shadow:0 18px 50px rgba(0,0,0,0.10);
  padding:10px 0;
  max-height:70vh;
  overflow-x:hidden;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  display:block;
  height:auto;
}

.main-navigation .main-nav ul ul > li{
  display:block;
  margin:0;
  padding:0;
}

.main-navigation .main-nav ul ul > li > a{
  display:block;
  width:100%;
  padding:6px 16px;
  font-size:14px;
  line-height:1.25;
  color:var(--me-ink);
  background:transparent;
  text-decoration:none;
  white-space:normal;
}

.main-navigation .main-nav ul ul > li > a:hover{
  background:var(--me-surface);
}

@media (max-width:768px){
  .main-navigation .main-nav ul ul > li > a{
    padding-top:10px;
    padding-bottom:10px;
  }
}

/* Header horizontal tightening */
.main-navigation .main-nav ul{
  gap:16px;
}

/* =========================================
   Mobile off canvas submenu spacing fix
   GeneratePress mobile menu
   ========================================= */

@media (max-width:768px){
  .main-navigation.toggled .main-nav ul ul{
    display:block;
    margin:0;
    padding:0;
  }

  .main-navigation.toggled .main-nav ul ul > li{
    margin:0;
    padding:0;
  }

  .main-navigation.toggled .main-nav ul ul > li > a{
    display:block;
    width:100%;
    padding:10px 16px;
    line-height:1.25;
  }

  .main-navigation.toggled .main-nav ul ul > li > a{
    padding-left:26px;
  }
}

/* =========================================
   Mobile submenu hard fix
   Goal: stop overlap, remove giant dropdown styling, stack clean
   Scope: mobile only
   ========================================= */

@media (max-width:768px){
  .main-navigation .main-nav ul ul{
    position:static !important;
    float:none !important;
    width:100% !important;
    max-height:none !important;
    overflow:visible !important;
    box-shadow:none !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    padding:0 !important;
    margin:0 !important;
  }

  .main-navigation .main-nav ul ul > li{
    display:block !important;
    margin:0 !important;
    padding:0 !important;
  }

  .main-navigation .main-nav ul ul > li > a{
    display:block !important;
    width:100% !important;
    box-sizing:border-box !important;
    padding:10px 16px 10px 28px !important;
    line-height:1.25 !important;
    background:transparent !important;
    min-height:0 !important;
  }

  .slideout-navigation ul ul{
    position:static !important;
    max-height:none !important;
    overflow:visible !important;
    box-shadow:none !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    padding:0 !important;
    margin:0 !important;
  }

  .slideout-navigation ul ul > li > a{
    display:block !important;
    width:100% !important;
    box-sizing:border-box !important;
    padding:10px 16px 10px 28px !important;
    line-height:1.25 !important;
  }
}

/* =========================================
   Mobile submenu containment
   Prevent submenu from overflowing into next menu
   ========================================= */

@media (max-width:768px){
  .main-navigation.toggled .main-nav{
    max-height:80vh;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }

  .main-navigation.toggled .main-nav ul ul{
    max-height:56vh;
    overflow-y:auto;
    overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
  }

  .main-navigation.toggled .main-nav ul ul > li > a{
    padding-top:12px;
    padding-bottom:12px;
  }
}

@media (max-width:768px){
  .slideout-navigation{
    max-height:80vh;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }

  .slideout-navigation ul ul{
    max-height:56vh;
    overflow-y:auto;
    overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
  }

  .slideout-navigation ul ul > li > a{
    padding-top:12px;
    padding-bottom:12px;
  }
}

/* =========================================
   Mobile menu overflow fix
   Target GeneratePress submenu classes
   Prevent expanded submenu from pushing into next menu
   ========================================= */

@media (max-width:768px){
  .main-navigation.toggled .inside-navigation,
  .slideout-navigation .inside-navigation,
  .slideout-navigation{
    max-height:80vh !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling:touch;
  }

  .main-navigation.toggled ul.sub-menu,
  .main-navigation.toggled ul.children,
  .slideout-navigation ul.sub-menu,
  .slideout-navigation ul.children{
    max-height:60vh !important;
    overflow-y:auto !important;
    overflow-x:hidden !important;
    -webkit-overflow-scrolling:touch;
  }

  .main-navigation.toggled ul.sub-menu > li,
  .main-navigation.toggled ul.children > li,
  .slideout-navigation ul.sub-menu > li,
  .slideout-navigation ul.children > li{
    margin:0 !important;
    padding:0 !important;
  }

  .main-navigation.toggled ul.sub-menu > li > a,
  .main-navigation.toggled ul.children > li > a,
  .slideout-navigation ul.sub-menu > li > a,
  .slideout-navigation ul.children > li > a{
    display:block !important;
    width:100% !important;
    padding:12px 16px 12px 28px !important;
    line-height:1.25 !important;
    box-sizing:border-box !important;
  }
}

/* =========================================
   Footer Equal Housing image sizing
   ========================================= */

.footer-widgets img{
  max-width:100%;
  height:auto;
}

.footer-widgets img[alt*="Equal Housing"]{
  max-width:140px;
  height:auto;
  display:block;
}

/* =========================================
   A11y Lock – Gravity Forms Required Text
   Force sufficient contrast on beige cards
   ========================================= */

.me-card .gform_wrapper .gfield_required,
.me-card .gform_wrapper .gfield_required_text,
.me-card .gform_wrapper legend span.gfield_required,
.me-card .gform_wrapper label span.gfield_required{
  color:#7A1B1B !important;
}

