/*!
Theme Name: RosaLux Geneva
Theme URI: https://gitlab.com/partnerandpartners/partner-starter
Author: Partner & Partners — Logan, Zach, Greg
Author URI: https://partnerandpartners.com
Description: Default
Version: 1.0.0
Tested up to: 7.4
Requires PHP: 7.0
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: partner-starter
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
!*/

* {
    padding: 0;
    margin: 0;
    top: 0;
    box-sizing: border-box !important;
    scroll-margin-top: calc(var(--header-height) + 2rem);
    hyphens: auto !important;
    -webkit-hyphens: auto !important;
    -moz-hyphens: auto !important;
    -ms-hyphens: auto !important;
}

.site-main {
    padding-left: 2.5%;
    padding-right: 2.5%;
    margin-left: 15vw !important}

.lang-select-desktop .wpml-ls-display,
.lang-select-mobile .wpml-ls-display {
    display: none;
}

.mobile-wrap {
    display: none;
}

.desktop-wrap {
    width: fit-content;
    margin-left: 2.5%;
}

.lang-select-desktop {
    display: flex;
    flex-direction: column-reverse;
    text-transform: uppercase;
    color: var(--rls-red);
    max-height: 3.6rem;
    font-size: 2.4rem !important;
    margin-right: 1rem;
    border: 1px solid var(--rls-red) !important;
    background: white;
    overflow: hidden;
    cursor: pointer;
}

.cart-reminder {
    position: fixed;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    top: var(--header-height);
    right: 0;
    margin-top: 2rem;
    margin-right: 2.5%;
    padding: 2rem;
    background: white;
    border: 1px solid var(--rls-red);
    color: var(--rls-red);
    z-index: 999;
}

.cart-reminder > * {
    margin-bottom: -0.5rem;
    line-height: 1;
}

.cart-reminder button {
    background: none;
    border: none;
    color: var(--rls-red);
    margin-left: 2rem;
}

section#banner {
    position: sticky;
    bottom: 0;
    z-index: 998;
}

.cookie-banner {
    position: sticky;
    bottom: 0;
    line-height: 1;
    transition: all 0.2s ease;
}

.cookie-banner label {
    border: 1px solid white;
    padding-top: 5px;
    margin: 0;
    cursor: pointer;
    transition: all 0.2s ease;
}

.cookie-banner label:hover,
.cookie-banner input:checked ~ label {
    opacity: 0.5;
}

/* For .lang-select-desktop */
.open-select {
    max-height: none;
}

.lang-select-desktop ul {
    list-style: none;
    margin: 0;
}

.lang-select-desktop ul.main-switcher {
    padding: 1rem;
}

.lang-select-desktop.span + .lang-select-desktop.sub-menu {
    margin: 10rem;
}

.lang-select-desktop ul.sub-menu > li {
    margin-bottom: 1rem;
}

.lang-select-desktop .main-switcher > li {
    display: flex;
    flex-direction: column-reverse;
}

.lang-select-desktop .main-switcher > li > span,
.lang-select-desktop ul.sub-menu > li {
    height: 2.4rem;
    line-height: 2.4rem;
}

.lang-select-desktop .main-switcher > li > span {
    margin-bottom: -10px;
}

.lang-select-desktop .main-switcher > li > span::after {
    content: '';
    position: relative;
    display: inline;
    border-right: solid 0.9rem transparent;
    border-bottom: solid 1.8rem var(--rls-red);
    border-left: solid 0.9rem transparent;
    top: -2.5rem;
    margin-left: 0.5rem;
}

.lang-select-desktop .sub-menu .active {
    display: none;
}


/* General */
.wp-block-separator {
    position: relative;
    display: inline-block;
    height: 1px !important;
    min-width: 100% !important;
    background-color: var(--rls-red);
    border-bottom: none !important;
    margin-top: 2rem;
    margin-bottom: 2rem;}

.mx-auto a,
.styled-link {
    color: var(--rls-red) !important;
    text-decoration: underline;}

.wp-block-button {
    display: flex;
    flex-direction: row;
    align-items: baseline;}

.wp-block-button > * {
    display: inline-block;}

