/*--------------------------------------------------------------
# General
--------------------------------------------------------------*/
/* Mobile related modifications */
.mobile-show {
	display: none;
}

body {
  font-family: "Open Sans", sans-serif;
  color: #000000;
  line-height: 27px;
  font-size: 17px;
}

/* Paragraph links */
p a:link,
p a:visited {
  font-family: "Open Sans", sans-serif;
  line-height: 27px;
  font-size: 17px;
  text-decoration: underline;
  color: #000000;
}
p a:hover,
p a:active {
  font-family: "Open Sans", sans-serif;
  line-height: 27px;
  font-size: 17px;
  color: #7b297b;
  text-decoration: none;
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
  font-family: "Open Sans", sans-serif; /* FIXED: was "Open San" */
  text-decoration: none !important;
}

a { text-decoration: none; }
p a { text-decoration: underline; }

/*--------------------------------------------------------------
# Preloader
--------------------------------------------------------------*/
#preloader {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  z-index: 9999; overflow: hidden; background: #fff;
}
#preloader:before {
  content: "";
  position: fixed;
  top: calc(50% - 30px); left: calc(50% - 30px);
  border: 6px solid #a536a5; border-top-color: #d2f9eb;
  border-radius: 50%; width: 60px; height: 60px;
  animation: animate-preloader 1s linear infinite;
}
@keyframes animate-preloader {
  0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); }
}

