/**
 * SBUP Main Stylesheet
 * Professional CSS with BEM methodology and modern standards
 * Author: SBUP Development Team
 * Version: 1.0.0
 */

/* Import Variables */
@import url('./variables.css');

/* ==========================================================================
   Header Styles
   ========================================================================== */

.mainHeader {
  position: fixed;
  top: 32px;
  left: 50%;
  transform: translateX(-50%);
  width: min(1720px, 90vw);
  max-width: 1720px;
  z-index: 1000;
  opacity: 1;
  border-radius: 23.19px;
  background: linear-gradient(250.38deg, rgba(255, 255, 255, 0.8) -1.09%, rgba(255, 255, 255, 0.8) 96.04%);
  backdrop-filter: blur(23.186933517456055px);
  padding: 15px 30px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  /* Ensure header doesn't cause horizontal scroll */
  box-sizing: border-box;
}

.headerContainer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  width: 100%;
}

.headerLogo {
  display: flex;
  align-items: center;
}

.headerLogo__img {
  height: auto;
  width: auto;
}

.headerNavigation {
  display: flex;
  justify-content: center;
}

.navigationMenu {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 20px;
}

.navigationMenu__item {
  position: relative;
}

.navigationMenu__link {
  color: var(--color-menu-text);
  text-decoration: none;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  transition: color 0.3s ease;
  position: relative;
}

.journeyTitle {
  padding-right: 15%;
}

.navigationMenu__link:hover {
  color: var(--color-headings);
}

.navigationMenu__link::after {
  content: '';
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--color-button);
  transition: width 0.3s ease;
}

.navigationMenu__link:hover::after,
.navigationMenu__link--active::after {
  width: 100%;
}

.navigationMenu__link--active {
  color: var(--color-headings);
  font-weight: var(--font-weight-semibold);
}

button.button.button--primary.button--large.formSubmit {
  width: fit-content;
  border-radius: 200px;
  gap: 10px;
}

/* Header Responsive Design */
@media (max-width: 1900px) {
  .aboutLeft {
    padding-right: 0%;
  }
}

@media (max-width: 1720px) {
  .journeyTitle {
    padding-right: 0%;
  }

  .mainHeader {
    width: 90vw;
    max-width: 1720px;
    left: 50%;
    transform: translateX(-50%);
  }
}

@media (max-width: 1600px) {
  .testimonialCard__image {
    flex: none;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-right: 30px;
  }

  .testimonialCard__image img {
    width: 200px;
  }

  .testimonialContent {
    gap: 1rem;
  }

  .researchJourney {
    max-width: 100%;
    z-index: 99;
  }

  .stipendItem__content {
    flex-direction: column;
    width: 100%;
  }

  .stipendItem__amount {
    padding: var(--inner-small-padding);
  }
}

@media (max-width: 1440px) {
  .navigationMenu {
    gap: 12px;
  }
}


@media (max-width: 1200px) {
  .testimonialCard__image img {
    width: auto;
  }

  .mainHeader {
    width: 95vw;
    height: auto;
    min-height: 80px;
    padding: 12px 20px;
  }

  .navigationMenu {
    gap: 15px;
  }

  .navigationMenu__link {
    font-size: var(--font-size-sm);
  }
}


@media (max-width: 1024px) {
  .mainHeader {
    width: 100vw;
    height: auto;
    min-height: 70px;
    padding: 10px 15px;
    border-radius: 0;
    top: 0;
    /* Ensure no horizontal scroll */
    box-sizing: border-box;
    left: 0;
    transform: none;
  }

  .headerContainer {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }

  .hamburgerMenu {
    display: flex;
    z-index: 1002;
  }

  .headerNavigation {
    position: fixed;
    top: 70px;
    left: 0;
    width: 100%;
    height: calc(100vh - 70px);
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    transform: translateX(-100%);
    transition: transform 0.3s ease;
    z-index: 1000;
    padding: 20px;
    box-sizing: border-box;
    /* Ensure it's completely hidden by default */
    visibility: hidden;
    opacity: 0;
  }

  .headerNavigation--active {
    transform: translateX(0);
    visibility: visible;
    opacity: 1;
  }

  .navigationMenu {
    flex-direction: column;
    gap: 2rem;
    justify-content: flex-start;
    align-items: center;
    padding-top: 2rem;
  }

  .navigationMenu__link {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    padding: 1rem 0;
    display: block;
    width: 100%;
    text-align: center;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  }

  .navigationMenu__link:hover {
    background-color: rgba(0, 37, 129, 0.1);
    border-radius: var(--border-radius-md);
  }
}

/* ==========================================================================
   Hamburger Menu Styles
   ========================================================================== */

.hamburgerMenu {
  display: none;
  flex-direction: column;
  justify-content: space-around;
  width: 30px;
  height: 30px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 1001;
  transition: all 0.3s ease;
}

.hamburgerMenu__line {
  width: 100%;
  height: 3px;
  background-color: var(--color-menu-text);
  border-radius: 2px;
  transition: all 0.3s ease;
  transform-origin: center;
}

.hamburgerMenu:hover .hamburgerMenu__line {
  background-color: var(--color-headings);
}

.hamburgerMenu--active .hamburgerMenu__line:nth-child(1) {
  transform: rotate(45deg) translate(6px, 6px);
}

.hamburgerMenu--active .hamburgerMenu__line:nth-child(2) {
  opacity: 0;
}

.hamburgerMenu--active .hamburgerMenu__line:nth-child(3) {
  transform: rotate(-45deg) translate(6px, -6px);
}


@media (max-width: 768px) {
  .mainHeader {
    width: 100vw;
    height: auto;
    min-height: 65px;
    padding: 8px 15px;
    border-radius: 0;
    top: 0;
    /* Ensure no horizontal scroll */
    box-sizing: border-box;
    left: 0;
    transform: none;
  }

  .headerContainer {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
  }

  .headerLogo {
    flex-shrink: 0;
    max-width: 70%;
  }

  .headerLogo__img {
    max-height: 45px;
    width: auto;
    object-fit: contain;
  }

  .hamburgerMenu {
    display: flex;
    width: 28px;
    height: 28px;
    flex-shrink: 0;
    z-index: 1002;
  }

  .hamburgerMenu__line {
    height: 2.5px;
  }

  .headerNavigation {
    position: fixed;
    top: 65px;
    left: 0;
    width: 100%;
    height: calc(100vh - 65px);
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    transform: translateX(-100%);
    transition: transform 0.3s ease;
    z-index: 1000;
    padding: 20px;
    box-sizing: border-box;
  }

  .headerNavigation--active {
    transform: translateX(0);
    visibility: visible;
    opacity: 1;
  }

  .navigationMenu {
    flex-direction: column;
    gap: 1.5rem;
    justify-content: flex-start;
    align-items: center;
    padding-top: 1.5rem;
  }

  .navigationMenu__link {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    padding: 1rem 0;
    display: block;
    width: 100%;
    text-align: center;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  }

  .navigationMenu__link:hover {
    background-color: rgba(0, 37, 129, 0.1);
    border-radius: var(--border-radius-md);
  }
}

@media (max-width: 600px) {
  .mainHeader {
    width: 100vw;
    height: auto;
    min-height: 60px;
    padding: 8px 12px;
    border-radius: 0;
    top: 0;
    /* Ensure no horizontal scroll */
    box-sizing: border-box;
    left: 0;
    transform: none;
  }

  .headerContainer {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
  }

  .headerLogo {
    flex-shrink: 0;
    max-width: 60%;
  }

  .headerLogo__img {
    max-height: 40px;
    width: auto;
    object-fit: contain;
  }

  .hamburgerMenu {
    display: flex;
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    z-index: 1002;
  }

  .hamburgerMenu__line {
    height: 2px;
  }

  .headerNavigation {
    position: fixed;
    top: 60px;
    left: 0;
    width: 100%;
    height: calc(100vh - 60px);
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    transform: translateX(-100%);
    transition: transform 0.3s ease;
    z-index: 1000;
    padding: 15px;
    box-sizing: border-box;
  }

  .headerNavigation--active {
    transform: translateX(0);
    visibility: visible;
    opacity: 1;
  }

  .navigationMenu {
    flex-direction: column;
    gap: 0;
    justify-content: flex-start;
    align-items: center;
    padding-top: 1.5rem;
  }

  .navigationMenu__link {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    padding: 0.8rem 0;
    display: block;
    width: 100%;
    text-align: center;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  }

  .navigationMenu__link:hover {
    background-color: rgba(0, 37, 129, 0.1);
    border-radius: var(--border-radius-md);
  }
}

/* ==========================================================================
   Page Sections
   ========================================================================== */

.pageSection {
  padding: var(--space-20) 0;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 80px;
}

.pageSection h2 {
  font-family: var(--font-family-primary);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: var(--font-weight-bold);
  color: var(--color-headings);
  text-align: center;
  margin-bottom: var(--space-6);
}

.pageSection p {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  color: var(--color-paragraph);
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}

