@media (max-width: 991.9px) {

  .our-school-page .offcanvas-menu label span,
  .offcanvas-menu label span::before,
  .offcanvas-menu label span::after {
    background: #fff;
  }
}

/* Fix: keep header always visible on our-school page */
/* .our-school-page header.header {
  position: fixed !important;
  top: 0 !important;
  transform: translateY(0) !important;
  opacity: 1 !important;
  z-index: 1000 !important;
} */
/* Hero section css start */
.campus-section {
  position: relative;
  background: #ffffff;
}

.campus-stage {
  position: relative;
}

.campus-viewport {
  position: relative;
  top: 0;
  height: 100vh;
  min-height: 540px;
  overflow: hidden;
}

.campus-media {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.campus-media img,
.campus-slide-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.campus-stack {
  position: absolute;
  inset: 0;
  z-index: 2;
  opacity: 0;
  pointer-events: none;
}

.campus-slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  will-change: transform;
}

.campus-slide.slide-1 {
  z-index: 3;
}

.campus-slide.slide-2 {
  z-index: 2;
}

.campus-slide.slide-3 {
  z-index: 1;
}

.campus-slide-visual {
  position: absolute;
  inset: 0;
  overflow: hidden;
  will-change: clip-path;
}

.campus-slide-caption {
  position: absolute;
  left: clamp(24px, 5vw, 88px);
  right: auto;
  bottom: clamp(28px, 7vh, 86px);
  z-index: 3;
  width: min(480px, calc(100% - 48px));
  min-height: 220px;
}

.campus-slide-circle {
  position: absolute;
  left: -168px;
  bottom: -390px;
  width: 530px;
  height: 510px;
  background: #ffea2c;
  border-radius: 50%;
  z-index: 0;
}

.campus-slide-text {
  position: relative;
  z-index: 1;
  padding: 0;
  opacity: 1;
  width: 60%;
  top: 170px;
  left: -104px;
  margin: auto;
}

.campus-slide-text p {
  margin: 0;
  color: #101010;
  font-family: Poppins;
  font-size: 0.9em;
  font-weight: 600;
  line-height: 139%;
}

.our-school-page .location-section {
  position: relative;
  z-index: 20;
}

.our-school-page .footer-reveal-wrapper {
  position: relative;
  z-index: 10;
}

.our-school-page .campus-section {
  position: relative;
  z-index: 1;
}

