/************************* COMMON CSS ***************************/
.text-blue {
  color: #0d6efd;
  position: relative;
}
.pt-title {
  font-size: clamp(26px, 2.4vw, 45px);
  line-height: 1.15;
  letter-spacing: -0.02em;
}

/***************************** NAVBAR SECTION STARTS *******************************/
.company_logo {
  width: 100px !important;
}

@media (max-width: 575px) {
  .company_logo {
    width: 75px !important;
  }
  /* .header-bottom{
    padding: 0 20px !important;
  } */
}
@media (max-width: 991px) {
  .page-header {
    padding: 50px 20px !important;
  }
  .header-bottom,
  .footer_section {
    padding: 0 20px !important;
  }
}

/* =========================================
   FIX: Header break between 992px–1008px
   (Compact layout)
   ========================================= */
@media (min-width: 992px) and (max-width: 1218px) {
  /* Reduce side padding because px-lg-5 is too wide here */
  .header-bottom .container-fluid.px-lg-5 {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  /* Keep everything on one line */
  .header-wrapper {
    display: flex;
    align-items: center;
    flex-wrap: nowrap !important;
    gap: 14px;
  }

  /* Slightly smaller logo to save space */
  .company_logo {
    width: 90px !important;
  }

  /* Menu spacing reduce */
  .menu.menu--style1 {
    display: flex;
    flex-wrap: nowrap;
    gap: 14px !important;
  }

  /* Menu font smaller */
  .menu.menu--style1 li a {
    font-size: 15px !important;
    padding: 10px 10px !important;
    white-space: nowrap;
  }

  /* Button compact */
  .header-btn .neo-btn {
    padding: 12px 18px !important;
    white-space: nowrap;
  }
}

/***************************** NAVBAR SECTION ENDS *******************************/

/***************************** HOME SECTION STARTS *******************************/
/* --------- Banner section ---------- */
.banner--style1 {
  padding: 50px 20px !important;
}

.banner--style1 {
  position: relative;
  padding-top: 140px;
  padding-bottom: 200px;
  overflow: visible;
}

.banner__bg-element img,
.banner__bg-element span {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.banner__content-heading span {
  color: var(--secondary-color);
}

.banner__content-moto {
  color: var(--text-color);
  margin-bottom: 32px;
}

.banner__content-coin img {
  width: 70px;
  animation: rotate 3s ease-in-out infinite alternate;
}

.banner__thumb {
  position: relative;
  width: 100%;
}

.banner__thumb img {
  width: 100%;
  height: auto;
  display: block;
}

@media (min-width: 992px) {
  .banner__thumb {
    position: absolute;
    right: 40px;
    top: 160px;
    max-width: 520px;
  }
}

/* Large screens */
@media (min-width: 1400px) {
  .banner__thumb {
    right: 80px;
    top: 140px;
    max-width: 560px;
  }
}

@media (max-width: 991px) {
  .banner--style1 {
    padding-bottom: 80px;
  }

  .banner__thumb {
    position: static;
    max-width: 100%;
    margin-top: 30px;
  }
}

.banner__content-social p {
  font-size: 1.1rem;
  margin-bottom: 12px;
}

.banner,
.banner__wrapper,
.container,
.row {
  overflow: visible !important;
}

/* --------- Partner section ---------- */
.partner {
  width: 100%;
  min-height: 110px;
  display: flex;
  align-items: center;
  padding: 14px 0;
}

.partner--gradient {
  background: #dff6f2;
}

.partner__wrapper {
  width: 100%;
  display: flex;
  align-items: center;
}

.partner__slider,
.partner__slider .swiper-wrapper {
  display: flex;
  align-items: center;
}

.partner__slider .swiper-slide {
  display: flex;
  align-items: center;
  justify-content: center;
}

.partner__item,
.partner__item-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.partner_logo {
  max-width: 170px;
  object-fit: contain;
  display: block;
  margin: auto;
}

@media (max-width: 768px) {
  .partner {
    min-height: 90px;
    padding: 10px 0;
  }
}

/* ------------ About section ------------- */
.pt-about-neo {
  position: relative;
  padding: 85px 0;
  background:
    radial-gradient(
      1200px 520px at 10% 30%,
      rgba(10, 166, 255, 0.1),
      transparent 60%
    ),
    radial-gradient(
      900px 420px at 90% 60%,
      rgba(0, 214, 143, 0.1),
      transparent 62%
    ),
    #ffffff;
  overflow: hidden;
}

.pt-about-neo__row {
  --bs-gutter-x: 2rem;
  --bs-gutter-y: 1.25rem;
}

/*  LEFT MEDIA  */
.pt-about-neo__media {
  position: relative;
}

.pt-about-neo__media-inner {
  position: relative;
  height: 520px;
  border-radius: 22px;
  overflow: hidden;
  transform: translateZ(0);
}

.pt-about-neo__img {
  width: 100%;
  object-fit: cover;
  border-radius: 20px;
}

.pt-about-neo__glow {
  position: absolute;
  border-radius: 999px;
  filter: blur(30px);
  opacity: 0.9;
  pointer-events: none;
}

.pt-about-neo__glow--1 {
  width: 220px;
  height: 220px;
  left: -40px;
  top: -40px;
  background: rgba(10, 166, 255, 0.35);
}

.pt-about-neo__glow--2 {
  width: 260px;
  height: 260px;
  right: -60px;
  bottom: -70px;
  background: rgba(0, 214, 143, 0.3);
}

/*  RIGHT CONTENT  */
.pt-about-neo__content {
  padding-left: 6px;
}

.pt-about-neo__kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
  font-weight: 900;
  letter-spacing: 0.7px;
  text-transform: uppercase;
  color: #0b1b2b;
  margin-bottom: 12px;
}

.pt-kdot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, #00d68f, #0aa6ff);
  box-shadow: 0 0 0 4px rgba(10, 166, 255, 0.12);
}

