/* Site Navbar */
body > header {
    --margin: 15px;
    --side-margin: calc(((100vw - var(--content-width)) / 2) + var(--margin));

    position: absolute;
    top: var(--margin);
    left: var(--side-margin);
    right: var(--side-margin);
    border-radius: 30px;
    padding: 15px 30px;
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    z-index: var(--stacking-level-header);

    /* backdrop-filter: blur(10px); */
    background-color: rgba(0, 0, 0, 0.5);

    #logo {
        height: 35px;
    }

    #desktop-nav { display: none; }
    #mobile-nav { 
        display: block;
        position: relative;

        #nav-menu-icon {
            display: block;
            cursor: pointer;
            fill: var(--color-white);
            height: 35px;
            width: 35px;
        }

        .menu {
            display: none;
            position: absolute;
            top: calc(100% + 12px);
            right: 0;
            background-color: rgba(0, 0, 0, 0.85);
            backdrop-filter: blur(10px);
            -webkit-backdrop-filter: blur(10px);
            border-radius: 15px;
            padding: 12px 8px;
            min-width: 180px;
            flex-flow: column nowrap;
            gap: 4px;
            z-index: calc(var(--stacking-level-header) + 1);

            a {
                display: block;
                padding: 10px 16px;
                border-radius: 8px;
                white-space: nowrap;

                &:hover {
                    background-color: rgba(255, 255, 255, 0.1);
                }
            }

            &[data-state="open"] {
                display: flex;
            }
        }
    }

    nav {
        a {
            color: var(--color-white);
            text-decoration: none;
            text-transform: uppercase;
            letter-spacing: 0.1em;
        }
    }
}

/* Site footer */
body > footer {
    color: white;

    display: grid;
    grid-template-columns: repeat(2, 50%);

    overflow: hidden;
    max-width: 100vw;

    h3 {
        font-family: "Inter", sans-serif;
        font-weight: bold;
        text-transform: uppercase;
    }

    .footer__column {
        padding-left: var(--content-margin);
        display: flex;
        flex-flow: column nowrap;
        line-height: 1.75rem;
        font-size: var(--font-size-md);
        margin-top: var(--content-margin);
    }

    #map {
        margin: var(--content-margin) 0;
        grid-row: 3;
        grid-column: 1 / 3;
        justify-self: center;
    }

    #footer-services {
        grid-row: 1;
        grid-column: 2;
    }

    #footer-info {
        grid-row: 1;
    }

    #footer-locations {
        grid-row: 2;
        grid-column: 1 / 3;
    }
}

header > h2 {
    font-size: var(--font-size-lg);
}

@media screen and (width >= 567px) {
    body > footer {
        display: flex;
        flex-flow: row wrap;
        justify-content: space-around;
        gap: 100px;

        .footer__column {
            line-height: 2rem;
            font-size: unset;
            min-width: 200px;
        }
    }

    body > header {
        #desktop-nav { 
            display: flex; 
            flex-flow: row nowrap;
            align-items: center;
            gap: 30px;
        }
        #mobile-nav { display: none; }
    }
}

.map {
    --map-size: min(400px, calc(100vw - 64px));
    width: var(--map-size);
    height: var(--map-size);
    min-width: var(--map-size);
    min-height: var(--map-size);
}

.card {
    border-radius: 15px;
    display: flex;
    flex-flow: column nowrap;
    padding: 35px 20px;

    header {
        margin-top: 30px;
        flex: 1;

        .sub {
            text-transform: uppercase;
        }

        h3 {
            margin: 0;
            margin-top: 5px;
            font-size: clamp(24px, 3vw, 42px);
        }
    }
}

