@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Bold.ttf') format('truetype');
    font-weight: bold;
    font-style: normal;
}

.container {
    width: 85% !important;
}

* {
    font-family: 'Montserrat', sans-serif;
    margin: 0;
}

/* Header css */
.h2-color {
    color: #3f59a8 !important;
    font-weight: 700 !important;
}

header {
    position: fixed;
    z-index: 999;
    width: 100%;
    min-height: 80px;
    text-align: center;
    margin-bottom: 70px;
    display: flex !important;
    align-items: center;
}

header nav>div {
    gap: 20px;
}

.nav-item .nav-link {
    font-weight: 400 !important;
}

.navbar-brand {
    padding-right: 10px;
}

.nav-link {
    color: #979595 !important;
    font-weight: 400 !important;
    /* font-size: 20px; */
    text-transform: capitalize !important;
}

.navbar-nav .nav-link:hover {
    color: #3f59a8 !important;
}

.navbar-logo img {
    width: 200px;
}

.header-btn {
    border-radius: 20px !important;
    background-color: #3f59a8;
    color: #fff;
    font-size: 12px !important;
    height: 40px !important;
}

.header-btn a {
    color: #fff;
    padding: 12px 15px !important;

}

.header-btn a:hover {
    color: #fff;
    text-decoration: none;
}

.nav-item .active {
    color: #3f59a8 !important;
}

/* language btn css */
.lang-btn {
    background-color: #ddd;
    border: none;
    padding: 3px 7px !important;
    border-radius: 12px;
    display: flex;
    align-items: center;
}

.lang-btn .flag-icon {
    width: 20px;
    height: 20px;
    border-radius: 50%;
}

.dropdown-menu {
    min-width: 150px;
    border-radius: 8px;
    padding: 5px 0;
}

.dropdown-item {
    display: flex;
    align-items: center;
}

.dropdown-item .flag-icon {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    margin-right: 8px;
}

@media screen and (max-width: 576px) {
    .navbar-logo img {
        width: 100px !important;
    }

    .header-btn {
        padding: 5px 10px !important;
        height: 30px !important;
    }

    .header-btn a {
        font-size: 10px !important;
        padding: 5px 8px !important;
    }

    .header-btn.mob-hide {
        display: none !important;
    }
}

/* banner section css */
.banner {
    width: 100vw;
    background: url('../images/new-banner.jpg') no-repeat center center !important;
    background-size: cover !important;
    min-height: 90vh;
    padding: 150px 0px;
    position: relative;
    vertical-align: middle;
    top: 60px;
}

.banner .col-lg-6 {
    padding: 0 !important;
}

.banner h1 {
    font-weight: 700;
    padding-bottom: 20px;
}

.banner .gap-5 {
    margin-top: 40px;
    margin-left: 0 !important;
    gap: 20px;
}

.banner::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100% !important;
    background: #00124982 !important;
}

.banner-text {
    font-size: 20px !important;
}

@media screen and (max-width: 576px) {
    .banner h1 {
        font-weight: 700;
        padding-bottom: 10px !important;
        font-size: 30px !important;
    }

    .banner p {
        margin-bottom: -10px !important;
        font-size: 15px !important;
    }

    .banner {
        padding-bottom: 80px !important;
        padding-top: 80px !important;
        min-height: 70vh !important;
    }
}

/* why choose section css */
.why-choose {
    padding-top: 140px !important;
    padding-bottom: 60px;
}

.why-choose .col-md-6 {
    padding: 0 !important;
}

.why-choose-img {
    background: url('../images/why-choose-img.jpg') no-repeat center center !important;
    background-size: contain !important;
    border-radius: 20px !important;
    min-height: 400px !important;
}

.why-choose li {
    padding-bottom: 20px;
    margin: 0 !important;
}

.why-choose li img {
    min-height: 30px;
}

@media screen and (max-width: 576px) {
    .why-choose {
        padding-top: 100px !important;
        padding-bottom: 40px !important;
    }

    .why-choose-img {
        min-height: 250px !important;
    }
}

/* our services section css */
.our-service {
    background-color: #F4F4F4;
    padding-top: 80px;
    padding-bottom: 50px;
}

.our-service .card-img-top.rounded-5 {
    border-radius: 15px !important;
}

