/*
 Theme Name:   Turbo Makina
 Theme URI:    https://www.turbomakina.com
 Description:  Base Theme for Turbo Makina
 Author:       Berk Uralcan
 Author URI:   https://www.turbomakina.com
 Text Domain:  tm-theme
*/

/* REGISTER FONTS  */
@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-Black.woff2') format('woff2'),
        url('fonts/Montserrat-Black.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-BlackItalic.woff2') format('woff2'),
        url('fonts/Montserrat-BlackItalic.woff') format('woff');
    font-weight: 900;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-Bold.woff2') format('woff2'),
        url('fonts/Montserrat-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-BoldItalic.woff2') format('woff2'),
        url('fonts/Montserrat-BoldItalic.woff') format('woff');
    font-weight: bold;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-ExtraBoldItalic.woff2') format('woff2'),
        url('fonts/Montserrat-ExtraBoldItalic.woff') format('woff');
    font-weight: bold;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-ExtraBold.woff2') format('woff2'),
        url('fonts/Montserrat-ExtraBold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-ExtraLight.woff2') format('woff2'),
        url('fonts/Montserrat-ExtraLight.woff') format('woff');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-ExtraLightItalic.woff2') format('woff2'),
        url('fonts/Montserrat-ExtraLightItalic.woff') format('woff');
    font-weight: 200;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-Italic.woff2') format('woff2'),
        url('fonts/Montserrat-Italic.woff') format('woff');
    font-weight: normal;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-Light.woff2') format('woff2'),
        url('fonts/Montserrat-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-LightItalic.woff2') format('woff2'),
        url('fonts/Montserrat-LightItalic.woff') format('woff');
    font-weight: 300;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-Medium.woff2') format('woff2'),
        url('fonts/Montserrat-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-MediumItalic.woff2') format('woff2'),
        url('fonts/Montserrat-MediumItalic.woff') format('woff');
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-Regular.woff2') format('woff2'),
        url('fonts/Montserrat-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-SemiBold.woff2') format('woff2'),
        url('fonts/Montserrat-SemiBold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat-SemiBoldItalic.woff2') format('woff2'),
        url('fonts/Montserrat-SemiBoldItalic.woff') format('woff');
    font-weight: 600;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Neue Haas Grotesk Display Pro';
    src: url('fonts/NeueHaasDisplay-Medium.woff2') format('woff2'),
        url('fonts/NeueHaasDisplay-Medium.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Neue Haas Grotesk Display Pro';
    src: url('fonts/NeueHaasDisplay-Thin.woff2') format('woff2'),
        url('fonts/NeueHaasDisplay-Thin.woff') format('woff');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Neue Haas Grotesk Display Pro';
    src: url('fonts/NeueHaasDisplay-Bold.woff2') format('woff2'),
        url('fonts/NeueHaasDisplay-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Neue Haas Grotesk Display Pro';
    src: url('fonts/NeueHaasDisplay-Black.woff2') format('woff2'),
        url('fonts/NeueHaasDisplay-Black.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Neue Haas Grotesk Display Pro';
    src: url('fonts/NeueHaasDisplay-Roman.woff2') format('woff2'),
        url('fonts/NeueHaasDisplay-Roman.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}



/* VARIABLES  */

:root {

    color-scheme: light;

    --site-width: 88.33333%;
    --box-width: 135rem;

    --color-primary: #070e17;
    --accent-color: #d63e2d;
    --second-red: #e31e25;
    --third-red: #f23b3f;
    --alt-red-transparent:rgb(227, 30,37, 56%);
    --alt-red: rgb(227, 30,37);
    --accent-gray: #b2b2b2;
    --subtle-gray: #B2B2B2;
    --almost-black: rgb(53,53,53);
    --color-background: #fff;
    --color-text: #333;

    --header-height: 7rem;

/*     --body-font: "Montserrat", -apple-system, sans-serif;
    --heading-font: "Montserrat", -apple-system, sans-serif;
 */

    --body-font: "Neue Haas Grotesk Display Pro", -apple-system, sans-serif;
    --heading-font: "Neue Haas Grotesk Display Pro", -apple-system, sans-serif;

    --current-content-font-size: 1.85rem;
    --current-line-height: 1.885;
    --current-paragraph-margin: 1.5rem;


    --mobile-margin-top: 2.4rem;
    --mobile-margin-top-l: 3.6rem;
    --mobile-margin-top-xl: 4.2rem;

    --site-padding: 4rem;

    --section-margin-bottom: 6.4rem;
    --section-vertical-margin: 3.2rem 0;

    --space-xs: 0.8rem;
    --space-sm: 1.2rem;
    --space-md: 1.6rem;
    --space-lg: 2.4rem;
    --space-xl: 3.2rem;
}


/* RESETS */

*,
*::before,
*::after {
    box-sizing: border-box;
}

* {
    margin: 0;
    padding: 0;
}

html {
    font-size: 62.5%;
    scroll-behavior: smooth;
}

html,
body {
    scroll-behavior: smooth;
    height: 100%;
}

body {
    position: relative;
    font-family: var(--body-font);
    font-size: 1.6rem;

}

body a {
    color: var(--color-secondary);
    transition: color .2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    text-decoration: none;
    cursor: pointer;
}

body a:hover {
    color: var(--color-primary);
}

/* Wordpress overrides */

.site-container .alignwide {
    margin-left: calc(25% - 25vw);
    width: calc(50vw + 50%);
    max-width: calc(50vw + 50%);
}

.site-container .alignfull {
    margin-left: calc(50% - 50vw);
    width: 100vw !important;
    max-width: 100vw;
}

.single-post-container .alignwide {
    margin-left: calc(25% - 25vw);
    width: calc(50vw + 50%);
    max-width: calc(50vw + 50%);
}

.single-post-container .alignfull {
    margin-left: calc(50% - 50vw);
    width: 100vw;
    max-width: 100vw;
}

.alignfull {
    width: 100%;
}

.wp-block-cover__inner-container:has(.alignfull) {
    width: 100% !important;
}

.wp-block-embed iframe {
    width: 100%;
    height: 100%;
    aspect-ratio: 16 / 9;
}

/* Global */

    /* Containers */
.site-container {
    width: 100%;
    margin: 0 auto;
    padding-bottom: var(--site-padding);
}

.site-container.with-padding{
    padding-top: 10rem;
}

.ac-text-container {
    width: var(--box-width);
    margin: 0 auto;
    padding-top: calc(var(--header-height) + var(--site-padding));
    padding-bottom: var(--site-padding);
}

.single-post-container {}

.tm-narrow-container{
    width: var(--box-width);
    margin: 0 auto;
}

    /* Containers Responsive */

    @media screen and (max-width: 1300px) {
        .tm-narrow-container{
            width: 88%;
            padding: 0 1.6rem;
            margin: 0 auto;
        }
    }

.site-container h1 {
    font-size: 3.2rem;
    font-weight: 700;
    font-family: var(--heading-font);
    margin-bottom: 2rem;
}

.site-container h2 {
    font-size: 2.9rem;
    font-weight: 400;
    font-family: var(--heading-font);
    margin: 1.6rem 0;
}

.site-container h3 {
    font-size: 2.3rem;
    font-weight: 500;
    font-family: var(--heading-font);
    margin-bottom: 1.2rem;
}

.site-container h4 {
    font-size: 1.8rem;
    font-weight: 500;
    font-family: var(--heading-font);
    margin-bottom: 1.2rem;
}

.site-container h5 {
    font-size: 1.6rem;
    font-weight: 600;
    font-family: var(--heading-font);
    margin-bottom: 1rem;
}

.site-container p {
    font-size: 1.6rem;
    font-weight: 400;
    font-family: var(--body-font);
    margin-bottom: 1.6rem;
    color: var(--color-text);
    line-height: 1.6;
}

.site-container strong {
    font-size: 1.6rem;
    font-weight: bold;
}

.site-container em {
    font-style: italic;
}


.site-container ul,
.site-container ol {
    margin-left: 2rem;
    padding-left: 0;
    font-size: 1.6rem;
    line-height: 1.6;
    margin-bottom: 1.6rem;
}

.site-container ul li,
.site-container ol li {
    margin-bottom: 0.8rem;
}

.site-container blockquote {
    font-size: 1.8rem;
    font-style: italic;
    margin: 2rem 0;
    padding-left: 2rem;
    border-left: 4px solid var(--color-accent);
    color: var(--color-muted);
}

.site-container table {
    width: 100%;
    border-collapse: collapse;
    font-size: 1.6rem;
    margin-bottom: 2rem;
}

.site-container th,
.site-container td {
    padding: 1rem;
    border: 1px solid #ddd;
    text-align: left;
}

.site-container figcaption,
.site-container .caption,
.site-container small {
    font-size: 1.2rem;
    color: var(--accent-gray);
    line-height: 1.4;
}

    /* Typography Responsive  */

@media screen and (max-width: 1000px) {
    .site-container h1 {
        font-size: 2.4rem;
    }

    .site-container h2 {
        font-size: 2.1rem;
    }

    .site-container h3 {
        font-size: 1.8rem;
    }
    
}   

/* POSTS (AND PAGES) CONTENT AND CONTENT TYPE MODIFICATIONS */

.single-post-container p {
    font-size: 1.8rem;
    line-height: 1.8;
    color: var(--almost-black);
}

.single-post-container__content a>img {
    cursor: zoom-in;
}

.single-post-container__content img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin: 2rem auto;
}

.single-post-container__content img.alignleft {
    float: left;
    margin-right: 1rem;
}

.single-post-container__content img.alignleft {
    float: left;
    margin-right: 1rem;
}

.single-post-container__content img.alignright {
    float: right;
    margin-left: 1rem;
}


.single-post-container__content a:has(img.aligncenter) {
    margin: 2rem auto;
    width: 100%;
}

/* Single Post Content Modifications Responsive */

@media screen and (max-width: 1000px) {
    .single-post-container__content p{
        font-size: 1.7rem;
    }
}

/* HEADER */

header.site-header {
    height: var(--header-height);
    width: 100%;
    z-index: 99;
    background-color: white;
    position: fixed;
    transition: position 0.3s ease, box-shadow 0.3s ease;
}

header.scrolled {
    background-color: white;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.header-content {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    max-width: var(--box-width);
    margin: 0 auto;
    height: 100%;
    font-family: var(--body-font);
}

.header-elements {
    display: flex;
    align-items: center;
}

.header-items {
    display: flex;
    align-items: center;
    height: 100%;
}

.language-switcher {
    display: inline-block;
    font-size: 1.6rem;
    font-weight: 600;
    margin-left: 4rem;
    margin-top: .3rem;
}

.language-switcher a {
    text-decoration: none;
    color: #ffffff;
    font-weight: bold;
}

.language-switcher img{
    width: 20px;
    height: 20px;
    border-radius: 50%;
}

.language-switcher a:hover {
    text-decoration: none;
    color: var(--accent-color);
}

.logo-area {
    margin-top: 0;
    margin-right: 4rem;
    margin-bottom: 0;
}

.logo-area a {
    margin-right: 0;
    display: inline-flex;
    align-items: center;
}

.logo {
    width: 18.6rem;
/*     margin-top: 4px;
 */}

#main-navigation .main-navigation__list {
    display: flex;
    font-size: 1.5rem;
    color: var(--almost-black);
    list-style: none;
    font-family: var(--heading-font);
    font-weight:bold;
    letter-spacing: 0.55px;
    gap: 4rem;
    margin-bottom: unset;
}

#main-navigation .main-navigation__list li:last-child {
    margin-right: unset;
}



.responsive-menu__checkbox {
    display: none;
}

.navigation-button {
    display: none;
    width: 4rem;
    height: 100%;
    align-items: center;
    cursor: pointer;
    z-index: 9999;
}

input[type="checkbox"].navigation-button {
    display: none;
}


.navigation__icon {
    display: inline-block;
    position: relative;
    width: 3.3rem;
    height: 4px;
    background-color: var(--accent-color);
    border-radius: 3px;
    transition: all .2s;
    z-index: 3000;
}

.responsive-menu__navigation {
    position: absolute;
    right: 0;
    top: -3.3rem;
    background-image: linear-gradient(90deg, #070e17ef, #02070ee5);
    height: 130vh;
    padding: 0 2rem;
    overflow: hidden;
    visibility: hidden;
    width: 0vw;
    transition: width .3s, visibility .001s;
    font-family: var(--main-font);

}

.responsive-menu__checkbox:checked~.responsive-menu__navigation {
    display: flex;
    width: 25vw;
    flex-direction: column;
    visibility: visible;
    transition: all .2s;
    justify-content: flex-start;
    align-items: flex-start;
    z-index: 1999;
    box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.2);
}

.responsive-menu__navigation__list {
    list-style: none;
    margin-top: 12rem;
    font-size: 1.6rem;
    padding-left: 0;
    user-select: none;
    width: 100%;
    margin-bottom: 0;
}

.responsive-menu__navigation__list ul {
    list-style: none;
}


.responsive-menu__navigation__list li a {
    color: white;
    font-weight: 400;
    font-family: var(--content-font);
    text-decoration: none;
    display: flex;
    align-items: center;
    margin-bottom: 1.6rem;
}

.responsive-menu__navigation__list li ul {
    display: none;
    opacity: 0;
    transform: translateY(-10%);
    position: absolute;
}

.responsive-menu__navigation__list li ul.is-visible {
    display: block;
    position: unset;
    opacity: 100%;
    transform: translateY(0);
    animation: menu_fade_in 0.5s
}

.responsive-menu__navigation__list li ul.fade-out {
    animation: menu_fade_out 0.3s;
    transform: translateY(-10%);

}

#main-navigation .main-navigation__list li {
    position: relative;
}

#main-navigation .main-navigation__list li.menu-item-has-children > a::after {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid var(--almost-black);
    margin-left: 6px;
    vertical-align: middle;
}

