/*
	Theme Name: Boostmonitor
	Theme URI:
	Description: Boostmonitor WordPress Theme
	Version: 1.0
	Author: Boostmonitor/Hector Felan
	Author URI: https://boostmonitor.com
	Tags: Boostmonitor, HTML5, CSS3

	License: MIT
	License URI: http://opensource.org/licenses/mit-license.php
*/

/*------------------------------------*\
    ROOT
\*------------------------------------*/
:root {
    --primary-color: #231f20;
    --secondary-color: #001b37;
    --tertiary-color: #caa36f;
    --tertiary-color-clear: #e8c49a;
    --quaternary-color: rgb(225, 113, 101);
    --light-background: #f7f5ee;
    --light-background-2: #f2f4f5;
    --base-color: #221624;
    --clear-color: #FFFFFF;
    --clear-color-semitransparent: rgba(255, 255, 255, 0.85);
    --secondary-color-semitransparent: rgba(0, 45, 89, 0.9);
    --secondary-color-semitransparent-2: rgba(0, 45, 89, 0.4);
    --black: #000000;
    --whatsapp-color: #FFFFFF;
    --fill-quaternary-color: var(--quaternary-color);
    --border-radius: 3px;
    --tertiary-button-gradient-color: linear-gradient(to top, var(--tertiary-color) 0%, var(--tertiary-color-clear) 100%);
    --border-color: #393435;
    --border-weight: 1px;
    --default-padding: 20px;
    --input-box-shadow: 2px 2px 0px var(--border-color);
    --font-size: 1rem;
    --featured-box-border-radius: 5px;
    --featured-box-shadow: 0px 10px 20px rgba(0, 0, 0, 0.1);
    --image-card-overlay: linear-gradient(to top, var(--quaternary-color) 25%, transparent 80%);
    --image-card-overlay-2: linear-gradient(to top, #003668 0%, transparent 100%);
    --team-member-details-background: linear-gradient(to top, #00040b 0%, var(--secondary-color) 100%);
    --quaternary-input-bg-color: rgba(255, 255, 255, 0.2);
    --template-hero-background: linear-gradient(to top, var(--secondary-color-semitransparent) 0%, var(--secondary-color) 100%);
}
/*------------------------------------*\
    MAIN
\*------------------------------------*/

/* global box-sizing */
*,
*:after,
*:before {
	-moz-box-sizing:border-box;
	box-sizing:border-box;
	-webkit-font-smoothing:antialiased;
	font-smoothing:antialiased;
	text-rendering:optimizeLegibility;
}
html {
    font-size: 100%;
}
body {
    width: 100%;
    margin: 0;
    padding: 0;
    font-family: 'Spartan', sans-serif;
    background-color: var(--clear-color);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-optical-sizing: auto;
}
.modal-open {
    overflow: hidden;
}
.modal-open-overlay {
    position: fixed;
    z-index: 12;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100vh;
    background: rgba(0, 0, 0, 0.8);
    display: none;
}
/* clear */
.clear:before,
.clear:after {
    content:' ';
    display:table;
}

.clear:after {
    clear:both;
}
.clear {
    *zoom:1;
}
img {
	max-width:100%;
	vertical-align:bottom;
}
a {
	text-decoration:none;
}
a:hover {

}
a:focus {
	outline:0;
}
a:hover,
a:active {
	outline:0;
}
input:focus {
	outline:0;
	border:1px solid #04A4CC;
}

/*------------------------------------*\
    STRUCTURE
\*------------------------------------*/

/* wrapper */
.wrapper {
	width:100%;
	position: relative;
}
/* top header bar */
.top-header-bar {
    position: sticky !important;
    top: 0;
    z-index: 12;
    display: block;
    width: 100%;
    height: 40px;
    background: var(--secondary-color);
    border-bottom: 1px solid var(--border-color)
}
.top-header-bar-right {
    width: 100%;
    line-height: 1;
}
.top-header-bar-left {
    line-height: 1;
}
.top-header-bar-left a {
    width: 100%;
    white-space: nowrap;
    display: none;
}
.top-header-bar-option {
    font-size: calc(var(--font-size) * 0.8);
    font-weight: 500;
    line-height: 1;
    color: var(--clear-color) !important;
}
.top-header-bar-option span {
    display: none;
}
.top-header-bar-option svg {
    height: 1.5rem;
    fill: var(--tertiary-color);
}
/* header */
.header {
    position: relative;
    z-index: 11;
    width: 100%;
    height: 100px;
    display: flex;
    align-items: center;
    background-color: var(--secondary-color);
}
main {
    position: relative;
    width: 100%;
}
section {
    max-width: 1440px;
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
    margin: 0 auto;
}
section.section-narrow {
    max-width: 1100px;
}
section.section-medium {
    max-width: 1300px
}
/* logo */
.logo {

}
.logo-img {
    width: auto;
    height: 60px;
    object-fit: contain;
}
/* nav */
.nav ul li:not(.nav-whatsapp-button) {
    display: none;
}
.nav ul {
    padding: 0;
    margin: 0;
    display: flex;
    gap: 0 30px;
    align-items: center;
    list-style: none;
}
.nav ul li {
    line-height: 1;
}
.nav ul li a {
    display: block;
    font-size: calc(var(--font-size) * 0.9);
    font-weight: 600;
    letter-spacing: 0.5px;
    color: var(--clear-color);
    line-height: 1;
}
.nav ul li:not(.nav-whatsapp-button) a {
    text-transform: uppercase;
}
/* mobile */
.mobile-menu-button-wrapper {
    display: block;
}
.mobile-menu-button-wrapper .mobile-menu-button-text {
    position: relative;
    top: 2px;
    font-size: var(--font-size);
    color: var(--clear-color);
    line-height: 1;
}
.mobile-menu-button {
    position: relative;
    width: 25px;
    height: 15px;
    cursor: pointer;
}
.mobile-menu-button > * {
    width: 100%;
    height: 1.5px;
    background-color: var(--tertiary-color);
    opacity: 1;
    transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.mobile-menu-button > *:nth-child(1) {
    position: absolute;
    top: 0;
    left: 0;
}
.mobile-menu-button > *:nth-child(2) {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}
.mobile-menu-button > *:nth-child(3) {
    position: absolute;
    bottom: 0;
    right: 0;
}
.mobile-menu-container {
    position: fixed;
    z-index: 13;
    top: 40px;
    left: -100%;
    width: 100%;
    height: calc(100vh - 40px);
    background: var(--clear-color);
    padding: var(--default-padding);
    transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.mobile-menu-container.active {
    left: 0%;
}
.mobile-menu-button.active span:nth-child(1) {
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
}
.mobile-menu-button.active span:nth-child(2) {
    opacity: 0;
}
.mobile-menu-button.active span:nth-child(3) {
    bottom: 50%;
    transform: translateY(50%) rotate(-45deg);
}
.mobile-menu-nav ul {
    display: flex;
    gap: 5px 0;
    flex-direction: column;
    padding: 0;
    margin-top: 20px;
    list-style: none;
}
.mobile-menu-nav ul li {
    display: block;
}
.mobile-menu-nav ul a {
    font-size: calc(var(--font-size) * 1.2);
    font-weight: 600;
}
.mobile-menu-nav .nav-whatsapp-button {
    display: none;
}
.mobile-menu-nav .current-menu-item .button-list {
    border: 1px solid var(--tertiary-color);
    background: rgba(202, 163, 111, 0.1);
}
/* footer */
.footer {
    display: block;
    background-color: var(--secondary-color);
}
.footer-logo {
    height: 60px;
    width: auto;
    object-fit: contain;
    opacity: 0.5;
}
.footer p,
.footer span,
.footer-page-links a {
    opacity: 0.5;
}
.footer-list-menu ul {
    padding: 0;
    margin: 0;
}
.footer-list-menu ul li::marker {
    color: var(--clear-color);
}
.footer-list-menu ul li {
    display: list-item;
    list-style: square;
    opacity: 0.5;
    transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    font-size: calc(var(--font-size) * 0.9);
    padding: 4px 0;
    line-height: calc(var(--font-size) * 1.5) !important;
}
.footer-list-menu ul li:hover {
    opacity: 1;
}
.footer-list-menu ul li a {
    font-weight: 500;
    color: var(--clear-color);
}
.footer-list-menu .nav-whatsapp-button {
    display: none !important;
}
.footer-list-menu h4 {
    opacity: 0.5;
    border-bottom: 1px solid var(--border-color);
    margin-top: 0;
    padding-bottom: 20px;
}
.footer-menu-list-icon ul li a img,
.footer-menu-list-icon ul li a svg {
    height: calc(var(--font-size) * 1.1);
    width: auto;
    object-fit: contain;
    fill: var(--clear-color);
}
.footer-view-all-button {
    color: var(--quaternary-color) !important;
}
.copyright {
    padding: 10px 0 !important;

}
.copyright > * {
    line-height: calc(var(--font-size) * 2);
}
.footer-boostmonitor-logo {

}
.footer-boostmonitor-logo svg,
.footer-boostmonitor-logo img {
    height: 22px;
    width: auto;
    object-fit: contain;
    opacity: 0.5;
    transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.footer-boostmonitor-logo svg:hover,
.footer-boostmonitor-logo img:hover {
    opacity: 1;
}
.footer-page-links a {
    color: var(--quaternary-color);
    font-size: calc(var(--font-size) * 0.9);
    transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    line-height: calc(var(--font-size) * 1.5) !important;
}
.footer-page-links a:hover {
    opacity: 1;
}
/*------------------------------------*\
    HOME PAGE
\*------------------------------------*/
.hero {
    position: relative;
    background: var(--secondary-color);
}
.hero::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    opacity: 0.06;
}
.hero-wrapper > section {
    position: relative;
    z-index: 1;
    padding-bottom: 80px;
}
.hero-wrapper {
    max-width: 1440px;
    width: 100%;
    min-height: 650px;
    margin: 0 auto;
}
.hero-featured-img {
    display: none;
    position: absolute;
    z-index: 1;
    right: 0;
    bottom: 0;
    max-width: 600px;
    width: 100%;
    height: auto;
    object-fit: contain;
}

/**
--------------
FEATURED BOXES
--------------
 */
.home-featured-boxes {
    position: relative;
    z-index: 1;
    margin-top: -70px;
}
.featured-box {
    background-color: var(--clear-color);
    border-radius: var(--border-radius);
    padding: calc(var(--default-padding) * 1.5);
    position: relative;
    height: 100%;
    box-shadow: var(--featured-box-shadow);
}
.featured-box-icon svg {
    height: calc(var(--font-size) * 2.7);
    width: auto;
    object-fit: contain;
}
.featured-box-content {
    display: flex;
    flex-direction: column;
    gap: 5px 0;
}
.featured-box-pretitle {
    display: block;
    font-size: calc(var(--font-size) * 1.1);
    font-weight: 600;
}
.featured-box-title {
    display: block;
    font-size: calc(var(--font-size) * 1.2);
    font-weight: 500;
}

/**
-------------
HOME ABOUT US
-------------
 */
.home-about-us > .bm.row {
    margin-left: -10px;
    margin-right: -10px;
}
.home-about-us > .bm-row > * {
    padding: 10px;
}
.home-about-us-wreath svg {
    width: 130px;
    height: auto;
    object-fit: contain;
    flex-shrink: 0;
}

/**
-------------
HOME FEATURES
-------------
 */
.home-main-features {
    padding-top: 0 !important;
}
.home-features-img {
    width: 100%;
    min-height: 550px;
    height: 100%;
    background-image: url('img/features.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: calc(var(--border-radius) * 2);
    overflow: hidden;
}
.home-features-img-container {
    width: 100px;
    height: 100px;
    padding: var(--default-padding);
    background-color: var(--clear-color);
    border-radius: var(--border-radius);
}
.home-features-img-container svg {
    height: calc(var(--font-size) * 3.5);
    width: auto;
    object-fit: contain;
    fill: var(--quaternary-color);
}
.home-features-content h4 {
    margin-top: 0;
}

/**
-------------
HOME SERVICES
-------------
 */
.home-services {
    overflow: hidden;
}
.home-services .bm-row > *:last-child {
    min-height: 800px;
}
.image-card-default-wrapper {
    border-radius: calc(var(--border-radius) * 2);
    overflow: hidden;
}
.home-service-cat-list {
    margin-top: 40px;
    padding: 0;
}
.home-service-cat-list li {
    cursor: pointer;
    padding: calc(var(--default-padding) / 3) var(--default-padding);
    border-radius: calc(var(--border-radius) * 2);
    border: 1px solid transparent;
}
.home-service-cat-list li.active {
    border: 1px solid var(--border-color);
    background-color: rgba(225, 113, 101, 0.09);
}
.home-service-cat-list li .fa-loader {
    display: none;
    position: absolute;
    top: 20px;
    right: 20px;
    color: var(--clear-color);
    opacity: 0.1;
}
.home-cat-list-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background: var(--clear-color);
    border-radius: var(--border-radius);
    padding: calc(var(--default-padding) / 1.5);
}
.home-cat-list-icon svg,
.home-cat-list-icon img {
    position: relative;
    z-index: 2;
    opacity: 1;
    fill: var(--quaternary-color);
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.category-service-list a,
.archive-category-service-card a,
.image-card-default-wrapper a {
    pointer-events: none !important;
}
.image-card-default > img {
    position: relative;
    width: 100%;
    height: 400px;
    object-fit: cover;
    object-position: center top;
    border-radius: calc(var(--border-radius) * 2);
    transition: 1s cubic-bezier(0.4, 0, 0.2, 1);
}
.image-card-content {
    position: relative;
    margin-top: -10px;
    width: 100%;
    padding: calc(var(--default-padding) / 2) var(--default-padding);
    background: var(--quaternary-color);
    backdrop-filter: blur(4px);
}
.image-card-icon {
    position: absolute;
    z-index: 2;
    top: calc(var(--default-padding) * -1 - 30px);
    left: var(--default-padding);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background-color: var(--secondary-color);
    border-radius: var(--border-radius);
    padding: calc(var(--default-padding) / 1.5);
    border: 1px solid var(--quaternary-color);
    transition: 1s cubic-bezier(0.4, 0, 0.2, 1);
}
.image-card-icon > svg {
    fill: var(--quaternary-color);
    transition: 1s cubic-bezier(0.4, 0, 0.2, 1);
}
.home-services-carousel .owl-item img {
    transform: scale(1);
    transition: 1.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.home-services-carousel .owl-item.active img {
    transform: scale(1.2) rotate(2deg) !important;
}
.home-services-carousel a {
    pointer-events: all
}
.image-card-default:hover .image-card-icon {
    border-color: var(--clear-color);
    background-color: var(--clear-color);
}
.image-card-default:hover .image-card-icon > svg {
    fill: var(--quaternary-color);
}
.category-icon svg {
    width: 40px;
    height: auto;
    object-fit: contain;
}

/*------------------------------------*\
    TEAM MEMBERS
\*------------------------------------*/
.team-member {
    position: relative;
    border-radius: calc(var(--border-radius) * 2);
    overflow: hidden;
}
.team-members::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url('img/background-images/mexico-map.svg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0.1;
}
.team-members > section {
    position: relative;
    z-index: 1;
}
.team-member-photo {
    width: 100%;
    height: 400px;
    object-fit: cover;
    object-position: center top;
}
.team-member-details {
    position: relative;
    display: block;
    padding: calc(var(--default-padding) * 1.2);
    background: var(--team-member-details-background);
}
.team-member-details > * {
    margin: 0;
    margin-bottom: 0.5rem;
}
.member-social-links {
    padding: 0;
    margin-top: 20px;
}
.member-social-links a {
    font-size: calc(var(--font-size) * 1.3);
    color: var(--clear-color);
}
.member-social-links a:hover {
    color: var(--quaternary-color)
}

/*------------------------------------*\
   CONTACT SECTION
\*------------------------------------*/
.blog-card-single {
    position: relative;
    border-radius: calc(var(--border-radius) * 2);
    overflow: hidden;
}
.blog-card-single img {
    width: 100%;
    height: 400px;
    object-fit: cover;
    object-position: center;
}
.blog-card-details {
    position: relative;
    padding: var(--default-padding);
    background-color: var(--secondary-color);
}
.blog-card-category {
    font-weight: 600;
    pointer-events: all
}
.blog-card-excerpt {
    line-height: calc(var(--font-size) * 1.3);
}
.blog-card-read-more-button {
    display: flex;
    align-items: center;
    margin-top: 20px;
    color: var(--tertiary-color);
    font-weight: 600;
    font-size: calc(var(--font-size) * 0.9);
}
.contact-section {
    position: relative;
    z-index: 1;
}
/*------------------------------------*\
    LATEST POSTS
\*------------------------------------*/
.latest-posts {
    position: relative;
    z-index: 0;
}

/*------------------------------------*\
    ABOUT US PAGE
\*------------------------------------*/
.template-hero-section {
    position: relative;
    background-size: cover;
    background-position: 50% 30%;
    padding-top: 50px;
    padding-bottom: 50px;
}
.template-hero-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    background: var(--secondary-color-semitransparent);
}
.template-hero-section > section {
    position: relative;
    z-index: 1 !important;
}
.template-hero-section h1 {
    margin-bottom: 20px;
}
.about-history-messenger {
    position: relative;
    display: block;
    padding: var(--default-padding);
    border-radius: var(--border-radius);
}
.about-history-messenger::after {
    content: '\f10e';
    font-family: 'Sharp Icons Solid', sans-serif;
    position: absolute;
    z-index: 0;
    bottom: -10px;
    right: 20px;
    font-size: calc(var(--font-size) * 10);
    opacity: 0.05;
    color: var(--quaternary-color);
}
.about-history-messenger p {
    position: relative;
    z-index: 1;
}

/*
ABOUT - MISION, VISION AND VALUES
 */
.mvv-card {
    position: relative;
    padding: var(--default-padding);
    border-radius: var(--border-radius);
    background-color: var(--clear-color);
    height: 100%;
    box-shadow: 0 20px 20px -10px rgba(0, 0, 0, 0.1);
}
.mvv-card-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    padding: calc(var(--default-padding) / 2);
    background-color: var(--light-background);
    border-radius: var(--border-radius);
}
.mvv-card-icon svg,
.mvv-card-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.mvv-card-content {
    margin-top: var(--default-padding);
}
.value-card {
    position: relative;
    padding: var(--default-padding);
    border-radius: var(--border-radius);
    background-color: var(--light-background);
    height: 100%;
}

/*
ABOUT SERVICES
 */
.category-service-column {
    position: relative;
    padding: var(--default-padding);
    border-radius: calc(var(--border-radius) * 2);
    background-color: var(--clear-color);
    box-shadow: 0 20px 20px -10px rgba(0, 0, 0, 0.1);
}
.category-service-icon svg,
.category-service-icon img {
    flex-shrink: 0;
    height: 30px;
    width: auto;
    object-fit: contain;
}
.category-service-list {
    padding: 0 0 0 0px;
    margin-top: 40px;
    display: flex;
    flex-direction: column;
    gap: 20px 0;
    list-style: none;
}
.category-service-list li a {
    pointer-events: all
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0 20px;
    color: var(--primary-color);
    font-size: calc(var(--font-size) * 1.15);
    font-weight: 500;
    transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.category-service-list li a svg,
.category-service-list li a img {
    flex-shrink: 0;
    height: auto;
    width: 25px;
    object-fit: contain;
    fill: var(--quaternary-color);
    transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.category-service-list li a:hover {
    color: var(--quaternary-color);
    opacity: 1;
}
.category-service-list li a:hover svg {
    fill: var(--quaternary-color);
    opacity: 1;
}

/*
ABOUT CONTACT SECTION
 */
.about-contact-section {
    padding-top: 0;
    padding-bottom: 50px;
}
.about-contact-featured-img {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center;
}

/*------------------------------------*\
    SERVICES
\*------------------------------------*/
.content-with-sidebar {
    display: flex;
    align-items: flex-start;
    flex-direction: row;
    gap: 40px;
    flex-wrap: wrap;
    position: relative;
    margin-top: calc(var(--default-padding) * 2);
    margin-bottom: calc(var(--default-padding) * 2);
}
.content-sidebar {
    position: relative;
    display: block;
    width: 100%;
    min-height: 300px;
    background-color: var(--clear-color);
}
.sidebar {
    display: block;
    flex-shrink: 0;
    max-width: 500px;
    width: 100%;
    border-radius: none;
    background-color: var(--clear-color);
    position: relative;
    top: 0;
    height: auto;
    padding: 0;
}
.content-sidebar .archive-category-header {
    margin-top: 50px;
}
.content-sidebar .archive-category-header:first-of-type {
    margin-top: 0;
    padding-top: 0;
}
.archive-pretitle {
    display: block;
    font-weight: 500;
    font-size: calc(var(--font-size) * 1.2);
}
.archive-category-service-card {
    position: relative;
    border-radius: var(--border-radius);
    overflow: hidden;
    background-color: var(--quaternary-color);
    height: 100%;
}
.archive-category-service-card a {
    pointer-events: all
}
.archive-category-service-card-img {
    position: relative;
    width: 100%;
    overflow: hidden;
}
.archive-category-service-card-img img {
    width: 100%;
    height: 300px;
    object-fit: cover;
    object-position: center top;
    transition: 1s cubic-bezier(0.4, 0, 0.2, 1);
}
.archive-category-service-card:hover .archive-category-service-card-img img {
    transform: scale(1.2) rotate(2deg);
}
.archive-category-service-card-details {
    position: relative;
    width: 100%;
    padding: var(--default-padding) var(--default-padding) 10px var(--default-padding);
}
.archive-category-service-card-icon {
    position: absolute;
    top: -45px;
    left: var(--default-padding);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    padding: calc(var(--default-padding) / 2);
    background-color: var(--clear-color);
    fill: var(--quaternary-color);
    border-radius: var(--border-radius);
    border: 2px solid var(--quaternary-color);
}


/*------------------------------------*\
    BLOG PAGE
\*------------------------------------*/
.blog-article-card {
    position: relative;
    height: 100%;
    background-color: var(--secondary-color);
    border-radius: var(--border-radius);
    overflow: hidden;
}
.blog-article-card-image {
    position: relative;
}
.blog-article-card-image img {
    width: 100%;
    height: 400px;
    object-fit: cover;
    object-position: center;
}
.blog-article-card-date {
    position: absolute;
    z-index: 2;
    top: 0;
    right: 20px;
    width: 70px;
    height: 100px;
    padding: calc(var(--default-padding) / 2) calc(var(--default-padding) / 2) var(--default-padding);
    background-color: var(--clear-color);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 50% 90%, 0 100%);
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 50% 90%, 0 100%);
}
.blog-article-card-date-day {
    display: block;
    font-size: calc(var(--font-size) * 2);
    line-height: calc(var(--font-size) * 2);
    font-weight: 900;
}
.blog-article-card-date-month {
    display: block;
    font-size: calc(var(--font-size) * 1.3);
    line-height: calc(var(--font-size) * 1.3);
    text-transform: uppercase;
    font-weight: 900;
}
.blog-article-card-date-year {
    display: block;
    font-size: calc(var(--font-size) * 1.1);
    font-weight: 900;
    line-height: calc(var(--font-size) * 1.1);
}
.blog-article-card-meta {
    position: relative;
    padding: calc(var(--default-padding) / 3) var(--default-padding) var(--default-padding);
}
.blog-page-hero {
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
}
.blog-page-hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to top, var(--secondary-color-semitransparent-2) 0%, var(--secondary-color) 100%);
    z-index: 0;
}
.blog-page-hero > section {
    position: relative;
    z-index: 1;
}
.blog-page-hero-content {
    max-width: 700px;
}
.blog-page-hero-description p {
    font-size: calc(var(--font-size) * 1.2);
    line-height: calc(var(--font-size) * 1.9);
    font-weight: 500;
    color: var(--clear-color);
}

/*------------------------------------*\
    CONTACT PAGE
\*------------------------------------*/
.contact-hero {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.contact-hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to top, var(--secondary-color-semitransparent) 0%, var(--secondary-color) 100%);
    z-index: 0;
}
.contact-hero > section {
    position: relative;
    z-index: 1;
}
.contact-page-channels {
    background-color: var(--light-background);
}
.contact-channel-icon {
    flex-shrink: 0;
    width: 60px;
    height: 60px;
    background-color: var(--clear-color);
    padding: calc(var(--default-padding) / 2);
    border-radius: var(--border-radius);
}
.contact-channel-details small {
    font-weight: 500;
    color: var(--primary-color);
}

/*------------------------------------*\
    SINGLE POST PAGE
\*------------------------------------*/
.single-post-hero {
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
}
.single-post-hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to top, var(--secondary-color-semitransparent-2) 0%, var(--secondary-color) 100%);
    z-index: 0;
}
.single-post-hero > section {
    position: relative;
    z-index: 1;
}
.single-post-hero-content {
    max-width: 700px;
}
.single-post-heading-1 {
    font-size: calc(var(--font-size) * 2);
    text-transform: uppercase;
}
.single-post-hero-content p {
    font-size: calc(var(--font-size) * 1.2);
    line-height: calc(var(--font-size) * 1.9);
    font-weight: 500;
    color: var(--clear-color);
}
.single-the-content .content-sidebar {
    font-size: 102%;
}
.single-post-meta {
    padding: var(--default-padding);
    background-color: var(--light-background-2);
    border-radius: var(--border-radius);
}
/*------------------------------------*\
    IMAGES
\*------------------------------------*/