/* ==========================================================================
   About Us Section
   ========================================================================== */

/* .aboutSection {
    background: url('../images/buildingback.webp'), var(--primary-gradient);
    background-size: auto;
    background-position: center right;
    background-repeat: no-repeat;
    padding: var(--space-20) 0 0 0;
    position: relative;
    display: flex;
    align-items: center;
    border-radius: 0 0 50px 50px;
} */
.aboutSection {
  background: url('../images/aboutback.webp');
  background-size: cover;
  background-position: center right;
  background-repeat: no-repeat;
  padding: var(--space-20) 0 0 0;
  position: relative;
  display: flex;
  align-items: center;
  border-radius: 0 0 50px 50px;
}

.aboutContent {
  display: grid;
  grid-template-columns: 60% 40%;
  gap: var(--space-16);
  align-items: start;
  position: relative;
  z-index: 2;
}

.aboutLeft {
  color: var(--color-primary-white);
  padding-right: 10%;
}

.aboutTitle {
  font-family: var(--font-family-primary);
  font-size: var(--about-title-size);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary-white);
  margin-bottom: var(--space-4);
  line-height: 1.2;
}

.aboutSubtitle {
  font-family: var(--font-family-primary);
  font-size: var(--about-subtitle-size);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary-white);
  margin-bottom: var(--space-6);
  line-height: 1.4;
}

.aboutParagraph {
  font-family: var(--font-family-primary);
  font-size: var(--about-para-size);
  font-weight: var(--font-weight-regular);
  color: var(--color-primary-white);
  line-height: 1.6;
  margin-bottom: var(--space-8);
  opacity: 0.9;
}

.featureBoxes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
  margin-top: var(--space-8);
}

.featureBox:nth-child(3) {
  grid-column: 1 / -1;
  justify-self: center;
  max-width: 80%;
}

.featureBox {
  display: flex;
  align-items: center;
  gap: 0px;
  border-radius: var(--border-radius-lg);
}

.featureIcon__container {
  border: 1px solid var(--color-button);
  border-radius: 50%;
  padding: 7px;
}

.featureIcon {
  flex-shrink: 0;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: var(--background-icon-gradient);
  padding: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.featureIcon__img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.featureText {
  width: 100%;
  max-width: 400px;
  font-family: var(--font-family-primary);
  font-size: var(--about-feature-text-size);
  font-weight: var(--font-weight-medium);
  color: var(--color-primary-white);
  line-height: 1.4;
  background: rgba(255, 242, 227, 0.2);
  padding: 14px 21px;
  border-radius: 200px;
  min-height: 50px;
  display: flex;
  align-items: center;
}

.aboutRight {
  display: flex;
  align-items: center;
  justify-content: center;
}

.buildingImage {
  width: 100%;
  height: 100%;
  max-height: 600px;
  border-radius: var(--border-radius-xl);
  overflow: hidden;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

.buildingImage__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.aboutBanner {
  background: var(--color-primary-white);
  padding: 12px 50px;
  border-radius: 200px;
  width: fit-content;
  padding-bottom: 50px;
  margin-top: 90px;
  margin-bottom: -50px;
}

.aboutBanner__text {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-headings);
  text-align: center;
  margin: 0;
  padding-bottom: 10px;
  line-height: 1.4;
}


/* About Section Responsive */
@media (max-width: 1600px) and (min-width: 1440px) {
  .aboutSection {
    background-position: -25rem center;
  }
}

@media (max-width: 1440px) and (min-width: 1300px) {
  .featureText {
    font-size: 12px;
  }

  .aboutSection {
    background-position: -31rem center;
  }
}

@media (max-width: 1299px) and (min-width: 1200px) {
  .aboutSection {
    background-position: -44rem center;
  }
}

@media (max-width: 1199px) and (min-width: 1024px) {
  .aboutSection {
    background-position: -55rem center;
  }
}

@media (max-width: 1300px) {
  .featureText {
    font-size: 12px;
  }

  .featureBox:nth-child(3) {
    max-width: 100%;
    justify-self: flex-start;
  }

  .featureBoxes {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1024px) {
  .aboutContent {
    grid-template-columns: 1fr;
    gap: var(--space-12);
  }

  .aboutRight {
    order: -1;
  }

  .buildingImage {
    max-height: 400px;
  }

  .featureBoxes {
    grid-template-columns: 1fr;
  }

  .featureBox:nth-child(3) {
    grid-column: 1;
    max-width: 100%;
  }
}

.mobileBuildingImage {
  display: none !important;
}

@media (max-width: 1024px) {
  section#about .container {
    padding: 0;
  }

  .aboutLeft {
    padding: 0px 30px !important;
  }

  .featureText,
  .featureBox:nth-child(3) {
    width: 100%;
    max-width: 100%;
  }

  .aboutLeft {
    padding-right: 0%;
  }

  .contentSection__content {
    flex: 1;
    min-width: 0;
    overflow-x: hidden;
    word-wrap: break-word;
    overflow-wrap: break-word;
    width: 100%;
  }

  .mobileBuildingImage {
    display: block !important;
  }

  .aboutSection {
    padding: var(--space-16) 0 var(--space-20);
    background: var(--primary-gradient);
  }

  .featureBox {
    text-align: center;
  }

  .featureIcon {
    align-self: center;
  }

  .aboutBanner {
    position: relative;
    bottom: auto;
    left: auto;
    padding: 10px;
    border-radius: 12px 12px 0 0;
    width: 90%;
    margin: 0 auto;
    transform: none;
    margin-top: var(--space-8);
    background: #F9F8F8;
  }

  .aboutBanner__text {
    font-size: 14px;
  }

  section#about {
    padding-bottom: 0;
    border-radius: 20px;
    padding-top: 30px;
  }

  .mobileBuildingImage {
    display: flex !important;
    justify-content: flex-end !important;
  }
}

/* ==========================================================================
   Admission Process Section
   ========================================================================== */

.admissionSection {
  background: url('../images/clippathback.webp');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: var(--space-20) 0;
  position: relative;
  padding-bottom: 0px;
}

.admissionTitle {
  font-family: var(--font-family-primary);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--font-weight-bold);
  color: var(--color-headings);
  text-align: center;
  margin-bottom: var(--space-12);
}

.admissionContent {
  display: grid;
  grid-template-columns: 35% 65%;
  gap: var(--space-12);
  align-items: stretch;
}

.smallText {
  font-weight: var(--font-weight-regular);
}

/* Left Side: Tabs */
.admissionTabs {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  justify-content: space-between;
}

.tabLabels {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  align-items: flex-end;

}

.tabLabel {
  border: 1px solid var(--color-accent-1);
  border-radius: var(--border-radius-200);
  padding: var(--space-8) var(--space-5);
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.tabLabel:hover {
  background: var(--color-accent-1);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.tabLabel.active {
  background: var(--color-accent-1);
  border-color: var(--color-headings);
}

.tabLabel__text {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-headings);
  transition: color 0.3s ease;
}

.tabLabel:hover .tabLabel__text,
.tabLabel.active .tabLabel__text {
  color: var(--color-primary-white);
}

/* Important Dates Box */
.importantDates {
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid var(--color-accent-1);
  border-radius: 20px 20px 0 0;
  padding: var(--space-6);
  margin-bottom: 0;
  padding-bottom: 30px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.importantDates__title {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-headings);
  text-align: center;
  margin-bottom: var(--space-4);
}

.importantDates__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  align-items: flex-start;
}

.dateItem__label,
.dateItem__value {
  flex: 1;
}

.dateItem {
  display: flex;
  justify-content: space-between;
  border: 0.5px solid #ff8e0b78;
  width: 100%;
}

/* .dateItem:last-child {
  border-bottom: none;
} */

.dateItem__label {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-headings);
  padding: var(--space-2) var(--space-2);
  display: flex;
  align-items: center;
}

.dateItem__value {
  font-family: var(--font-family-primary);
  font-size: 14px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary-white);
  background: var(--color-button);
  padding: var(--space-2) var(--space-2);
  line-height: 1.2;
  display: flex;
  align-items: center;
}

