@import url('https://fonts.googleapis.com/css2?family=Fira+Code:wght@300..700&family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..800&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap');

html {
    scroll-behavior: smooth;
}


body {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 18px;
    line-height: 24px;
    color: #4B4B4B;
    background-color: #F5F5F5;
}


h1 {
    color: #000814;
    font-size: 48px;
    line-height: 60.48px;
    font-weight: 800;
    margin:0;
}

h3 {
    font-family: 'Fira Code', monospace;
    color: #4B4B4B;
    font-size: 32px;
    line-height: 41.98px;
    font-weight: 400;
    margin: 0;
}


/*Chrome wierdness*/
input:-internal-autofill-selected {
    background-color: #ffffff !important;
}

-webkit-tap-highlight-color {
    background-color: #ffffff !important;
}

input:focus {
    outline: none;
    box-shadow: none;
    background-color: inherit;  
}

input:focus-visible {
    outline: none;
    box-shadow: none;
    background-color: inherit;  
}

*:focus {
    outline: none;
}
.form-control:focus {
    outline: none;
    box-shadow: none;
    background-color: inherit;  
}

.mt-7 {
    margin-top: 7rem;
}

.w-35 {
    width: 35%;
}

.w-55 {
    width: 55%;
}

.bg-blue {
    background-color: #3374E8;
}

/* medium screens */
@media (min-width: 768px) {
    .w-md-55 {
        width: 55% !important;
    }
}


/* Ensure the container-xxl is centered on all devices */
.container-xxl {
    max-width: 1400px !important;
    margin: 0 auto;
/*    padding-left: 15px;
    padding-right: 15px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;*/
}



/*@media (max-width: 576px) {
    .container-xxl {
        margin-left: auto;
        margin-right: auto;*/
      /*  padding-left: 15px;
        padding-right: 15px;*/
        /*width: 100%;
        box-sizing: border-box;
    }
}*/


.cursor-pointer {
    cursor: pointer;
}

.navlogo {
    width: 56px;
    height: 56px;
}

.navbar {
    font-weight: 500;
    font-size: 20px;
    height: 56px;
    background-color: #F5F5F5;
    box-shadow: none;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .navbar .navbar-brand,
    .navbar .nav-link,
    .navbar .navbar-toggler {
        line-height: 56px;
        height: 56px;
        padding: 0;
        color: #4B4B4B;
    }

.navbar-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}

    .navbar-nav .nav-item {
        margin: 0 10px; /* Adjust the margin as needed */
    }

/* Ensure the navbar has a background when collapsed on small screens */
.navbar-collapse {
    background-color: #F5F5F5; /* Set the background color */
}

.navbar-nav {
    background-color: #F5F5F5; 
}
  




.btn-login {
    border: 1px solid #4B4B4B;
    border-radius: 28px;
    color: #4B4B4B;
    background-color: #F5F5F5;
    padding: 0.45rem 1.35rem;
    display: flex;
    align-items: center;
    font-weight: 500;
    font-size: 20px;
}

    .btn-login svg {
        margin-right: 0.5rem;
    }

    .btn-login:hover {
        background-color: #f5f5f5;
    }


.login-dropdown > a {
    border: 1px solid #4B4B4B;
    border-radius: 28px;
    color: #4B4B4B;    
    padding: 0.7rem 1.35rem;
   /* padding: 1rem 1.5rem;   */
    display: flex;
    align-items: center;
    font-weight: 500;
    font-size: 20px;
}

    .login-dropdown > ul {
        border: 1px solid #4B4B4B;
        border-radius: 28px;
        color: #4B4B4B;
        background-color: #F5F5F5;
    }

        .login-dropdown > ul > li > a,
        .login-dropdown > ul > li > a:hover {
            padding: 0.45rem 1.35rem;
            display: flex;
            align-items: center;
            font-weight: 500;
            font-size: 20px;
            background-color: transparent;
        }

        .login-dropdown > ul > li > hr {
            border: 1px solid #000814;
            width: 80%;
            opacity: 0.1;
            margin-left: 5%;
        }




