@font-face {
    font-family: 'Poppins-ExtraBold';
    src: url(../fonts/poppins/Poppins-ExtraBold.ttf);
    font-display: block
}

@font-face {
    font-family: 'Poppins-Regular';
    src: url(../fonts/poppins/Poppins-Regular.ttf);
    font-display: block
}

@font-face {
    font-family: 'Poppins-Black';
    src: url(../fonts/poppins/Poppins-Black.ttf);
    font-display: block
}

@font-face {
    font-family: 'Poppins-SemiBold';
    src: url(../fonts/poppins/Poppins-SemiBold.ttf);
    font-display: block
}

@font-face {
    font-family: 'Poppins-Bold';
    src: url(../fonts/poppins/Poppins-Bold.ttf);
    font-display: block
}

:root {
    --white: #ffffff;
    --dark: #000;
    --secondary: #053a4d;
    --primary: #04a4a4;
    --primaryLight: #daeced;
    --grayLight: #dee2e6;
}

html,
body {
    overflow-x: hidden !important
}

body {
    background-size: cover;
    font-family: 'Poppins-Regular';
    color: var(--dark);
    font-weight: 400;
    font-size: 0.8rem;
    line-height: 1.7rem;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

.row:before,
.row:after {
    display: flex !important
}

a,
.btn,
i {
    -webkit-transition: all .3s ease-out 0;
    transition: all .3s ease-out 0
}

input,
select,
textarea {
    -webkit-transition: all .5s ease-out 0;
    transition: all .5s ease-out 0
}

.btn {
    border-radius: 0;
    font-size: 0.8rem;
    line-height: 1.5rem
}

.btn:hover {
    color: var(--white) !important
}

a:focus,
.btn:focus {
    text-decoration: none;
    outline: none
}

a:focus,
a:hover {
    color: var(--white);
    text-decoration: none
}

a,
button,
input {
    outline: medium none;
    color: inherit
}

html {
    font-size: 100%
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
    font-family: 'Poppins-Bold';
    color: var(--white);
    -webkit-font-variant-ligatures: common-ligatures;
    font-variant-ligatures: common-ligatures;
    margin-top: 0;
    font-weight: 700
}

h5,
.h5,
h6,
.h6 {
    font-family: 'Poppins-Bold';
    font-weight: 400
}

h1,
.h1 {
    font-size: 36px
}

h2,
.h2 {
    font-size: 1.5rem;
}

h3,
.h3 {
    font-size: 26px
}

h4,
.h4 {
    font-size: 1.5rem
}

h5,
.h5 {
    font-size: 0.8rem;
}

h6,
.h6 {
    font-size: 16px
}

@media all and (max-width: 768px) {
    html {
        font-size: 87.5%
    }
}

@media all and (max-width: 767px) {

    h1,
    .h1 {
        font-size: 25px;
        font-size: 1.5rem;
        font-weight: 500
    }

    h2,
    .h2 {
        font-size: 1.6rem;
    }

    h3,
    .h3 {
        font-size: 25px;
        font-size: 1.5rem
    }

    h4,
    .h4 {
        font-size: 16px;
        font-size: 1.5rem;
    }

    h5,
    .h5 {
        font-size: 16px;
        font-size: 0.8rem
    }

    h6,
    .h6 {
        font-size: 16px
    }
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a,
span a,
li a {
    color: inherit
}

p {
    font-family: 'Poppins-Regular';
    font-size: 0.8rem;
    font-weight: 300;
    line-height: normal;
    margin-bottom: 15px
}

img {
    -webkit-transition: all .3s ease-out 0;
    transition: all .3s ease-out 0
}

ul {
    margin: 0;
    padding: 0
}

li {
    list-style: none
}

td {
    font-weight: 300
}

label {
    color: var(--dark);
    font-size: 0.9vw;
    font-family: 'Poppins-Regular';
    font-weight: 800;
}

::-moz-selection {
    text-shadow: none;
    color: var(--dark);
    background: var(--primaryLight);
    text-shadow: none
}

::selection {
    color: var(--dark);
    background: var(--primaryLight);
    text-shadow: none
}

a.button:after,
a.button-small:after {
    -webkit-transition: all .3s ease-out 0;
    transition: all .3s ease-out 0
}

a.button-border span,
a.button-border-white span,
input,
select,
textarea {
    -webkit-transition: all .5s ease-out 0;
    transition: all .5s ease-out 0
}

.button {
    font-family: 'Poppins-Bold';
    border-radius: 3rem;
    color: var(--white);
    display: inline-block;
    text-transform: uppercase;
    cursor: pointer;
    text-align: center
}

.button:hover {
    background: var(--dark)06C
}

select,
input[type="text"],
input[type="number"],
input[type="tel"],
input[type="email"],
input[type="password"] {
    background: var(--white);
    border: 1px solid var(--white);
    color: var(--dark);
    font-family: 'Poppins-Regular';
    font-size: 0.8rem;
    font-weight: 300;
    height: 3.5rem;
    padding: 0 1rem;
    width: 100%;
    border-radius: 3rem;
}

select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding-right: 2.5rem;
    position: relative;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 140 140' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20,50 70,100 120,50' fill='none' stroke='%23000' stroke-width='15' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1.2rem center;
    background-size: 12px;
}

select:focus {
    outline: none;
    box-shadow: none;
}

input::-webkit-input-placeholder {
    color: var(--dark);
    opacity: 1;
}

input::-moz-placeholder {
    color: var(--dark);
    opacity: 1;
}

input::-ms-input-placeholder {
    color: var(--dark);
    opacity: 1;
}

input::-moz-placeholder {
    color: var(--dark);
    opacity: 1;
}

textarea::-webkit-input-placeholder {
    color: var(--dark);
    opacity: 1;
}

textarea::-moz-placeholder {
    color: var(--dark);
    opacity: 1;
}

textarea::-ms-input-placeholder {
    color: var(--dark);
    opacity: 1;
}

textarea::-moz-placeholder {
    color: var(--dark);
    opacity: 1;
}

button {
    background: rgba(0, 0, 0, 0) none repeat scroll 0 0;
    border: medium none;
    font-family: 'Poppins-Bold', sans-serif;
    font-weight: 400
}

textarea {
    background: var(--white);
    border: 1px solid var(--white);
    border-radius: 1.5rem !important;
    box-shadow: none !important;
    color: var(--dark);
    font-family: 'Poppins-Regular';
    font-size: 0.8rem;
    font-weight: 300;
    padding: 1rem 1rem !important;
    resize: vertical;
    width: 100%;
}

textarea:focus {
    outline: none
}

::-moz-placeholder {
    color: var(--dark);
    font-size: 13px
}

.container {
    width: 80vw;
    max-width: 80vw;
}

.z-9 {
    position: relative;
    z-index: 9 !important;
}

.navbar-transparent .navbar-brand {
    color: rgba(255, 255, 255, 0.9);
}

.fixed-top.affix {
    top: 0;
    transition: all .4s ease-in-out;
    -webkit-transition: all .4s ease-in-out;
    -ms-transition: all .4s ease-in-out;
    -moz-transition: all .4s ease-in-out;
    -o-transition: all .4s ease-in-out;
}

.navbar-theme-primary.affix {
    background-color: var(--white) !important;
    box-shadow: 0 4px 10px 0 rgb(0 0 0 / 6%) !important;
}

.navbar-expand-lg .navbar-nav {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    margin: 0 auto;
}

.navbar-expand-lg .navbar-nav .nav-link {
    padding-right: 1.5vw;
    padding-left: 1.5vw;
}

.navbar-nav .nav-link {
    padding-top: 1rem;
    border-radius: 0px;
}

.navbar .navbar-nav .nav-link {
    font-size: 0.8rem;
    text-transform: normal;
    letter-spacing: 0;
    font-weight: 600 !important;
    -webkit-transition: all 0.8s cubic-bezier(0.34, 1.45, 0.7, 1);
    transition: all 0.8s cubic-bezier(0.34, 1.45, 0.7, 1);
    color: var(--white);
}

.navbar-theme-primary.affix .nav-link {
    color: var(--secondary) !important;
    font-weight: 600 !important;
}

.navbar .navbar-nav .nav-link:hover,
.navbar-theme-primary.affix .active,
.navbar-dark .navbar-nav .nav-link.active,
.nav-link:active {
    color: var(--primary) !important;
    font-weight: 600 !important;
}

.navbar .navbar-nav .nav-link-arrow {
    -webkit-transition: -webkit-transform 0.2s ease;
    transition: -webkit-transform 0.2s ease;
    transition: transform 0.2s ease;
    transition: transform 0.2s ease, -webkit-transform 0.2s ease;
}

.navbar-nav .dropdown:hover .nav-link>.nav-link-arrow {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
}

.navbar-expand-lg .navbar-nav .dropdown-menu {
    position: absolute;
}

.navbar .navbar-nav .dropdown .dropdown-menu {
    padding: 0;
    min-width: 200px;
}

.navbar .navbar-nav .dropdown .dropdown-item {
    font-weight: 400;
    font-size: 0.875rem;
}

.section-header {
    z-index: 1;
    text-align: center;
    width: 100%;
    min-width: 100%;
    padding: 10rem 0rem 3rem 0rem;
    position: relative;
    overflow: hidden;
    background-position: top left;
    background-image: url(https://unistudio.co/html/lexend/assets/images/template/pricing-06-bg-masked.png);
    background-repeat: no-repeat;
    background-size: cover;
    -webkit-background-size: cover;
}

.section-header:before {
    background: -webkit-gradient(linear, left top, right top, color-stop(30%, var(--secondary)), to(rgba(26, 44, 121, 0.18)));
    background: linear-gradient(to bottom, var(--secondary) 0%, rgb(0 0 0 / 89%) 100%);
    content: "";
    position: absolute;
    height: 100%;
    width: 100%;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
}

.logo {
    width: 11rem;
}

.dropdown-toggle::after {
    display: none;
}

.navbar-theme-primary {
    top: 1.5rem;
    transition: all .4s ease-in-out;
    -webkit-transition: all .4s ease-in-out;
    -ms-transition: all .4s ease-in-out;
    -moz-transition: all .4s ease-in-out;
    -o-transition: all .4s ease-in-out;
}

.dropdown-item.active,
.dropdown-item:active {
    color: var(--white) !important;
    text-decoration: none;
    background-color: var(--primary);
}

.section-header .panel {
    max-width: 750px !important;
    margin: 0 auto;
    position: relative;
}

.section-header .fs-8 {
    border-radius: 50rem !important;
    gap: .5rem !important;
    padding-top: .5rem !important;
    padding-bottom: .5rem !important;
    padding-right: 1rem !important;
    padding-left: 1rem !important;
    color: var(--white);
    text-transform: uppercase;
    font-size: 0.8rem;
    border: 1px solid rgba(131, 131, 131, 0.25) !important;
}

.section-header h1 {
    font-size: 3.5rem !important;
    margin-top: 1rem;
}

.section-header h1 .span {
    padding-right: .5rem !important;
    padding-left: .5rem !important;
    font-family: 'Poppins-Bold';
    color: var(--primary);
    min-width: 14.5rem;
    height: 4.5rem;
    padding: 10px 30px;
    font-size: 3.5rem !important;
    margin: 10px 0px;
    line-height: 1 !important;
    letter-spacing: -0.2rem !important;
    border-radius: 12px !important;
    transform: rotate(-2deg) !important;
    background-color: var(--grayLight) !important;
    display: inline-flex !important
}

.section-header p {
    color: var(--white);
    font-size: 1.1rem !important;
    display: block !important;
    margin: 2rem;
}

.section-title {
    margin-bottom: 35px;
}

.section-title .sub-title {
    display: block;
    text-transform: uppercase;
    font-size: 0.8rem;
    font-family: 'Poppins-SemiBold';
    line-height: normal;
    color: var(--primary);
    margin-bottom: 12px;
}

.section-title .title {
    margin: 1rem 0px 3rem 0px;
    font-size: 1.8rem;
    color: var(--secondary);
}

.about-area {
    position: relative;
    padding: 4.5rem 0px;
}

.about-img-wrap {
    position: relative;
    z-index: 1;
    padding-bottom: 30px;
}

.about-img-wrap .mask-img-wrap {
    -webkit-mask-image: url(https://apexa-html-demo.vercel.app/assets/img/images/mask_img.png);
    mask-image: url(https://apexa-html-demo.vercel.app/assets/img/images/mask_img.png);
    -webkit-mask-size: 100%;
    mask-size: 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    height: 472px;
    width: 417px;
    margin: 0 auto;
}

.about-img-wrap .mask-img-wrap img {
    max-width: unset;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.about-img-wrap .shape img {
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    z-index: -1;
}

.about-list .list-wrap {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    margin: 0 -15px;
    gap: 30px 0;
    margin-bottom: 25px;
}

.about-list .list-wrap li {
    padding: 0 15px;
    width: 50%;
    flex: 0 0 auto;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    list-style: none;
    align-items: flex-start;
    gap: 15px;
}

.about-list .list-wrap li .icon {
    width: 70px;
    height: 70px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--primaryLight);
    color: var(--primary);
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    -o-border-radius: 8px;
    -ms-border-radius: 8px;
    border-radius: 8px;
    flex: 0 0 auto;
    font-size: 40px;
    line-height: 0;
}

.about-list .list-wrap li .content .title {
    font-size: 1.2rem;
    margin-bottom: 5px;
    font-weight: 600;
    color: var(--primary);
}

.about-list .list-wrap li .content p {
    margin-bottom: 0;
}

.about-list .list-column {
    margin: 0px -15px 25px -15px;
}

.about-list .list-column li {
    padding: 0 15px;
    width: 100%;
    flex: 0 0 auto;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    list-style: none;
    align-items: flex-start;
    gap: 15px;
    padding-bottom: 30px;
}

.about-list .list-column li .icon {
    width: 40px;
    height: 40px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--primary);
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    -o-border-radius: 8px;
    -ms-border-radius: 8px;
    border-radius: 8px;
    flex: 0 0 auto;
    font-size: 40px;
    line-height: 0;
}

.about-list .list-column li .content .title {
    font-size: 1.1rem;
    margin-bottom: 5px;
    font-family: 'Poppins-SemiBold';
    font-weight: 600;
    color: var(--primary);
}

.about-list .list-column li .content p {
    margin-bottom: 0;
}

.about-content>p {
    margin-bottom: 30px;
    width: 93%;
    line-height: 1.62;
}

.about-shape-wrap img:nth-child(1) {
    right: 10%;
    top: 30%;
}

.about-shape-wrap img {
    position: absolute;
    z-index: -1;
}

@media (max-width: 1500px) {
    .about-shape-wrap img:nth-child(1) {
        right: 6%;
        top: 26%;
    }
}

.about-shape-wrap img:nth-child(2) {
    right: 6%;
    top: 36%;
    z-index: -2;
}

.about-shape-wrap img {
    position: absolute;
    z-index: -1;
}

@media (max-width: 1500px) {
    .about-shape-wrap img:nth-child(2) {
        right: 2%;
        top: 34%;
    }
}

.about-left-shape img {
    position: absolute;
    z-index: -1;
    left: 0;
    bottom: 0;
}

.button-primary {
    color: var(--white);
    width: max-content;
    padding: 8px 20px;
    text-align: center;
    display: block;
    background: var(--primary);
    border-radius: 3rem;
    animation-delay: 2.1s;
    transition: all .4s ease-in-out;
    -webkit-transition: all .4s ease-in-out;
    -ms-transition: all .4s ease-in-out;
    -moz-transition: all .4s ease-in-out;
    -o-transition: all .4s ease-in-out;
}

.button-primary:hover {
    background: var(--secondary);
    color: var(--white);
}

.button-call {
    color: var(--white);
    width: max-content;
    padding: 4px 12px;
    margin-top: .5rem;
    text-align: center;
    display: block;
    border: 1px solid #99e5b754 !important;
    background: rgb(255 255 255 / 5%);
    border-radius: 3rem;
    animation-delay: 2.1s;
    transition: all .4s ease-in-out;
    -webkit-transition: all .4s ease-in-out;
    -ms-transition: all .4s ease-in-out;
    -moz-transition: all .4s ease-in-out;
    -o-transition: all .4s ease-in-out;
}

.button-call:hover,
.navbar-theme-primary.affix .button-call {
    background: var(--secondary);
    color: var(--white);
}

.section-header a {
    margin: 0 auto;
}

.service-section {
    position: relative;
    padding: 4.5rem 0px;
}

.service-btn-wrapper {
    display: flex;
    align-items: center;
    gap: 40px;
}

.service-btn-wrapper .array-button {
    gap: 10px;
}

.service-btn-wrapper .array-button .s-prev,
.service-btn-wrapper .array-button .s-next {
    width: 60px;
    height: 60px;
    border: none;
    background: var(--dark);
    color: var(--dark);
}

.service-btn-wrapper .array-button .s-prev:hover,
.service-btn-wrapper .array-button .s-next:hover {
    color: var(--white);
    background: #555;
}

.service-btn-wrapper .array-button .s-next.active {
    color: var(--dark);
    background: #555;
    border-color: #555;
}

.service-btn-wrapper .service-btn a {
    color: var(--white);
    background: linear-gradient(var(--white) 0%, var(--white) 98%);
    background-repeat: no-repeat;
    background-size: 87% 1px;
    background-position: left 100%;
    transition: all 0.3s ease;
}

.service-btn-wrapper .service-btn a:hover {
    background-size: 0 1px;
}

.service-single-box {
    padding: 50px 40px 50px;
    border-radius: 10px;
    position: relative;
    z-index: 1;
    overflow: hidden;
    background-color: var(--grayLight);
    margin: 0px 0px 1rem 0px;
    transition: background-color .4s ease-in-out;
    -webkit-transition: all .3s ease-out 0s;
    -o-transition: all .3s ease-out 0s;
    -moz-transition: all .3s ease-out 0s;
    transition: all .3s ease-out 0s;
    height: 23rem;
}

.service-single-box:hover {
    cursor: pointer;
    background-color: #114f4f;
}

.service-single-box:hover .service-btn {
    padding: 8px 25px;
    max-width: 170px;
    gap: 10px;
    border-radius: 3rem;
}

.service-single-box:hover .link-text {
    animation: typing 1s steps(20) forwards;
    visibility: visible !important;
    width: inherit !important;
    color: var(--white);
    opacity: 1 !important;
}

.service-single-box:hover .icon i {
    animation: mirrorWave 0.5s ease-in-out;
}

.service-single-box.white .icon {
    filter: brightness(0) invert(1);
}

.service-single-box .icon {
    width: 3rem;
    height: 3rem;
    margin-bottom: .4rem;
    color: var(--secondary);
    transition: all 0.3s ease;
    font-size: 2rem;
}

.service-single-box .title {
    font-size: 1rem;
    font-family: 'Poppins-SemiBold';
    font-weight: 600;
    margin: 1rem 0px;
    transition: all 0.3s ease;
    color: var(--secondary);
    text-align: left;
}

.service-single-box .text {
    font-size: 0.8rem;
    line-height: 1.66;
    color: var(--secondary);
    margin-bottom: 23px;
    transition: all 0.3s ease;
    text-align: left;
}

.service-single-box .service-border {
    position: relative;
    border-bottom: 1px solid rgb(5 58 77 / 15%);
    margin: 20px auto 10px auto;
}

.service-single-box:hover .service-border::before {
    left: 0;
    width: 100%;
}

.service-single-box .service-border::before {
    position: absolute;
    content: "";
    width: 0;
    height: 1px;
    background: var(--primary);
    transition: all .4s ease-in-out;
    left: 50%;
}

.service-single-box .service-btn {
    border: 1px solid var(--secondary);
    background: transparent;
    overflow: hidden;
    max-width: 45px;
    height: 45px;
    gap: 0;
    color: var(--secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    /* centrado horizontal al inicio */
    border-radius: 50%;
    -webkit-transition: all .3s ease-out 0s;
    -o-transition: all .3s ease-out 0s;
    -moz-transition: all .3s ease-out 0s;
    transition: all .3s ease-out 0s;
}

.service-single-box .service-btn .link-text {
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    position: relative;
    display: block;
    height: 26px;
    white-space: nowrap;
    overflow: hidden;
    width: 0;
    -webkit-transition: all .3s ease-out 0s;
    -o-transition: all .3s ease-out 0s;
    -moz-transition: all .3s ease-out 0s;
    transition: all .3s ease-out 0s;
}

.service-single-box .service-btn:hover .link-text {
    opacity: 1;
    width: unset;
    color: var(--white);
    visibility: inherit;
}

.service-single-box .serial {
    position: absolute;
    top: 1rem;
    font-family: 'Poppins-SemiBold';
    right: 2rem;
    color: var(--secondary);
    font-size: 1.3rem;
}

.service-single-box.white .serial,
.service-single-box.white .icon,
.service-single-box.white .title,
.service-single-box.white .text {
    color: var(--white);
}

.service-single-box.white .service-btn {
    color: var(--white);
    border-color: var(--white);
}

.service-contact {
    padding: 40px 60px 40px 50px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: var(--secondary);
    clip-path: polygon(30px 0, 100% 0, 100% 50%, 100% 100%, 0 100%, 0 30px);
}

.service-contact .social-proof {
    display: flex;
    align-items: center;
    gap: 25px;
}

.service-contact .social-proof .social img {
    width: 57px;
    height: 57px;
    border-radius: 50%;
    margin-left: -30px;
}

.service-contact .social-proof .social img:first-child {
    margin-left: 0;
}

.service-contact .social-proof .text {
    font-size: 18px;
    color: var(--white);
    margin-bottom: 0;
}

.service-section.style-3 .service-btn-inner {
    gap: 30px;
}

.service-section.style-3 .service-btn-inner .line {
    width: 100%;
    height: 1px;
    background: var(--grayLight);
}

.service-section.style-3 .service-btn-inner .array-prev,
.service-section.style-3 .service-btn-inner .array-next {
    border-color: var(--grayLight);
    background-color: var(--grayLight);
    color: rgba(255, 255, 255, 0.5);
    transition: all 0.3s ease-in-out;
}

.service-section.style-3 .service-btn-inner .array-prev:hover,
.service-section.style-3 .service-btn-inner .array-next:hover {
    color: var(--white);
}

.service-section.style-3 .service-single-box {
    background-color: #DCF1F4;
    transition: background-color 0.4s ease-in-out;
}

.service-section.style-3 .service-single-box:hover {
    background-color: var(--secondary);
}

.service-section.style-3 .service-single-box:hover .icon {
    color: var(--primary);
    filter: brightness(1.2);
}

.service-section.style-3 .service-single-box:hover .title {
    color: var(--white);
}

.service-section.style-3 .service-single-box:hover .text {
    color: var(--white);
}

.service-section.style-3 .service-single-box:hover .serial {
    color: var(--primary);
}

.service-section.style-3 .service-single-box:hover .service-btn {
    color: var(--primary);
    border-color: var(--primary);
}

.service-section.style-3 .service-single-box:hover .border::before {
    left: 0;
    width: 100%;
}

.service-section.style-3 .service-single-box:hover .path__shape {
    opacity: 10;
}

.service-section.style-3 .service-single-box:hover .path__shape::after {
    right: 50px;
    bottom: 50px;
}

.service-section.style-3 .service-single-box .border::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    height: 1px;
    background-color: var(--primary);
    width: 0;
    transition: all 0.4s ease-in-out;
}

.service-section.style-3 .service-single-box .path__shape {
    opacity: 0;
    transition: opacity 0.4s ease-in-out;
}

.service-section.style-3 .service-single-box .path__shape::before {
    content: "";
    position: absolute;
    width: 50px;
    height: 50px;
    background-color: var(--primary);
    right: 0;
    bottom: 0;
}

.service-section.style-3 .service-single-box .path__shape::after {
    content: "";
    position: absolute;
    width: 40px;
    height: 40px;
    background-color: var(--primary);
    right: 0;
    bottom: 0;
}

.service-section .sec-title {
    font-size: 1.8rem;
    line-height: 1.18;
    margin: 1rem 0px 3rem 0px;
    font-weight: 400;
    position: relative;
    color: var(--secondary);
}

.service-section .sub-title {
    display: block;
    text-transform: uppercase;
    font-size: 0.8rem;
    font-family: 'Poppins-SemiBold';
    line-height: normal;
    color: var(--primary);
    margin-bottom: 12px;
}

.section-customers {
    clear: both;
    padding: 4.5rem 0px;
    background-color: transparent;
    position: relative;
    width: 100%;
}

#owl-carousel-2 .owl-item img {
    width: 70%;
    margin: 0 auto;
}

.container-box {
    max-width: 1920px;
    margin: auto;
}

.work-carsouel2 .item {
    position: relative;
    overflow: hidden;
}

#owl-carousel-1 .owl-item img {
    height: 600px;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center center;
    object-position: center center;
}

.work-carsouel2 .item .cont {
    position: absolute;
    left: 30px;
    bottom: 30px;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: all .3s ease-out 0s;
    -o-transition: all .3s ease-out 0s;
    -moz-transition: all .3s ease-out 0s;
    transition: all .3s ease-out 0s;
    z-index: 3;
}

.work-carsouel2 .item .cont h6 {
    padding: 5px 20px;
    background: var(--secondary);
    border-radius: 30px;
    display: inline-block;
    font-weight: 500;
    position: relative;
    z-index: 3;
}

.work-carsouel2 .item .cont h4 {
    font-size: 28px;
    position: relative;
    z-index: 3;
}

.work-carsouel2 .item .cont:after,
.work-carsouel2 .item .cont:before {
    content: '';
    position: absolute;
    top: -150px;
    right: -150px;
    width: 700px;
    height: 700px;
    border-radius: 50%;
    background-color: var(--primary);
    opacity: .5;
    z-index: -1;
}

.work-carsouel2 .item .cont:before {
    top: -120px;
    right: -120px;
    background: -webkit-linear-gradient(250deg, var(--white), var(--primary));
    background: -o-linear-gradient(250deg, var(--white), var(--primary));
    background: linear-gradient(200deg, var(--white), var(--primary));
    opacity: .8;
    z-index: 2;
}

.work-carsouel2 .item:hover .cont,
.left-item .item .cont {
    opacity: 1;
    visibility: visible;
}

.work-carsouel2.work-page .item .img {
    height: 580px;
    min-height: 75vh;
}

.section-4 {
    background-color: var(--white);
    position: relative;
    width: 100%;
    padding: 4.5rem 0px;
    background-size: cover;
    background-attachment: fixed;
    background-position: center;
}

.section-4 h4 {
    margin: 1.5rem 0;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1.2;
    color: var(--secondary);
    -ms-word-wrap: break-word;
    word-wrap: break-word;
}

.intro .pre-title {
    width: fit-content;
    margin: auto;
    display: block;
    font-size: 0.9rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--primary);
}