/*------------------------------------*\
	TYPOGRAPHY
\*------------------------------------*/

@font-face {
	font-family:'Spartan';
	src:url('fonts/Spartan/spartan/Spartan[wght].ttf');
}

@font-face {
	font-family:'Roboto-Slab';
	src:url('fonts/Roboto_Slab/RobotoSlab-VariableFont_wght.ttf');
}

@font-face {
	font-family:'Brand Icons';
	src:url('../../assets/fontawesome-pro-6.5.1-web/webfonts/fa-brands-400.ttf');
}

@font-face {
	font-family:'Sharp Icons Regular';
	src:url('../../assets/fontawesome-pro-6.5.1-web/webfonts/fa-sharp-regular-400.ttf');
}

@font-face {
	font-family:'Sharp Icons Solid';
	src:url('../../assets/fontawesome-pro-6.5.1-web/webfonts/fa-sharp-solid-900.ttf');
}

.hero-pretitle,
.hero-heading-1,
.hero-heading-2,
.featured-box-pretitle,
.featured-box-title,
.pretitle,
.blog-card-category,
.category-service-list li a,
.archive-pretitle,
.widget-latest-articles-item p,
h1, h2, h3, h4, h5, h6,
.blog-article-card-date-day,
.blog-article-card-date-month,
.blog-article-card-date-year,
.pagination-links > * {
    font-family: 'Roboto-Slab', sans-serif;
}
input,
textarea,
.button,
.hero-button-default {
    font-family: 'Spartan', sans-serif;
}

