/*--------------------- Copyright (c) 2023 -----------------------
[Master Stylesheet] Project: Locksmith Services-*/
/*----------- 1. Global CSS -----------*/
body {
    color: var(--main-txt-color);
    background: var(--main-bg-color);
}
a {
    color: var(--main-link-color);
}
a:hover, a:focus {
    color: var(--main-color);
}
h1, h2, h3, h4, h5, h6 {
    color: var(--main-color);
}
html {
    scroll-behavior: smooth;
}
/*----------- 2. Comman CSS -----------*/
.px_btn {
    background: var(--main-color);
    color: var(--main-bg-color);
    display: inline-block;
    border: 2px solid transparent;
    border-radius: 30px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    padding: 0 15px;
    width: 170px;
    margin-top: 10px;
    z-index: 0;
    font-weight: 400;
    overflow: hidden;
    position: relative;
}
.px_btn::after, .px_btn.white::after {
    width: 0;
    height: 103%;
    top: 50%;
    left: 50%;
    opacity: 0;
    -webkit-transform: translateX(-50%) translateY(-50%);
    -ms-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
    border-radius: 30px;
    content: "";
    position: absolute;
    z-index: -1;
    -webkit-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
.px_btn:hover::after, .px_btn:focus::after {
    background: var(--main-bg-color);
    width: 100%;
    opacity: 1;
}
.px_btn:hover, .px_btn:focus {
    color: var(--main-color);
    background: transparent;
    border-color: var(--main-color);
    box-shadow: 0 0 20px 0 rgba(83, 80, 255, 0.08);
}
.px_btn.white {
    background: transparent;
    color: var(--main-bg-color);
    border-color: var(--main-bg-color);
}
.px_btn.white:hover::after {
    background: var(--main-bg-color);
    width: 100%;
    opacity: 1;
}
.px_btn.white:hover {
    color: var(--main-color);
    border-color: var(--main-bg-color);
}
.px_heading_wrapper {
    margin-bottom: 45px;
}
.px_heading_wrapper h2 {
    position: relative;
    font-size: 40px;
    font-weight: 700;
    padding-bottom: 10px;
    margin-bottom: 8px;
    color: var(--main-link-color);
}
.px_heading_wrapper h2:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 5px;
    width: 124px;
    height: 1px;
    right: 0;
    background: var(--main-color);
    margin: auto;
    z-index: 0;
}
.px_heading_wrapper h2:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 1px;
    width: 84px;
    height: 1px;
    right: 0;
    background: var(--main-color);
    margin: auto;
}
.px_sub_heading {
    padding-bottom: 10px;
    margin-bottom: 10px;
    font-weight: 700;
    font-size: 22px;
    text-transform: capitalize;
}
.px_sub_heading:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 80px;
    height: 1px;
    background: var(--main-color);
}
.px_sub_heading:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 4px;
    width: 100px;
    height: 1px;
    background: var(--main-color);
}
.px_divider {
    margin: 22px 0;
    display: block;
}
#scroll {
    background-color: var(--main-color);
}
#scroll span {
    color: var(--main-bg-color);
}
.px_section_heading {
    color: var(--main-link-color);
    font-size: 32px;
    margin-bottom: 35px;
    font-weight: 700;
}
.px_btn.white:hover {
    background: var(--main-bg-color);
}
.main_menu_wrapper ul > li > a {
    padding: 12px 0px;
    text-transform: capitalize;
}
.main_menu_wrapper .sub_menu > li > a {
    padding: 10px 15px;
}
/*----------- 3. Preloader CSS -----------*/
.preloader_active .preloader_holder {
    background-color: var(--main-bg-color);
}
.preloader_active .preloader_holder .preloader span {
    box-shadow: 0px 0px 0px 0px var(--main-color);
}
@-webkit-keyframes loadingCircles {
    0% {
        -webkit-transform: scale(0);
        opacity: 1;
        box-shadow: 0px 0px 0px 10px var(--main-color);
   }
    100% {
        -webkit-transform: scale(1);
        opacity: 0;
        box-shadow: 0px 0px 0px 2px var(--main-color);
   }
}
@-moz-keyframes loadingCircles {
    0% {
        -moz-transform: scale(0);
        opacity: 1;
        box-shadow: 0px 0px 0px 10px var(--main-color);
   }
    100% {
        -moz-transform: scale(1);
        opacity: 0;
        box-shadow: 0px 0px 0px 2px var(--main-color);
   }
}
@keyframes loadingCircles {
    0% {
        transform: scale(0);
        opacity: 1;
        box-shadow: 0px 0px 0px 10px var(--main-color);
   }
    100% {
        transform: scale(1);
        opacity: 0;
        box-shadow: 0px 0px 0px 2px var(--main-color);
   }
}
.preloader_open:before, .preloader_open:after {
    background-color: var(--main-bg-color);
}
/*----------- 4. Header Start -----------*/
.px_header_wrapper {
    background: var(--main-bg-color);
    box-shadow: var(--main-comman-shadow);
    padding: 26px 0;
    position: relative;
    top: 0;
    z-index: 9;
    width: 100%;
}
.main_menu_wrapper ul > li.active > a {
    color: var(--main-color);
}
.px_search_wrapper > ul {
    justify-content: space-between;
    align-items: center;
}
.main_menu_wrapper ul > li.active > a {
    color: var(--main-color);
}
.px_search_wrapper .px_btn {
    margin: 0;
    line-height: 45px;
}
.px_search_wrapper {
    position: relative;
}
.px_search_wrapper li {
    display: flex;
}
.px_search_btn {
    width: 16px;
    display: inline-block;
    font-size: 16px;
    margin-right: 24px;
}
.fixed_header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 999;
    background-color: white;
    -webkit-transition: all 0.5s ease-in-out;
    -moz-transition: all 0.5s ease-in-out;
    -ms-transition: all 0.5s ease-in-out;
    -o-transition: all 0.5s ease-in-out;
    transition: all 0.5s ease-in-out;
    box-shadow: 0 14px 28px rgb(0 0 0 / 12%), 0 10px 10px rgb(0 0 0 / 2%);
    padding: 12px 0;
}
/*----------- 5. Banner Start -----------*/
.px_banner_wrapper {
    position: relative;
    background: url(../images/banner.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: bottom;
    width: 100%;
}
.px_banner_img {
    padding-top: 50px;
}
.px_banner_text h1 {
    font-size: 72px;
    color: var(--main-link-color);
    line-height: 80px;
    font-weight: 700;
}
.px_banner_text h4 {
    padding: 16px 0 12px;
    margin-bottom: 14px;
    font-size: 22px;
    font-weight: 700;
    line-height: 18px;
    text-transform: uppercase;
    letter-spacing: 1.3px;
}
.px_banner_text h4:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background: var(--main-color);
    width: 60%;
    height: 1px;
}
.px_banner_text h4:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    background: var(--main-color);
    width: 60%;
    height: 1px;
}
.px_border:before {
    content: "";
    position: absolute;
    top: -4px;
    left: 0;
    background: var(--main-color);
    width: 57%;
    height: 1px;
}
.px_border:after {
    content: "";
    position: absolute;
    bottom: -4px;
    left: 0;
    background: var(--main-color);
    width: 57%;
    height: 1px;
}
.px_banner_text {
    margin: 12px 0 0;
}
/*----------- 6. About Start -----------*/
.px_about_wrapper {
    background: var(--main-bg-color);
    padding: 100px 0 70px;
}
.px_about_wrapper .px_sub_headingm, .px_work_wrapper .px_sub_headingm {
    text-transform: uppercase;
}
.px_about_img {
    padding: 0 0 0 20px;
}
.px_about_img img {
    position: relative;
    border: none;
    border-radius: 6px;
    width: 100%;
}
.px_about_img:before {
    content: "";
    position: absolute;
    left: 0;
    background: var(--main-color);
    z-index: 0;
    width: 300px;
    top: -20px;
    bottom: -20px;
    border-radius: 6px 0 0 6px;
}
.px_about_text {
    display: inline-block;
    width: 100%;
}
.px_about_text h2 {
    font-size: 42px;
    line-height: 50px;
    color: var(--main-link-color);
    margin-bottom: 10px;
    font-weight: 700;
}
.px_list_item li {
    display: inline-block;
    width: 45%;
    line-height: 30px;
    font-weight: 500;
}
.px_list_item li span {
    margin-right: 10px;
}
.px_list_item li a {
    color: var(--main-color);
    font-weight: 500;
}
.px_list_item li a:hover {
    color: var(--main-link-color);
}
.px_list_item {
    margin-top: 6px;
    margin-bottom: 10px;
    display: block;
}
/*----------- 7. Counter Start -----------*/
.px_counter_wrapper {
    position: relative;
    background: url(../images/counter-bg.jpg) no-repeat;
    background-size: cover;
    background-position: center;
    padding: 91px 0 42px;
}
.counter_item h1 {
    font-size: 42px;
    color: var(--main-bg-color);
}
.counter_item p {
    font-size: 18px;
    color: var(--main-bg-color);
}
.px_counter_icon {
    width: 80px;
    height: 80px;
    line-height: 80px;
    border: 2px solid var(--main-bg-color);
    margin: auto;
    transform: rotate(45deg);
    border-radius: 15px;
    margin-bottom: 20px;
}
.px_counter_icon img {
    width: 40px;
    position: relative;
    transform: rotate(-45deg);
}
.counter_item:hover .px_counter_icon {
    background: var(--main-color);
    box-shadow: 0px 0px 20px 0 rgba(255, 255, 255, 0.16);
}
.counter_item, .counter_item:hover .px_counter_icon, .counter_item:hover, .counter_item .px_counter_icon {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
/*----------- 8. Service Start -----------*/
.px_service_wrapper {
    padding: 69px 0 0px;
    position: relative;
    background: url(../images/service-bg.jpg) no-repeat;
    background-size: 100%;
    background-position: top center;
    width: 100%;
    overflow: hidden;
}
.px_service_section {
    margin-top: 50px;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    flex-direction: row-reverse;
}
.px_service_section.icon_left {
    flex-direction: row;
}
.px_service_section .px_service_icon img {
    -webkit-transform: rotateY(0deg);
    transform: rotateY(0deg);
}
.px_service_section:hover .px_service_icon img {
    -webkit-animation: 500ms ease-in-out 0s normal none 1 running zoomIn;
    animation: 500ms ease-in-out 0s normal none 1 running zoomIn;
    -webkit-transform: rotateY(0deg);
    transform: rotateY(0deg);
}
.px_service_text {
    width: calc(100% - 125px);
}
.px_service_icon {
    text-align: right;
    width: 110px;
    margin-left: 15px;
}
.px_service_text p {
    width: 90%;
    float: right;
}
.px_service_section.icon_left .px_service_text p {
    float: left;
}
.px_service_text h4 {
    font-size: 28px;
    color: var(--main-link-color);
    font-weight: 700;
    margin-top: 6px;
}
.px_service_section.icon_left .px_service_icon {
    margin-right: 15px;
    margin-left: 0;
    text-align: left;
}
.px_service_section:hover a {
    color: var(--main-color);
}
.px_service_wrapper .px_heading_wrapper {
    margin-bottom: 41px;
}
.mt_31 {
    margin-top: 31px;
}
/*----------- 9. Testimonials Start -----------*/
.px_testimonial_wrapper {
    padding: 69px 0 139px;
    position: relative;
    background: url(../images/testimonial-bg.jpg) no-repeat;
    background-size: cover;
    background-position: top center;
}
.px_testimonial_wrapper .px_heading_wrapper h2, .px_testimonial_wrapper .px_heading_wrapper p {
    color: var(--main-bg-color);
}
.px_testimonial_wrapper .px_heading_wrapper h2:before, .px_testimonial_wrapper .px_heading_wrapper h2:after {
    background: var(--main-bg-color);
}
.px_testimonial_slider {
    margin-top: 96px;
}
.px_client_quote {
    background: var(--main-bg-color);
    padding: 44px 35px;
    width: 100%;
    border: none;
    border-radius: 8px;
    text-align: center;
    background-image: url(../images/quote.png);
    background-repeat: no-repeat;
    background-position: center;
}
.px_client_quote h4 {
    color: var(--main-link-color);
    font-size: 20px;
    font-weight: 700;
    width: 230px;
    margin: auto;
    margin-top: 6px;
}
.px_client_quote h4 span {
    font-size: 14px;
    vertical-align: middle;
    font-weight: 400;
    color: var(--main-link-color);
}
.px_client_img img {
    width: 211px;
    height: 211px;
    object-fit: fill;
    border: none;
    border-radius: 100%;
}
.px_partner_section {
    display: flex;
    flex-wrap: nowrap;
}
.swiper-container {
    z-index: 0;
}
.px_testimonial_bullets {
    width: 350px;
    height: 350px;
    position: absolute;
    left: 24px;
    top: -70px;
    border: 1px dashed rgba(255, 255, 255, 0.28);
    border-radius: 50%;
    background: transparent;
}
.px_testimonial_wrapper .swiper-pagination-bullet {
    background: transparent;
}
.px_testimonial_bullets .swiper-pagination-bullet-active {
    background: var(--main-color);
    animation: pulsees 2s linear infinite;
    -webkit-animation: pulsees 2s linear infinite;
    -moz-animation: pulsees 2s linear infinite;
}
.px_testimonial_bullets > .swiper-pagination-bullet {
    border-radius: 50%;
    padding: 6px;
    width: 70px;
    height: 70px;
    outline: none;
    opacity: 1;
    position: absolute;
}
.px_testimonial_bullets > .swiper-pagination-bullet:nth-child(1) {
    bottom: -25px;
    left: 120px;
}
.px_testimonial_bullets > .swiper-pagination-bullet:nth-child(2) {
    bottom: 60px;
    left: -15px;
}
.px_testimonial_bullets > .swiper-pagination-bullet:nth-child(3) {
    top: 30px;
    left: 0;
}
.px_testimonial_bullets > .swiper-pagination-bullet:nth-child(4) {
    top: -35px;
    left: -20px;
    right: 50px;
    margin: auto;
}
.px_testimonial_bullets > .swiper-pagination-bullet:nth-child(5) {
    top: -15px;
    right: 40px;
}
.px_testimonial_bullets > .swiper-pagination-bullet:after {
    content: "";
    display: block;
    width: 58px;
    height: 60px;
    border-radius: 50%;
    background-size: cover;
    background-repeat: no-repeat;
    cursor: pointer;
}
.px_testimonial_bullets > .swiper-pagination-bullet:nth-child(1):after {
    background-image: url("../images/testimonial/01.png");
}
.px_testimonial_bullets > .swiper-pagination-bullet:nth-child(2):after {
    background-image: url("../images/testimonial/04.png");
}
.px_testimonial_bullets > .swiper-pagination-bullet:nth-child(3):after {
    background-image: url("../images/testimonial/03.png");
}
.px_testimonial_bullets > .swiper-pagination-bullet:nth-child(4):after {
    background-image: url("../images/testimonial/02.png");
}
.px_testimonial_bullets > .swiper-pagination-bullet:nth-child(5):after {
    background-image: url("../images/testimonial/05.png");
}
.swiper-button-next, .swiper-container-rtl .swiper-button-prev, .swiper-button-prev, .swiper-container-rtl .swiper-button-next {
    background-image: none;
    cursor: pointer;
}
.swiper-button-next:hover, .swiper-button-prev:hover, .swiper-button-next, .swiper-button-prev, .swiper-button-prev1:hover, .swiper-button-next1:hover, .swiper-button-prev1, .swiper-button-next1 {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
.swiper-button-next:hover, .swiper-button-prev:hover, .swiper-button-prev1:hover, .swiper-button-next1:hover {
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -ms-transform: scale(1.2);
    -o-transform: scale(1.2);
    transform: scale(1.2);
}
svg.Capa_1 {
    fill: var(--main-txt-color);
    width: 20px;
}
.px_team_button > div:hover svg, .px_testimonial_button > div:hover svg {
    fill: var(--main-color);
}
.px_testimonial_wrapper .px_testimonial_button {
    bottom: 32%;
    position: absolute;
    width: 370px;
    right: 17.5%;
    margin: auto;
    font-size: 25px;
    color: var(--main-color);
}
@keyframes pulsees {
    0% {
        box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.06);
        -webkit-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.06);
        -moz-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.06);
   }
    40% {
        box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -webkit-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -moz-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
   }
    80% {
        box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -webkit-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -moz-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
   }
    100% {
        box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
        -webkit-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
        -moz-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
   }
}
@-webkit-keyframes pulsees {
    0% {
        box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.06);
        -webkit-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.06);
        -moz-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.06);
   }
    40% {
        box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -webkit-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -moz-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
   }
    80% {
        box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -webkit-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -moz-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
   }
    100% {
        box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
        -webkit-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
        -moz-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
   }
}
@-moz-keyframes pulsees {
    0% {
        box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.06);
        -webkit-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.06);
        -moz-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.06);
   }
    40% {
        box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -webkit-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -moz-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
   }
    80% {
        box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -webkit-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
        -moz-box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
   }
    100% {
        box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
        -webkit-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
        -moz-box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
   }
}
/*----------- 10. Work Start -----------*/
.px_work_wrapper {
    background: var(--main-bg-color);
    padding: 100px 0 70px;
}
.px_about_wrapper .px_sub_heading, .px_work_wrapper .px_sub_heading {
    text-transform: uppercase;
}
.px_work_img img {
    position: relative;
    border: none;
    border-radius: 6px;
    right: 20px;
    width: 100%;
}
.px_work_img:before {
    content: "";
    position: absolute;
    right: 0;
    background: var(--main-color);
    z-index: 0;
    width: 300px;
    top: -20px;
    bottom: -20px;
    border-radius: 0 6px 6px 0;
}
.px_work_text h2 {
    font-size: 42px;
    line-height: 50px;
    color: var(--main-link-color);
    margin-bottom: 10px;
    font-weight: 700;
}
.px_work_item li {
    width: 100%;
    line-height: 30px;
    font-weight: 500;
}
.px_work_item li span {
    margin-right: 10px;
}
.px_work_item li a {
    color: var(--main-color);
    font-weight: 500;
}
.px_work_item li a:hover {
    color: var(--main-link-color);
}
.px_work_item {
    margin-top: 6px;
    margin-bottom: 10px;
}
/*----------- 11. Quote Start -----------*/
.px_quote_wrapper {
    padding: 80px 0 0;
    position: relative;
    background: url(../images/testimonial-bg.jpg) no-repeat;
    background-size: cover;
    background-position: center;
}
.px_quote_text h2 {
    color: var(--main-bg-color);
    font-size: 42px;
    font-weight: 700;
    line-height: 47px;
}
.px_quote_text p {
    color: var(--main-bg-color);
    margin: 12px 0;
}
.px_quote_text h4 {
    color: var(--main-bg-color);
    font-size: 22px;
    font-weight: 500;
    margin-top: 26px;
}
.px_quote_text h1 .px_quate_no {
    font-size: 62px;
    color: var(--main-bg-color);
    display: inline-block;
    font-weight: 700;
    margin-bottom: 1px;
}
/*----------- 12. Project Start -----------*/
.px_project_wrapper {
    padding: 69px 0 41px;
    position: relative;
    background: url(../images/portfolio-bg.jpg) no-repeat;
    background-size: cover;
    background-position: center;
}
.px_project_wrapper .px_heading_wrapper {
    margin-bottom: 41px;
}
.px_project_inner img {
    border: none;
    border-radius: 8px;
}
.px_project_inner .px_project_read {
    background: rgba(0, 0, 0, 0.8);
    opacity: 0;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    width: auto;
    border: none;
    font-weight: 500;
    border-radius: 8px;
    height: 0%;
}
.px_project_inner:hover .px_project_read {
    opacity: 1;
    bottom: 0;
    height: 100%;
}
.px_project_inner:hover .px_project_read, .px_project_inner .px_project_read, .px_project_inner {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
.px_project_read p {
    position: absolute;
    left: 15px;
    right: 15px;
    color: var(--main-bg-color);
    top: 50%;
    width: 170px;
    margin: auto;
    text-align: center;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
}
.px_project_read a {
    color: var(--main-color);
}
/*----------- 13. Appointement Start -----------*/
.px_appointment_wrapper {
    padding: 77px 0 0;
    background: url(../images/appointment-bg.jpg) no-repeat;
    background-size: cover;
    background-position: center;
}
.px_appointment_form h4 {
    color: var(--main-bg-color);
    font-size: 32px;
    margin-bottom: 43px;
    line-height: 32px;
}
.px_appointment_form input {
    width: 100%;
    height: 50px;
    background: transparent;
    border: 1px solid var(--main-bg-color);
    border-radius: 3px;
    padding: 20px;
    color: var(--main-bg-color);
    opacity: 45%;
}
.px_appointment_form textarea {
    width: 100%;
    height: 123px;
    background: transparent;
    border: 1px solid var(--main-bg-color);
    border-radius: 3px;
    padding: 20px;
    color: var(--main-bg-color);
    opacity: 45%;
}
.px_appointment_form .px_btn {
    margin-top: 20px;
}
.px_appointment_form input:focus, .px_appointment_form textarea:focus {
    opacity: 1;
}
.px_appointment_form input:focus, .px_appointment_form textarea:focus, .px_appointment_form input, .px_appointment_form textarea {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
.px_appointment_form {
    margin-bottom: 71px;
}
.px_appointment_form input::-webkit-input-placeholder {
    color: var(--main-bg-color);
    opacity: 45%;
}
.px_appointment_form input::-moz-placeholder {
    color: var(--main-bg-color);
    opacity: 45%;
}
.px_appointment_form input:-ms-input-placeholder {
    color: var(--main-bg-color);
    opacity: 45%;
}
.px_appointment_form input:-moz-placeholder {
    color: var(--main-bg-color);
    opacity: 45%;
}
.px_appointment_form textarea::-webkit-input-placeholder {
    color: var(--main-bg-color);
    opacity: 45%;
}
.px_appointment_form textarea::-moz-placeholder {
    color: var(--main-bg-color);
    opacity: 45%;
}
.px_appointment_form textarea:-ms-input-placeholder {
    color: var(--main-bg-color);
    opacity: 45%;
}
.px_appointment_form textarea:-moz-placeholder {
    color: var(--main-bg-color);
    opacity: 45%;
}
/*----------- 14. Team Start -----------*/
.px_team_wrapper {
    padding: 69px 0 44px;
    background: var(--main-bg-color);
}
.team_slider.swiper-container {
    padding-bottom: 36px;
}
.px_team_img {
    background: var(--main-gym-bg);
    position: relative;
}
.px_team_img img {
    width: 100%;
    border: none;
    border-radius: 8px;
}
.px_team_identity {
    background: var(--main-bg-color);
    padding: 20px 12px;
}
.px_team_identity > a {
    color: var(--main-link-color);
    font-size: 20px;
    font-weight: 700;
    line-height: 20px;
    display: inline-block;
}
.px_team_section:hover .px_team_identity a {
    color: var(--main-color);
}
.px_team_inner {
    margin: auto;
    text-align: center;
    color: var(--main-bg-color);
}
.px_team_hover {
    background: rgba(0, 0, 0, 0.8);
    opacity: 0;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    border: none;
    display: flex;
    align-items: center;
    font-weight: 500;
    border-radius: 8px 8px 0 0;
    -webkit-transform: translateY(-500px);
    -moz-transform: translateY(-500px);
    -ms-transform: translateY(-500px);
    -o-transform: translateY(-500px);
    transform: translateY(-500px);
}
.px_team_section:hover .px_team_hover {
    opacity: 1;
    -webkit-transform: translateY(0px);
    -moz-transform: translateY(0px);
    -ms-transform: translateY(0px);
    -o-transform: translateY(0px);
    transform: translateY(0px);
}
.px_team_section {
    background: var(--main-bg-color);
    box-shadow: 0px 6px 20px 0px rgba(0, 0, 0, 0.06);
    margin: 0;
    border: none;
    border-radius: 8px;
    overflow: hidden;
}
.px_team_section:hover .px_team_identity h4, .px_team_section:hover, .px_team_hover, .px_team_section:hover .px_team_hover {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
.px_team_social, .px_team_info {
    width: 100%;
    display: inline-block;
}
.px_team_info h6 {
    font-size: 20px;
    color: var(--main-bg-color);
}
.px_team_info a {
    color: var(--main-bg-color);
}
.px_team_info a:hover {
    color: var(--main-color);
}
.px_team_info:first-child {
    margin-bottom: 10px;
    padding-bottom: 10px;
    position: relative;
}
.px_team_info:first-child:before {
    background: var(--main-bg-color);
    content: "";
    position: absolute;
    height: 1px;
    width: 60%;
    left: 0;
    right: 0;
    margin: auto;
    bottom: 0;
}
.px_team_social {
    margin-top: 20px;
}
.px_team_social li {
    display: inline-block;
    margin: 0 6px;
    line-height: 1;
    padding-top: 8px;
}
.px_team_social li a {
    color: var(--main-bg-color);
}
.px_team_social li a:hover {
    color: var(--main-color);
}
.px_team_social ul {
    width: auto;
    background: rgba(249, 249, 249, 0.1);
    display: inline-block;
    padding: 6px 20px;
    border: none;
    border-radius: 30px;
}
.swiper-button-prev1, .swiper-button-next1 {
    width: 40px;
    color: var(--main-color);
    cursor: pointer;
    position: absolute;
    height: 36px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.swiper-button-prev1 {
    left: -90px;
}
.swiper-button-next1 {
    right: -100px;
}
.px_team_button {
    position: absolute;
    top: 42%;
    left: 0;
    right: 0;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
}
.swiper-button-next1.swiper-button-disabled, .swiper-button-prev1.swiper-button-disabled {
    color: var(--main-txt-color);
}
.px_team_wrapper.px_team_page_wrapper {
    padding: 80px 0 50px;
}
.px_team_wrapper.px_team_page_wrapper .px_team_section {
    margin-bottom: 30px;
}
.px_team_wrapper .px_heading_wrapper {
    margin-bottom: 41px;
}
/*----------- 15. Partner Start -----------*/
.px_partner_wrapper {
    padding: 80px 0 50px;
    background: url(../images/client-bg.jpg) no-repeat;
    background-size: cover;
    background-position: center;
}
.px_partners_container img {
    opacity: 0.6;
    max-height: 124px;
}
.px_partners_container img:hover {
    opacity: 1;
}
.px_partners_container img:hover, .px_partners_container img {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
/*----------- 16. Footer Start -----------*/
footer {
    background: url(../images/footer-bg.jpg) no-repeat;
    background-size: cover;
    background-position: center;
}
.px_footer_wrapper {
    padding: 80px 0 28px;
    color: var(--main-bg-color);
}
.px_widgets > p {
    margin: 20px 0 18px;
}
.px_address_wrap h4 {
    font-weight: 700;
    color: var(--main-bg-color);
    font-size: 22px;
}
.px_footer_wrapper .px_sub_heading {
    color: var(--main-bg-color);
    margin-bottom: 26px;
    text-transform: capitalize;
    margin-top: 12px;
}
.px_footer_wrapper .px_sub_heading:before, .px_footer_wrapper .px_sub_heading:after {
    background: var(--main-bg-color);
}
.px_widgets .px_sub_heading {
    display: inline-block;
    font-size: 22px;
    margin-top: 0;
}
.px_widgets .px_sub_heading:before {
    width: 80%;
}
.px_widgets .px_sub_heading:after {
    width: 100%;
}
.px_footer_address li {
    margin-bottom: 13px;
}
.px_footer_menu ul li {
    position: relative;
    padding-left: 20px;
    margin-bottom: 13px;
}
.px_footer_menu ul li:before {
    content: "\f105";
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    text-decoration: inherit;
    position: absolute;
    left: 0;
    top: -2px;
    font-size: 20px;
}
.px_footer_address h6 {
    font-size: 18px;
    color: var(--main-bg-color);
    margin-bottom: 8px;
}
.px_footer_address h5 {
    color: var(--main-bg-color);
    font-size: 26px;
}
.px_footer_menu ul li a {
    color: var(--main-bg-color);
    display: inline-block;
    position: relative;
}
.px_footer_menu ul li a:before {
    background: var(--main-bg-color);
    content: "";
    position: absolute;
    width: 0%;
    height: 1px;
    bottom: 0;
}
.px_footer_menu ul li a:hover:before {
    width: 100%;
}
.px_footer_menu ul li a, .px_footer_menu ul li a:hover, .px_footer_menu ul li a:before, .px_footer_menu ul li a:hover:before {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
.px_copyright_wrapper {
    padding: 14px 0 11px;
    border-top: 1px solid rgb(51, 51, 53);
    color: var(--main-bg-color);
}
.px_copyright_wrapper a {
    color: var(--main-color);
}
/*----------- 17. Page Title Start -----------*/
.px_page_title_wrapper {
    position: relative;
    background: url(../images/page_titil_bg.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    width: 100%;
    padding: 41px 0;
    color: var(--main-bg-color);
}
.px_page_title_text h1 {
    color: var(--main-bg-color);
    font-size: 38px;
    line-height: 46px;
    font-weight: 700;
    margin-bottom: 6px;
}
.px_page_title_text ul {
    display: flex;
    justify-content: center;
}
.px_page_title_text ul > li {
    position: relative;
    padding-left: 20px;
}
.px_page_title_text ul > li:first-child {
    padding-left: 0;
}
.px_page_title_text ul > li:before {
    content: "\f105";
    display: inline-block;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    position: absolute;
    top: 3px;
    left: 8px;
}
.px_page_title_text ul > li:first-child:before {
    content: unset;
}
.px_page_title_text ul > li a {
    color: #ffffff;
}
/*----------- 18. About Page Why Us Start -----------*/
.px_tabs_nav {
    display: flex;
    justify-content: space-between;
    border: 1px solid var(--main-border-color);
    border-radius: 6px;
    flex-wrap: wrap;
    margin-bottom: 24px;
    margin-top: 17px;
}
.px_tabs_nav li {
    width: 33.33%;
    height: 70px;
    text-align: center;
    position: relative;
    border-right: 1px solid var(--main-border-color);
    padding: 21px 0;
}
.px_tabs_nav li:last-child {
    border-right: 0px;
}
.px_tabs_nav li a {
    font-size: 20px;
    font-weight: 500;
    display: inline-block;
    position: relative;
}
.px_tabs_nav li::before {
    content: "";
    background: var(--main-color);
    width: 0%;
    height: 4px;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
}
.px_tabs_nav li.active::before, .px_tabs_nav li:hover::before {
    width: 60%;
}
.px_tabs_nav li, .px_tabs_nav li::before, .px_tabs_nav li.active::before, .px_tabs_nav li:hover::before {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
.px_work_wrapper.px_whyUs_wrapper .px_work_text h2 {
    font-size: 36px;
}
.px_work_wrapper.px_whyUs_wrapper {
    padding: 69px 0 70px;
}
/*----------- 19. Service Page Service Thumb Start -----------*/
.px_service_thumb_wrapper {
    padding: 80px 0 30px;
}
.px_service_thumb_section {
    background: var(--main-bg-color);
    margin-bottom: 41px;
}
.px_service_thumb_img {
    position: relative;
    border: none;
    border-radius: 10px;
}
.px_service_thumb_img > a > img {
    border: none;
    border-radius: 10px;
    width: 100%;
}
.px_service_thumb_img .px_service_thumb_icon {
    position: absolute;
    bottom: -30px;
    right: 30px;
}
.px_service_thumb_text {
    margin-top: 30px;
}
.px_service_thumb_text .px_sub_heading {
    margin-bottom: 14px;
    color: var(--main-link-color);
    text-transform: capitalize;
}
.px_service_thumb_section .px_service_thumb_icon img {
    -webkit-transform: rotateY(180deg);
    transform: rotateY(180deg);
}
.px_service_thumb_section:hover .px_service_thumb_icon img {
    -webkit-animation: 500ms ease-in-out 0s normal none 1 running zoomIn;
    animation: 500ms ease-in-out 0s normal none 1 running zoomIn;
    -webkit-transform: rotateY(180deg);
    transform: rotateY(180deg);
}
.px_service_thumb_section {
    -webkit-transform: translateY(0px);
    -moz-transform: translateY(0px);
    -ms-transform: translateY(0px);
    -o-transform: translateY(0px);
    transform: translateY(0px);
}
.px_service_thumb_section:hover {
    -webkit-transform: translateY(-10px);
    -moz-transform: translateY(-10px);
    -ms-transform: translateY(-10px);
    -o-transform: translateY(-10px);
    transform: translateY(-10px);
}
.px_service_thumb_section:hover, .px_service_thumb_section {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
/*----------- 20. Pricing Table Start -----------*/
.px_price_wrapper {
    padding: 69px 0 50px;
}
.px_price_section {
    border: 2px solid var(--main-border-color);
    border-radius: 3px;
    padding: 40px 30px;
    margin-bottom: 30px;
}
.px_price_section h2 {
    color: var(--main-link-color);
    padding-bottom: 12px;
    margin-bottom: 12px;
    position: relative;
}
.px_price_section h2:before {
    content: "";
    background: var(--main-border-color);
    height: 1px;
    width: 20%;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
}
.px_price_section h1 {
    font-size: 62px;
    font-weight: 700;
    margin: 20px 0;
}
.px_price_section h1 > sub {
    font-size: 32px;
    margin-right: 8px;
}
.px_price_section h1 sub.px_price_duration {
    font-size: 16px;
    color: var(--main-link-color);
    margin: 0 0 0 8px;
    bottom: 0;
}
.px_price_section ul li {
    margin-bottom: 18px;
    color: var(--main-link-color);
    font-weight: 500;
}
.px_price_section, .px_price_section:hover, .px_price_section h2, .px_price_section:hover h2 {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -ms-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}
.px_price_section:hover {
    border-color: var(--main-color);
}
.px_price_section:hover h2 {
    color: var(--main-color);
}
/*----------- 21. Project Page Start -----------*/
.px_project_wrapper.px_project_page_wrapper {
    padding: 80px 0 41px;
    background: var(--main-bg-color);
}
/*----------- 22. Blog Page Start -----------*/
.px_blog_wrapper {
    padding: 80px 0 30px;
}
.px_sidebar_widgets {
    margin-bottom: 42px;
}
.px_sidebar_widgets:last-child {
    margin-bottom: 0px;
}
.px_blog_sidebar, .px_sidebar_widgets {
    width: 100%;
}
.px_search_field {
    position: relative;
}
.px_search_field input {
    width: 100%;
    border: 1px solid #e6e6e6;
    height: 50px;
    border-radius: 6px;
    padding: 0 50px 0 30px;
    position: relative;
    line-height: 50px;
    margin-bottom: 4px;
}
.px_search_field > a {
    position: absolute;
    right: 18px;
    top: 0;
    color: var(--main-color);
    bottom: 0;
    line-height: 50px;
}
.px_sidebar_widgets .px_sub_heading {
    margin-bottom: 16px;
}
.px_category_field ul li, .px_archives_field ul li {
    padding: 0 0 12px 20px;
    position: relative;
    justify-content: space-between;
    display: flex;
    flex-wrap: wrap;
}
.px_category_field ul li a, .px_archives_field ul li a {
    width: calc(100% - 60px);
}
.px_category_field ul li:before, .px_archives_field ul li:before {
    content: "\f105";
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    text-decoration: inherit;
    position: absolute;
    top: -2px;
    left: 0;
}
.px_category_field ul li:last-child, .px_archives_field ul li:last-child {
    padding-bottom: 0;
}
.px_latestPost_field ul li {
    display: flex;
    margin-bottom: 12px;
    flex-wrap: wrap;
    align-items: center;
}
.px_latestPost_field ul li:last-child {
    margin-bottom: 0px;
}
.px_latestPost_field ul li .px_blog_thumb {
    margin-right: 10px;
    width: 70px;
    display: inline-block;
}
.px_blog_thumb img {
    border: none;
    border-radius: 3px;
}
.px_blog_title_wrap {
    width: calc(100% - 80px);
}
.px_blog_title {
    font-weight: 700;
    text-transform: capitalize;
}
.px_blog_date {
    color: var(--main-color);
    font-weight: 700;
}
.px_insta_field ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.px_insta_field ul li {
    width: 31%;
    margin: 0 0 10px;
}
.px_insta_field ul li img {
    width: 83px;
    height: auto;
    border-radius: 3px;
    object-fit: cover;
}
.px_blog_img, .px_blog_thumb, .px_effect {
    position: relative;
    overflow: hidden;
}
.px_blog_img img {
    border: none;
    border-radius: 10px;
}
.px_blog_img:after, .px_blog_img:before, .px_blog_thumb:after, .px_blog_thumb:before, .px_effect:after, .px_effect:before {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    z-index: 1;
    background: var(--main-bg-color);
    -webkit-transition: all 0.5s linear;
    -moz-transition: all 0.5s linear;
    -ms-transition: all 0.5s linear;
    -o-transition: all 0.5s linear;
    transition: all 0.5s linear;
}
.px_blog_img:before, .px_blog_img:hover:before, .px_blog_thumb:before, .px_blog_thumb:hover:before, .px_effect:hover:before, .px_effect:before {
    right: 0;
    top: 0;
}
.px_blog_img:hover:after, .px_blog_img:hover:before, .px_blog_thumb:hover:after, .px_blog_thumb:hover:before, .px_effect:hover:after, .px_effect:hover:before {
    width: 100%;
    height: 100%;
    opacity: 0;
}
.px_blog_img:after, .px_blog_img:hover:after, .px_blog_thumb:after, .px_blog_thumb:hover:after, .px_effect:after, .px_effect:hover:after {
    left: 0;
    bottom: 0;
}
.px_blog_img:after, .px_blog_thumb:after, .px_effect:after {
    opacity: 0.3;
}
.px_blog_info ul {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.px_blog_info ul li {
    margin-right: 60px;
}
.px_blog_info ul li:last-child {
    margin-right: 0px;
}
.px_blog_info {
    padding: 30px 0 21px;
}
.px_blog_info ul li img.px_user, .px_blog_info ul li i {
    margin-right: 10px;
}
.px_blog_info ul li .px_user_name, .px_blog_info ul li i {
    color: var(--main-color);
}
img.px_user {
    width: 30px;
    height: 30px;
    border-radius: 100%;
}
.px_blog_info ul li a {
    color: var(--main-txt-color);
}
.px_blog_info ul li a:hover {
    color: var(--main-color);
}
.px_blog_heading {
    font-size: 38px;
    font-weight: 700;
    line-height: 46px;
    display: inline-block;
    margin-bottom: 12px;
}
.px_blog_btn {
    margin-top: 21px;
}
.px_blog_section {
    margin-bottom: 41px;
}
.blog_pagination_wrapper ul li {
    display: inline-block;
    font-size: 18px;
}
.blog_pagination_wrapper ul li a, .blog_pagination_wrapper ul li.dot:hover a {
    color: var(--main-link-color);
    font-weight: 700;
    width: 40px;
    height: 40px;
    line-height: 42px;
    border-radius: 100%;
    display: inline-block;
    text-align: center;
    background: var(--main-bg-color);
}
.blog_pagination_wrapper ul li.dot:hover a {
    cursor: none;
}
.blog_pagination_wrapper ul li.blog_page_prev a, .blog_pagination_wrapper ul li.blog_page_next a {
    width: auto;
    height: 40px;
}
.blog_pagination_wrapper ul li.blog_page_prev:hover a, .blog_pagination_wrapper ul li.blog_page_next:hover a {
    background: var(--main-bg-color);
    color: var(--main-color);
}
.blog_pagination_wrapper ul li.active a, .blog_pagination_wrapper ul li:hover a {
    color: var(--main-bg-color);
    background: var(--main-color);
}
.px_sidebar_widgets.px_sidebar_cat_widgets .px_sub_heading.relative {
    margin-bottom: 14px;
}
.px_sidebar_widgets.px_sidebar_arc_widgets .px_sub_heading.relative {
    margin-bottom: 14px;
}
.px_sidebar_widgets.px_sidebar_cat_widgets {
    margin-bottom: 40px;
}
.px_sidebar_widgets.px_sidebar_arc_widgets {
    margin-bottom: 41px;
}
.px_sidebar_widgets.px_sidebar_insta_widgets .px_sub_heading.relative {
    margin-bottom: 20px;
}
/*----------- 23. Blog Single Page Start -----------*/
.px_blockquote {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.px_blockquote_img {
    width: 160px;
    margin-right: 10px;
    position: relative;
}
.px_blockquote_quote {
    width: calc(100% - 170px);
    color: var(--main-link-color);
    position: relative;
    text-align: center;
}
.px_blockquote_quote p, .px_quote_user {
    text-align: left;
}
.px_blockquote_img img.px_quote_user {
    border: 3px solid var(--main-color);
    border-radius: 50%;
    width: 130px;
    height: 130px;
}
.px_blockquote_img:before {
    content: "\f10e";
    right: 12px;
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    text-decoration: none;
    color: var(--main-color);
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    width: 40px;
    height: 40px;
    line-height: 32px;
    background: var(--main-bg-color);
    border: 5px solid var(--main-color);
    padding-left: 8px;
    border-radius: 100%;
}
.px_quote_user {
    color: var(--main-link-color);
    font-weight: 700;
    font-size: 20px;
    width: 100%;
    display: inline-block;
}
.px_quote_user > span {
    color: var(--main-txt-color);
    font-size: 16px;
    font-weight: 400;
}
.px_blockquote_quote:before {
    content: "\f10e";
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    text-decoration: none;
    color: var(--main-color);
    position: absolute;
    left: 0;
    right: 0;
    font-size: 2%;
    margin: auto;
}
.px_blockquote_quote:before {
    content: "\f10e";
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    text-decoration: none;
    color: var(--main-color);
    position: absolute;
    left: 0;
    right: 0;
    font-size: 84px;
    margin: auto;
    top: 50%;
    opacity: 0.1;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
}
.px_img_text_container {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.px_img_text_container img {
    width: 370px;
    display: inline-block;
    margin: 6px 15px 6px 0;
}
.px_img_text_container p {
    display: inline-block;
    width: calc(100% - 385px);
    text-align: justify;
}
.px_single_blog_text p {
    text-align: justify;
}
.px_author_message_box {
    background: var(--main-color);
    border: none;
    border-radius: 6px;
    padding: 30px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 74px 0 73px;
    color: var(--main-bg-color);
}
.px_author_content h5 {
    color: var(--main-bg-color);
    font-weight: 700;
    font-size: 20px;
}
.px_author_content h5 span {
    font-weight: 400;
    font-size: 16px;
}
.px_author_content {
    width: calc(100% - 140px);
}
.px_author_image {
    width: 110px;
    height: 110px;
    overflow: hidden;
    margin-right: 30px;
}
.px_author_image img {
    width: 110px;
    height: 110px;
    border: none;
    border-radius: 100%;
    object-fit: fill;
}
.px_comment_holder {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.px_comment_detail {
    width: calc(100% - 130px);
}
.px_comment_user {
    width: 100px;
    height: 100px;
    overflow: hidden;
    margin-right: 30px;
}
.px_comment_user img {
    width: 100px;
    height: 100px;
    border: none;
    border-radius: 100%;
    object-fit: fill;
}
.px_blog_comment > ul > li {
    margin-bottom: 26px;
    display: inline-block;
}
.px_blog_comment ul li ul {
    padding-left: 80px;
}
.px_blog_comment > ul > li > ul > li {
    margin-top: 26px;
}
.px_comment_form {
    margin-top: 43px;
}
.px_form_field {
    width: 100%;
    border: 1px solid var(--main-border-color);
    padding: 0 20px;
    height: 50px;
    border-radius: 6px;
    display: flex;
}
textarea.px_form_field {
    height: 150px;
    resize: none;
    padding: 12px 20px;
}
.px_field_holder {
    margin-bottom: 30px;
}
.px_comment_form .px_section_heading {
    margin-bottom: 40px;
}
.px_comment_form .px_btn {
    margin: 0;
}
.px_reply_btn {
    color: var(--main-color);
    margin-left: 15px;
}
.px_reply_btn svg {
    width: 16px;
    fill: var(--main-color);
}
/*----------- 24. Contact Page Start -----------*/
.px_contact_wrapper {
    padding: 80px 0;
}
.px_contact_wrapper .col-lg-4.d-flex {
    padding-left: 0;
    padding-right: 20px;
}
.px_info_bg {
    background: var(--main-color);
}
.px_contact_wrapper > div > .row {
    background: var(--main-bg-color);
    box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.12);
    border: none;
    border-radius: 6px;
    overflow: hidden;
    margin: 0;
}
.px_contact_form {
    padding: 44px 35px 41px 15px;
}
.px_contact_form .px_sub_heading {
    margin-bottom: 30px;
    font-size: 26px;
    color: var(--main-link-color);
}
.px_contact_info {
    padding: 44px 35px 0 50px;
    color: var(--main-bg-color);
}
.px_contact_info .px_sub_heading {
    color: var(--main-bg-color);
    margin-bottom: 28px;
    font-size: 26px;
}
.px_contact_wrapper .px_sub_heading:after {
    width: 115px;
}
.px_contact_wrapper .px_sub_heading:before {
    width: 100px;
}
.px_contact_info .px_sub_heading:after, .px_contact_info .px_sub_heading:before {
    background: var(--main-bg-color);
}
.px_conatact_section > h4 {
    color: var(--main-bg-color);
    font-size: 22px;
    line-height: 22px;
    margin-bottom: 4px;
}
.px_contact_info_inner {
    padding: 0 0 0 25px;
    font-size: 18px;
    position: relative;
    line-height: 28px;
}
.px_contact_info_inner span {
    position: absolute;
    left: 0;
    top: 0;
}
.px_contact_info_inner svg {
    width: 16px;
    fill: var(--main-bg-color);
}
.px_conatact_section {
    margin-bottom: 29px;
    padding-bottom: 22px;
    position: relative;
}
.px_conatact_section:before {
    content: "";
    border-bottom: 1px solid var(--main-bg-color);
    position: absolute;
    bottom: 0px;
    left: -50px;
    right: -50px;
    opacity: 0.2;
}
.px_conatact_section:last-child:before {
    content: unset;
}
.px_contact_form .px_field_holder {
    margin-bottom: 20px;
}
.px_contact_form textarea.px_form_field {
    height: 140px;
}
.px_map {
    width: 100%;
}
.px_map iframe {
    display: block;
    width: 100%;
    height: 640px;
    margin: 0 auto;
}
.px_contact_form .px_btn {
    width: 160px;
    font-size: 15px;
}
/*----------- Index Two Style -----------*/



/*----------- 25. Responsive CSS Start -----------*/
@media (max-width: 1744px) and (min-width: 1401px) {
    .px_service_wrapper .mt_31 {
        margin-top: 0;
   }
    .px_service_section {
        margin-top: 40px;
   }
}
@media (max-width: 1400px) and (min-width: 1200px) {
    .px_service_wrapper .mt_31 {
        margin-top: 0;
   }
}
@media (min-width: 1200px) {
    .px_search_wrapper {
        padding-left: 25px;
   }
}
@media (max-width: 1400px) {
    .swiper-button-next1 {
        right: 4px;
   }
    .swiper-button-prev1 {
        left: 13px;
   }
    .px_service_section {
        margin-top: 20px;
   }
    .px_service_wrapper {
        background-position: center center;
   }
    .px_service_icon {
        flex: 2;
        margin-left: 10px;
   }
    .px_service_section.icon_left .px_service_icon {
        margin: 0 10px 0 0;
   }
    .px_service_wrapper .mb_40 {
        margin-top: 0;
   }
    .px_service_text {
        flex: 5;
   }
    .px_service_text p {
        width: 100%;
   }
}
@media (max-width: 1199.98px) {
    .px_banner_text h1 {
        font-size: 60px;
        line-height: 60px;
   }
    .px_about_text h2, .px_work_text h2 {
        font-size: 30px;
        line-height: 40px;
   }
    .px_service_text h4 {
        font-size: 22px;
   }
    .px_quote_text h2 {
        font-size: 40px;
   }
    .px_quote_text h1 .px_quate_no {
        font-size: 50px;
   }
    .px_service_wrapper .row {
        align-items: flex-end;
   }
    .px_project_read p {
        width: auto;
   }
    .px_price_section {
        padding: 40px 20px;
   }
    .main_menu_wrapper > ul > li {
        position: relative;
        margin-right: -7px;
   }
}
@media (min-width: 992px) and (max-width: 1199.98px) {
    .px_nav_items {
        width: 68%;
   }
    .px_btn {
        padding: 0 30px;
   }
    .px_nav_items ul > li > a {
        padding: 0 5px;
   }
    .px_search_wrapper li:last-of-type {
        margin-left: 6px;
   }
    .px_testimonial_wrapper .px_testimonial_button {
        bottom: 29%;
        right: 9.6%;
   }
    .px_insta_field ul li {
        margin: 0 0 6px;
   }
    .px_service_wrapper .mt_31 {
        margin-top: 0;
   }
    .px_service_section {
        margin-top: 0;
        margin-bottom: 30px;
   }
}
@media (min-width: 991.98px) {
    .px_blog_heading {
        width: 80%;
   }
    .px_testimonial_bullets {
        z-index: 1;
   }
    .main_menu_wrapper ul > li:hover > a {
        color: var(--main-color);
   }
}
@media (max-width: 991.98px) {
    .px_search_wrapper {
        width: 100%;
   }
    .px_search_wrapper ul {
        justify-content: flex-end;
   }
    .main_menu_wrapper li.has_submenu:before, .main_menu_wrapper li.has_submenu:after {
        background: var(--main-color);
   }
    .px_search_btn {
        text-align: center;
        border: none;
        border-radius: 50%;
        width: 50px;
        height: 50px;
        line-height: 50px;
        margin: 0;
   }
    .px_banner_text h1 {
        font-size: 50px;
   }
    .px_list_item li {
        width: 49%;
   }
    .px_service_section {
        margin: 0 0 15px;
   }
    .px_service_section.icon_left .px_service_icon {
        text-align: center;
        margin: 0 10px 10px 0;
   }
    .px_service_wrapper .col-lg-4 {
        margin-top: 0;
   }
    .px_partner_section {
        flex-wrap: wrap;
   }
    .px_testimonial_bullets {
        left: 0;
        right: 0;
        margin: auto;
   }
    .px_testimonial_slider {
        margin-top: 100px;
   }
    .px_client_quote {
        margin-top: 130px;
   }
    .px_testimonial_wrapper .px_testimonial_button {
        bottom: 12.5%;
        width: auto;
        right: 15px;
        left: 15px;
   }
    .px_testimonial_wrapper {
        padding: 70px 0 80px;
   }
    .px_quote_text h2 {
        font-size: 30px;
        line-height: 38px;
   }
    .px_quote_text h4 {
        font-size: 18px;
        margin-top: 20px;
   }
    .px_quote_text h1 .px_quate_no {
        font-size: 36px;
        line-height: 58px;
   }
    .px_project_inner {
        margin-bottom: 18px;
   }
    .px_heading_wrapper h2 {
        font-size: 30px;
   }
    .px_tabs_nav li a {
        font-size: 16px;
   }
    .px_tabs_nav {
        margin-bottom: 20px;
   }
    .px_tabs_nav li {
        height: 60px;
   }
    .px_price_section {
        padding: 30px 15px;
   }
    .px_price_section h1 {
        font-size: 50px;
   }
    .px_search_field input {
        padding: 0 40px 0 20px;
   }
    .px_img_text_container img, .px_img_text_container p {
        width: 100%;
   }
    .px_img_text_container img {
        margin: 15px 0;
   }
    .px_project_wrapper.px_project_page_wrapper {
        padding: 80px 0 44px;
   }
    .px_blog_section {
        margin-bottom: 44px;
   }
    .px_contact_info {
        width: 100%;
   }
    .px_contact_wrapper .col-lg-4.d-flex {
        padding: 0 0 15px 0;
   }
    .px_contact_info {
        padding: 44px 15px 0 15px;
   }
    .px_contact_form {
        padding: 44px 0 41px 0;
   }
}
@media (min-width: 768px) and (max-width: 991.98px) {
    .px_about_wrapper .row, .px_work_wrapper .row {
        align-items: center;
   }
    .px_service_wrapper {
        background-size: cover;
   }
    .px_service_text {
        width: 100%;
        flex: auto;
        text-align: center !important;
   }
    .px_service_icon {
        flex: auto;
        margin: 0 0 10px;
        width: 100%;
        text-align: center;
   }
    .px_category_field ul li a, .px_archives_field ul li a, .px_blog_title_wrap {
        width: 100%;
   }
    .px_latestPost_field ul li .px_blog_thumb {
        width: 100%;
        margin: 0 0 12px;
   }
    .px_insta_field ul li {
        margin: 0 0 5px;
   }
    .px_footer_address h5 {
        font-size: 25px;
   }
    .px_about_wrapper {
        padding: 76px 0 44px;
   }
    .px_counter_wrapper {
        padding: 91px 0 45px;
   }
    .px_service_wrapper {
        padding: 74px 0 0px;
   }
    .px_testimonial_wrapper {
        padding: 74px 0 80px;
   }
    .px_work_wrapper {
        padding: 76px 0 44px;
   }
    .px_project_wrapper {
        padding: 74px 0 44px;
   }
    .px_team_wrapper {
        padding: 74px 0 44px;
   }
}
@media (max-width: 767.98px) {
    .px_project_inner img {
        width: 100%;
   }
    .px_search_wrapper li:last-of-type {
        padding: 0 15px;
   }
    .px_search_wrapper .px_btn {
        width: auto;
        height: 40px;
        line-height: 36px;
        padding: 0 20px;
   }
    .menu_btn {
        margin: 0;
   }
    .px_banner_text h1 {
        font-size: 32px;
        line-height: 40px;
   }
    .px_banner_text h4 {
        font-size: 16px;
   }
    .px_border:before, .px_border:after {
        width: 90%;
   }
    .px_banner_text h4:before, .px_banner_text h4:after {
        width: 100%;
   }
    .px_service_section.icon_left {
        margin: 15px 0 0;
   }
    .px_service_section.icon_left:last-of-type {
        margin-bottom: 70px;
   }
    .px_quote_wrapper > div > .row, .px_appointment_wrapper > div > .row {
        flex-direction: column-reverse;
   }
    .px_search_bar input {
        padding: 6px 100px 6px 15px;
   }
    .px_insta_field ul {
        justify-content: flex-start;
   }
    .px_insta_field ul li img {
        width: 100%;
   }
    .px_insta_field ul li {
        width: 20%;
        margin: 0 10px 10px 0;
   }
    .px_blog_heading {
        font-size: 30px;
        line-height: 40px;
   }
    .px_testimonial_wrapper .px_testimonial_button {
        bottom: 12.3%;
   }
    .px_banner_wrapper .row {
        align-items: flex-end;
   }
    .px_banner_text {
        padding: 10px 0px 34px;
   }
    .menu_btn {
        padding: 13px 0 0;
   }
    .px_about_text {
        margin-top: 16px;
   }
    .px_about_wrapper {
        padding: 100px 0 44px;
   }
    .counter_item {
        margin-bottom: 6px;
   }
    .px_counter_wrapper {
        padding: 91px 0 39px;
   }
    .px_service_wrapper {
        padding: 74px 0 0px;
   }
    .px_service_img {
        margin: 16px 0 15px;
   }
    .px_testimonial_wrapper {
        padding: 74px 0 80px;
   }
    .px_work_wrapper {
        padding: 76px 0 70px;
   }
    .px_work_text {
        margin-bottom: 14px;
   }
    .px_quote_wrapper {
        padding: 73px 0 0;
   }
    .px_quote_text h1 .px_quate_no {
        line-height: 58px;
   }
    .px_project_wrapper {
        padding: 74px 0 44px;
   }
    .px_appointment_wrapper {
        padding: 76px 0 0;
   }
    .px_appointment_form {
        margin-bottom: 24px;
   }
    .px_team_wrapper {
        padding: 74px 0 44px;
   }
    .px_work_wrapper.px_whyUs_wrapper {
        padding: 74px 0 70px;
   }
    .px_service_thumb_wrapper {
        padding: 80px 0 33px;
   }
    .px_price_wrapper {
        padding: 74px 0 50px;
   }
    .px_blog_section {
        margin-bottom: 44px;
   }
    .blog_pagination_wrapper ul li a {
        margin-right: 14px;
   }
    .px_work_wrapper.px_whyUs_wrapper .px_heading_wrapper {
        margin-bottom: 38px;
   }
    .px_footer_wrapper {
        padding: 80px 0 48px;
   }
}
@media (min-width: 576px) {
    .px_service_thumb_wrapper .row {
        margin: 0 -30px;
   }
}
@media (max-width: 575.98px) {
    .px_header_wrapper {
        padding: 15px 0;
   }
    .px_logo {
        padding: 0 0 12px;
        text-align: center;
   }
    .px_search_bar_container {
        width: 80%;
   }
    .px_banner_text h4 {
        padding: 6px 0;
        margin-bottom: 10px;
   }
    .px_banner_text h4 {
        font-size: 12px;
   }
    .px_btn {
        padding: 0 30px;
        width: auto;
        height: 40px;
        line-height: 40px;
   }
    .px_search_wrapper .px_btn {
        margin: 0;
        line-height: 38px;
   }
    .px_search_wrapper ul {
        justify-content: space-between;
   }
    .px_search_wrapper li:last-of-type {
        padding: 0;
   }
    .px_list_item li {
        width: 100%;
   }
    .px_testimonial_bullets {
        width: 280px;
        height: 280px;
        top: -62px;
   }
    .px_client_img img {
        width: 160px;
        height: 160px;
   }
    .px_testimonial_wrapper .px_testimonial_button {
        bottom: 6%;
   }
    .px_work_img {
        padding: 0;
   }
    .px_work_text, .px_about_text {
        padding-top: 15px;
   }
    .px_project_wrapper > div > .row > .row {
        margin: 0;
   }
    .px_quote_text h1 .px_quate_no {
        font-size: 30px;
   }
    .px_appointment_wrapper .padder0, .px_team_wrapper .padder0, .px_footer_wrapper .padder_left, .px_footer_wrapper .padder_right, .px_footer_wrapper .padder0 {
        padding: 0 15px;
   }
    .px_tabs_nav li {
        width: 100%;
        border: none;
        border-bottom: 1px solid #ececec;
   }
    .px_tabs_nav li:last-child {
        border: none;
   }
    .px_blog_info ul li:first-child {
        width: 100%;
        margin: 0 0 20px;
   }
    .px_blog_info ul li {
        margin: 0 30px 0 0;
   }
    .px_blockquote_quote, .px_author_content, .px_comment_detail {
        width: 100%;
        margin: 12px 0 0 0;
   }
    .px_banner_text {
        padding: 72px 15px 0 0;
        text-align: center;
   }
    .px_border:before, .px_border:after {
        width: 100%;
   }
    .px_banner_img {
        padding-top: 24px;
   }
    .px_service_section.icon_left:last-of-type {
        margin-bottom: 74px;
   }
    .px_work_wrapper {
        padding: 61px 0 70px;
   }
    .px_work_wrapper.px_whyUs_wrapper .px_heading_wrapper {
        margin-bottom: 23px;
   }
}
@media (max-width: 359.98px) {
    .px_about_img:before, .px_work_img:before {
        width: 270px;
   }
}
/* manu-css */
.px_nav_items li {
    display: inline-block;
    position: relative;
}
.px_nav_items a {
    text-transform: uppercase;
    text-decoration: none;
    display: block;
    position: relative;
    padding: 4px 0;
}
.px_nav_items a::before {
    content: "";
    width: 100%;
    height: 3px;
    position: absolute;
    left: 0;
    bottom: 5px;
    background: #fff;
    transition: 0.5s transform ease;
    transform: scale3d(0, 1, 1);
    transform-origin: 0 50%;
}
.px_nav_items a::before {
    transform-origin: 50% 50%;
    background: #ff4e4e;
}
.px_nav_items a:hover::before {
    transform: scale3d(1, 1, 1);
}
.px_nav_items a.active::before {
    transform: scale3d(1, 1, 1);
}