.our-service .card-hover:hover {
    background-color: #fff !important;
    border-radius: 15px;
}

.our-service .card-hover:hover .card-title {
    color: #3f59a8;
}

.our-service .card-text {
    font-size: 16px !important;
}

.our-service .card-title {
    font-weight: 700 !important;
}

.service-cards {
    width: 49%;
}

.our-service .card-body {
    padding: 20px 40px !important;
}

@media screen and (max-width: 576px) {
    .our-service {
        padding-top: 50px !important;
        padding-bottom: 40px !important;
    }

    .service-cards {
        width: 100%;
        margin-bottom: 20px;
    }

    .service-cards .card-title {
        font-size: 20px !important;
    }

    .our-service .card-body {
        padding: 20px !important;
    }
}

/* easy steps section css */
.easy-steps {
    padding-top: 80px;
    padding-bottom: 60px;
}

.step-col {
    width: 50% !important;
}

.step-col h3 {
    font-weight: 600 !important;
    font-size: 20px !important;
}

.easy-steps .step-col p {
    font-size: 20px !important;
    width: 70%;
}

.step-2 h3,
.step-2 p {
    padding-left: 100px;
}

@media screen and (max-width: 576px) {
    .easy-steps {
        padding-top: 40px !important;
        padding-bottom: 40px !important;
    }

    .easy-steps .step-col p {
        font-size: 16px !important;
        width: 100%;
    }

    .easy-steps .step-col h3 {
        padding-top: 25px !important;
        margin-bottom: -10px !important;
    }

    .map {
        min-height: 300px !important;
        padding-top: 50px !important;
        padding-bottom: 30px !important;
    }

    .step-2 {
        flex-direction: column-reverse;
    }

    .step-col {
        width: 100% !important;
    }

    .step-2 h3,
    .step-2 p {
        padding-left: unset;
    }

    .map-img {
        width: 20px !important;
        height: 20px !important;
    }

    .map h5 {
        font-size: 15px;
        font-weight: 500 !important;
    }

    .available {
        display: block !important;
    }

    .available>.row {
        padding-bottom: 10px;
    }
}

/* where you can find us section css */
.map {
    background-color: #E8EBF3;
    min-height: 500px;
    padding-top: 80px;
    padding-bottom: 60px;
}

.map-img {
    width: 30px;
    height: 30px;
}

/* Testimonial */

.testimonial {
    padding: 80px 0px;
    background-color: #F4F4F4;
}

.quote {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 64px;
    font-weight: 700;
    color: #3F59A8;
    position: absolute;
    top: 20px;
    left: 20px;
}

.card-list {
    padding-top: 40px;
    padding-bottom: 70px;
}

.card-list .card-item {
    color: #000;
    width: 50%;
    padding: 35px 60px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(30px);
    border-radius: 20px;
    background-color: #fff;
    border: 1px solid #CCCCCC;
}

.card-list .card-item .user-image {
    width: 40px;
    height: 40px;
    border-radius: 50%;
}

.card-list .card-item .user-message {
    text-align: center;
    color: #505050;
    padding-top: 50px;
    padding-bottom: 60px;
}

.card-list .card-item .user-detail {
    position: absolute;
    bottom: 20px;
    height: 50px;
    align-items: center !important;
    gap: 10px;
}

.user-detail .user-name {
    font-size: 25px;
    font-weight: 600;
    margin: 0 !important;
}

/* swiper pagination active butllet css */
.swiper-pagination-bullet-active {
    background: #3F59A8 !important;
    width: 18px !important;
    border-radius: 10px !important;
}

@media screen and (max-width: 576px) {
    .testimonial {
        padding-top: 50px !important;
        padding-bottom: 30px !important;
    }

    .testimonial>div p {
        margin-bottom: -15px;
    }

    .testimonial>div h2 {
        padding-bottom: 10px !important;
    }

    .user-detail .user-name {
        font-size: 20px;
    }

    .card-list .card-item .user-message {
        padding-top: 40px;

    }

}

/* contact us css */
.contact-us {
    padding: 80px 0px;
    background: url('../images/cantact-back.png') no-repeat right center !important;
    background-size: contain !important;
}