.intro {
    margin-right: auto;
    margin-left: auto;
    font-size: 0.8rem;
    font-weight: 400;
    line-height: 1.5;
}

.intro h2 {
    margin: 1.5rem 0;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.2;
    color: var(--secondary);
    -ms-word-wrap: break-word;
    word-wrap: break-word;
}

.intro h2 .featured {
    position: relative;
    display: inline-block;
    padding: 5px 15px;
    color: var(--primary);
}

.intro h2 .featured:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 4px;
    background-color: var(--primary);
    opacity: 0.15;
}

.intro h2 .featured span {
    position: relative;
    font-family: 'Poppins-Black';
}

.process .items {
    position: relative;
    cursor: crosshair;
    margin: 1.5rem 0px;
}

.projects .btn-icon {
    color: var(--white);
    opacity: 0;
}

.projects .card:hover .btn-icon {
    opacity: 1;
}

.process .items {
    position: relative;
    cursor: crosshair;
}

.process .items:before {
    content: '';
    position: absolute;
    z-index: 0;
    top: 21px;
    left: 0;
    width: 100%;
    height: 5px;
    background-color: rgba(5, 130, 131, 0.15);
}

.process .step {
    position: relative;
    width: 45px;
    height: 45px;
    margin: auto;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 45px;
    color: var(--primary);
    -webkit-transition: all .3s ease-out 0s;
    -o-transition: all .3s ease-out 0s;
    -moz-transition: all .3s ease-out 0s;
    transition: all .3s ease-out 0s;
}