.actions {
    display: flex;
    flex-flow: row wrap;
    gap: 15px;

    a {
        letter-spacing: 10%;
        border: 3px solid var(--color-blue);
        border-radius: 25px;
        padding: var(--spacing-sm) var(--spacing-md);
        text-decoration: none;
        text-transform: uppercase;
        text-align: center;
        width: 150px;
        display: inline-block;
        font-weight: 600;
        font-size: 14px;
        font-family: "Zalando Sans Expanded", sans-serif;
        font-optical-sizing: auto;

        color: var(--color-blue);

        &.filled {
            background-color: var(--color-blue);
            color: var(--color-black);
        }
    }
}

#splash {
    padding: 0;
    background-color: var(--color-black);
    overflow: hidden;
    height: 100vh;
    width: 100vw;
    position: relative;

    video {
        --height: calc(100vh * 1.35);
        --margin: calc(var(--height) * -0.125);

        object-fit: cover;
        object-position: center center;
        height: var(--height);
        width: 100vw;
        margin-top: var(--margin);
    }

    .container {
        position: absolute;
        inset: 0;

        &::before {
            content: '';
            position: absolute;
            inset: 0;
            z-index: 0;
            background-color: rgba(0, 0, 0, 0.6);
        }

        & > * {
            z-index: 1;
        }
    }

    .content {
        display: flex;
        flex-flow: column nowrap;
        align-items: center;
        text-align: center;
        position: absolute;
        top: 35%;
        left: 15px;
        right: 15px;
        color: var(--color-white);

        h1 {
            margin: 0;
            font-size: var(--font-size-xxl);
            line-height: 1.1;
            margin-bottom: 10px;
            letter-spacing: -2%;
        }

        .actions {
            margin-top: 20px;
            display: flex;
            flex-flow: column nowrap;
        }
    }
}

@media screen and (width >= 567px) {
    #splash {
        .content {
            display: block;
            text-align: left;
            top: 45%;
            left: var(--content-margin);

            .actions {
                flex-flow: row nowrap;
            }
        }
    }
}

#statement {
    display: flex;
    align-items: center;
    justify-content: center;

    .content {
        font-family: "Libre Caslon Text", serif;
        font-size: var(--font-size-lg);
        letter-spacing: -2%;
        line-height: 1.3;
        text-align: center;
        max-width: 900px;
    }
}