.hero-img {
    margin-top: 2.5rem;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/*.my-carousel {
    overflow: hidden;*/ /* Prevent overflow */
/*}

    .my-carousel .slick-slide {
        display: inline-block;
        float: none;
        vertical-align: top;
        width: 128px !important;*/ /* Set the width of each slide */
        /*height: 128px !important;*/ /* Set the height of each slide */
        /*display: flex;
        align-items: center;
        justify-content: center;
        border: 1px solid #d3d3d3;*/ /* Light gray border */
        /*box-shadow: 0 4px 8px rgba(0, 8, 20, 0.1);*/ /* Drop shadow */
        /*border-radius: 8px;*/ /* Rounded borders */
        /*margin: 0 36px;
        box-sizing: border-box;*/ /* Include border in the element's total width and height */
        /*padding: 0;*/ /* Ensure no padding affects the size */
    /*}


        .my-carousel .slick-slide img {
            max-width: 80%;  
            max-height: 80%;  
            object-fit: contain; 
        }

    .my-carousel .slick-track {
        display: flex;
        align-items: center;
    }*/


.my-carousel {
    overflow: hidden; /* Prevent overflow */
}

    .my-carousel .slick-slide {
        background-color: #fff; /* White background */
        display: flex;
        align-items: center;
        justify-content: center;
        width: 128px !important; /* Set the width of each slide */
        height: 128px !important; /* Set the height of each slide */
        border: 1px solid #d3d3d3; /* Light gray border */
        box-shadow: 0 4px 8px rgba(0, 8, 20, 0.1); /* Drop shadow */
        border-radius: 8px; /* Rounded borders */
        box-sizing: border-box; /* Include border in the element's total width and height */
        padding: 0; /* Ensure no padding affects the size */
    }

    .my-carousel .slick-list {
        padding: 0 10px; /* Optional: Add padding to the edges */
    }

    .my-carousel .slick-slide img {
        max-width: 80%; /* Ensure the image does not take more than 80% of the width */
        max-height: 80%; /* Ensure the image does not take more than 80% of the height */
        object-fit: contain; /* Ensure the image fits within the div */
    }

    .my-carousel .slick-track {
        display: flex;
        align-items: center;
        justify-content: space-between; /* Evenly spread the items */
        width: 100%; /* Ensure the track takes the full width */
    }


.section-tag {
    font-family: 'Fira Code', monospace;
    color: #3373EA;
    font-size: 16px;
    line-height: 16px;
    font-weight: 600;
    padding: 5px 15px;
    text-transform: uppercase;
    background-color: rgba(51, 115, 234, 0.1);
    border-radius: 33px;
}



/********* Services **************/
.card {
    border-radius: 24px;
}

.card.first-service  {
    background: linear-gradient(90deg, rgba(51, 116, 232, 0.1) 0%, rgba(51, 116, 232, 0.02) 100%);
    border: 1px solid rgba(51, 116, 232, 0.1)
}

.card.service {
    background-color: #fff;
    box-shadow: 0px 0px 4px 0px #0008141A;       
}

.send-request,
.send-request:hover 
{
    background-color: #3374E8;
    color: #fff;
    border-radius: 45px;
    font-size: 20px;
    font-weight: 500;
    line-height: 20px;
    padding: 16px 24px;
}

.send-request-icon,
.send-request-icon:hover {
    background-color: #3374E8;
    color: #fff;
    border-radius: 45px;
    font-size: 20px;
    padding: 16px 16px;
}

.service-card-tag {
    font-family: 'Fira Code', monospace;
    font-weight: 500;
    font-size: 20px;
    line-height: 20px;
    color: #4B4B4B;
}

.service-headline {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 18px;
    font-weight: 700;
    font-size: 32px;
    line-height: 44px;
    color: #000814;
}

.service-description {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 28px;
    color: #4B4B4B;
}

/************ Projects ***************/
.project-red-gradient, 
.bg-red-gradient {
    background: linear-gradient(90deg, rgba(193, 24, 24, 0.1) 48.82%, rgba(255, 255, 255, 0.1) 100%);
    border: 1px solid #C118181A;
    box-shadow: 0px 0px 4px 0px #0008141A;
}

.project-green-gradient, 
.bg-green-gradient {
    background: linear-gradient(90deg, rgba(15, 153, 114, 0.1) 57.9%, rgba(255, 255, 255, 0.1) 100%);
    border: 1px solid #0F99721A;
    box-shadow: 0px 0px 4px 0px #0008141A;
}

.project-gray-gradient {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.1) 0%, rgba(102, 102, 102, 0.1) 100%);
    border: 1px solid #0000001A;
    box-shadow: 0px 0px 4px 0px #0008141A;
}