.process .step:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 100%;
    background-color: var(--primaryLight);
    -webkit-transition: all .3s ease-out 0s;
    -o-transition: all .3s ease-out 0s;
    -moz-transition: all .3s ease-out 0s;
    transition: all .3s ease-out 0s;
}

.process .step span {
    position: relative;
    font-size: 1.4rem;
    cursor: pointer;
}

.process .items .item:hover .step span {
    color: var(--white);
}

.process .items .item:hover .step:before {
    background-color: var(--primary);
}

.container.full {
    max-width: 100% !important;
    min-width: 100% !important;
}

.appointment-area {
    background-color: var(--primary);
    border-radius: 30px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    padding: 5rem 3rem 1.5rem 3rem;
}

@media (max-width: 1199px) {
    .appointment-area {
        margin: 0
    }
}

.appointment-area .title {
    border-bottom: 1px solid #E4E6EA;
    padding: 40px 50px 20px 50px;
    margin-bottom: 0
}

.appointment-area .title-area {
    margin-bottom: 30px;
    position: relative;
    z-index: 2
}

.appointment-area .sec-title {
    margin-bottom: 30px;
    margin-top: 20px;
    text-transform: capitalize;
    font-size: 1.8rem;
}

.appointment-area .sec-desc {
    font-size: 0.8rem;
    color: var(--white);
}

