/*
Theme Name: Flatsome Child
Description: This is a child theme for Flatsome Theme
Author: UX Themes
Template: flatsome
Version: 3.18.2
*/

/*************** ADD CUSTOM CSS HERE.   ***************/
@font-face {
    font-family: 'avenir';
    src: url(./assets/fonts/avenir/AvenirLTStd-Light.eot);
    src: url(./assets/fonts/avenir/AvenirLTStd-Light.eot?#iefix) format('embedded-opentype'),
        url(./assets/fonts/avenir/AvenirLTStd-Light.woff) format('woff'),
        url(./assets/fonts/avenir/AvenirLTStd-Light.ttf) format('truetype');
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: 'avenir';
    src: url(./assets/fonts/avenir/AvenirLTStd-Book.eot);
    src: url(./assets/fonts/avenir/AvenirLTStd-Book.eot?#iefix) format('embedded-opentype'),
        url(./assets/fonts/avenir/AvenirLTStd-Book.woff) format('woff'),
        url(./assets/fonts/avenir/AvenirLTStd-Book.ttf) format('truetype');
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'avenir';
    src: url(./assets/fonts/avenir/AvenirLTStd-Medium.eot);
    src: url(./assets/fonts/avenir/AvenirLTStd-Medium.eot?#iefix) format('embedded-opentype'),
        url(./assets/fonts/avenir/AvenirLTStd-Medium.woff) format('woff'),
        url(./assets/fonts/avenir/AvenirLTStd-Medium.ttf) format('truetype');
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: 'avenir';
    src: url(./assets/fonts/avenir/AvenirLTStd-Medium.eot);
    src: url(./assets/fonts/avenir/AvenirLTStd-Medium.eot?#iefix) format('embedded-opentype'),
        url(./assets/fonts/avenir/AvenirLTStd-Medium.woff) format('woff'),
        url(./assets/fonts/avenir/AvenirLTStd-Medium.ttf) format('truetype');
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'avenir';
    src: url(./assets/fonts/avenir/AvenirLTStd-Heavy.eot);
    src: url(./assets/fonts/avenir/AvenirLTStd-Heavy.eot?#iefix) format('embedded-opentype'),
        url(./assets/fonts/avenir/AvenirLTStd-Heavy.woff) format('woff'),
        url(./assets/fonts/avenir/AvenirLTStd-Heavy.ttf) format('truetype');
    font-weight: 800;
    font-style: normal;
}

@font-face {
    font-family: 'avenir';
    src: url(./assets/fonts/avenir/AvenirLTStd-Heavy.eot);
    src: url(./assets/fonts/avenir/AvenirLTStd-Heavy.eot?#iefix) format('embedded-opentype'),
        url(./assets/fonts/avenir/AvenirLTStd-Heavy.woff) format('woff'),
        url(./assets/fonts/avenir/AvenirLTStd-Heavy.ttf) format('truetype');
    font-weight: 900;
    font-style: normal;
}

/* @font-face {
    font-family: dita sweet;
    src: url(./assets/fonts/DitaSweet.woff2)format('woff2'),url(./assets/fonts/DitaSweet.woff)format('woff'),url(./assets/fonts/DitaSweet.svg#DitaSweet)format('svg');
    font-weight: 400;
    font-style: normal
} */

:root {
    --fs-color-black: #000000;
    --fs-color-white: #ffffff;
    --fs-color-grey: #cccccc;
    --fs-color-text: #343638;
    --FontAwesome: 'Font Awesome 7 Pro';
    --FontAwesomeBrands: 'Font Awesome 7 Brands';
    --font-html-size: 62.5%;
}

html {
    font-size: var(--font-html-size);
}

body {
    font-size: 1.6rem !important;
    font-family: 'avenir', sans-serif;
}

h1,
.h1 {
    font-size: 3em;
}

h2,
.h2 {
    font-size: 2.625em;
}

.banner h2 {
    font-size: 4.25em;
}

h3,
.h3 {
    font-size: 2.25em;
}

h4,
.h4 {
    font-size: 1.75em;
}

.box-text h2 {
    font-size: 1.75em;
}

.box-text h3 {
    font-size: 1.5em;
}

.box-text h4 {
    font-size: 1.125em;
}

.banner h1,
.banner h2,
.banner h3 {
    font-weight: 700;
    line-height: 1.25;
    margin-bottom: 1rem;
    margin-top: 0;
    padding: 0;
}

.entry-content h2,
.entry-content .h2 {
    font-size: 2em;
}

.entry-content h3,
.entry-content .h3 {
    font-size: 1.75em;
}

.entry-content h4,
.entry-content .h4 {
    font-size: 1.5em;
}

.uppercase,
h6,
span.widget-title,
th {
    letter-spacing: 0;
}

.last-reset > p:has(+ style) {
    margin-bottom: 0;
}
.slider [data-animate='fadeInLeft'],
[data-animate='fadeInLeft'] {
    transform: translate3d(-100px, 0, 0);
}
.slider [data-animate],
[data-animate] {
    transition: filter 0.3s, transform 0.75s, opacity 0.2s ease-in;
}
span[data-animate] {
    display: inline-block;
}

.is-outline {
    color: var(--fs-color-text);
}

.button.icon {
    margin-left: 4px;
    margin-right: 4px;
    margin-bottom: 4px;
}

p {
    margin-bottom: 1.5rem;
}

b,
strong {
    font-weight: inherit;
    font-weight: 700;
}

.dark,
.dark p,
.dark td {
    color: var(--fs-color-white);
}

.col-child-left > .col-inner {
    margin-right: auto !important;
    margin-left: 0 !important;
}
.col-child-center > .col-inner {
    margin-right: auto !important;
    margin-left: auto !important;
}

.col-child-right > .col-inner {
    margin-right: 0 !important;
    margin-left: auto !important ;
}

.off-canvas-left .mfp-content,
.off-canvas-right .mfp-content {
    background-color: hsla(0, 0%, 100%, 1);
}

.off-canvas:not(.off-canvas-center) .nav-vertical li > a {
    font-size: 1em;
    text-transform: capitalize;
    font-weight: 500;
    color: var(--fs-color-black);
}

.nav > li > a {
    font-size: 0.75em;
    font-weight: 600;
}

.nav-size-medium > li > a {
    font-size: 0.875em;
}

.nav-uppercase > li > a {
    letter-spacing: 0;
    text-transform: uppercase;
}

.icon-envelop:before {
    content: '\f0e0';
    font-family: var(--FontAwesome);
    font-weight: 400;
}
.icon-play:before {
    content: '\f144';
    font-family: var(--FontAwesome);
    font-weight: bold;
}

.icon-facebook:before {
    content: '\f09a';
    font-family: var(--FontAwesomeBrands);
    font-weight: 400;
}

.icon-linkedin:before {
    content: '\f08c';
    font-family: var(--FontAwesomeBrands);
    font-weight: 400;
}
.icon-youtube:before {
    content: '\f167';
    font-family: var(--fa-family-brands);
    font-weight: 400;
}

.video-button-wrapper .icon-play {
    font-size: 3.5em !important;
}

.video-button-wrapper .open-video {
    background: transparent;
    border: none;
    box-shadow: none !important;
    width: auto;
    height: auto;
    min-width: auto;
    min-height: unset;
    line-height: unset;
}

.video-button-wrapper small {
    display: block;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 1.5em;
}

.dark a:hover,
.nav-dark a:hover {
    opacity: 1 !important;
    color: var(--fs-experimental-link-color-hover) !important;
}

.dark .button.primary:hover {
    color: var(--fs-color-white) !important;
}

.widget .widget-title {
    font-weight: 600;
    display: block;
    width: 100%;
    text-transform: uppercase;
    margin-bottom: 1.5em;
}

.widget .widget-title + .is-divider {
    display: none;
}

.fixed-section .section-bg {
    background-repeat: no-repeat;
    background-size:cover;
}

.fixed-section:not(.dark) .section-content {
    color: var(--fs-color-primary);
}

.fixed-section .video-button-wrapper .button {
    color: var(--fs-color-primary);
}

.fixed-section h1 {
    font-weight: 600;
    font-size: 4.25em;
    text-transform: capitalize;
    margin-bottom: 0;
    color: currentColor;
}

.fixed-section .small h1 {
    font-size: 3em;
}

.button,
button,
input[type='button'],
input[type='reset'],
input[type='submit'] {
    font-size: 1em;
    font-weight: 600;
    letter-spacing: 0;
    place-content: center;
}

 .select2-container .select2-choice,
 .select-resize-ghost,
 .select2-container .select2-selection,
 input[type='date'],
 input[type='email'],
 input[type='number'],
 input[type='password'],
 input[type='search'],
 input[type='tel'],
 input[type='text'],
 input[type='url'],
 select,
 textarea {
    box-shadow: none;
    color: var(--fs-color-text);
    font-size: 1em;
    height: 4rem;
}

 input[type='email']:focus,
 input[type='number']:focus,
 input[type='password']:focus,
 input[type='search']:focus,
 input[type='tel']:focus,
 input[type='text']:focus,
 select:focus,
 textarea:focus {
    box-shadow: none;
    color: var(--fs-color-text);
    opacity: 1 !important;
    border-color: #000;
}

.wpcf7 [type='email']:focus,
.wpcf7 input[type='number']:focus,
.wpcf7 input[type='password']:focus,
.wpcf7 input[type='search']:focus,
.wpcf7 input[type='tel']:focus,
.wpcf7 input[type='text']:focus,
.wpcf7 select:focus,
.wpcf7textarea:focus {
    border-radius: 4px;
}

.section-text-title span {
    color: var(--fs-color-primary);
}

.wpcf7 label {
    color: var(--fs-color-text);
    font-size: 1em;
    font-weight: 400;
    margin-bottom: 0.4em;
    font-size: 2rem;
}

.wpcf7 .wpcf7-form-control-wrap label {
    font-weight: bold;
    margin-bottom: 0;
}

input[type='checkbox'],
input[type='radio'] {
    width: 16px;
    height: 16px;
}

#main,
#wrapper {
    z-index: 9;
}

.linear-title {
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent;
    width: fit-content;
    margin: 0;
    background: -webkit-linear-gradient(right, #e61846, #056db6);
    background: -o-linear-gradient(right, #e61846, #056db6);
    background: -moz-linear-gradient(right, #e61846, #056db6);
    background: linear-gradient(to right, #e61846, #056db6);
}

.has-off-canvas-right #wrapper {
    transform: translateX(-320px);
    transition: all 0.3s ease-in-out;
}

.flickity-page-dots .dot {
    border-width: 2px;
}

/*************** MENU MOBILE ***************/
html[ng-app='uxBuilder'] .mobile-sidebar {
    display: none;
}

.mobile-sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    width: 320px;
    right: 0;
    background-color: #f3f3f3;
}

.mobile-sidebar .sidebar-menu-top-content {
    padding: 5rem 2rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.mobile-sidebar .nav li > a {
    padding: 1rem 1rem 1rem 0;
    font-size: 1.5rem;
    text-transform: initial;
    font-weight: 400;
    margin-left: 2rem;
    color: var(--fs-color-text);
}

.mobile-sidebar .nav li.menu-item-has-children > a {
    border-right: 1px solid rgba(0, 0, 0, 0.1);
}

.mobile-sidebar .nav li .toggle {
    margin: 0;
    opacity: 1;
    font-size: 1.4rem;
}

.mobile-sidebar .nav li .toggle {
    margin: 0;
    opacity: 1;
    font-size: 1.4rem;
    height: 44px;
}

.mobile-sidebar .nav li .toggle i {
    transform: rotate(-90deg);
}

.mobile-sidebar .nav li.active > .toggle {
    background-color: #e7e7e7;
    transform: rotate(0deg);
}

.mobile-sidebar .nav li.active > .toggle i {
    transform: rotate(0deg);
}

.nav-sidebar.nav-vertical > li.menu-item.active,
.nav-sidebar.nav-vertical > li.menu-item:hover {
    background-color: transparent;
}

.nav-sidebar.nav-vertical > li.menu-item.active > ul {
    background-color: #e7e7e7;
}

.nav-sidebar.nav-vertical > li + li {
    border-top: none;
}

.nav-sidebar.nav-vertical > li + li > a {
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.nav:not(.nav-slide) .active > .children {
    padding-bottom: 0;
}

.nav-vertical li li.menu-item-has-children > a {
    color: var(--fs-color-text);
    font-size: 1em;
    font-weight: 400;
    text-transform: initial;
}

#wide-nav .html_topbar_right {
    width: 100%;
}

.menu-mb-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px;
}

.menu-mb-wrapper .toggle-menu-mb {
    margin: 0;
    font-size: 1.5rem;
    width: 100%;
    border: 1px solid #f5f5f5;
}
.menu-mb-wrapper .toggle-menu-mb i {
    margin-left: 2px;
    font-size: 1.4rem;
    position: relative;
    top: -1px;
}

#wrapper {
    transition: all 0.3s ease-in-out;
}

#wrapper.active {
    transform: translateX(-32rem);
}

/*************** END MENU MOBILE ***************/

/*************** HEADER ***************/
.stuck #top-bar,
.stuck #wide-nav {
    display: none;
}
#header #header-contact a {
    letter-spacing: 0;
    text-transform: initial;
}

#header #header-contact i {
    font-size: 1.2rem !important;
}

#header #header-contact.nav-divided > li + li > a:after {
    border-left: none;
}

#header .social-icons {
    font-size: 1.25em;
}

