@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Vidaloka&display=swap');

body {
  font-family: "Open Sans", sans-serif;
  font-weight: 600;
  overflow-x: hidden; /* Prevent horizontal scroll */
  margin: 0; /* Remove default body margin */
}

.hdd {
  font-family: "Vidaloka", serif;
}

img {
  max-width: 100%;
  height: auto;
  display: block; /* Removes bottom space under images */
}

.main-container {
  /* float: left; Removed */
  width: 100%;
}

/* --- Top Header --- */
.top-header {
    /* Specific styling if needed */
}
.top-left {
  padding: 0;
  text-align: center;
  background: #191654;
}

.top-left-1 {
  color: #57acff;
  font-size: 25px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 0 0 3px;
}

.marquee {
  overflow: hidden;
}

.marquee__inner {
  width: fit-content;
  display: flex;
  position: relative;
  --offset: 1rem;
  --move-initial: calc(-25% + var(--offset));
  --move-final: calc(-50% + var(--offset)); /* Ensure this is defined */
  transform: translate3d(var(--move-initial), 0, 0);
  animation: marquee 5s linear infinite;
  animation-play-state: running;
}

.marquee span {
  white-space: nowrap;
  padding: 11px 25px 8px;
  /* text-shadow: 0 0 20px #57acff; Original */
  animation: animate-text-shadow 0.8s linear infinite;
}