.wp-block-buttons .wp-block-button a.wp-block-button__link {
    font-size: 1.4rem;
    font-family: 'Univers Bold';
    line-height: 1;
    padding: 0.5rem 0.5rem 0.25rem 0.5rem;
    border: 1px solid !important;
    border-radius: 0;
    color: black !important;
    border-color: black;
    background-color: var(--rls-red-tint);
    transition: all 0.2s ease;
}

.wp-block-buttons .wp-block-button a.wp-block-button__link:hover {
    background-color: var(--rls-red);
}

.wp-block-buttons .wp-block-button.is-style-outline a.wp-block-button__link {
    color: var(--rls-red) !important;
    padding: 0.5rem 0.5rem 0.25rem 0.5rem;
    border-color: var(--rls-red) !important;
    background-color: transparent;
}

.wp-block-buttons .wp-block-button.is-style-outline a.wp-block-button__link:hover {
    color: black !important;
    border-color: black;
    background-color: var(--rls-red-tint);
}

/* Single.php */
.hero-container {
    position: relative;
    height: calc(100vh - var(--header-height));
    width: 100%;}

.matte-layer,
.image-layer,
.noise-layer,
.gradient-layer {
    position: absolute;
    height: 100%;
    width: 100%;}

.matte-layer {
    background-color: black;
    z-index: 1;}

.image-layer {
    opacity: 0.85;
    z-index: 2;
    background-size: cover;
    background-position: center;}

.gradient-layer {
    background-image: linear-gradient(to bottom, rgba(255,0,0,0), var(--rls-red));
    z-index: 3;}

.noise-layer {
    background-image: url('./img/red-noise.png');
    background-size: 35%;
    background-repeat: repeat;
    z-index:4;}

.text-layer {
    text-align: center;
    position: absolute;
    width: auto !important;
    height: auto !important;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);-ms-transform: translate(-50%,-50%);-webkit-transform: translate(-50%,-50%);
    z-index: 5;}

.splash-text-container {
    width: 100%;
    padding: 5rem 30rem;
}

.single-template .wp-block-image.size-large {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;}
    
.share-options {
    display: flex;
    flex-direction: column;
}

.share-options > a::before {
    content: '';
    position: absolute;
    width: calc(1rem * 0.5333);
    height: 1rem;
    background-color: red;
    margin-left: -1rem;
}

.share-options > a {
    margin-left: 1rem;
    margin-top: 0.5rem;
}

.wp-block-file,
.wp-block-button__link {
    text-align: center;
    color: grey !important;
    border: 0 !important;}

.wp-block-button::after {
    display: none;
}

.wp-block-file::after {
    content: '';
    position: absolute;
    width: 0;
    height: 0;
    margin-top: 2px;
    margin-left: 1rem;
    border-top: 1rem solid transparent;
    border-left: 2rem solid grey;
    border-bottom: 1rem solid transparent;}

.wp-block-file__button {
    display: none;}

.wp-block-media-text {
    grid-gap: 2rem !important;
}

.wp-block-media-text__media {
    margin-bottom: 2rem;
}