#header .searchform-wrapper {
    display: flex;
    align-items: center;
}

#header .searchform-wrapper .open-searchform {
    display: inline-block !important;
    visibility: visible !important;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
}

#header .searchform-wrapper .searchform {
    display: none;
    z-index: 10;
}

#header .searchform input[type='search'] {
    height: 2rem;
    box-shadow: none !important;
    border: none;
    font-size: 1.2rem;
}

#header .searchform input[type='search']::placeholder {
    opacity: 0;
}

#header .searchform button {
    height: 2rem;
    width: 2rem;
    line-height: 2rem;
    border: none;
    box-shadow: none !important;
    min-height: 2rem;
    min-width: 2rem;
    font-size: 0.75rem;
    background-color: var(--fs-color-white);
    color: var(--fs-color-black);
}

#header .searchform button i {
    top: 0;
}

#header .nav-dropdown.nav-dropdown-default {
    border-bottom: 8px solid #dcdcdc;
    padding: 0;
}

.nav-column > li > a,
.nav-dropdown > li > a,
.nav-vertical-fly-out > li > a,
.nav > li > a {
    color: #000000b3;
    transition: all 0.2s;
    font-weight: 600;
}

.nav-dropdown-default .nav-column li > a,
.nav-dropdown.nav-dropdown-default > li > a {
    padding: 16px 12px;
    margin: 0;
}