.appointment-area .sub-title {
    position: relative;
    font-weight: 600;
    font-size: 0.8rem;
    text-transform: uppercase;
    color: var(--white);
    margin-bottom: 25px
}

.appointment-area .sub-title::before {
    margin-left: -4.5rem;
    display: none
}

.appointment-area .sub-title:after {
    background-color: var(--white)
}

.appointment-area .sub-title::before,
.appointment-area .sub-title:after {
    content: "";
    position: absolute;
    bottom: -10px;
    height: 2px;
    width: 40px;
    left: 0px;
}

.feature-wrapper {
    margin-bottom: 60px;
    display: inline-flex
}

.feature-wrapper .feature-icon {
    width: 50px;
    height: 50px;
    line-height: 50px;
    border-radius: 50%;
    color: var(--white);
    margin-right: 10px;
    text-align: center;
    background-color: transparent;
    border: 1px solid rgba(255, 255, 255, 0.6);
    cursor: pointer;
    font-size: 1.3rem;
}

.feature-wrapper .feature-icon:hover {
    background-color: var(--white);
    color: var(--primary)
}

.feature-wrapper .header-info_label {
    font-size: 16px;
    color: var(--white);
    font-weight: 500;
    letter-spacing: -0.32px
}

.feature-wrapper .header-info_link {
    font-size: 0.8rem;
    color: var(--white);
    font-weight: 600;
    line-height: 30px;
    letter-spacing: -0.48px;
    margin: 0px;
}

