body,
html {
    font-size: 18px;
    line-height: 1.7;
    color: #2b2a29;
    font-family: 'Montserrat', sans-serif;
}

a {
    text-decoration: none;
    color: #2b2a29 !important;
}

.font-alt {
    font-family: 'Titillium Web', sans-serif;
}

.text-black {
    color: #000;
}

.section-head {
    font-size: 2.34rem;
}

.page-header {
    padding: 2rem 0 0;
}

.page-header .brand-logo {
    width: 8rem;
}

.page-header ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.page-header .header-social-links *,
.page-header .header-nav-menu * {
    line-height: 1 !important;
}

.page-header .header-social-links img {
    width: 1rem;
}

.page-header .header-social-links li {
    padding-bottom: 0.4rem;
}

.page-header .header-nav-menu a,
.page-header .header-nav-menu a:hover,
.page-header .header-nav-menu a:active,
.page-header .header-nav-menu a:focus {
    text-decoration: none;
    color: #000;
    text-transform: uppercase;
    font-size: 0.9rem;
}

.page-header .header-nav-menu {
    padding-top: 0.8rem;
}

.page-header .header-nav-menu li {
    padding-bottom: 0.76rem;
}

.page-header .header-nav-menu li:last-child,
.page-header .header-social-links li:last-child {
    padding-bottom: 0;
}

.page-header .site-banner-area {
    margin-top: -6.5rem;
}

.page-header .page-banner {
    width: 17rem;
    border-radius: 3rem;
}

.page-header .page-banner-text {
    transform: translateY(6%);
}

.site-intro {
    padding: 3rem 0 2rem;
}

.site-intro p.intro-para {
    font-size: 1.36rem;
}

.about-image {
    width: 18rem;
}

.site-about-sub {
    padding-top: 3rem;
}

.cta-wrap {
    padding: 3rem 0;
}

.about-sub-image {
    width: 11rem;
    border-radius: 1.4rem;
}

.site-about-sub .section-head {
    font-size: 2rem;
    margin-bottom: 0.1rem;
    line-height: 1;
    color: #000;
}

.site-about-sub p {
    font-size: 0.8rem;
    line-height: 1.35;
}

.custom-cta-btn {
    margin: 3rem 0;
    background-color: #c5a36c;
    color: #ffffff !important;
    line-height: 1;
    font-size: 2.3rem;
    border: none;
    outline: none;
    box-shadow: none;
    padding: 0.55em;
    border-radius: 0.75rem;
}

.custom-cta-btn:hover,
.custom-cta-btn:active,
.custom-cta-btn:focus {
    color: #ffffff;
    border: none;
    outline: none;
    box-shadow: none;
}

.project-wrap .service-box {
    position: relative;
    z-index: 1;
    overflow: hidden;
    border-radius: 1rem;
    cursor: pointer;
}

.project-wrap .service-box .projects-image {
    position: relative;
    z-index: 1;
}

.project-wrap .service-box .service-text {
    position: absolute;
    z-index: 3;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.35);
}

.project-wrap .service-box .service-text h4 {
    color: #ffffff;
    margin: 0;
    padding: 0;
    font-size: 0.9rem;
}

.project-wrap .section-head,
.services-wrap .section-head,
.testimonial-wrap .section-head {
    margin-bottom: 0.9rem;
}

.services-wrap {
    padding: 3rem 0;
}

.services-wrap img {
    border-radius: 1.5rem;
    width: 15rem;
}

.services-wrap p {
    font-size: 1rem;
    line-height: 1.56;
    margin: 0;
}

.services-wrap p a:hover,
.services-wrap p a:active,
.services-wrap p a:focus {
    text-decoration: underline;
}

.testimonial-wrap .carousel-inner {
    background: #d5ad6c;
    border-radius: 1.5rem;
}

.testimonial-wrap .carousel-inner p {
    color: #ffffff;
    margin: 0;
    text-align: left;
    font-size: 0.85rem;
    line-height: 1.56;
    padding: 1.3em 1.7em 0.7em;
}

.testimonial-wrap .carousel-inner h6 {
    color: #ffffff;
    font-size: 0.75rem;
    line-height: 1;
    padding: 0 1.8em 1.4em;
}

.testimonial-wrap .carousel-indicators {
    margin-bottom: 0;
    bottom: -1.5rem !important;
}

.testimonial-wrap .carousel-indicators [data-bs-target] {
    width: 0.7rem;
    height: 0.7rem;
    margin: 0;
    line-height: 1;
    border-radius: 50%;
    background: #d5ad6c;
    padding: 0 !important;
    flex: none !important;
    border: 1px solid #d5ad6c !important;
    margin: 0 0.2rem;
}

