:root {
    --theme-color: #3868B3;
    --secondary-color: #3D3434;
    --dark-color: #000;
    --white-color: #fff;
    --bg-color: #d8d2d2;
    --light-blue: #eff6fd;
    --h1-font-size: 58px;
    --h2-font-size: 42px;
    --h3-font-size: 36px;
    --h4-font-size: 32px;
    --h5-font-size: 24px;
    --h6-font-size: 22px;
}

body {
    color: rgb(0, 0, 0);
    background: #f6f2ef;
    font-family: "League Spartan", sans-serif;
    font-size: 15px;
    line-height: 30px;
    /* font-weight: 500; */
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

a {
    text-decoration: none;
}

main {
    flex-grow: 1;
}

.border-theme {
    border: 2px solid var(--theme-color);
}

.bg-black {
    background: var(--dark-color);
}

.topbar {
    background: var(--theme-color);
}

.navbar-dark .navbar-nav .nav-link.active,
.navbar-dark .navbar-nav .show>.nav-link {
    /* color: rgb(0, 0, 0); */
    font-family: Poppins, sans-serif;
}

.navbar-dark .navbar-nav .nav-link {
    color: #fff;
    font-weight: 400;
    font-size: 18px;
    font-size: 20px;
}

@media (min-width: 768px) {
    .navbar-expand-md .navbar-nav .nav-link {
        padding-right: 2rem;
        padding-left: 0;
    }
}

.navbar-dark .navbar-nav .nav-link:focus,
.navbar-dark .navbar-nav .nav-link:hover {
    color: #fefefec9;
}

a.navbar-brand img {
    width: 142px;
}

.pt-50 {
    padding-top: 50px;
}

.pb-50 {
    padding-bottom: 50px;
}

.btn-black {
    color: #000;
    border: 5px solid #000;
}

.btn.btn-link {
    padding: 13px 27px;
    font-style: normal;
    font-size: 18px;
    line-height: 18px;
    color: #000;
    text-decoration: none;
    font-weight: 600;
}

.btn {
    transition: all 150ms linear 0s;
}

a:hover {
    color: var(--theme-color);
}

.btn:hover,
.btn:focus {
    transform: translateY(-2px);
}

.btn {
    border-radius: 0px;
    /* padding: 10px 24px; */
    background: var(--theme-color);
}

.btn:hover {
    color: #fff !important;
    background-color: var(--theme-color);
    border-color: var(--theme-color);
}

.hometext h1 {
    font-size: 95px;
    font-weight: 700;
    color: var(--theme-color);
}

.fs-20 {
    font-size: 20px;
}

.fs-22 {
    font-size: 22px;
}

.fs-23 {
    font-size: 23px;
}

.fs-48 {
    font-size: 48px;
}

.fs-33 {
    font-size: 33px;
}

.fs-26 {
    font-size: 26px;
}

.fs-39 {
    font-size: 39px;
}

.fs-24 {
    font-size: 24px;
}

.bg-head {
    background: var(--secondary-color);
}

.homebg_section {
    background: var(--theme-color);
}

.inner-content {
    position: absolute;
    bottom: 0;
    transform: translateY(-50%);
    text-align: center;
    z-index: 9;
    padding: 10px;
    left: 0;
    right: 0;
}

.inner-content .btn {
    background: var(--theme-color);
    color: #fff;
    /* padding: 17px 30px; */
}

.allbtn .btn {
    background: #f6f2ef;
    color: #623e2a;
}

.section_title h2 {
    font-size: 79px;
    font-weight: 700;
    color: #000;
}

.bg-img {
    background-size: cover;
    background-repeat: no-repeat;
    width: 100%;
}

.servicecard .card {
    background: #3868b34f;
}

.clients img:hover {
    opacity: 0.75;
}

.clients img {
    object-fit: contain;
    /* height: 97px; */
    width: 100%;
    opacity: 1;
}

.bg-color {
    background: var(--theme-color);
}

.btn-white {
    color: #000;
}

.text-black {
    color: #000 !important;
}

.btn-white:hover {
    border: 1px solid #fff !important;
    color: #fff !important;
    background: transparent !important;
}

.ctaform .form-control {
    border: 3px solid var(--theme-color);
    padding: 13px 13px;
    /* border-radius: 13px; */
}

.submitbtn {
    border: 3px solid var(--theme-color);
    padding: 13px 40px;
    /* border-radius: 13px; */
    font-weight: 500;
    color: #000 !important;
}

.ctaform ::placeholder {
    color: #000;
    font-weight: 500;
    font-size: 20px;
}

.fs-64 {
    font-size: 64px !important;
}

.text-theme {
    color: var(--theme-color);
}

.bg-black1 {
    background: var(--secondary-color);
}

.icon-md i {
    width: 3.6rem;
    height: 3.6rem;
    line-height: 2.6rem;
    text-align: center;
    font-size: 1.5rem;
    background-color: var(--theme-color);
    border-radius: 100%;
    color: #fff;
    justify-content: center;
    align-items: center;
    display: flex;
}

.text-color {
    color: var(--theme-color) !important;
}

.blogs a {
    color: #000;
}

.blogs a:hover {
    color: var(--theme-color);
}

#feedback {
    height: 0px;
    width: 84px;
    position: fixed;
    right: 0;
    top: 50%;
    z-index: 1000;
    transform: rotate(-90deg);
    -webkit-transform: rotate(-90deg);
    -moz-transform: rotate(-90deg);
    -o-transform: rotate(-90deg);
    filter: progid: DXImageTransform.Microsoft.BasicImage(rotation=3);
}

