/* =====================================
   1. Base / Global
===================================== */
*, html { scroll-behavior: smooth !important; }

/* =====================================
   2. Typography / Generic
===================================== */
.heading { display: block; text-align: center; }

/* =====================================
   3. Layout / Sections
===================================== */
header { position: relative; width: 100%; height: 100vh; min-height: 25rem; overflow: hidden; background-color: #000;  display: flex; justify-content: center; }
header video { position: absolute; top: 50%; left: 50%; min-width: 100%; min-height: 100%; width: auto; height: auto; transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); -moz-transform: translate(-50%, -50%); -webkit-transform: translate(-50%, -50%); z-index: 0; }
header .overlay { position: absolute; inset: 0; background-color: #000; opacity: 0.5; z-index: 1; }
header .container { position: relative; z-index: 2; }
section { scroll-margin-top: 120px; }
header img{ position: absolute; }
.customMarginTop { margin-top: 30px; }

/* =====================================
   4. Navbar
===================================== */
.navbar { height: 120px; }
.navbar .navbar-nav{ background:unset!important; }
.navbar .navbar-nav { background: #000; }
.navbar .navbar-nav .nav-link:hover,
.navbar .navbar-nav .nav-link.active { color: #fee600; }

header {
    position: relative;
    height: 100vh; /* Full viewport height */
    background: url('../img/website-bg.jpg') no-repeat center center fixed;
    background-size: cover;
    z-index: -1;
}

.overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5); /* Add an overlay to darken the background */
    z-index: 1;
}

#joinjugnu img{
   max-width: 100%;
}

#contact img{
   max-width: 100%;
}


/* =====================================
   5. Buttons & Forms
===================================== */
.btn-primary { background-color: #fee600; border-color: #fee600 !important; color: #000; }
.btn-primary:hover { background-color: #fee600; }
.btn-outline-primary { color: #fee600; border-color: #fee600 !important; }
.btn-outline-primary:hover { border-color: #fee600; background-color: #fee600; }
.btn-check:focus+.btn-outline-primary, .btn-outline-primary:focus { box-shadow: none; }
.form-control:focus { box-shadow: none; }

/* =====================================
   6. Text Utilities
===================================== */
.text-primary { color: #fee600 !important; }
a { color: #fee600; }
a:hover { color: #FFF; }

/* =====================================
   7. Carousel
===================================== */
.multi-carousel-container { position: relative; max-width: 100%; margin: 0 auto; overflow: hidden; cursor: grab; }
#multiCarousel { cursor: grab; touch-action: pan-y; }
#multiCarousel.dragging,
.multi-carousel-container.dragging { cursor: grabbing; }
#multiCarousel.dragging { user-select: none; -webkit-user-select: none; }
.multi-carousel-inner { display: flex; transition: transform 0.5s cubic-bezier(.25, .46, .45, .94); }
.multi-carousel-item,
.clone { flex: 0 0 33.333333%; box-sizing: border-box; padding: 0 5px; position: relative; }

/* =====================================
   8. Carousel Controls
===================================== */
.multi-carousel-control-prev,
.multi-carousel-control-next { position: absolute; top: 50%; transform: translateY(-50%); z-index: 10; display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border: none; border-radius: 50%; color: #fff; background-color: rgba(0, 0, 0, 0.5); cursor: pointer; text-decoration: none; transition: background-color 0.3s ease; }
.multi-carousel-control-prev { left: 10px; }
.multi-carousel-control-next { right: 10px; }
.multi-carousel-control-prev:hover,
.multi-carousel-control-next:hover { background-color: rgba(0, 0, 0, 0.7); }

/* =====================================
   9. Images
===================================== */
.img-container { position: relative; overflow: hidden; border-radius: 1.5rem; }
.img-container img,
#carouselInner img { width: 100%; height: 100%; object-fit: cover; object-position: top; pointer-events: none; -webkit-user-drag: none; transition: transform 0.3s ease; }
.img-container:hover img { transform: translateZ(0) scale(1.02); }

/* =====================================
   10. Overlays / Badges
===================================== */
.item-number { position: absolute; top: 1rem; left: 1rem; z-index: 2; display: inline-flex; align-items: center; justify-content: center; width: 35px; height: 35px; font-size: 120%; font-weight: 700; background-color: rgba(255, 255, 255, 0.75); border-radius: 50%; isolation: isolate; }
.team-item .team-name { background: rgba(0, 0, 0, .9); }

/* =====================================
   11. Components
===================================== */
.team-item:hover .team-body .team-before,
.team-item:hover .team-body .team-after { width: 100%; }
.team-item .team-body .team-before { text-align: center; }
.service-item .service-img::before { border: none; }
.service-item.service-item-left { background: linear-gradient(to left, var(--bs-secondary), var(--bs-dark)); }
.service-item.service-item-right { background: linear-gradient(to right, var(--bs-secondary), var(--bs-dark)); }
.carousel-caption { background: unset; }

/* =====================================
   12. Responsive
===================================== */
@media (max-width: 45em) {
.clone,
.multi-carousel-item { flex: 0 0 100%; }
.navbar { justify-content: unset; }
.navbar-dark .navbar-toggler { position: fixed; right: 0; }
}

@media (max-width: 991.98px) {
.navbar .navbar-nav { background: #000; }
}