/**
 * Theme Name:     Hello Elementor Child
 * Author:         Elementor Team
 * Template:       hello-elementor
 * Text Domain:	   hello-elementor-child
 * Description:    Hello Elementor is a lightweight and minimalist WordPress theme that was built specifically to work seamlessly with the Elementor site builder plugin. The theme is free, open-source, and designed for users who want a flexible, easy-to-use, and customizable website. The theme, which is optimized for performance, provides a solid foundation for users to build their own unique designs using the Elementor drag-and-drop site builder. Its simplicity and flexibility make it a great choice for both beginners and experienced Web Creators.
 */

body {overflow-x:hidden;}

.inline-links a:active {
  color: #EF3B8A;
}
.inline-links a:hover {
  color: #EF3B8A;
  text-decoration: underline;
}

.pink-text {
  color: #ef3b8a;
}

.overflow-hidden {
  overflow: hidden;
}

.about-accordion .e-n-accordion-item:first-child {
  border-top: 1px solid #e1e1fa;
}
.about-accordion .e-n-accordion-item {
  border-bottom: 1px solid #e1e1fa;
}

span.e-n-accordion-item-title-icon {
  border: 1px solid;
  width: 38px !important;
  display: flex;
  height: 38px;
  justify-content: center;
  align-items: center;
  border-radius: 50px;
}

summary.e-n-accordion-item-title {
  margin-bottom: 0 !important;
}

.footer-contact-info h3.elementor-image-box-title {
  margin-bottom: 15px !important;
}

.footer-contact-info img {
  width: 50px;
  min-width: 50px;
}

.footer-contact-info figure.elementor-image-box-img {
  margin-right: 15px !important;
}

.footer-contact-info figure.elementor-image-box-img {
  max-width: 50px;
}

.faq span.e-n-accordion-item-title-icon {
  border: none;
  width: auto !important;
  height: auto !important;
}

.margaret-mason-obe {
  border-top-right-radius: 40px;
  border-bottom-left-radius: 40px;
}

.price-tag span {
  font-size: 15px;
  color: #545a64;
  font-weight: normal;
}

.feature-item {
  padding: 0;
  border: 0;
}
.feature-item ul li.elementor-icon-list-item {
  padding-left: 15px;
  position: relative;
}
.feature-item ul li .elementor-icon-list-icon {
  display: none;
}
.feature-item ul li:before {
  content: '\f00c';
  font-family: 'FontAwesome';
  font-size: 10px;
  margin-right: 10px;
  position: absolute;
  left: 0;
  top: 4px;
}

.faq-container .hrf-entry {
  display:table;
  background:#f7f0ed;
  border-radius:10px;
  width:100%;
  margin-bottom:15px
}
.faq-container .hrf-entry .hrf-title {
  padding:14px 45px 19px 25px;
  cursor:pointer;
  margin:0;
  font-size:14px;
  font-weight:bold;
  transition:all .2s ease-in-out;
  position:relative;
  line-height:20px;
      font-weight:600;
}
.faq-container .hrf-entry .hrf-title .fa {
  position:absolute;
  top:15px;
  right:15px;
  font-size:10px;
  color:#cecece;
  transition:all .2s ease-in-out
}
.faq-container .hrf-entry .hrf-title .fa.fa-chevron-right:before {
  left:1px;
  top:-1px;
  position:relative
}
.faq-container .hrf-entry .hrf-title .fa-border {
  border-color:#cecece;
  width:20px;
  height:20px;
    border-radius:50%;
    text-align: center;
    padding-top:4px;
}
.faq-container .hrf-entry:hover .hrf-title .fa-border {
  color:#ee3897;
  border-color:#ee3897
}
.faq-container .hrf-entry .hrf-title.open-faq {
  color:#ee3897
}
.faq-container .hrf-entry .hrf-title.open-faq .fa {
  color:#ee3897
}
.faq-container .hrf-entry .hrf-title.open-faq .fa-border {
  border-color:#ee3897;
    padding-top:5px;
}
.faq-container .hrf-entry .hrf-title.open-faq .fa.fa-chevron-right:before {
  content:"\f00d";
  top:-2px;
  left:0
}
.faq-container .hrf-entry .hrf-content {
  display:none;
  padding:0 40px 30px 40px;
  color:#888;
font-size:14px;
}
.faq-container .hrf-entry .hrf-content ul li {
  position:relative;
  padding-left:25px;
  margin-bottom:4px;
}
.faq-container .hrf-entry .hrf-content ul li:before {
  content:"\f00c";
  font-family:FontAwesome;
  font-size:13px;
  position:absolute;
  left:0;
  top:0
}
.faq-container .hrf-entry .hrf-content a {
  color:#ee3897
}
.faq-container .hrf-entry .hrf-content ul {
  margin-top:20px
}
.faq-container .hrf-entry .hrf-content ul li:before {
  color:#8066a6
}
.faq-container .hrf-entry .hrf-content strong {
  font-weight:900;
  color:#8066a6
}