.pt-about-neo__title {
  font-size: clamp(30px, 2.35vw, 48px);
  line-height: 1.12;
  /* font-weight: 950; */
  color: #0b1b2b;
  margin: 0 0 14px;
}

.pt-gradient {
  background: #0a4fd5;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.pt-about-neo__title::after {
  content: "";
  display: block;
  width: 120px;
  height: 4px;
  margin-top: 14px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    rgba(10, 166, 255, 0.9),
    rgba(0, 214, 143, 0.9)
  );
  opacity: 0.65;
}

.pt-about-neo__text {
  font-size: 15.4px;
  line-height: 1.85;
  color: #556477;
  margin-bottom: 12px;
}

.pt-about-neo__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 18px 0 22px;
}

.pt-chip {
  display: inline-flex;
  align-items: center;
  padding: 9px 12px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
  color: #0b1b2b;
  background: linear-gradient(
    135deg,
    rgba(10, 166, 255, 0.1),
    rgba(0, 214, 143, 0.1)
  );
  border: 1px solid rgba(11, 27, 43, 0.08);
  transition:
    transform 0.2s ease,
    border-color 0.2s ease;
}

.pt-chip:hover {
  transform: translateY(-2px);
  border-color: rgba(10, 166, 255, 0.28);
}

.pt-about-neo__stats {
  display: flex;
  align-items: center;
  gap: 26px;
  margin: 10px 0 24px;
}

.pt-about-neo__vline {
  width: 1px;
  height: 44px;
  background: linear-gradient(
    180deg,
    rgba(10, 166, 255, 0.3),
    rgba(0, 214, 143, 0.3)
  );
  opacity: 0.8;
}

.pt-stat__value {
  font-size: 34px;
  font-weight: 950;
  letter-spacing: -0.6px;
  color: #0aa6ff;
  line-height: 1;
}

.pt-stat__value span {
  color: #00d68f;
}

.pt-stat__label {
  margin-top: 6px;
  font-size: 13.5px;
  font-weight: 700;
  color: #6a7a8f;
}

