:root {
    --top-z-index: 999999999;
    --under-top-z-index: 999999998;
    --min-screen-width: 20rem;
    --line-height: 1.6;
    --font-family: 'Rubik', arial, sans-serif;
    --page-width: 90%;
    --page-width-padding: calc( (100% - var(--page-width)) / 2 );

    /* Primary */
    --color-primary: #c30c0c;
    --color-primary-darker: #ab0a0a;
    --color-on-primary: #ffffff;
    --color-on-primary-darker: #ffffff;

    /* Secondary */
    --color-secondary: #00473B;
    --color-on-secondary: #DBFFF9;

    /* Background */
    --color-background: #fbfbf9;
    --color-on-background: #260000;
    
    /* Surface */
    --color-surface: #F5F4F0;
    --color-on-surface: #260000;

    --button-font-size: 1rem;
    --button-font-weight: 300;
    --button-border-radius: .25rem;
}

@media (min-width: 1280px) {

    :root {
        --page-width: 70%;
    }

}

@font-face {
    font-family: 'Rubik';
    src: url('../fonts/Rubik/Rubik-VariableFont_wght.ttf') format('truetype');
    font-style: normal;
    font-weight: 300 900;
    font-display: swap;
}

*,
*::after,
*::before { 
    box-sizing: border-box;
}

* {
    margin: 0;
}

html {
    scroll-behavior: smooth;
}

body {
    min-height: 100vh;
    font-family: var(--font-family);
    font-weight: 300;
    line-height: var(--line-height);
    color: var(--color-on-background);
    -webkit-font-smoothing: antialiased;
    accent-color: var(--color-primary);
    background-color: var(--color-background);
}

p, h1, h2, h3, h4, h5, h6 {
    overflow-wrap: break-word;
}

a {
    color: inherit;
}

li {
    list-style: none;
}

img, picture, video, canvas, svg {
    display: block;
    max-width: 100%;
}

input,
textarea,
select,
button {
    font: inherit;
}

main {
    display: block;
    min-height: 80vh;
}

textarea {
    min-width: 100%;
    max-width: 100%;
}

.wpcf7 form {
    max-width: min(100%, 37.5rem);
    margin-top: 1.5rem;
}

.wpcf7 form p {
    margin-top: 1rem;
}

.wpcf7 form input:not(input[type="submit"]), 
.wpcf7 form select {
    width: 100%;
}

.wpcf7 form textarea, 
.wpcf7 form input:not(input[type="submit"]), 
.wpcf7 form select {
    margin-top: 0.25rem;
    padding: .5rem .75rem .5rem;
    border: 1px solid transparent;
    border-radius: .25rem;
    color: #676767;
    background-color: #f5f5f5;
    transition: filter .3s ease;
}

.wpcf7 form textarea:hover, 
.wpcf7 form input:not(input[type="submit"]):hover, 
.wpcf7 form select:hover {
    filter: brightness(98%);
}

.wpcf7 form input:not(input[type="submit"]).input-license-plate {
    /* position: relative; */
    /* padding-left: 60px; */
    /* font-weight: bold; */
    /* text-transform: uppercase; */
    /* letter-spacing: .25rem; */
    /* background-color: #f3b909; */
}

.wpcf7 form .wpcf7-submit {
    width: fit-content;
    padding-top: .25rem;
    padding-bottom: .25rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    border: 1px solid transparent;
    border-radius: .25rem;
    color: var(--color-on-primary);
    background-color: var(--color-primary);
    cursor: pointer;
}

.wpcf7 form .wpcf7-submit:active:not(:disabled) {
    transform: scale(0.98);
}

.isn-page {
    margin-top: 2rem;
}

.isn-wrapper {
    width: var(--page-width);
    margin-left: auto;
    margin-right: auto;
}

.isn-flex-wrap {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    column-gap: 1rem;
    row-gap: .75rem;
}

.isn-flex-col {
    display: flex;
    flex-direction: column;
}

.isn-pre-title {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1;
    color: var(--color-primary);
}

.isn-highlight {
    color: var(--color-primary);
}

/* BUTTON [START] */
.button {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    column-gap: .25rem;
    width: fit-content;
    padding-top: .25rem;
    padding-bottom: .25rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    border: none;
    border-radius: var(--button-border-radius);
    font-size: var(--button-font-size);
    font-weight: var(--button-font-weight);
    text-align: center;
    text-decoration: none;
    appearance: none;
    cursor: pointer;
}

.button svg {
    fill: currentColor;
}

/* Color variants */
.button--primary {
    color: var(--color-on-primary);
    background-color: var(--color-primary);
}

.button--secondary {
    color: var(--color-on-secondary);
    background-color: var(--color-secondary);
}

/* Modifiers */
.button--outline {
    border-width: 1px;
    border-style: solid;
    color: inherit;
    background-color: transparent !important;
}

.button--ghost {
    padding: 0;
    border: none;
    box-shadow: none;
    color: inherit;
    background-color: transparent !important;
}

/* States */
.button:hover:not(:disabled),
.button:focus:not(:disabled) {
    opacity: 80%;
}

.button:active:not(:disabled) {
    transform: scale(0.98);
}

.button:disabled {
    opacity: 50%;
    cursor: not-allowed;
}
/* BUTTON [END] */