.custom-icon svg .st0 {fill:none;}

.sub-nav-container {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content !important;
  box-shadow: 0 0 20px 20px #fff;
  transition:opacity 0.2s ease-in-out;
}
.footer-contact-info .elementor-image-box-wrapper {
    display: flex;
}

.page-id-1284 .elementor-element-2c19b8b {display:none;}

.price-tag .elementor-heading-title a {
  font-weight: 800;
}

.price-size a {
  font-weight: 500;
}

.elementor-widget-text-editor p a:hover {
    color:#EF3B8A;
    text-decoration: underline;
}

.elementor-15 .e-con-inner {
/*    padding-top: 30px;*/
}

.blog-card-content .cat-name {display: inline-block; margin-right:10px;}

@media (max-width: 767px) {
  .footer-contact-info .elementor-image-box-wrapper {
    display: flex;
  }

  .footer-contact-info .elementor-image-box-content {
    text-align: left;
  }

  br {
    display: none;
  }

  .statistics-section .elementor-image-box-img img {
    margin: 0 auto !important;
  }
}

.footer-contact-info .elementor-image-box-img {
  align-items: center !important;
}

.footer-contact-info .elementor-image-box-wrapper {
 
}

.testimonial-item {
  box-shadow: 0 0 20px #eee;
  padding: 30px;
  border-radius: 20px;
  background-color: #fff;
}

.testimonial-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.testimonial-meta-left {
  display: flex;
  align-items: center;
  gap: 15px;
}

.testimonial-meta-desc h4 {
  margin-bottom: 0;
}

.testimonial-meta-desc p {
  margin-bottom: 0;
}

.testimonial-meta-desc {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.testimonial-body p {
  color: #545a64;
  font-size: 20px;
}

.testimonial-rating i {
  color: #ffb632;
}

.testimonial-rating {
  display: flex;
  flex-direction: row;
  gap: 3px;
}

.testimonial-meta-left img {
  max-width: 75px;
}

.testimonial-item {
  height: 100%;
}

.pagination-wrapper a {
  color: #969fb7;
  font-size: 22px;
}

.pagination-wrapper span {
  font-size: 22px;
  color: #ef3b8a;
}

.pagination-wrapper span,
.pagination-wrapper a {
  border: 2px solid #edf4ff;
  width: 65px;
  display: flex;
  justify-content: center;
  height: 65px;
  align-items: center;
  border-radius: 50px;
}

.pagination-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.pagination-wrapper a.next,
.pagination-wrapper a.prev {
  background-color: #ef3b8a;
  border-color: #ef3b8a;
  color: #fff;
}

.pagination-wrapper {
  margin-top: 50px;
}

.testimonial-slider-arrows {
  display: flex;
  justify-content: space-between;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 9;
  top: 50%;
  transform: translateY(-50%);
}

section.testimonial-sliders {
  position: relative;
}

.testimonial-slider-init .testimonial-item {
  box-shadow: none;
}

.testimonial-item.slick-slide {
  margin: 0 15px;
}

.testimonial-slider-next,
.testimonial-slider-prev {
  background-color: #ef3b8a;
  color: #fff;
  width: 65px;
  height: 65px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50px;
  cursor: pointer;
}

.testimonial-slider-next {
  margin-right: -90px;
}
.testimonial-slider-prev {
  margin-left: -90px;
}

.testimonial-item.slick-slide {
  min-height: 380px;
}

.header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.site-logo img {
  max-width: 180px;
}

.site-navigation a {
  color: #545a64;
  font-weight: 600;
}

.search-form-wrapper form {
  border: 1px solid #d8def1;
  display: flex;
  border-radius: 50px;
  overflow: hidden;
  padding: 5px;
}

.search-form-wrapper form input {
  border: none;
}

.search-form-wrapper button {
  background-color: transparent;
  border: none;
  padding: 0;
}

.search-form-wrapper form input:focus {
  outline: none;
}

.header-right {
  display: flex;
  align-items: center;
  gap: 20px;
}

.header-button a {
  border: 2px solid;
  display: inline-block;
  padding: 12px 20px;
  border-radius: 50px;
}

.header-button a img {
  margin-right: 5px;
}

section.header-desktop {
  padding: 15px 0;
}

.header-button a:hover {
  background-color: #ef3b8a;
  border-color: #ef3b8a;
  color: #fff;
  transition: 0.3s;
}

.header-button a:hover img {
  filter: brightness(0) invert(1);
}

.mobile-header {
  display: none;
}

.mobile-header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px;
}

