:root{--primary-color:#007bff;--primary-bg-color:rgb(40 40 105);--secondary-color:#333;--light-bg:#f9f9f9;--white:#fff;--dark-overlay:rgba(0,0,0,0.4);--box-shadow:0 4px 10px rgba(0,0,0,0.1)}html{scroll-behavior:smooth}*{margin:0;padding:0;box-sizing:border-box}a,a:hover{text-decoration:none!important}.bg-primary{--bs-bg-opacity:1;background-color:var(--primary-bg-color)!important}.text-primary{color:var(--primary-bg-color)!important}.bg-maroon{background-color:#660000}.text-maroon{color:#660000}body{font-family:'Jost',sans-serif;background-color:#fff;color:var(--secondary-color);line-height:1.6;font-size:1rem}h1,h2,h3,h4,h5,h6{font-weight:bold;font-family:'Jost',sans-serif;color:var(--secondary-color);font-weight:600}p{font-size:1rem}section[id]{scroll-margin-top:90px}@media(max-width:767.98px){section[id]{scroll-margin-top:60px}}.section-title{font-size:2.5rem;text-transform:uppercase;margin-bottom:30px;letter-spacing:1px}.bg-blue{background-color:#0f1f3b}.text-white{color:#fff!important}.text-shadow{text-shadow:0 2px 4px rgba(0,0,0,0.6)}.bg-semi-white{background-color:var(--dark-overlay)}.hero-carousel .owl-item,.hero-carousel .hero-bg-img,.hero-carousel .hero-bg-img img{height:100vh;width:100%;object-fit:cover}.hero-carousel .slide-wrapper{position:relative;height:100vh}.hero-carousel .slide-wrapper a{ display:block; height:100%; width:100%; position:relative; z-index:2; }.hero-carousel .overlay{pointer-events:none;position:absolute;top:0;left:0;height:100%;width:100%;background:rgba(0,0,0,0.3);z-index:1}.hero-carousel .hero-bg-img{position:relative;z-index:0}.hero{position:relative;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;color:#fff}.hero-bg-img{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:auto}.hero-bg-img img{width:100%;height:100%;object-fit:cover;display:block}.hero>.container{position:relative;z-index:2}.hero .marquee-wrapper{position:absolute;bottom:0;left:0;width:100%;padding:.5rem 0;text-align:center;background-color:rgba(0,0,0,0.75);color:#fff;z-index:4}.sticky-btn-group{position:fixed;bottom:1%;right:0;transform:translateY(-50%);z-index:9999;padding-right:18px;display:flex;flex-direction:column;gap:8rem}.sticky-btn-group .btn{border-radius:.5rem .5rem 0 0;text-align:center;box-shadow:0 4px 10px rgba(0,0,0,0.15);transform:rotate(270deg);transform-origin:right center;padding:.2rem .5rem;white-space:nowrap;font-weight:600;font-size:18px;margin:0;opacity:.6;transition:opacity .3s ease}.sticky-btn-group .btn:hover{opacity:1}@media(max-width:767.98px){.sticky-btn-group{gap:6rem;padding-right:12px}.sticky-btn-group .btn{font-size:14px;padding:.15rem .4rem;min-width:100px}}.icon-box{width:70px;height:70px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%}.testimonial-item{background:white;border-radius:.5rem;box-shadow:0 5px 15px rgba(0,0,0,0.05)}.testimonial-carousel{z-index:12}.testimonial-carousel .owl-nav{position:absolute;top:-70px;right:0}.testimonial-carousel .owl-nav button{width:40px;height:40px;border-radius:50%!important;background:var(--primary-color)!important;color:white!important;margin-left:10px}.testimonial-carousel img{max-height:150px;height:150px;object-fit:contain;display:block;margin-left:auto;margin-right:auto}.main-header{position:absolute;top:0;width:100%;z-index:99999;transition:.3s ease;background-color: rgba(0, 0, 0, 0.45);}.main-header .nav-link{color:#fff!important;font-weight:600;text-transform:uppercase;text-shadow:0 1px 3px rgba(0,0,0,0.6)}footer img{max-height:48px;height:auto;width:auto;}.main-header.sticky{position:fixed;background-color:#fff;box-shadow:var(--box-shadow)}.main-header.sticky .navbar{--bs-navbar-padding-y:0!important;--bs-navbar-padding-x:0!important}.main-header.sticky .nav-link{color:#000!important;text-shadow:none}.main-header.sticky .logo-img{transform:scale(0.75)}.logo-img{height:72px;transition:transform .3s ease}@media(max-width:991px){.main-header{background-color:#fff!important}.main-header .nav-link{color:#000!important}.logo-img{height:45px}.navbar-nav{padding:15px;border:2px solid #ddd;border-radius:8px;background-color:#fff}.navbar-nav .nav-item{padding:10px 0;border-bottom:1px solid #ddd}.navbar-nav .nav-item:last-child{border-bottom:none}.navbar-nav .nav-link{color:#333;font-size:16px;font-weight:600;padding:0 10px}.navbar-nav .nav-link:hover{background-color:#f1f1f1;color:#0056b3}}.logo-color{display:none}@media(max-width:991px){.logo-light{display:none}.logo-color{display:block}}.page-header{padding-top:90px;background-image:url('../images/siteassets/breadcrumb.webp?v1');background-size:cover;background-position:center;position:relative;color:white;z-index:1}.page-header h1{color:white}.page-header .overlay{background-color:rgba(0,0,0,0.5);position:absolute;top:0;left:0;width:100%;height:100%;z-index:2}.page-header .container{position:relative;z-index:3}footer{background-color:var(--dark-color)}footer h5{color:white;margin-bottom:1.5rem;font-weight:600}footer a{color:#adb5bd;transition:all .3s ease}footer a:hover{color:white;padding-left:5px}.social-icons a{display:inline-block;width:40px;height:40px;border-radius:50%;background-color:rgba(255,255,255,0.1);text-align:center;line-height:40px;transition:all .3s ease}.social-icons a:hover{background-color:var(--primary-color);color:white!important}#academics{background-color:var(--light-bg);padding:40px 0}.academics-stream{background-color:var(--white);border-radius:8px;padding:20px;box-shadow:var(--box-shadow);margin-bottom:30px}.stream-title{font-size:1.8rem;color:var(--primary-color);margin-bottom:15px}.subject-list{list-style:none;padding-left:0}.subject-list li{color:var(--secondary-color);margin-bottom:10px}@media(max-width:767px){#academics{padding:20px 0}.section-title{font-size:2rem}}.apply-now-btn{position:fixed;bottom:20px;right:0;z-index:9999;background-color:#dc3545;color:#fff;padding:10px 5px;border-radius:8px;font-weight:bold;text-align:center;writing-mode:vertical-rl;text-orientation:mixed;text-decoration:none;box-shadow:0 4px 6px rgba(0,0,0,0.1);transition:background-color 0.3s ease;display:none}.apply-now-btn:hover{background-color:#c82333;color:#fff}.main-header .nav-link{font-size:16px} @media(max-width:1279px){.main-header .nav-link{font-size:13px}}.faculty-card{border-radius:12px;overflow:hidden;background:#fff;transition:transform .3s ease,box-shadow .3s ease}.faculty-card:hover{transform:translateY(-8px);box-shadow:0 8px 20px rgba(0,0,0,0.15)}.faculty-img img{width:100%;height:280px;object-fit:cover;transition:transform .4s ease}.faculty-card:hover .faculty-img img{transform:scale(1.05)}.faculty-info h5{font-weight:600;font-size:16px}.faculty-info p{margin-bottom:4px;font-size: .9rem;}.btn-maroon{background-color:#660000!important;border-color:#660000!important;color:#fff!important}.btn-maroon:hover{background-color:#282869!important;border-color:#282869!important}.btn-maroon-outline{border:2px solid #660000!important;color:#660000!important;background:transparent!important}.btn-maroon-outline:hover{background-color:#660000!important;color:#fff!important}

.whatsapp-btn{
  position: fixed;
  left: 6px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 9999;
  background: #25d366;
  color: #fff;
  width: 55px;
  height: 55px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  box-shadow: 0 4px 10px rgba(0,0,0,.3);
  text-decoration: none;
  transition: transform .2s ease-in-out;
}
.whatsapp-btn:hover{transform:scale(1.1);color:#fff}

.residence-bg{
  background: url("../images/siteassets/residence-life-bg.webp") center center / cover no-repeat;
  position: relative;
}

.residence-bg::before{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55); /* dark overlay */
}

.residence-bg .container{
  position: relative;
  z-index: 1;
}



.contact-bg{
  background: url("../images/siteassets/contact-bg.webp") center center / cover no-repeat;
  position: relative;
}

.contact-bg::before{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55); /* dark overlay */
}

