@media (max-width: 991.98px) {
    .header.header-image {
        background-image: none !important;
        background-color: #ffffff !important;
        min-height: auto !important;
    }
    .header-inner {
        padding-top: 40px !important;
        padding-bottom: 20px !important;
    }
    .header-mobile-app {
        margin-top: 2rem !important;
    }
    .header-mobile-app img {
        max-width: 60%;
        height: auto;
        margin: 0 auto;
        display: block;
    }
}

/* Hero CTA button group — natural-width side by side on ≥430px screens (iPhone Plus/Pro Max
   and larger); full-width stacked on narrower phones (≤429px). 430px aligns with iPhone 15
   Plus/Pro Max (430pt) so the most common large-phone sizes stay side by side. */
.hero-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center; /* mirrors text-center on the parent row */
}
@media (min-width: 1200px) {
    .hero-cta-buttons {
        justify-content: flex-start; /* mirrors text-xl-start on the parent row */
    }
}
@media (max-width: 429.98px) {
    .hero-cta-buttons > .btn {
        flex: 1 1 100%;
    }
}

.header-search .search-input input {
    border: 1px solid #e5e7eb !important;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05) !important;
    background-color: #ffffff !important;
}

.header-search .search-input input:focus {
    border-color: rgb(var(--primary_color)) !important;
}

/* ============================================================
   Branded Card component
   Used by: home discover section, home business-alert,
            business-home business-alert, business-home features

   All gradient stops are derived via color-mix() from the
   admin-configurable --primary_color and --secondary_color
   tokens, so the component automatically adapts to any theme.
   ============================================================ */
.branded-card {
    position: relative;
    min-height: 100%;
    padding: clamp(32px, 3vw, 45px);
    overflow: hidden;
    border: 1px solid transparent;
    box-shadow: 0 16px 40px rgba(18, 24, 39, 0.06);
}

.branded-card > * {
    position: relative;
    z-index: 1;
}

.branded-card--neutral {
    background:
        radial-gradient(circle at 100% 100%, rgba(var(--secondary_color), 0.24) 0%, rgba(var(--secondary_color), 0.14) 16%, rgba(var(--secondary_color), 0) 35%) padding-box,
        linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(var(--elements_background_color), 0.92) 100%) padding-box,
        linear-gradient(135deg,
            color-mix(in srgb, rgb(var(--primary_color)) 70%, white) 0%,
            color-mix(in srgb, rgb(var(--primary_color)) 45%, white) 55%,
            color-mix(in srgb, rgb(var(--secondary_color)) 70%, white) 100%
        ) border-box;
}

.branded-card--accent {
    background:
        radial-gradient(circle at 85% 100%, rgba(var(--secondary_color), 0.45) 0%, rgba(var(--secondary_color), 0.18) 18%, rgba(var(--secondary_color), 0) 42%) padding-box,
        linear-gradient(116deg,
            rgb(var(--primary_color)) 0%,
            color-mix(in srgb, rgb(var(--primary_color)) 80%, white) 52%,
            rgba(var(--secondary_color), 0.88) 100%
        ) padding-box,
        linear-gradient(116deg,
            color-mix(in srgb, rgb(var(--primary_color)) 60%, white) 0%,
            color-mix(in srgb, rgb(var(--primary_color)) 35%, white) 58%,
            color-mix(in srgb, rgb(var(--secondary_color)) 65%, white) 100%
        ) border-box;
    border-color: transparent;
    color: #fff;
}

.branded-card--accent :is(h2, h3, h4, p) {
    color: inherit;
}

.branded-card--accent p {
    max-width: 34rem;
    color: rgba(255, 255, 255, 0.86);
}

.branded-card__media {
    margin-top: clamp(20px, 3vw, 36px);
}

.branded-card--accent .branded-card__media img {
    width: min(100%, 500px);
}

.branded-card--accent .btn.btn-primary,
.branded-card--accent .btn.btn-primary:active,
.branded-card--accent .btn.btn-primary:focus,
.branded-card--accent .btn.btn-primary:hover {
    background-color: #fff;
    border-color: #fff;
    color: rgb(var(--primary_color));
}

.branded-card--accent .btn.btn-primary {
    box-shadow: 0 12px 28px rgba(7, 18, 56, 0.16);
}

.branded-card--accent .btn.btn-primary:active,
.branded-card--accent .btn.btn-primary:focus,
.branded-card--accent .btn.btn-primary:hover {
    background-color: #f5f7fd;
    border-color: #f5f7fd;
}

@media (max-width: 991.98px) {
    .branded-card {
        padding: 32px 24px;
    }

    .branded-card__media {
        margin-top: 24px;
    }

    .branded-card--accent .branded-card__media {
        text-align: center;
    }
}

@media (max-width: 767.98px) {
    .branded-card--accent {
        background:
            radial-gradient(circle at 72% 74%, rgba(var(--primary_color), 0.22) 0%, rgba(var(--primary_color), 0.10) 18%, rgba(var(--primary_color), 0) 38%) padding-box,
            radial-gradient(circle at 90% 98%, rgba(var(--secondary_color), 0.54) 0%, rgba(var(--secondary_color), 0.24) 18%, rgba(var(--secondary_color), 0) 40%) padding-box,
            linear-gradient(152deg,
                rgb(var(--primary_color)) 0%,
                color-mix(in srgb, rgb(var(--primary_color)) 70%, white) 42%,
                color-mix(in srgb, rgb(var(--primary_color)) 55%, white) 76%,
                rgba(var(--secondary_color), 0.84) 100%
            ) padding-box,
            linear-gradient(116deg,
                color-mix(in srgb, rgb(var(--primary_color)) 60%, white) 0%,
                color-mix(in srgb, rgb(var(--primary_color)) 35%, white) 58%,
                color-mix(in srgb, rgb(var(--secondary_color)) 65%, white) 100%
            ) border-box;
    }
}