/* Right Side: Tab Content */
.admissionTabContent {
  background: rgba(255, 255, 255, 0.54);
  border: 1px solid var(--color-accent-1);
  border-radius: var(--border-radius-lg) var(--border-radius-lg) 0 0;
  padding: 60px 70px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  backdrop-filter: blur(10px);
  overflow-x: hidden;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.tabContent {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.contentSection {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  border-radius: var(--border-radius-md);
}

.contentSection__icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.contentSection__icon-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.contentSection__content {
  flex: 1;
  min-width: 0;
  overflow-x: hidden;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.contentSection__title {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-headings);
  margin-bottom: var(--space-3);
}

.contentSection__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.contentSection__list li {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  color: var(--color-paragraph);
  line-height: 1.6;
  margin-bottom: var(--space-2);
  position: relative;
  padding-left: var(--space-6);
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
}

.contentSection__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 16px;
  height: 16px;
  background-image: url('../images/limarker.svg');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

/* Financial Support */
.financialSupport {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.financialItem {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: var(--space-3);
  background: var(--color-primary-white);
  border-radius: var(--border-radius-sm);
  flex-direction: column;
}

.financialItem__label {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-1xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-headings);
}

.financialItem__amount {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-medium);
  color: var(--color-headings);
}

/* Responsive Design */
@media (max-width: 1350px) and (min-width: 1024px) {
  .admissionContent {
    gap: var(--space-6);
  }
}

@media (max-width: 1024px) {
  .admissionContent {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .tabLabels {
    flex-direction: row;
    justify-content: center;
  }

  .tabLabel {
    flex: 1;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .contentSection__title {
    display: flex;
    align-items: flex-end;
    gap: 20px;
    text-align: left;
  }

  .contentSection__title.eli:before {
    content: url("../images/group.svg");
  }

  .contentSection__title.fina:before {
    content: url("../images/money.svg");
  }

  .contentSection__title.full:before {
    content: url("../images/time.svg");
  }

  .contentSection__title.indus:before {
    content: url("../images/tick.svg");
  }

  .contentSection__title.carrer:before {
    content: url("../images/business.svg");
  }

  .contentSection__title.part:before {
    content: url("../images/group.svg");
  }

  .contentSection__title.elig:before {
    content: url("../images/group.svg");
  }

  .financialSupport {
    flex-direction: column;
  }

  .admissionTitle,
  .aboutTitle {
    font-size: 32px;
    margin-bottom: 24px;
  }

  .admissionSection {
    padding: var(--space-16) 0;
  }

  .admissionContent {
    grid-template-columns: 1fr;
    gap: var(--space-6);
    padding: 0 var(--space-4);
  }

  .tabLabels {
    flex-direction: column;
    gap: var(--space-2);
  }

  .tabLabel {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    text-align: center;
  }

  .admissionTabContent {
    padding: var(--space-4);
    margin: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow-x: hidden;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }

  .contentSection {
    flex-direction: column;
    text-align: center;
    gap: var(--space-3);
  }

  .contentSection__icon {
    align-self: center;
  }

  .contentSection__title {
    font-size: var(--font-size-lg);
    margin-bottom: var(--space-2);
  }

  .contentSection__list li {
    font-size: var(--font-size-sm);
    padding-left: 20px;
    margin-bottom: var(--space-1);
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
    max-width: 100%;
    text-align: left;
  }

  .importantDates {
    width: 100%;
    margin-top: var(--space-4);
  }
}

/* ==========================================================================
   Specializations Section
   ========================================================================== */
.dblockText {
  display: block;
}

.specializationsSection {
  background: var(--primary-gradient);
  padding: var(--space-20) 0;
  position: relative;
}

.specializationsContent {
  display: grid;
  grid-template-columns: 40% 60%;
  gap: var(--space-12);
  align-items: start;
}

/* Left Side: Specialization Tabs */
.specializationsTabs {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  padding: var(--space-8) 0;
}

.specializationsTitle {
  font-family: var(--font-family-primary);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary-white);
  margin: 0;
  line-height: 1.2;
}

/* Pagination Line */
.paginationLine {
  position: relative;
  display: flex;
  align-items: center;
  margin-bottom: var(--space-4);
}

.paginationLine__bar {
  height: 2px;
  background: rgba(255, 255, 255, 0.2);
  flex: 1;
  margin-right: var(--space-4);
  position: relative;
  border-radius: 1px;
}

.paginationLine__progress {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  background: linear-gradient(to right, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0.8) 100%);
  border-radius: 1px;
  transition: width 0.5s ease;
}

.paginationLine__count {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.7);
}

/* Specialization List */
.specializationList {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.specializationItem {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
}

.specializationItem:hover {
  transform: translateX(5px);
}

.specializationItem.active {
  transform: translateX(10px);
}

.specializationItem__arrow {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
  flex-shrink: 0;
}

.specializationItem.active .specializationItem__arrow {
  opacity: 1;
}

.specializationItem__arrow-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.specializationItem__text {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.7);
  transition: all 0.3s ease;
}

.specializationItem.active .specializationItem__text {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary-white);
  margin-bottom: 10px;
}

.specializationItem:hover .specializationItem__text {
  color: var(--color-primary-white);
}


/* Right Side: Specialization Content */
.specializationsContentArea {
  background: var(--color-primary-white);
  border-radius: var(--border-radius-xl);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}

.specializationContent {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  align-items: stretch;
}

.specializationInfo {
  padding: var(--space-12);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  justify-content: space-between;
}

.specializationInfo__title {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-primary-black);
  margin: 0;
  line-height: 1.2;
}

.specializationInfo__description {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-paragraph);
  line-height: 1.6;
  margin: 0;
}

.specializationImage {
  display: flex;
  align-items: center;
  justify-content: center;
}

.specializationImage__img {
  width: 100%;
  height: auto;
  border-radius: var(--border-radius-lg);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Mobile apply now button - hidden by default */
.mobileApplyNowButton {
  display: none;
}

/* Responsive Design */
@media (max-width: 1024px) {
  .specializationsContent {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .specializationContent {
    grid-template-columns: 1fr;
    gap: var(--space-6);
    text-align: center;
  }

  .specializationImage {
    order: -1;
  }

  /* Horizontal scrollable specialization list on tablets and mobile */
  .specializationList {
    display: flex;
    flex-direction: row;
    gap: var(--space-3);
    overflow-x: auto;
    overflow-y: hidden;
    padding: var(--space-2) 0;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    /* Firefox */
    -ms-overflow-style: none;
    /* IE and Edge */
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  .specializationList::-webkit-scrollbar {
    display: none;
    /* Chrome, Safari, Opera */
  }

  .specializationItem {
    flex: 0 0 auto;
    min-width: 180px;
    white-space: nowrap;
    padding: var(--space-3) var(--space-4);
    background: transparent;
    border-radius: var(--border-radius-lg);
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }

  .specializationItem:hover {
    transform: translateY(-2px);
  }

  .specializationItem.active {
    background: transparent;
    color: var(--color-headings);
  }

  .specializationItem__text {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary-white);
    margin: 0;
  }

  .specializationItem.active .specializationItem__text {
    color: var(--color-primary-white);
  }

  .specializationItem__arrow {
    width: 16px;
    height: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .specializationItem__arrow-img {
    width: 100%;
    height: 100%;
    filter: brightness(0) invert(1);
    transform: rotate(90deg);
  }

  .specializationItem.active .specializationItem__arrow-img {
    filter: brightness(0) invert(1);
    transform: rotate(90deg);
    margin-top: -10px;
  }

  .specializationsTabs {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    box-sizing: border-box;
  }

  .specializationsSection {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    box-sizing: border-box;
  }
}

@media (max-width: 1600px) {
  .specializationInfo {
    padding: 30px;
  }
}

@media (max-width: 768px) {

  #specializations,
  #why-sbup {
    padding: 30px 0px;
  }

  span.specializationItem__text {
    margin-bottom: 10px;
  }

  .contentSection__list li::before {
    top: 2px;
  }

  .specializationsSection {
    padding: var(--space-16) 0;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    box-sizing: border-box;
  }

  .specializationsTabs {
    padding: var(--space-6) 0;
    padding-bottom: 0;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    box-sizing: border-box;
  }


  /* Hide original apply now button in tabs section on mobile */
  .specializationsTabs .applyNowButton {
    display: none;
  }

  .specializationsContentArea {
    padding: 0;
  }

  .specializationImage {
    order: 0;
  }

  .specializationInfo {
    padding: var(--space-6);
    text-align: left;
  }

  /* Mobile apply now button styling */
  .mobileApplyNowButton {
    display: block;
    padding: var(--space-6);
    text-align: center;
  }

  .specializationItem {
    padding: var(--space-2) 0;
  }

  .specializationItem__text {
    font-size: var(--font-size-base);
  }

  .specializationItem.active .specializationItem__text {
    font-size: var(--font-size-lg);
  }
}

/* ==========================================================================
   Why SBUP Section
   ========================================================================== */

.whySbupSection {
  background: url('../images/whysbup.webp'), var(--secondary-gradient);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: var(--space-20) 0;
  position: relative;
}

.whySbupContent {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-8);
}

.whySbupTitle {
  font-family: var(--font-family-primary);
  font-size: 48px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary-white);
  margin: 0;
  line-height: 1.2;
}

.whySbupTitle__small {
  font-weight: var(--font-weight-regular);
}

.whySbupTitle__highlight {
  color: var(--color-button);
  font-weight: var(--font-weight-semibold);
}

.whySbupDescription {
  font-family: var(--font-family-primary);
  font-size: 16px;
  font-weight: var(--font-weight-regular);
  color: var(--color-primary-white);
  line-height: 1.6;
  margin: 0;
  max-width: 800px;
}