.project-blue-gradient, 
.bg-blue-gradient {
    background: linear-gradient(180deg, rgba(46, 117, 235, 0.1) 20%, rgba(46, 117, 235, 0.02) 60%);
    border: 1px solid #2E75EB1A;
    box-shadow: 0px 0px 4px 0px #0008141A;
}

.project-purple-gradient {
    background: linear-gradient(0deg, rgba(61, 76, 235, 0.1) 20%, rgba(61, 76, 235, 0.05) 60%);
    border: 1px solid #3D4CEB1A;
    box-shadow: 0px 0px 4px 0px #0008141A;
}

.project-purple-light-gradient {
    background: linear-gradient(90deg, rgba(176, 138, 213, 0.1) 56.94%, rgba(176, 138, 213, 0.02) 100%);
    border: 1px solid #B08AD51A;
    box-shadow: 0px 0px 4px 0px #0008141A;
}

.project-lime-gradient {
    background: linear-gradient(90deg, rgba(176, 138, 213, 0.1) 56.94%, rgba(176, 138, 213, 0.02) 100%);
    border: 1px solid #E5FF241A;
    box-shadow: 0px 0px 4px 0px #0008141A;
}


.project-white {
    background-color: #fff;
    border: 1px solid #E5FF241A;
    box-shadow: 0px 0px 4px 0px #0008141A;
}

.project-title {
    font-family: 'Fira Code', monospace;
    font-weight: 600;
    font-size: 32px;
    line-height: 40px;
    color: #000814;
}

.project-description {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 28px;
    color: #4B4B4B;
}

span.project-badge, div.project-badge {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 24px;
    color: #4B4B4B;
    background-color: #fff;
    border-radius: 8px;
    padding: 4px 12px;
    margin-right: 10px;
}

span.badge-border {
    border: 1px solid #4B4B4B;
}

/* for a description */
.close-btn-container {
    display: flex;
    justify-content: flex-end;
}

.close-btn {
    background: none;
    border: none;
    font-size: 20px;
    cursor: pointer;
}


/* Style for WebKit browsers (Chrome, Safari) */
.hidden-project-description::-webkit-scrollbar {
    width: 12px;
}

.hidden-project-description::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 10px;
}

.hidden-project-descriptionn::-webkit-scrollbar-thumb {
    background: #888;
    border-radius: 10px;
}

.hidden-project-description::-webkit-scrollbar-thumb:hover {
    background: #555;
}

/* Style for Firefox */
.hidden-project-description {
    scrollbar-width: thin;
    scrollbar-color: #888 #f1f1f1;
}

/* Style for Internet Explorer and Edge */
.hidden-project-description {
    -ms-overflow-style: -ms-autohiding-scrollbar;
}


/************ showcase *************/
.image-container {
    position: relative;
    width: 100%;
    /*width: 690px;*/
    height: 294px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0px 0px 4px 0px #0008141A;
    border-radius: 24px;
    background-color: #fff;
}