.th-btn {
    position: relative;
    z-index: 2;
    overflow: hidden;
    vertical-align: middle;
    display: inline-block;
    border: none;
    text-transform: uppercase;
    text-align: center;
    background-color: var(--primary);
    color: var(--white);
    font-family: var(--body-font);
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
    padding: 20.5px 20px;
    min-width: 144px;
    border-radius: 3rem;
    -webkit-transition: all .3s ease-out 0s;
    -o-transition: all .3s ease-out 0s;
    -moz-transition: all .3s ease-out 0s;
    transition: all .3s ease-out 0s;
}
.th-btn:hover{
 background-color: var(--secondary);
 border: 1px solid var(--primary);
    color: var(--white);
}
.th-btn:before,
.th-btn:after {
    content: "";
    position: absolute;
    height: 100%;
    top: 0;
    left: 0;
    width: 100%;
    background-color: var(--title-color);
    z-index: -1;
    -webkit-transition: all 0.4s ease-out;
    transition: all 0.4s ease-out;
    border-radius: 99px;
    -webkit-transform: scaleY(1.1);
    -ms-transform: scaleY(1.1);
    transform: scaleY(1.1)
}

.th-btn:before {
    -webkit-transform: scaleY(0);
    -ms-transform: scaleY(0);
    transform: scaleY(0)
}