/* Custom Slider Styles */
.whySbupCards {
  margin-top: var(--space-8);
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 0 var(--space-3);
  gap: var(--space-3);
  position: relative;
  width: 100%;

  /* Hide scrollbar */
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.whySbupCards::-webkit-scrollbar {
  display: none;
}

.whySbupCard {
  flex: 0 0 auto;
  padding: var(--space-8);
  background: rgba(255, 255, 255, 0.15);
  border-radius: var(--border-radius-lg);
  backdrop-filter: blur(10px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  position: relative;
  overflow: hidden;
  height: 100%;
  width: calc(100% / 4.2 - var(--space-6));
  min-width: calc(100% / 4.2 - var(--space-6));
  scroll-snap-align: start;
  scroll-snap-stop: always;
  will-change: transform;
  backface-visibility: hidden;
}

.whySbupCard:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  background: rgba(255, 255, 255, 0.2);
  transition: all 0.3s ease;
}

.whySbupCard__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-4);
  height: 100%;
}

.whySbupCard__icon {
  width: 60px;
  height: 60px;
  background: var(--color-primary-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.whySbupCard__icon-img {
  width: 32px;
  height: 32px;
  object-fit: contain;
}

.whySbupCard__title {
  font-family: var(--font-family-primary);
  font-size: 22px;
  font-weight: var(--font-weight-regular);
  color: var(--color-primary-white);
  margin: 0;
  line-height: 1.3;
  min-height: 60px;
}

.whySbupCard__description {
  font-family: var(--font-family-primary);
  font-size: 14px;
  font-weight: var(--font-weight-regular);
  color: var(--color-primary-white);
  line-height: 1.5;
  margin: 0;
  min-height: 85px;
}

/* Glass Effect Overlay */
.whySbupCard::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0.05) 100%);
  border-radius: inherit;
  pointer-events: none;
}

/* Slider Controls */
.whySbupSliderControls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-6);
  margin-top: var(--space-8);
}

.whySbupSliderBtn {
  width: 48px;
  height: 48px;
  background: rgba(255, 255, 255, 0.15);
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  backdrop-filter: blur(10px);
  color: var(--color-primary-white);
}

.whySbupSliderBtn:hover {
  background: rgba(255, 255, 255, 0.25);
  transform: scale(1.1);
}

.whySbupSliderBtn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.whySbupSliderDots {
  display: none;
}

.whySbupSliderDot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  cursor: pointer;
  transition: all 0.3s ease;
}

.whySbupSliderDot.active {
  background: var(--color-button);
  transform: scale(1.2);
}

/* Hide slider controls - using infinite scroll only */
.whySbupSliderBtn {
  display: none;
}

/* Responsive Design */
@media (max-width: 1600px) and (min-width: 1201px) {

  /* Show 3.2 slides for 1200px-1600px */
  .whySbupCards {
    padding: 0 var(--space-3);
  }

  .whySbupCard {
    width: calc(100% / 3.2 - var(--space-3));
    min-width: calc(100% / 3.2 - var(--space-3));
    flex-shrink: 0;
  }
}

@media (max-width: 1200px) and (min-width: 769px) {

  /* Show 2.2 slides for 768px-1200px */
  .whySbupCards {
    padding: 0 var(--space-3);
  }

  .whySbupCard {
    width: calc(100% / 2.2 - var(--space-3));
    min-width: calc(100% / 2.2 - var(--space-3));
    flex-shrink: 0;
  }
}

@media (max-width: 768px) {

  section#fees,
  section#testimonial,
  section.nirfSection {
    padding: 30px 0px;
  }

  .whySbupCard__title {

    min-height: 35px;
  }

  .whySbupSection {
    padding: var(--space-16) 0;
  }

  .whySbupTitle {
    font-size: clamp(2rem, 5vw, 3rem);
  }

  .whySbupDescription {
    font-size: 14px;
  }

  /* Show 1.1 slides on mobile - one full card + 10% of next card */
  .whySbupCards {
    padding: 0 var(--space-4);
  }

  .whySbupCard {
    width: calc(90% - var(--space-3));
    min-width: calc(90% - var(--space-3));
    flex-shrink: 0;
  }

  .whySbupSliderBtn--prev {
    left: -40px;
  }

  .whySbupSliderBtn--next {
    right: -40px;
  }

  .whySbupCard {
    padding: var(--space-6);
  }
}

@media (max-width: 480px) {
  .aboutBanner__text {
    font-size: 14px;
  }

  .aboutTitle {
    font-size: 28px;
  }

  .whySbupCard {
    width: calc(100% - var(--space-6));
    min-width: calc(100% - var(--space-6));
  }

  .whySbupSliderBtn {
    width: 40px;
    height: 40px;
  }

  .whySbupSliderBtn--prev {
    left: -35px;
  }

  .whySbupSliderBtn--next {
    right: -35px;
  }
}

@media (max-width: 480px) {
  .whySbupCard {
    width: calc(100% - var(--space-6));
    min-width: calc(100% - var(--space-6));
  }

  .whySbupCard__title {
    font-size: 20px;
  }

  .whySbupCard__description {
    font-size: 13px;
  }

  .whySbupSliderBtn {
    width: 40px;
    height: 40px;
  }

  .whySbupSliderBtn--prev {
    left: -35px;
  }

  .whySbupSliderBtn--next {
    right: -35px;
  }
}

/* ==========================================================================
   Fees Section
   ========================================================================== */

.feesSection {
  padding: var(--space-20) 0;
  background: var(--color-primary-white);
}



.feesTitle {
  font-family: var(--font-family-primary);
  font-size: var(--fees-title-size);
  font-weight: var(--font-weight-medium);
  color: var(--color-headings);
  text-align: center;
  margin-bottom: var(--space-6);
}

.feesDescription {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: var(--color-headings);
  text-align: center;
  margin-bottom: var(--space-12);
  line-height: 1.6;
  max-width: 800px;
}

/* Fee Cards */
.feesCards {
  display: grid;
  grid-template-columns: 1fr 1fr 2fr 1fr;
  gap: 0;
  margin-bottom: var(--space-12);
  align-items: center;
}

.feesCard {
  padding: 114px 34px 58px 34px;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  min-height: 200px;
}

.feesContent {
  place-items: center;
}

.feesCard--1 {
  background: var(--fees-card-bg-1);
}

.feesCard--2 {
  background: var(--fees-card-bg-2);
}

.feesCard--4 {
  background: var(--fees-card-bg-4);
}

.feesCard__title {
  font-family: var(--font-family-primary);
  font-size: var(--fees-card-title-size);
  font-weight: var(--font-weight-regular);
  color: var(--fees-text-light);
  margin: 0 0 var(--space-4) 0;
  text-align: left;
  line-height: 1.3;
}

.feesCard__amount {
  font-family: var(--font-family-primary);
  font-size: var(--fees-card-amount-size);
  font-weight: var(--font-weight-semibold);
  color: var(--fees-text-light);
  margin: 0;
  text-align: left;
}

/* Fees Table */
.feesTable {
  background: var(--color-primary-white);
  border-radius: var(--border-radius-lg);
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.feesTable__content {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-family-primary);
}

.feesTable__content thead {
  background: var(--color-table-headers);
}

.feesTable__content th {
  font-size: var(--fees-table-title-size);
  font-weight: var(--font-weight-medium);
  color: var(--fees-text-light);
  padding: var(--space-6);
  text-align: left;
  border: none;
}