@keyframes animate-text-shadow { /* Renamed from 'animate' */
  0% { text-shadow: 0 0 5px #57acff; }
  50% { text-shadow: 0 0 20px #57acff; }
  100% { text-shadow: 0 0 5px #57acff; } /* Loop back */
}

@keyframes marquee {
  0% { transform: translate3d(var(--move-final), 0, 0); }
  100% { transform: translate3d(var(--move-initial), 0, 0); }
}

/* .top-left-1 p was likely for the marquee text, animation moved to .marquee span */
/* If .top-left-1 p exists for other text, style it here. */

.top-right {
  padding: 0 5px 10px;
  position: relative;
  margin-bottom: -68px;
  /* float: right; Let Bootstrap columns handle this */
}

.top-right:before {
  position: absolute;
  content: '';
  left: 0;
  top: 0;
  width: 100%;
  height: 75%;
  display: block;
  background-color: #57acff;
}

.top-right-1 {
  position: relative;
  text-align: center;
}

.top-right-1 p {
  color: #ffffff;
  font-size: 23px;
  font-weight: 600;
  text-transform: capitalize;
  padding: 6px 15px 5px;
  text-align: center;
  background: #191654;
}

.toplist1 ul { /* Remove Bootstrap utility class p-0 m-0 if not available */
    padding: 0;
    margin: 0;
}
.toplist1 ul li {
  padding: 7px 15px 63px;
  display: inline-block;
  position: relative;
  font-size: 18px;
  color: #000;
  text-align: center;
  text-transform: capitalize;
  font-weight: 700;
}

.toplist1 li span {
  position: absolute;
  height: 52px;
  width: 52px;
  bottom: 0;
  color: #fff;
  right: 0;
  margin: 0 auto;
  left: 0;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  border: 4px solid #000;
  font-size: 21px;
  box-shadow: 0 0 0 6px #ffffff;
  background: #191654;
}

/* --- Head Branding Section --- */
.head-branding {
    padding-top: 10px;
    padding-bottom: 10px;
}
.head-align { /* On Bootstrap .row */
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
}

.head-left1 { padding: 0; }
.head-right1 { padding: 0; text-align: right; }

.head-right2 {
  display: flex;
  align-items: center;
  justify-content: flex-end; /* Corrected from 'right' */
  margin-top: 70px;
}

.head-left2 img {
  margin-top: -20px;
}

.head-right2 .head-call {
  text-transform: capitalize;
  font-size: 35px;
  font-weight: 800;
  padding: 0 15px 0 0;
  animation: text-color-change-animation 1s infinite; /* Renamed from bounce */
  color: #191654; /* Initial animation color */
  display: inline-block;
  text-decoration: none;
}

@keyframes text-color-change-animation { /* Renamed from bounce */
  0% { color: #191654; }
  50% { color: #000; }
  100% { color: #191654; }
}

.head-right2 .head-text {
  text-transform: capitalize;
  font-size: 21px;
  font-weight: 500;
  color: #ffffff;
  padding: 1px 23px 2px;
  background: #191654;
  display: inline-block;
  border-radius: 40px;
}

/* --- Headline Section --- */
.headline-sec {
  padding: 0; /* Bootstrap 3 does not have px-2 */
  background: #57acff; /* Initial */
  animation: blink-background 1s infinite; /* Renamed from blink */
}

@keyframes blink-background { /* Renamed from blink */
  0% { background-color: #191654; }
  50% { background-color: #000; }
  100% { background-color: #191654; }
}

.headline-left1 { padding: 0; }
.headline-left2 span {
  font-weight: 700;
  padding: 0 0 3px;
  font-size: 25px;
  text-transform: capitalize;
  display: inline-block;
  color: #ffffff;
  margin-top: 5px;
}

.headline-right1 { padding: 0; }
.headline-right2 span {
  font-weight: 900;
  padding: 4px 15px;
  color: #191654;
  font-size: 25px;
  text-transform: uppercase;
  display: block;
  background: #57acff;
  text-align: center;
}

/* --- Reusable Services Heading --- */
.services-heading {
  text-align: center;
  padding: 0;
  margin-bottom: 30px;
}

.services-heading p { margin: 0; }
.services-heading p span {
  height: 2px;
  display: inline-block;
  margin: 0 0 3px;
  width: 50px;
  position: relative;
  background: linear-gradient(45deg, #98ffeb, #57acff);
}

.services-heading p span:before {
  height: 20px;
  width: 20px;
  position: absolute;
  content: "";
  top: -9px;
  background: linear-gradient(45deg, #98ffeb, #57acff);
  left: 0;
  border-radius: 50px;
}

.services-heading i {
  background: linear-gradient(45deg, #98ffeb, #57acff);
  color: #000;
  padding: 7px 20px;
  text-shadow: 1px -1px 6px #191654;
  display: inline-block;
  font-size: 15px;
  font-style: normal;
  letter-spacing: 1px;
  font-weight: 600;
  text-transform: uppercase;
}

.services-heading p .bgicon-right:before {
  height: 20px;
  width: 20px;
  position: absolute;
  content: "";
  top: -9px;
  background: linear-gradient(45deg, #98ffeb, #57acff);
  /* left: 0px; Replaced by right:0 */
  border-radius: 50px;
  right: 0;
  /* left: auto; Not needed */
}

.services-heading strong.hdd { /* Added .hdd for font */
  font-size: 47px;
  /* font-weight: 600; From body */
  display: block;
  text-transform: capitalize;
  color: #191654;
  margin-top: 5px;
}

/* --- Banner Sections (banner1.jpg, banner2.jpg) --- */
.banner-main, .banner-secondary, .banner-tertiary {
    padding: 10px 0; /* Example */
}
.banner3 img {
    width: 100%; /* Ensure banner images are responsive */
}


/* --- Mid Section (About Us) --- */
.mid-section {
  padding: 50px 0 0; /* Only top padding here */
  /* float: left; width: 100%; Removed */
}

.mid-section1-wrapper { /* Was .mid-section1 which was col-*-12 */
    /* Add padding if needed for this wrapper */
}

.midsection-left1 { padding: 0; }
.midsection-left2 { padding: 0 30px 50px 0; }

.form-section {
  /* padding: 0; This is a flex container */
  display: flex;
  justify-content: center;
  align-items: center;
}

.whatsapp-left1 { padding: 0; }
.whatsapp-left1 img { border-radius: 8px; }

.form-section1 { /* col-*-10 for image area */
  padding: 60px 0 31px;
  border-radius: 20px; /* This applies to what was .form-section1, if it's a visual block */
}

.aboutus-image {
  text-align: center;
  padding: 0;
  overflow: visible; /* Allow round-image to be fully visible if it 'overflows' this div bounds */
  margin: -110px 0 0;
  position: relative; /* For z-index of children */
  z-index: 1;
}

.aboutus-image .mata-ji {
  display: block;
  margin: 0 auto;
  width: 70%;
  position: relative;
  z-index: 2;
}

.aboutus-image .round-image {
  position: absolute;
  left: 0;
  top: 141px;
  height: 305px;
  right: 0;
  margin: 0 auto;
  z-index: 1; /* Behind mata-ji */
  animation: rotation 15s linear infinite;
}

@keyframes rotation {
  0% { transform: rotate(0); }
  100% { transform: rotate(1turn); }
}

.midsection-right1 { padding: 0; }
.midsection-right2 { padding: 0; }

.aboutus-design {
  padding: 0 0 50px 30px;
  position: relative; /* Ensure it's above any potential overlaps from left */
  z-index: 2;
}

.aboutus-heading { padding: 0; text-align: left; }
.aboutus-heading p { margin: 0; position: relative; z-index: 9; }
.aboutus-heading p i { /* Same as .services-heading i */
  background: linear-gradient(45deg, #98ffeb, #57acff); color: #000; padding: 7px 20px;
  text-shadow: 1px -1px 6px #57acff; display: inline-block; font-size: 15px;
  font-style: normal; letter-spacing: 1px; font-weight: 600; text-transform: uppercase;
}
.aboutus-heading p span { /* Same as .services-heading p span */
  height: 2px; display: inline-block; margin: 0 0 3px; width: 50px;
  position: relative; background: linear-gradient(45deg, #98ffeb, #57acff);
}
.aboutus-heading p span:before { /* Right aligned dot */
  height: 20px; width: 20px; position: absolute; content: ""; top: -9px;
  background: linear-gradient(45deg, #98ffeb, #57acff); right: 0; border-radius: 50px;
}

.aboutus-heading h1.hdd { /* Added .hdd */
  font-size: 40px; padding: 10px 0 0; color: #191654;
  display: block; text-transform: capitalize; margin: 0 0 10px;
}
.aboutus-heading h1 a { color: #191654; text-decoration: none; }
.aboutus-heading h1 a:hover { color: #57acff; }

.about-design { padding: 16px 0 0; text-align: left; }
.about-design p {
  color: #000000; font-size: 15px; padding: 0 0 10px; margin: 0; line-height: 30px;
}
.about-design p:last-of-type { padding-bottom: 20px; } /* Space before button */
.about-design p strong { color: #191654; font-weight: 700; }
.about-design a {
  color: #000; text-shadow: 1px -1px 6px rgba(0,0,0,0.3); font-size: 17px;
  display: inline-block; font-weight: 500; border-radius: 30px 0 0 30px;
  background: #57acff; padding: 8px 23px; margin: 0; text-transform: capitalize;
  letter-spacing: 1px; text-decoration: none; transition: background-color 0.3s ease, color 0.3s ease;
}
.about-design a:hover { background-color: #191654; color: #fff; }


/* --- Marksection Callout --- */
.marksection-callout { /* Renamed from .marksection */
  padding: 0; background: #191654;
}
.marksection1 { padding: 40px 0 30px; }
.mark-left1 { padding: 0; text-align: center; }
.mark-left2 { padding: 10px; position: relative; display: inline-block; }
.mark-left2:before {
  background: #57acff; content: ""; position: absolute; height: 110px;
  width: 100%; left: 0; top: 34px; z-index: 0;
}
.mark-left2 span {
  height: 150px; width: 150px; display: flex; justify-content: center; align-items: center;
  background: #57acff; text-align: center; position: relative; border-radius: 50%;
  z-index: 9; margin: 0 auto;
}
.mark-left2 span:before {
  height: 120px; width: 120px; background: #ffffff; content: ""; position: absolute;
  border-radius: 50%; z-index: -1;
}
.mark-left2 span img { height: 67px; width: auto; }
.mark-right1 { padding: 0; }
.mark-right2 { padding: 0; text-align: center; color: #fff; }
.mark-right2 strong.hdd { /* Added .hdd */
  padding: 0; display: block; font-size: 50px; color: #b5fff1;
  text-transform: capitalize; margin: 0;
}
.mark-right3 {
  padding: 10px 0 0; color: #fff; display: flex; justify-content: center;
  align-items: center; flex-wrap: wrap;
}
.mark-right3 p {
  width: 60%; padding: 0 20px 10px 0; font-size: 17px; line-height: 34px;
  text-transform: capitalize; margin: 0;
}
.mark-right3 a {
  width: 40%; line-height: 71px; padding: 0; background: #b5fff1; font-size: 41px;
  font-weight: 500; color: #191654; text-transform: capitalize; display: block;
  text-align: center; text-decoration: none; transition: background-color 0.3s ease;
}
.mark-right3 a:hover { background-color: #87ccf1; }


/* --- Best Services Section (First Image Style) --- */
.best-services-section { /* Renamed from .best-ser */
  width: 100%; padding: 50px 0; overflow: hidden;
}
.best-services1 { /* col-sm-4 */
  padding: 0 15px; /* Use BS column padding */
  margin-top: 70px;
  margin-bottom: 70px;
}
.best-services2 { /* Card */
  padding: 0 20px 20px;
  border: 2px solid #191654;
  text-align: center;
  overflow: hidden;
  background: linear-gradient(to bottom, #c1f6ed, #79c0f2);
  border-radius: 30px 30px 250px 250px; /* Large pixel values for deep curve */
  position: relative;
  padding-bottom: 70px;
  display: flex;
  flex-direction: column;
  min-height: 430px; /* Adjust this height */
  box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}
.best-services3 { /* Image Frame */
  width: 130px; height: 130px;
  margin: -65px auto 20px;
  background-color: #fff;
  border-radius: 50%;
  border: 3px solid #191654; /* Dark outline around white frame */
  padding: 8px; /* Creates thick white border inside dark outline */
  box-sizing: border-box;
  display: flex; justify-content: center; align-items: center;
  position: relative; z-index: 2;
}
.best-services3 img {
  width: 100%; height: 100%; object-fit: cover;
  border-radius: 50%; display: block;
}
.best-services4 { /* Text content */
  padding: 0 15px; flex-grow: 1; z-index: 1; margin-top: 10px;
}
.best-services4 strong.hdd { /* Added .hdd */
  font-size: 26px; text-transform: capitalize; margin: 0 0 10px;
  display: block; color: #191654;
}
.best-services4 p {
  color: #222; line-height: 1.65; margin: 0;
  padding: 0 0 15px; font-size: 14px;
}
.best-services5 { /* Button Container */
  width: 110px; height: 110px;
  position: absolute; bottom: -55px; left: 50%;
  transform: translateX(-50%); z-index: 3;
}
.best-services5 a { /* Button */
  display: flex; justify-content: center; align-items: center;
  width: 100%; height: 100%; background: #191654; border-radius: 50%;
  font-size: 16px; color: #fff; text-transform: capitalize; text-decoration: none;
  font-weight: 600; box-shadow: 0 2px 5px rgba(0,0,0,0.2);
  transition: background-color 0.3s ease, transform 0.2s ease;
  border: 3px solid #fff; box-sizing: border-box;
}
.best-services5 a:hover { background-color: #0d0b2b; transform: scale(1.03); }

/* --- Why Choose Us Section (Astrology Solutions) --- */
.why-choose-us-section { /* Renamed from .whychoose-section */
    padding: 50px 0;
}
.whychoose-section1-wrapper { /* Renamed from .whychoose-section1 (if it's a wrapper) */
    /* Add padding if this is a full-width wrapper and not a BS column */
}
.chooseus-left1 { padding: 0; }
.chooseus-left2 { padding: 0; }
.choose-us { padding: 20px 0 0; position: relative; }
.choose-us:before { /* Top dot casing */
  content: ""; height: 60px; width: 60px; position: absolute; border-radius: 50%;
  top: -2px; left: 20px; background: #fff; z-index: 9;
}
.choose-us:after { /* Top dot inner */
  content: ""; height: 40px; width: 40px; border-radius: 50%; left: 30px; top: 9px;
  position: absolute; z-index: 99;
  box-shadow: inset 0.2em 0.2em 0.2em 0 rgb(46 112 169), inset -0.2em -0.2em 0.2em 0 rgb(98 180 254);
  background: #5fb1fe; border: 4px solid #87ccf1;
}
.choose-us1 { padding: 10px 0; position: relative; }
.choose-us1:before { /* Bottom dot casing for item */
  content: ""; height: 60px; width: 60px; position: absolute; border-radius: 50%;
  bottom: -30px; left: 20px; background: #fff; z-index: 9;
}
.choose-us2 { /* Item content box */
  padding: 20px 13px 30px 100px; display: flex;
  background: linear-gradient(45deg, #cbfff5, #57acff);
  justify-content: flex-start; align-items: center; /* Corrected from 'left' */
  border-radius: 0 10px 10px 0; position: relative;
}
.choose-us2:after { /* Bottom dot inner for item */
  content: ""; height: 40px; width: 40px; border-radius: 50%; left: 30px;
  bottom: -20px; /* Adjusted alignment */
  position: absolute; z-index: 99;
  box-shadow: inset 0.2em 0.2em 0.2em 0 rgb(46 112 169), inset -0.2em -0.2em 0.2em 0 rgb(98 180 254);
  background: #5fb1fe; border: 4px solid #87ccf1;
}
.choose-text { width: 80%; text-align: left; }
.choose-text strong.hdd { /* Added .hdd */
  font-size: 37px; /* font-weight: 700; */ text-transform: capitalize; display: block;
  border-bottom: 1px solid #eee; -webkit-text-stroke-width: 0.4px;
  -webkit-text-stroke-color: white; color: #191654; /* Ensure color */
  margin-bottom: 10px;
}
.choose-text p { color: #000; font-size: 15px; margin: 0; padding: 0; line-height: 30px; }
.choose-image { padding: 0; text-align: center; width: 20%; }
.choose-image span {
  display: flex; justify-content: center; align-items: center;
  height: 100px; width: 100px; border-radius: 50%;
  background: #fff; margin: 0 auto;
}
.choose-image span img { height: 63px; width: auto; }
.chooseus-right1 { padding: 0; position: relative; height: 100%; } /* Ensure it spans height */
.chooseus-right1:before {
  background: url(../images/sidebg.jpg) no-repeat center center / cover; content: "";
  right: 0; top:0; height: 100%; width: 70%; position: absolute; z-index: -9;
}
.chooseus-right1:after {
  background: #191654eb; content: ""; width: 70%; height: 100%;
  right: 0; top:0; position: absolute; z-index: -8; /* Above image, below content */
}
.chooseus-right2 { padding: 70px 0; position: relative; z-index: 1; }
.choose-banner { padding: 20px 0 0 40px; }
.choose-banner:first-child { padding-top: 0; }
.choose-banner img { border: 3px solid #fff; border-radius: 30px; }

/* --- Stats Section --- */
.stats-section { /* Renamed from .chooseus-section */
  padding: 20px 0; background-color: #f0f0f0; /* Example */
}
/* .chooseus-section1 is the .row for these .pick-1 items */
.pick-1 { /* col-*-3 */
  overflow: hidden; padding: 40px 10px; position: relative;
}
.pick-2 { padding: 0; text-align: center; position: relative; }
.pick-2:before { /* Dot on top */
  top: -13px; width: 28px; height: 28px; border-radius: 50%; content: "";
  position: absolute; left: 50%; transform: translateX(-50%);
  background: #222; border: 6px solid #fff; z-index: 99;
}
.pick-3 { /* Circular content area */
  height: 244px; background: #fff; width: 245px; border: 0; text-align: center;
  border-radius: 50%; margin: 0 auto; padding: 20px; overflow: hidden;
  display: flex; flex-direction: column; justify-content: center; align-items: center;
}
.pick-3 span { /* Icon wrapper */
  height: 87px; width: 87px; display: flex; justify-content: center; align-items: center;
  background: linear-gradient(45deg, #98ffeb, #57acff);
  border-radius: 0 0 50% 50%; margin: 0 auto 10px;
}
.pick-3 span img { height: 45px; width: auto; /* filter: brightness(0) invert(0); default */ }
.pick-3 strong.hdd { /* Added .hdd */
  font-size: 20px; margin: 10px 0 5px; /* font-weight: 700; */
  display: block; text-transform: capitalize; color: #191654;
}
.pick-3 p { color: #000; font-size: 14px; line-height: 22px; margin: 0; }
.pick-2 .round-pick1 { /* Rotating BG image */
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  overflow: hidden; z-index: -1; animation: rotation 15s linear infinite;
  width: 280px; height: 280px; /* Ensure it's larger than .pick-3 */
}
.pick-12 { margin-top: 100px; }


/* --- Awards & Achievements Section --- */
.awards-achievements-section { /* Renamed from .award */
  width: 100%; padding: 50px 0;
}
.awards { /* col-sm-4 content */
  width: 100%; margin-top: 30px; text-align: center;
}
.awards img {
  display: inline-block; border: 1px solid #ddd; padding: 5px;
  background-color: #fff; box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

/* --- Promo Banner Section (Side images like side3.jpg) --- */
.promo-banner-section { /* Renamed from .banner-section */
  padding: 0; position: relative;
}
.promo-banner-section:before { /* Left decorative strip */
  height: 100%; width: 17%; position: absolute; background: #cbfff5; content: "";
  z-index: -9; left: 100px; top: 0; border-radius: 0;
}
.promo-banner-section:after { /* Right decorative strip */
  height: 100%; width: 16%; position: absolute; background: #cbfff5; content: "";
  z-index: -9; right: 100px; top: 0; border-radius: 0;
}
.banner-section1-content { /* Renamed from .banner-section1 */
  padding: 80px 0;
}
.banner-1 { padding: 0; } /* This is a col-*-6 */
.banner-2 { padding: 0; text-align: center; } /* Image wrapper */
.banner-2 img { display: inline-block; border: 2px solid #eee; /* Example */ }
.banner-11 { padding-top: 30px; }


/* --- More Services Section (Second Image Style) --- */
.more-services-section { /* Renamed from .ourservices-section */
  padding: 70px 0; /* Increased top/bottom padding */
  background: #191654;
  width: 100%;
}
/* .ourservices-section1 is the .row for these cards */
.our-services1 { /* col-sm-6 col-md-4 */
  padding: 0 15px; /* Rely on BS column padding or adjust if needed */
  margin-bottom: 70px;
}
.our-services2 { /* Card */
  text-align: center; padding: 0 20px 20px; position: relative; height: 100%;
  display: flex; flex-direction: column;
  background: linear-gradient(to bottom, #c1f6ed, #79c0f2);
  border-radius: 30px 30px 250px 250px; /* Deep curve */
  border: 2px solid #191654;
  overflow: hidden;
  min-height: 430px; /* Adjust */
  padding-bottom: 60px; /* Space for button */
  box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}
.our-services3 { /* Image Frame */
  width: 130px; height: 130px; margin: -65px auto 20px;
  background-color: #f0f0f0; /* Light gray/off-white outer border */
  border-radius: 50%; padding: 4px; /* This padding is the gray border thickness */
  box-sizing: border-box; display: flex; justify-content: center; align-items: center;
  position: relative; z-index: 2;
}
.our-services3 img { /* Actual image */
  width: 100%; height: 100%; object-fit: cover; border-radius: 50%;
  display: block; border: 2px solid #fff; /* Thin white border */
  box-sizing: border-box;
}
.our-services4 { /* Text and button wrapper */
  padding: 0 15px; position: relative; z-index: 1; margin-top: 10px;
  flex-grow: 1; display: flex; flex-direction: column;
}
.our-services_4 { /* Innermost text & button positioner */
  padding: 0; position: relative; padding-bottom: 50px; /* Space for button */
  display: flex; flex-direction: column; height: 100%; flex-grow: 1;
}
.our-services_4 strong.hdd { /* Added .hdd */
  background: none; /* Text directly on card gradient */
  display: block; font-size: 24px; padding: 10px 15px 5px;
  color: #191654; text-transform: capitalize; margin-bottom: 10px;
  font-weight: 700;
}
.our-services_4 strong.hdd span { display: block; }
.our-services_4 p {
  color: #222; /* Darker text for readability */
  font-size: 14px; margin: 0; padding: 0 10px 15px;
  line-height: 1.65; flex-grow: 1;
}
.our-services_4 a { /* Button */
  background: #191654; color: #fff; display: flex; justify-content: center; align-items: center;
  width: 100px; height: 100px; font-size: 16px; border-radius: 50%;
  font-weight: 600; text-transform: capitalize; text-decoration: none;
  position: absolute; left: 50%; transform: translateX(-50%);
  bottom: -50px; /* Half out */
  box-shadow: 0 2px 5px rgba(0,0,0,0.2);
  transition: background-color 0.3s ease, transform 0.2s ease;
  /* border: none; or 1px solid #191654; */
}
.our-services_4 a:hover {
  background-color: #0d0b2b; transform: translateX(-50%) scale(1.03);
}

/* --- Testimonials Section --- */
.testimonials-section { /* Renamed from .award */
    padding: 50px 0; background-color: #f9f9f9;
}
.testimonials1 { /* col-sm-4 */
  padding: 10px;
}
.testimonials2 { /* Card */
  background-color: #191654; position: relative; text-align: center;
  padding: 0 10px 20px; box-shadow: 0 1px 6px rgb(32 33 36 / 28%);
  margin-top: 60px; /* Increased for image overlap */
  border-radius: 8px; height: 100%; display: flex; flex-direction: column;
}
.testi-pic { /* Image Container */
  width: 120px; height: 120px; padding: 0;
  background: linear-gradient(45deg, #98ffeb, #57acff);
  text-align: center; margin: -60px auto 0; /* Pull up by half height */
  position: relative; z-index: 1; border-radius: 50%;
  display: flex; justify-content: center; align-items: center;
}
.testi-pic img {
  border-radius: 50%; border: 6px solid #191654;
  height: 100px; width: 100px; display: block;
}
.testimonials3 { /* Text content */
  padding: 20px 13px 0; position: relative; flex-grow: 1;
}
.testimonials3 strong {
  color: #ffffff; font-weight: 600; font-size: 18px;
  text-transform: capitalize; display: block; margin-bottom: 5px;
}
.testimonials3 i { /* For location, assuming <i>Location</i> in HTML */
  color: #98ffeb; font-style: normal; font-size: 14px; display: block;
  text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px;
}
.testimonials3 span { /* For stars */
  color: #fff; display: block; margin-bottom: 15px; font-size: 16px;
}
.testimonials3 span .fa-star { margin: 0 2px; } /* Space between stars */
.testimonials3 p {
  color: #ffffff; font-size: 15px; padding: 0;
  line-height: 28px; text-align: center; margin: 0;
}

/* --- Footer --- */
footer { /* Renamed from .footer */
  padding: 42px 15px 0; background: #191654; color: #fff;
}
footer .head-align { align-items: center; } /* Override for footer alignment */
.footer-left { padding: 0; }
.footer-left-1 { padding: 0; text-align: center; }
.foot-contac { padding: 0 28px; }
.foot-leftt { padding: 0; }
.foot-leftt-1 { padding: 0 25px 0 0; }
.foot-leftt-1 img { background: #fff; border-radius: 12px; padding: 5px; }
.foot-rightt { padding: 0; }
.foot-rightt-1 { padding: 0; }
.footer-about {
  padding: 0 0 0 27px; text-align: left;
  border-left: 1px dashed #ffffff2e; height: 100%; /* Try to match logo column height */
}
.footer-about span { /* "about us" title */
  text-align: center; padding: 2px 18px; font-size: 21px; font-weight: 600;
  line-height: 31px; color: #000; text-transform: capitalize;
  background: #57acff; border-radius: 40px 40px 0 0; /* Adjusted radius */
  display: inline-block; margin-bottom: 10px;
}
.footer-about p {
  padding: 0; font-size: 15px; font-weight: 300;
  line-height: 33px; color: #fff; margin-bottom: 0;
}
.footer-about p strong { color: #57acff; font-weight: 600; }
.footer-right { padding: 0 0 0 20px; }
.footer-right-1 { padding: 0; }
.footer-contact1 { padding: 0 5px; }
.footer-contact2 { padding: 20px 4px; text-align: center; }
.footer-contact2 span { /* Icon wrapper */
  height: 85px; width: 85px; display: flex; justify-content: center; align-items: center;
  border-radius: 50%; background: #57acff; text-align: center; margin: 0 auto;
  animation: calla 0.8s linear infinite; /* Re-using calla animation */
  outline: #57acff solid 2px; border: 6px solid #191654;
  color: #191654; font-size: 34px;
}
.footer-contact2 span i { font-weight: 600; } /* Makes icon bold if font supports */
.footer-contact2 strong {
  display: block; color: #57acff; padding: 26px 0 5px; font-size: 16px;
  text-transform: capitalize; font-weight: 500;
}
.footer-contact2 a {
  display: block; padding: 0; border-radius: 60px; font-size: 18px;
  color: #fff; text-decoration: none; transition: color 0.3s ease;
}
.footer-contact2 a:hover { color: #98ffeb; }

.dis-sec { padding: 0; } /* Copyright section row */
.copyryt {
  padding: 15px 0; position: relative; z-index: 0; text-align: center;
}
.copyryt span {
  font-size: 16px; font-weight: 700; line-height: 30px; color: #000000;
  text-align: center; padding: 5px 47px 3px; display: inline-block;
  background: #57acff; clip-path: polygon(9% 0%, 91% 0%, 100% 100%, 0% 100%);
}

/* Fixed Call/WhatsApp Buttons */
/* Keyframes pulsate, callb (unused), calla are defined above */
.call a i, .whatsapp a i { line-height: 60px; /* If not using flex for button link */ }

@keyframes pulsate { /* General purpose scaling pulse */
    0% { transform: scale(0.9, 0.9); opacity: 1; }
    50% { transform: scale(1.2, 1.2); opacity: 1; }
    100% { transform: scale(0.9, 0.9); opacity: 1; }
}

@keyframes calla { /* Shadow pulse */
    0% { box-shadow: 0 0 0 4px rgba(162, 162, 162, 0.8); }
    20% { box-shadow: 0 0 0 6px rgba(162, 162, 162, 0.6); }
    40% { box-shadow: 0 0 0 8px rgba(162, 162, 162, 0.4); }
    60% { box-shadow: 0 0 0 10px rgba(162, 162, 162, 0.2); }
    80% { box-shadow: 0 0 0 12px rgba(162, 162, 162, 0.1); }
    100% { box-shadow: 0 0 0 14px rgba(162, 162, 162, 0); }
}

.call, .whatsapp {
    position: fixed; z-index: 999999; bottom: 20px; display: inline-block;
    font-size: 30px; text-align: center; height: 60px; width: 60px;
    border: 1px solid #000; /* Corrected from border-radius: 1px solid #000; */
    animation-name: calla; animation-duration: 0.8s; animation-iteration-count: infinite;
    line-height: 60px; /* Fallback if flex on 'a' fails */
    border-radius: 50%; transition: transform 0.3s ease;
}
.call a, .whatsapp a { /* Make the link fill the button and center icon */
    display: flex; justify-content: center; align-items: center;
    width: 100%; height: 100%; text-decoration: none; color: #fff;
}
.call:hover, .whatsapp:hover { transform: scale(1.1); }

.call { left: 20px; background: #df0505; }
.whatsapp { right: 20px; background: #03A437; }

/* --- Media Queries (Consolidated and refined) --- */
@media(min-width:992px) and (max-width:1200px){ /* Large Desktops */
  .head-left2 img { margin-top: 50px; }
  .head-right1 { margin-top: -50px; } /* Pulls up contact info */
  .our-services_4 a { padding: 6px 10px; line-height: normal; font-size: 14px; }
}

@media(min-width:768px) and (max-width:991px){ /* Tablets */
  .awards-achievements-section .col-sm-4 { width: 50%; float: left; } /* BS3 two-column */
  .our-services_4 a { padding: 6px 10px; line-height: normal; font-size: 14px; }
  .best-services-section .col-sm-4 { width: 50%; float: left; } /* BS3 two-column */
  .head-left2 img { margin-top: 50px; }
  .head-right1 { margin-top: -50px; }
  .top-right { margin-bottom: -40px; }
  .toplist1 ul li { padding: 7px 10px 50px; font-size: 16px; }
  .toplist1 li span { height: 45px; width: 45px; font-size: 18px; }
}

@media(max-width:767px){ /* Mobile - General */
  .head-left2 img { margin-top: 30px; }
  .head-right2 { display: block; margin-top: 20px; text-align: center; }
  .head-right2 .head-call { display: block; margin:0 auto 10px; padding-right: 0;}
  .head-right2 .head-text { display: inline-block; }

  .services-heading strong.hdd,
  .aboutus-heading h1.hdd { font-size: 35px; }
  .mark-right2 strong.hdd { font-size: 30px; }
  .mark-right3 p, .mark-right3 a { width: 100%; margin-bottom: 10px; padding-right:0; }
  .mark-right3 a { line-height: 60px; font-size: 30px; }

  .chooseus-right1 { display: none; } /* Hide side images */
  .why-choose-us-section .chooseus-left1 { width: 100%; /* Make left side full width */ }

  .pick-12 { margin-top: 20px !important; /* Force if needed */ } /* !important from old code */

  .top-right { margin-bottom: 0; float: none; width: 100%; }
  .top-right:before { display: none; }
  .top-right-1 p { font-size: 20px; }
  .toplist1 { display: none; }
  
  footer .head-align { display: block; } /* Stack footer columns */
  .footer-left, .footer-right { width: 100%; text-align: center; margin-bottom: 20px;}
  .footer-about { border-left: none; padding: 0 15px; text-align: center;} /* Centered about for mobile */
  .foot-leftt-1 img { margin: 0 auto; }
  .footer-contact1 { margin-bottom: 15px; }

  .best-services1, .our-services1, .testimonials1, .awards .col-sm-4 {
      width: 100%; /* Stack cards */
      float: none;
  }
  .best-services2, .our-services2 { min-height: auto; } /* Allow height to adjust */

  /* For .pick-1 items in stats section if they are col-*-3 */
  .stats-section .pick-1 { width: 50%; float: left; }
  .stats-section .pick-1:nth-child(odd) { clear: left; } /* Clear for 2-column layout */


}

@media(max-width:639px) { /* Small Phones */
  .whatsapp-left1 { display: none; }
  .form-section { display: block; } /* Stack image and about us text */
  .aboutus-image .round-image { top: 15px; height: 200px; }
  .midsection-right2 { padding-left: 0; } /* Remove left padding if about us design is centered */
  .aboutus-design { padding-left: 15px; padding-right: 15px; }


  .choose-us2 {
    padding: 20px 15px 30px; /* Equal side padding */
    display: block; text-align: center;
  }
  .choose-text { width: 100%; text-align: center; }
  .choose-text strong.hdd { font-size: 30px; }
  .choose-image { width: 100%; margin-top: 15px; }
  .choose-us:before, .choose-us:after, .choose-us1:before, .choose-us2:after {
      left: 50%; transform: translateX(-50%);
  }

  .our-services4 { padding: 0 15px; } /* Content padding for service cards */
  .our-services_4 a { padding: 8px 10px; line-height: normal; font-size: 14px; width: auto; min-width: 120px;}

  .promo-banner-section:before, .promo-banner-section:after { display: none; }
  .promo-banner-section .banner-1 { width: 100%; margin-bottom: 15px; }

  .copyryt span { font-size: 14px; padding: 5px 20px 3px; clip-path: polygon(5% 0%, 95% 0%, 100% 100%, 0% 100%);}

  .call, .whatsapp { bottom: 10px; height: 50px; width: 50px; font-size: 24px; }
  .call { left: 10px; }
  .whatsapp { right: 10px; }

  .stats-section .pick-1 { width: 100%; float: none; } /* Stack stats items on very small screens */

}