#main-navigation .main-navigation__list .sub-menu {
    display: none;
    position: absolute;
    top: 150%;
    left: 0;
    background-color: white;
    border: 1px solid rgba(0, 0, 0, 0.15);
    padding: 1rem 0;
    min-width: 200px;
    border-radius: 4px;
    z-index: 1000;
    font-size: 1.6rem;
    list-style: none;
}

#main-navigation .main-navigation__list li:hover > .sub-menu {
    display: block;
    animation: menu_fade_in 0.3s ease;
}

/* Create hover-safe area */
#main-navigation .main-navigation__list li.menu-item-has-children::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -50%;
    height: 50%;
    background: transparent;
}

#main-navigation .main-navigation__list .sub-menu li {
    margin: 0;
    padding: 0.5rem 1rem;
}

#main-navigation .main-navigation__list .sub-menu li a {
    color: var(--almost-black);
    text-decoration: none;
    display: block;
    padding: 0.5rem;
    transition: color 0.2s ease;
}

#main-navigation .main-navigation__list .sub-menu li a:hover {
    color: var(--accent-color);
}



.responsive-menu__navigation__list ul li a:after {
    display: none;
}


.responsive-menu__navigation__list li.menu-item-has-children>a {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    pointer-events: none;
}

.responsive-menu__navigation__list li.menu-item-has-children a::after {
    content: url('images/down-arrow.svg');
    height: 24px;
    width: 24px;
    transform: rotate(-90deg) translateX(12%) translateY(75%);
    filter: invert(1);
    transition: transform .2s;
}