.contact-us form input,
.contact-us form textarea {
    padding: 15px 10px;
    border-radius: 10px;
    margin-bottom: 20px;
    border: 1px solid #ABABAB;
}

.contact-us form textarea {
    min-height: 150px;
}

.btn-grad {
    border-radius: 50px;
    padding: 15px;
    background-color: #3F59A8;
    border: none;
    color: #fff;
    font-weight: 600;
    text-transform: none !important;
    cursor: pointer;
    width: 50%;
}

.btn-grad:hover {
    background-color: #5770bc;
}

.contact-form {
    align-items: center;
}

.contact-info {
    padding-left: 150px !important;
    padding-bottom: 30px;
    align-items: center;
    gap: 20px;
}

.contact-info img {
    width: 30px;
    height: 30px;
}

.contact-info p {
    margin: 0;
}

.contact-info a {
    color: #505050;
    text-decoration: underline;
}

@media screen and (min-width:1200px) {
    .contact-us {
        width: 1263px !important;
    }
}

@media screen and (min-width: 576px) and (max-width: 768px) {
    .contact-info {
        padding-left: 90px !important;
    }
}

@media screen and (max-width: 576px) {
    .contact-us {
        padding: 40px 0 0;
        background: none !important;
    }

    .contact-us h2 {
        font-size: 30px !important;
    }

    .h2-color {
        font-size: 25px !important;
    }

    .btn-grad {
        width: 100% !important;
        font-size: 14px;
        padding: 10px;
    }

    .contact-form>div {
        padding-bottom: 30px !important;
    }

    .contact-info {
        gap: 10px;
        padding-left: 0px !important;
    }

    .contact-info {
        flex-wrap: nowrap !important;
    }

    .contact-us form input,
    .contact-us form textarea {
        padding: 10px;
    }
}

