:root {
    --white: #F4F4F9;
    --dark-gray: #1F1F1F;
    --primary-green: #13F36E;
    --frost-glass: rgba(53, 53, 53, .65);
    --frost-stroke: rgba(244, 244, 249, .5);
}

* {
    box-sizing: border-box
}

html, body {
    height: 100%
}

body {
    margin: 0;
    background: #0a0a0a;
    color: var(--white)
}

.oswald {
    font-family: "Oswald", sans-serif
}

.barlow {
    font-family: "Barlow", sans-serif
}

.page-root {
    position: relative;
    width: 100%;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center
}

.hero-section {
    position: relative;
    width: 100%;
    background: var(--dark-gray);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center
}

.hero-background {
    position: absolute;
    inset: 0;
    overflow: hidden
}

.hero-background img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.topbar {
    width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
    margin-top: 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    position: relative
}

.logo-pos {
    position: absolute;
    top: 0;
    left: 2%;
}

.logo-wrapper {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    position: relative;
}

.logo-wrapper img {
    height: 100%;
    width: auto
}

@media (max-width: 991px) {
    .logo-pos {
        position: relative;
        left: 0
    }

    .logo-wrapper {
        margin-top: 0
    }
}

.hero-container {
    width: 100%;
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1rem;
    padding-right: 1rem;
    position: relative;
    margin-top: 200px;
    margin-bottom: 150px
}

@media (min-width: 1024px) {
    .hero-container {
        padding-left: 56px;
        padding-right: 56px
    }
}

@media (max-width: 991px) {
    .hero-container {
        margin-top: 0;
        margin-bottom: 0
    }
}

.hero-grid {
    display: grid;
    grid-template-columns:1fr;
    align-items: center;
    gap: 24px
}

@media (min-width: 1024px) {
    .hero-grid {
        grid-template-columns:1fr 1fr;
        gap: 32px
    }
}

.hero-text {
    color: #fff;
    font-size: 32px;
    line-height: 1;
    font-weight: 400;
    margin: 0
}

@media (min-width: 1024px) {
    .hero-text {
        font-size: 42px
    }
}

.car-box {
    display: flex;
    justify-content: center;
    align-items: center
}

@media (min-width: 1024px) {
    .car-box {
        width: 539px;
        height: 310.047px;
        justify-content: center;
        align-items: center;
        flex-shrink: 0;
        margin-left: auto
    }
}

.car-img {
    width: 100%;
    height: auto;
    object-fit: contain
}

@media (min-width: 1024px) {
    .car-img {
        width: 539px;
        height: 310.047px
    }
}

.footer {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
    padding-top: 64px;
    padding-bottom: 64px;
    overflow: hidden;
    background: #1F1F1F;
    color: #fff
}

@media (min-width: 768px) {
    .footer {
        padding-top: 96px;
        padding-bottom: 96px
    }
}

.footer-inner {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 48px;
    max-width: 1200px;
    width: 100%;
    z-index: 10
}

.footer-top {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 48px;
    width: 100%;
    margin-bottom: 56px
}

@media (min-width: 768px) {
    .footer-top {
        flex-direction: row
    }
}

.footer-info {
    flex: 1;
    font-size: 16px;
    line-height: 1.45
}

.footer-links {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0;
    margin: 16px 0 0 0;
    list-style: none
}

.footer-links a {
    color: #fff;
}

.footer-links li {
    padding-bottom: 8px
}

.underline-link {
    text-decoration: underline
}

.footer-company {
    flex: 1;
    font-size: 16px;
    line-height: 1.45;
    text-align: right
}

@media (max-width: 767px) {
    .footer-company {
        text-align: left
    }
}

.footer-bottom {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
    gap: 48px;
    flex-wrap: wrap
}

@media (min-width: 768px) {
    .footer-bottom {
        flex-direction: row
    }
}

.social-col {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 240px
}

.social-links {
    display: flex;
    gap: 16px;
    align-items: center
}

.semi {
    font-weight: 600
}

.footer-logo {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
    flex: 1
}

.footer-logo img {
    width: 176px;
    max-width: 100%;
    height: auto
}

.footer-logo p {
    font-size: 16px;
    line-height: 1.45;
    text-align: right
}

.tilt {
    transform: rotate(0.59deg)
}

@media (max-width: 991px) {
    .footer-bottom {
        align-items: center;
        gap: 20px
    }

    .footer-logo {
        align-items: center
    }

    .footer-logo p {
        text-align: center
    }
}