.responsive-menu__navigation__list li.menu-item-has-children a.is-active::after {
    transform: rotate(0deg) translateX(75%) translateY(20%);;
}

.responsive-menu__navigation__list .sub-menu {
    padding-left: 1.4rem;
    font-size: 1rem;
    list-style: none;
}

.navigation__icon::before {
    top: -.9rem;
    content: "";
    position: absolute;
    left: 0;
    width: 3.3rem;
    height: 4px;
    background-color: var(--accent-color);
    display: inline-block;
    border-radius: 3px;
    transition: all .2s;
}

.navigation__icon::after {
    content: "";
    position: absolute;
    top: .9rem;
    left: 0;
    width: 3.3rem;
    height: 4px;
    background-color: var(--accent-color);
    display: inline-block;
    transition: all .2s;
    border-radius: 3px;
}

.responsive-menu__checkbox:checked+.navigation-button .navigation__icon {
    background-color: rgba(0, 0, 0, 0);
    transform: translate(15vw, 0);
}

.responsive-menu__checkbox:checked+.navigation-button .navigation__icon::before {
    top: 0;
    z-index: 2000;
    transform: rotate(135deg);
}

.responsive-menu__checkbox:checked+.navigation-button .navigation__icon::after {
    top: 0;
    z-index: 2000;
    transform: rotate(-135deg);
}

.animation-enter {
    -webkit-animation: tracking-in-expand 0.7s cubic-bezier(0.215, 0.610, 0.355, 1.000) both;
    animation: tracking-in-expand 0.7s cubic-bezier(0.215, 0.610, 0.355, 1.000) both;
}

/* Header Search */

.search-icon {
    cursor: pointer;
    margin: 0 4rem;
    margin-top: .5rem;
}

.search-icon img {
    width: 15px;
    height: 15px;

}

.search-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: var(--header-height);
    background: var(--color-primary);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

.search-overlay.active {
    display: flex;
}

.search-form {
    width: 100%;
    position: relative;
    display: flex;
    align-items: center;
}

.search-input {
    width: 100%;
    padding: 15px 50px 15px 20px;
    background: transparent;
    font-size: 24px;
    border: none;
    color: white;

    outline: none;
}

.search-submit {
    padding: 5px 10px;
    background-color: white;
    font-family: var(--typing-font);
    font-size: 1.6rem;
    border-radius: 5px;
}

.search-close {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 32px;
    color: white;
    padding: 0 15px;
}

.search-overlay {
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
}

.search-overlay.active {
    opacity: 1;
    visibility: visible;
}

.search-input::-webkit-search-cancel-button {
    -webkit-appearance: none;
    appearance: none;
}

/* Header search responsive */

@media screen and (max-width: 1000px) {
    .search-input {
        font-size: 1.5rem;
    }
}

/* Header responsive */

@media screen and (max-width: 1000px) {

    .navigation-button {
        display: flex;
    }

    .header-desktop,
    .language-switcher-desktop {
        display: none
    }

    .header-content{
        justify-content: space-between;
        padding: 0 2.4rem;
    }

    .language-switcher-mobile {
        font-size: 2rem;
        margin-left: 0;
    }

    .search-icon{
        display: none;
    }

    #main-navigation {
        display: none;
    }

    .responsive-menu__checkbox:checked~.responsive-menu__navigation {
        width: 50vw;
    }

    .responsive-menu__checkbox:checked+.navigation-button .navigation__icon {
        transform: translate(50%, 0);
    }


    .responsive-menu__checkbox:checked~.responsive-menu__navigation {
        width: 50vw;
    }

    ul.sub-menu.is-visible li {
        font-size: 1.6rem;
    }


}

/* Search Page */

header.search-header {
    display: flex;
    align-items: baseline;
    gap: .3rem;
    font-family: var(--typing-font);
}

.search-header span {
    font-size: 3.6rem;
    color: #070e17;
}

.search-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 2%;
    row-gap: 4rem;
}

.search-item {
    cursor: pointer;
}

section.search-section {
    margin-top: 6rem;
    margin-bottom: 6rem;
}

.search-item a {
    display: block;
}

.search-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 4/3;
}

.search-item h3 {
    font-size: 2rem;
    margin-top: 1rem;
    margin-bottom: 0;
    font-weight: 300;
}

.search__no-results {
    min-height: 60vh;
}

/* Search Page Responsive */

@media screen and (max-width: 1000px) {
    .search-grid {
        grid-template-columns: repeat(2, 1fr);
        row-gap: 4rem;
    }

    .search-item h3 {
        font-size: 1.6rem;
    }
}

/* Homepage */

    /* Homepage Slider */

.homepage-slider.swiper{
    height: 80vh;
    width: 100%;
    padding-top: var(--header-height);
}

.slide-container{
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
}