/*.image-container {
    position: relative;
    width: 100%;
    height: 294px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0px 0px 4px 0px #0008141A;
    border-radius: 24px;
}*/

.background-image {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    border: none;
}

.overlay-image {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); /* Centers the overlay image */
    width: 150px; /* Adjust the size as needed */
    height: auto;
}

.text-container {
    position: absolute;
    bottom: 0; /* Aligns the tag to the bottom */
    left: 0; /* Aligns the tag to the left */
    margin: 0px; /* Adjust margin as needed */
}

.showcase-tag {
    font-family: 'Fira Code', monospace;
    font-family: Fira Code;
    font-weight: 600;
    font-size: 28px;
    line-height: 36px;
    color: #fff;
    background-color: #3374E8;
    border-top-right-radius: 24px; /* Top-right corner */
    border-bottom-left-radius: 24px; /* Bottom-left corner */
    padding: 10px 20px; /* Adjust padding as needed */   
}

.showcase-description {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 400;
    font-size: 20px;
    line-height: 28px;
    color: #4B4B4B;
    background-color: transparent;
    margin-top: 1rem;
}


.btn-show-more, .btn-show-more:hover {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 600;
    font-size: 20px;
    line-height: 20px;
    color: #000814;
    border: 1px solid #000814;
    border-radius: 45px;
    padding: 16px 24px;
}


/*************** Schedule Call *************/
.schedule-call {
    background-color: #3374E8;
    border-radius: 24px;
    padding: 24px;
}

.schedule-call-title {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 800;
    font-size: 48px;
    line-height: 64px;
    color: #FFFFFF; 
}

.schedule-call-description {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 400;
    font-size: 20px;
    line-height: 32px;
    color: #FFFFFF;
    opacity: 0.8;
}

.btn-schedule-call {   
    font-weight: 600;
    font-size: 20px;
    line-height: 20px;    
    padding: 16px 24px;
    border-radius: 45px;
}

/*.contact-us input::placeholder,
.contact-us textarea::placeholder,
.contact-us input[type="email"]::placeholder {
    color: #4B4B4B;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 20px;
}*/

/* Placeholder styling for input fields */
.contact-us input::placeholder,
.contact-us textarea::placeholder {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 20px;   
    vertical-align: middle;
    color: #D1D1D1;
}

.contact-us input:focus,
.contact-us textarea:focus {
    background-color: white; /* Keep the same background color when in focus */
    outline: none; /* Remove the default outline */
    box-shadow: none; /* Remove the default box shadow */
}

.contact-us input[type="text"],
.contact-us textarea,
.contact-us input[type="email"],
.contact-us button
{
    padding: 16px 24px;
    border-radius: 16px;
}

.contact-us button, 
.contact-us button:hover {
    background-color: #3374E8;
    color: #fff;
    border-radius: 45px;
    font-size: 20px;
    font-weight: 500;
    line-height: 20px;
    padding: 16px 24px;
}

    .contact-us button .send-request-icon
    .contact-us button .send-request-icon:hover {
        background-color: #3374E8;
        color: #fff;
        border-radius: 45px;
        font-size: 20px;
        padding: 16px 16px;
    }
   

/********* Footer **************/


.footer a {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 500;
    font-size: 20px;
    line-height: 28px;
    color: #4B4B4B;
}

.footer .divider {
    width: 100%;
    height: 1px;
    background-color: #282828;
    opacity: 0.1;
}

.footer .credentials {
    font-family: Roboto;
    font-weight: 400;
    font-size: 20px;
    line-height: 24px;
    letter-spacing: 0px;
    color: #78859E;
    opacity: 0.5;
}