.mobile-header-inner .site-logo img {
  max-width: 100px;
}

.mobile-button-trigger span,
.offcanvas-header .btn-offcanvas-close {
  background-color: #ef3b8a;
  width: 35px;
  display: flex;
  height: 35px;
  justify-content: center;
  align-items: center;
  border-radius: 50px;
  color: #fff;
  max-width: 35px;
  padding: 0;
  opacity: 1;
  border: none;
  cursor: pointer;
}

.offcanvas-header {
    justify-content: end;
}

.admin-bar .offcanvas-header {
  margin-top: 46px;
}

.offcanvas-body ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
  text-transform: uppercase;
  margin: 50px 0;
}

.offcanvas-body ul li a {
  color: #333;
  font-size: 18px;
  font-weight: 600;
  display: block;
  text-transform: capitalize;
  text-align: center;
  padding: 7px;
}

.offcanvas-body ul li.current_page_item a {
  color: #ef3b8a;
}

.offcanvas-body .header-right {
  display: flex;
  flex-direction: column;
  padding-bottom: 30px;
}

.offcanvas-body .header-social-button .elementor-social-icon {
    background-color: #fff3ee;
    width: 35px;
    height: 35px;
    border-radius: 50%;
}
.offcanvas-body .header-social-button .elementor-social-icon svg {
    fill: #1c1c1c;
    width: 0.5em;
    height: 0.5em;
}
.offcanvas-body .header-social-button {
  display: flex;
  gap: 10px;
  padding-top: 20px;
}