/*************** END HEADER ***************/

/*************** FOOTER ***************/

#footer {
    font-size: 0.938em;
}
#footer .footer-logo {
    max-width: 26rem;
}

#footer .sidebar-wrapper .widget {
    padding: 0;
}

#footer .widget li {
    display: inline;
    border: none;
}

#footer .widget li + li::before {
    content: '- ';
    display: inline;
    opacity: 1;
    margin: 0;
    font-family: auto;
}

#footer .widget li a {
    font-weight: 600;
}

/*************** END FOOTER ***************/

/*************** HOME PAGE ***************/
.home-hero-section .slider .banner span[data-animated='true'] {
    transition-delay: 0.4s;
}
.home-hero-section .slider .banner p[data-animated='true'] {
    transition-delay: 0.8s;
}

.home-hero-section .slider .banner .button[data-animated='true'] {
    transition-delay: 1s;
}

/*************** END HOME PAGE ***************/

/*************** CONTACT PAGE ***************/
.contact-hero-section {
    background: url(https://quanta.dev/wp-content/uploads/2025/12/Contact_Us_22-img.jpg) no-repeat center / cover;
}

.contact-form-section .wpcf7 label {
    margin-bottom: 1.5rem;
}

.contact-form-section .wpcf7 .wpcf7-form-control-wrap label {
    margin-bottom: 0rem;
}
.contact-form-section .wpcf7 span.wpcf7-list-item {
    margin-left: 0;
    margin-right: 0;
    display: block;
    width: 100%;
    margin-bottom: 0 !important;
}

.contact-form-section .wpcf7 textarea {
    border: 3px solid var(--fs-color-primary);
    padding: 10px;
    outline: none;
    resize: none;
    box-shadow: none;
    background-color: transparent;
    height: 25rem;
    box-shadow: none !important;
}

.contact-form-section input[type='email'],
.contact-form-section input[type='tel'],
.contact-form-section input[type='text'] {
    border: none;
    box-shadow: none !important;
    border-bottom: 3px solid var(--fs-color-primary);
    background-color: transparent;
    padding: 1rem 0;
    font-size: 2rem;
}

.wpcf7-acceptance .wpcf7-list-item-label {
    font-weight: 400 !important;
}

.wpcf7-acceptance .wpcf7-list-item-label a {
    color: var(--fs-color-primary);
    text-decoration: underline;
    text-underline-offset: 4px;
}

.wpcf7-acceptance .wpcf7-list-item-label a:hover {
    text-decoration: none;
}

.wpcf7-acceptance input {
    margin-bottom: 0;
}

.contact-form-section .button {
    font-weight: 400;
    font-size: 1.125em;
    border-radius: 10rem;
    min-width: 15rem;
    padding: 0.8rem 3.2rem;
}

.swal2-popup {
    font-size: 1.6rem !important;
}

/*************** END CONTACT PAGE ***************/

/*************** PARTNER PAGE ***************/
.logos-section .logos-row {
    border: 1px solid #ddd;
}
.logos-section .logos-row > .col > .col-inner {
    padding: 0.8rem;
}

.logos-section .logos-row .box .box-image img {
    object-fit: contain;
}
.ux-relay__control--bottom {
    margin-top: 3rem;
}

.partner-lightbox {
    border-radius: 12px;
    background: url(/wp-content/uploads/2025/12/stock-photo-backgrounds-img.webp) no-repeat center / cover;
}

.partner-content {
    text-align: center;
}

.partner-lightbox .main-title {
    font-size: 3.2rem;
    font-weight: bold;
    color: var(--fs-color-primary);
    text-transform: uppercase;
    margin-bottom: 3rem;
}

.partner-lightbox .sub-title {
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 2rem;
    color: var(--fs-color-primary);
}

.partner-lightbox .phone {
    font-weight: bold;
}
.partner-lightbox .address {
    font-weight: bold;
}

.partner-lightbox .phone i,
.partner-lightbox .address i {
    color: var(--fs-color-primary);
}

.row-dashed .col:before,
.row-solid .col:before {
    border-left: 1px dashed #ddd;
    content: ' ';
    height: 100%;
    right: -1px;
    position: absolute;
    top: 0;
    left: auto;
}

.row-solid .col:before {
    border-left-style: solid;
}

/*************** END PARTNER PAGE ***************/

/*************** BLOG ARCHIVE ***************/
.blog-archive {
    padding-top: 0;
}

.archive-page-header-wrapper {
    margin-bottom: 5rem;
}

.archive-page-header {
    min-height: 30rem;
    place-content: center;
    background-color: #333;
    position: relative;
    background-position: 50% 50%;
}

.archive-page-header .overlay {
    background-color: rgba(0, 0, 0, 0.75);
}

.archive-page-header h1.page-title,
.archive-page-header h2.page-title {
    font-size: 4.25em;
    margin-bottom: 0;
    text-transform: capitalize;
}

.box-text {
    font-size: 1em;
    padding-bottom: 1rem;
    padding-top: 1rem;
}

.box-text.is-xsmall {
    font-size: 0.75em;
}

.box-text.is-small {
    font-size: 0.875em;
}

.box-text.is-large {
    font-size: 1.25em;
}

.box-text.is-xlarge {
    font-size: 1.5em;
}

.box-blog-post .is-divider {
    display: none;
}

.box-blog-post .box-image img {
    border-radius: 12px;
    overflow: hidden;
}

.box-blog-post .post-title.is-xxsmall {
    font-size: 1rem;
}
.box-blog-post .post-title.is-xsmall {
    font-size: 1.2rem;
}
.box-blog-post .post-title.is-smaller {
    font-size: 1.4rem;
}

.box-blog-post .post-title.is-small {
    font-size: 1.6rem;
}

.box-blog-post .post-title.is-large {
    font-size: 2rem;
}

.box-blog-post .post-title.is-larger {
    font-size: 2.8rem;
}

.box-blog-post .post-title.is-xlarge {
    font-size: 3.6rem;
}

.box-blog-post .post-title.is-xxlarge {
    font-size: 4.2rem;
}

.box-blog-post .post-title a {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    margin: 0 0 1rem;
}

.box-blog-post .post-meta {
    margin-bottom: 1rem;
    opacity: 1;
}

.box-blog-post .from_the_blog_excerpt {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.box-blog-post .box-text.is-large .from_the_blog_excerpt {
    margin: 2rem 0;
}

.box-blog-post .box-text .button {
    font-size: 12px;
    padding: 10px 24px;
    border-radius: 10em;
    text-transform: initial;
}

.box-blog-post .box-text .button.is-large {
    font-size: 14px;
    padding:6px 24px
}

.box-blog-post .box-text .button.is-link {
    padding:0 ;
    position: relative;
    margin-top: 0;
}

.box-blog-post .box-text .button.is-link:after {
    content: '\f324';
    font-family: var(--FontAwesome);
    font-weight: 300;
    font-size: 8px;
    position: relative;
    top: -2px
}

ul.links {
    font-size: 1em;
}

.nav-pagination > li > a,
.nav-pagination > li > span {
    border: 1px solid;
    border-radius: 0;
    font-size: 1em;
    font-weight: 500;
    padding: 0 7px;
}

.taxonomy-description li,
.taxonomy-description p,
.taxonomy-description div {
    font-size: 2rem;
}

blockquote {
    border-left: 5px solid var(--fs-color-primary);
    font-size: 1em;
    font-weight: 600;
    font-style: normal;
    color: var(--fs-color-primary);
}

/*************** END BLOG ARCHIVE ***************/

/***************  BLOG SINGLE ***************/
.blog-single {
    padding-top: 0;
}

.post-sidebar .box-blog-post .post-title a {
    -webkit-line-clamp: 4;
    line-height: 1.25;
    margin-bottom: 0;
}

.post-sidebar .box-vertical .box-image {
    vertical-align: top;
}

.post-sidebar .widget .widget-title {
    font-size: 2.4rem;
    font-weight: bold;
    text-transform: initial;
    margin-bottom: 1.5rem;
    line-height: 1.25;
    display: block;
}

.post-sidebar .is-sticky-column__inner .widget {
    box-shadow: 0px 3px 10px 0px rgba(0, 0, 0, 0.1);
    border-radius: 16px;
    padding: 2rem;
}

.post-sidebar .is-sticky-column__inner .widget .widget-title {
    text-align: center;
}

.post-sidebar form  {
    margin-bottom: 0;
}

.post-sidebar form input[type='text'],
.post-sidebar form input[type='tel'],
.post-sidebar form button {
    border-radius: 8px;
}

.blog-single .entry-header-text {
    padding-bottom: 0;
}

.blog-single .entry-image img {
    border-radius: 12px;
}

.blog-single .entry-meta {
    margin-bottom: 1rem;
    font-weight: 600;
}

.blog-single .entry-meta a:not(:hover) {
    color: var(--fs-color-text);
}

.blog-single .entry-meta .posted-on {
    position: relative;
    margin-left: 11px;
}

.blog-single .entry-meta .posted-on::before {
    content: '';
    position: absolute;
    top: 15%;
    left: -7px;
    height: 70%;
    border-left: 1px solid #ddd;
}

/*************** END BLOG SINGLE ***************/

/*************** PRODUCT ARCHIVE ***************/
.banner-desc {
    font-size: 2rem;
    font-weight: 600;
}
.product-archive #post-list .quanta_product-item > .col-inner {
    max-width: 1160px;
    margin: 0 auto;
}

.product-archive #post-list .quanta_product-item .box .box-text {
    padding: 3rem 1.5rem;
}