/*------------------------------------*\
    BUTTONS
\*------------------------------------*/
.button {
    display: flex;
    align-items: center;
    cursor: pointer;
    letter-spacing: -0.5px !important;
    transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    font-weight: 600;
}
button.icon {
    font-size: 1.8rem
}
.button-default {
    display: flex;
    align-items: center;
    width: fit-content;
    padding: 15px 15px;
    background-color: var(--quaternary-color);
    border-radius: var(--border-radius);
    color: var(--clear-color);
    font-size: calc(var(--font-size) * 0.9);
    font-weight: 600;
    overflow: hidden;
}
.button-default:hover {
    background-color: var(--secondary-color);
}
.button-secondary {
    display: flex;
    align-items: center;
    height: fit-content;
    width: fit-content;
    padding: 15px 15px;
    background-color: transparent;
    border: 1px solid var(--secondary-color);
    border-radius: var(--border-radius);
    color: var(--secondary-color);
    font-size: calc(var(--font-size) * 0.9);
    font-weight: 600;
    overflow: hidden;
}
.button-secondary:hover {
    background-color: var(--secondary-color);
    color: var(--clear-color);
}
.button-clear {
    display: flex;
    align-items: center;
    width: fit-content;
    padding: 15px 15px;
    background-color: var(--clear-color);
    border-radius: var(--border-radius);
    color: var(--quaternary-color);
    border: none;
    outline: none;
    font-size: calc(var(--font-size) * 0.9);
    font-weight: 00;
    overflow: hidden;
}
.button-quaternary {
    display: flex;
    align-items: center;
    height: fit-content;
    width: fit-content;
    padding: 15px 15px;
    background-color: transparent;
    border: 1px solid var(--quaternary-color);
    border-radius: var(--border-radius);
    color: var(--quaternary-color);
    font-size: calc(var(--font-size) * 0.9);
    font-weight: 600;
    overflow: hidden;
}
.button-quaternary:hover {
    background-color: var(--quaternary-color);
    color: var(--clear-color);
}
.button-pagination {
    display: flex;
    align-items: center;
    width: fit-content;
    padding: 15px 15px;
    background-color: var(--light-background-2);
    border-radius: var(--border-radius);
    color: var(--primary-color);
    border: none;
    outline: none;
    font-size: calc(var(--font-size) * 0.9);
    font-weight: 00;
    overflow: hidden;
}
.prev.page-numbers i {
    margin-right: 8px;
}
.next.page-numbers i {
    margin-left: 8px;
}
.page-numbers.current {
    background-color: var(--quaternary-color);
    color: var(--clear-color);
}

