/* ===================================
    Style   
====================================== */
/* font */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@200;300;400;500;600;700;800&display=swap');
/* variable */
:root {     
    --base-color: #5c6ac4; /* Indigo 400 */
    --dark-gray: #23255a; /* Deep indigo shade */
    --extra-medium-gray: #D3D3D3; /* Medium indigo shade */
    --black: #181a2f; /* Indigo-tinted black */
    --medium-gray: #a3a7d9; /* Muted indigo gray */
    --very-light-gray: #eef0fa; /* Light indigo gray */
    --primary-font: 'Plus Jakarta Sans', sans-serif;

    
}
/* reset */
body{
    line-height: 29px;
}
/* responsive improvements for services-details */
@media (max-width: 991px) {
    .hero-section .container .row .col-12 h1 {
        font-size: 2.5rem !important;
    }
    .hero-section .container .row .col-12 p {
        font-size: 1rem !important;
    }
    .service-main-content .col-lg-6 {
        margin-bottom: 30px;
    }
    .service-features .col-lg-8 {
        padding-left: 15px;
        padding-right: 15px;
    }
    .technologies-process .col-lg-6 {
        margin-bottom: 25px;
    }
    .benefits-section .col-lg-4 {
        margin-bottom: 25px;
    }
    .cta-buttons .btn {
        margin-bottom: 10px;
        width: 100%;
    }
}

@media (max-width: 767px) {
    .hero-section .container .row .col-12 h1 {
        font-size: 2rem !important;
        line-height: 1.2;
    }
    .hero-section .container .row .col-12 p {
        font-size: 0.9rem !important;
        margin-top: 10px !important;
    }
    .hero-section .container .row .col-12 span {
        padding: 5px 15px !important;
        font-size: 11px !important;
    }
    .service-main-content .col-xl-5 h3 {
        font-size: 1.5rem !important;
    }
    .service-features h3 {
        font-size: 1.5rem !important;
    }
    .service-features h5 {
        font-size: 1.1rem !important;
    }
    .technologies-process h5 {
        font-size: 1.1rem !important;
    }
    .benefits-section h3 {
        font-size: 1.5rem !important;
    }
    .benefits-section h6 {
        font-size: 1rem !important;
    }
    .badge {
        font-size: 0.75rem !important;
        padding: 0.3rem 0.6rem !important;
    }
    .process-step .step-text {
        font-size: 0.85rem !important;
    }
    .cta-section h3 {
        font-size: 1.5rem !important;
    }
    .cta-section p {
        font-size: 0.9rem !important;
    }
}

@media (max-width: 575px) {
    .hero-section .container .row .col-12 h1 {
        font-size: 1.8rem !important;
    }
    .service-main-content figcaption {
        width: 120px !important;
        padding: 15px !important;
        bottom: 15px !important;
        left: 15px !important;
    }
    .service-main-content figcaption span {
        font-size: 3rem !important;
    }
    .service-main-content figcaption .fw-500 {
        font-size: 1rem !important;
    }
    .service-features .bg-white {
        padding: 20px !important;
    }
    .technologies-process .bg-white {
        padding: 15px !important;
    }
    .benefits-section .feature-box {
        padding: 15px !important;
    }
    .benefits-section .icon i {
        font-size: 2.2rem !important;
    }
}
/* reset */
body{
    line-height: 29px;
}
/* header */
header .navbar-brand img {
    max-height: 32px;
} 
.navbar .navbar-nav .nav-link {
    font-size: 17px;
}
header .btn.btn-rounded.btn-large {
    padding:10px 26px;
    border-color: var(--extra-medium-gray);
}
.sticky .header-transparent .header-button .btn:hover {
    border-color: var(--dark-gray);
    color: var(--white);
    background:  var(--dark-gray);
}
header.sticky.sticky-active [data-header-hover="light"] .widget-text i {
    color: var(--white);
}
/* accordion style 02 */
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu {
    background-color: var(--dark-gray);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--white);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li:hover a,
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li.active a{
    opacity: .5;
}
/* btn */
[class*=btn-transparent], [class*=" btn-transparent"] {
    font-weight: 500;
}
.btn {
    text-transform: none;
    font-family: var(--primary-font);
}
.btn.btn-switch-text.btn-extra-large > span {
    padding: 19px 40px;
}