.product-archive #post-list .quanta_product-item::before {
    content: '';
    height: 4px;
    width: 100%;
    position: absolute;
    bottom: 0;
    background-color: var(--fs-color-primary);
}

.product-archive #post-list .quanta_product-item:nth-child(odd) {
    background-color: #f5f5f5;
}

.product-archive #post-list .quanta_product-item:nth-child(even) .box-vertical {
    direction: rtl;
}

 #post-list .ux-relay__control {
    margin-top: 3rem;
}


 #post-list .ux-relay__control  .ux-relay__button {
    padding:6px 32px;
    min-width: 150px;
 }

.ux-relay__button {
    border-radius: 10rem;
    text-transform: inherit;
}

.quanta_product-item .box-blog-post .post-title a:not(:hover) {
    color: var(--fs-experimental-link-color);
}

.quanta_product-item .box-text-bottom .box-image {
    border-bottom: 3px solid var(--fs-experimental-link-color);
    border-radius: 0;
}

.slider-show-nav .flickity-prev-next-button {
    opacity: 0.3;
}

.slider-nav-circle .flickity-prev-next-button:hover .arrow,
.slider-nav-circle .flickity-prev-next-button:hover svg {
    fill: var(--fs-color-black) !important;
    background-color: transparent;
    border-color: var(--fs-color-black);
}