/* footer css */
.footer-copy {
    background: linear-gradient(to bottom, #3F59A8, #192342) !important;
    padding-top: 80px;
    padding-bottom: 30px;
}

.footer-copy h3 {
    font-weight: 600;
}

.right-arrow {
    position: absolute;
    right: 60px;
    top: -10px;
}

.left-arrow {
    position: absolute;
    left: 60px;
    top: -10px;
}

.footer-copy .gap-5 {
    gap: 20px;
    padding-top: 30px;
}

.footer-logo {
    width: 150px;
    height: 30px;
}

.footer-copy a {
    color: #fff;
    text-decoration: underline;
}

.app-store {
    width: 150px;
}

.footer-copy p {
    margin: 0;
}

@media screen and (max-width: 576px) {
    .footer-copy {
        padding: 30px 10px 20px 10px;
    }

    .footer-copy p {
        font-size: 12px;
        margin: auto !important;
        /* padding-top: 10px; */
    }

    .footer-copy h3 {
        font-size: 25px !important;
    }

    .left-arrow,
    .right-arrow {
        display: none;
    }

    .footer-logo {
        width: 100px;
        height: 20px;
        text-align: center !important;
        margin: auto !important;

    }

    .app-store {
        width: 100px;
        margin-top: -20px;
        margin-bottom: -30px;
    }

    .mob-lang {
        display: none !important;
    }

    .dropdown-menu {
        left: calc(50% - 30px) !important;
    }

    .map-container {
        height: 300px !important;
    }

    .maps {
        height: 300px !important;
    }

    ul.navbar-nav {
        padding-right: 0px !important;
    }

}

@media screen and (min-width:769px) and (max-width:1023px) {
    .left-arrow {
        left: -10% !important;
    }

    .right-arrow {
        right: -10% !important;
    }

    .nav-link {
        font-size: 9px !important;
    }

    .header-btn.mob-hide {
        display: none !important;
    }

    .mob-lang {
        display: none !important;
    }

    .contact-us {
        background: none !important;
    }

    .dropdown-menu {
        left: calc(50% - 30px) !important;
    }

    .map-container {
        height: 400px !important;
    }

    .maps {
        height: 400px !important;
    }

    .contact-info {
        padding-left: 90px !important;
    }

    .why-choose-img {
        padding-left: 50px !important;
    }
}

@media screen and (max-width:768px) {

    .right-arrow,
    .left-arrow {
        display: none !important;
    }
    .mob-lang {
        display: none !important;
    }
    .container {
        width: 98% !important;
    }
    .contact-us {
        background: none !important;
    }
    .dropdown-menu {
        left: calc(50% - 30px) !important;
    }
    .header-btn.mob-hide {
        display: none !important;
    }
    .map-container {
        height: 400px !important;
    }
    .maps {
        height: 400px !important;
    }
    .why-choose-img {
        padding-left: 50px !important;
    }
    .riyadh-pin {
        top: 45%;
        left: 54%;
    }
    .khobar-pin {
        top: 53%;
        left: 64%;
    }
    .dammam-pin {
        top: 60%;
        left: 58%;
    }
}

/* Main container */
select {
    width: 200px;
    padding: 10px;
}

select option {
    padding-left: 20px;
    background-repeat: no-repeat;
    background-size: 20px 20px;
}

.flag {
    width: 20px;
    height: 15px;
    margin-right: 10px;
}

.dropdown.d-lg-none {
    margin-top: 15px;
}

/* map css */
.map-container {
    position: relative;
    width: 100%;
    height: 500px;
    overflow: hidden;
    max-width: 100%;
}

.maps {
    width: 100%;
    height: auto;
    transition: transform 0.3s ease-in-out;
    transform-origin: center center;
    will-change: transform;
}

/* Styling the pins */
.pin {
    position: absolute;
    transform: translate(-50%, -50%);
    color: white;
    padding: 5px 10px;
    text-align: center;
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
}

/* When the pin is visible */
.pin.show {
    opacity: 1;
}

/* css for rtl which is not change from body */
[dir="rtl"] .why-choose h2,
[dir="rtl"] .why-choose p,
[dir="rtl"] .our-service h2,
[dir="rtl"] .our-service p,
[dir="rtl"] .testimonial h2,
[dir="rtl"] .testimonial p,
[dir="rtl"] .contact-us h2,
[dir="rtl"] .easy-steps h3,
[dir="rtl"] .easy-steps p {
    text-align: right !important;
    direction: rtl !important;
}

[dir="rtl"] .why-choose ul {
    padding-right: 0px !important;
}

.force-ltr {
    direction: ltr !important;
}

[dir="rtl"] .banner h1,
[dir="rtl"] .banner p {
    text-align: right !important;
}

[dir="rtl"] .our-service p.card-text {
    text-align: center !important;
}

[dir="rtl"] .banner .rtl-img {
    justify-content: flex- !important;
}

[dir="rtl"] .easy-steps .step-2>.step-col {
    padding-right: 40px;
}

[dir="rtl"] .banner {
    transform: scaleX(-1);
}

[dir="rtl"] .banner>.row {
    transform: scaleX(-1);
}

@media screen and (max-width:500px) {
    [dir="rtl"] .why-choose ul span {
        text-align: right !important;
    }

    [dir="rtl"] .easy-steps .step-2>.step-col {
        padding-right: 0px;
    }

    .riyadh-pin {
        top: 50%;
        /* Adjust as per your image */
        left: 55%;
    }

    .khobar-pin {
        top: 55%;
        left: 63%;
    }

    .dammam-pin {
        top: 58%;
        left: 57%;
    }

    [dir="rtl"] .force-ltr.mob {
        direction: rtl !important;
    }
}

/* form message css */
.form-message {
    padding: 10px;
    margin: 0px 0px 20px 0px;
    border-radius: 8px;
    font-weight: 600;
    display: none;
}

.form-message.success {
    color: #3f59a8;
    background-color: #eaf1ff;
}

.form-message.error {
    color: red;
    background-color: #ffe5e5;
}

@media screen and (min-width: 1201px) {
    .riyadh-pin {
        top: 55%;
        left: 54%;
    }

    .khobar-pin {
        top: 63%;
        left: 64%;
    }

    .dammam-pin {
        top: 70%;
        left: 58%;
    }
}

@media screen and (min-width: 768px) and (max-width: 1200px) {
    /* riyadh-pin */
    .riyadh-pin {
        top: 45%;
        left: 54%;
    }

    .khobar-pin {
        top: 53%;
        left: 64%;
    }

    .dammam-pin {
        top: 60%;
        left: 58%;
    }
}

.dropdown-toggle::after, .navbar-toggler {
    color: #3f59a8 !important;
}