.our-school-page .development-sec {
  background: #fff;
  position: relative;
  overflow: hidden;
  z-index: 2;
  margin-top: 0;
  height: 100vh;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.our-school-page .dev-sticky-wrapper {
  position: relative;
  z-index: 1;
}

/* body.our-school-page {
  overflow-x: hidden;
} */

.campus-section .panel {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 4;
  width: min(43vw, 600px);
  height: 100%;
  display: flex;
  align-items: flex-start;
  overflow: visible;
}

.campus-section .half-circle {
  position: absolute;
  top: -9.8958vw;
  left: -56.25vw;
  z-index: 0;
  display: block;
  width: 98.9583vw;
  height: 98.9583vw;
  background: rgb(10, 61, 156);
  border-radius: 50%;
  pointer-events: none;
}

.campus-section .body-txt {
  position: relative;
  z-index: 4;
  margin: clamp(264px, 19.4vw, 308px) 0 auto clamp(40px, 6.9vw, 100px);
  max-width: clamp(320px, 30vw, 470px);
  display: flex;
  flex-direction: column;
  gap: clamp(24px, 3.2vw, 46px);
  opacity: 0;
  visibility: hidden;
  /* filter: blur(18px); */
  transform: translate3d(-42px, 0, 0);
  will-change: transform, opacity;
}

.campus-section .panel-title {
  /* position: relative; */
  z-index: 1;
  color: #fff;
  font-family: Satoshi;
  font-size: clamp(1.75rem, 2.55vw, 2.3em);
  font-weight: 700;
  line-height: 112%;
}

/* .campus-section .panel-title::before {
  content: "";
  position: absolute;
  top: -55px;
  left: -52px;
  width: 191px;
  height: 191px;
  background: #09439f;
  pointer-events: none;
  z-index: -1;
  border-radius: 50%;
} */

.campus-section .panel-body {
  color: #fff;
  font-family: Poppins;
  font-size: clamp(14px, 1vw, 0.9em);
  font-style: normal;
  font-weight: 400;
  line-height: 166%;
  margin-top: 2em !important;
}

@media (max-width: 991.9px) {
  .campus-section {
    padding: 0;
  }

  .campus-stage,
  .campus-viewport,
  .campus-stack {
    position: relative;
    width: 100%;
    height: auto;
    min-height: 0;
    overflow: visible;
  }

  .campus-viewport {
    padding: calc(max(100vh, 540px) + 86px) 0 0;
  }

  .campus-slide-circle {
    display: none;
  }

  .campus-media {
    position: absolute;
    inset: 0 0 auto;
    display: block;
    height: max(100vh, 540px);
    overflow: hidden;
  }

  .campus-media img {
    position: absolute;
    width: 100%;
    min-width: 160%;
    height: 100%;
    bottom: -16%;
    left: -40%;
    object-fit: cover;
  }

  .campus-section .panel {
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    width: 100%;
    height: max(100vh, 540px);
    overflow: hidden;
  }

  .campus-section .half-circle {
    display: block;
    width: 1092px;
    height: 1092px;
    top: -80%;
    left: -50px;
  }

  .campus-section .body-txt {
    gap: 36px;
    margin: 0 auto;
    top: 10%;
    left: 5%;
    width: 40%;
    opacity: 1;
    visibility: visible;
    filter: none;
    transform: none;
  }

  .campus-section .panel-title::before {
    display: none;
  }

  .campus-stack {
    inset: auto;
    z-index: 1;
    width: 86%;
    margin: 50px auto;
    display: grid;
    gap: 20px;
    opacity: 1 !important;
    pointer-events: auto !important;
    position: relative;
  }

  .campus-slide {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    min-width: 0;
    height: auto;
    min-height: 0;
    aspect-ratio: 279 / 234;
    overflow: hidden;
    background: #101010;
  }

  .campus-slide-visual {
    position: absolute;
    inset: 0;
    clip-path: none !important;
  }

  .campus-slide-visual img {
    position: static;
    width: 100%;
    min-width: 0;
    height: 100%;
    max-width: none;
    display: block;
    object-fit: cover;
    object-position: center;
  }

  .campus-slide-caption {
    position: absolute;
    inset: auto 0 0;
    z-index: 2;
    width: 100%;
    min-height: 96px;
    display: flex;
    align-items: flex-end;
    padding: 42px 16px 16px;
    background: linear-gradient(180deg,
        rgba(0, 0, 0, 0) 0%,
        rgba(0, 0, 0, 0.78) 100%);
  }

  .campus-slide-text {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    margin: 0;
    transform: none;
    opacity: 1;
    visibility: visible;
  }

  .campus-slide-text p {
    color: #fff;
    font-size: 17px;
    font-weight: 700;
    line-height: 140%;
  }

  .our-school-page .development-sec {
    margin-top: 0;
  }
}

@media (max-width: 767.9px) {
  .campus-slide-visual img {
    max-width: 767px;
  }

  .campus-section .half-circle {
    left: -20%;
  }

  .campus-stack {
    margin: 38px auto 0 auto;
  }

  .campus-section .panel-title {
    font-size: 28px;
    font-weight: 700;
    line-height: 118%;
    margin-bottom: 30px !important;
    /* 33.04px */
  }

  .campus-section .panel-body {
    font-size: 14.5px;
    font-weight: 400;
    line-height: 150%;
    /* 21.75px */
    letter-spacing: 0.145px;
  }

  .campus-section .body-txt {
    gap: 27px;
    top: 13%;
    left: 0%;
    width: 45%;
  }

  .campus-slide-text p {
    font-size: 13px;
    font-weight: 600;
    line-height: 140%;
    /* 18.2px */
    letter-spacing: 0.13px;
  }

  .campus-stack {
    gap: 17px;
  }

  .campus-slide-caption {
    padding: 42px 6px 20px 21px;
  }
}

@media (max-width: 576.9px) {

  /* .campus-slide-visual img {
    max-width: 576px;
  } */
  .campus-section .half-circle {
    width: 792px;
    height: 793px;
    top: -36%;
    left: -49%;
  }

  .campus-media {
    height: max(100vh, 540px);
  }

  .campus-media img {
    width: 438px;
    height: 570px;
    bottom: -2%;
  }

  .campus-section .body-txt {
    top: 16%;
    width: 75%;
  }
}

/* Hero section css end */

/* development section css start */
section.development-sec {
  padding: 5px 0 136px;
}

.development-sec h2.title-txt {
  color: #0a3d9c;
  font-family: Satoshi;
  font-size: clamp(28px, 2.5vw, 2.3em);
  font-weight: 700;
  line-height: 112%;
  width: clamp(450px, 49vw, 750px);
  padding-bottom: clamp(30px, 4.5vw, 65px);
  padding-top: 50px;
}

.main-img-slider {
  margin-top: 88px;
  overflow: visible;
}

.img-relative {
  position: relative;
}

.development-swiper .image-container {
  position: relative;
  padding-bottom: 78px;
}

.development-swiper .img-relative img {
  width: 100%;
  height: auto;
  aspect-ratio: 539 / 320;
  object-fit: cover;
}

.development-swiper .absolute-box {
  position: absolute;
  right: 0;
  bottom: 40px;
  z-index: 2;
  width: min(100%, 450px);
  height: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}

.development-swiper .absolute-box p {
  color: #000;
  font-family: Poppins;
  font-size: 18px;
  font-weight: 500;
  line-height: 27px;
  padding: 18px 42px;
}

.yellow-box {
  background: #f7df00;
}

.orange-box {
  background: #fc8b5f;
}

.purple-box {
  background: #beacff;
}

.dev-slide .img-relative {
  position: relative;
  height: clamp(320px, 60vh, 720px);
  overflow: hidden;
}

.dev-slide .img-relative img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.image-container.dev-slide {
  position: relative;
  padding-bottom: 56px;
}

.dev-slide .absolute-box {
  position: absolute;
  right: 0;
  bottom: clamp(0%, 2vw, 5%);
  z-index: 2;
  width: min(100%, clamp(450px, 38vw, 589px));
  display: flex;
  align-items: center;
  justify-content: center;
}

.dev-slide .absolute-box p {
  color: #000;
  font-family: Poppins;
  font-size: clamp(14px, 1.2vw, 1em);
  font-weight: 500;
  line-height: 154%;
  padding: clamp(12px, 1.1vw, 16px) clamp(20px, 2.2vw, 32px);
  margin: 0;
}

.dev-horizontal {
  position: relative;
  overflow: hidden;
  width: 100%;
  flex: 0 0 auto;
  display: flex;
  align-items: flex-start;
  min-height: 0;
  padding-bottom: 0;
  padding-left: 20px;
}

.dev-track {
  display: flex;
  align-items: flex-start;
  width: max-content;
  will-change: transform;
  padding: 0 clamp(80px, 6.25vw, 120px);
  gap: clamp(150px, 13.2vw, 377px);
}

.dev-slide {
  flex: 0 0 min(72vw, clamp(550px, 56vw, 980px));
  position: relative;
}

.dev-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 991.9px) {
  .our-school-page .development-sec {
    height: auto;
    min-height: 0;
    display: block;
    overflow: visible;
    padding: 56px 0 32px;
    margin-top: 0;
    background: #fff;
  }

  .development-sec h2.title-txt {
    width: 53%;
    padding-bottom: 0;
  }

  .dev-horizontal {
    display: block;
    overflow: visible;
    padding: 0;
    width: 86%;
    margin: 40px auto 0;
  }

  .dev-track {
    display: grid;
    flex-direction: column;
    width: 100%;
    padding: 0;
    gap: 58px;
  }

  .dev-slide {
    width: 100%;
    flex: none;
    padding-bottom: 0;
  }

  .dev-slide .img-relative {
    height: auto;
    aspect-ratio: 279 / 170;
  }

  .dev-slide .absolute-box {
    position: static;
    width: 50%;
  }

  .dev-slide .absolute-box p {
    padding: 18px 0 0 0;
    font-size: 1.2em;
  }

  .yellow-box,
  .orange-box,
  .purple-box {
    background: transparent;
  }

  .image-container.dev-slide {
    padding-bottom: 0;
  }
}