.pt-about-neo__actions {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.neo-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  border-radius: 12px;
  background: linear-gradient(135deg, #00d68f, #0aa6ff);
  color: #071522;
  font-weight: 900;
  font-size: 14px;
  text-decoration: none;
  text-align: center;
  /* box-shadow: 0 22px 50px rgba(10,166,255,.18); */
  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    color 0.25s ease;
  border: none;
  text-align: center;
}

.neo-btn:hover {
  color: #ffffff;
}

.pt-neo-link {
  font-weight: 900;
  color: #0b1b2b;
  text-decoration: none;
  position: relative;
  padding-bottom: 3px;
}

.pt-neo-link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 2px;
  width: 100%;
  background: linear-gradient(90deg, #0aa6ff, #00d68f);
  transform: scaleX(0.55);
  transform-origin: left;
  transition: transform 0.25s ease;
}
.pt-neo-link:hover::after {
  transform: scaleX(1);
}

/*  RESPONSIVE  */
@media (max-width: 991px) {
  .pt-about-neo__row {
    --bs-gutter-x: 1.2rem;
  }

  .pt-about-neo__content {
    padding-left: 0;
  }
  .pt-about-neo {
    padding: 85px 20px !important;
  }
}

@media (max-width: 575px) {
  .pt-about-neo__stats {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

  .pt-about-neo__vline {
    display: none;
  }

  .neo-btn {
    width: 100%;
    justify-content: center;
  }
}

/* ------------- Feature Section ------------- */
.feature_section,
.pricing_section {
  padding: 85px 0;
}

@media (max-width: 991px) {
  .feature_section,
  .pricing_section {
    padding: 85px 20px;
  }
}

.feature--style1 .feature__image {
  position: relative;
}

.feature--style1 .feature__image img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 20px;
}

/* floating cards inside image */
.feature--style1 .floating-content__top-right--style2 {
  position: absolute;
  top: 16px;
  right: 16px;
}

.feature--style1 .floating-content__bottom-left--style2 {
  position: absolute;
  bottom: 50px;
  left: 16px;
}

@media (max-width: 991px) {
  .feature--style1 .feature__thumb {
    margin-top: 40px;
  }

  .feature--style1 .floating-content__top-right--style2 {
    top: 12px;
    right: 12px;
    transform: scale(0.95);
    transform-origin: top right;
  }

  .feature--style1 .floating-content__bottom-left--style2 {
    bottom: 60px;
    left: 12px;
    transform: scale(0.95);
    transform-origin: bottom left;
  }
}

@media (max-width: 420px) {
  .feature--style1 .floating-content__top-right--style2,
  .feature--style1 .floating-content__bottom-left--style2 {
    transform: scale(0.88);
  }
}

/* ------------ Courses Section ------------- */
/* .premium-courses {
  position: relative;
  padding: 85px 0;
  overflow: hidden;
}

.ptc-title {
  font-size: clamp(28px, 2.2vw, 44px);
  color: #0b1b2b;
  margin-bottom: 8px;
}

.ptc-title span {
  background: linear-gradient(90deg, #0aa6ff, #00d68f);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.ptc-subtitle {
  color: #6a7a8f;
  font-size: 15px;
  max-width: 760px;
  margin: 0 auto;
  line-height: 1.7;
}

.ptc-card {
  position: relative;
  height: 100%;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(11, 27, 43, 0.08);
  box-shadow: 0 18px 60px rgba(11, 27, 43, 0.07);
  padding: 22px 22px 18px;
  transition: transform 0.25s ease, box-shadow 0.25s ease,
    border-color 0.25s ease;
  overflow: hidden;
}

.ptc-card__topline {
  position: absolute;
  left: 0;
  top: 0;
  height: 4px;
  width: 100%;
  background: linear-gradient(90deg, #00d68f, #0aa6ff);
  opacity: 0.95;
}

.ptc-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 30px 85px rgba(11, 27, 43, 0.12);
  border-color: rgba(10, 166, 255, 0.18);
}

.ptc-card__head {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.ptc-icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: linear-gradient(
    135deg,
    rgba(10, 166, 255, 0.12),
    rgba(0, 214, 143, 0.1)
  );
  border: 1px solid rgba(11, 27, 43, 0.08);
  flex: 0 0 auto;
}

.ptc-icon img {
  width: 30px;
  height: 30px;
  object-fit: contain;
}


.ptc-name {
  margin: 0 0 6px;
  font-weight: 950;
  color: #0b1b2b;
}

.ptc-name a {
  color: #0b1b2b;
  text-decoration: none;
}

.ptc-desc {
  margin: 0 0 10px;
  font-size: 14.6px;
  line-height: 1.65;
  color: #5b6a7d;
}

.ptc-points {
  list-style: none;
  padding: 0;
  margin: 0 0 14px;
  display: grid;
  gap: 7px;
}

.ptc-points li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13.6px;
  color: #2c3c52;
  font-weight: 700;
}

.ptc-points i {
  color: #00d68f;
  margin-top: 2px;
  font-size: 13px;
}

.ptc-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid rgba(11, 27, 43, 0.06);
}

.ptc-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(11, 27, 43, 0.03);
  border: 1px solid rgba(11, 27, 43, 0.06);
  font-weight: 800;
  font-size: 13px;
  color: #2c3c52;
}

.ptc-pill i {
  color: #0aa6ff;
  font-size: 13px;
}

@media (max-width: 991px) {
  .premium-courses {
    padding: 85px 20px;
  }
}
@media (max-width: 575px) {
  .ptc-card {
    padding: 20px;
  }
} */

.premium-courses {
  position: relative;
  padding: 85px 0;
  overflow: hidden;
}
@media (max-width: 991px) {
  .premium-courses {
    padding: 85px 20px;
  }
}
.pt-course-overview {
  background: linear-gradient(135deg, #f8fbff, #eef5ff);
}

.pt-subheading {
  color: #6c757d;
  font-size: 0.95rem;
}

/* Card */
.pt-single-course-card {
  background: #ffffff;
  padding: 40px 30px;
  border-radius: 20px;
  text-align: center;
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.08);
  transition: 0.3s ease;
  border: 1px solid rgba(13, 110, 253, 0.1);
}

.pt-single-course-card:hover {
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.12);
}