/* NAV WHATSAPP BUTTON */
.nav-whatsapp-button {
    padding: 10px 10px;
    border-radius: var(--border-radius);
    background: var(--tertiary-button-gradient-color);
    position: relative;
    overflow: hidden;
}
.nav-whatsapp-button::before {
    content: '';
    position: absolute;
    z-index: 1;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(-45deg, transparent 25%, rgba(255, 255, 255, 1) 50%, transparent 75%);
    transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.nav-whatsapp-button:hover::before {
    left: 100%;
}
.nav-whatsapp-button a {
    display: flex !important;
    align-items: center !important;
    gap: 0 6px;
    color: var(--primary-color) !important;
}
.nav-whatsapp-button a .menu-item-description {
    display: block;
    font-size: calc(var(--font-size) * 0.7);
}
.nav-whatsapp-button a .menu-item-title {
    display: block;
    margin-top: 3px;
    font-size: calc(var(--font-size) * 0.9);
}
.nav-whatsapp-button a::before {
    content: '\f232';
    font-family: 'Brand Icons';
    font-size: calc(var(--font-size) * 1.9);
    color: var(--primary-color);
}

/* HERO BUTTONS */
.hero-button-default {
    display: inline-block;
    position: relative;
    padding: 20px 20px;
    background: var(--tertiary-button-gradient-color);
    border-radius: var(--border-radius);
    color: var(--primary-color);
    border: none;
    font-size: calc(var(--font-size) * 0.85);
    font-weight: 700;
    margin-top: 40px;
    overflow: hidden;
    text-transform: uppercase
}
.hero-button-default::after {
    content: '';
    position: absolute;
    z-index: 1;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(-45deg, transparent 25%, rgba(255, 255, 255, 1) 50%, transparent 75%);
    transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.hero-button-default:hover::after {
    left: 100%;
}

/**
--------------------
BUTTON HTML ELEMENTS
--------------------
 */
.button-list {
    display: flex;
    align-items: center;
    width: 100%;
    height: 50px;
    padding: 0 var(--default-padding);
    border: 1px solid transparent;
    outline: none;
    border-radius: var(--border-radius);
    font-size: var(--font-size);
    color: var(--secondary-color);
    transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.button-list:hover {
    border: 1px solid var(--tertiary-color);
    background: rgba(202, 163, 111, 0.1);
}

/**
------------
BUTTON ICONS
------------
*/
.button-phone-left::before {
    content: '\f2a0';
    font-size: calc(var(--font-size) * 1.4);
    font-family: 'Sharp Icons Solid', sans-serif;
    margin-right: 8px;
}
.button-arrow-right::after {
    content: '\e09f';
    font-size: calc(var(--font-size) * 1.2);
    font-family: 'Sharp Icons Regular', sans-serif;
    margin-left: 8px;
}
.button-right-loading-spinner::after {
    content: '\e1d4';
    font-size: calc(var(--font-size) * 1.2);
    font-family: 'Sharp Icons Regular', sans-serif;
    margin-left: 8px;
    animation: 1.5s loading-spinner linear infinite;
}
@keyframes loading-spinner {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}
.link-arrow-right::after {
    content: '\e09f';
    font-family: 'Sharp Icons Regular', sans-serif;
    margin-left: 8px;
}

/*------------------------------------*\
    COMPONENTS
\*------------------------------------*/
.relative {
    position: relative;
}
.block {
    display: block;
}
.transitioned {
    transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.padding-default {
    padding: var(--default-padding);
}
.border-right {
    border-right: 1px solid;
}
.border-md-left {
    border: none;
}
.border-t-default {
    border-top: 1px solid var(--border-color);
}
.border-b-default {
    border-bottom: 1px solid var(--border-color);
}
.border-color-quaternary {
    border-color: var(--quaternary-color) !important;
}
.pad-def-2 {
    padding: var(--default-padding);
}
.pad-t-md {
    padding-top: 35px;
}
.pad-t-sm {
    padding-top: 10px;
}
.pad-b-sm {
    padding-bottom: 10px;
}
.pad-b-md {
    padding-bottom: 35px;
}
.pad-t-big {
    padding-top: 50px;
}
.pad-b-big {
    padding-bottom: 50px;
}
.pad-t-large {
    padding-top: 100px;
}
.pad-b-large {
    padding-bottom: 100px;
}
.m-t-0 {
    margin-top: 0;
}
.m-t-5 {
    margin-top: 5px;
}
.m-t-10 {
    margin-top: 10px;
}
.m-t-20 {
    margin-top: 20px;
}
.m-t-30 {
    margin-top: 30px;
}
.m-t-40 {
    margin-top: 40px;
}
.m-b-0 {
    margin-bottom: 0;
}
.m-b-5 {
    margin-bottom: 5px;
}
.m-b-10 {
    margin-bottom: 10px;
}
.m-b-20 {
    margin-bottom: 20px;
}
.m-b-30 {
    margin-bottom: 30px;
}
.m-b-40 {
    margin-bottom: 40px;
}
.clear-background-color {
    background-color: var(--clear-color);
}
.light-background-color {
    background-color: var(--light-background);
}
.light-background-color-2 {
    background-color: var(--light-background-2);
}
.secondary-background-color {
    background-color: var(--secondary-color);
}
.max-width-500 {
    max-width: 500px;
}
.max-width-600 {
    max-width: 600px;
}
.h-scroll {
    overflow-x: scroll;
    overflow-y: hidden;
}
.f-w-300 {
    width: 300px;
}
.f-w-350 {
    width: 350px;
}
.f-w-500 {
    width: 500px;
}
.f-w-550 {
    width: 550px;
}
.f-w-600 {
    width: 600px;
}
.w-full {
    width: 100%;
}
.h-full {
    height: 100%;
}
.no-list-style {
    list-style: none;
}
.no-resize {
    resize: none
}
.element-icon svg,
.element-icon img {
    width: 80px;
    height: 80px;
    padding: calc(var(--default-padding) * 0.8);
    object-fit: contain;
    background-color: var(--clear-color);
    border-radius: var(--border-radius);
}
.v-divider > * {
    padding: 0 20px;
    margin: 0;
    border-right: 1px solid var(--border-color);
}
.v-divider > *:last-of-type {
    border-right: none;
}
.bm-breadcrumbs > ul {
    padding: 0;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 0 10px;
    list-style: none;
}
.bm-breadcrumbs > ul i {
    font-size: 10px;
    color: var(--tertiary-color);
}
.bm-breadcrumbs > ul li,
.bm-breadcrumbs > ul li a {
    font-weight: 500;
    color: var(--clear-color);
    transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.bm-breadcrumbs > ul li a:hover {
    color: var(--tertiary-color);
}
.font-w-500 {
    font-weight: 500;
}
.scroll-y {
    overflow-y: scroll;
}
.text-capitalize {
    text-transform: capitalize;
}

/*------------------------------------*\
    WIDGETS
\*------------------------------------*/
.sidebar-widget {
    display: block;
    margin: var(--default-padding) 0;
}
.newsletter-subscription-widget-image-container {
    position: relative;
}
.newsletter-subscription-widget-image {
    width: 100%;
    height: 550px;
    object-fit: cover;
    object-position: center;
    border-radius: var(--border-radius);
    overflow: hidden;
}
.newsletter-subscription-widget-image-container::after {
    content: '';
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--secondary-color-semitransparent);
}
.newsletter-subscription-widget-details {
    position: absolute;
    z-index: 2;
    padding: var(--default-padding);
    bottom: 0;
    left: 0;
}
.newsletter-subscription-widget-logo {
    height: 70px;
    width: auto;
    object-fit: contain;
    position: relative;
    margin-bottom: 20px;
}
.newsletter-subscription-widget .input-error-message {
    color: var(--quaternary-color);
    font-size: calc(var(--font-size) * 0.8);
    font-weight: 500;
}

/* LATEST BLOG ARTICLES SIDEBAR WIDGET */
.widget-latest-articles {
    display: block;
    position: relative;
    background-color: var(--clear-color);
    border-radius: var(--border-radius);
    padding: var(--default-padding);
}
.widget-latest-articles-list {
    display: flex;
    flex-direction: column;
    gap: 20px 0;
    list-style: none;
    padding: 0;
}
.widget-latest-articles-item img {
    width: 60px;
    height: 60px;
    object-fit: cover;
    object-position: center;
    overflow: hidden;
    border-radius: var(--border-radius);
    flex-shrink: 0;
}
.widget-latest-articles-item p {
    font-size: calc(var(--font-size) * 1);
    line-height: calc(var(--font-size) * 1.3);
    font-weight: 500;
    margin: 0;
    transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.widget-latest-articles-item a:hover p {
    color: var(--quaternary-color);
}

/*------------------------------------*\
    VIDEO COMPONENTS
\*------------------------------------*/
.video-play-button {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: calc(var(--font-size) * 5);
    color: var(--clear-color);
    z-index: 4;
    cursor: pointer;
}
.video-play-button::before {
    content: '';
    position: absolute;
    z-index: -1;
    top: calc(50% - 6px);
    left: 50%;
    width: 50px;
    height: 50px;
    transform: translate(-50%, -50%);
    background-color: var(--quaternary-color);
    border-radius: 50%;
}
.video-play-button::after {
    content: '';
    position: absolute;
    z-index: -2;
    top: calc(50% - 6px);
    left: 50%;
    transform: translate(-50%, -50%);
    background-color: var(--clear-color);
    border-radius: 50%;
    animation: video-button-animation 1.3s infinite;
}
@keyframes video-button-animation {
    0% {
        width: 50px;
        height: 50px;
        opacity: 1;
    }
    80% {
        width: 150px;
        height: 150px;
        opacity: 0;
    }
    85% {
        width: 150px;
        height: 150px;
        opacity: 0;
    }
    100% {
        width: 50px;
        height: 50px;
        opacity: 0;
    }
}
.youtube-video-modal {
    display: none;
    position: fixed;
    z-index: 11;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(35, 31, 32, 0.95);
}
.modal-content {
    position: relative;
    max-width: 900px;
    width: 100%;
    margin: 0 auto;
    opacity: 0;
    transform: translateY(20px);
    transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.modal-content.active {
    opacity: 1;
    transform: translateY(0);
}
.close-modal {
    display: none;
    position: absolute;
    z-index: 3;
    right: 0;
    top: -40px;
    color: var(--clear-color);
    font-size: calc(var(--font-size) * 2);
    cursor: pointer
}
.video-wrapper {
    position: relative;
    padding-bottom: 56.25%; /* 16:9 aspect ratio */
    height: 0;
    overflow: hidden;
    border-radius: calc(var(--border-radius) * 2);
    box-shadow: 0px 40px 40px -20px rgba(0, 0, 0, 0.5);
}
.video-wrapper iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/*------------------------------------*\
    FORMS AND FIELDS
\*------------------------------------*/
.field-group {
    display: block;
    margin-top: 15px;
    margin-bottom: 15px;
    position: relative;
}
input:not([type="checkbox"]) {
    display: block;
    width: 100%;
    height: 50px;
    padding: 0 15px;
    border: var(--border-weight) solid var(--primary-color);
    outline: none;
    border-radius: var(--border-radius);
    font-size: var(--font-size);
    color: var(--primary-color);
    flex: 0;
    position: relative;
}
input:focus,
input:active {
    border: var(--border-weight) solid var(--primary-color);
}
input[name='name'],
input[name='first_name'],
input[name='firstname'] {
    text-transform: capitalize;
}
.input-w-button-right {
    position: relative;
}
.input-w-button-right button {
    position: absolute;
    right: 0;
    top: 0;
    z-index: 1;
    height: 50px;
    padding: 0 var(--default-padding);
    background: transparent;
    color: var(--primary-color);
    border: none;
    border-left: var(--border-weight) solid var(--primary-color);
    border-top-right-radius: var(--border-radius);
    border-bottom-right-radius: var(--border-radius);
    outline: none;
}
.input-w-button-right input {
    padding-right: 70px;
}
textarea {
    display: block;
    width: 100%;
    padding: 15px 15px;
    border: var(--border-weight) solid var(--border-color);
    outline: none;
    border-radius: var(--border-radius);
    font-size: var(--font-size);
    color: var(--primary-color);
    position: relative;
}
.field-group.icon-right input {
    padding-right: 70px;
}
.field-group.icon-right button[type="submit"] {
    position: absolute;
    right: 0;
    top: 0;
    z-index: 1;
    height: 50px;
    padding: 0 var(--default-padding);
    font-size: calc(var(--font-size) * 1.1);
    background: transparent;
    color: var(--primary-color);
    border: none;
    border-left: var(--border-weight) solid var(--primary-color);
    border-top-right-radius: var(--border-radius);
    border-bottom-right-radius: var(--border-radius);
    outline: none;
    cursor: pointer;
}
.input-error-message {
    display: block;
    position: relative;
    margin-top: 5px;
}
/* FORM TERTIARY */
.form-tertiary {
    background-color: var(--tertiary-color);
}
.form-tertiary input {
    border: none;
    background-color: var(--quaternary-input-bg-color);
    color: var(--clear-color);
    font-weight: 600;
}
.form-tertiary input::placeholder,
.form-tertiary textarea::placeholder{
    opacity: 1;
    color: var(--clear-color) !important;
}
.form-tertiary input:focus,
.form-tertiary input:active {
    border: none;
    box-shadow: none;
    transform: none;
}
.form-tertiary textarea {
    display: block;
    width: 100%;
    padding: 15px 15px;
    border: none;
    outline: none;
    border-radius: var(--border-radius);
    font-size: var(--font-size);
    background-color: var(--quaternary-input-bg-color);
    color: var(--clear-color);
    position: relative;
}
.form-tertiary .input-error-message {
    display: none;
    position: relative;
    color: var(--clear-color);
    font-weight: 600;
    line-height: calc(var(--font-size) * 2);
}
/* FORM QUATERNARY */
.form-quaternary {
    background-color: var(--quaternary-color);
    box-shadow: 10px 10px 20px rgba(0, 0, 0, 0.2);
    border-radius: 0;
    margin-left: -20px;
    margin-right: -20px;
}
.form-quaternary input {
    border: none;
    background-color: var(--quaternary-input-bg-color);
    color: var(--clear-color);
    font-weight: 600;
}
.form-quaternary input[name='full_name'] {
    text-transform: capitalize;
}
.form-quaternary input::placeholder,
.form-quaternary textarea::placeholder {
    opacity: 1;
    color: var(--clear-color) !important;
}
.form-quaternary input:focus,
.form-quaternary input:active {
    border: none;
    box-shadow: none;
    transform: none;
}
.form-quaternary textarea {
    display: block;
    width: 100%;
    padding: 15px 15px;
    border: none;
    outline: none;
    border-radius: var(--border-radius);
    font-size: var(--font-size);
    background-color: var(--quaternary-input-bg-color);
    color: var(--clear-color);
    position: relative;
    font-weight: 600;
}
.form-quaternary .input-error-message {
    display: none;
    position: relative;
    color: var(--clear-color);
    font-weight: 600;
    line-height: calc(var(--font-size) * 2);
}
/*------------------------------------*\
    TEXTS
\*------------------------------------*/
.hero-pretitle {
    display: block;
    margin: 0;
    padding: 0;
    font-size: calc(var(--font-size) * 1);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.hero-heading-1 {
    max-width: 100%;
    font-size: calc(var(--font-size) * 2.2);
    text-transform: uppercase;
}
.hero-heading-2 {
    max-width: 100%;
    font-size: calc(var(--font-size) * 2.0);
    text-transform: uppercase;
}
.hero-description {
    max-width: 100%;
    font-size: calc(var(--font-size) * 1.1);
    font-weight: 500;
    letter-spacing: 0.5px;
    margin: 0;
    padding: 0;
}

h1 {

}
h2 {
    font-size: calc(var(--font-size) * 1.8);
    margin-top: calc(var(--font-size) / 1.2);
    margin-bottom: calc(var(--font-size) / 1.2);
    line-height: calc(var(--font-size) * 2.5);
}
h3 {
    font-size: calc(var(--font-size) * 1.5);
    margin-top: calc(var(--font-size) / 1.5);
    margin-bottom: calc(var(--font-size) / 1.5);
}
h4 {
    font-size: calc(var(--font-size) * 1.1);
    margin-top: calc(var(--font-size) / 1.2);
    margin-bottom: calc(var(--font-size) / 1.2);
}
h5 {

}
p, li {
    line-height: calc(var(--font-size) * 1.5);
}
p > small {
    line-height: calc(var(--font-size) * 1.1);
}
h3 > svg {
    height: calc(var(--font-size) * 2.2);
    width: auto;
}
.pretitle {
    font-size: calc(var(--font-size) * 1);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.underline {
    text-decoration: underline;
}

/* TEXT COLORS */
.primary-text-color {
    color: var(--primary-color);
}
.secondary-text-color {
    color: var(--secondary-color);
}
.clear-text-color {
    color: var(--clear-color);
}
.tertiary-text-color {
    color: var(--tertiary-color);
}
.quaternary-text-color {
    color: var(--quaternary-color);
}

/**
-----------
FONT STYLES
-----------
 */
.font-italic {
    font-style: italic;
}

/**
------------
FONT WEIGHTS
------------
 */
.font-regular {
    font-weight: 400;
}
.font-semibold {
    font-weight: 600;
}
.font-bold {
    font-weight: 900;
}
/**
-----------
ICON COLORS
-----------
 */
.fill-primary-color {
    color: var(--primary-color);
}
.fill-quaternary-color {
    fill: var(--quaternary-color) !important;
}
.fill-clear-color {
    fill: var(--clear-color);
}

/**
------------------
NOTIFICATION MODAL
------------------
 */
.notification-modal {
    position: fixed;
    z-index: 12;
    bottom: -150px;
    right: 20px;
    max-width: 500px;
    opacity: 0;
    width: calc(100% - 40px);
    padding: var(--default-padding);
    background-color: var(--clear-color);
    border-radius: calc(var(--border-radius) * 3);
    box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.2);
    transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.notification-modal.active {
    bottom: 20px;
    opacity: 1;
}
#notification-icon {
    font-size: 24px;
    color: var(--secondary-color);
}
#notification-text {
    font-weight: 600;
}
.notification-success {
    background-color: #e6ffd6;
}
.notification-error {
    background-color: #fabdbd;
}

/*------------------------------------*\
    RESPONSIVE
\*------------------------------------*/

@media only screen and (min-width:320px) {

}
@media only screen and (min-width:480px) {
    /* MISCELANEUS */
    .pad-t-big {
        padding-top: 70px;
    }
    .pad-b-big {
        padding-bottom: 70px;
    }
    .pad-t-large {
        padding-top: 140px;
    }
    .pad-b-large {
        padding-bottom: 140px;
    }

    /* SINGLE POST PAGE */
    .single-post-heading-1 {
        font-size: calc(var(--font-size) * 2.5);
    }
}
@media only screen and (min-width:768px) {
    html {
        font-size: 100%;
    }
    .top-header-bar,
    .header {
        position: relative !important;
        top: unset !important
    }
    .top-header-bar-left a {
        display: block;
    }
    .mobile-menu-button-wrapper {
        display: none;
    }
    .top-header-bar-option span {
        display: inline-block;
    }
    .header {
        height: 100px;
    }
    .logo-img {
        height: 70px;
    }
    .nav-whatsapp-button {
        padding: 15px 15px;
    }

    /* TEXT DEFAULTS */
    hero-pretitle {
        font-size: calc(var(--font-size) * 1.1);
    }
    .hero-heading-1 {
        max-width: 100%;
        font-size: calc(var(--font-size) * 3.8);
    }
    .hero-heading-2 {
        max-width: 100%;
        font-size: calc(var(--font-size) * 3.6);
    }
    .hero-description {
        max-width: 100%;
        font-size: var(--font-size);
    }
    h2 {
        font-size: calc(var(--font-size) * 2.3);
        margin-top: calc(var(--font-size) / 2);
        margin-bottom: calc(var(--font-size) / 2);
        line-height: calc(var(--font-size) * 3);
    }

    /*  HOME PAGE  */
    .hero::after {
        background-size: contain;
    }
    .home-about-us > .bm.row {
        margin-left: -40px;
        margin-right: -40px;
    }
    .home-about-us > .bm-row > * {
        padding: 40px;
    }
    .home-main-features {
        padding-top: 100px !important;
    }

    /* SINGLE POST PAGE */
    .single-post-heading-1 {
        font-size: calc(var(--font-size) * 2.8);
    }

    /* FEATURED BOXES */
    .featured-box-icon svg {
        height: calc(var(--font-size) * 2.5);
        width: auto;
        object-fit: contain;
    }
    .featured-box-pretitle {
        font-size: calc(var(--font-size) * 1);
    }
    .featured-box-title {
        font-size: calc(var(--font-size) * 1.1);
    }

    /* COMPONENTS */
    .pad-t-big {
        padding-top: 100px;
    }
    .pad-b-big {
        padding-bottom: 100px;
    }
    .pad-t-large {
        padding-top: 200px;
    }
    .pad-b-large {
        padding-bottom: 200px;
    }
    .border-md-left {
        border-left: 1px solid;
    }
    .pad-def-2 {
        padding: calc(var(--default-padding) * 2);
    }

}
@media only screen and (min-width:1024px) {
    .nav ul li:not(.nav-whatsapp-button) {
        display: inline-block;
    }

    /* TEXT DEFAULTS */
    .hero-pretitle {
        font-size: calc(var(--font-size) * 1.2);
    }
    .hero-heading-1 {
        max-width: 55%;
        font-size: calc(var(--font-size) * 4.1);
    }
    .hero-heading-2 {
        max-width: 55%;
        font-size: calc(var(--font-size) * 3.6);
    }
    .hero-description {
        max-width: 50%;
        font-size: calc(var(--font-size) * 1.1);
    }
    h2 {
        font-size: calc(var(--font-size) * 2.5);
        margin-top: calc(var(--font-size) * 2);
        margin-bottom: calc(var(--font-size) * 2);
        line-height: calc(var(--font-size) * 3);
    }

    /* FEATURED BOXES */
    .featured-box-icon svg {
        height: calc(var(--font-size) * 3);
        width: auto;
        object-fit: contain;
    }
    .featured-box-pretitle {
        font-size: calc(var(--font-size) * 1);
    }
    .featured-box-title {
        font-size: calc(var(--font-size) * 1.2);
    }

    /* HERO */
    .hero-wrapper {
        min-height: 800px;
    }
    .hero-featured-img {
        display: inline;
    }
    .home-services .bm-row > *:last-child {
        min-height: unset;
    }

    /*  ABOUT PAGE */
    .about-contact-section {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .about-contact-featured-img {
        position: absolute;
        top: 0;
        left: 50%;
        width: 50%;
        height: 100%;
        object-fit: cover;
        object-position: center;
    }

    /* SINGLE POST PAGE */
    .single-post-heading-1 {
        font-size: calc(var(--font-size) * 3);
    }

    /* ARCHIVE SERVICIOS */
    .content-with-sidebar {
        flex-wrap: nowrap;
    }
    .sidebar {
        max-width: 400px;
        width: 400px;
        border-radius: var( --border-radius );
        background-color: var(--light-background);
        position: sticky;
        top: 25px;
        height: calc(100vh - 50px);
        padding: var(--default-padding);
    }
}
@media only screen and (min-width:1140px) {

}
@media only screen and (min-width:1280px) {

}
@media only screen and (-webkit-min-device-pixel-ratio:1.5),
	   only screen and (min-resolution:144dpi) {

}

/*------------------------------------*\
    MISC
\*------------------------------------*/
::selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}
::-webkit-selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}
::-moz-selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}

/*------------------------------------*\
    WORDPRESS CORE
\*------------------------------------*/

.alignnone {
	margin:5px 20px 20px 0;
}
.aligncenter,
div.aligncenter {
	display:block;
	margin:5px auto 5px auto;
}
.alignright {
	float:right;
	margin:5px 0 20px 20px;
}
.alignleft {
	float:left;
	margin:5px 20px 20px 0;
}
a img.alignright {
	float:right;
	margin:5px 0 20px 20px;
}
a img.alignnone {
	margin:5px 20px 20px 0;
}
a img.alignleft {
	float:left;
	margin:5px 20px 20px 0;
}
a img.aligncenter {
	display:block;
	margin-left:auto;
	margin-right:auto;
}
.wp-caption {
	background:#FFF;
	border:1px solid #F0F0F0;
	max-width:96%;
	padding:5px 3px 10px;
	text-align:center;
}
.wp-caption.alignnone {
	margin:5px 20px 20px 0;
}
.wp-caption.alignleft {
	margin:5px 20px 20px 0;
}
.wp-caption.alignright {
	margin:5px 0 20px 20px;
}
.wp-caption img {
	border:0 none;
	height:auto;
	margin:0;
	max-width:98.5%;
	padding:0;
	width:auto;
}
.wp-caption .wp-caption-text,
.gallery-caption {
	font-size:11px;
	line-height:17px;
	margin:0;
	padding:0 4px 5px;
}
.sticky {

}
.bypostauthor {

}

/*------------------------------------*\
    PRINT
\*------------------------------------*/

@media print {
	* {
		background:transparent !important;
		color:#000 !important;
		box-shadow:none !important;
		text-shadow:none !important;
	}
	a,
	a:visited {
		text-decoration:underline;
	}
	a[href]:after {
		content:" (" attr(href) ")";
	}
	abbr[title]:after {
		content:" (" attr(title) ")";
	}
	.ir a:after,
	a[href^="javascript:"]:after,
	a[href^="#"]:after {
		content:"";
	}
	pre,blockquote {
		border:1px solid #999;
		page-break-inside:avoid;
	}
	thead {
		display:table-header-group;
	}
	tr,img {
		page-break-inside:avoid;
	}
	img {
		max-width:100% !important;
	}
	@page {
		margin:0.5cm;
	}
	p,
	h2,
	h3 {
		orphans:3;
		widows:3;
	}
	h2,
	h3 {
		page-break-after:avoid;
	}
}