#feedback a {
    display: block;
    background: var(--theme-color);
    height: 56px;
    padding-top: 10px;
    width: 178px;
    text-align: center;
    color: #fff;
    font-size: 17px;
    font-weight: bold;
    text-decoration: none;
    border-radius: 10px;
}

#feedback a:hover {
    background: var(--secondary-color);
}

.bg-theme {
    background: var(--theme-color);
}

.swiper {
    height: 100% !important;
}

.swiper .swiper-slide {
    height: auto !important;
}

.btn-check:focus+.btn-primary,
.btn-primary:focus {
    color: #fff;
    background-color: #3868b3 !important;
    border-color: #3868b3 !important;
    box-shadow: unset !important;
}

.hometext {
    padding-top: 2em;
}

.terms li {
    margin-bottom: 1rem;
}

.quotation-header p {
    font-size: 1.1rem;
    opacity: 0.9;
}

.card-custom {
    background: white;
    border: none;
    border-radius: 12px;
    padding: 2rem;
    margin-bottom: 2rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    transition: transform 0.3s ease;
}

.card-custom:hover {
    transform: translateY(-5px);
}

@media(min-width:992px) {
    .py-30 {
        padding: 0 30px;
    }
    ul.quick_links {
        /* text-align: start; */
        columns: 2;
        text-align: start;
    }
    ul.quick_links li {
        font-size: 23px;
        margin-bottom: 10px;
    }
}

@media(max-width:767px) {
    .hometext h1 {
        font-size: 40px;
    }
    .fs-48 {
        font-size: 27px;
    }
    .inner-content {
        position: absolute;
        bottom: -24px;
        transform: 0;
        text-align: center;
        z-index: 9;
        padding: 2px;
        left: 0;
        right: 0;
        /* top: 0; */
    }
    .fs-33 {
        font-size: 21px;
    }
    .w-25 {
        width: 50% !important;
    }
    .videoWrapper img {
        height: 8em;
    }
    .section_title h2 {
        font-size: 40px;
        padding-top: 1em;
    }
    .fs-26 {
        font-size: 17px;
    }
    .fs-39 {
        font-size: 30px;
    }
    .fs-24 {
        font-size: 17px;
    }
    .fs-64 {
        font-size: 40px !important;
    }
    .clients img {
        object-fit: contain;
        height: 81px;
    }
}