.feesTable__content td {
  font-size: var(--fees-table-data-size);
  font-weight: var(--font-weight-regular);
  color: var(--color-paragraph);
  padding: var(--space-5);
  border: none;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.feesTable__content tbody tr:nth-child(even) {
  background: var(--fees-table-alt-bg);
}

.feesTable__content tbody tr:nth-child(odd) {
  background: var(--color-primary-white);
}

.feesTable__content tbody tr:last-child td {
  border-bottom: none;
}

/* Responsive Design for Fees Section */
@media (max-width: 1200px) {
  .testimonialContent {
    flex-direction: column;
  }

  .feesCards {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 0;
    margin-bottom: var(--space-8);
  }

  .feesCard {
    min-height: 120px;
    padding: var(--space-6);
    flex: 1;
    width: 100%;
  }

  .feesCard__title {
    font-size: 18px;
    text-align: center;
  }

  .feesCard__amount {
    font-size: 24px;
    text-align: center;
  }

  .feesTable {
    margin-top: var(--space-8);
    order: 4;
    width: 100%;
  }

  .feesTable__content th,
  .feesTable__content td {
    padding: var(--space-4);
    font-size: 14px;
  }

  .feesTitle {
    font-size: 36px;
  }

  .feesDescription {
    font-size: var(--font-size-base);
  }
}

@media (max-width: 768px) {

  .mobileAdmissionRight,
  input.formInput,
  select.formSelect {
    border: 1px solid var(--color-button) !important;
  }
}

@media (max-width: 480px) {
  .feesCard {
    min-height: 120px;
    padding: var(--space-4);
  }

  .feesCard__title {
    font-size: 18px;
  }

  .feesCard__amount {
    font-size: 24px;
  }

  .feesTable__content th,
  .feesTable__content td {
    padding: var(--space-3);
    font-size: 12px;
  }

  .feesTitle {
    font-size: 28px;
  }
}

/* ==========================================================================
   Testimonial Section
   ========================================================================== */

.testimonialSection {
  padding: var(--space-20) 0;
  background: var(--color-primary-white);
}

.testimonialContent {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: start;
}

/* Left Side Content */
.testimonialLeft {
  padding-right: var(--space-8);
}

.testimonialTitle {
  font-family: var(--font-family-primary);
  font-size: var(--fees-title-size);
  font-weight: var(--font-weight-medium);
  color: var(--color-headings);
  margin-bottom: var(--space-6);
  text-align: left;
}

.testimonialDescription {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: var(--color-paragraph);
  line-height: 1.6;
  text-align: left;
}

/* Right Side Slider */
.testimonialRight {
  position: relative;
}

.testimonialSlider {
  position: relative;
}

.testimonialCards {
  /* Slick will override these styles */
  position: relative;
}

.testimonialCustomNav--desktop {
  display: flex;
  align-items: flex-end;
  margin-top: auto !important;
  padding-bottom: 16px;
  justify-content: flex-end;
}

.testimonialLeft {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}


@media (max-width: 1200px) and (min-width: 769px) {
  .testimonialLeft {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }

  .testimonialCustomNav.testimonialCustomNav--desktop {
    margin-top: 20px !important;
  }
}

.testimonialCard {
  background: var(--color-primary-white);
  border-radius: var(--border-radius-lg);
  overflow: hidden;
  margin: 0 var(--space-3);
  box-shadow: 0px 0px 6.8px 0px #0000001A;
  height: auto;
  display: flex;
  flex-direction: row;
  align-items: stretch;
}

.testimonialSlider .slick-track {
  padding: 5px 0px;
}


.testimonialCard__image {
  flex: 0 0 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
}



.testimonialCard__content {
  flex: 1;
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.testimonialCard__text {
  font-family: var(--font-family-primary);
  font-size: 20px;
  font-weight: var(--font-weight-regular);
  color: var(--color-paragraph);
  line-height: 1.6;
  margin-bottom: var(--space-4);
}

.testimonialCard__quotes {
  margin-bottom: var(--space-4);
}

.testimonialCard__quotes img {
  width: 40px;
  height: 40px;
  opacity: 0.7;
}

.testimonialCard__details {
  margin-top: auto;
  background: var(--primary-gradient);
}

.testimonialCard__name {
  font-family: var(--font-family-primary);
  font-size: 24px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary-white);
  margin: 0 0 var(--space-2) 0;
}

.testimonialCard__qualification {
  font-family: var(--font-family-primary);
  font-size: 20px;
  font-weight: var(--font-weight-regular);
  color: var(--color-primary-white);
  margin: 0;
}

/* Slider Navigation */
.testimonialNavigation {
  display: none;
}


/* Responsive Design */
@media (max-width: 1100px) {
  .testimonialCard {
    flex-direction: column;
  }
}

@media (max-width: 768px) {
  .slideBox {
    flex: 0 0 100%;
    max-width: 250px;
    min-height: 150px;
    padding: var(--space-4);
  }

  .slideBox__content h3 {
    font-size: 18px;
  }

  .slideBox__content p {
    font-size: 14px;
  }
}


.testimonialNavBtn {
  width: 50px;
  height: 50px;
  background: #E5E5E5;
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  padding: 16.5px;
}

.testimonialNavBtn:hover {
  background: #D0D0D0;
  transform: scale(1.05);
}

.testimonialNavBtn img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.testimonialNavBtn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

/* Responsive Design for Testimonial Section */
@media (max-width: 1024px) {
  section#fees {
    padding-bottom: 20px;
  }

  .testimonialContent {
    grid-template-columns: 1fr;
    gap: var(--space-12);
  }

  .testimonialLeft {
    padding-right: 0;
    text-align: center;
  }

  .testimonialTitle,
  .testimonialDescription {
    text-align: center;
  }
}

/* ==========================================================================
   Testimonial Slider Styles
   ========================================================================== */

/* Fix width and container issues */
.testimonialRight {
  width: 100%;
  overflow: hidden;
}

.testimonialSlider {
  width: 100%;
  overflow: hidden;
}

.testimonialCards {
  width: 100%;
  overflow: hidden;
}

.testimonialCards .slick-slide {
  width: auto;
  height: auto;
}

.testimonialCards .slick-slide>div {
  width: 100%;
  height: 100%;
  box-sizing: border-box;

}

/* Flexbox layout instead of grid */
.testimonialContent {
  display: flex;
  gap: 3rem;
  align-items: stretch;

}

/* Left content - fixed width */
.testimonialLeft {
  flex: 0 0 20%;
  padding-right: 1rem;
}

section#testimonial .container {
  padding-right: 0;
}

/* Right slider - flexible width */
.testimonialRight {
  flex: 1;
  padding-left: 1rem;
  min-width: 0;
  /* Prevent flex item from overflowing */
}

/* Slider container spacing */
.testimonialSlider {
  padding: 1rem 0;
  width: 100%;
}

/* Card spacing within slider */
.testimonialCards .slick-slide {
  padding: 0 0.5rem;
}

/* Ensure slider doesn't overflow */
.testimonialCards {
  max-width: 100%;
  overflow: hidden;
}

/* Prevent slides from breaking out of container */
.testimonialCards .slick-track {
  display: flex;
  align-items: stretch;
}

.testimonialCards .slick-slide {
  height: auto;
  display: flex;
}

.testimonialCards .slick-slide>div {
  width: 100%;
  height: 100%;
}

/* Ensure testimonial cards don't exceed container */
.testimonialCard {
  max-width: 100%;
  box-sizing: border-box;
}

/* Testimonial Card Layout - Image Left, Content Right */
.testimonialCard {
  display: flex !important;
  background: white;
  border-radius: 20px;
  overflow: hidden;
  margin: 0 10px;
  min-height: 300px;
}

.testimonialCard__image {
  flex: 0 0 40%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-right: 30px;
}

.testimonialCard__content {
  flex: 1;
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  background-image: url('../images/quotes.svg');
  background-repeat: no-repeat;
  background-position: right 70%;
  background-size: 40%;
  background-opacity: 0.1;
}

.testimonialCard__text {
  font-family: var(--font-family-primary);
  font-size: 18px;
  font-weight: var(--font-weight-regular);
  color: #333;
  line-height: 1.6;
  min-height: 190px;
  margin: 0 0 20px 0;
}


.testimonialCard__details {
  margin-top: auto;
  background: linear-gradient(90deg, #002581 0%, #00081B 100%);
  padding: 20px;
  border-radius: 12px 0px 12px 12px;
  margin: 20px -30px -30px -30px;
}

.testimonialCard__name {
  font-family: var(--font-family-primary);
  font-size: 20px;
  font-weight: var(--font-weight-semibold);
  color: white;
  margin: 0 0 5px 0;
}

.testimonialCard__qualification {
  font-family: var(--font-family-primary);
  font-size: 16px;
  font-weight: var(--font-weight-regular);
  color: white;
  margin: 0;
  padding-left: 25px;
}

/* Responsive adjustments for cards */
@media (max-width: 768px) {
  .testimonialCard {
    flex-direction: column;
    min-height: auto;
  }

  .testimonialCard__image {
    flex: none;
    padding: 20px;
  }

  .testimonialCard__image img {
    width: 100%;
  }

  .testimonialCard__content {
    padding: 20px;
  }

  .testimonialCard__text {
    font-size: 16px;
  }

  .testimonialCard__name {
    font-size: 18px;
  }

  .testimonialCard__qualification {
    font-size: 14px;
  }

  .testimonialCard__details {
    margin: 15px -20px -20px -20px;
    border-radius: 0 0 20px 20px;
  }
}

/* Responsive adjustments */
@media (max-width: 1024px) {
  .testimonialContent {
    gap: 2rem;
  }

  .testimonialLeft {
    flex: 0 0 40%;
    padding-right: 0.5rem;
  }

  .testimonialRight {
    padding-left: 0.5rem;
  }
}

@media (max-width: 768px) {
  .testimonialContent {
    flex-direction: column;
    gap: 2rem;
  }

  .testimonialLeft {
    flex: none;
    padding-right: 0;
    text-align: center;
  }

  .testimonialRight {
    flex: none;
    padding-left: 0;
    width: 100%;
  }

  .testimonialSlider {
    padding: 0.5rem 0;
  }
}

/* Hide default Slick arrows */
.testimonialCards .slick-prev,
.testimonialCards .slick-next {
  display: none !important;
}

/* Custom Navigation Arrows */
.testimonialCustomNav {
  display: flex;
  gap: 1rem;
  margin-top: 2rem;
  justify-content: flex-start;
}

/* Desktop navigation - show by default */
.testimonialCustomNav--desktop {
  display: flex;
}

/* Mobile navigation - hidden by default */
.testimonialCustomNav--mobile {
  display: none;
}

.testimonialCustomNav__btn {
  width: 50px;
  height: 50px;
  background: #E5E5E5;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  padding: 0;
}

.testimonialCustomNav__btn:hover {
  background: #D0D0D0;
  transform: scale(1.05);
}

.testimonialCustomNav__btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.testimonialCustomNav__btn img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

/* Responsive adjustments for custom nav */
@media (max-width: 768px) {

  /* Hide desktop navigation on mobile */
  .testimonialCustomNav--desktop {
    display: none;
  }

  /* Show mobile navigation below testimonial cards */
  .testimonialCustomNav--mobile {
    display: flex;
    justify-content: center;
    margin-top: 1.5rem;
    margin-bottom: 0;
  }
}

/* ==========================================================================
   NIRF Ranking Section
   ========================================================================== */
section.nirfSection {
  padding-bottom: var(--container-padding);
}


.nirfContent {
  display: flex;
  align-items: center;
  gap: 3rem;
  border: 1px solid #CCCCCC;
  padding: 32px 37px;
  border-radius: 15px;
}

.nirfLeft {
  flex: 0 0 50%;
  padding: 60px 40px;
  background: var(--nirf-gradient);
  border-radius: 20px;
}

.nirfRight {
  flex: 0 0 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 2rem;
}

.nirfTitle {
  font-family: var(--font-family-primary);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--font-weight-medium);
  color: var(--color-headings);
  margin: 0 0 var(--space-4) 0;
  line-height: 1.2;
}