@media (max-width: 767.9px) {
  .our-school-page .development-sec {
    padding: 82px 0 58px 0;
  }

  .development-sec h2.title-txt {
    width: 49%;
    font-size: 26px;
    font-weight: 700;
    line-height: 115%;
    /* 29.9px */
  }

  .dev-horizontal {
    margin-top: 38px;
  }

  .dev-slide .absolute-box p {
    font-size: 14px;
    font-weight: 400;
    line-height: 150%;
    /* 21px */
  }

  .dev-slide .img-relative {
    overflow: unset;
  }

  .image-container:nth-child(2) .img-relative:before {
    content: "";
    position: absolute;
    width: 57px;
    height: 15px;
    background: #fc8b5f;
    top: -15px;
    right: 0;
  }

  .image-container:nth-child(2) .img-relative::after {
    content: "";
    position: absolute;
    width: 49px;
    height: 15px;
    background: #beacff;
    top: 0;
    right: 57px;
  }

  .image-container:nth-child(4) .img-relative::before {
    content: "";
    position: absolute;
    width: 49px;
    height: 15px;
    background: #ffea2c;
    top: 0;
    left: 48px;
  }

  .image-container:nth-child(4) .img-relative:after {
    content: "";
    position: absolute;
    width: 49px;
    height: 15px;
    background: #beacff;
    top: -15px;
    left: 0;
  }

  .image-container:nth-child(6) .img-relative::before {
    content: "";
    position: absolute;
    width: 57px;
    height: 15px;
    background: #ffea2c;
    top: -15px;
    right: 0;
  }

  .image-container:nth-child(6) .img-relative::after {
    content: "";
    position: absolute;
    width: 49px;
    height: 15px;
    background: #fc8b5f;
    top: 0;
    right: 57px;
  }

  .image-container:nth-child(8) .img-relative::before {
    content: "";
    position: absolute;
    width: 49px;
    height: 15px;
    background: #fc8b5f;
    top: -15px;
    left: 0;
  }

  .image-container:nth-child(8) .img-relative::after {
    content: "";
    position: absolute;
    width: 49px;
    height: 15px;
    background: #ffea2c;
    top: 0;
    left: 49px;
  }

  .image-container:nth-child(10) .img-relative::before {
    content: "";
    position: absolute;
    width: 49px;
    height: 15px;
    background: #beacff;
    top: -15px;
    right: 0;
  }

  .image-container:nth-child(10) .img-relative::after {
    content: "";
    position: absolute;
    width: 49px;
    height: 15px;
    background: #ffea2c;
    top: 0;
    right: 49px;
  }

  .image-container:nth-child(12) .img-relative::before {
    content: "";
    position: absolute;
    width: 49px;
    height: 15px;
    background: #beacff;
    top: -15px;
    left: 0;
  }

  .image-container:nth-child(12) .img-relative::after {
    content: "";
    position: absolute;
    width: 57px;
    height: 15px;
    background: #fc8b5f;
    top: 0;
    left: 49px;
  }
}