/* Icon */
.pt-icon-box {
  width: 80px;
  height: 80px;
  margin: auto;
  border-radius: 20px;
  background: rgba(13, 110, 253, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
}

.pt-icon-box img {
  width: 45px;
  height: 45px;
}

/* Course Text */
.pt-course-text {
  font-size: 0.95rem;
  color: #555;
  margin-bottom: 20px;
}

/* Feature List */
.pt-feature-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 20px;
  margin-bottom: 25px;
  font-size: 0.9rem;
  color: #333;
}

/* --------- Testimonial Section -------------------- */
.testimonial_section {
  padding: 85px 0;
}

.testimonial__slider .swiper-slide {
  height: auto;
  display: flex;
}

.testimonial__item {
  width: 100%;
  display: flex;
}

.testimonial__item-inner {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  min-height: 320px; /* adjust if needed */
}

.testimonial__item-content {
  height: 100%;
  display: flex;
  flex-direction: column;
}

.testimonial__item-content > p {
  flex: 1;
  margin-bottom: 18px;
}

.testimonial__footer {
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
}
@media (max-width: 991px) {
  .testimonial__item-inner {
    min-height: 300px;
  }
  .testimonial_section {
    padding: 85px 20px;
  }
}

@media (max-width: 575px) {
  .testimonial__item-inner {
    min-height: 280px;
  }
}

/***************************** HOME SECTION ENDS *******************************/

/***************************** FOOTER SECTION STARTS *******************************/
.footer__top--style1 {
  padding-block: 40px;
}

.company_logo_footer {
  width: 120px !important;
}

@media (max-width: 576px) {
  .footer__top--style1 {
    padding-block: 50px;
  }
}

/***************************** FOOTER SECTION ENDS *******************************/