.slide-content-area{
    max-width: var(--box-width);
    margin-left: auto;
    margin-right: auto;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.slide-content-container{
    background-color: var(--alt-red-transparent);
    color: white;
    max-width: 50%;
}

.slide-content-container:not(:has(.slide-link-container)){
    border-bottom: 10px solid var(--alt-red);
}

h3.slide-title{
    font-size: 5rem;
    font-family: var(--heading-font);
    color: white;
    margin-bottom: 4rem;
    padding: 2rem 0 0 4rem;

}

.slide-content{
    font-size: 1.5rem;
    font-weight: 700;
    padding: 0 4rem 2rem 4rem;
}

.slide-link-container{
    background-color: var(--alt-red);
    padding: .7rem 2rem;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    font-size: 1.5rem;
    font-weight: 700;
}

.slide-link-container a{
    display: inline-flex;
    align-items: center;
}

.slide-link-container a:hover{
    text-decoration: none;
    color: white;
}

.slide-link-container a::after{
    content: "\2192";
    background-color: white;
    height: 15px;
    width: 15px;
    color: var(--alt-red);
    display: flex;  
    align-items: center;
    font-size: 1.5rem;
    justify-content: center;
    border-radius: 100%;
    margin-left: 1rem;
    padding-bottom: 2px;
}

.homepage-slider .swiper-button-prev,
.homepage-slider .swiper-button-next{
    color: var(--alt-red);
}

section.product-area{
    position: relative;
}

.homepage-separator-full{
    width: 100%;
    height: 7rem;
    position: absolute;
    top: -3rem;
    left: 0;
    z-index: 1;
}

.homepage-separator-thin{
    height: 3rem;
}

 /* Homepage Products  */

 .hp-products-row{
    overflow-x: auto;
    height: 32rem;
    display: flex;
    align-items: center;
}

.hp-products-row .wp-block-cover,
.hp-product-item{
    max-width: 23.5%;
    height: 32rem !important;
    max-height: 32rem !important;
}

.hp-products-row span{
    max-height: 32rem !important;
}

.hp-products-row .wp-block-cover img{
    max-height: 32rem !important;
    object-fit: cover;
    filter: brightness(0.7);
}

.hp-cover-elements{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    height: 29rem;
}

.hp-product-title{
    font-size: 3.2rem !important;
    font-weight: 700 !important;
    text-align: center;
    text-shadow: -1px -1px 1px rgba(255, 255, 255, 0.1), 2px 2px 1px rgba(125, 125, 125, 0.31);
    font-weight: 900;
}

.hp-product-button a{
    background-color: white;
    padding: 1.2rem 2.5rem;
    border-radius: 2px;
    font-size: 1.5rem;
    color: #787878;
    font-size: 1.5rem;
    font-family: var(--body-font);
}   


.hp-ft-column{
    margin-top: 1rem;
    padding: 1.6rem;
    background-color: #f9f9f9;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    border-radius: 10px;
}

h3.product-title{
    font-size: 2.8rem;
    color: var(--second-red);
    margin-bottom: 1.5rem;
}

p.ft-product-text{
    font-size: 1.8rem;
    color: var(--almost-black);
    line-height: 1.6;
}

p.hp-product-link{
    padding-right: 1.6rem;
    font-size: 1.8rem;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.hp-product-link::after{
    content: "\2192";
    background-color: #555;
    height: 20px;
    width: 20px;
    color: white;
    display: flex;  
    align-items: center;
    font-size: 1.8rem;
    justify-content: center;
    border-radius: 100%;
    margin-left: 1rem;
    padding-bottom: 2px;
}

    /* Homepage Logos */

    .hp-logo-row-turbo-logo{
        flex-basis: 45rem !important;
        min-width: 45rem !important;
    }

    .hp-logo-row-turbo-logo img{
        width: 100% !important;
    }

    .hp-partner-logo img{
        max-width: 15rem;
        max-height: 10rem;
        object-fit: contain;
        user-select: none;
    }

    /* Homepage Latest Fair */

    .hp-latest-fair{
        position: relative;
        z-index: 2;
    }

    .hp-latest-fair li{
        display: flex;
        gap: 2.4rem;
    }

    .hp-latest-fair h2{
        font-size: 3.75rem;
        font-weight: 800;
        color: var(--almost-black);
        line-height: 1.1;
        margin-top: 0 !important;
    }

    .hp-latest-fair .all-fairs-link{
        font-weight: 600;
        color: var(--second-red);
        font-size: 1.8rem;
        display: flex;
        align-items: center;
        gap: .5rem;

    }

    .has-small-decor-left{  
        position: relative;
    }

    .has-small-decor-left::before{
        content: "";
        height: 7rem;
        width: 30%;
        background-color: var(--second-red);
        position: absolute;
        top: 25%;
        left: 0;
    }

    .hp-latest-fair .all-fairs-link a:hover{
        text-decoration: underline;
        color: var(--second-red) !important;
    }

    .hp-latest-fair .all-fairs-link::after{
        content: "\2192";
        background-color: var(--second-red);
        color: white;
        border-radius: 100%;
        margin-left: .5rem;
        font-size: 1.6rem;
        font-weight: 400;
        display: flex;
        align-items: center;
        justify-content: center;
        line-height: 1;
        margin: 0;
        width: 1.5rem;
        height: 1.5rem; 
    }

.hp-recent-posts-container{
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(25%, 1fr));
    gap: 2.4rem;
    align-items: stretch;
    align-content: stretch;
    max-width: 100%;
}

h2.hp-recent-posts-title{
    font-size: 3.75rem !important;
    font-weight: 800 !important;
    color: var(--almost-black);
    line-height: 1.1;
    margin-bottom: 2.4rem;
    grid-column: 1 / -1;
}

.hp-recent-posts-container .hp-recent-posts__post{
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
    height: 100%;
    justify-content: flex-start;
    max-width: 100%;
}
.hp-recent-posts-container .hp-recent-posts__post img{
    width: 100%;
    border-radius: 0;
    height: 40rem;
}

.hp-recent-posts-container .hp-recent-posts__post h4{
    font-size: 2rem;
    font-weight: 700;
    color: var(--almost-black);
    margin-bottom: 1rem !important;

    /* Limit to a single line */
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}

.hp-recent-posts-container .hp-recent-posts__post p{
    font-size: 1.6rem;
    margin: 0 !important;
    font-weight: 400;
    color: var(--almost-black);
}

.hp-recent-posts-container .hp-recent-posts__post-read-more{
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--second-red);
    margin-top: 1rem;
}

.hp-recent-posts-container .hp-recent-posts__post-read-more::after{
    content: "\2192";
    background-color: var(--second-red);
    color: white;
    border-radius: 100%;
    margin-left: 1rem;
    height: 20px;
    width: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding-bottom: 2px;
}


/* Home Page Responsive */

@media screen and (max-width: 1280px) {

    .hp-recent-posts-container{
        grid-template-columns: repeat(2, 49%);
    }

    .hp-recent-posts-container .hp-recent-posts__post img{
        height: 30rem;
        max-width: 100%;
    }

    .hp-recent-posts-container .hp-recent-posts__post h4{
        font-size: 1.8rem;
    }
}