@media (max-width: 576.9px) {
  .dev-horizontal {
    width: 80%;
  }

  .development-sec h2.title-txt {
    width: 91%;
  }

  .dev-slide .img-relative img {
    max-width: 100%;
    width: 100%;
    height: 254px;
  }

  .dev-slide .absolute-box {
    width: 86%;
  }
}

/* development section css end */

/* Location section css Start */
.our-school-page .campus-heading,
.our-school-page .campus-grid {
  visibility: hidden;
}

@media (prefers-reduced-motion: reduce) {

  .our-school-page .campus-heading,
  .our-school-page .campus-grid {
    visibility: visible;
  }
}

.location-section {
  background: ##ffea2c;
  display: flex;
  gap: 40px;
  align-items: flex-start;
  padding: clamp(60px, 5.5vw, 130px) 0;
  /* margin-top: clamp(0px, 5.5vw, 80px); */
  position: relative;
}

@media (min-width: 992px) {
  .our-school-page .location-section {
    min-height: 100vh;
    box-sizing: border-box;
    will-change: transform;
  }
}

.location-section .d-flex {
  display: flex;
  gap: clamp(70px, 10.7vw, 155px);
  align-items: flex-start;
}

.campus-heading {
  flex: 0 0 clamp(70px, 6.25vw, 200px);
  color: #0a3d9c;
  font-family: Satoshi;
  font-size: clamp(28px, 2.5vw, 2.3em);
  font-style: normal;
  font-weight: 700;
  line-height: 112%;
}

