.elementor-19519 .elementor-element.elementor-element-9b42d4a{--display:flex;}.elementor-19519 .elementor-element.elementor-element-a4b9727{--display:flex;}.elementor-19519 .elementor-element.elementor-element-46d2727{padding:0px 0px 30px 0px;text-align:center;}.elementor-19519 .elementor-element.elementor-element-46d2727 .elementor-heading-title{color:#412D5E;}/* Start custom CSS for container, class: .elementor-element-9b42d4a *//* ==========================================================
   1. GLOBAL HEADER (Solid Purple & Phone Icon)
========================================================== */
html body .site_header {
    position: relative !important;
    background-color: #3f1a66 !important;
    display: block !important;
    z-index: 9999 !important;
    margin-bottom: 0 !important;
}
 
html body .site_header .call_ico {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
}
 
html body .site_header .call_ico svg,
html body .site_header .top_call svg { fill: #ffffff !important; }
html body .site_header .call_num { color: #ffffff !important; }
 
html body .menu_trigger span,
html body .menu_trigger span::before,
html body .menu_trigger span::after { background-color: #ffffff !important; }
 
 
/* ==========================================================
   2. DESKTOP (992px and up)
========================================================== */
@media (min-width: 992px) {

    /* ---- DROPDOWN MENUS: White bg, purple text ---- */
    html body .site_header .top_nav .mainMenu li ul.sub-menu,
    html body .site_header .top_nav .mainMenu li.mega_menu ul.sub-menu,
    html body .site_header .top_nav .mainMenu li ul.sub-menu li ul.sub-menu,
    html body .site_header .hear_r_btm .mainMenu li ul.sub-menu,
    html body .site_header .mainMenu > li > ul.sub-menu,
    html body .site_header .mainMenu .sub-menu,
    html body .site_header ul.sub-menu {
        background: #ffffff !important;
        background-color: #ffffff !important;
    }
 
    html body .site_header .top_nav .mainMenu li ul.sub-menu li a,
    html body .site_header .top_nav .mainMenu li.mega_menu ul.sub-menu li a,
    html body .site_header .top_nav .mainMenu li ul.sub-menu li ul.sub-menu li a,
    html body .site_header .hear_r_btm .mainMenu li ul.sub-menu li a,
    html body .site_header .mainMenu .sub-menu li a,
    html body .site_header ul.sub-menu li a {
    }
 
    html body .site_header .top_nav .mainMenu li ul.sub-menu li a:hover,
    html body .site_header .mainMenu .sub-menu li a:hover,
    html body .site_header ul.sub-menu li a:hover {
        background-color: #f5f0fa !important;
    }
 
    /* Homepage Hero Desktop */
    html body.home section.bnr_sec,
    html body.home section.bnr_sec .bnr_slider,
    html body.home section.bnr_sec .slick-list,
    html body.home section.bnr_sec .slick-track,
    html body.home section.bnr_sec .bnr_slide {
        height: 600px !important;
        min-height: 600px !important;
        margin-top: 0 !important;
        position: relative !important;
    }
 
    html body.home section.bnr_sec .bnr_txt {
        display: flex !important;
        align-items: flex-start !important;
        height: 100% !important;
        padding-top: 180px !important;
    }
 
    html body.home section.bnr_sec .bnr_txt .container .bnr_txt_in {
        max-width: 550px !important;
    }
 
    html body.home section.bnr_sec .bnr_txt .container .bnr_txt_in .bnr_lg {
        font-size: 34px !important;
        line-height: 1.2 !important;
        margin-bottom: 15px !important;
        text-shadow: 0px 4px 10px rgba(0,0,0,0.8) !important;
    }
 
    html body.home section.bnr_sec .bnr_txt .container .bnr_txt_in .bnr_md {
        font-size: 16px !important;
        line-height: 1.5 !important;
        margin-bottom: 20px !important;
    }
 
    /* Subpage Hero (.inner_bnr) — Desktop: text overlays image */
    html body .inner_bnr {
        position: relative !important;
        height: 560px !important;
        overflow: hidden !important;
        margin: 0 !important;
        display: block !important;
    }
 
    html body .inner_bnr .bnr_pic {
        position: absolute !important;
        inset: 0 !important;
        width: 100% !important;
        height: 100% !important;
        background-size: cover !important;
        background-position: center !important;
    }
 
    html body .inner_bnr .bnr_txt {
        position: relative !important;
        z-index: 2 !important;
        background: transparent !important;
        padding-top: 130px !important;
        height: 100% !important;
    }
 
    html body .inner_bnr .bnr_lg {
        font-size: 42px !important;
        line-height: 1.2 !important;
        color: #ffffff !important;
        text-shadow: 0 3px 10px rgba(0,0,0,0.7) !important;
        margin-bottom: 14px !important;
    }
 
    html body .inner_bnr .bnr_md {
        font-size: 16px !important;
        line-height: 1.5 !important;
        color: #ffffff !important;
        text-shadow: 0 2px 6px rgba(0,0,0,0.5) !important;
    }
}
 
 
/* ==========================================================
   3. MOBILE & TABLET (up to 991px)
========================================================== */
@media (max-width: 991px) {
 
    /* Mobile Menu: Dark purple text on white panel */
    html body .site_header .mainMenu > li > a {
        color: #3f1a66 !important;
        font-weight: 600 !important;
    }
 
    /* Mobile sub-menu items */
    html body .site_header .top_nav .mainMenu li ul.sub-menu li a,
    html body .site_header .mainMenu .sub-menu li a {
        color: #3f1a66 !important;
    }
 
    /* Homepage Hero Mobile Stacking */
    html body.home section.bnr_sec,
    html body.home section.bnr_sec .bnr_slider,
    html body.home section.bnr_sec .slick-list,
    html body.home section.bnr_sec .slick-track,
    html body.home section.bnr_sec .bnr_slide {
        height: auto !important;
        min-height: auto !important;
    }
 
    html body.home section.bnr_sec .bnr_slide {
        display: flex !important;
        flex-direction: column !important;
    }
 
    html body.home section.bnr_sec .bnr_pic {
        position: relative !important;
        height: 300px !important;
        width: 100% !important;
        order: 1 !important;
    }
 
    html body.home section.bnr_sec .bnr_txt {
        position: relative !important;
        background-color: #3f1a66 !important;
        padding: 40px 20px !important;
        height: auto !important;
        order: 2 !important;
    }
 
    html body.home section.bnr_sec .bnr_txt .container { padding: 0 !important; }
 
    /* Homepage Mobile Fonts */
    html body.home .bnr_lg {
        font-size: 32px !important;
        line-height: 1.2 !important;
        color: #ffffff !important;
        text-shadow: none !important;
        margin-bottom: 15px !important;
    }
    html body.home .bnr_md {
        font-size: 18px !important;
        line-height: 1.5 !important;
        color: #ffffff !important;
    }
 
    /* Subpage Hero (.inner_bnr) — Mobile: image top, purple text below */
    html body .inner_bnr {
        display: flex !important;
        flex-direction: column !important;
        height: auto !important;
        margin: 0 !important;
    }
 
    html body .inner_bnr .bnr_pic {
        position: relative !important;
        height: 280px !important;
        width: 100% !important;
        background-size: cover !important;
        background-position: right center !important;
        flex-shrink: 0 !important;
        order: 1 !important;
    }
 
    html body .inner_bnr .bnr_txt {
        order: 2 !important;
        background-color: #3f1a66 !important;
        padding: 32px 20px 40px !important;
        height: auto !important;
        position: relative !important;
    }
 
    html body .inner_bnr .bnr_txt .container {
        padding: 0 !important;
    }
 
    html body .inner_bnr .bnr_lg {
        font-size: 26px !important;
        line-height: 1.25 !important;
        color: #ffffff !important;
        text-shadow: none !important;
        margin-bottom: 12px !important;
    }
 
    html body .inner_bnr .bnr_md {
        font-size: 15px !important;
        line-height: 1.5 !important;
        color: #ffffff !important;
        text-shadow: none !important;
    }
 
    html body .inner_bnr .bnr_cta {
        margin-top: 20px !important;
    }
 
    /* Homepage White Section Clearance */
    html body.home .elementor-element-025ceb6,
    html body.home .elementor-element-6a39ca8,
    html body.home .elementor-element-4b3e69b {
        position: relative !important;
        margin-top: 0 !important;
        display: block !important;
        padding-top: 20px !important;
    }
    html body.home .elementor-element-3e3bdb1 {
        margin-top: 0 !important;
        position: relative !important;
    }
}
 
 
/* ==========================================================
   4. GHOST TEXT FIX (MEDIA PAGE)
========================================================== */
.elementor-57 .elementor-element-54bb8bb4 .elementor-heading-title::before {
    display: none !important;
}
 
 
/* ==========================================================
   5. HEALTH PAGE — Circle Icons with #836F93 Tint
      Slow gentle fade at outer edge — feels embedded
========================================================== */
.services-grid .health_card {
    position: relative !important;
    isolation: isolate !important;
}
 
.services-grid .health_card > img {
    width: 180px !important;
    height: 180px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    display: block !important;
    margin: 0 auto 20px !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    position: relative !important;
    z-index: 1 !important;
    -webkit-mask-image: radial-gradient(circle, black 65%, transparent 90%) !important;
    mask-image: radial-gradient(circle, black 65%, transparent 90%) !important;
}
 
/* Purple tint overlay — same gentle fade */
.services-grid .health_card::after {
    content: '' !important;
    position: absolute !important;
    width: 180px !important;
    height: 180px !important;
    border-radius: 50% !important;
    background-color: #836F93 !important;
    mix-blend-mode: color !important;
    z-index: 2 !important;
    top: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    pointer-events: none !important;
    -webkit-mask-image: radial-gradient(circle, black 65%, transparent 90%) !important;
    mask-image: radial-gradient(circle, black 65%, transparent 90%) !important;
}/* End custom CSS */