@media screen and (max-width: 1000px) {

    .homepage-slider.swiper{
        height: 50vh;
    }

    .slide-content-area{
        justify-content: center;
    }

    .slide-content-container{
       max-width: 75%;
    }

    h3.slide-title{
        font-size: 2.5rem;
        padding: 2rem 2.4rem 0 2.4rem;
    }

    .slide-content{
        font-size: 1.4rem;
        padding: 0 2.4rem 2rem 2.4rem;

    }

    .slide-link-container{
        font-size: 1.3rem;
    }

    .swiper-button-prev,
    .swiper-button-next{
        width: 2.5rem !important;
        height: 2.5rem !important;
    }

    .swiper-button-prev::after,
    .swiper-button-next::after{
        font-size: 2.4rem !important;
    }

    .hp-products-row .wp-block-cover,
    .hp-product-item{
        max-width: 100svw;
        margin: 0 auto;
    }

    .hp-cover-elements{
        max-width: 80%;
        margin: 0 auto;
    }

    .hp-product-title{
        font-size: 2.4rem !important;
    }

    p.hp-product-link{
        text-align: left;
        justify-content: flex-start;
    }

    .hp-logo-row-turbo-logo{
        display: none;
    }

    .hp-logo-row-turbo-logo img{
        width: 100% !important;
    }

    .hp-partner-logo img{
        max-width: 10rem;
        max-height: 5rem;
        object-fit: contain;
        user-select: none;
    }

    .hp-latest-fair li{
        flex-direction: column;
        align-items: center;
    }

    .hp-latest-fair figure{
        max-width: 90%;
        margin: 0 auto;
    }

    .hp-latest-fair li h2{
        font-size: 2.8rem;
    }

    .hp-latest-fair li .wp-block-group{
        max-width: 90%;
        margin: 0 auto;
    }

    .has-small-decor-left::before{
        height: 15rem;
        width: 100%;
        left: 0;
        top: -2rem;
    }

    .hp-recent-posts-container{
        display: flex;
        flex-direction: column;
    }





}

/* Pages */

.section-header{
    padding-top: calc(var(--header-height) + var(--site-padding));
    background-size: cover;
    background-repeat: no-repeat;
    height: clamp(44rem, 44vh, 54rem);
    margin-bottom: 3rem;
}

.default-section-header{
    background-size: cover !important;
    background-repeat: no-repeat !important;
    background-position: center 15% !important;
}

.section-header-content{
    display: flex;
    align-items: center;
    justify-content: flex-end;
    height:100%;
}

h1.section-header-title{
    font-size: 4.95rem;
    color: white;
    font-weight: 800;
    line-height: 1.1;
    background-color: var(--alt-red-transparent);
    max-width: 50%;
    width: 100%;
    padding: 2rem 4rem;

}



     /* Pages Responsive  */

@media screen and (max-width: 1000px) {
    .section-header{
        height: clamp(30rem, 30vh, 45rem);
    }

    .default-section-header{
        background-position: top !important;
    }
    
    .section-header-content{
        justify-content: center;
    }

    h1.section-header-title{
        font-size: 3.5rem;
        max-width: 100%;
        text-align: center;
    }

    .certificates-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    
}

/* Fairs Archive */

.archive-title{
    font-size: 3.75rem !important;
    font-weight: 700;
    margin-bottom: 4.5rem !important;
}

.archive-grid{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 3.6rem;
}

.archive-fair-image{
    max-width: 100%;
    height: 40rem;
    object-fit: cover;
    border-radius: 10px;
}

.fair-title{
    font-size: 2rem !important;
    font-weight: 700 !important;
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important; 
}

.archive-fair-excerpt{
    font-size: 1.5rem !important;
    font-weight: 400 !important;
    margin-bottom: .7rem !important;
}

.archive-fair-info-container{
    display: flex;
    flex-direction: row;

    justify-content: space-between;
    align-items: center;
}

.archive-fair-info-container p{
    color: var(--almost-black);
    font-weight: 600;
    font-size: 1.4rem !important;
}

    /* Fairs Archive Responsive */

@media screen and (max-width: 1000px) {
    .archive-grid{
        grid-template-columns: repeat(1, 1fr);
        gap: 3.6rem;
        margin-bottom: 3.6rem;
    }

    .archive-fair-image{
        height: 30rem;
    }

    
    
}

/* Blog Archive */

.blog-grid{
    grid-template-columns: repeat(3, 1fr);
    gap: 2.4rem;
}