#packages {
    display: flex;
    flex-flow: column nowrap;
    padding: var(--content-margin) 0;

    & > * {
        margin: 0 var(--content-margin);
    }
    
    & > header {
        display: flex;
        gap: 12px;
        margin-bottom: 45px;

        h2 {
            font-size: 36px;
        }

        .sub {
            margin: 0;
            color: #6A6A6A;
        }
    }

    ul#package-tabs {
        --border-radius: 30px;

        align-self: flex-start;
        border-radius: var(--border-radius);
        padding: var(--spacing-sm);
        background-color: var(--color-light-grey);
        display: flex;
        gap: 10px;
        margin-top: 30px;
        margin-bottom: 15px;
        list-style-type: none;
        justify-content: space-around;

        li {
            padding: 5px 10px;
            flex: 1;
            text-align: center;
            cursor: pointer;
            text-wrap: nowrap;
            font-size: var(--font-size-sm);

            &.selected {
                background-color: var(--color-blue);
                border-radius: var(--border-radius);
            }

            a {
                text-decoration: none;
                pointer-events: none;
                color: var(--color-black);
            }
        }
    }

    .values {
        display: flex;
        flex-flow: row nowrap;
        gap: 15px;
        margin: 0;
        padding: 0;

        .card {
            aspect-ratio: 9 / 16;
            padding: 0;
            border: var(--border);
            display: grid;
            grid-template-rows: repeat(2, 1fr) 1.5fr;
            min-width: 90%;

            img {
                grid-row: 1 / 3;
                object-fit: cover;
                height: 400px;
                width: 100%;
                border-top-left-radius: 15px;
                border-top-right-radius: 15px;
            }

            .content { 
                background: white;
                padding: var(--spacing-lg);
                border-bottom-left-radius: 15px;
                border-bottom-right-radius: 15px;
                display: flex;
                flex-flow: column nowrap;

                header {
                    margin: 0;
                    display: flex;
                    flex-flow: column nowrap;
                    justify-content: flex-end;

                    h3 {
                        margin: 0;
                        margin-top: var(--spacing-sm);
                        font-size: var(--font-size-lg);
                        letter-spacing: -2%;
                    }

                    .sub {
                        font-size: 12px;
                        letter-spacing: 10%;
                    }
                }

                .spacer { flex-grow: 1; }

                p { 
                    font-size: 14px;
                    color: var(--color-text-tertiary);
                    flex-grow: 1;

                    &.starting-at {
                        margin-top: var(--spacing-md);
                        color: var(--color-black);
                        font-weight: bold;
                        flex-grow: unset;
                    }
                }

                ul {
                    margin: var(--spacing-sm) 0;
                    padding-left: var(--spacing-lg);
                    font-size: 14px;
                    color: var(--color-text-tertiary);
                }
            }
        }
    }

    .actions > a {
        margin-top: var(--spacing-lg);
        width: unset;
        padding: var(--spacing-sm) var(--spacing-lg);
        color: black;
    }

    #maintenance-detail {
        margin-top: calc(var(--content-margin) * 2);
        color: var(--color-black);
        border: var(--border);
        padding: 0;
        display: grid;
        grid-template-rows: auto;
        max-height: 715px;
        overflow: hidden;

        .content {
            min-width: 100%;
            font-size: var(--font-size-md);
            border-top-left-radius: 15px;
            border-top-right-radius: 15px;
            padding: calc(var(--content-margin) / 2);
            background-color: var(--color-white);
            
            .sub {
                margin-top: 0;
                font-size: var(--font-size-sm);
                text-transform: uppercase;
                letter-spacing: 20%;
            }

            h3 {
                margin: 6px 0 16px;
                font-size: clamp(24px, 3vw, 42px);
                line-height: 1.1;
            }

            .periods {
                display: flex;
                flex-flow: row nowrap;
                align-items: center;
                gap: 0;
                margin-bottom: 20px;
                font-size: var(--font-size-sm);
                text-transform: uppercase;
                letter-spacing: 0.08em;
                font-weight: 600;

                span {
                    font-family: "Zalando Sans Expanded", sans-serif;
                }

                .divider {
                    margin: 0 10px;
                    opacity: 0.5;
                }
            }

            p {
                margin: 0;
                font-size: var(--font-size-sm);
                color: var(--color-text-tertiary);
            }

            .disclaimer {
                margin-top: 8px;
                margin-bottom: 12px;
                font-size: var(--font-size-sm);
                font-family: "Zalando Sans Expanded", sans-serif;
                font-weight: 500;
            }
        }

        img {
            grid-row: 3;
            border-bottom-left-radius: 15px;
            border-bottom-right-radius: 15px;
            -webkit-filter: grayscale(1);
            filter: grayscale(1);
        }
    }
}

@media screen and (width >= 576px) {
    #packages {
        padding: var(--content-margin);

        & > header {
            gap: 36px;
            flex-flow: row nowrap;

            h2 {
                font-size: 36px;
                text-wrap: nowrap;
            }
        }

        .values {
            flex-flow: row wrap;
            justify-content: space-around;

            .card {
                flex: 1;
                min-width: unset;
            }
        }

        #maintenance-detail {
            grid-template-rows: 1fr;
            grid-template-columns: 1.25fr 1fr;
            max-height: 500px;

            .content {
                grid-row: 1;
                border-bottom-left-radius: 15px;
                border-top-right-radius: 0;

                .periods .divider {
                    margin: 0 20px;
                }
            }

            img {
                grid-row: 1;
                height: 100%;
                object-fit: cover;
                border-bottom-left-radius: 0;
                border-top-right-radius: 15px;
            }
        }
    }
}

