:root {
    --bs-blue: #0d6efd;
    --bs-body-font-size: 1rem;
    --bs-body-color: #212529;
    --bs-body-bg: #fff;
    --bs-link-color: #0d6efd;
    --bs-border-color: #dee2e6;
    --bs-border-radius: 0.375rem;
    --main-blue-color: #040158
}

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

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: var(--bs-body-font-size);
    line-height: 1.5;
    color: var(--bs-body-color);
    background-color: var(--bs-body-bg);
    -webkit-text-size-adjust: 100%
}

.header {
    position: sticky;
    top: 0;
    z-index: 1020;
    background: #fff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1)
}

.topbar {
    background: #040158;
    padding: 10px 0
}

.container {
    width: 100%;
    padding: 0 15px;
    margin: 0 auto;
    max-width: 1320px
}

.d-flex {
    display: flex !important
}

.align-items-center {
    align-items: center !important
}

.justify-content-center {
    justify-content: center !important
}

.gap-3 {
    gap: 1rem !important
}

.text-white {
    color: #fff !important
}

.hero {
    width: 100%;
    min-height: 400px;
    position: relative
}

.carousel-item {
    width: 100%
}

.carousel-item img {
    width: 100%;
    height: auto;
    display: block
}

[class^="bi-"]::before,
[class*=" bi-"]::before {
    font-family: "bootstrap-icons" !important;
    font-style: normal;
    font-weight: normal !important;
    line-height: 1
}

body {
    font-display: swap;
    font-size-adjust: 0.5
}

:root {
    --scroll-margin-top: 120px
}

.main {
    min-height: 100vh;
    contain: layout
}

.navmenu {
    min-height: 60px;
    contain: layout
}

.navmenu ul {
    min-height: 40px
}

.hero {
    min-height: 70vh;
    contain: layout
}

.hero .carousel {
    min-height: 40vh;
    contain: layout
}

.hero p,
.hero h1,
.hero h2,
.hero h3 {
    font-display: swap;
    min-height: 1.2em
}

.carousel-indicators {
    min-height: 20px;
    contain: layout
}

.featured-services {
    contain: layout
}

.service-item {
    min-height: 200px;
    contain: layout
}

.navmenu a {
    min-height: 50px;
    display: flex;
    align-items: center;
    contain: layout
}

.hero .container {
    min-height: auto;
    contain: layout
}

.hero p {
    min-height: 3em;
    line-height: 1.5;
    contain: layout;
    margin-bottom: 0;
}

@media (max-width: 767px) {
    .hero img {
        width: 100%;
        height: auto;
        display: block;
        contain: layout;
        object-fit: cover
    }

    .hero {
        min-height: 28vh;
        contain: layout
    }

    .hero .carousel {
        min-height: 28vh;
        contain: layout
    }

    .hero .carousel-item {
        min-height: 28vh;
        contain: layout
    }
}

.branding h1 {
    min-height: 1.2em;
    font-display: swap;
    contain: layout
}

.topbar .d-flex {
    min-height: 40px;
    contain: layout
}

.topbar {
    min-height: 40px;
    contain: layout
}

#gallery .swiper-pagination .swiper-pagination-bullet-active {
    background-color: #040158 !important
}

#navmenu,
.index-page,
.hero [data-aos] {
    transform: none !important;
    opacity: 1 !important
}

#preloader {
    position: fixed;
    inset: 0;
    z-index: 9999;
    overflow: hidden;
    transition: all 0.6s ease-out
}

#preloader:before {
    content: '';
    position: fixed;
    top: calc(50% - 30px);
    left: calc(50% - 30px);
    border: 6px solid var(--main-blue-color);
    border-top-color: color-mix(in srgb, var(--main-blue-color), transparent 90%);
    border-radius: 50%;
    width: 60px;
    height: 60px;
    animation: animate-preloader 1s linear infinite
}

.about .content .h4 {
    font-size: 1.5rem;
    font-weight: 700
}

@media (max-width: 768px) {
    .imgMBL {
        width: 100%
    }

    .hero {
        aspect-ratio: auto !important
    }

    .hero .container {
        position: absolute !important;
        bottom: 0 !important;
        left: 0;
        right: 0;
        margin-inline: auto !important
    }
}