.wp-block-media-text * {
    top: 0 !important;
    align-self: flex-start !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.wp-block-media-text p {
    padding: 0rem !important;
    font-size: inherit !important;
}

.wp-block-pullquote {
    border-top: 1px solid var(--rls-red) !important;
    border-bottom: 1px solid var(--rls-red) !important;
    color: black !important;
    padding: 2rem 0rem !important;
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
}

.wp-block-pullquote p {
   margin-bottom: 0rem !important;
}

.wp-block-preformatted {
    color: gray;
    border: 1px solid gray;
    margin: 0 7rem 2rem 7rem;
    padding: 2rem;
    white-space: pre-line;
}

.wp-block-preformatted a {
    color: var(--rls-red);
    text-decoration: underline;
}

.wp-block-preformatted a:hover {
    color: var(--rls-red);
}

/* Archive.php */
.archive-container {
    position: relative;
    height: calc(75vh - var(--header-height));
    width: 100%;}

/* Image */
.portrait-image {
    width: 100%;
    padding-top: 187.5%;
    background-color: grey;
    background-size: cover;
    background-position: center;}

.landscape-image {
    width: 100%;
    padding-top: 53.333%;
    background-color: grey;
    background-size: cover;
    background-position: center;}

.square-image {
    width: 100%;
    padding-top: 100%;
    background-color: grey;
    background-size: cover;
    background-position: center;}

.hero-image {
    position: relative;
    display: block;
    width: 100%;
    height: calc(100vh - var(--header-height));
    background-size: cover;
    background-position: center;}

.work-hero {
    position: relative;
    display: flex;
    overflow: hidden;
    background-size: cover;
    background-position: center;}

.work-hero::after {
    display: block;
    content: '';
    padding-bottom: 53.333%;
}

.work-hero > img {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    min-width: 100%;
    min-height: 100%;
}

.work-hero figcaption {
    height: fit-content;
    width: 100%;
    margin: 0 !important;
    padding-top: 1rem;
    z-index: 999;
    align-self: flex-end;
    background-color: white;
}

/* Front Page */
.work-meta {
    display: flex;
    flex-direction: row;
    align-items: baseline;
    flex-flow: wrap;}

.rect-divider {
    height: 1.6rem;
    width: calc(1.6rem * 1.875);
    background-color: var(--rls-red);}

.latest-image {
    padding-top: 100%;
    background-size: cover;
    background-position: center;
    background-color: grey;}

.inline-shape {
    display: flex;
    flex-direction: row;
    align-items: baseline;}

.inline-shape * {
    display: inline-block !important;}

.big-tri {
    width: 0;
    height: 0;
    border-top: 1.5rem solid transparent;
    border-left: 3rem solid var(--rls-red);
    border-bottom: 1.5rem solid transparent;}

.small-tri {
    display: inline-block;
    width: 0;
    height: 0;
    border-top: 0.75rem solid transparent;
    border-left: 1.5rem solid #767676;
    border-bottom: 0.75rem solid transparent;
}

/* Newsletter Module */
/* Add div enclosing the form */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus textarea:-webkit-autofill,
textarea:-webkit-autofill:hover textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus {
    -webkit-box-shadow: 0 0 0px 1000px var(--rls-red) inset !important;
    box-shadow: 0 0 0px 1000px var(--rls-red) inset !important;
    -webkit-text-fill-color: #ffffff;}

#mce-EMAIL,
#mc-embedded-subscribe {
    width: 100% !important;
}

#mce-EMAIL-mobile {
    border: 1px solid white !important;
    background: none !important;
    width: 100%;
    color: white;
}
    
#mce-EMAIL, #mce-EMAIL:focus {
    background: none;
    border: 1px solid white;
    outline: none !important;
    text-align: center;
    color: white !important;}

#mce-EMAIL::placeholder,
#mce-EMAIL-mobile::placeholder {
    color: white !important;}

#mc-embedded-subscribe {
    background: white;
    border: none;
    outline: none !important;
    text-align: center;
    color: var(--rls-red) !important;}

.mobile-newsletter {
    display: none;
    left: 0;
    position: fixed;
    width: 100%;
    height: fit-content;
    bottom: 0;
    top: 100%;
    transform: translateY(-100%);
    border-top: 1px solid white;
}

.mobile-newsletter #mc_embed_signup {
    background: none !important;
}

.mobile-newsletter #mc_embed_signup input[type="email"] {
    padding: 1.5rem 1rem 1rem 1rem !important;
    font-size: 1.6rem !important;
    color: white !important;
}

.mobile-newsletter #mc_embed_signup .button {
    height: auto;
    padding: 1.5rem 1rem 1rem 1rem !important;
    font-size: 1.6rem !important;
}

/* Contact Form Block */
/* Hidden Bits */
.field-shift {
    left: -9999px; position: absolute;
}

html[dir="rtl"] .field-shift {
    right: -9999px;
    left: auto;
}

body:not(.home) #mc_embed_signup input,
body:not(.home) #mc_embed_signup .button {
    color: var(--rls-red) !important;
    border: 1px solid var(--rls-red);
}

#mc_embed_signup form {
    padding: 0 !important;
    font-family: 'Univers';
    font-size: 2rem !important;
}

#mc_embed_signup div {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