#reputation {
    & > header > h2 {
        font-size: 36px;
    }

    #testimonials {
        display: flex;
        flex-flow: row nowrap;
        gap: 30px;
        margin-bottom: 50px;
        overflow-x: scroll;

        article {
            min-width: 200px;

            .stars {
                display: flex;
                flex-flow: row nowrap;
                gap: 2px;
                margin-bottom: 10px;

                .star-icon {
                    fill: var(--color-blue);
                    width: 20px;
                    height: 20px;
                }
            }

            p {
                font-size: var(--font-size-sm);
                margin: 0 0 10px;
            }

            .author {
                font-weight: 500;
                text-transform: uppercase;
                font-family: "Zalando Sans Expanded", sans-serif;
                font-size: var(--font-size-sm);
                letter-spacing: 0.05em;
            }
        }
    }

    footer {
        padding-top: 30px;

        & > .heading {
            text-align: center;
            font-size: var(--font-size-xl);
        }
    }
}

@media screen and (width >= 576px) {
    #reputation {
        #testimonials {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
        }
    }
}

#services {
    padding: var(--content-margin) 0;

    & > * {
        margin: 0 var(--content-margin);
    }

    & > header > h2 {
        font-size: 36px;
    }

    .services-container {
        display: flex;
        flex-flow: row nowrap;
        gap: 15px;
        margin: 0;
        padding: 0;

        .card {
            position: relative;
            overflow: hidden;
            min-width: 90%;

            background-size: cover;
            background-repeat: no-repeat;
            background-position: center;

            color: var(--color-white);
            justify-content: flex-end;
            min-height: 350px;

            &::before {
                content: '';
                position: absolute;
                inset: 0;
                z-index: 0;
                background-color: rgba(0, 0, 0, 0.7);
            }

            & > * {
                position: relative;
                z-index: 1;
            }

            header {
                margin-top: 0;

                h3 {
                    margin: 0;
                    margin-top: var(--spacing-sm);
                    font-size: var(--font-size-lg);
                    letter-spacing: -2%;
                }

                .sub {
                    font-size: 12px;
                    letter-spacing: 10%;
                }
            }

            .content {
                position: relative;
                font-size: var(--font-size-sm);

                p {
                    margin-bottom: 12px;
                }
            }
        }

        #fleet-detail {
            background-image: url("/assets/home/fleet-detailing-steinbach-2d6b1f9f.webp");
        }

        #mobile-detail {
            background-image: url("/assets/home/mobile-detail-steinbach-b364d69c.webp");
        }

        #rv-boat-detail {
            background-image: url("/assets/home/boat-detailing-steinbach-1d7c638c.webp");
        }
    }

    .actions > a {
        width: unset;
        padding: var(--spacing-sm) var(--spacing-lg);
    }

    footer {
        display: flex;
        flex-flow: column nowrap;
        align-items: center;
        gap: 15px;
        margin-top: 30px;

        p {
            text-transform: uppercase;
            letter-spacing: 15%;
            font-size: var(--font-size-sm);
        }
    }
}

@media screen and (width >= 576px) {
    #services {
        .services-container {
            padding: 0;
            display: grid;
            margin-top: 30px;
            grid-template-columns: 1fr 1fr;

            .card {
                min-width: unset;
            }

            .card--wide {
                grid-column: 1 / -1;
                align-items: center;
                min-height: unset;
                display: grid;
                grid-template-columns: 1fr 1fr;

                .content {
                    min-width: 100%;
                }
            }
        }

        .carousel-controls {
            display: none;
        }
    }
}

#companies {
    h2 {
        font-family: "Zalando Sans Expanded", sans-serif;
        font-optical-sizing: auto;
        font-size: var(--font-size-md);
    }

    .content {
        display: flex;
        justify-content: space-around;
        flex-wrap: wrap;
        gap: 100px;
    }
}

#instagram {
    h2 {
        font-family: "Zalando Sans Expanded", sans-serif;
        font-optical-sizing: auto;
        font-size: var(--font-size-md);
    }
}