.blog-item{
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    border-radius: 10px;
    border: 1px solid #e0e0e0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.blog-title,
.archive-blog-excerpt,
.blog-read-more{
    padding: 0 1.6rem;
}

.blog-title{
    font-size: 2rem !important;
    font-weight: 700 !important;
    margin: 1.6rem 0;
}

.blog-item img{
    max-width: 100%;
    height: 20rem;
    object-fit: cover;
    border-radius: 10px;
} 

a.blog-read-more{
    font-size: 1.4rem !important;
    font-weight: 600 !important;
    color: var(--second-red) !important;
    margin: 1.6rem 0;
    align-self: flex-end;
}

.blog-item:hover .blog-read-more{
    text-decoration: underline;
}

.blog-read-more::after{
    content: "\2192";
    background-color: var(--second-red);
    color: white;
    border-radius: 100%;
    margin-left: 1rem;
    height: 20px;
    width: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding-bottom: 2px;
}

.blog-pagination{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.6rem;
    margin: 3.6rem 0;
}

.page-numbers.current,
.blog-pagination a{
    font-size: 1.4rem !important;
    font-weight: 600 !important;
    border: 1px solid var(--second-red);
    padding: 1.6rem 2rem;
    color: var(--second-red) !important;
}

.page-numbers.current{
    background-color: var(--second-red);
    color: white !important;
}

    /*  Blog Archive Responsive */

@media screen and (max-width: 1000px) {
    .blog-grid{
        grid-template-columns: repeat(1, 1fr);
    }

    .blog-item img{
        height: 30rem;
    }

    .blog-title{
        font-size: 1.8rem !important;
    }
}

/* Archive Brands */

.brand-item{
    border: 1px solid #e0e0e0;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    transition: box-shadow 0.3s ease;
    margin-bottom: 6rem;
    padding: 2.4rem;
    transition: box-shadow 0.3s ease;
    border-top: 20px solid var(--accent-color);
    position: relative;
}

.brand-item:hover{
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}



.brand-container{
    display: flex;
    align-items: center;
}

.brand-content{
    display: flex;
    flex-direction: column;
    padding: 1.6rem;
    flex-basis: 60%;
}

.brand-logo{
    flex-basis: 30%;
    max-width: 30%;
    max-height: 20rem;
    object-fit: contain;
}

.brand-title{
    font-size: 2.8rem !important;
    font-weight: 700 !important;
    margin-top: 2.4rem;
    padding-left: 1.6rem;
}

.brand-excerpt{
    font-size: 1.5rem !important;
    font-weight: 400;
    padding-left: 1.6rem;
}

.brand-link{
    font-size: 1.5rem !important;
    font-weight: 600 !important;
    margin: 1.6rem 0;
    align-self: flex-end;
    position: absolute;
    bottom: .67rem;
    right: 2.4rem;
    line-height: 1;
}

.brand-link::after{
    content: "\2192";
    background-color: var(--second-red);
    color: white;
    border-radius: 100%;
    margin-left: .3rem;
    height: 15px;
    width: 15px;
    font-size: 1.5rem !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    padding-bottom: 1px;
}

/* Archive Brands Responsive */

@media screen and (max-width: 1000px) {

    .brand-container{
        flex-direction: column;
        align-items: flex-start;
    }

    .brand-logo{
        max-width: 75%;
        max-height: 20rem;
        margin: 0 auto;
        align-self: center;
    }

   
}

/* Single Brands */

.brands-section-header{
    padding-top: var(--header-height);
}

.brand-meta{
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
    margin-bottom: 2.4rem;
}

.brand-thumbnail-container{
    display: flex;
    justify-content: center;
    align-items: center;
}
.brand-thumbnail{
    height: auto;
    max-width: 100%;
    object-fit: contain;
    margin: 2.4rem auto;
}

.brand-meta strong{
    color: var(--second-red);
}

.related-products{
    margin: 3.6rem 0; 
}

.related-products-grid{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2.4rem;

}

.related-product-item{
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    border: 1px solid #e0e0e0;
    transition: box-shadow 0.3s ease;
}

.related-product-item:hover{
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}
.related-product-item img{
    width: 100%;
    height: 20rem;
    object-fit: cover;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    margin-bottom: 1.6rem;
}

.related-product-title{
    font-size: 1.8rem !important;
    font-weight: 700 !important;
    margin-bottom: 1.6rem !important;
    padding: 0 1.6rem !important;
}



.brand-button-row{
    display: flex;
    flex-direction: row;
    gap: 1.6rem;
    margin: 4.2rem 0;
}

.brand-button{
    background-color: var(--second-red);
    color: white;
    padding: 1.6rem 2rem;
    border-radius: 4px;
    font-weight: 600;
    font-size: 1.6rem;
    border: none;
    text-decoration: none;
    transition: background-color 0.3s ease;
    display: flex;
    align-items: center;
    gap: .8rem;
}

.brand-button:hover{
    background-color: var(--third-red);
    color: white;
}

/* Single Brands Responsive */

@media screen and (max-width: 1000px) {
    .related-products-grid{
        grid-template-columns: repeat(2, 1fr);
    }

    .related-product-item img{
        height: 15rem;
    }

    .related-product-title{
        font-size: 1.5rem !important;
    }
}

/* Single Fairs and Posts */

.fair-article-container{
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    padding: 2.5rem;
    border-radius: 10px;
    margin-bottom: 2.5rem;
}

.post-metas{
    margin-bottom: 2.5rem;
    color: rgb(136, 136, 136);
    font-size: 1.4rem;
}

.fair-thumbnail{
    max-width: 100%;
    width: 100%;
    margin-bottom: 2.5rem;
    height: 40rem;
    object-fit: cover;
    border-radius: 10px;
}

.fair-info-container{
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

.fair-info-container h4, 
.fair-info-container p{
    font-size: 1.5rem !important;
    margin-bottom: 0;
}

.fair-info-item{
    display: inline-flex;
    align-items: center;
    gap: .4rem;
}

h4.fair-info-title{
    font-weight: 600;
}

p.fair-info-value{
    font-weight: 400;
}

h3.related-posts-title{
    font-size: 3.75rem !important;
    font-weight: 800;
    padding-left: 2rem;
    border-left: 6px solid var(--second-red);
    margin: 4.5rem 0;
}

/* Product Category Pages */

.product-category-grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2.4rem;
    max-width: var(--box-width);
    margin: 6rem auto;

}

.product-category-description{
    font-size: 1.8rem !important;
    font-weight: 400;
    margin-bottom: 2.4rem;
    max-width: var(--box-width);
    margin: 0 auto;
    grid-column: 1 / -1;
}

.category-grid-item{
    border: 1px solid #e0e0e0;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    transition: box-shadow 0.3s ease;
    transition: box-shadow 0.3s ease;
    position: relative;
}

.category-grid-item .overlay{
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 25rem;
    align-items: center;
    justify-content: center;
    background-color: var(--second-red);
    display: none;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
    border-top-right-radius: 10px;
    border-top-left-radius: 10px;
}


.overlay img{
    height: 5rem !important;
    width: unset !important;
    filter: brightness(0) invert(1);
}

.category-grid-product .overlay img{
    transform: rotateY(180deg);
}

.category-grid-item:hover .overlay{
    display: flex;
    opacity: .7;
    pointer-events: auto;
}

.category-grid-item a{
    display: flex;
    flex-direction: column;
    cursor: pointer;
}

.category-grid-item h3{
    font-size: 1.8rem !important;
    font-weight: 700 !important;
    padding: 1.6rem;
    margin-bottom: 0 !important;
}

.category-grid-item img{
    width: 100%;
    height: 25rem;
    object-fit: cover;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
}

/* Product Category Pages Responsive */

@media screen and (max-width: 1000px) {
    .product-category-grid{
        grid-template-columns: repeat(1, 1fr);
        padding: 0 1.6rem;
    }
}

/* Single Product */

.single-product-order-now{
    margin: 3.6rem 0;
}

a.brand-info-container{
    display: flex;
    align-items: center;
    gap: 1.6rem;
    text-decoration: none;
}

.brand-logo-container__text{
    margin-bottom: 0 !important;
    font-weight: 700 !important;
}

.brand-logo-container__logo{
    width: 10rem;
    height: 10rem;
    object-fit: contain;
}

.brand-logos-container{
    margin-top: 1.6rem;
    display: flex;
    flex-direction: row;
    gap: 3.6rem;
    align-items: flex-end;
}

.brand-logos-container a{
    display: flex;
    align-items: flex-end;
    gap: 1.6rem;
    text-decoration: none;
}

.product-all-categories{
    display: flex;
    gap: 2.4rem;
    max-width: var(--box-width);
    overflow-x: auto;
    margin: 6rem auto;
}

.product-category{
    border: 1px solid #e0e0e0;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    transition: box-shadow 0.3s ease;
    transition: box-shadow 0.3s ease;
    position: relative;
    width: 30%;

}

.product-category-image{
    max-width: 100%;
    height: 25rem;
    object-fit: cover;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    object-fit: cover;
    width: 100%;
}

p.product-category-name{
    font-size: 1.8rem !important;
    font-weight: 700 !important;
    padding: 1.6rem;
    margin-bottom: 0 !important;
}

    /* Single Product Responsive */

@media screen and (max-width: 1000px) {
    .product-all-categories{
        flex-direction: column;
    }

    h3.related-posts-title{
        font-size: 3.2rem !important;
    }

    .product-category{
        width: 100%;
    }

    p.product-category-name{
        font-size: 1.5rem !important;
    }
}

/* Single Post */

.blog-meta-category{
    font-weight: 600;
    color: var(--second-red);
}

/* Components */

.newsletter-container{
    background-color: #4a4a4a;
    padding: 3rem;
}



.newsletter-container__content{
    width: 50%;
    margin: 0 auto;
    text-align: center;
}

h2.newsletter-container__title{
    font-size: 2.2rem;
    font-weight: 400;
    margin-bottom: 1.5rem;
    color: white;
}

.newsletter-form{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .8rem;
    width: 100%;
    justify-content: center;
}

.newsletter-form-fields{
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
    gap: 1.6rem;
    width: 100%;
    margin-bottom: 1.6rem;
}

.newsletter-form-privacy-policy{
    display: flex;
    align-items: baseline;
    color: white;
    max-width: 75%;
    text-align:left;
    gap: 1.6rem;
    justify-content: center;
    font-size: 1.4rem;
}

.newsletter-form-privacy-policy a{
    color: var(--accent-color);
    white-space: nowrap;
}

.newsletter-form-fields input{
    border: none;
    border-radius: 4px;
    padding: 1.6rem 1.6rem;
    color: var(--almost-black);
    font-size: 1.6rem;
    width: 50%;
}

.newsletter-form input:focus{
    outline: none;
}

.newsletter-form button{
    background-color: var(--third-red);
    color: white;
    padding: 1.6rem 2rem;
    border-radius: 4px;
    font-weight: 200;
    font-size: 1.6rem;
    border: none;
}

    /* Newsletter Responsive */

@media screen and (max-width: 1000px) {
    .newsletter-container__content{
        width: 100%;
    }

    .newsletter-form input{
        padding: 1rem 1.6rem;
    }

    .newsletter-form button{
        padding: 1rem 1.6rem;
    }

    .newsletter-form-privacy-policy{
        max-width: 95%;
    }
}

/* Newsletter Message Styles */
.newsletter-message {
    margin-top: 1.6rem;
    padding: 1.2rem 1.6rem;
    border-radius: 4px;
    font-size: 1.4rem;
    font-weight: 500;
    text-align: center;
}

.newsletter-message.success {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}

.newsletter-message.error {
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}

.newsletter-form button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Related Posts */

.related-posts{
    display: flex;
    align-items: stretch;
}

.related-post{
    background-color: #f9f9f9;
    border-radius: 10px;
    text-align: left;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    height: 45rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 48rem;
    position: relative;
}

.hp-recent-posts-container .related-post{
    min-width: 45rem;
}

.related-post-thumbnail{
    width: 100%;
    height: 20rem;
    object-fit: cover;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    margin-bottom: 1.5rem;
}

h4.related-post-title{
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
    padding: 0 1.8rem;
    /* limit to 2 lines */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

p.related-post-excerpt{
    font-size: 1.5rem;
    padding: 0 1.8rem;
    height: 15rem;
}

a.related-post-link{
    color: var(--second-red);
    font-size: 1.5rem;
    font-weight: 300;
    padding: 0 1.8rem;
    margin-top: 1.5rem;
    position: absolute;
    bottom: 1.5rem;
    right: .3rem;
    display: flex;
    align-items: center;
    gap: .3rem;
}

a.related-post-link::after{
    content: "\2192";
    background-color: var(--second-red);
    height: 20px;
    width: 20px;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 100%;
    margin-left: 1rem;
    padding-bottom: 2px;
}

.related-buttons.swiper-button-prev,
.related-buttons.swiper-button-next{
    display: none;
}

@media screen and (max-width: 1000px) {


    h1.fair-title{
        font-size: 2.5rem !important;
    }

    h4.related-post-title{
        padding-left: 4rem;
    }

    p.related-post-excerpt{
        padding-left: 4rem;
    }

    .related-buttons.swiper-button-prev,
    .related-buttons.swiper-button-next{
        display: block;
        color: var(--second-red);
        width: 2.5rem !important;
        height: 2.5rem !important;
        font-size: 2.4rem !important;
        opacity: .7;
    }

    .related-buttons.swiper-button-prev::after,
    .related-buttons.swiper-button-next::after{
        font-size: 2.4rem !important;
        text-shadow: 0 0 10px rgba(164, 7, 7, 0.603);
    }

    .hp-recent-posts-container .related-post{
        min-width: 100%;
    }
}

/* User Generated Sliders */

.tm-ug-swiper{
    width: 100%;
    height: 60vh;
    margin-bottom: 3.6rem;
}

.tm-ug-swiper .swiper-slide img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 10px;
}

.tm-ug-swiper .swiper-button-next,
.tm-ug-swiper .swiper-button-prev{
    color: var(--second-red);
}

.tm-ug-swiper .swiper-button-next::after,
.tm-ug-swiper .swiper-button-prev::after{
    font-size: 2.4rem !important;
    text-shadow: 0 0 10px rgba(164, 7, 7, 0.603);
}

/* Contact page */

.contact-page-container{
    padding-top: var(--header-height);
}

.contact-information{
    height: 40rem;
    padding: 2rem 0;
}

#map {
    width: 100%;
    height: 37rem;
}