.flickity-prev-next-button {
    color: var(--fs-color-black);
    width: 42px;
}

.slider-nav-circle .flickity-prev-next-button .arrow,
.slider-nav-circle .flickity-prev-next-button svg {
    padding: 25%;
}

/*************** END PRODUCT ARCHIVE ***************/

/*************** PRODUCT SINGLE ***************/
.product-single .request-info-wrapper {
    background-color: #f5f5f5;
    margin: 0;
    padding: 3em 0;
}

.product-single .request-info-wrapper .button {
    margin: 0;
    border-radius: 10rem;
    padding: 6px 36px;
    font-size: 1.4rem;
}

.image-hotspot a.hotspot {
    background-color: transparent !important;
    opacity: 1;
    width: auto;
    height: auto;
    color: var(--fs-color-primary);
    font-size: 3.6rem;
    position: relative;
    cursor: pointer;
    transition: all 0.2s ease-in;
}

.image-hotspot a.hotspot:hover {
    transform: scale(0.9);
}

.image-hotspot .icon-plus:before {
    content: '\f00e';
    font-family: var(--FontAwesome);
    font-weight: 300;
}

.hotspot-content-wrapper {
    pointer-events: none;
    z-index: -999;
    opacity: 0 !important;
    visibility: hidden !important;
}