#instagram-feed {
    display: grid;
    grid-template-columns: repeat(2, 1fr);


    a {
        display: block;
        overflow: hidden;

        &:hover img {
            opacity: 0.8;
            transform: scale(1.05);
        }
    }

    img {
        display: block;
        width: 100%;
        aspect-ratio: 1;
        object-fit: cover;
        transition: opacity 0.3s ease, transform 0.3s ease;
    }
}

@media screen and (width >= 567px) {
    #instagram-feed {
        grid-template-columns: repeat(5, 1fr);
    }
}

/* Contact page */
#contact-form {
    background-color: var(--color-black);
    color: var(--color-white);
    margin-top: 50px;

    .contact-form {
        max-width: 700px;
        margin: 0 auto;
    }

    .form-errors {
        background-color: rgba(255, 77, 77, 0.15);
        border: 1px solid #ff4d4d;
        border-radius: 8px;
        padding: 16px 20px;
        margin-bottom: 24px;
        font-size: var(--font-size-sm);

        p {
            font-weight: bold;
            margin: 0 0 8px;
        }

        ul {
            margin: 0;
            padding-left: 20px;

            li {
                margin-bottom: 4px;
            }
        }
    }

    .form-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 20px;
    }

    .form-group {
        margin-bottom: 20px;
    }

    #messaging-consent-item {
        display: flex;
        gap: 3px;

        input {
            height: 25px;
            width: 25px;
        }
        
        span {
            display: block;
        }

        label {
            margin-left: 10px;
            text-transform: none;
            font-weight: normal;
            letter-spacing: unset;
        }

    }

    .form-submit {
        margin-top: 10px;
        display: flex;
        justify-content: flex-end;

        input[type="submit"] {
            cursor: pointer;
            letter-spacing: 0.1em;
            border: 3px solid var(--color-blue);
            border-radius: 25px;
            padding: var(--spacing-sm) var(--spacing-md);
            text-decoration: none;
            text-transform: uppercase;
            text-align: center;
            min-width: 160px;
            font-weight: bold;
            font-size: var(--font-size-sm);
            background-color: var(--color-blue);
            color: var(--color-black);
            transition: opacity 0.2s ease;

            &:hover {
                opacity: 0.85;
            }
        }
    }
}

#privacy,
#terms {
    margin-top: 50px;
    background-color: var(--color-black);
    color: var(--color-white);

    p {
        font-size: var(--font-size-md);
    }

    h1, h2, h3, p {
        font-family: "Inter", sans-serif;
    }

    h2 {
        margin-top: 20px;
        margin-bottom: 10px;
    }

    h3 {
        margin-top: 15px;
        margin-bottom: 8px;
    }

    ul, ol {
        margin: 10px 0;
    }
}

.carousel {
    margin: 0;
    display: flex;
    flex-flow: column nowrap;

    & > [data-carousel-target="track"] {
        overflow-x: scroll;
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
        padding-left: 1px;
        scroll-padding-left: 1px;

        &::-webkit-scrollbar {
            width: 0px;
            background: transparent;
        }

        & > * {
            scroll-snap-align: start;
        }
    }

    .carousel-controls {
        align-self: flex-end;
        display: flex;
        justify-content: center;
        gap: 12px;
        margin-top: var(--content-margin);
        padding: 0 var(--content-margin) var(--spacing-sm);

        button {
            border: var(--border);
            border-radius: 50%;
            width: 50px;
            height: 50px;
            font-size: 18px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;

            .carousel-icon {
                fill: var(--color-border);
                width: 100%;
                height: 100%;
            }

            &:disabled {
                opacity: 0.3;
                cursor: default;
            }
        }
    }
}
 
@media screen and (width >= 576px) {
    #packages .values .card {
        min-width: calc((100% - 30px) / 3);
    }

    #packages .carousel[data-active-group] .card[data-group] {
        display: none;
    }

    #packages .carousel[data-active-group="packages"] .card[data-group="packages"],
    #packages .carousel[data-active-group="ceramic"] .card[data-group="ceramic"] {
        display: grid;
    }
}

.learn-button {
    display: none !important;
}