.offcanvas-body {
  padding-top: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.offcanvas-body .custom-logo-link .custom-logo {
  width:150px;
}

section.featured-blog-section {
  margin: 100px 0;
}

.section-titlle a.primary-btn {
  background-color: #ef3b8a !important;
  color: #fff;
  display: inline-block;
  font-size: 16px;
  padding: 15px 25px;
  border-radius: 50px;
}

.featured-blog-section .section-titlle {
  margin-bottom: 50px;
}

.blog-card {
  border: 1px solid #edf3ff;
}

.blog-thumbnail img {
  width: 100%;
}

.blog-card {
  padding: 10px;
  border-radius: 15px;
}

.blog-card h4 a {
  color: #3b3250;
  font-weight: 600;
  font-size: 20px;
}

.blog-card-content span {
  color: #ef3b8a;
}

.blog-card-content {
  margin: 15px;
}

.blog-card-content p {
  color: #3b3250;
  margin-bottom: 20px;
}

.blog-card-bottom {
  display: flex;
  justify-content: space-between;
}

.readmore a {
  color: #3b3250;
}

.readmore a i {
  margin-left: 4px;
}

.blog-card-small-right img {
  height: 105px;
  object-fit: cover;
  border-radius: 5px;
}

.blog-card-small-left h4 a {
  font-size: 18px;
  color: #1e1e24;
  font-weight: 600;
}

.blog-card-small-left p {
  font-size: 14px;
  margin-bottom: 0;
}

.blog-card-small-left h4 {
  margin-top: 5px;
  margin-bottom: 8px;
}

.blog-card-small {
  margin-bottom: 20px;
  border-bottom: 1px solid #ddd;
  padding-bottom: 20px;
}

section.lates-blog-posts {
  margin-bottom: 100px;
}

section.lates-blog-posts .section-titlle {
  margin-bottom: 50px;
}

@media (max-width: 1400px) {
  .e-con-inner {
    max-width: 1140px !important;
  }

  .testimonial-slider-next {
    margin-right: 0px;
  }
  .testimonial-slider-prev {
    margin-left: 0px;
  }
  .site-navigation ul.menu li a {
    display: block;
    padding: 8px 10px !important;
  }
}

@media (max-width: 1200px) {
  .e-con-inner {
    max-width: 960px !important;
  }

  .testimonial-slider-next,
  .testimonial-slider-prev {
    display: none !important;
  }

  .header-desktop {
    display: none;
  }

  .mobile-header {
    display: block;
  }
}

@media (max-width: 992px) {
  .e-con-inner {
    max-width: 720px !important;
  }

  section.testimonial-sliders .testimonial-item {
    min-height: auto;
  }
}

@media (max-width: 768px) {
  .e-con-inner {
    max-width: 540px !important;
  }
  .testimonial-meta {
    flex-direction: column;
    align-items: start;
    gap: 20px;
  }

  .testimonial-body p {
    font-size: 16px;
  }

  .testimonial-meta-right {
    display: none;
  }
  .testimonial-meta-desc h4 {
    font-size: 16px;
  }

  .testimonial-meta-desc {
    gap: 5px;
  }
  .testimonial-meta-desc p {
    font-size: 14px;
  }

  section {
    overflow: hidden;
  }
  .featured-blog-section .section-titlle {
    margin-bottom: 20px;
  }

  .featured-blog-section .section-titlle {
    flex-direction: column;
    align-items: start !important;
    justify-content: start;
  }

  .featured-blog-section .section-titlle h2 {
    font-size: 30px;
  }

  .featured-blog-section .blog-card {
    margin-bottom: 30px;
  }

  .blog-card-small-right img {
    width: 100%;
    height: auto;
    margin-top: 20px;
  }

  section.lates-blog-posts .section-titlle h2 {
    font-size: 30px;
  }

  section.lates-blog-posts .section-titlle {
    margin-bottom: 30px;
  }
}

.featured-card {
  transition: 0.3s;
}

.featured-card:hover {
  transform: translateY(-10px);
}

.current-menu-item a {
  color: #ef3b8a;
}

a.solid-btn {
  background-color: #ef3b8a;
  color: #fff;
  border-color: #ef3b8a;
  transition: 0.3s;
}

a.solid-btn i {
  margin-left: 8px;
}

a.solid-btn:hover {
  background-color: transparent;
  color: #ef3b8a;
}

.header-button {
  display: flex;
  gap: 15px;
}

.faq .e-n-accordion-item {
  border-radius: 10px !important;
  overflow: hidden !important;
  border: 1px solid #ddd;
}

.date {
  font-size: 14px;
  opacity: 0.7;
}

.readmore a {
  transition: 0.3s;
}

.readmore a:hover {
  color: #ef3b8a;
}

.role-tabs .nav-link.active img {
  filter: brightness(0) invert(1);
}

.role-tabs .nav-link img {
  max-width: 20px;
  margin-right: 5px;
}

.role-tabs .nav-link {
  padding: 13px 20px;
}

.role-tabs .nav-link:hover img {
  filter: brightness(0) invert(1);
}

.pricing-tabl-button-content {
  display: flex;
  justify-content: center;
  gap: 15px;
}

.pricing-tabl-button-content button {
  background-color: transparent;
  color: #ef3b8a;
  padding: 12px 22px;
  font-size: 15px;
}

.pricing-tabl-button-content button.active {
  background-color: #ef4b8a;
  color: #fff;
}

.pricing-tabl-button-content button:hover {
  background-color: #ef4b8a;
  color: #fff;
}

.icon-card-theme {
  background-color: #fff !important;
  box-shadow: 0px 10px 41px 19px #dadada4f;
  border-radius: 20px;
  border-bottom: 2px solid #fff;
}

.icon-card-theme:hover {
  border-color: #ef4b8a;
}

.price-offcanvas {
  background-color: #3b3250;
  color: #fff;
}

.price-offcanvas h2 {
  color: #fff;
}

.price-offcanvas {
  padding: 50px 0;
  height: auto !important;
}

.price-offcanvas h2 {
  font-size: 40px;
}

.price-offcanvas h4 {
  font-size: 20px;
  color: #fff;
  font-weight: normal;
}

.pricing-button button {
  width: 100%;
  padding: 15px;
}

.single-blog-header h1 {
  font-size: 30px;
}

.single-blog-header .date {
  font-size: 16px;
  font-weight: 600;
}

.single-blog-meta {
  display: flex;
  align-items: center;
  gap: 15px;
}

.single-blog-meta img {
  border-radius: 50px;
  max-width: 50px;
}

.blog-single-content img {
  width: 100%;
}

.blog-single-content img:first-of-type {
  border-radius: 30px;
}

.single-blog-header {
  margin-bottom: 30px;
}

.single-blog-meta {
  margin-bottom: 15px;
}

.blog-single-content {
  padding-bottom: 80px;
}

.blog-meta-content h4 {
  margin: 0;
}

.single-blog-header .date {
  margin-bottom: 25px;
}

@media (max-width: 1199px) {
  .single-blog-header h1 {
    font-size: 30px;
  }
}
@media (width: 768px) {
    .pricing-scroll {
        width: 710px;
    }
}
@media (max-width: 767px) {
  .single-blog-header h1 {
    font-size: 25px;
  }
}

.form-group .checkbox label {
  font-size: 14px;
}

div#book-a-demo input,
div#book-a-demo select {
  padding: 18px 17px;
}