h2.contact-title{
    color: var(--almost-black);
    font-weight: 800;
    font-size: 2.7rem;
}


.ac-contact-form .wpforms-field-container{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 2.4rem;
    width: 100%;
}
.ac-contact-form .wpforms-field-container .wpforms-field-name,
.ac-contact-form .wpforms-field-container .wpforms-field-email,
.ac-contact-form .wpforms-field-container .wpforms-field-text{
    flex-basis: 31.3333%;
    display: flex;
    flex-direction: column;
    width: 100%;
}

.ac-contact-form .wpforms-field-container .wpforms-field-name input,
.ac-contact-form .wpforms-field-container .wpforms-field-email input,
.ac-contact-form .wpforms-field-container .wpforms-field-text input{
    min-width: 100%;
    border-width: 0 0 1px 0;
    border-color: var(--almost-black);
    border-radius: 0;
    padding-left: 0;
}

.ac-contact-form .wpforms-field-container .wpforms-field-textarea{
    flex-basis: 100%;
}

.ac-contact-form label.wpforms-field-label {
    font-size: 1.5rem !important;
    color: var(--almost-black);
    font-weight: 300 !important;
}

.ac-contact-form input:focus,
.ac-contact-form input:focus-visible,
.ac-contact-form input:focus-within {
    outline: none !important;
    border-width: 0 0 2px 0 !important;
    border-color: var(--almost-black) !important;
    box-shadow: none !important;

}

.ac-contact-form textarea {
    border-width: 0 0 1px 0 !important;
    border-color: var(--almost-black) !important;
    border-radius: 0 !important;
    resize: none !important;
    padding-left: 0 !important;

}

.ac-contact-form textarea:focus,
.ac-contact-form textarea:focus-visible,
.ac-contact-form textarea:focus-within {
    outline: none !important;
    border-width: 0 0 2px 0 !important;
    border-color: var(--almost-black) !important;
    box-shadow: none !important;
}


.ac-submit-button{
    background-color: var(--second-red) !important;
    color: white !important;
    font-weight: 600 !important;
    font-size: 1.5rem !important;
    padding: 1rem 2rem !important;
    border-radius: 0 !important;
    
}
/* Contact Page Responsive */

@media screen and (max-width: 1000px) {
    
    .contact-information{
        height: 100%;
    }
    
    .ac-contact-form .wpforms-field-container{
        flex-direction: column;
    }

    .ac-contact-form .wpforms-field-container .wpforms-field-name,
    .ac-contact-form .wpforms-field-container .wpforms-field-email,
    .ac-contact-form .wpforms-field-container .wpforms-field-text{
        flex-basis: 100%;
    }
    
}


/* Footer */

footer.site-footer {
    color: white;
    font-family: var(--body-font);
    background-color: #000000b5;
    width: 100%;
}

footer.site-footer p{
    color: white ;
}

.footer-container {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    padding: 4.5rem 0;
    width: var(--box-width);
    margin-left: auto;
    margin-right: auto;
    gap: 2rem;
}