.hotspot-content-wrapper-fixed {
    position: absolute;
    z-index: 99999;
    opacity: 0;
    -webkit-transition: transform 0.2s ease-in, opacity 0.2s ease-in;
    transition: transform 0.2s ease-in, opacity 0.2s ease-in;
}

.hotspot-content-wrapper-fixed,
.hotspot-content-wrapper {
    width: 20em;
    height: 20em;
    max-width: 20rem;
    max-height: 20rem;
    opacity: 0;
    position: absolute;
    -webkit-transition: transform 0.2s ease-in, opacity 0.2s ease-in;
    transition: transform 0.2s ease-in, opacity 0.2s ease-in;
}

.hotspot-content-wrapper-fixed .hotspot-content-inner {
    height: 100%;
    width: 100%;
    border-radius: 50%;
    place-content: center;
    text-align: center;

    position: relative;
    z-index: 100;
    padding: 25px;
    color: var(--fs-color-white);
    background-color: var(--fs-color-primary);
    border-color: var(--fs-color-primary);
    -webkit-transition: transform 0.5s ease-in, opacity 0.5s ease-in;
    transition: transform 0.5s ease-in, opacity 0.5s ease-in;
    -webkit-transform: scale(0, 0);
    transform: scale(0, 0);
}

.hotspot-content {
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    z-index: 100;
    position: relative;
}

.hotspot-content-wrapper.top {
    top: -3rem;
    left: 50%;
    transform: translate(-50%, -100%);
}
.hotspot-content-wrapper.bottom {
    bottom: -3rem;
    left: 50%;
    transform: translate(-50%, 100%);
}
.hotspot-content-wrapper.left {
    top: 50%;
    left: -3rem;
    transform: translate(-100%, -50%);
}
.hotspot-content-wrapper.right {
    top: 50%;
    right: -3rem;
    transform: translate(100%, -50%);
}
.hotspot-content-wrapper.top-left {
    top: 0;
    left: 0;
    transform: translate(-100%, -100%);
}
.hotspot-content-wrapper.top-right {
    top: 0;
    right: 0;
    transform: translate(100%, -100%);
}
.hotspot-content-wrapper.bottom-left {
    bottom: 0;
    left: 0;
    transform: translate(-100%, 100%);
}
.hotspot-content-wrapper.bottom-right {
    bottom: 0;
    right: 0;
    transform: translate(100%, 100%);
}