.copyright-text {
    padding: 15px;
    background: #f0f0f0;
}

.copyright-text p {
    font-size: 12px;
    margin: 0;
}

.copyright-text p a {
    color: #000;
    text-decoration: none;
}

.site-footer {
    padding: 3rem 0 2rem;
}

.site-footer a {
    text-decoration: none;
    color: #2b2a29;
}

.site-footer hr {
    background: #000000;
    border: none !important;
    height: 1px !important;
    margin: 0 0 2rem;
}

.footer-contact {
    font-size: 0.55rem;
}

.footer-logo {
    width: 9.5rem;
}

.footer-social-links {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.footer-social-links li {
    display: inline-block;
    padding: 0 0.2rem 0 0;
}

.footer-social-links li img {
    width: 1rem;
}

.footer-nav-menu {
    list-style-type: none;
    padding: 0;
    margin: 0;
}

.footer-nav-menu a {
    font-size: 0.85rem;
    text-transform: uppercase;
}


/*-------------------------- CONTACT FORM ---------------*/

.contact-form-wrap {
    background: #ffeacc;
    padding: 3rem 1.5rem;
    border-radius: 3rem;
}

.contact-form-wrap form label {
    font-size: 0.85rem;
}

.contact-form-wrap form p {
    font-size: 0.85rem;
    margin-bottom: 2rem;
}

.contact-form-wrap form sup {
    color: #f00;
}

.contact-form-wrap .form-wrap {
    margin: 0;
    padding-bottom: 0.5rem;
    position: relative;
    z-index: 1;
}

.contact-form-wrap .form-wrap label.error {
    position: absolute;
    bottom: 0;
    left: 0;
    font-size: 11px;
    color: #f00;
    padding: 0;
    margin: 0;
    transform: translateY(50%);
}

.contact-form-wrap .form-control {
    border: 1px solid #e9c182;
    border-radius: 0;
    resize: none;
}

.contact-form-wrap .form-control:hover,
.contact-form-wrap .form-control:active,
.contact-form-wrap .form-control:focus {
    border: 1px solid #a8792b;
    outline: none;
    box-shadow: none;
}

.contact-form-wrap .section-head {
    font-size: 1.75rem;
}

.btn-submit {
    background: #a8792b;
    border: none !important;
    border-radius: 0 !important;
    outline: none !important;
    box-shadow: none !important;
    color: #ffffff !important;
    font-size: 1.1rem;
    padding: .4rem 1.5rem;
}

.contact-details .page-banner-text {
    font-size: 2.24rem;
    margin-bottom: 1rem;
}

.contact-details p,
.contact-details p a {
    color: #000000;
    font-size: 0.9rem;
}

.contact-details p {
    padding-left: 2rem;
    margin-bottom: 0.75rem;
    position: relative;
    z-index: 1;
}

.contact-details p::before {
    position: absolute;
    content: "";
    top: 0.1rem;
    left: 0;
    width: 1.3rem;
    height: 1.3rem;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

.contact-details p.phone::before {
    background-image: url(../assets/icons/phone-icon.svg);
}

.contact-details p.addr::before {
    background-image: url(../assets/icons/location-icon.svg);
}

.contact-details p.mail::before {
    background-image: url(../assets/icons/mail-icon.svg);
}

.contact-details p:last-child {
    margin-bottom: 0;
}


/*------------- About Us and projects -----------------*/

.about-page .site-intro p.intro-para {
    font-size: 1rem;
}

.about-page .site-about .custom-cta-btn {
    pointer-events: none;
    margin: 0;
}

.about-page .site-about .section-head,
.projects-page .site-about .section-head,
.services-page .site-about .section-head {
    font-size: 1.6rem;
    margin-bottom: 0.4em;
}

.about-page .site-about p,
.projects-page .site-about p {
    line-height: 1.7;
    margin-bottom: 1.9em;
}

.projects-page .site-about p {
    line-height: 1.9;
    color: #000000;
}

.about-page .site-about p:last-child {
    margin-bottom: 0;
}

.projects-page .projects-image {
    width: 49%;
    border-radius: 2.5rem;
}

.projects-page .alt .projects-image {
    width: 32%;
    border-radius: 2rem;
}

.services-page .site-about ul {
    padding-left: 20px;
    margin-bottom: 1.4rem;
}

.services-page .site-about .section-head.alt {
    color: #a8792b;
}

.services-page .site-about ul.alt li {
    color: #a8792b;
}

.services-page .site-about ul p {
    color: #000000;
    margin-bottom: 0.4rem;
}

.services-page .about-sub-image {
    width: 13.5rem;
}

.services-page .about-sub-image.alt {
    width: 17.5rem;
}

.more-projects {
    color: #a8792b !important;
}

@media( min-width: 1401px) {
    body,
    html {
        font-size: 24px;
    }
    .container {
        max-width: 1140px;
    }
    /*--------- Contact Us -------------*/
    .contact-details p,
    .contact-details p a {
        font-size: 0.8rem;
    }
}

@media( max-width: 1400px) and ( min-width: 1000px) {
    body,
    html {
        font-size: 20px;
    }
    .container {
        max-width: 990px;
    }
    .site-intro p.intro-para {
        font-size: 1.42rem;
    }
}

@media( max-width: 999px) {
    .intro-para br {
        display: none;
    }
    .page-header .site-banner-area {
        margin-top: 0;
    }
    /*---------- about us ----------------*/
    .about-page .intro-para br {
        display: inline;
    }
    .navigation-wrap {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 999;
        background: #fff;
        padding: 20px;
        display: flex;
        flex-direction: column-reverse;
        justify-content: space-around;
        transform: translateX(-110%);
        transition: all 0.4s ease-in-out;
    }
    .navigation-wrap.active {
        transform: translateX(0%);
        transition: all 0.8s ease-in-out;
    }
    .header-nav-menu li {
        padding-bottom: 30px !important;
    }
    .header-social-links li {
        display: inline-block;
        margin-right: 20px;
    }
    .page-header .header-nav-menu {
        padding: 50px 0 50px;
    }
    .navigation-wrap .header-nav-menu,
    .navigation-wrap .header-social-links {
        transform: translateX(25%);
        opacity: 0;
        transition: all 0.4s ease-in-out;
    }
    .navigation-wrap.active .header-nav-menu,
    .navigation-wrap.active .header-social-links {
        transform: translateX(0%);
        opacity: 1;
        transition: all 0.7s ease-in-out 0.3s;
    }
    .nav-close {
        position: absolute;
        top: 30px;
        right: 30px;
        width: 24px;
        height: 24px;
        z-index: 99;
        cursor: pointer;
    }
    .nav-close::after,
    .nav-close::before {
        position: absolute;
        content: "";
        top: 50%;
        left: 0;
        right: 0;
        height: 2px;
        background: #a0a0a0;
        transform: translateY(-50%) rotate(45deg);
    }
    .nav-close::before {
        transform: translateY(-50%) rotate(-45deg);
    }
    #open-navigation {
        cursor: pointer;
    }
}

@media( max-width: 767px) {
    .intro-para {
        font-size: 1.3rem;
    }
    .site-about-sub p br {
        display: none;
    }
    .site-about-sub .section-head {
        font-size: 1.7rem;
    }
    .custom-cta-btn {
        font-size: 1.7rem;
    }
    .footer-contact {
        font-size: 0.7rem;
    }
    .page-header .page-banner {
        width: 15rem;
    }
    .page-header .page-banner-text {
        font-size: 2.5rem;
    }
    .site-about-sub p {
        font-size: 0.85rem;
    }
    .testimonial-wrap .carousel-inner p,
    .testimonial-wrap .carousel-inner h6 {
        font-size: 0.95rem;
    }
    .projects-page .projects-image,
    .projects-page .alt .projects-image {
        max-width: 400px;
        width: 100%;
    }
}

@media( max-width: 575px) {
    .page-header .brand-logo {
        width: 5rem;
    }
    .custom-cta-btn {
        line-height: 1.3;
        padding: 0.7em 1.3em;
    }
    .services-wrap img {
        width: 70vw;
        height: 355px;
        object-fit: cover;
        object-position: center center;
        margin-left: -5px;
    }
    .footer-nav-menu a {
        font-size: 0.7rem;
    }
    .footer-logo {
        max-width: calc( 50vw - 30px);
    }
    .page-header {
        padding: 1rem 0 0;
    }
    /*------------- Contact Us ------------------*/
    .contact-form-wrap .section-head {
        margin-bottom: 1.5rem;
        font-size: 1.65rem;
    }
    .page-header .page-banner-text {
        font-size: 2.4rem;
    }
    .contact-details p,
    .contact-details p a {
        font-size: 0.8rem;
    }
    /*---------- Projects --------------------*/
    .projects-page .projects-image {
        width: 100%;
    }
}