.footer-left {
    font-size: 14px;
    flex: 0 0 25%;
    max-width: 25%;
}

.footer-logo{
    width: 20rem;
    margin-bottom: 1rem;
}

.footer-legal{
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.footer-menus-container{
    display: flex;
    gap: 6rem;
    flex: 0 1 50%;
    max-width: 50%;
    justify-content: flex-end;
}


.footer-contact {
    margin-left: 2.4rem;
}

.footer-contact-item{
    display: flex;
    flex-direction: column;
    margin: 1rem 0;
}



.footer-contact-form{
    display: block;
    text-decoration: none;
    color: white;
    font-size: 1.6rem;
    margin-bottom: 2.4rem;
}


h3.footer-menu__title {
    font-size: 2rem;
    font-weight: 600;
    margin-bottom: 1.6rem;
    margin-top: .6rem;
}

ul.footer-menu__menu {
    display: flex;
    flex-direction: column;
    list-style: none;
    margin-bottom: 0;
}

ul.footer-menu__menu li{
    margin-bottom: .75rem;
}

ul.footer-menu__menu li a {
    text-decoration: none;
    color: white;
    font-weight: 500;
    font-size: 1.6rem;
}

ul.footer-menu__menu li a:hover {
    text-decoration: underline;
}

a.footer-scroll-to-top {
    display: block;
    color: var(--color-primary);
    font-family: var(--gidole);
    text-align: center;
    text-decoration: none;
    width: 100%;
    padding-bottom: 1rem;
}

.footer-social-media {
    display: flex;
    gap: 2.215rem;
    align-items: center;
    justify-content: flex-start;
    margin: 1.6rem 0;
    margin-left: auto;
    margin-right: auto;
}

.footer-social-media a {
    display: block;
    border: 1px solid white;
    border-radius: 50%;
    width: 3.5rem;
    height: 3.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.footer-social-media a:hover {
    background-color: white;
}

.footer-social-media a:hover img {
    filter: brightness(0) invert(0);
}

.footer-social-media a img {
    width: 14px;
    height: auto;
    filter: brightness(0) invert(1);
}

.scroll-to-top {
    width: 2.2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 2.2rem;
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    color: white;
    line-height: 0;
    font-size: .70rem;
    background-color: var(--color-primary);
    cursor: pointer;
    opacity: 85%;
    font-family: var(--content-font);
    transition: all .5s;

    visibility: hidden;
    z-index: -99;
    pointer-events: none;
}

.scroll-to-top:hover {
    background-color: #363636;

}

.scroll-to-top__active {
    visibility: visible !important;
    z-index: 99 !important;
    pointer-events: all !important;
}

/* Footer responsive */

@media screen and (max-width: 1350px) {
    .footer-container{
        width: 90%;

    }
}

@media screen and (max-width: 1000px) {
    footer.site-footer {
        padding: 0
    }

    .footer-container {
        flex-direction: column;
        align-items: center;
        justify-content: center;
        text-align: center;
        gap: 1rem;
        width: 100%;
    }

    .footer-contact,
    .footer-menus-container{
        display: none;
    }

    .footer-contact{
        margin-left: unset;
    }

    .footer-left{
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        text-align: center;
        gap: 1rem;
        width: 100%;
        flex:unset;
        max-width: unset;
    }

    .footer-social-media{
        justify-content: center;
    }

    .scroll-to-top {
        width: 2rem;
        height: 2rem;
        font-size: .8rem;
    }
}

/* 404 Page */

.not-found-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-family: var(--gidole);
    min-height: 75vh;
}

.not-found-image {
    opacity: .8;
    margin-bottom: 2rem;
    filter: drop-shadow(0px 0px 10px rgba(141, 5, 5, 0.2));
}

.not-found-title {
    text-align: center;
    font-size: 2rem !important;
    color: var(--color-primary);
    margin-bottom: 1rem;
}

.not-found-actions-container form div {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 1rem;
}

.not-found-actions-container input {
    padding: .4rem;
    font-size: 1.2rem;
    border-radius: 6px;
    border: 2px solid var(--color-primary) !important;
    width: 90%;
}


.not-found-actions-container input[type="submit"] {
    background-color: var(--color-primary);
    color: white;
    cursor: pointer;
    width: 10%;
}

a.return-home {
    text-align: center;
    font-size: 1.2rem;
    color: var(--color-secondary);
    text-decoration: none;
    width: 100%;
    margin-top: 1.2rem !important;
    display: inline-block;
    cursor: pointer;
}

/* HELPERS AND UTILITIES */

.set-width{
    width: fit-content;
}

.line-height-top {
    line-height: .8 !important;
}

.no-padding-top {
    margin-top: calc((var(--header-height) + var(--site-padding)) * -1);
}

.no-padding-bottom {
    margin-bottom: calc(var(--site-padding) * -1);
}

.share-button {
    background: transparent;
    border: none;
}

hr.small-separator {
    margin-top: .3rem;
    margin-bottom: .6rem;
    height: 2px;
    background-color: var(--color-secondary);
    width: 5%;
    border: none;
}

hr.full-width-separator {
    width: 85%;
    margin: 2rem auto;
    height: 2px;
    background-color: var(--subtle-gray) !important;
}

.mobile-center-flex {
    display: flex;
    flex-direction: column;
    text-align: center;
    justify-content: center !important;
    align-items: center !important;
}

/* Custom color classes for text color */
.has-custom-blue-color {
    color: #20324b;
}

.has-custom-red-color {
    color: #ff3131;
}

.has-custom-gray-color {
    color: #B2B2B2;
}

.has-custom-white-gray-color {
    color: #d4d4d4;
}

/* Custom color classes for background color */
.has-custom-blue-background-color {
    background-color: #20324b;
}

.has-custom-red-background-color {
    background-color: #ff3131;
}

.has-custom-gray-background-color {
    background-color: #B2B2B2;
}

.has-custom-white-gray-background-color {
    background-color: #d4d4d4;
}

.has-horizontal-padding{
    padding-left: 2.4rem;
    padding-right: 2.4rem;
}

@media screen and (max-width: 1000px) {


    .has-mobile-margin-top {
        margin-top: var(--mobile-margin-top-xl);
    }

    .mobile-hidden {
        display: none;
    }

    .mobile-reverse{
        flex-direction: column-reverse;
    }

    .has-horizontal-padding,
    .has-mobile-padding {
        padding-left: 1.6rem;
        padding-right: 1.6rem;

    }

    .mobile-full-width {
        width: 100% !important;
    }

    .mobile-h2 {
        font-size: 24px !important;
    }

    .img-mobile-smaller{
        max-width: 30rem;
        margin: 0 auto;
    }

    .img-mobile-smaller img{
        max-width: 30rem;
    }

}

/* Animations */

@keyframes menu_fade_in {
    0% {
        transform: translateY(-10%);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes menu_fade_out {
    0% {
        transform: translateY(0);
        opacity: 100%;
    }

    100% {
        opacity: 10%;
        transform: translateY(-10%);
    }
}

/* VENDORS  */

    /* SWIPER */