/* ERROR-PAGE [START] */
.error-page__content {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.error-page__title {
    font-size: 6rem;
}

.error-page__message {
    font-size: 1.25rem;
    font-weight: normal;
}

.error-page__actions {
    margin-top: .5rem;
}
/* ERROR-PAGE [END] */


/* HEADER [START] */
.page-header {
    --header-inner-width: var(--page-width);
    --header-bg-color: var(--color-primary);
    --header-inner-bg-color: var(--header-bg-color);
    --header-navigation-bg-color: transparent;

    width: 100%;
    height: auto;
    border-bottom: 1px solid rgba(0, 0, 0, 6%);
    background-color: var(--header-bg-color);
}

.page-header__inner {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    column-gap: 2rem;
    row-gap: .5rem;
    width: var(--header-inner-width);
    height: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-top: .75rem;
    padding-bottom: .75rem;
    background-color: var(--header-inner-bg-color);
}

.page-header__link {
    width: fit-content;
}

.page-header__link:hover {
    filter: brightness(90%);
}

.page-header__nav {
    position: static;
    display: block;
    flex-grow: 1;
    flex-basis: 18.75rem;
    width: auto;
    height: auto;
    margin: 0;
    padding: 0;
    background-color: var(--header-navigation-bg-color);
}

.page-header__navigation-list {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    column-gap: 1.5rem;
    row-gap: .5rem;
    width: auto;
    min-height: auto;
    margin: 0;
    padding: 0;
}

.page-header__nav-button {
    color: var(--color-on-primary);
}

.button.page-header__nav-button--primary {
    color: var(--color-primary);
    background-color: #f4dfdd;
}

.page-header__nav-item {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    column-gap: .25rem;
    width: fit-content;
    padding-top: .25rem;
    padding-bottom: .25rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    border: none;
    font-size: var(--button-font-size);
    font-weight: var(--button-font-weight);
    text-align: center;
    text-decoration: none;
    appearance: none;
    color: #fff;
}

.page-header__nav-item svg {
    fill: currentColor;
}
/* HEADER [END] */


/* FOOTER [START] */
.page__footer {
    --footer-width: var(--page-width);
    --footer-bg-color: var(--color-primary);
    --footer-text-color: var(--color-on-primary);
    --footer-copyright-width: var(--footer-width);
    --footer-copyright-bg-color: var(--footer-bg-color);
    --footer-copyright-text-color: var(--footer-text-color);

    width: 100%;
    height: auto;
    margin-top: 5rem;
    background-color: var(--footer-bg-color);
}

.footer__inner {
    display: flex;
    flex-direction: column;
    justify-content: normal;
    width: var(--footer-width);
    height: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
    padding-left: 0;
    padding-right: 0;
    gap: 1.5rem;
    color: var(--footer-text-color);
}

.footer__copyright {
    width: 100%;
    font-size: .75rem;
    color: var(--footer-copyright-text-color);
    background-color: var(--footer-copyright-bg-color);
}

.footer-copyright__inner {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    column-gap: 2rem;
    align-items: center;
    justify-content: space-between;
    width: var(--footer-copyright-width);
    margin-left: auto;
    margin-right: auto;
    padding-top: .5rem;
    padding-bottom: .5rem;
}

.footer-copyright__powered-by {
    text-decoration: none;
}
/* FOOTER [END] */


/* FRONTPAGE [START] */
/* HERO */
.frontpage-hero {
    min-height: 40vh;
    padding-top: 3.5rem;
    padding-bottom: 3.5rem;
    background-color: #f8efed;
}

.frontpage-hero__body {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    column-gap: 2.5rem;
    row-gap: 1rem;
}

.frontpage-hero__content {
    flex-basis: 31.25rem;
    flex-grow: 1;
    padding: 1rem;
    border-radius: .5rem;
    box-shadow: 0 0 2px 1px #f3d8d6;
    background-color: #f6e6e4;
}

.frontpage-hero__title {
    font-size: 2rem;
    line-height: 1.2;
}

.frontpage-hero__paragraph {
    position: relative;
    max-width: 75ch;
    margin-top: .25rem;
    padding-left: 1rem;
    font-size: 1rem;
}

.frontpage-hero__paragraph::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    display: block;
    width: 2px;
    height: 100%;
    background-color: var(--color-primary);
}

.frontpage-hero__contact-actions {
    width: fit-content;
    margin-top: .75rem;
    padding: 1rem;
    border-radius: .5rem;
    background-color: #f4dfdd;
}

.frontpage-hero__actions {
    margin-top: 1.25rem;
}

.frontpage-hero__visual {
    flex-basis: 21.25rem;
    flex-grow: 1;
    height: auto;
    border-radius: .5rem;
    opacity: .9;
    overflow: hidden;
}

.frontpage-hero__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: blur(6px);
    transform: scale(1.01);
    opacity: .9;
    animation: hero-image 1s ease forwards;
    animation-delay: .1s;
}

@keyframes hero-image {
    to {
        filter: blur(0px);
        transform: scale(1.05);
        opacity: 1;
    }
}

/* STOCK */
.frontpage-stock {
    margin-top: 7.5rem;
}

.frontpage-stock__card {
    width: fit-content;
    margin-top: .75rem;
    padding: 1.25rem;
    border-radius: 8px;
    box-shadow: 1px 4px 4px 1px #f5e0de;
    background-color: #f8efed;
    transition: all .3s ease;
}

.frontpage-stock__card:hover {
    box-shadow: 1px 6px 4px 2px #f5e0de;
    transform: scale(1.01);
}

.frontpage-stock-card__img {
    border-radius: .25rem;
}

.frontpage-stock-card__title {
    margin-top: 1rem;
    font-size: 1.25rem;
}

.frontpage-stock-card__paragraph {
    font-size: 0.875rem;
}

.frontpage-stock-card__button {
    margin-top: .75rem;
}


/* TRADE */
.frontpage-trade {
    margin-top: 7.5rem;
}

.frontpage-trade__paragraph {
    font-size: 1rem;
}


@media (min-width: 1000px) {

    .frontpage-hero__content {
        padding: 2rem;
    }

    .frontpage-hero__title {
        font-size: 2.25rem;
        line-height: 1.3;
    }

}
/* FRONTPAGE [END] */