.nirfSubtitle {
  font-family: var(--font-family-primary);
  font-size: 18px;
  font-weight: var(--font-weight-regular);
  color: var(--color-headings);
  margin: 0 0 var(--space-6) 0;
}

.nirfDescription {
  font-family: var(--font-family-primary);
  font-size: 18px;
  font-weight: var(--font-weight-regular);
  color: var(--color-paragraph);
  line-height: 1.6;
  margin: 0 0 var(--space-8) 0;
}

.nirfButton {
  background: var(--color-button);
  color: var(--color-primary-white);
  border: none;
  border-radius: 8px;
  padding: 12px 24px;
  font-family: var(--font-family-primary);
  font-size: 16px;
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: all 0.3s ease;
}

.nirfButton:hover {
  background: #e67a0a;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(255, 142, 11, 0.3);
}

.nirfLogo {
  max-width: 100%;
  height: auto;
  max-height: 300px;
  object-fit: contain;
}

/* Responsive adjustments for NIRF section */
@media (max-width: 1024px) {
  .nirfContent {
    gap: 2rem;
  }

  .nirfLeft {
    padding: 60px 40px;
  }

  .nirfRight {
    padding-left: 1rem;
  }

}

@media (max-width: 768px) {
  .nirfContent {
    flex-direction: column;
    gap: 2rem;
    text-align: center;
  }

  .nirfLeft {
    flex: none;
    padding: 40px 30px;
  }

  .nirfRight {
    flex: none;
    padding-left: 0;
  }


  .nirfSubtitle,
  .nirfDescription {
    font-size: 16px;
  }

  .nirfLogo {
    max-height: 200px;
  }
}

/* ==========================================================================
   FAQ Section
   ========================================================================== */

.faqSection {
  padding: var(--space-20) 0;
  background: linear-gradient(180deg, #152157 0%, #0F1635 100%), url('../images/textureblue.webp') no-repeat center center;
  background-size: cover;
  background-blend-mode: overlay;
}

.faqContent {
  display: flex;
  gap: 3rem;
  align-items: flex-start;
}

.faqLeft {
  flex: 0 0 30%;
  padding-right: 2rem;
}

.faqRight {
  flex: 0 0 70%;
}

.faqTitle {
  font-family: var(--font-family-primary);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary-white);
  margin: 0 0 var(--space-4) 0;
  line-height: 1.3;
}

.faqDescription {
  font-family: var(--font-family-primary);
  font-size: 16px;
  font-weight: var(--font-weight-regular);
  color: var(--color-primary-white);
  line-height: 1.6;
  margin: 0;
  opacity: 0.9;
}

.faqAccordion {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.faqItem {
  background: url('../images/accordianback.webp') no-repeat center right !important;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  background-size: cover !important;
}

.faqQuestion {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  cursor: pointer;
  background: transparent;
  position: relative;
  z-index: 5;
}

.faqQuestion h3 {
  font-family: var(--font-family-primary);
  font-size: 24px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-headings);
  margin: 0;
  flex: 1;
  padding-right: 1rem;
}

.faqToggle {
  background: #FF8E0B;
  border: none;
  border-radius: 8px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  flex-shrink: 0;
  position: relative;
  z-index: 10;
  pointer-events: auto;
}

.faqToggle:hover {
  background: #e67a0a;
  transform: scale(1.05);
}

.faqIcon {
  width: 20px;
  height: 20px;
  transition: all 0.3s ease;
}

.faqIcon--close {
  display: block !important;
}

.faqIcon--open {
  display: none !important;
}

.faqAnswer {
  padding: 0 24px;
  max-height: 0;
  overflow: hidden;
  transition: all 0.3s ease;
  background: transparent;
}

.faqAnswer.active {
  padding: 24px;
  max-height: 500px;
}

.faqAnswer p,
.faqAnswer li {
  font-family: var(--font-family-primary);
  font-size: 16px;
  font-weight: var(--font-weight-regular);
  color: var(--color-headings);
  line-height: 1.6;
  margin: 0 0 12px 0;
}

.faqAnswer ul {
  margin: 0;
  padding-left: 20px;
}

.faqAnswer li {
  margin-bottom: 8px;
}

.faqItem.active .faqIcon--close {
  display: none !important;
}

.faqItem.active .faqIcon--open {
  display: block !important;
}

/* Responsive adjustments for FAQ section */
@media (max-width: 1024px) {
  .faqContent {
    gap: 2rem;
  }

  .faqLeft {
    flex: 0 0 30%;
    padding-right: 1rem;
  }

  .faqRight {
    flex: 0 0 70%;
  }

  .faqQuestion h3 {
    font-size: 20px;
  }
}

@media (max-width: 768px) {
  section#testimonial .container {
    padding-right: 20px;
    padding-left: 20px;
  }

  .faqContent {
    flex-direction: column;
    gap: 2rem;
  }

  .faqLeft {
    flex: none;
    padding-right: 0;
    text-align: center;
  }

  .faqRight {
    flex: none;
  }

  .faqTitle {
    font-size: 32px;
  }

  .faqQuestion h3 {
    font-size: 18px;
  }

  .faqAnswer p,
  .faqAnswer li {
    font-size: 14px;
  }

  .faqAccordion {
    gap: 20px;
  }
}

@media (max-width: 768px) {
  .nirfContent {
    background: linear-gradient(135deg, #dee4ff4d 0%, #dde3ff4d 100%);
    flex-direction: column-reverse;
  }

  .nirfLeft {
    background: none;
  }

  .testimonialCard {
    flex-direction: column;
    margin: 0 8px;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    min-height: auto;
  }

  .testimonialCard__image {
    flex: none;
    padding: var(--space-4);
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .testimonialCard__image img {
    width: 80%;
    height: auto;
    object-fit: cover;
    border-radius: 8px;
  }

  .testimonialCard__content {
    padding: var(--space-4);
  }

  .testimonialCard__text {
    font-size: 16px;
    line-height: 1.5;
    margin-bottom: var(--space-3);
  }

  .testimonialCard__name {
    font-size: 18px;
    margin-bottom: var(--space-1);
  }

  .testimonialCard__qualification {
    font-size: 14px;
  }

  .testimonialTitle {
    font-size: 36px;
  }

  .testimonialDescription {
    font-size: var(--font-size-base);
  }
}

@media (max-width: 480px) {
  .nirfLeft {
    padding: 0 20px;
  }

  .nirfRight {
    width: 50%;
  }

  .nirfTitle {
    font-size: 20px;
  }

  .testimonialCard__text {
    font-size: 16px;
  }

  .testimonialCard__name {
    font-size: 20px;
  }

  .testimonialCard__qualification {
    font-size: 16px;
  }

  .testimonialTitle {
    font-size: 28px;
  }
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-normal);
  color: var(--color-paragraph);
  background-color: var(--color-primary-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* Prevent horizontal scroll */
  overflow-x: hidden;
}

/* Prevent horizontal scroll on all sections */
.pageSection,
.aboutSection,
.admissionSection,
.specializationsSection,
.whySbupSection,
.feesSection,
.testimonialSection,
.nirfSection,
.faqSection,
.ctaSection,
.mobileAdmissionSection {
  overflow-x: hidden;
  box-sizing: border-box;
}

section#about {
  overflow: unset;
}

/* Mobile responsive fixes for all containers */
@media (max-width: 768px) {

  .container,
  .aboutContent,
  .admissionContent,
  .specializationsContent,
  .whySbupContent,
  .feesContent,
  .testimonialContent,
  .nirfContent,
  .faqContent,
  .ctaContent,
  .mobileAdmissionContent {
    width: 100%;
    max-width: 100%;
    padding-left: var(--space-4);
    padding-right: var(--space-4);
    box-sizing: border-box;
  }

  /* Override admission content padding since it has its own mobile styles */
  .admissionContent {
    padding-left: 0;
    padding-right: 0;
  }

  /* Fix any fixed widths that could cause horizontal scroll */
  .featureText,
  .slideBox,
  .testimonialCard,
  .whySbupCard,
  .feesCard {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
}

/* ==========================================================================
   Layout Components
   ========================================================================== */

.container {
  width: 100%;
  margin: 0 auto;
  padding: 0 var(--container-padding);
}


/* ==========================================================================
   Hero Section Styles
   ========================================================================== */

.heroSection {
  display: flex;
  align-items: center;
  background: var(--background-primary);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: var(--color-primary-white);
  position: relative;
  overflow: hidden;
}


.heroContent {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-16);
  align-items: start;
  position: relative;
  align-items: center;
  padding: 190px 0 45px 0;
}

@media (min-width: 768px) {
  .heroContent {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
  }
}

.heroText {
  text-align: center;
}

@media (min-width: 768px) {
  .heroText {
    text-align: left;
  }
}

.heroTitle {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-normal);
  margin-bottom: var(--space-6);
  color: var(--color-headings);
  background: linear-gradient(45deg, var(--color-primary-white), rgba(255, 255, 255, 0.8));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

@media (min-width: 640px) {
  .heroTitle {
    font-size: var(--font-size-5xl);
  }
}

@media (min-width: 1024px) {
  .heroTitle {
    font-size: var(--font-size-6xl);
  }
}

.heroDescription {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--space-8);
  color: var(--color-primary-text);
  max-width: 500px;
}