.hotspot-content-wrapper-fixed.active .hotspot-content-inner,
.hotspot-content-wrapper-fixed.active .hotspot-content-inner-shadow {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}

.hotspot-content-inner-shadow {
    position: absolute;
    inset: 0;
    z-index: 10;
    -webkit-transform: scale(0, 0);
    transform: scale(0, 0);
    transition: all 0.5s ease-in;
}

.hotspot-content-inner-shadow::before,
.hotspot-content-inner-shadow::after {
    position: absolute;
    content: '';
    width: 100%;
    height: 100%;
    border-radius: 50%;
    z-index: 1;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%) scale(1, 1);
    transform: translate(-50%, -50%) scale(1, 1);
    -webkit-transition: all 0.2s ease-in;
    transition: all 0.2s ease-in;
}
.hotspot-content-inner-shadow::before,
.hotspot-content-inner-shadow::after {
    background-color: rgba(190, 56, 71, 0.5);
    opacity: 0;
}

.hotspot-content-inner-shadow::before {
    opacity: 1;
    -webkit-transition: 1s linear all;
    transition: 1s linear all;
    -webkit-transform: translate(-50%, -50%) scale(1, 1);
    transform: translate(-50%, -50%) scale(1, 1);
}

.hotspot-content-inner-shadow::after {
    opacity: 1;
    -webkit-transition: 0.5s ease-in all;
    transition: 0.5s ease-in all;
    -webkit-transition-delay: 0.5s;
    transition-delay: 0.5s;
    -webkit-transform: translate(-50%, -50%) scale(1, 1);
    transform: translate(-50%, -50%) scale(1, 1);
}

.hotspot-content-wrapper-fixed.active .hotspot-content-inner-shadow::before {
    -webkit-transform: translate(-50%, -50%) scale(1.2, 1.2);
    transform: translate(-50%, -50%) scale(1.2, 1.2);
}

.hotspot-content-wrapper-fixed.active .hotspot-content-inner-shadow::after {
    -webkit-transform: translate(-50%, -50%) scale(1.1, 1.1);
    transform: translate(-50%, -50%) scale(1.1, 1.1);
}

.image-hotspot {
    position: relative;
}

.image-hotspot .hotspot-wrapper {
    position: absolute;
    z-index: 10;
}

.single-contact-form .toggle-contact-form {
    padding: 1.2rem 4.8rem;
    border-radius: 1em;
    margin: 0 auto 3rem;
    display: block;
    width: auto;
    max-width: max-content;
}

.toggle-contact-form .span-hide,
.toggle-contact-form.active .span-show {
    display: none;
}

.toggle-contact-form.active .span-hide {
    display: block;
}

.single-contact-form .wpcf7 {
    display: none;
}

.single-contact-form form {
}
/*************** END PRODUCT SINGLE ***************/

@media only screen and (min-width: 550px) {
    .product-archive #post-list .quanta_product-item:nth-child(odd)::before {
        left: -50%;
    }

    .product-archive #post-list .quanta_product-item:nth-child(even)::before {
        left: 50%;
    }
}
@media only screen and (min-width: 850px) {
    .fixed-section .section-bg {
        background-attachment: fixed;
    }

    .blog-featured-title .page-title-inner {
        min-height: 500px !important;
    }

    .is-full-height {
        height: calc(100vh - 132px) !important;
    }

    .logged-id .is-full-height {
        height: calc(100vh - 170px) !important;
    }

    .blog-single .row.row-large {
        max-width: 1170px;
    }

    .blog-single .row.row-large > .col {
        padding: 0 20px 30px;
    }

    .post-sidebar .box.box-vertical .box-text {
        padding: 0 0 0 1rem;
    }
}

.slider-nav-outside .flickity-prev-next-button.previous {
    left: 0;
    right: auto;
}
.slider-nav-outside .flickity-prev-next-button.next {
    left: auto;
    right: 0;
}
@media only screen and (min-width: 1280px) {
    .slider-nav-outside .flickity-prev-next-button.next {
        left: 100%;
        right: auto;
    }
    .slider-nav-outside .flickity-prev-next-button.previous {
        left: auto;
        right: 100%;
    }
}

