:root {
    --stan-brown: #6b3934;
    --stan-brown-soft: #8f6761;
    --stan-border: #c8b2ad;
    --stan-page: #ffffff;
}

body {
    margin: 0;
    font-family: "Archivo", sans-serif;
    color: var(--stan-brown);
    background: #ffffff;
}

.page-shell {
    background: var(--stan-page);
}

.content-frame {
    max-width: 1640px;
    margin: 0 auto;
}

.hero-wrap {
    padding: 0 0.95rem 0 0.95rem;
    position: relative;
}

.hero-image {
    display: block;
    width: 100%;
    height: auto;
}

.hero-message {
    position: absolute;
    right: 5.25rem;
    top: 50%;
    transform: translateY(-50%);
    width: 700px;
    max-width: calc(100% - 10.5rem);
    background: rgba(255, 255, 255, 0.68);
    padding: 2.4rem 2rem;
    text-align: center;
    color: var(--stan-brown);
}

.hero-message h1 {
    font-size: 40px;
    line-height: 53px;
    font-weight: 700;
    margin: 0 0 1.1rem;
}

.hero-message p {
    font-size: 30px;
    line-height: 40px;
    margin: 0;
}

.retailer-section {
    padding: 2.5rem 1rem 3.25rem;
}

.retailer-row {
    min-height: 8rem;
}

.retailer-copy {
    text-align: center;
    font-size: 20px;
    font-weight: 700;
    line-height: 27px;
    max-width: 22rem;
    margin: 0 auto;
}

.retailer-divider {
    width: 1px;
    background: var(--stan-border);
    min-height: 4.8rem;
    margin: 0 auto;
}

.retailer-logos img {
    display: block;
    width: 100%;
    max-width: 12rem;
    max-height: 4.75rem;
    object-fit: contain;
    margin: 0 auto;
}

.product-band {
    background: var(--stan-brown);
    color: #fff;
    padding: 0;
}

.band-frame {
    max-width: 1640px;
    margin: 0 auto;
}

.band-inner {
    min-height: 126px;
    position: relative;
    display: flex;
    align-items: center;
}

.band-copy {
    color: rgba(255, 255, 255, 0.5);
    font-size: 30px;
    font-style: italic;
    font-weight: 600;
    line-height: 35px;
    letter-spacing: -0.02em;
    width: calc(100% - 27rem);
    max-width: none;
    padding: 0.20rem 1.5rem 0.20rem 0.5rem;
}

.product-stack {
    position: absolute;
    right: 0;
    top: -15px;
    display: flex;
    gap: 1.2rem;
}

.product-box {
    width: 11.8rem;
    height: 9.8rem;
    background: #fff;
    border: 1px solid #b48f88;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem;
}

.product-box img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.contact-row {
    padding: 1.25rem 1rem 1rem;
    color: var(--stan-brown-soft);
    font-size: clamp(0.95rem, 1vw, 1.15rem);
    text-align: left;
}

.contact-row strong {
    color: var(--stan-brown);
}

.contact-row a {
    color: inherit;
    text-decoration: none;
}

.contact-row a:hover,
.contact-row a:focus {
    text-decoration: underline;
}

@media (max-width: 992px) {
    .hero-message {
        left: 50%;
        right: auto;
        width: min(32rem, calc(100% - 4rem));
        transform: translate(-50%, -50%);
        padding: 1.5rem 1.25rem;
    }

    .retailer-section {
        padding: 2rem 1rem 2.5rem;
    }

    .retailer-divider {
        width: 7rem;
        min-height: 1px;
        height: 1px;
    }

    .retailer-logos {
        margin-top: 1rem;
    }

    .band-inner {
        min-height: 0;
        display: block;
        padding: 2rem 0 1.5rem;
    }

    .band-copy {
        width: 100%;
        max-width: none;
        padding: 0 1.5rem;
        text-align: center;
        font-size: 24px;
        line-height: 30px;
        margin: 0 auto;
    }

    .hero-message h1 {
        font-size: 34px;
        line-height: 44px;
        margin-bottom: 0.75rem;
    }

    .hero-message p {
        font-size: 24px;
        line-height: 32px;
    }

    .product-stack {
        position: static;
        justify-content: center;
        flex-wrap: wrap;
        margin-top: 1.5rem;
    }

    .contact-row {
        text-align: center;
    }
}

@media (max-width: 1400px) and (min-width: 993px) {
    .band-copy {
        font-size: 26px;
        line-height: 31px;
        width: calc(100% - 23.5rem);
        padding-right: 1.25rem;
    }

    .product-box {
        width: 10.75rem;
        height: 9rem;
    }
}

@media (max-width: 576px) {
    .hero-wrap {
        padding: 0.45rem 0.45rem 0;
    }

    .retailer-section {
        padding-top: 1.5rem;
    }

    .hero-message {
        right: auto;
        left: 50%;
        top: 0.75rem;
        transform: translateX(-50%);
        width: min(100%, 21rem);
        max-width: calc(100% - 1.5rem);
        padding: 0.85rem 0.85rem 0.9rem;
    }

    .hero-message h1 {
        font-size: 21px;
        line-height: 27px;
        margin-bottom: 0.35rem;
    }

    .hero-message p {
        font-size: 15px;
        line-height: 20px;
    }

    .hero-message h1 br,
    .hero-message p br {
        display: none;
    }

    .product-box {
        width: 10.25rem;
        height: 8.75rem;
    }

    .contact-row {
        padding-top: 1rem;
        font-size: 0.95rem;
    }
}