.th-btn:after {
    -webkit-transform: scaleY(0);
    -ms-transform: scaleY(0);
    transform: scaleY(0)
}

.th-btn:hover,
.th-btn.active {
    color: var(--white);
    box-shadow: none
}

.th-btn:hover::before,
.th-btn:hover:after,
.th-btn.active::before,
.th-btn.active:after {
    border-radius: 0;
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1)
}

.th-btn.style9 {
    background-color: var(--white);
    color: var(--primary);
    box-shadow: none;
    border: none;
    font-weight: 700;
    border-radius: 100px;
    padding: 1rem 1.3rem;
    font-size: 0.8rem;
}

.th-btn.style9:hover {
    color: var(--white)
}

.th-btn.style9:hover:before,
.th-btn.style9:hover:after {
    background-color: var(--secondary)
}

.top-button {
    margin: 30px auto 0;
    display: inline-block;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: var(--primary);
    opacity: 0;
    color: var(--white);
    font-size: 0.8rem;
    line-height: 2.5rem;
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    transition: all .3s;
    position: fixed;
    right: 3vw;
    bottom: 4vw;
    text-align: center;
    cursor: pointer;
    transition: all .4s ease-in-out;
    -webkit-transition: all .4s ease-in-out;
    -ms-transition: all .4s ease-in-out;
    -moz-transition: all .4s ease-in-out;
    -o-transition: all .4s ease-in-out;
    z-index: 22;
}