@media only screen and (max-width: 849px) {
    /*************** ADD TABLET CSS HERE  ***************/
    .stuck #masthead,
    .stuck #wide-nav {
        display: none;
    }

    .stuck #top-bar {
        display: flex;
    }
    .home-hero-section .banner.is-full-height {
        height: auto;
    }

    .banner h2,
    .archive-page-header h1.page-title,
    .archive-page-header h2.page-title,
    .fixed-section h1 {
        font-size: 3.75em;
    }
    .video-button-wrapper .icon-play {
        font-size: 2.5em !important;
    }
    .video-button-wrapper small {
        font-size: 1em;
    }

    h1,
    .h1 {
        font-size: 2.5em;
    }

    h2,
    .h2 {
        font-size: 2.25em;
    }
    h3,
    .h3 {
        font-size: 1.75em;
    }

    h4,
    .h4 {
        font-size: 1.5em;
    }

    .taxonomy-description li,
    .taxonomy-description p,
    .taxonomy-description div {
        font-size: 1.8rem;
    }
    #header .social-icons a {
        width: 4rem;
        height: 3.6rem;
        border: 1px solid #8f8f8f;
        display: inline-block;
        place-content: center;
        text-align: center;
        margin: 0;
    }

    #header .social-icons a:not(:first-child) {
        border-left: 0;
    }

    .box-blog-post .post-title.is-large {
        font-size: 1.8rem;
    }

    .box-blog-post .post-title.is-larger {
        font-size: 2.4rem;
    }

    .box-blog-post .post-title.is-xlarge {
        font-size: 2.8rem;
    }

    .box-blog-post .post-title.is-xxlarge {
        font-size: 3.2rem;
    }

    .select-resize-ghost,
    .select2-container .select2-choice,
    .select2-container .select2-selection,
    input[type='date'],
    input[type='email'],
    input[type='number'],
    input[type='password'],
    input[type='search'],
    input[type='tel'],
    input[type='text'],
    input[type='url'],
    select,
    textarea {
        font-size: 1.6rem;
    }

    .image-hotspot a.hotspot {
        font-size: 2.4rem;
    }
}

@media only screen and (max-width: 549px) {
    /*************** ADD MOBILE ONLY CSS HERE  ***************/
    .small-text-center {
        text-align: center;
    }
    #footer .footer-logo {
        margin: 0 auto;
    }

    .video-button-wrapper .icon-play {
        font-size: 2.25em !important;
    }

    .video-button-wrapper small {
        font-size: 0.75em;
    }

    h1,
    .h1 {
        font-size: 2.25em;
    }

    h2,
    .h2 {
        font-size: 2em;
    }

    h3,
    .h3 {
        font-size: 1.5em;
    }

    h4,
    .h34 {
        font-size: 1.25em;
    }

        .banner h2,
    .archive-page-header h1.page-title,
    .archive-page-header h2.page-title,
    .fixed-section h1 {
        font-size: 2em;
    }

    .res-text {
        font-size: 16px;
    }

 
    .contact-form-section input[type='email'],
    .contact-form-section input[type='tel'],
    .contact-form-section input[type='text'] {
        border-bottom: 2px solid var(--fs-color-primary);
        font-size: 1.6rem;
    }

    .wpcf7 label {
        font-size: 1.6rem;
    }

    .contact-form-section .button {
        font-size: 1em;
        min-width: 12rem;
        padding: 0.5rem 3.2rem;
    }

    .box-blog-post .box-text.is-large .from_the_blog_excerpt {
        margin: 1rem 0;
    }

    .box-text.is-large {
        font-size: 1em;
    }

    .box-text.is-xlarge {
        font-size: 1.25em;
    }
    .image-hotspot a.hotspot {
        font-size: 2rem;
    }
    .hotspot-content-wrapper-fixed {
        position: fixed;
        bottom: 0 !important;
        left: 0 !important;
        top: auto !important;
        right: 0 !important;
        width: 100%;
        height: auto;
        max-width: unset;
        max-height: unset;
        transform: translate(0%, 0%) !important;
        transition: all 0.3s;
    }

    .hotspot-content-inner-shadow {
        display: none !important;
    }
    .hotspot-content-wrapper-fixed .hotspot-content-inner {
        transform: translateY(100%);
        border-radius: 0;
        transition: all 0.5s;
    }
    .hotspot-content-wrapper-fixed.active .hotspot-content-inner {
        transform: translateY(0%);
    }
    .partner-lightbox .main-title {
        font-size: 2.4rem;
        margin-bottom: 1.6rem;
    }

    .partner-lightbox .sub-title {
        font-size: 1.8rem;
        margin-bottom: 1.2rem;
    }
}

.is-xxxlarge {
    font-size: 2.5em;
}

.is-xxlarge {
    font-size: 2em;
}

.is-xlarge {
    font-size: 1.5em;
}

.is-larger {
    font-size: 1.3em;
}

.is-large {
    font-size: 1.15em;
}

.is-small,
.is-small.button {
    font-size: 0.8em;
}

.is-smaller {
    font-size: 0.75em;
}

.is-xsmall {
    font-size: 0.7em;
}

.is-xxsmall {
    font-size: 0.6em;
}

@media (max-width: 549px) {
    .is-xxlarge {
        font-size: 1.75em;
    }

    .is-xlarge {
        font-size: 1.25em;
    }

    .is-larger {
        font-size: 1.2em;
    }

    .is-large {
        font-size: 1em;
    }
}