.single-blog-header .date {
  margin-bottom: 15px !important;
}

.single-blog-header {
  margin-bottom: 10px;
}

seciton.blog-single-post {
  margin-top: 50px !important;
  overflow: hidden;
  display: block;
}

.single-blog-header h1 {
  margin-top: 20px;
  font-weight: bold;
}

section.breadcrumb-section {
  background-color: #fff3ee;
  padding: 30px 0;
}

section.breadcrumb-section a.primary-btn {
  border: 1px solid #ef3b8a;
  border-radius: 40px;
  padding: 6px 20px 7px 20px;
  color: #ef3b8a;
  background: #fff;
}

section.breadcrumb-section a.primary-btn:hover {
  color: #fff;
  background: #ef3b8a;
}

section.breadcrumb-section h1 {
  font-size: 40px;
}

.blog-content h2 {
  font-size: 30px;
}

.blog-content h3 {
  font-size: 28px;
}

.blog-content h4 {
  font-size: 24px;
}

.blog-content h5 {
  font-size: 20px;
}

.blog-content h6 {
  font-size: 18px;
}

blockquote {
  border-left: 4px solid #ef3b8a;
  background-color: #efefef;
  padding: 15px;
}

.nursary-title-box {
  width: 100%;
  overflow: hidden;
}

@media (max-width: 991px) {
  .nursary-title-box figure {
    position: absolute;
    max-width: 70px;
    left: 0;
    bottom: 0;
  }

  .nursary-title-box h3 {
    margin-top: 0;
    margin-bottom: 5px;
  }

  .nursary-title-box.title-box-alt figure {
    position: absolute;
    max-width: 70px;
    left: auto;
    right: 0;
    bottom: 0;
  }

  .nursary-title-box .elementor-image-box-content {
    padding: 20px 0;
  }
}

@media (max-width: 767px) {
  .nursary-title-box .elementor-image-box-content {
    padding: 40px 30px;
  }

  .nursary-title-box h3 {
    font-size: 24px !important;
  }
  .pricing-scroll-wrap {
    position: relative;
    overflow: hidden; /* keeps fade overlay fixed */
  }
  .pricing-scroll {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth; /* adds smooth sliding */
    gap: 16px;
    padding: 10px;
    position: relative;
  }
  .pricing-scroll-wrap:after {
    content: "";
    position: absolute;
    right: 0; top: 0; bottom: 0;
    width: 40px; 
    background: linear-gradient(to right, transparent, rgba(255,255,255,1));
    pointer-events: none;
    opacity: 1;
    transition: opacity 0.3s ease;
  }

  .pricing-scroll-wrap:before {
    content: "";
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 40px; 
    background: linear-gradient(to left, transparent, rgba(255,255,255,1));
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 1;
  }

  .pricing-scroll .e-child {
    flex: 0 0 250px; /* adjust to 70–90% if you want more/less of next card visible */
    scroll-snap-align: center;
  }

  .pricing-scroll-wrap.hide-left::before { opacity: 0; }
  .pricing-scroll-wrap.show-left::before { opacity: 1; }
  .pricing-scroll-wrap.hide-right::after { opacity: 0; }
  .pricing-scroll-wrap.show-right::after { opacity: 1; }
  
  /* optional: hide scrollbar */
  .pricing-scroll::-webkit-scrollbar { display: none; }
  .pricing-scroll { scrollbar-width: none; }
}