.top-button:hover {
    background: var(--secondary);
}

.footer-bottom {
    background: var(--secondary);
}

.footer-bottom p {
    font-size: 0.8rem !important;
    color: var(--white);
    padding: 1.5rem 0px;
    text-align: right;
}

figure {
    margin: 0rem;
}

.footer-bottom img {
    width: 12rem;
    margin: 1.3rem 0px;
}

@keyframes moveY {
    0% {
        transform: translateY(0);
    }

    100% {
        transform: translateY(10px);
    }
}

.header-circle {
    position: absolute;
    border: 1px solid #99e5b754 !important;
    background: rgb(255 255 255 / 5%);
    width: 56px;
    height: 56px;
    line-height: 56px;
    border-radius: 50%;
    animation: moveY 0.5s linear infinite alternate;
    animation-delay: 50ms;
}

.header-circle img {
    width: 80%;
}

.btn-toogle {
    display: none;
    position: absolute;
    z-index: 999;
    float: left;
    left: 0px;
    top: 0px;
    padding: .2rem 0px 0px 0px;
    color: var(--white) !important;
    font-size: 1.8rem;
    cursor: pointer;
    transition: all .5s ease;
    -moz-transition: all .5s ease;
    -webkit-transition: all .5s ease;
    -ms-transition: all .5s ease;
    -o-transition: all .5s ease;
    cursor: pointer;
}

.navbar-theme-primary.affix .btn-toogle,
.btn-toogle:hover {
    color: var(--primary) !important;
}

@media (max-width: 1024px) {
    .container {
        width: 90vw;
        max-width: 90vw;
    }

    .about-list .list-wrap li .content .title {
        width: inherit;
    }

    .service-single-box {
        height: auto;
    }
}

.fixed-mobile {
    position: fixed;
    height: 100%;
    width: 100%;
    left: 0px;
    top: 0px;
    opacity: 0;
    transform: translateY(-20px);
    /* Desplazamiento inicial */
    transition: opacity 0.5s ease, transform 0.5s ease;
    /* Animaciones suaves */
    transition: 0.5s ease;
    background: rgb(0 0 0 / 32%);
    z-index: 999;
}

.visible {
    display: block;
    /* Visible cuando se activa */
    opacity: 1;
    transform: translateY(0);
    /* Posición original */
}

.nav-mobile {
    z-index: 9999;
    border-top-right-radius: 2rem;
    border-bottom-right-radius: 2rem;
    padding: 1rem;
    background: var(--primary);
    left: 0px;
    top: 0px;
    width: 80%;
    transition: width 0.5s ease;
    height: 100%;
    overflow: hidden;
}

.nav-mobile h6 {
    font-family: 'Poppins-SemiBold';
}

.nav-mobile .top .fa {
    float: right;
    margin-top: 1rem;
    color: var(--white);
    z-index: 9999;
    cursor: pointer;
}

.nav-mobile .logo {
    width: 15rem;
    cursor: pointer;
}

.nav-mobile .navbar-nav {
    border-top: 1px solid rgb(255 242 242 / 35%);
    border-bottom: 1px solid rgb(255 242 242 / 35%);
    margin: 20px 0px;
}

.nav-mobile .navbar-nav .nav-link {
    color: var(--white);
    border-radius: 1rem;
    padding: 10px;
    margin: 2px 10px 2px 0px;
    cursor: pointer;
}

.nav-mobile .navbar-nav .nav-link.active,
.nav-mobile .navbar-nav .nav-link:hover,
.nav-mobile .navbar-nav li:hover .nav-link {
    background: rgb(255 242 242 / 35%);
}

.nav-mobile .navbar-nav .nav-link .fa {
    float: right;
    color: var(--white);
    margin-top: .4rem;
}

.nav-mobile .navbar-nav li:first-child {
    margin-top: 20px;
}

.nav-mobile .navbar-nav li:last-child {
    margin-bottom: 20px;
}

.nav-mobile .contact-us li {
    color: var(--white);
    border-radius: 1rem;
    padding: 10px;
    margin: 0px 10px 0px 0px;
    cursor: pointer;
}

.nav-mobile .contact-us li .fa {
    margin-right: 5px;
}

@media (min-width: 1024px) {
    .hidden-md {
        display: none !important;
    }
}

.section-lg-1 {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
}

.breadcrumb {
    background-color: transparent;
    font-size: 0.7rem;

}

.breadcrumb-item.active {
    color: var(--primary);
    font-weight: bold;
}

@media (max-width: 980px) {
    .hidden-sm {
        display: none !important;
    }

    .nav-item {
        list-style: none;
        display: inline-block;
        text-align: left;
        width: 100%;
        padding-right: 0px;
    }

    .navbar-expand-lg .navbar-nav .nav-link {
        padding-right: 0px;
        padding-left: 0px;
    }

    .btn-toogle {
        display: block;
    }

    .navbar-collapse-header {
        margin-left: 3rem;
    }

    .logo {
        width: 13rem;
    }

    .button-call {
        background: var(--secondary);
        color: var(--white);
        padding: 10px;
        border-radius: 1rem;
        width: 100%;
        margin: 10px 0px;
    }
}