#mc_embed_signup label {
    margin: 0 !important;
}

#mc_embed_signup input {
    padding: 1rem !important;
    border-radius: 0 !important;
    border-width: 1px !important;
    text-align: left !important;
    text-indent: 0 !important;
}

#mce-EMAIL, #mce-EMAIL:focus {
    background: none;
    border: 1px solid white;
    outline: none !important;
    text-align: center;
}

#mc_embed_signup .button {
    max-width: fit-content !important;
    background: white !important;
    padding: 1rem !important;
    line-height: initial !important;
    margin: 0 !important;
}

/* Slideshow ACF Block */
.slideshow_block {
    display: grid;
    padding-left: 7rem;
    padding-right: 7rem;
    margin-bottom: 2rem;
}

.item_container {
    grid-column: 1/-1;
    grid-row: 1;
    display: none;
}

.slideshow_img_container {
    display: block;
    width: 100%;
    position: relative;
    overflow: hidden;
    padding-top: 53.333%;
    border: 1px solid var(--rls-red);
}

.slideshow_img_container img {
    position: absolute;
    width: 100%;
    height: 100%;
    padding: 2rem;
    object-fit: contain;
    background-color: transparent;
}

.item_container p {
    position: relative;
    display: block;
    margin: 1rem 0 0 0;   
    padding: 0 !important;
}

.active {
    display: block;
}

.slideshow_block .controls {
    grid-column: 1/-1;
    grid-row: 1;
    align-self: center;
    z-index: 999;
    display: flex;
    justify-content: space-between;
}

.slideshow_block .back,
.slideshow_block .forward {
    padding: 1rem;
    background: white;
    border: 1px solid var(--rls-red);
    display: flex;
    justify-content: center;
    align-items: center;
}

.slideshow_block .back {
    transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
}

.slideshow_block .forward {
    transform: translateX(50%);
    -ms-transform: translateX(50%);
    -webkit-transform: translateX(50%);
}

.slideshow_block .back::after {
    content: '';
    width: 0;
    height: 0;
    border-top: 0.75rem solid transparent !important;
    border-right: 1.5rem solid var(--rls-red) !important;
    border-bottom: 0.75rem solid transparent !important;
}

.slideshow_block .forward::after {
    content: '';
    width: 0;
    height: 0;
    border-top: 0.75rem solid transparent !important;
    border-left: 1.5rem solid var(--rls-red) !important;
    border-bottom: 0.75rem solid transparent !important;
}

/* WMPL */
.wpml-ls-statics-shortcode_actions {
    padding: 0rem !important;
}

.wpml-ls-statics-shortcode_actions li {
    display: block !important;
}

.wpml-ls-statics-shortcode_actions li * {
    align-self: flex-start !important;
    padding-left: 0rem !important;
}

.wpml-ls-statics-shortcode_actions li:not(:last-child) {
    display: block;
    margin-bottom: 1rem;
}

.wpml-ls-current-language a::before{
    content: '';
    position: absolute;
    left: 0rem;
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    background-color: var(--rls-red); 
}

.wpml-ls-item a:not(.wpml-ls-current-language)::before{
    content: '';
    position: absolute;
    left: 0rem;
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    border: 1px solid var(--rls-red);
}

/* Order Form Styling */
.order-form input[type=text] {
    width: 100%;
    padding: 0.5rem 1rem 0rem 1rem;
    border-radius: 0rem;
    border: 1px solid black;
}

.order-form input[type=submit] {
    border: 1px solid var(--rls-red);
    color: var(--rls-red);
    padding: 0.5rem 1rem 0rem 1rem;
    background: none;
    transition: all 0.2s ease;
}

.order-form input[type=submit]:hover {
    border: 1px solid var(--rls-red);
    color: white;
    padding: 0.5rem 1rem 0rem 1rem;
    background: var(--rls-red);
}