@media (min-width: 768px) {
  .heroDescription {
    font-size: var(--font-size-xl);
  }
}

.heroButtons {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  align-items: center;
}

@media (min-width: 640px) {
  .heroButtons {
    flex-direction: row;
    gap: var(--space-6);
    justify-content: center;
  }
}

@media (min-width: 768px) {
  .heroButtons {
    justify-content: flex-start;
  }
}

.heroImage {
  display: flex;
  justify-content: center;
  align-items: center;
}

.heroImage__img {
  width: 100%;
  max-width: 600px;
  height: auto;
  border-radius: var(--border-radius-2xl);
  box-shadow: var(--shadow-2xl);
}

.heroImage__img:hover {
  transform: scale(1.02);
}

/* ==========================================================================
   Accessibility & Focus Styles
   ========================================================================== */

:focus {
  outline: 2px solid var(--color-accent-2);
  outline-offset: 2px;
}

:focus:not(:focus-visible) {
  outline: none;
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

/* ==========================================================================
   Left Side: Research Journey Content
   ========================================================================== */

.heroLeft {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.researchJourney {
  max-width: 100%;
}

.journeyTitle {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-normal);
  margin-bottom: var(--space-4);
  color: var(--color-primary-text);
}

.journeyTitle__part1 {
  margin-bottom: var(--space-2);
  font-weight: var(--font-weight-bold);
}

.programTypes {
  gap: var(--space-1);
  margin-bottom: var(--space-6);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-button);
  line-height: var(--line-height-tight);
}

.programTypes__text {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-regular);
  color: var(--color-headings);
  line-height: var(--line-height-tight);
}

.applyBanner {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background-image: url('../images/Layer 3.svg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: var(--color-primary-white);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--border-radius-lg);
  margin-bottom: var(--space-6);
}

.applyBanner__text {
  padding-left: var(--space-4);
  padding-right: var(--space-4);
  padding-top: var(--space-2);
  padding-bottom: var(--space-2);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
}

.applyBanner__arrow {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
}

.stipendsBanner {
  background: url('../images/Clip path group.webp'), linear-gradient(135deg, var(--color-accent-1), var(--color-headings));
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: var(--color-primary-white);
  padding: 20px 34px 29px;
  border-radius: var(--border-radius-xl);
  margin-bottom: 71px;
  box-shadow: 0 4px 12px rgba(0, 45, 129, 0.3);
}

.stipendsBanner__title {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  text-align: center;
  margin-bottom: var(--space-4);
}

.stipendsBanner__content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.stipendItem {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-1);
  align-items: flex-start;
}

.stipendItem__content {
  border: 1px solid var(--color-button);
  display: flex;
  box-sizing: content-box;
}

.stipendItem__label {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  margin-bottom: 14px;
}

.stipendItem__amount {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  padding: 8px 13px;
  place-content: center;
}

.stipendItem__period {
  background-color: var(--color-button);
  color: var(--color-primary-white);
  padding: 8px 17px;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-medium);
}

.disclaimer {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  color: var(--color-primary-text);
  font-style: italic;
  text-align: left;
  font-weight: var(--font-weight-medium);
}

/* ==========================================================================
   Bottom Person Image
   ========================================================================== */

.heroBottomImage {
  position: absolute;
  bottom: 0;
  left: 59%;
  transform: translateX(-50%);
  z-index: 10;
  pointer-events: none;
}

.heroBottomImage__img {
  display: block;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.3));
}

/* ==========================================================================
   Mobile Building Image Section
   ========================================================================== */

.mobileBuildingSection {
  display: none;
  padding: var(--space-8) 0;
  background: var(--color-primary-white);
}

.mobileBuildingImage {
  display: flex;
  justify-content: center;
  align-items: center;

}

.mobileBuildingImage__img {
  width: 100%;
  max-width: 600px;
  height: auto;
  object-fit: cover;
  border-radius: var(--border-radius-lg);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}

/* Show mobile building section only on mobile */
@media (max-width: 768px) {
  .testimonialLeft {
    align-items: center;
  }

  .importantDates__content {
    gap: 12px;
  }

  .testimonialContent {
    padding: 0;
  }

  .testimonialContent .slick-slide {
    padding: 0 10px;
  }

  .testimonialCard {
    margin: 0 5px;
    min-height: auto;
  }


  .aboutLeft {
    padding: 0px 30px;
  }

  .mobileBuildingImage__img {
    width: 100%;
    max-width: unset;
  }

  section#about .container {
    padding: 0;
  }

  section#about .aboutContent {
    padding: 0;
  }

  .mobileBuildingSection {
    display: block;
  }
}

.forMobile {
  display: none;
}

/* Mobile adjustments for banner person image and stipends layout */
@media (max-width: 768px) {
  .stipendsBanner__title {
    text-align: left;
  }

  p.disclaimer.forMobile {
    position: absolute;
    bottom: 20px;
    z-index: 999;
  }

  .forMobile {
    display: block;
  }

  .forDesktop {
    display: none;
  }

  .heroBottomImage {
    position: absolute;
    bottom: 0px;
    right: var(--space-4);
    left: auto;
    transform: none;
    z-index: 99;
  }

  .heroBottomImage__img {
    max-width: 350px;
    height: auto;
  }

  .stipendsBanner {
    padding: 16px;
    margin-bottom: var(--space-8);
  }

  .stipendsBanner__content {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  .stipendItem {
    align-items: stretch;
    text-align: left;
  }

  .stipendItem__content {
    display: inline-flex;
    width: fit-content;
    gap: 10px;
    padding: 0;
    box-sizing: border-box;
    flex-direction: row;
    justify-content: space-between;
    flex-wrap: wrap;
  }

  .stipendItem__amount {
    font-size: var(--font-size-base);
    padding: 8px 12px;
  }

  .stipendItem__period {
    font-size: var(--font-size-sm);
    padding: 8px 12px;
  }
}

/* ==========================================================================
   Right Side: Admission Form
   ========================================================================== */

.heroRight {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
}

.admissionForm {
  background-color: #ffffff0d;
  padding: var(--space-8);
  border-radius: var(--border-radius-xl);
  border: 1px solid var(--color-button);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  width: 100%;
  backdrop-filter: blur(40px);
  z-index: 11;
  max-width: 500px;
}

/* Thank You Message Styles */
.thankYouMessage {
  background-color: #ffffff0d;
  padding: var(--space-10);
  border-radius: var(--border-radius-xl);
  border: 1px solid var(--color-button);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  width: 100%;
  backdrop-filter: blur(40px);
  z-index: 11;
  max-width: 500px;
  text-align: center;
}

.thankYouContent {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
}

.thankYouTitle {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-button);
  margin: 0;
  text-align: center;
}

.thankYouText {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: var(--color-headings);
  line-height: 1.6;
  margin: 0;
  text-align: center;
}

.thankYouNote {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--color-paragraph);
  line-height: 1.5;
  margin: 0;
  text-align: center;
  background: rgba(255, 142, 11, 0.1);
  padding: var(--space-4);
  border-radius: var(--border-radius-md);
  border-left: 4px solid var(--color-button);
  width: 100%;
  box-sizing: border-box;
}

