.fs-15 {
  font-size: 15px !important;
}
.fs-14 {
  font-size: 14px !important;
}

.brd {
  border-radius: 12px !important;
}
.rounded-15 {
  border-radius: 15px !important;
}

   .page-header {
  background: linear-gradient(#d7e1f0, #d7e1f0)!important;
  background-size: cover;
  background-repeat: no-repeat;
}

   .page-header2 {
  background:linear-gradient(to bottom right, rgb(11 43 89), rgb(36 52 75 / 0)),url(../img/breadcrumb2.jpg) !important;
  background-size: cover;
  background-repeat: no-repeat;
}

.brd-top {
  border-top-left-radius: 12px !important;
  border-top-right-radius: 12px !important;
}
.brd-bottom {
  border-bottom-left-radius: 12px !important;
  border-bottom-right-radius: 12px !important;
}

.b-bottom {
   border-bottom-left-radius: 50px;
   border-bottom-right-radius: 50px;
}

.pro-color {
  color: #0b2b59 !important;
}

/* navbar dropdown  */
 @media (min-width: 992px) {
        .navbar .dropdown:hover .dropdown-menu {
          display: block;
        }
      }
    /* navbar dropdown  */

.it-btn-border {
  font-size: 16px;
  padding: 15.5px 29px;
  font-weight: 500;
  text-align: center;
  transition: 0.4s;
  border-radius: 8px;
  position: relative;
  display: inline-flex;
  align-items: center;
  line-height: 1.1;
  justify-content: center;
  text-decoration: none;
  color: #0F4C81;
  font-family: 'Jost', sans-serif;
  background-color: #023a32;
  border: 1px solid #023a32;
  overflow: hidden;
}

@media only screen and (min-width: 992px) and (max-width: 1199px), 
       only screen and (min-width: 768px) and (max-width: 991px), 
       (max-width: 767px) {
  .it-btn-border {
    font-size: 14px;
    padding: 13px 25px;
  }
}

.it-btn-border span {
  position: relative;
  z-index: 1;
  overflow: hidden;
  display: inline-block;
  color: #fff;
}

.it-btn-border span span.text-1 {
  position: relative;
  display: block;
  transition: 0.3s;
}

.it-btn-border span span.text-2 {
  position: absolute;
  top: 100%;
  left: 0;
  display: block;
  transition: 0.3s;
  white-space: nowrap;
}

.it-btn-border svg {
  width: 14px;
  height: 14px;
  margin-left: 10px;
  display: inline-block;
  transform: translateY(-1px);
  color: #fff;
  transition: 0.3s;
}

.it-btn-border:hover {
  color: #ffffff;
  background-color: #002d8d;
  border: 1px solid #002d8d;
}

.it-btn-border:hover span {
  color: #ffffff;
}

.it-btn-border:hover span span.text-1 {
  transform: translateY(-150%);
}

.it-btn-border:hover span span.text-2 {
  top: 50%;
  transform: translateY(-50%);
}

.it-btn-border:hover svg {
  color: #ffffff;
}



   /* Client Section */
        .client-section {
            overflow: hidden;
            min-height: auto;
            padding: 60px 20px;
        }

        .container {
            max-width: 1200px;
            margin: 0 auto;
        }

      

        /* Logo Carousel Wrapper */
        .logo-carousel-wrapper {
            position: relative;
            overflow: hidden;
            margin-bottom: 40px;
        }

        /* Blur/Fog Effect on Edges */
        .logo-carousel-wrapper::before,
        .logo-carousel-wrapper::after {
            content: '';
            position: absolute;
            top: 0;
            bottom: 0;
            width: 150px;
            z-index: 10;
            pointer-events: none;
        }

        .logo-carousel-wrapper::before {
            left: 0;
            background: linear-gradient(to right, #202122 0%, transparent 100%);
        }

        .logo-carousel-wrapper::after {
            right: 0;
            background: linear-gradient(to left, #202122 0%, transparent 100%);
        }

        /* Continuous Sliding Animation */
        .logo-carousel {
            display: flex;
            width: fit-content;
        }

        /* Left to Right Animation */
        .logo-carousel.ltr {
            animation: scrollLTR 30s linear infinite;
        }

        /* Right to Left Animation */
        .logo-carousel.rtl {
            animation: scrollRTL 30s linear infinite;
        }

        .logo-carousel:hover {
            animation-play-state: paused;
        }

        @keyframes scrollLTR {
            0% {
                transform: translateX(0);
            }
            100% {
                transform: translateX(-50%);
            }
        }

        @keyframes scrollRTL {
            0% {
                transform: translateX(-50%);
            }
            100% {
                transform: translateX(0);
            }
        }

        /* Logo Styling */
        .logo-carousel .item {
            flex: 0 0 auto;
            display: flex;
            align-items: center;
            justify-content: center;
            min-width: 180px;
        }

        .logo-carousel .item img {
            width: 150px;
            height: 100px;
            object-fit: contain;
            /* filter: grayscale(100%); */
            /* opacity: 0.7; */
            transition: all 0.3s ease;
        }

        .logo-carousel .item img:hover {
            /* filter: grayscale(0%); */
            /* opacity: 1; */
            transform: scale(1.05);
        }

        /* Responsive adjustments */
        @media (max-width: 768px) {
           

            .logo-carousel .item img {
                width: 120px;
                height: 80px;
            }

            .logo-carousel .item {
                margin-right: 30px;
            }

            .logo-carousel-wrapper::before,
            .logo-carousel-wrapper::after {
                width: 80px;
            }
        }


        /* Why Choose us  */
          .image-container {
    position: relative;
    display: inline-block;
    border-radius: 1000px;
    overflow: hidden;
}

.zoom-image-why-choose {
    border-radius: 1000px;
    transition: transform 0.6s ease-in-out;
    display: block;
    width: 100%;
    height: 700px;
    object-fit: cover;
}

.image-container:hover .zoom-image-why-choose {
    transform: scale(1.1);
}

/* Efficient: Single container with 3 pulse layers */
.image-container {
    box-shadow: none;
    transition: box-shadow 0.3s ease;
}

.image-container:hover {
    animation: pulse-rings 2s infinite;
}

/* Single animation with multiple expanding rings */
@keyframes pulse-rings {
    0% {
        box-shadow: 
            0 0 0 0 rgba(59, 130, 246, 0.7),
            0 0 0 0 rgba(59, 130, 246, 0.5),
            0 0 0 0 rgba(59, 130, 246, 0.3);
    }
    30% {
        box-shadow: 
            0 0 0 15px rgba(59, 130, 246, 0),
            0 0 0 0 rgba(59, 130, 246, 0.7),
            0 0 0 0 rgba(59, 130, 246, 0.5);
    }
    60% {
        box-shadow: 
            0 0 0 0 rgba(59, 130, 246, 0),
            0 0 0 20px rgba(59, 130, 246, 0),
            0 0 0 0 rgba(59, 130, 246, 0.7);
    }
    80% {
        box-shadow: 
            0 0 0 0 rgba(59, 130, 246, 0),
            0 0 0 0 rgba(59, 130, 246, 0),
            0 0 0 25px rgba(59, 130, 246, 0);
    }
    100% {
        box-shadow: 
            0 0 0 0 rgba(59, 130, 246, 0),
            0 0 0 0 rgba(59, 130, 246, 0),
            0 0 0 0 rgba(59, 130, 246, 0);
    }
}


        /* Add this to your existing CSS */
.floating {
  animation: floatUpDown 3s ease-in-out infinite;
}

@keyframes floatUpDown {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
}




    .your-element {
  background: #0b2b59;
  background-size: 400% 400%;  /* Oversize for smooth movement */
  animation: gradient-loop 10s ease infinite;  /* Duration/timing/loop */
  
}

/* @keyframes gradient-loop {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
} */


    .transition-card {
      transition: all 0.3s ease !important;
    }
    
    .transition-card:hover {
      transform: translateY(-10px);
      box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15) !important;
      background: rgba(255, 255, 255, 1) !important;
    }
    
    .transition-card:hover .card-title {
      color: #0b2b59;
    }




  /* Accordion Styles */
  .accordion-button:not(.collapsed) {
    background-color: #0d6efd;
    color: #fff;
    box-shadow: none !important;
    border-color: transparent !important;
  }

  .accordion-button:focus {
    outline: none;
    box-shadow: none !important;
    border-color: transparent !important;
  }

  .accordion-button::after {
    display: none;
  }

  .accordion-button:not(.collapsed) i {
    color: #fff;
  }

  .accordion-button {
    padding: 1.25rem;
    transition: all 0.3s ease;
  }

  .accordion-button i {
    transition: transform 0.3s ease, color 0.3s ease;
  }

  .accordion-button:not(.collapsed) i {
    transform: rotate(45deg);
  }

  .accordion-body {
    padding: 1.25rem;
    color: #555;
    line-height: 1.8;
  }

  /* Floating Shapes Animation */
  .floating-shapes {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
    pointer-events: none;
    z-index: 0;
  }

  .floating-shapes li {
    position: absolute;
    display: block;
    width: 40px;
    height: 40px;
    background: rgba(13, 110, 253, 0.08);
    bottom: -150px;
    animation: float-up 25s linear infinite;
  }

  /* Individual shape positions and timing */
  .floating-shapes li:nth-child(1) {
    left: 10%;
    width: 80px;
    height: 80px;
    animation-delay: 0s;
    animation-duration: 20s;
    border-radius: 50%;
  }

  .floating-shapes li:nth-child(2) {
    left: 25%;
    width: 50px;
    height: 50px;
    animation-delay: 2s;
    animation-duration: 18s;
    border-radius: 15px;
    background: hwb(198 75% 1% / 0.795);
  }

  .floating-shapes li:nth-child(3) {
    left: 45%;
    width: 60px;
    height: 60px;
    animation-delay: 4s;
    animation-duration: 22s;
    border-radius: 50%;
    background: hsla(308, 91%, 74%, 0.801);
  }

  .floating-shapes li:nth-child(4) {
    left: 65%;
    width: 70px;
    height: 70px;
    animation-delay: 1s;
    animation-duration: 24s;
    border-radius: 20px;
  }

  .floating-shapes li:nth-child(5) {
    left: 80%;
    width: 55px;
    height: 55px;
    animation-delay: 6s;
    animation-duration: 19s;
    border-radius: 50%;
    background: lch(86.09% 42.62 92.58 / 0.815);
  }

  .floating-shapes li:nth-child(6) {
    left: 35%;
    width: 45px;
    height: 45px;
    animation-delay: 3s;
    animation-duration: 26s;
    border-radius: 10px;
    background: #97cec4b4;
  }

  .floating-shapes li:nth-child(7) {
    left: 55%;
    width: 65px;
    height: 65px;
    animation-delay: 7s;
    animation-duration: 21s;
    border-radius: 50%;
  }

  .floating-shapes li:nth-child(8) {
    left: 15%;
    width: 50px;
    height: 50px;
    animation-delay: 5s;
    animation-duration: 23s;
    border-radius: 25px;
    background: #e0dca5b4;
  }

  @keyframes float-up {
    0% {
      transform: translateY(0) rotate(0deg);
      opacity: 0;
    }
    10% {
      opacity: 1;
    }
    90% {
      opacity: 1;
    }
    100% {
      transform: translateY(-120vh) rotate(720deg);
      opacity: 0;
    }
  }

  /* Keep content above shapes */
  .container {
    position: relative;
    z-index: 1;
  }

 /* Courses global styling */
  .primary-container{
     background:  linear-gradient(rgba(40, 120, 235, 0.9), rgba(40, 120, 235, 0.9));
  }

   /* Course overview section styling start  */
   .overview-container{
    border: 1px solid #e5e7eb ;
      max-width: 1300px; 
      background-color: #fff;
}
   /* Course overview section styling end  */

    /* Course Card styling start  */
    .course-card {
  /* background: #1ea4b8; */
   background: linear-gradient(135deg, #0B2D5B 0%, #127DA0 100%);
  border-radius: 10px;
  padding: 22px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.course-card h5{
    color: #ffffff;
   margin-bottom: 8px;
  line-height: 1.35;
}
.course-card p{
   color: #e9f7fa;
   font-size: 14px;
  margin: 0;
  line-height: 1.5;
}
.course-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.15);
}
.course-icon{
 width: 64px;
  height: 64px;
  background: #ffffff;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;

  flex-shrink: 0;
}
.course-icon i {
  font-size: 32px;
    line-height: 1; 
     color: #475569;
  display: block;
}
    /* Course Card styling end */
    
 /* Course Table Styling start*/
.course-table {
    border: 1px solid #e5e7eb;
  width: 100%;
  border-collapse: collapse;
  font-size: 15px;
}

.course-table thead th {
  font-weight: 700;
  color: #000;
  border-bottom: 2px solid #e5e7eb;
  padding: 14px 16px;
  text-align: left;
}
.course-table th,
.course-table td {
  border-right: 1px solid #e5e7eb;
}

.course-table th:last-child,
.course-table td:last-child {
  border-right: none;
}
.course-table tbody td {
  border-bottom: 1px solid #e5e7eb;
  padding: 14px 16px;
  vertical-align: top;
  color: #1f2937;
}


.course-table tbody td:first-child,
.course-table tbody td:nth-child(2) {
  font-weight: 600;
}
 /* Course Table Styling end*/

 /* course outcome (check list )*/
 .impact-item .icon {
  font-size: 1.2rem;
  color: #0d6efd;
  margin-right: 15px;
  margin-top: 4px;
}

.impact-item h5 {
  margin-bottom: 6px;
  font-weight: 600;
}

.impact-item p {
  margin-bottom: 0;
  color: #555;
}

@media (max-width: 767px) {
  .impact-item {
    align-items: flex-start;
  }
}
.impact-wrapper {
  position: relative;
  display: inline-block;
  
}

.impact-wrapper::before {
  content: "";
  position: absolute;
  top: -20px;
  left: -40px;
 width: 140px;
  height: 140px;
  background-color: #0d6efd; 
  border-radius: 12px;
  transform: rotate(-6deg);
  z-index: 0;
}

.impact-image {
  position: relative;
  z-index: 1;
  border-radius: 12px;
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.15);
}

@media (max-width: 992px) {
  .impact-wrapper::before {
    width: 110px;
    height: 110px;
    top: -14px;
    left: -24px;
    border-radius: 10px;
  }
}

/* Mobile */
@media (max-width: 576px) {
  .impact-wrapper::before {
    width: 70px;
    height: 70px;
    top: -8px;
    left: -12px;
    border-radius: 8px;
  }
}

 /*what students gain carousel start */
.gain-section {
  background: linear-gradient(rgba(40, 120, 235, 0.9), rgba(40, 120, 235, 0.9));
}

/* Carousel item wrapper */
.gain-item {
  position: relative;
  padding-top: 45px;
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 100%;  
}

/* Floating icon */
.gain-icon {
  position: absolute;
  top: -5px; 
  left: 50%;
  transform: translateX(-50%);
  width: 82px;
  height: 82px;
  background: #0a1440;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}

.gain-icon i {
  font-size: 28px;
  color: #fff;
}

/* Card */
.gain-card {
  background: #ffffff;
  border-radius: 18px;
  padding: 40px 22px; 
  text-align: center;
  box-shadow: 0 12px 30px rgba(0,0,0,0.15);
  display: flex;
  align-items: center;    
  justify-content: center;
  flex-direction: column;
  height: 100%;  
  min-height: 250px;  
  padding: 50px 20px;  
  max-width: 300px;
}

.gain-card p {
  margin: 0;
  font-size: 18px;
  font-weight: 500;
}
/* Ensure Owl items are same height */
.gain-carousel .owl-item {
  display: flex !important;
  justify-content: center;
  height: auto !important;
}

/* Owl spacing fix */
.gain-carousel .owl-stage-outer {
  padding: 40px 0 40px;
}

/* Dots styling */
.gain-carousel .owl-dot span {
  background: rgba(255,255,255,0.6);
}

.gain-carousel .owl-dot.active span {
  background: #ffffff;
}
/*what students gain carousel start */

 /* course global styling end  */


  /* workshop global styling start */

  .apply-list {
  list-style: none;
  padding-left: 0;
    /* margin: 0 auto;            */
  max-width: 800px;
}

.apply-text{
    text-align: left;         
  font-size: 1rem;
  font-weight: 500;
  color: #555;
  /* line-height: 1.4; */
  /* margin: 0 auto 20px auto;  */
  max-width: 800px; 
}
.apply-list li {
  display: flex;
   align-items: center;
  gap: 14px;
  /* margin-bottom: 5px; */
  font-size: 15px;
  /* line-height: 1.4; */
  color: #333;
  
}

.apply-list i {
   width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: #2878EB;
  background: rgba(40, 120, 235, 0.1);
  border-radius: 50%;
  padding: 6px;
  flex-shrink: 0;
}

  /* workshop global styling end */