.campus-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(110px, 7vw, 140px) clamp(102px, 9vw, 152px);
  margin-top: 100px;
  width: 70%;
  margin: 110px auto 0;
}

.campus-card {
  display: flex;
  flex-direction: column;
}

.card-header {
  display: flex;
  align-items: center;
  gap: clamp(15px, 1.4vw, 20px);
  margin-bottom: clamp(15px, 1.4vw, 20px);
  justify-content: center;
}

.arrow-icon {
  display: flex;
  gap: 2px;
  flex-shrink: 0;
}

.arrow-icon span {
  display: block;
  width: 0;
  height: 0;
  border-top: 9px solid transparent;
  border-bottom: 9px solid transparent;
  border-left: 12px solid #f07058;
}

.campus-name {
  color: #000;
  font-family: Satoshi;
  font-size: 1.4em;
  font-style: normal;
  font-weight: 700;
  line-height: 119%;
}

.campus-address {
  color: #000;
  font-family: Poppins;
  font-size: 1em;
  font-weight: 400;
  line-height: 169%;
  text-align: center;
}

.directions-link {
  display: inline-block;
  margin-top: 10px;
  cursor: pointer;
  color: #0a3d9c;
  font-family: Poppins;
  font-size: 1em;
  font-weight: 600;
  line-height: normal;
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-color: #fc8b5f;
  text-underline-offset: 3px;
  text-underline-position: from-font;
  text-align: center;
}

.directions-link:hover {
  text-decoration: underline;
}

@media (max-width: 1366px) {
  .campus-grid {
    width: 100%;
  }
}

@media (max-width: 991.9px) {
  .location-section {
    padding: 60px 0;
  }

  .location-section .d-flex {
    flex-direction: column;
  }

  .campus-heading {
    flex: unset;
  }

  .location-section .d-flex {
    flex-direction: column;
    gap: 50px;
  }
}

@media (max-width: 767.9px) {
  .location-section {
    padding: 59px 0 89px 0;
    margin-top: 0px;
  }

  .campus-heading {
    color: #0a3d9c;
    font-family: Satoshi;
    font-size: 28px;
    font-weight: 700;
    line-height: 118%;
    text-align: left !important;
  }

  .location-section .d-flex {
    gap: 61px;
  }

  .arrow-icon svg {
    display: none;
  }

  .campus-grid {
    margin: 60px auto 0;
    grid-template-columns: unset;
    gap: 51px;
  }

  .campus-card {
    align-items: flex-start;
  }

  .campus-name {
    font-size: 16px;
    font-weight: 600;
    line-height: 140%;
    /* 22.4px */
  }

  .campus-address {
    padding-left: 0;
    font-size: 14px;
    font-weight: 400;
    line-height: 150%;
    text-align: left;
  }

  .card-header {
    display: block;
    margin-bottom: 5px;
  }

  .directions-link {
    padding-left: 0;
    margin-top: 9px;
    font-size: 15px;
    font-weight: 600;
    text-decoration-thickness: 10%;
    /* 1.5px */
    text-underline-offset: 14.5%;
    /* 2.175px */
    text-underline-position: from-font;
  }
}

/* Location section css End */