.formTitle {
  font-family: var(--font-family-secondary);
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-headings);
  text-align: center;
  margin-bottom: var(--space-4);
}

.admissionForm__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.formGroup {
  display: flex;
  flex-direction: column;
}

.formInput,
.formSelect {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  padding: var(--space-3);
  border: 1px solid var(--color-button);
  border-radius: var(--border-radius-md);
  transition: var(--transition-normal);
  background-color: transparent;
  color: var(--color-headings);
}

.formInput::placeholder {
  color: var(--color-headings);
  opacity: 0.7;
}

.formInput:focus,
.formSelect:focus {
  outline: none;
  border-color: var(--color-button);
  box-shadow: 0 0 0 3px rgba(255, 142, 11, 0.1);
}

.formSubmit {
  width: 100%;
  margin-top: var(--space-2);
}

@media (min-width: 640px) {
  .journeyTitle {
    font-size: var(--font-size-3xl);
  }

  .programTypes {
    font-size: var(--font-size-3xl);
  }

  .programTypes__text {
    font-size: var(--font-size-xl);
  }
}

@media (min-width: 1024px) {
  .journeyTitle {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-weight-light);
  }

  .programTypes__text {
    font-size: var(--font-size-3xl);
  }
}

@media print {

  *,
  *::before,
  *::after {
    background: transparent !important;
    color: black !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }

  .heroSection {
    background: white !important;
    color: black !important;
  }

  .heroSection::before {
    display: none;
  }
}

/* ==========================================================================
   Footer Section
   ========================================================================== */

.mainFooter {
  background-color: var(--color-primary-black);
  padding: var(--space-6) 0;
}

.footerContent {
  text-align: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--container-padding);
}

.footerText {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-primary-white);
  margin: 0;
  line-height: var(--line-height-normal);
}

/* Footer Responsive Design */
@media (max-width: 768px) {
  .mainFooter {
    padding: var(--space-4) 0;
  }

  .footerContent {
    padding: 0 var(--space-4);
  }

  .footerText {
    font-size: var(--font-size-sm);
  }
}

/* ==========================================================================
   Call to Action Section
   ========================================================================== */

.ctaSection {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-image: url('../images/footerback.webp');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: 190px var(--container-padding) 500px;
  text-align: center;
  overflow: hidden;
}


.ctaContent {
  position: relative;
  z-index: 2;
  max-width: 1200px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
}

.ctaTitle {
  font-family: var(--font-family-primary);
  font-size: 48px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary-white);
  line-height: 1.2;
  margin: 0;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}



.ctaDescription {
  font-family: var(--font-family-primary);
  font-size: 24px;
  font-weight: var(--font-weight-medium);
  color: var(--color-primary-white);
  line-height: 1.5;
  max-width: 1000px;
  margin: 0;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.ctaSubtext {
  font-family: var(--font-family-primary);
  font-size: 18px;
  font-weight: var(--font-weight-medium);
  color: var(--color-primary-white);
  line-height: 1.4;
  margin: 0;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
  padding-bottom: var(--space-16);
}

/* Responsive Design for CTA Section */
@media (max-width: 768px) {
  .ctaSection {
    padding: 120px var(--space-4) 500px;
  }

  .ctaContent {
    gap: var(--space-6);
  }

  .ctaTitle {
    font-size: 36px;
  }

  .ctaTitle .smallText {
    font-size: 36px;
  }

  .ctaDescription {
    font-size: 20px;
  }

  .ctaSubtext {
    font-size: 16px;
    padding-bottom: var(--space-12);
  }
}

/* Responsive image scaling for smaller screens */
@media (max-width: 768px) {
  .heroBottomImage__img {
    max-width: 60vw;
    height: auto;
  }
}

@media (max-width: 600px) {
  .heroBottomImage__img {
    max-width: 55vw;
    height: auto;
  }
}


@media (max-width: 480px) {

  span.dateItem__value,
  span.dateItem__label {
    font-size: 12px;
  }

  .featureText {
    font-size: 12px;
  }

  p.disclaimer.forMobile {
    font-size: 12px;
  }

  .stipendItem__label {
    margin-bottom: 0;
  }

  .heroBottomImage {
    right: -20px;
  }

  .stipendItem__amount,
  .stipendItem__period {
    font-size: 12px;
    padding: 7px;
  }

  .ctaSection {
    padding: 80px var(--space-3) 400px;
  }

  .ctaContent {
    gap: var(--space-4);
  }

  .ctaTitle,
  .faqTitle,
  .whySbupTitle,
  .specializationsTitle,
  .admissionTitle {
    font-size: 28px;
  }

  .ctaTitle .smallText {
    font-size: 28px;
  }

  .ctaDescription {
    font-size: 18px;
  }

  .ctaSubtext {
    font-size: 14px;
    padding-bottom: var(--space-8);
  }
}

@media (max-width: 400px) {
  .applyBanner {
    background-size: 95%;
  }

  .applyBanner__text {
    font-size: 12px;
    padding: 0px 10px;
  }
}

/* ==========================================================================
   Mobile Admission Form Section
   ========================================================================== */

.mobileAdmissionSection {
  display: none;
  padding: var(--space-20) var(--container-padding);
  background: var(--color-primary-white);
}

.mobileAdmissionContent {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}

.mobileAdmissionLeft {
  padding-right: var(--space-8);
}

.mobileAdmissionTitle {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-headings);
  margin-bottom: var(--space-6);
  line-height: 1.2;
}

.mobileAdmissionDescription {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: var(--color-paragraph);
  line-height: 1.6;
  margin: 0;
}

.mobileAdmissionRight {
  background: var(--color-primary-white);
  border-radius: var(--border-radius-xl);
  padding: var(--space-12);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  border: 1px solid rgba(0, 37, 129, 0.1);
}

.mobileAdmissionRight .admissionForm {
  background: transparent;
  border: none;
  padding: 0;
  border-radius: 0;
  box-shadow: none;
}

.mobileAdmissionRight .formTitle {
  display: none;
}

.mobileAdmissionRight .formGroup {
  margin-bottom: var(--space-6);
}

.mobileAdmissionRight .formInput,
.mobileAdmissionRight .formSelect {
  width: 100%;
  padding: var(--space-4);
  border: 2px solid #e5e7eb;
  border-radius: var(--border-radius-md);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  transition: border-color 0.3s ease;
}

.mobileAdmissionRight .formInput:focus,
.mobileAdmissionRight .formSelect:focus {
  outline: none;
  border-color: var(--color-button);
  box-shadow: 0 0 0 3px rgba(255, 142, 11, 0.1);
}

.mobileAdmissionRight .formSubmit {
  width: 100%;
  margin-top: var(--space-4);
}

/* Hide banner form on mobile and show mobile admission form section */
@media (max-width: 768px) {
  h3.aboutSubtitle {
    font-size: 16px;
    font-weight: var(--font-weight-medium);
    margin-bottom: 20px;
  }

  .aboutParagraph {
    font-size: 14px;
  }

  .heroContent {
    padding: 90px 0 45px 0;
  }

  .heroRight {
    display: none;
  }

  .mobileAdmissionSection {
    display: block;
    padding: var(--space-12) var(--container-padding);
  }

  .mobileAdmissionContent {
    grid-template-columns: 1fr;
    gap: var(--space-8);
    padding: 0;
    text-align: center;
    max-width: 100%;
  }

  .mobileAdmissionLeft {
    padding-right: 0;
    order: 1;
  }

  .mobileAdmissionRight {
    order: 2;
    padding: var(--space-8);
    width: 100%;
    border-radius: 10px;
  }

  .mobileAdmissionRight .admissionForm {
    width: 100%;
    max-width: 100%;
  }

  .mobileAdmissionRight .thankYouMessage {
    width: 100%;
    max-width: 100%;
    padding: var(--space-8);
  }

  .thankYouTitle {
    font-size: var(--font-size-3xl);
  }

  .thankYouText {
    font-size: var(--font-size-base);
  }

  .mobileAdmissionRight .formGroup {
    width: 100%;
    margin: 0;
  }

  .mobileAdmissionRight .formInput,
  .mobileAdmissionRight .formSelect {
    width: 100%;
    border-radius: 8px;
  }

  .mobileAdmissionRight .formSubmit {
    width: fit-content;
    gap: 10px;
    border-radius: 200px;
  }

  .mobileAdmissionTitle {
    font-size: var(--font-size-2xl);
    margin-bottom: 0;
    font-weight: var(--font-weight-semibold);
    font-family: roboto;
    text-align: left;
  }

  .mobileAdmissionDescription {
    font-size: var(--font-size-base);
  }
}

@media (max-width: 480px) {
  .mobileAdmissionSection {
    padding: 30px 0px;
  }

  .mobileAdmissionContent {
    gap: var(--space-8);
  }

  .mobileAdmissionRight {
    padding: var(--space-6);
  }

  .mobileAdmissionTitle {
    font-size: var(--font-size-2xl);
  }
}