.order-form input:focus {
    outline: none !important;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus textarea:-webkit-autofill,
textarea:-webkit-autofill:hover textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus,
input:-webkit-autofill::first-line {
    -webkit-box-shadow: 0 0 0px 1000px white inset !important;
    box-shadow: 0 0 0px 1000px white inset !important;
    -webkit-text-fill-color: black;
    font-family: "Univers",-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    font-size: 2rem;
}

/* E-Comm */
/* Single Prod. */
.woocommerce div.product div.images.woocommerce-product-gallery {
    display: none;
}

.summary.entry-summary {
    width: 100% !important;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    border-bottom: 1px solid var(--rls-red);
    padding-bottom: 2rem;
    margin-bottom: 2rem !important;
}


.woocommerce-product-details__short-description {
    display: none;
}

.summary.entry-summary .product_meta,
.summary.entry-summary .stock {
    display: none;
}

.summary.entry-summary > * {
    margin: 0 !important;
}

.summary.entry-summary .price {
    color: var(--rls-red) !important;
    font-size: 2rem !important;
    vertical-align: baseline;
    align-self: flex-end;
}

.summary.entry-summary .quantity input {
    border-radius: 0;
    border: 1px solid var(--rls-red);
    background: none;
    padding: 0.5rem 0rem 0rem 1rem;
    font-weight: normal;
    line-height: inherit;
    margin-left: 2rem;
    color: var(--rls-red);
}

.summary.entry-summary form.cart button {
    border-radius: 0;
    border: 1px solid var(--rls-red);
    background: var(--rls-red);
    padding: 0.5rem 1rem 0rem 1rem;
    font-weight: normal;
    line-height: inherit;
    margin-left: 2rem;
}

.summary.entry-summary form.cart button:hover {
    background: var(--rls-red);
}

ul.tabs.wc-tabs {
    display: none;
}

.woocommerce-tabs.wc-tabs-wrapper h2 {
    display: none;
}

.cart-contents.desktop {
    display: flex;
    padding: 0 1rem;
    align-items: center;
    line-height: 1;
    height: 3.6rem;
    font-size: 2.4rem;
}

.cart-contents.desktop a {
    margin-bottom: -8px;
}

.cart-contents {
    align-items: center;
    color: var(--rls-red);
    border: 1px solid;
    background: white;
}

.cart-contents a {
    display: flex;
    align-self: center;
    line-height: 2.4rem;
}

p.product.woocommerce.add_to_cart_inline  {
    border: 0 !important;
    padding: 0 !important;
    display: flex;
    justify-content: center;
}

p.product.woocommerce.add_to_cart_inline span:first-child {
    display: none;
}

p.product.woocommerce.add_to_cart_inline a {
    width: max-content;
    height: min-content;
    border: 1px solid var(--rls-red);
    border-radius: 0;
    background: none !important;
    padding: 0.5rem 1rem 0rem 1rem;
    font-weight: normal;
    line-height: inherit;
    text-decoration: none;
    color: var(--rls-red);
    cursor: pointer;
}

/* Cart */
.woocommerce table.shop_table {
    border: 1px solid var(--rls-red);
    margin: 2rem 0rem;
    text-align: left;
    width: 100%;
    border-collapse: separate;
    border-radius: 0;
}

.woocommerce table.shop_table td {
    border-color: gray;
}

.woocommerce .coupon,
.woocommerce .checkout_coupon.woocommerce-form-coupon {
    display: none !important; 
}

.woocommerce .actions button.button {
    width: max-content;
    height: min-content;
    border-radius: 0;
    border: 1px solid var(--rls-red);
    background: var(--rls-red);
    padding: 0.5rem 1rem 0rem 1rem;
    font-weight: normal;
    line-height: inherit;
    text-decoration: none;
    color: white;
    cursor: pointer;
}

.woocommerce .cart-collaterals h2 {
    position: relative;
    text-transform: uppercase;
    font-family: 'Univers Extended Black';
    height: auto;
    top: 0;
    max-width: none;
    transform: translate(0);
    -ms-transform: translate(0);
    -webkit-transform: translate(0);
    font-size: 1.5rem;
    line-height: 1.5rem !important;
    color: var(--rls-red);
    z-index: 997;
    margin-bottom: 1rem;
}

.woocommerce a.checkout-button {
    background: var(--rls-red) !important;
}

/* Checkout */
.woocommerce .form-row {
    padding: 0 !important;
    margin: 0 !important;
}

.woocommerce .form-row.form-row-last {
    float: left !important;
    margin-left: 2rem !important;
}

.woocommerce .form-row input.input-text,
.woocommerce .form-row button.button,
.woocommerce select,
.woocommerce textarea.input-text {
    padding: 0.5rem 1rem 0rem 1rem !important;
    border-radius: 0 !important;
    border: 1px solid var(--rls-red) !important;
    font-weight: normal !important;
    line-height: normal !important;
}

.woocommerce textarea.input-text,
.woocommerce select {
    color: var(--rls-red);
}

.woocommerce .form-row input.input-text {
    background: white !important;
    color: var(--rls-red) !important;
}

.woocommerce .form-row button.button {
    background: var(--rls-red) !important;
    color: white !important;
}

.woocommerce form .form-row label {
    line-height: inherit !important;
}

.woocommerce .woocommerce-billing-fields__field-wrapper span.woocommerce-input-wrapper input,
.woocommerce .woocommerce-billing-fields__field-wrapper span.woocommerce-input-wrapper select {
    margin-bottom: 2rem !important;
}

.woocommerce ul.wc_payment_methods {
    padding: 0rem !important;
    border-bottom: 1px solid var(--rls-red) !important;
}

.woocommerce li.woocommerce-notice::before {
    color: var(--rls-red) !important;
}

.woocommerce div.woocommerce-checkout-payment {
    border: 1px solid var(--rls-red) !important;
    border-radius: 0 !important;
}

.woocommerce div.woocommerce-checkout-payment,
.woocommerce li.woocommerce-notice {
    background: none !important;
}

.woocommerce .woocommerce-info {
    border-top-color: var(--rls-red) !important;
}

.woocommerce div.woocommerce-checkout-payment .form-row.place-order {
    padding: 1em !important;
}

.woocommerce div.woocommerce-checkout-payment button.button {
    display: flex;
    float: none !important;
    margin-top: 1em;
    margin-left: auto;
    margin-right: auto;
}



@media (max-width: 991px) {

    h2 {
        position: relative;
        display: block;
        top: 0;
    }

    .site-main {
        padding-left: 2.5%;
        padding-right: 2.5%;
        margin-left: 0vw !important}

    .mobile-wrap {
        display: flex;
        align-items: center;
        max-height: var(--header-height);
    }

    .desktop-wrap{
        display: none !important;
    }

    .lang-select-mobile {
        display: flex;
        text-transform: uppercase;
        color: var(--rls-red);
        max-height: 3.6rem;
        margin-right: 1rem;
        overflow: hidden;
    }

    /* For .lang-select-mobile */
    .open-select {
        overflow: visible !important;
    }

    .lang-select-mobile ul {
        list-style: none;
        margin: 0;
    }

    .lang-select-mobile ul.main-switcher {
        padding: 1rem;
        margin-top: -1rem;
        border: 1px solid transparent;
    }

    /* For ul.main-switcher */
    .open-switcher {
        background: white;
        border-color: var(--rls-red) !important;
    }

    .lang-select-mobile .main-switcher > li > span::after {
        content: '';
        position: relative;
        display: inline;
        border-top: solid 1.8rem var(--rls-red);
        border-right: solid 0.9rem transparent;
        border-bottom: solid 1.8rem transparent;
        border-left: solid 0.9rem transparent;
        top: 1.7rem;
        margin-left: 0.5rem;
    }

    .lang-select-mobile .sub-menu .active {
        display: none;
    }

    .share-options {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .share-options::after {
        content: '';
        position: relative;
        display: block;
        width: 100%;
        height: 1px;
        background-color: var(--rls-red);
        margin-top: 1rem;
    }

    .share-options span {
        width: 100%;
    }

    .share-options * {
        font-size: 2rem !important;
    }
    
    .share-options > a::before {
        content: '';
        position: absolute;
        width: calc(1.5rem * 0.5333);
        height: 1.5rem;
        background-color: red;
        margin-left: -1rem;
        margin-top: 4px;
    }
    
    .share-options > a:not(:first-child) {
        margin-left: 1rem;
        margin-right: 2rem;
        margin-top: 0rem;
    }

    .big-tri {
        border-top: 0.875rem solid transparent;
        border-left: 1.75rem solid var(--rls-red);
        border-bottom: 0.875rem solid transparent;}

    .small-tri {
        display: inline-block;
        width: 0;
        height: 0;
        border-top: 0.5625rem solid transparent;
        border-left: 1.125rem solid #767676;
        border-bottom: 0.5625rem solid transparent;}

    .splash-text-container {
        padding: 5rem 5rem;
    }

    .slideshow_block {
        display: grid;
        padding-left: 3rem;
        padding-right: 3rem;
        margin-bottom: 2rem;
    }

    /* WMPL */
    .wpml-ls-statics-shortcode_actions {
        font-size: 1.5rem !important;
    }

    .wpml-ls-statics-shortcode_actions ul::before,
    .wpml-ls-statics-shortcode_actions ul::after {
        content: '';
        position: absolute;
        width: 100%;
        height: 1px;
        background: var(--rls-red);
        left: 0rem !important;
    }

    .wpml-ls-statics-shortcode_actions li:first-child {
        padding-top: 2rem;
    }

    .wpml-ls-statics-shortcode_actions li:last-child {
        padding-bottom: 2rem;
    }

    .wpml-ls-statics-shortcode_actions li * {
        display: flex;
        align-self: flex-start !important;
        top: 0rem !important;
        padding-left: 0rem !important;
    }
    
    .wpml-ls-current-language a::before{
        content: '';
        align-self: flex-start;
        position: absolute;
        margin-top: 7px;
        left: 0rem;
        width: 1rem;
        height: 1rem;
        border-radius: 50%;
        background-color: var(--rls-red); 
    }

    .wpml-ls-item a:not(.wpml-ls-current-language)::before{
        content: '';
        align-self: flex-start;
        position: absolute;
        margin-top: 7px;
        left: 0rem;
        width: 1rem;
        height: 1rem;
        border-radius: 50%;
        border: 1px solid var(--rls-red);
    }

    /* E-Comm */
    .cart-contents.desktop {
        display: none !important;
    }
    
    .cart-contents.mobile {
        display: flex !important;
        margin-top: -5px;
        font-size: auto;
        margin-right: 1rem;
        padding: 0 0.5rem;
    }

    .cart-contents.mobile a {
        height: 2.4rem;
        display: flex;
        align-self: center;
        line-height: 3rem;
    }
}

/**********************
Mapbox Theme CSS
***********************/

.marker {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	cursor: pointer;
    background-color: var(--rls-red);
    transition: all 0.5s ease-in-out;
}

.marker:hover, .marker:focus, .marker:focus-within, .marker:active {
  background-color: var(--rls-red);
  width: 15px;
  height: 15px;
}

.mapboxgl-popup-content {
    font-family: 'Univers';
    padding: 2rem;
}

.mapboxgl-popup-content h6 {
    font-size: 2rem;
    margin-bottom: 1rem;
}

.mapboxgl-popup-content .city-state,
.mapboxgl-popup-content .country {
    font-size: 1.5rem;
}

button.mapboxgl-popup-close-button {
    padding: 2rem;
    font-size: 2rem;
    transition: all 0.1s ease-in-out;
}

button.mapboxgl-popup-close-button:hover {
    background: none !important;
    color: var(--rls-red);
}

.border {
    border-width: 1px;
    border-style: solid;
    border-color: inherit;
}

/* Ratio Wrappers */
/* Use these for content that needs to always display at a specific ratio; */
/* inner element then gets the classes 'p-absolute w-100 h-100 top-0 left-0' */                                                                                                                                                                             

.wrapper-1x1 {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 100%;
}

.wrapper-4x3 {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 75%;
}

.wrapper-16x9 {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
}

.wrapper-landscape {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 53.333%;
}

.wrapper-portrait {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 187.5%;
}

.wrapper-2x1 {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 50%;
}

.wrapper-1x1 img,
.wrapper-4x3 img,
.wrapper-16x9 img,
.wrapper-landscape img,
.wrapper-2x1 img,
.wrapper-portrait img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.object-fit-cover {
  object-fit: cover;
}

.transition-all {
    transition: all 0.2s ease;
}