@media (max-width: 780px) {
    .footer-bottom {
        text-align: center;
    }

    .footer-bottom p {
        padding: 0px 0px;
        text-align: center;
    }
}

@media (max-width: 498px) {
    .container {
        width: 95% !important;
        max-width: 95% !important;
    }

    .hidden-xs {
        display: none !important;
    }

    .section-header h1 {
        font-size: 2rem !important;
        margin-top: 2rem;
    }

    .section-header h1 .span {
        min-width: 7.5rem;
        height: 3rem;
        padding: 10px 30px;
        margin: 10px 0px;
        font-size: 2rem !important;
    }

    .section-header .panel {
        max-width: 100% !important;
    }

    .header-circle {
        display: none;
    }

    .appointment-area {
        padding: 5rem 2rem;
    }

    .about-list .list-wrap {
        display: block;
    }

    .about-list .list-wrap li {
        width: 100%;
        margin: 1rem 0px;
    }

    .about-img-wrap .mask-img-wrap {
        height: inherit;
        width: inherit;
        margin: 0 auto;
    }

    .about-content {
        padding-top: 4rem;
    }
}

.m-icon {
    width: 16px;
    height: 16px;
    float: left;
    margin: -1px 10px 0px 0px;
    text-align: left;
}

.m-icon img {
    width: 100%;
}

.custom-accordion .card-header {
    background-color: #fff;
    border-bottom: none;
    padding: 0;
}

.custom-accordion .btn-link {
    color: var(--secondary) !important;
    font-family: 'Poppins-SemiBold';
    text-decoration: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 1rem 1.25rem;
    font-weight: 500;
    font-size: 0.9rem;
    box-shadow: none;
    background-color: transparent;
    border: none;
    outline: none;
    transition: color 0.3s ease;
    border-radius: 4px;
}

.custom-accordion .btn-link[aria-expanded="true"] {
    background-color: var(--secondary);
    color: #fff !important;
}


.custom-accordion .toggle-icon {
    font-weight: bold;
    font-size: 1.2rem;
    user-select: none;
}

.custom-accordion .card+.card {
    margin-top: 1rem;
    border-top: 1px solid #dee2e6;
}

.custom-accordion .card {
    box-shadow: none;
    border: none !important;
}

.bg-light-area {
    background: #DCF1F4;
}

.about-img-wrap-1 {
    width: 100%;
    text-align: center;
}

.about-img-wrap-1 img {
    width: 90%;
}

.mm-t40 {
    margin-top: 40px
}

.cta-sec6 {
    padding: 5rem 6.25rem; /* 80px 100px */
    border-radius: 1.875rem; /* 30px */
    background-color: var(--secondary) !important;
    margin: 2rem 0;
}

.cta-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

@media (max-width: 991px) { /* 991px */
    .cta-content {
        display: block;
    }
}

.cta-content .cta-wrapper {
    display: flex;
    align-items: center;
    gap: 1.5625rem; /* 25px */
    border-right: 1px solid rgba(255, 255, 255, 0.15);
    padding-right: 5rem; /* 80px */
    margin-right: 5rem; /* 80px */
    min-width: 27.5rem; /* 440px */
}

@media (max-width: 1299px) { /* 1299px */
    .cta-content .cta-wrapper {
        padding-right: 2.5rem; /* 40px */
        margin-right: 2.5rem; /* 40px */
        min-width: 22.5rem; /* 360px */
    }
}

@media (max-width:991px) { /* 991px */
    .cta-content .cta-wrapper {
        border: none;
        padding: 0;
        margin: 0;
    }
}

@media (max-width: 480px) { /* 375px */
    .cta-content .cta-wrapper {
        display: block;
    }
}

.cta-content .cta-wrapper .cta-icon {
    width: 5.625rem; /* 90px */
    height: 5.625rem;
    line-height: 5.625rem;
    border-radius: 5.625rem;
    text-align: center;
    border: 1px solid rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(11px);
    transition: all 0.4s ease-in-out;
}

.cta-content .cta-wrapper .cta-icon:hover {
    background-color: var(--primary);
}

@media (max-width: 480px) { /* 375px */
    .cta-content .cta-wrapper .cta-icon {
        margin-bottom: 1.25rem; /* 20px */
    }
}

.cta-content .cta-wrapper .header-info_link {
    font-size: 1.875rem; /* 30px */
    font-weight: 600;
    color: var(--white);
    letter-spacing: -0.01875rem; /* -0.3px */
    margin-bottom: 0;
    
}

@media (max-width: 1299px) { /* 1299px */
    .cta-content .cta-wrapper .header-info_link {
        font-size: 1.5rem; /* 24px */
    }
}

.cta-content .cta-wrapper .header-info_link a {
    color: inherit;
}

.cta-content .title-area {
    margin-right: 4rem; /* 64px */
}

@media (max-width: 1299px) { /* 1299px */
    .cta-content .title-area {
        margin-right: 1.25rem; /* 20px */
    }
}

@media (max-width: 991px) { /* 991px */
    .cta-content .title-area {
        margin: 1.875rem 0 !important; /* 30px 0 */
    }
}

.cta-content .cta-group {
    min-width: 10rem; /* 160px */
    justify-content: flex-end;
    margin-left: auto;
    flex: none;
}

@media (max-width: 991px) { /* 991px */
    .cta-content .cta-group {
        justify-content: flex-start;
        margin: 0;
    }
}

@media(max-width: 480px){
    .cta-sec6 {
    padding: 5rem 3.25rem;
    }
}