/***** Login section *****************/
.login-area {
    background-color: #ffffff;
    border: 1px solid #F1F1F6;
    box-shadow: 0px 0px 4px 0px #0008141A;
    border-radius: 24px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
}

    .login-area .headline {
        padding-top:5rem;
    }

    .login-area h1 {
        font-family: 'Plus Jakarta Sans', sans-serif;
        font-weight: 800;
        font-size: 32px;
        line-height: 40.32px;
        color: #000814;
    }

    .login-area h4 {
        font-family: 'Plus Jakarta Sans', sans-serif;
        font-weight: 700;
        font-size: 24px;
        line-height: 30.24px;
        color: #000814;
    }

    .login-area img {
        width: 56px;
        height: 56px;
    }

    .login-area .input-div {
        background-color: #ffffff;
       /* padding: 16px 24px;*/
       padding-left:5px;
        border-radius: 16px;
        height: 60px;
        border: 1px solid #A5A5A533;
        box-shadow: 0px 0px 4px 0px #00081405;
        width: 85%;
        margin: 0 0;
    }

    .login-area input[type="email"],
    .login-area input[type="password"] {
        background-color: #ffffff;    
        width: 82%;
        margin: 0 0;
        color: #A5A5A5;
    }


    .login-area .btn-login {
        font-family: 'Plus Jakarta Sans', sans-serif;
        font-weight: 600;
        font-size: 20px;
        line-height: 20px;
        background-color: #3374E8;
        color: #fff;
        border-radius: 45px;
        padding: 16px 24px;
        width: 85%;
        border: none;
    }

.login-area-img {
    width: 100%;
    height: auto; /* Maintain aspect ratio */
    max-width: 100%; /* Ensure the image does not exceed the container's width */
    object-fit: cover; /* Ensures the image covers the entire div */
    object-position: center; /* Centers the image within the div */
}


.custom-email-input {
    background-color: white !important; /* Change the background color */
    color: #4B4B4B !important; /* Change the text color */
    border: none !important; /* Remove the border */
    padding: 0.5rem !important; /* Add padding */
    border-radius: 4px !important; /* Add rounded corners */
}

    .custom-email-input:focus {
        background-color: white !important; /* Change the background color when focused */
        color: #4B4B4B !important; /* Change the text color when focused */
        border: none !important; /* Remove the border when focused */
        outline: none !important; /* Remove the default outline */
        box-shadow: none !important; /* Remove the box shadow when focused */
    }

/* Override Chrome's autofill background color */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 30px white inset !important;
    -webkit-text-fill-color: #4B4B4B !important;
}



.btn-reset-password,
.btn-reset-password:hover {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 22.68px;
    background-color: #fff;
    border: 1px solid #4B4B4B33;
    box-shadow: 0px 0px 4px 0px #00081405;
    border-radius: 16px;
    padding: 16px 24px;
    width: 85%;  
    text-decoration: none; /* Remove underline */
    color: #4B4B4B; /* Set text color */
    display: inline-block; /* Ensure it behaves like a button */
    text-align: center; /* Center the text */
    margin-top: auto;
}

/****** Reset Password ***************/
.login-area .btn-login-reset {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 600;
    font-size: 20px;
    line-height: 20px;
    background-color: #ffffff;
    color: #4B4B4B;
    border-radius: 16px;
    padding: 16px 24px;
    width: 85%;
    border: 1px solid #4B4B4B33;
    box-shadow: 0px 0px 4px 0px #00081405;
}


/* scroolbar removal for the mobile website version */
@media (max-width: 767.98px) {
    html, body {
        overflow-x: hidden;
        max-width: 100%;
    }

    .container-xxl {
        width: 100% !important;
        max-width: 100% !important;
        padding-left: var(--bs-gutter-x, 0.75rem);
        padding-right: var(--bs-gutter-x, 0.75rem);
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

        /* Fix for the mx-4 class on container-xxl that may cause overflow */
        .container-xxl.mx-4 {
            margin-left: 0 !important;
            margin-right: 0 !important;
            width: 100% !important;
        }

    /* Ensure images don't overflow their containers */
    img {
        max-width: 100%;
        height: auto;
    }

    /* Make tables responsive */
    .table-responsive {
        overflow-x: auto;
    }
}