.contact-bg .container{
  position: relative;
  z-index: 1;
}



.gallery-item {
    overflow: hidden;
    border-radius: 12px;
  }

  .gallery-item img {
    transition: transform 0.4s ease;
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
  }

  .gallery-item:hover img {
    transform: scale(1.08);
  }
  
  
  
 


/* Owl Nav buttons */
.gallery-slider .owl-nav {
  position: absolute;
  top: 50%;
  left: -30px;
    right: -30px;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  pointer-events: none; /* allow clicks only on buttons */
}

.gallery-slider .owl-nav button.owl-prev,
.gallery-slider .owl-nav button.owl-next {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #660000 !important;
  /*box-shadow: 0 6px 18px rgba(0,0,0,0.15);*/
  pointer-events: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0 !important;
}

/* arrow icon style */
.gallery-slider .owl-nav button.owl-prev span,
.gallery-slider .owl-nav button.owl-next span {
  font-size: 30px;
  line-height: 1;
  color: #fff;
}

/* position left & right */
.gallery-slider .owl-nav button.owl-prev {
  margin-left: -15px;
}

.gallery-slider .owl-nav button.owl-next {
  margin-right: -15px;
}

/* hover effect */
.gallery-slider .owl-nav button.owl-prev:hover,
.gallery-slider .owl-nav button.owl-next:hover {
  transform: scale(1.05);
}

