html {
    background: var(--wa-color-neutral-95);
}
:root {
    @media (width < 650px) {
        /* avoid card border radius on mobile (let cards take the full width of the page) */
        --wa-panel-border-radius: 0;
        --wa-panel-border-width: 0;
    }
}
body {
    display: flex;
    flex-direction: column;
    gap: var(--wa-space-l);

    margin: 0 auto;

    min-height: 100vh;

    > main {
        flex: 1;
    }

    &.limit-width {
        padding: 0 var(--wa-space-l);
        max-width: 1200px;
        @media (width < 650px) {
            /* avoid space on the sides on mobile */
            padding: 0;
        }
    }
}

footer section {
    margin-top: auto;
    justify-content: center;
    margin-bottom: var(--wa-space-m);
}

.static-content {
    padding: var(--wa-space-m);
    margin: 0 auto;
    max-width: 80ch;
}

.static-content,
.producer-header {
    background: var(--wa-color-brand-95);

    box-shadow: var(--wa-shadow-s);
    border-left: var(--wa-panel-border-width) var(--wa-border-style)
        var(--wa-color-surface-border);
    border-right: var(--wa-panel-border-width) var(--wa-border-style)
        var(--wa-color-surface-border);
    border-bottom: var(--wa-panel-border-width) var(--wa-border-style)
        var(--wa-color-surface-border);
    border-radius: 0 0 var(--wa-panel-border-radius)
        var(--wa-panel-border-radius);
    overflow: hidden;
}

.producer-header {
    img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        border-radius: 0;
    }
    article {
        padding: var(--wa-space-m);
    }

    &.full {
        display: grid;
        grid-template-columns: minmax(300px, 1fr) 2fr;
        gap: var(--wa-space-l);
        align-items: start;
        @media (width < 650px) {
            grid-template-columns: 1fr;
        }
    }
}

.product-card {
    display: flex;
    --spacing: var(--wa-space-s);

    form {
        align-self: end;
        display: flex;
        gap: var(--wa-space-s);
    }

    form > * {
        flex: 1;
    }
    &::part(body) {
        flex: 1;
    }
}

#order-button-wrapper {
    position: sticky;
    bottom: var(--wa-space-m);

    .order-button {
        display: flex;
        justify-content: space-between;
        margin: var(--wa-space-m) auto;
        max-width: 350px;

        &::part(base) {
            box-shadow: 0px 0px 10px 3px
                color-mix(in srgb, var(--wa-color-brand-50) 50%, transparent);
            transition: box-shadow 0.2s ease;
        }

        &:hover::part(base) {
            box-shadow: 0px 0px 20px 6px
                color-mix(in srgb, var(--wa-color-brand-50) 70%, transparent);
        }

        &::part(label) {
            display: flex;
            justify-content: space-between;
            width: 100%;
        }

        wa-badge {
            position: static;
            translate: initial;
        }
    }
}

label:has(.errorlist) {
    & input,
    & select {
        border-color: red;
    }
}

.errorlist {
    margin-top: 0.6rem;
    padding-left: 0.6rem;
}

.order-summary-payment {
    margin-bottom: var(--wa-space-m);
}

table.order-summary {
    tfoot tr:not(:first-child) th {
        font-weight: var(--wa-font-weight-normal);
    }
}

.hero {
    min-height: clamp(350px, 40vh, 500px);
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        linear-gradient(to bottom, rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.5)),
        url("/static/reko/hero.webp") center/cover no-repeat;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.6);

    header {
        text-align: center;
        color: white;
        padding: var(--wa-space-xl);
        max-width: 800px;

        h1 {
            font-size: clamp(2.5rem, 10vw, 4rem);
            font-weight: var(--wa-font-weight-bold);
            margin: 0 0 var(--wa-space-s) 0;
            letter-spacing: -0.02em;
        }
        p {
            font-size: clamp(1.1rem, 2.5vw, 1.4rem);
            margin: 0 0 var(--wa-space-xl) 0;
            opacity: 0.95;
        }
    }
}

/* Intro section - 3 feature cards */
.intro-section {
    padding: 0 var(--wa-space-l);
    margin-top: calc(-1 * var(--wa-space-2xl));
    position: relative;
    z-index: 1;

    @media (width < 650px) {
        padding: 0 var(--wa-space-m);
        margin-top: calc(-1 * var(--wa-space-xl));
    }
}

.intro-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--wa-space-m);
    max-width: 1000px;
    margin: 0 auto;
}

.intro-card {
    text-align: center;
    padding: var(--wa-space-l);

    h3 {
        margin: var(--wa-space-s) 0;
        font-size: var(--wa-font-size-l);
        color: var(--wa-color-brand-40);
    }

    p {
        margin: 0;
        color: var(--wa-color-neutral-40);
        line-height: 1.6;
    }
}

.intro-icon {
    font-size: var(--wa-font-size-2xl);
    color: var(--wa-color-brand-50);
}

/* Content sections */
.content-section,
.audience-section {
    padding: var(--wa-space-xl) var(--wa-space-l);
    max-width: 1200px;
    margin: 0 auto;

    @media (width < 650px) {
        padding: var(--wa-space-l) var(--wa-space-m);
    }
}

.wide-card {
    max-width: 800px;
    margin: 0 auto;
    padding: var(--wa-space-l);

    p {
        line-height: 1.7;
        color: var(--wa-color-neutral-30);
    }

    p:last-child {
        margin-bottom: 0;
    }
}

.card-header {
    display: flex;
    align-items: center;
    gap: var(--wa-space-s);
    margin-bottom: var(--wa-space-m);

    h2 {
        margin: 0;
        font-size: var(--wa-font-size-xl);
        color: var(--wa-color-brand-40);
    }
}

.section-icon {
    font-size: var(--wa-font-size-xl);
    color: var(--wa-color-brand-50);
}

/* Audience grid */
.audience-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--wa-space-l);
}

.audience-card {
    padding: var(--wa-space-l);
    display: flex;
    flex-direction: column;

    p {
        color: var(--wa-color-neutral-30);
        line-height: 1.6;
    }

    ul {
        margin: var(--wa-space-s) 0 var(--wa-space-m) 0;
        padding-left: var(--wa-space-l);
        flex: 1;
    }

    li {
        margin-bottom: var(--wa-space-xs);
        color: var(--wa-color-neutral-30);
        line-height: 1.5;
    }
}

.card-cta {
    margin-top: auto;
    padding-top: var(--wa-space-m);
    border-top: 1px solid var(--wa-color-neutral-90);
    font-size: var(--wa-font-size-s);
    color: var(--wa-color-neutral-40);

    a {
        color: var(--wa-color-brand-50);
        text-decoration: none;
        font-weight: var(--wa-font-weight-semibold);

        &:hover {
            text-decoration: underline;
        }
    }
}


.pickup-select {
    flex-direction: column;

    #id_pickup {
        margin-top: var(--wa-space-xs);

        > div {
            display: flex;
            flex-direction: column;
            gap: var(--wa-space-xs);

            /* optgroup */
            > label {
                font-style: italic;
            }

            > div {
                /* option */
                min-height: calc(var(--wa-form-control-height) / var(--wa-line-height-normal));

                > label {
                    align-items: center;
                }
            }
        }
    }
}