/*--------------------------------------------------------------
# Back to top button
--------------------------------------------------------------*/
.back-to-top {
  position: fixed; visibility: hidden; opacity: 0;
  right: 15px; bottom: 15px; z-index: 996;
  background: #420942; width: 40px; height: 40px; border-radius: 50px;
  transition: all 0.4s;
}
.back-to-top i { font-size: 28px; color: #fff; line-height: 0; }
.back-to-top:hover { background: #7b297b; color: #fff; }
.back-to-top.active { visibility: visible; opacity: 1; }

/*--------------------------------------------------------------
# Disable AOS delay on mobile
--------------------------------------------------------------*/
@media screen and (max-width: 768px) {
  [data-aos-delay] { transition-delay: 0 !important; }
}

/*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/
#header {
  height: 140px; transition: all 0.5s; z-index: 997;
  background: rgba(0, 0, 0, 0.2);
}
#header.header-transparent { background: rgba(0, 0, 0, 0.5); }
#header.header-scrolled { background: rgba(0, 0, 0, 0.9); height: 130px; }

#header .logo h1 {
  font-size: 21px; margin: 0; padding: 0; line-height: 1;
  font-weight: 600; color: #ffffff;
}
#header .logo h1 a, #header .logo h1 a:hover {
  color: #fff; text-decoration: none;
}
#header:not(.header-scrolled) .logo img,
#header.header-scrolled .logo img {
  max-height: 110px; transition: max-height 0.3s ease;
}

/*--------------------------------------------------------------
# Navigation Menu
--------------------------------------------------------------*/
.navbar { padding: 0; }
.navbar ul {
  margin: 0; padding: 0; display: flex; list-style: none; align-items: center;
}
.navbar li { position: relative; }

.navbar a, .navbar a:focus {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 0 10px 30px; font-size: 16px; font-weight: 500;
  font-family: "Open Sans", sans-serif; color: #ffffff; white-space: nowrap; transition: 0.3s;
}
.navbar a i, .navbar a:focus i { font-size: 16px; font-weight: 500; line-height: 0; margin-left: 5px; }

.navbar>ul>li>a:before {
  content: ""; position: absolute; width: 0; height: 2px; bottom: 3px; left: 30px;
  background-color: #7b297b; visibility: hidden; transition: all 0.3s ease-in-out 0s;
}
.navbar a:hover:before, .navbar li:hover>a:before, .navbar .active:before { visibility: visible; width: 25px; }
.navbar a:hover, .navbar .active, .navbar .active:focus, .navbar li:hover>a { color: #fff; font-weight: 500; }

/* Dropdown */
.navbar .dropdown ul {
  display: block; position: absolute; left: 30px; top: calc(100% + 30px);
  margin: 0; padding: 10px 0; z-index: 99; opacity: 0; visibility: hidden;
  background-color: #ffffff; box-shadow: 0 0 30px rgba(127,137,161,0.25);
  transition: 0.3s; border-radius: 4px; font-weight: 500;
}
.navbar .dropdown ul li { min-width: 200px; }
.navbar .dropdown ul a {
  padding: 10px 20px; font-size: 16px; font-weight: 500; text-transform: none; color: #7b297b;
}
.navbar .dropdown ul a i { font-size: 16px; font-weight: 500; }
.navbar .dropdown ul a:hover,
.navbar .dropdown ul .active:hover,
.navbar .dropdown ul li:hover>a {
  color: #FFFFFF; background-color: #a536a5;
}
.navbar .dropdown:hover>ul { opacity: 1; top: 100%; visibility: visible; }
.navbar .dropdown .dropdown ul { top: 0; left: calc(100% - 30px); visibility: hidden; }
.navbar .dropdown .dropdown:hover>ul { opacity: 1; top: 0; left: 100%; visibility: visible; }

@media (max-width: 1366px) {
  .navbar .dropdown .dropdown ul { left: -90%; }
  .navbar .dropdown .dropdown:hover>ul { left: -100%; }
}

.navbar li .btn-get-started { margin-left: 20px; }

/* Mobile */
.mobile-nav-toggle {
  color: #fff; font-size: 28px; cursor: pointer; display: none; line-height: 0; transition: 0.5s;
}
@media (max-width: 991px) {
  .mobile-nav-toggle { display: block; }
  .navbar ul { display: none; }
}
.navbar-mobile {
  position: fixed; overflow: hidden; top: 0; right: 0; left: 0; bottom: 0;
  background: rgba(66, 9, 66, 0.9); transition: 0.3s; z-index: 999;
}
.navbar-mobile .mobile-nav-toggle { position: absolute; top: 15px; right: 15px; }
.navbar-mobile ul {
  display: block; position: absolute; top: 55px; right: 15px; bottom: 15px; left: 15px;
  padding: 10px 0; border-radius: 8px; background-color: #fff; overflow-y: auto; transition: 0.3s;
}
.navbar-mobile>ul>li>a:before { left: 20px; }
.navbar-mobile a, .navbar-mobile a:focus { padding: 10px 20px; font-size: 15px; color: #420942; }
.navbar-mobile a:hover, .navbar-mobile .active, .navbar-mobile li:hover>a { color: #7b297b; }
.navbar-mobile .getstarted, .navbar-mobile .getstarted:focus { margin: 15px; }
.navbar-mobile .dropdown ul, .navbar-mobile .dropdown .dropdown ul {
  position: static; display: none; margin: 10px 20px; padding: 10px 0;
  z-index: 99; opacity: 1; visibility: visible; background: #fff; box-shadow: 0 0 30px rgba(127,137,161,0.25);
}
.navbar-mobile .dropdown ul li, .navbar-mobile .dropdown .dropdown ul li { min-width: 200px; }
.navbar-mobile .dropdown ul a, .navbar-mobile .dropdown .dropdown ul a { padding: 10px 20px; }
.navbar-mobile .dropdown ul a i, .navbar-mobile .dropdown .dropdown ul a i { font-size: 12px; }
.navbar-mobile .dropdown ul a:hover,
.navbar-mobile .dropdown ul .active:hover,
.navbar-mobile .dropdown ul li:hover>a,
.navbar-mobile .dropdown .dropdown ul a:hover,
.navbar-mobile .dropdown .dropdown ul .active:hover,
.navbar-mobile .dropdown .dropdown ul li:hover>a { color: #7b297b; }

.navbar .btn-get-started {
  font-weight: 500; font-size: 14px; display: inline-block; padding: 4px 15px;
  border-radius: 8px; border: 2px solid #7b297b; transition: 0.5s; color: #fff; background: #7b297b;
}
.navbar .btn-get-started:hover { background: #000000; }

/*--------------------------------------------------------------
# Hero Section
--------------------------------------------------------------*/
#hero {
  width: 100%; background: url("../img/hero-bg2.jpg");
  position: relative; padding: 140px 0 0 0;
}
#hero:before {
  content: ""; background: rgba(66, 9, 66, 0.91);
  position: absolute; bottom: 0; top: 0; left: 0; right: 0;
}
#hero p {
  margin: 0 0 40px 0; font-size: 17px; font-weight: 500;
  line-height: 35px; letter-spacing: 1px; color: rgba(255,255,255,0.9);
}
#hero h1 {
  margin: 0 0 40px 0; font-size: 60px; font-weight: 600;
  line-height: 1.05; color: rgba(255,255,255,0.8);
}
#hero h1 span { color: #fff; border-bottom: 3px solid #a536a5; }
#hero h2 {

  margin: 0 0 45px 0; font-size: 20px; font-weight: 500;
  line-height: 35px; color: rgba(255,255,255,0.8);
}
#hero .btn-get-started {
  font-weight: 500; font-size: 15px; display: inline-block; padding: 4px 15px;
  border-radius: 8px; border: 2px solid #7b297b; transition: 0.5s; color: #fff; background: #000000;
}
#hero .btn-get-started:hover { background: #7b297b; border: 2px solid #a536a5; }
#hero .animated { animation: up-down 2s ease-in-out infinite alternate-reverse both; }

@media (min-width: 1024px) { #hero { background-attachment: fixed; } }
@media (max-width: 991px) {
  #hero { padding-top: 145px; }
  #hero .animated { animation: none; }
  #hero .hero-img { text-align: center; }
  #hero .hero-img img { max-width: 80%; }
  #hero h1 { font-size: 28px; line-height: 32px; margin-bottom: 10px; }
  #hero h2 { font-size: 18px; line-height: 24px; margin-bottom: 30px; }
}
@media (max-width: 575px) { #hero .hero-img img { width: 80%; } }

@keyframes up-down { 0% { transform: translateY(10px);} 100% { transform: translateY(-10px);} }
.hero-waves { display: block; margin-top: 60px; width: 100%; height: 60px; z-index: 5; position: relative; }
.wave1 use { animation: move-forever1 10s linear infinite; animation-delay: -2s; }
.wave2 use { animation: move-forever2 8s linear infinite; animation-delay: -2s; }
.wave3 use { animation: move-forever3 6s linear infinite; animation-delay: -2s; }
@keyframes move-forever1 { 0% { transform: translate(85px,0%);} 100% { transform: translate(-90px,0%);} }
@keyframes move-forever2 { 0% { transform: translate(-90px,0%);} 100% { transform: translate(85px,0%);} }
@keyframes move-forever3 { 0% { transform: translate(-90px,0%);} 100% { transform: translate(85px,0%);} }

/*--------------------------------------------------------------
# Sections General
--------------------------------------------------------------*/
section { padding: 40px 0; overflow: hidden; }
.section-bg { background-color: #f5f5ff; }

/* Page Title block */
.section-title { padding-top: 40px; } /* unified top offset */
.section-title h1 {
  font-size: 45px; font-weight: 500; padding: 0;
  line-height: 1.15;             /* FIXED: unitless */
  margin: 0 0 32px 32px;               /* FIXED: clean spacing */
  letter-spacing: 1px; color: #db27db; font-family: "Open Sans", sans-serif;
}
.section-title h2 {
  font-size: 39px; font-weight: 500; padding: 0;
  line-height: 1.2;               /* FIXED: was 1px */
  margin: 0 0 5px 0; letter-spacing: 1px; color: #7b297b; font-family: "Open Sans", sans-serif;
}
.section-title p {
  margin: 0; font-size: 36px; font-weight: 600; text-transform: uppercase;
  font-family: "Poppins", sans-serif; color: #7b297b;
}

/*--------------------------------------------------------------
# Breadcrumbs
--------------------------------------------------------------*/
.breadcrumbs {
  padding: 20px 0; background-color: #fafaff; min-height: 40px; margin-top: 80px;
}
@media (max-width: 992px) { .breadcrumbs { margin-top: 64px; } }
.breadcrumbs h2 { font-size: 24px; font-weight: 400; margin: 0; }
@media (max-width: 992px) { .breadcrumbs h2 { margin: 0 0 10px 0; } }
.breadcrumbs ol {
  display: flex; flex-wrap: wrap; list-style: none; padding: 0; margin: 0; font-size: 14px;
}
.breadcrumbs ol li+li { padding-left: 10px; }
.breadcrumbs ol li+li::before { display: inline-block; padding-right: 10px; color: #6c757d; content: "/"; }
@media (max-width: 768px) {
  .breadcrumbs .d-flex { display: block !important; }
  .breadcrumbs ol { display: block; }
  .breadcrumbs ol li { display: inline-block; }
}

/*--------------------------------------------------------------
# About
--------------------------------------------------------------*/
.about { padding: 0 0 0 0; } /* FIXED: remove extra top pad */
.about .icon-boxes h3 { font-size: 35px; font-weight: 500; color: #7b297b; margin-bottom: 15px; }
.about h3 { font-size: 28px; font-weight: 500; color: #911591; margin-bottom: 8px; }
.about h4, .about h5 { font-size: 21px; font-weight: 500; color: #232323; }
.about h5 { margin-top: 30px; }
.about .icon-box { margin-top: 30px; }
.about .icon-box .icon {
  float: left; display: flex; align-items: center; justify-content: center;
  width: 64px; height: 64px; border: 2px solid #420942; border-radius: 50px; transition: 0.5s;
}
.about .icon-box .icon i { color: #420942; font-size: 32px; }
.about .icon-box:hover .icon { background: #a536a5; border-color: #a536a5; }
.about .icon-box:hover .icon i { color: #fff; }
.about .icon-box .title { margin-left: 85px; font-weight: 700; margin-bottom: 10px; font-size: 18px; }
.about .icon-box .title a { color: #a536a5; transition: 0.3s; font-size: 20px; }
.about .icon-box .title a:hover { color: #42094d; }
.about .icon-box .description { margin-left: 85px; line-height: 24px; font-size: 17px; color: #000000; }
.about .video-box { background: url("../img/about.png") center center no-repeat; background-size: contain; min-height: 300px; }
.about .play-btn {
  width: 94px; height: 94px; background: radial-gradient(#420942 50%, rgba(63, 67, 253, 0.4) 52%);
  border-radius: 50%; display: block; position: absolute; left: calc(50% - 47px); top: calc(50% - 47px); overflow: hidden;
}
.about .play-btn::after {
  content: ""; position: absolute; left: 50%; top: 50%; transform: translateX(-40%) translateY(-50%);
  width: 0; height: 0; border-top: 10px solid transparent; border-bottom: 10px solid transparent; border-left: 15px solid #fff;
  z-index: 100; transition: all 400ms cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.about .play-btn::before {
  content: ""; position: absolute; width: 120px; height: 120px; animation: pulsate-btn 2s forwards infinite steps;
  opacity: 1; border-radius: 50%; border: 5px solid rgba(63,67,253,0.7); top: -15%; left: -15%; background: rgba(198,16,0,0);
}
.about .play-btn:hover::after { border-left: 15px solid #3f43fd; transform: scale(20); }
.about .play-btn:hover::before { content: ""; position: absolute; left: 50%; top: 50%; transform: translateX(-40%) translateY(-50%); width: 0; height: 0; border: none; z-index: 200; animation: none; border-radius: 0; }
@keyframes pulsate-btn { 0% { transform: scale(0.6,0.6); opacity: 1; } 100% { transform: scale(1,1); opacity: 0; } }

/*--------------------------------------------------------------
# Features
--------------------------------------------------------------*/
.features .icon-box {
  display: flex; align-items: center; padding: 20px; background: #f5f5ff; transition: ease-in-out 0.3s;
}
.features .icon-box i { font-size: 32px; padding-right: 10px; line-height: 1; }
.features .icon-box h3 { font-weight: 700; margin: 0; padding: 0; line-height: 1; font-size: 16px; }
.features .icon-box h3 a { color: #010483; transition: ease-in-out 0.3s; }
.features .icon-box h3 a:hover { color: #01036f; }
.features .icon-box:hover { background: #ebebff; }

/*--------------------------------------------------------------
# Counts
--------------------------------------------------------------*/
.counts { background: #f5f5ff; padding: 70px 0 60px; }
.counts .count-box {
  padding: 30px 30px 25px 30px; width: 100%; position: relative; text-align: center; background: #fff;
}
.counts .count-box i {
  position: absolute; top: -25px; left: 50%; transform: translateX(-50%);
  font-size: 20px; background: #a536a5; padding: 12px; color: #fff; border-radius: 50px;
  display: inline-flex; align-items: center; justify-content: center; line-height: 0; width: 48px; height: 48px;
}
.counts .count-box span { font-size: 36px; display: block; font-weight: 600; color: #010483; }
.counts .count-box p { padding: 0; margin: 0; font-family: "Montserrat", sans-serif; font-size: 14px; }

/*--------------------------------------------------------------
# Details
--------------------------------------------------------------*/
.details .content+.content { margin-top: 50px; }
.details .content h2 {
  font-size: 39px; font-weight: 500; padding: 0;
  line-height: 1.2;  /* FIXED: was 1px */
  margin: 0 0 5px 0; letter-spacing: 1px; color: #7b297b; font-family: "Open Sans", sans-serif;
}
.details .content h2:after {
  content: ""; width: 120px; height: 1px; display: inline-block; background: #7b297b; margin: 4px 10px;
}
.details .content h3 { font-weight: 600; font-size: 26px; color: #7b297b; }
.details h4 { font-weight: 500; font-size: 26px; color: #7b297b; margin: 25px 0 0 0; }
.details .content ul { list-style: none; padding: 0; }
.details .content ul li { padding-bottom: 10px; }
.details .content ul i { font-size: 20px; padding-right: 4px; color: #a536a5; }
.details .content p:last-child { margin-bottom: 0; }

/*--------------------------------------------------------------
# Gallery
--------------------------------------------------------------*/
.gallery .gallery-item { overflow: hidden; border-right: 3px solid #fff; border-bottom: 3px solid #fff; }
.gallery .gallery-item img { transition: all ease-in-out 0.4s; }
.gallery .gallery-item:hover img { transform: scale(1.1); }

/*--------------------------------------------------------------
# Testimonials
--------------------------------------------------------------*/
.testimonials {
  padding: 300px 0;
  background: url("../img/cta-bg3.jpg") no-repeat center center / cover;
  position: relative; color: #ffffff; text-align: center;
}
.testimonials::before {
  content: ""; position: absolute; left: 0; right: 0; top: 0; bottom: 0; background: rgba(1, 3, 111, 0.5);
}
.testimonials h3 {
  color: #ffffff; font-size: 24px; line-height: 1.5; margin: 0 auto; max-width: 900px; position: relative; z-index: 1;
}
.testimonials .section-header { margin-bottom: 40px; }
.testimonials .testimonials-carousel, .testimonials .testimonials-slider { overflow: hidden; }
.testimonials .testimonial-item { text-align: center; color: #fff; position: relative; z-index: 1; }
.testimonials .testimonial-item .testimonial-img {
  width: 100px; border-radius: 50%; border: 6px solid rgba(255,255,255,0.15); margin: 0 auto;
}
.testimonials .testimonial-item h3 { font-size: 35px; font-weight: bold; color: #ffffff; margin: 35px 0; }
.testimonials .testimonial-item h4 { font-size: 14px; color: #ddd; margin-bottom: 15px; }
.testimonials .testimonial-item .quote-icon-left,
.testimonials .testimonial-item .quote-icon-right { color: rgba(255,255,255,0.4); font-size: 26px; }
.testimonials .testimonial-item .quote-icon-left { display: inline-block; position: relative; left: -5px; }
.testimonials .testimonial-item .quote-icon-right { display: inline-block; position: relative; right: -5px; top: 10px; }
.testimonials .testimonial-item p { font-style: italic; margin: 0 auto 15px auto; color: #eee; }
.testimonials .swiper-pagination { margin-top: 20px; position: relative; }
.testimonials .swiper-pagination .swiper-pagination-bullet {
  width: 12px; height: 12px; opacity: 1; background-color: rgba(255,255,255,0.4);
}
.testimonials .swiper-pagination .swiper-pagination-bullet-active { background-color: #a536a5; }
@media (min-width: 1024px) { .testimonials { background-attachment: fixed; } }
@media (min-width: 992px) { .testimonials .testimonial-item p { width: 80%; } }

/*--------------------------------------------------------------
# Team
--------------------------------------------------------------*/
.team { background: #fff; }
.team .member { text-align: center; margin-bottom: 15px; position: relative; }
.team .member .pic { border-radius: 4px; overflow: hidden; }
.team .member img { transition: all ease-in-out 0.4s; }
.team .member:hover img { transform: scale(1.1); }
.team .member .member-info {
  position: absolute; bottom: -80px; left: 0; right: 0;
  background: rgba(255,255,255,0.9); padding: 15px 0; border-radius: 0 0 4px 4px;
  box-shadow: 0px 2px 15px rgba(0,0,0,0.1);
}
.team .member h4 {
  font-weight: 700; margin-bottom: 10px; font-size: 16px; color: #01036f; position: relative; padding-bottom: 10px;
}
.team .member h4::after {
  content: ""; position: absolute; display: block; width: 50px; height: 1px; background: #0d12fc;
  bottom: 0; left: calc(50% - 25px);
}
.team .member span { font-style: italic; display: block; font-size: 13px; color: #01036f; }

/*--------------------------------------------------------------
# Pricing
--------------------------------------------------------------*/
.pricing .box {
  padding: 20px; background: #fff; text-align: left; border: 1px solid #000;
  border-radius: 5px; position: relative; overflow: hidden;
}
.pricing h3 {
  font-weight: 400; margin: -20px -20px 20px -20px; padding: 20px 15px;
  font-size: 22px; color: #FFFFFF; background: #f8f8f8;
}
.pricing h4 {
  font-size: 36px; color: #a536a5; font-weight: 600; font-family: "Poppins", sans-serif; margin-bottom: 20px;
}
.pricing h4 sup { font-size: 20px; top: -15px; left: -3px; }
.pricing h4 span { color: #bababa; font-size: 16px; font-weight: 300; }
.pricing ul {
  padding: 0; list-style: none; color: #00000; text-align: left; line-height: 20px; font-size: 16px;
}
.pricing ul li { padding-bottom: 16px; }
.pricing ul i { color: #a536a5; font-size: 18px; padding-right: 4px; }
.pricing ul .na { color: #ccc; text-decoration: line-through; }
.pricing .featured h3 { color: #fff; background: #440f44; }
.pricing .advanced {
  width: 200px; position: absolute; top: 18px; right: -68px; transform: rotate(45deg); z-index: 1;
  font-size: 14px; padding: 1px 0 3px 0; background: #4c0f4c; color: #fff;
}

/*--------------------------------------------------------------
# F.A.Q
--------------------------------------------------------------*/
.faq .faq-list { padding: 0; }
.faq .faq-list ul { padding: 0; list-style: none; }
.faq .faq-list li+li { margin-top: 15px; }
.faq .faq-list li {
  padding: 20px; background: #fff; border-radius: 4px; position: relative;
}
.faq .faq-list a {
  display: block; position: relative; font-family: "Open Sans", sans-serif;
  font-size: 17px; line-height: 24px; font-weight: 600; padding: 0 30px; outline: none; cursor: pointer; color: #a536a5;
}
.faq .faq-list .icon-help { font-size: 24px; position: absolute; right: 0; left: 20px; color: #7b297b; }
.faq .faq-list .icon-show, .faq .faq-list .icon-close { font-size: 24px; position: absolute; right: 0; top: 0; }
.faq .faq-list p { margin-bottom: 0; padding: 10px 0 0 0; }
.faq .faq-list h2 {
  font-family: "Open Sans", sans-serif; font-weight: 500; font-size: 36px; color: #7b297b;
}
.faq .faq-list .icon-show { display: none; }
.faq .faq-list a.collapsed { color: #420942; }
.faq .faq-list a.collapsed:hover { color: #a536a5; }
.faq .faq-list a.collapsed .icon-show { display: inline-block; }
.faq .faq-list a.collapsed .icon-close { display: none; }
@media (max-width: 1200px) { .faq .faq-list { padding: 0; } }

/*--------------------------------------------------------------
# Contact
--------------------------------------------------------------*/
.contact .info { width: 100%; background: #fff; }
.contact .info i {
  font-size: 20px; color: #7b297b; float: left; width: 44px; height: 44px;
  background: #f0f0ff; display: flex; justify-content: center; align-items: center;
  border-radius: 50px; transition: all 0.3s ease-in-out;
}
.contact .info h4 {
  padding: 0 0 0 60px; font-size: 22px; font-weight: 600; margin-bottom: 5px; color: #010483;
}
.contact .info p {
  padding: 0 0 0 60px; margin-bottom: 0; font-size: 14px; color: #0205a1;
}
.contact .info .email, .contact .info .phone { margin-top: 40px; }
.contact .info .email:hover i, .contact .info .address:hover i, .contact .info .phone:hover i { background: #a536a5; color: #fff; }

.contact .php-email-form { width: 100%; background: #fff; }
.contact .php-email-form .form-group { padding-bottom: 8px; }
.contact .php-email-form .error-message {
  display: none; color: #fff; background: #ed3c0d; text-align: left; padding: 15px; font-weight: 600;
}
.contact .php-email-form .error-message br+br { margin-top: 25px; }
.contact .php-email-form .sent-message {
  display: none; color: #fff; background: #18d26e; text-align: center; padding: 15px; font-weight: 600;
}
.contact .php-email-form .loading {
  display: none; background: #fff; text-align: center; padding: 15px;
}
.contact .php-email-form .loading:before {
  content: ""; display: inline-block; border-radius: 50%; width: 24px; height: 24px; margin: 0 10px -6px 0;
  border: 3px solid #18d26e; border-top-color: #eee; animation: animate-loading 1s linear infinite;
}
@keyframes animate-loading { 0% { transform: rotate(0deg);} 100% { transform: rotate(360deg);} }

.contact .php-email-form input, .contact .php-email-form textarea {
  border-radius: 0; box-shadow: none; font-size: 14px;
}
.contact .php-email-form input { height: 44px; }
.contact .php-email-form textarea { padding: 10px 12px; }
.contact .php-email-form button[type=submit] {
  background: #a536a5; border: 0; padding: 10px 30px; color: #fff; transition: 0.4s; border-radius: 50px;
}
.contact .php-email-form button[type=submit]:hover { background: #34e5a6; }

/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/
#footer {
  background: #7b297b; padding: 0 0 30px 0; color: #fff; font-size: 14px;
}
#footer .footer-top { padding: 60px 0 30px 0; }
#footer .footer-top .footer-info {
  margin-bottom: 15px; background: #4c0f4c; color: #fff; border-top: 4px solid #a536a5;
  text-align: center; padding: 25px 5px;
}
#footer .footer-top .footer-info h3 {
  font-size: 24px; margin: 0 0 20px 0; padding: 2px 0; line-height: 1; font-weight: 700;
}
#footer .footer-top .footer-info p {
  font-size: 14px; line-height: 24px; margin-bottom: 0; font-family: "Montserrat", sans-serif;
}
#footer .footer-top .social-links a {
  font-size: 30px; display: inline-block; color: #fff; line-height: 1; padding: 8px 0; margin-right: 4px;
  border-radius: 50%; text-align: center; width: 46px; height: 46px; transition: 0.3s; text-decoration: none;
}
#footer .footer-top .social-links a:hover { background: #a536a5; color: #fff; text-decoration: none; }
#footer .footer-top h4 { font-size: 16px; font-weight: 600; color: #fff; position: relative; padding-bottom: 12px; }
#footer .footer-top .footer-links { margin-bottom: 30px; }
#footer .footer-top .footer-links ul { list-style: none; padding: 0; margin: 0; }
#footer .footer-top .footer-links ul i { padding-right: 2px; color: #ef70ef; font-size: 18px; line-height: 1; }
#footer .footer-top .footer-links ul li { padding: 10px 0; display: flex; align-items: center; }
#footer .footer-top .footer-links ul li:first-child { padding-top: 0; }
#footer .footer-top .footer-links ul a {
  color: #fff; transition: 0.3s; display: inline-block; line-height: 1; text-decoration: underline;
}
#footer .footer-top .footer-links ul a:visited { color: #FFFFFF; text-decoration: underline; }
#footer .footer-top .footer-links ul a:hover { color: #FFFFFF; text-decoration: none; }
#footer .footer-top .footer-links ul a:active { color: #fff; text-decoration: none; }

#footer .footer-top .footer-newsletter form {
  margin-top: 30px; background: #fff; padding: 6px 10px 6px 15px; position: relative; border-radius: 50px;
}
#footer .footer-top .footer-newsletter form input[type=email] {
  border: 0; padding: 4px; width: calc(100% - 110px);
}
#footer .footer-top .footer-newsletter form input[type=submit] {
  position: absolute; top: 0; right: -2px; bottom: 0; border: 0; background: none; font-size: 16px;
  padding: 0 20px; color: #fff; transition: 0.3s; border-radius: 50px;
}
#footer .footer-top .footer-newsletter form input[type=submit]:hover { background: #b838b8; }

#footer .copyright {
  border-top: 1px solid #c04fc0; text-align: center; padding-top: 30px;
}
#footer .credits { padding-top: 10px; text-align: center; font-size: 13px; color: #fff; }

#footer a { color: #fff; text-decoration: underline; }
#footer a:visited { color: #fff; text-decoration: underline; }
#footer a:hover { text-decoration: none; color: #fff; }
#footer a:active { color: #fff; text-decoration: underline; }

/* Footer info paragraph links */
#footer .footer-info p a {
  font-size: 14px; line-height: 24px; color: #fff; text-decoration: underline;
}
#footer .footer-info p a:hover { color: #fff; text-decoration: none; }

@media (max-width: 575px) {
  #footer .footer-top .footer-info { margin: -20px 0 30px 0; }
}

/*--------------------------------------------------------------
# Misc
--------------------------------------------------------------*/
.logo-link { display: flex; align-items: center; text-decoration: none; }
.logo-link img { height: 50px; margin-right: 10px; }
.logo-link h1 { font-size: 24px; margin: 0; color: #000; }

.navbar .dropdown-menu a { text-decoration: none !important; }
.navbar .dropdown-menu a:hover { text-decoration: underline; }

/* Match paragraph link styling for links in the Details list */
.details .content ul a:link,
.details .content ul a:visited {
  font-family: "Open Sans", sans-serif;
  line-height: 27px;
  font-size: 17px;
  text-decoration: underline;
  color: #000000;
}
.details .content ul a:hover,
.details .content ul a:active {
  font-family: "Open Sans", sans-serif;
  line-height: 27px;
  font-size: 17px;
  color: #7b297b;
  text-decoration: none;
}
/* Updated CSS for mobile dropdown functionality */
/* Replace the previous mobile dropdown CSS with this version */

/* Mobile dropdown menu styling - Enhanced version */
.navbar-mobile .dropdown-menu {
  position: static !important;
  float: none !important;
  width: 100% !important;
  margin-top: 0 !important;
  margin-bottom: 10px !important;
  background-color: #f8f9fa !important;
  border: 1px solid #dee2e6 !important;
  border-radius: 4px !important;
  box-shadow: none !important;
  display: none !important; /* Hidden by default */
  padding: 5px 0 !important;
  margin-left: 20px !important;
  margin-right: 20px !important;
  transform: none !important;
  opacity: 1 !important;
  visibility: visible !important;
}

/* Force show when .show class is present */
.navbar-mobile .dropdown-menu.show {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Dropdown items styling */
.navbar-mobile .dropdown-item {
  color: #420942 !important;
  padding: 8px 20px !important;
  display: block !important;
  width: 100% !important;
  clear: both !important;
  font-weight: 400 !important;
  text-align: left !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  background-color: transparent !important;
  border: 0 !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
}

.navbar-mobile .dropdown-item:hover,
.navbar-mobile .dropdown-item:focus {
  color: #7b297b !important;
  background-color: #e9ecef !important;
  text-decoration: none !important;
}

/* Ensure dropdown toggle arrows work in mobile */
.navbar-mobile .dropdown-toggle::after {
  display: inline-block !important;
  margin-left: 0.255em !important;
  vertical-align: 0.255em !important;
  content: "" !important;
  border-top: 0.3em solid !important;
  border-right: 0.3em solid transparent !important;
  border-bottom: 0 !important;
  border-left: 0.3em solid transparent !important;
}

/* Style for mobile nav items */
.navbar-mobile .nav-item {
  margin: 0 !important;
}

.navbar-mobile .nav-link {
  padding: 10px 20px !important;
  color: #420942 !important;
  font-size: 15px !important;
  border-bottom: 1px solid #eee !important;
  display: block !important;
  width: 100% !important;
}

.navbar-mobile .nav-link:hover {
  color: #7b297b !important;
}

.navbar-mobile .dropdown-toggle {
  background: none !important;
  border: none !important;
  width: 100% !important;
  text-align: left !important;
}

/* Fix for mobile menu spacing */
.navbar-mobile ul {
  padding: 10px 0 !important;
}

.navbar-mobile .nav-item:last-child .nav-link {
  border-bottom: none !important;
}

/* Override any conflicting Bootstrap styles */
.navbar-mobile .dropdown-menu {
  inset: unset !important;
  --bs-dropdown-zindex: 1000 !important;
}

/* Ensure proper z-index */
.navbar-mobile {
  z-index: 1001 !important;
}

.navbar-mobile .dropdown-menu {
  z-index: 1002 !important;
}
@media (max-width: 768px) {
	.mobile-center {
		text-align: center;
	}
	.mobile-center ul {
    padding-left: 0 !important;
    margin: 0 auto !important;
    display: inline-block;
    text-align: left; /* keeps icons and text aligned inside each <li> */
  }

  .mobile-center li {
    list-style: none;
    margin-bottom: 8px;
  }
	.mobile-show {
		display: block;
	}
	
	.mobile-hide {
		display: none;
	}
}