/* remove disabled opacity */
.gallery-slider .owl-nav button.disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

@media (max-width: 575.98px) {
  .gallery-slider .owl-nav {
    left: 0px;
    right: 0px;
  }
}














/* ================================
   FULL SCREEN HERO (NO GAP)
=================================== */

.hero{
  position: relative;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden;

  /* fallback */
  height: 100vh;
  min-height: 450px;
}

/* ✅ Chrome / modern browsers mobile safe */
@supports (height: 100svh){
  .hero{
    height: 100svh; /* safe viewport height */
  }
}

/* ✅ iOS Safari modern fix */
@supports (height: 100dvh){
  .hero{
    height: 100dvh; /* dynamic viewport height */
  }
}

/* Owl container full height */
.hero .hero-carousel{
  height: 100% !important;
}

/* Force owl wrappers to occupy full height */
.hero .hero-carousel .owl-stage-outer,
.hero .hero-carousel .owl-stage,
.hero .hero-carousel .owl-item{
  height: 100% !important;
}

/* owl-item inner slide div */
.hero .hero-carousel .owl-item > div{
  height: 100% !important;
}

/* Slide wrapper */
.hero .slide-wrapper{
  height: 100%;
  width: 100%;
  position: relative;
  overflow: hidden;
}

/* anchor fill */
.hero .slide-wrapper > a{
  height: 100%;
  width: 100%;
  display: block;
  position: relative;
}

/* picture fill */
.hero .hero-bg-img{
  height: 100%;
  width: 100%;
  display: block;
  position: relative;
  margin: 0;
  line-height: 0;
}

/* ✅ image always cover full banner + SMOOTH ZOOM (NO JERK) */
.hero .hero-slide-img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;

  /* ✅ Default slight zoom to prevent reset jerk */
  transform: scale(1.05);

  /* Smooth zoom + fade */
  transition: transform 7s ease-in-out, opacity 1.2s ease-in-out;
  will-change: transform, opacity;
}

/* Smooth fade transition for slides */
.hero .owl-item{
  opacity: 0;
  transition: opacity 1.2s ease-in-out;
}
.hero .owl-item.active{
  opacity: 1;
}

/* ✅ Active slide zooms IN smoothly */
.hero .owl-item.active .hero-slide-img{
  transform: scale(1.15);
}

/* Extra smooth rendering (prevents flicker) */
.hero .owl-item .slide-wrapper{
  backface-visibility: hidden;
  transform: translateZ(0);
}

/* Dots position */
.hero .owl-dots{
  position: absolute;
  left: 50%;
  bottom: 70px; /* ⬅ so marquee doesn't overlap dots */
  transform: translateX(-50%);
  margin: 0 !important;
  z-index: 6;
}

/* dots style */
.hero .owl-dots .owl-dot span{
  width: 10px;
  height: 10px;
  background: rgba(255,255,255,.7);
  border-radius: 50%;
  margin: 4px;
  transition: .3s ease;
}
.hero .owl-dots .owl-dot.active span{
  width: 25px;
  border-radius: 20px;
  background: rgba(255,255,255,1);
}

/* Marquee overlay */
.marquee-wrapper{
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 7;
  background: rgba(0,0,0,0.55);
  color: #fff;
  padding: 10px 0;
  font-size: 15px;
}

.events {
    background: #0b0f19;
    color: #fff;
}

.events h2 {
    font-size: 2.5rem;
}

.video-box {
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0,0,0,0.3);
}

.video-box video {
    border-radius: 12px;
}

/* Optional hover effect */
.video-box:hover {
    transform: translateY(-5px);
    transition: 0.3s ease;
}

