.btn-gradient-purple-pink {
    background-image: linear-gradient(to right, #5c6ac4, #7c83e4, #b3b8f7);
    background-size: 200% auto;
    color: #fff;
    border: none;
    transition: all 0.3s ease;
}

.btn-gradient-purple-pink:hover {
    background-position: right center;
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(92, 106, 196, 0.3);
}
/* bg gradient color */
 .bg-gradient-dark-gray-transparent {
    background: -webkit-linear-gradient(right, rgba(35, 37, 90, 0.7), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(35, 37, 90, 0.7), rgba(255, 255, 255, 0.0));
}
 .bg-gradient-very-light-gray-transparent {
    background: -webkit-linear-gradient(right, rgba(238, 240, 250, 1.0), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(238, 240, 250, 1.0), rgba(255, 255, 255, 0.0));
}
 .bg-gradient-flamingo-red-transparent {
    background: -webkit-linear-gradient(right, rgba(92, 106, 196, 1.0), rgba(179, 184, 247, 0.0));
    background: linear-gradient(to right, rgba(92, 106, 196, 1.0) 10%, rgba(179, 184, 247, 0.0) 95%);
}
 .bg-gradient-base-color-transparent {
    background: -webkit-linear-gradient(right, rgba(92, 106, 196, 1.0), rgba(124, 131, 228, 1.0), rgba(179, 184, 247, 0.0));
    background: linear-gradient(to right, rgba(92, 106, 196, 1.0) 10%, rgba(124, 131, 228, 1.0) 50%, rgba(179, 184, 247, 0.0) 95%);
}
 .bg-gradient-light-gray-transparent {
    background: -webkit-linear-gradient(right, rgba(179, 184, 247, 1.0), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(179, 184, 247, 1.0), rgba(255, 255, 255, 0.0));
}
 .bg-midnight-blue {
    background-color: #23255a;
}
/* text */
 .text-flamingo {
    color: #5c6ac4;
}
 .text-gradient-orange-sky-blue {
    background-image: linear-gradient(to right, #5c6ac4, #7c83e4, #b3b8f7);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
    margin-bottom: 25px;
}
/* portfolio filter */
.portfolio-filter li {
    padding: 0 18px;
    line-height: 24px;
}
/* blog */ 
.categories-btn {
    font-size: 11px;
}
/* page title */
.page-title-extra-large h1 {
    font-size: 4rem;
    line-height: 4rem;
}
.page-title-extra-large h2 {
    font-size: 17px;
    line-height: 28px;
    margin: 0 auto;
}
.process-step-style-05 .progress-step-separator {
    bottom: -10px;
    height: 100%;
    z-index: -1;
}
/* height */
.h-72px {
    height: 72px !important;
}
#map {
    height: 650px;
    border-radius: 6px 0 0 6px;
}
/* margin top */
.mt-minus-50px {
    margin-top: -50px;
}
/* line-height */
.lh-200 {
    line-height: 12.5rem;
}
/* bottom */
.bottom-auto {
    bottom: auto;
}
/* footer */
footer .footer-logo img {
    max-height: 35px;
}
footer ul li {
    margin-bottom: 0;
}
.footer-light a:hover, .footer-navbar li a:hover {
    color: var(--dark-gray);
}
@media (max-width: 1299px) {
    .navbar .navbar-nav .nav-link {
        font-size: 16px;
    }
    header .btn.btn-rounded.btn-large {
        padding: 10px 15px;
        font-size: 12px; 
    }
}
@media (max-width: 1199px) {
    .navbar .navbar-nav .nav-link {
        font-size: 15px;
    }
    header .btn.btn-rounded.btn-large {
        padding: 10px 10px;
        font-size: 11px; 
    }
}
@media (max-width: 991px) {
    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu {
        width: calc(100% + 30px) !important;
        margin-left: -15px;
        padding: 10px 45px;
        margin-bottom: 0;
        margin-right: -15px;
    }
    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li:last-child a {
        padding-bottom: 17px;
    }
    [data-mobile-nav-style=full-screen-menu] .navbar-full-screen-menu-inner .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a i {
        font-size: 19px;
    }
    header .btn.btn-rounded.btn-large {
        color: var(--dark-gray);
        border-color: var(--extra-medium-gray);
        padding: 10px 15px;
        font-size: 13px;
    }
}
@media (max-width: 767px) {
    .portfolio-filter li {
        padding: 0;
    }
}