/* /Components/Layout/MainLayout.razor.rz.scp.css */
/*
 * Layout-level scoped styles. The Blazor-template default rules (.page, .top-row,
 * etc.) were removed when MudLayout took over the page chrome — they were dead
 * code masquerading as defaults.
 *
 * Everything here is keyed off the brand breakpoint tokens declared in
 * wwwroot/css/brand.css (--rq-bp-sm, --rq-bp-md). CSS doesn't allow custom
 * properties inside @media expressions, so the px values are repeated literally;
 * the brand.css comment is the canonical source.
 */

/* ── Brand lockup (logo + wordmark) ──────────────────────────────────────── */

/*
 * Brand is absolutely positioned at the AppBar's left chrome edge so it stays
 * out of the flex flow. This lets the centred MudContainer below center on the
 * AppBar's full width — putting nav buttons at the same left edge as the page
 * content area (MaxWidth.Large) below.
 */
.qr-brand[b-ex0v64nre4],
.qr-brand:hover[b-ex0v64nre4],
.qr-brand:visited[b-ex0v64nre4] {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    gap: 8px;
    z-index: 2;
    color: inherit;
    text-decoration: none;
}

.qr-brand-mark[b-ex0v64nre4] {
    width: 32px;
    height: 32px;
    display: block;
}

.qr-brand-word[b-ex0v64nre4] {
    font-size: 1.5rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.5px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Below 400px (extreme narrow), drop the wordmark and keep only the icon.
   The wordmark adds ~120px of width that has nowhere to go on a 360px viewport
   once the hamburger button takes its share of the bar. */
@media (max-width: 399.98px) {
    .qr-brand-word[b-ex0v64nre4] {
        display: none;
    }
}

/* ── Inline nav (md and up) ───────────────────────────────────────────────── */

/*
 * Centred MudContainer at MaxWidth.Large. Same width as page content below,
 * so Home / Become-a-Painter sit at the same left edge as the body content.
 * !important on display because the d-flex on the wrapping MudHidden interferes
 * otherwise — we want the container's children to lay out as a flex row.
 */
[b-ex0v64nre4] .qr-nav-center {
    display: flex !important;
    align-items: center;
    padding: 0 16px;
}

/*
 * Auth (Sign in / Dashboard) anchored absolute-right, opposite the brand. Same
 * chrome-edge positioning so it survives whatever the centred container does.
 */
.qr-auth-slot[b-ex0v64nre4] {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
}

/* ── Drawer (sm and down) ─────────────────────────────────────────────────── */

/*
 * Drawer carries the same navy chrome as the AppBar so the collapsed nav reads
 * as an extension of the top bar, not a foreign panel. ::deep reaches through
 * MudDrawer's render tree because the elements it generates don't carry this
 * scope attribute.
 */
[b-ex0v64nre4] .qr-nav-drawer .mud-drawer {
    background-color: var(--rq-deep-navy);
    color: var(--rq-pure-white);
}

.qr-nav-drawer-head[b-ex0v64nre4] {
    display: flex;
    justify-content: flex-end;
    padding: 8px 8px 0;
}

[b-ex0v64nre4] .qr-nav-drawer-head .mud-icon-button {
    color: var(--rq-pure-white);
}

.qr-nav-drawer-menu[b-ex0v64nre4] {
    padding: 16px 12px;
}

/* Reach into MudNavLink's render tree to apply brand colours + minimum
   tap-target height. MudBlazor's default styling targets desktop densities
   that are too tight for thumb taps. */
[b-ex0v64nre4] .qr-nav-drawer-menu .mud-nav-link {
    color: var(--rq-pure-white);
    font-weight: 500;
    font-size: 0.9375rem;
    min-height: var(--rq-tap-target);
    border-radius: 8px;
    margin-bottom: 4px;
}

[b-ex0v64nre4] .qr-nav-drawer-menu .mud-nav-link:hover {
    background-color: var(--rq-overlay-soft);
}

[b-ex0v64nre4] .qr-nav-drawer-menu .mud-nav-link.active {
    background-color: var(--rq-overlay-soft);
    color: var(--rq-soft-gold);
}

/* Treat the "Become a Painter" drawer entry like a copper CTA — sole copper
   element in the drawer, matches the desktop header's primary action. */
[b-ex0v64nre4] .qr-nav-drawer-menu .qr-nav-drawer-cta {
    background-color: var(--rq-warm-copper);
    color: var(--rq-pure-white);
    font-weight: 700;
    margin: 4px 0 8px;
}

[b-ex0v64nre4] .qr-nav-drawer-menu .qr-nav-drawer-cta:hover {
    background-color: var(--rq-copper-dark);
}

[b-ex0v64nre4] .qr-nav-drawer-divider {
    background-color: var(--rq-overlay-soft);
    margin: 12px 4px;
}

/* ── Blazor-built-in error UI (kept verbatim from project template) ───────── */

#blazor-error-ui[b-ex0v64nre4] {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

#blazor-error-ui .dismiss[b-ex0v64nre4] {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}
/* /Components/Layout/ReconnectModal.razor.rz.scp.css */
.components-reconnect-first-attempt-visible[b-iqql0r9903],
.components-reconnect-repeated-attempt-visible[b-iqql0r9903],
.components-reconnect-failed-visible[b-iqql0r9903],
.components-pause-visible[b-iqql0r9903],
.components-resume-failed-visible[b-iqql0r9903],
.components-rejoining-animation[b-iqql0r9903] {
    display: none;
}

#components-reconnect-modal.components-reconnect-show .components-reconnect-first-attempt-visible[b-iqql0r9903],
#components-reconnect-modal.components-reconnect-show .components-rejoining-animation[b-iqql0r9903],
#components-reconnect-modal.components-reconnect-paused .components-pause-visible[b-iqql0r9903],
#components-reconnect-modal.components-reconnect-resume-failed .components-resume-failed-visible[b-iqql0r9903],
#components-reconnect-modal.components-reconnect-retrying[b-iqql0r9903],
#components-reconnect-modal.components-reconnect-retrying .components-reconnect-repeated-attempt-visible[b-iqql0r9903],
#components-reconnect-modal.components-reconnect-retrying .components-rejoining-animation[b-iqql0r9903],
#components-reconnect-modal.components-reconnect-failed[b-iqql0r9903],
#components-reconnect-modal.components-reconnect-failed .components-reconnect-failed-visible[b-iqql0r9903] {
    display: block;
}


#components-reconnect-modal[b-iqql0r9903] {
    background-color: white;
    width: 20rem;
    margin: 20vh auto;
    padding: 2rem;
    border: 0;
    border-radius: 0.5rem;
    box-shadow: 0 3px 6px 2px rgba(0, 0, 0, 0.3);
    opacity: 0;
    transition: display 0.5s allow-discrete, overlay 0.5s allow-discrete;
    animation: components-reconnect-modal-fadeOutOpacity-b-iqql0r9903 0.5s both;
    &[open]

{
    animation: components-reconnect-modal-slideUp-b-iqql0r9903 1.5s cubic-bezier(.05, .89, .25, 1.02) 0.3s, components-reconnect-modal-fadeInOpacity-b-iqql0r9903 0.5s ease-in-out 0.3s;
    animation-fill-mode: both;
}

}

#components-reconnect-modal[b-iqql0r9903]::backdrop {
    background-color: rgba(0, 0, 0, 0.4);
    animation: components-reconnect-modal-fadeInOpacity-b-iqql0r9903 0.5s ease-in-out;
    opacity: 1;
}

@keyframes components-reconnect-modal-slideUp-b-iqql0r9903 {
    0% {
        transform: translateY(30px) scale(0.95);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes components-reconnect-modal-fadeInOpacity-b-iqql0r9903 {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes components-reconnect-modal-fadeOutOpacity-b-iqql0r9903 {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

.components-reconnect-container[b-iqql0r9903] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

#components-reconnect-modal p[b-iqql0r9903] {
    margin: 0;
    text-align: center;
}

#components-reconnect-modal button[b-iqql0r9903] {
    border: 0;
    background-color: #6b9ed2;
    color: white;
    padding: 4px 24px;
    border-radius: 4px;
}

    #components-reconnect-modal button:hover[b-iqql0r9903] {
        background-color: #3b6ea2;
    }

    #components-reconnect-modal button:active[b-iqql0r9903] {
        background-color: #6b9ed2;
    }

.components-rejoining-animation[b-iqql0r9903] {
    position: relative;
    width: 80px;
    height: 80px;
}

    .components-rejoining-animation div[b-iqql0r9903] {
        position: absolute;
        border: 3px solid #0087ff;
        opacity: 1;
        border-radius: 50%;
        animation: components-rejoining-animation-b-iqql0r9903 1.5s cubic-bezier(0, 0.2, 0.8, 1) infinite;
    }

        .components-rejoining-animation div:nth-child(2)[b-iqql0r9903] {
            animation-delay: -0.5s;
        }

@keyframes components-rejoining-animation-b-iqql0r9903 {
    0% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    4.9% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    5% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 1;
    }

    100% {
        top: 0px;
        left: 0px;
        width: 80px;
        height: 80px;
        opacity: 0;
    }
}
/* /Components/Pages/Home.razor.rz.scp.css */
/*
 * Home page scoped styles. Class names use no project prefix — Blazor scoped
 * CSS appends a [b-xxx] attribute that prevents collisions with sibling pages.
 *
 * Section bands are full-bleed by virtue of MainLayout no longer wrapping pages
 * in a constraining MudContainer — each <section> renders edge-to-edge naturally.
 * Per-section content alignment is provided by an inner MudContainer.
 */

section.section[b-6s3wrvps8c] {
    padding: 96px 24px;
}

.section-title[b-6s3wrvps8c] {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 800;
    letter-spacing: -0.5px;
    color: var(--rq-near-black);
    margin: 0 0 12px;
    text-align: center;
}

.section-subtitle[b-6s3wrvps8c] {
    font-size: 1rem;
    color: var(--rq-slate-grey);
    max-width: 640px;
    margin: 0 auto 56px;
    text-align: center;
    line-height: 1.5;
}

/* ----- Section A: Hero ----- */
.hero[b-6s3wrvps8c] {
    background-color: var(--rq-deep-navy);
    color: var(--rq-pure-white);
    text-align: center;
}

.hero-logo[b-6s3wrvps8c] {
    display: block;
    width: clamp(64px, 12vw, 96px);
    height: auto;
    aspect-ratio: 1 / 1;
    margin: 0 auto 24px;
}

.hero h1[b-6s3wrvps8c] {
    font-size: clamp(2rem, 5vw, 3.75rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.5px;
    margin: 0 0 20px;
    color: var(--rq-pure-white);
}

.hero-subtitle[b-6s3wrvps8c] {
    font-size: 1.125rem;
    color: var(--rq-text-on-navy);
    max-width: 640px;
    margin: 0 auto 40px;
    line-height: 1.5;
}

.pill-container[b-6s3wrvps8c] {
    background: var(--rq-overlay-faint);
    border: 1px solid var(--rq-overlay-soft);
    border-radius: 16px;
    padding: 24px;
    max-width: 960px;
    margin: 0 auto 48px;
}

.pill[b-6s3wrvps8c] {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    text-align: left;
}

.pill-icon[b-6s3wrvps8c] {
    flex: 0 0 44px;
    height: 44px;
    background: var(--rq-overlay-soft);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pill-heading[b-6s3wrvps8c] {
    font-weight: 700;
    font-size: 0.9375rem;
    color: var(--rq-pure-white);
    margin: 0 0 4px;
    line-height: 1.3;
}

.pill-body[b-6s3wrvps8c] {
    font-size: 0.8125rem;
    color: var(--rq-text-on-navy-muted);
    margin: 0;
    line-height: 1.5;
}

/* `::deep` because .light-cta is forwarded onto MudButton's rendered <button>
   element, which doesn't carry this page's scope attribute. */
[b-6s3wrvps8c] .light-cta {
    background-color: var(--rq-pure-white) !important;
    color: var(--rq-copper-dark) !important;
    font-weight: 700;
    padding: 14px 32px;
    border-radius: 8px;
}

[b-6s3wrvps8c] .light-cta:hover {
    background-color: var(--rq-sandstone) !important;
}

.hero-microcopy[b-6s3wrvps8c],
.ready-microcopy[b-6s3wrvps8c] {
    margin-top: 20px;
    font-size: 0.8125rem;
    color: var(--rq-text-on-navy-muted);
}

/* ----- Section B: Choose Your Path ----- */
.roles[b-6s3wrvps8c] {
    background-color: var(--rq-warm-white);
}

.role-card[b-6s3wrvps8c] {
    background-color: var(--rq-pure-white);
    border: 1px solid var(--rq-sandstone);
    border-radius: 12px;
    padding: 32px;
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: border-color 0.2s ease;
}

.role-card:hover[b-6s3wrvps8c] {
    border-color: var(--rq-copper-dark);
}

.role-icon[b-6s3wrvps8c] {
    width: 56px;
    height: 56px;
    background-color: var(--rq-deep-navy);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 24px;
}

.role-heading[b-6s3wrvps8c] {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--rq-near-black);
    margin: 0 0 8px;
    letter-spacing: -0.3px;
}

.role-tagline[b-6s3wrvps8c] {
    font-size: 0.9375rem;
    color: var(--rq-slate-grey);
    margin: 0 0 24px;
    line-height: 1.5;
}

.role-divider[b-6s3wrvps8c] {
    height: 1px;
    background: var(--rq-sandstone);
    margin: 0 0 24px;
}

.role-bullets[b-6s3wrvps8c] {
    list-style: none;
    margin: 0 0 28px;
    padding: 0;
    flex: 1;
}

.role-bullets li[b-6s3wrvps8c] {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 12px;
    font-size: 0.9375rem;
    color: var(--rq-near-black);
    line-height: 1.5;
}

.role-bullets li:last-child[b-6s3wrvps8c] {
    margin-bottom: 0;
}

/* ----- Section C: Why Choose ----- */
.why[b-6s3wrvps8c] {
    background-color: var(--rq-pure-white);
}

.why-title[b-6s3wrvps8c] {
    color: var(--rq-deep-navy);
    margin-bottom: 56px;
}

.why-card[b-6s3wrvps8c] {
    text-align: center;
    padding: 0 16px;
}

.why-icon[b-6s3wrvps8c] {
    width: 64px;
    height: 64px;
    background: var(--rq-sandstone);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 24px;
}

.why-heading[b-6s3wrvps8c] {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--rq-near-black);
    margin: 0 0 12px;
    letter-spacing: -0.3px;
}

.why-body[b-6s3wrvps8c] {
    font-size: 0.9375rem;
    color: var(--rq-slate-grey);
    max-width: 280px;
    margin: 0 auto;
    line-height: 1.5;
}

/* ----- Section D: Ready ----- */
.ready[b-6s3wrvps8c] {
    background-color: var(--rq-deep-navy);
    color: var(--rq-pure-white);
    text-align: center;
}

.ready h2[b-6s3wrvps8c] {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 800;
    letter-spacing: -0.5px;
    color: var(--rq-pure-white);
    margin: 0 0 16px;
}

.ready-subtitle[b-6s3wrvps8c] {
    font-size: 1rem;
    color: var(--rq-text-on-navy);
    max-width: 560px;
    margin: 0 auto 40px;
    line-height: 1.5;
}
/* /Components/Pages/Quotes/QuoteResults.razor.rz.scp.css */
/*
 * Quote-results scoped styles. qr- prefix to mirror the qw-/qs- conventions of
 * the wizard. All colours flow through the --rq-* brand tokens defined in
 * wwwroot/css/brand.css; no raw hex values in this file.
 */

.qr-page[b-zvv8hdsua6] {
    /* Scales: 48→24 top, 24→16 sides, 96→48 bottom across desktop → mobile. */
    padding: clamp(24px, 4vw, 48px) clamp(16px, 4vw, 24px) clamp(48px, 8vw, 96px);
    background: var(--rq-warm-white);
    min-height: calc(100vh - 200px);
}

.qr-loading[b-zvv8hdsua6] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 96px 16px;
    color: var(--rq-slate-grey);
    font-size: 0.9375rem;
}

.qr-loading p[b-zvv8hdsua6] {
    margin: 0;
}

/* ── Utility bar ──────────────────────────────────────────────────────────── */

.qr-utility-bar[b-zvv8hdsua6] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 32px;
}

.qr-utility-left[b-zvv8hdsua6],
.qr-utility-right[b-zvv8hdsua6] {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

/* .rq-utility-pill lives in wwwroot/css/brand.css (shared with the wizard). */

/* ── Header ───────────────────────────────────────────────────────────────── */

.qr-header[b-zvv8hdsua6] {
    text-align: center;
    margin: 24px auto 40px;
    max-width: 720px;
}

.qr-heading[b-zvv8hdsua6] {
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: 800;
    letter-spacing: -0.5px;
    color: var(--rq-deep-navy);
    margin: 0 0 12px;
}

.qr-subhead[b-zvv8hdsua6] {
    font-size: 1rem;
    color: var(--rq-slate-grey);
    margin: 0;
    line-height: 1.5;
}

/* ── Tier grid ────────────────────────────────────────────────────────────── */

/*
 * Tier grid uses CSS subgrid so corresponding rows across the three cards line up:
 * headline ↔ headline, description ↔ description, price ↔ price, features ↔ features,
 * callout slot ↔ callout slot. Without subgrid, the Signature description (3 lines)
 * pushes everything below it down on that card only, breaking the side-by-side rhythm.
 *
 * 5 rows defined here, 5 rows consumed by each card via subgrid. Cards that don't
 * fill row 5 (Standard, Signature have no warning callout) leave it empty — the row
 * is sized to whichever card DOES fill it (Refresh), so all three cards reserve the
 * same vertical space at the bottom. grid-auto-rows handles the mobile stack where
 * cards collapse to a single column and the parent needs 3×5 = 15 rows total.
 */
.qr-tier-grid[b-zvv8hdsua6] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: auto auto auto auto auto;
    grid-auto-rows: auto;
    gap: 20px;
    margin-bottom: 32px;
    align-items: stretch;
}

/* Below md (960) the cards stack — 3-col is too cramped under desktop. */
@media (max-width: 959.98px) {
    .qr-tier-grid[b-zvv8hdsua6] {
        grid-template-columns: 1fr;
    }
}

.qr-tier-card[b-zvv8hdsua6] {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: subgrid;
    grid-row: span 5;
    gap: 16px;
    padding: clamp(20px, 3vw, 28px) clamp(18px, 3vw, 24px) clamp(18px, 3vw, 24px);
    background: var(--rq-pure-white);
    /*
     * Border defined per-side. Sides + bottom carry the card chrome; the TOP carries
     * the tier "spine" (4px) and is recoloured per tier below. Putting the spine
     * into the card's own border-box (rather than an absolutely-positioned ::before
     * overlay) means border-radius unifies both — no sub-pixel gap at the corners.
     * The transparent default top keeps all three cards the same total height so
     * subgrid row alignment isn't thrown off by tiers without a coloured spine.
     */
    border-top: 4px solid transparent;
    border-right: 1px solid var(--rq-sandstone);
    border-bottom: 1px solid var(--rq-sandstone);
    border-left: 1px solid var(--rq-sandstone);
    border-radius: 12px;
    text-align: left;
    cursor: pointer;
    font-family: inherit;
    color: var(--rq-near-black);
    transition: border-color 120ms ease, box-shadow 120ms ease, transform 120ms ease;
}

/*
 * Hover + selected colours are tier-aware so each card uses one consistent identity
 * colour across "you can click me" (hover) and "this is the choice" (selected):
 *   - Refresh + Standard → Deep Navy (structural authority)
 *   - Signature          → Copper Dark (brand-signature accent)
 * Hover and selected match per tier so the click-to-select transition doesn't
 * change colour family. The tier spine on the top border stays intact regardless.
 */

/*
 * Spine-less tiers (currently only Refresh) when idle — give the 4px top the same
 * sandstone colour as the rest of the border so the card reads as a complete
 * rectangle. The :not(.qr-tier-card-selected) bow-out is load-bearing: without it
 * this rule's (0,4,0) specificity would beat the selected rule's (0,2,0) and the
 * top would stay sandstone even when Refresh is chosen.
 * Standard / Signature override this via their tier-spine colour rules.
 */
.qr-tier-card:not(.qr-tier-card-recommended):not(.qr-tier-card-premium):not(.qr-tier-card-selected)[b-zvv8hdsua6] {
    border-top-color: var(--rq-sandstone);
}

/* Hover */
.qr-tier-card:not(.qr-tier-card-premium):hover[b-zvv8hdsua6] {
    border-left-color: var(--rq-deep-navy);
    border-right-color: var(--rq-deep-navy);
    border-bottom-color: var(--rq-deep-navy);
}

/* Spine-less hover — also close the top with navy so the hover ring is complete. */
.qr-tier-card:not(.qr-tier-card-recommended):not(.qr-tier-card-premium):hover[b-zvv8hdsua6] {
    border-top-color: var(--rq-deep-navy);
}

.qr-tier-card.qr-tier-card-premium:hover[b-zvv8hdsua6] {
    border-left-color: var(--rq-copper-dark);
    border-right-color: var(--rq-copper-dark);
    border-bottom-color: var(--rq-copper-dark);
}

/*
 * Selected — no border-width change (avoids the half-pixel content shift the
 * previous 1px→1.5px swap caused). Sides + bottom take the tier's identity
 * colour, top retains its tier spine, background warms, soft shadow underlines
 * the selection with a matching colour tint.
 */
.qr-tier-card-selected[b-zvv8hdsua6] {
    background: var(--rq-warm-white);
}

.qr-tier-card-selected:not(.qr-tier-card-premium)[b-zvv8hdsua6] {
    border-top-color: var(--rq-deep-navy);
    border-left-color: var(--rq-deep-navy);
    border-right-color: var(--rq-deep-navy);
    border-bottom-color: var(--rq-deep-navy);
    box-shadow: 0 4px 16px rgba(27, 42, 74, 0.12); /* Deep Navy tint */
}

.qr-tier-card-selected.qr-tier-card-premium[b-zvv8hdsua6] {
    border-left-color: var(--rq-copper-dark);
    border-right-color: var(--rq-copper-dark);
    border-bottom-color: var(--rq-copper-dark);
    box-shadow: 0 4px 16px rgba(168, 107, 40, 0.12); /* Copper Dark tint */
}

/*
 * Tier "spine" colours — recolour the card's 4px top border to give each tier its
 * own brand pairing independent of selection state. Standard owns navy (structural,
 * the dependable default); Signature owns copper (brand-forward, the featured
 * upmarket tier). Pairing copper with both the Signature spine and the page's
 * primary CTA reinforces "copper = our best".
 */
.qr-tier-card-recommended[b-zvv8hdsua6] {
    border-top-color: var(--rq-deep-navy);
}

.qr-tier-card-premium[b-zvv8hdsua6] {
    border-top-color: var(--rq-warm-copper);
}

/*
 * Selected tier checkmark — outlined copper ring. Softer than the wizard's filled
 * navy circle; aligns with the brand's "copper for small accent moments" rule
 * (stars, badges, highlights). Copper Dark is the AA-safe variant for normal-sized
 * iconography on light surfaces; Warm Copper would fail contrast for the stroke.
 * The check stays copper across all three tiers regardless of the per-tier border
 * colour — one consistent "selected" signal at the corner.
 */
.qr-tier-check[b-zvv8hdsua6] {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 26px;
    height: 26px;
    background: transparent;
    border: 2px solid var(--rq-copper-dark);
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--rq-copper-dark);
}

[b-zvv8hdsua6] .qr-tier-check .mud-icon-root {
    font-size: 16px !important;
    color: var(--rq-copper-dark);
    font-weight: 700;
}

/* ── Badges ───────────────────────────────────────────────────────────────── */

.qr-badge[b-zvv8hdsua6] {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    padding: 5px 14px;
    border-radius: 999px;
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    white-space: nowrap;
}

/* RECOMMENDED — Deep Navy + white. Authoritative "dependable default" signal;
   white on navy is 12.80:1 — AA Pass for normal AND large text. */
.qr-badge-recommended[b-zvv8hdsua6] {
    background: var(--rq-deep-navy);
    color: var(--rq-pure-white);
}

/* PREMIUM — Warm Copper + white. Brand-forward "featured" treatment.
   Warm Copper #C47A2E fails AA on white text at small sizes; the badge text is
   bold and uppercase (effectively "large text" by WCAG), so warm copper + white
   passes AA Large. */
.qr-badge-premium[b-zvv8hdsua6] {
    background: var(--rq-warm-copper);
    color: var(--rq-pure-white);
}

/* ── Tier content ─────────────────────────────────────────────────────────── */

.qr-tier-headline[b-zvv8hdsua6] {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--rq-deep-navy);
    letter-spacing: -0.4px;
    margin-top: 4px;
}

.qr-tier-description[b-zvv8hdsua6] {
    font-size: 0.875rem;
    color: var(--rq-slate-grey);
    line-height: 1.5;
    margin: 0;
}

.qr-tier-price-card[b-zvv8hdsua6] {
    padding: 18px 16px;
    background: var(--rq-pure-white);
    border: 1px solid var(--rq-sandstone);
    border-radius: 10px;
    text-align: center;
}

.qr-tier-card-selected .qr-tier-price-card[b-zvv8hdsua6] {
    border-color: var(--rq-warm-white);
    background: var(--rq-pure-white);
}

.qr-tier-price[b-zvv8hdsua6] {
    font-size: 2rem;
    font-weight: 800;
    color: var(--rq-near-black);
    letter-spacing: -0.5px;
    line-height: 1.1;
}

.qr-tier-price-caption[b-zvv8hdsua6] {
    margin-top: 6px;
    font-size: 0.75rem;
    color: var(--rq-slate-grey);
}

.qr-features-list[b-zvv8hdsua6] {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-size: 0.875rem;
    color: var(--rq-near-black);
    line-height: 1.45;
}

.qr-features-list li[b-zvv8hdsua6] {
    position: relative;
    padding-left: 18px;
}

.qr-features-list li[b-zvv8hdsua6]::before {
    content: "•";
    position: absolute;
    left: 4px;
    top: 0;
    color: var(--rq-copper-dark);
    font-weight: 700;
}

/* ── Warning callout (Refresh tier) ───────────────────────────────────────── */

.qr-warning-callout[b-zvv8hdsua6] {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    background: rgba(217, 119, 6, 0.08);
    border: 1px solid rgba(217, 119, 6, 0.25);
    border-radius: 8px;
    font-size: 0.8125rem;
    line-height: 1.4;
    color: var(--rq-warning-amber);
    text-align: left;
}

[b-zvv8hdsua6] .qr-warning-callout .mud-icon-root {
    color: var(--rq-warning-amber);
    flex-shrink: 0;
    margin-top: 1px;
}

/* ── CTA row ──────────────────────────────────────────────────────────────── */

.qr-cta-row[b-zvv8hdsua6] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin: 32px 0 24px;
}

.qr-back-link[b-zvv8hdsua6] {
    font-size: 0.875rem;
    color: var(--rq-slate-grey);
    text-decoration: underline;
    text-decoration-color: var(--rq-sandstone);
    text-underline-offset: 3px;
}

.qr-back-link:hover[b-zvv8hdsua6] {
    color: var(--rq-copper-dark);
    text-decoration-color: currentColor;
}

/* ── Disclaimer ───────────────────────────────────────────────────────────── */

.qr-disclaimer[b-zvv8hdsua6] {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: clamp(12px, 2vw, 16px) clamp(14px, 3vw, 20px);
    background: var(--rq-pure-white);
    border: 1px solid var(--rq-sandstone);
    border-radius: 10px;
    margin-bottom: 32px;
    font-size: 0.8125rem;
    color: var(--rq-slate-grey);
    line-height: 1.5;
}

[b-zvv8hdsua6] .qr-disclaimer .mud-icon-root {
    color: var(--rq-info-blue);
    flex-shrink: 0;
    margin-top: 2px;
}

.qr-disclaimer p[b-zvv8hdsua6] {
    margin: 0;
}

.qr-disclaimer strong[b-zvv8hdsua6] {
    color: var(--rq-near-black);
    font-weight: 700;
}

/* ── Breakdown (revealed by CTA) ──────────────────────────────────────────── */

.qr-breakdown[b-zvv8hdsua6] {
    margin-top: 24px;
    scroll-margin-top: 24px;
}

.qr-section-heading[b-zvv8hdsua6] {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--rq-deep-navy);
    letter-spacing: -0.3px;
    margin: 0 0 16px;
}

.qr-line-items[b-zvv8hdsua6] {
    background: var(--rq-pure-white);
    border: 1px solid var(--rq-sandstone);
    border-radius: 10px;
    overflow: hidden;
}

.qr-line[b-zvv8hdsua6] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 14px clamp(14px, 3vw, 20px);
    border-bottom: 1px solid var(--rq-sandstone);
    gap: 16px;
}

.qr-line:last-child[b-zvv8hdsua6] {
    border-bottom: none;
}

/* On narrow viewports, stack the desc above the qty + total so neither column
   crushes the other. Total stays right-aligned via the parent flex direction. */
@media (max-width: 599.98px) {
    .qr-line[b-zvv8hdsua6] {
        flex-direction: column;
        align-items: stretch;
        gap: 6px;
    }

    .qr-line-total[b-zvv8hdsua6] {
        flex-direction: row;
        justify-content: space-between;
        align-items: baseline;
    }
}

.qr-line-desc[b-zvv8hdsua6] {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 0.875rem;
    color: var(--rq-near-black);
}

.qr-line-notes[b-zvv8hdsua6] {
    font-size: 0.75rem;
    color: var(--rq-mid-grey);
    font-style: italic;
}

.qr-line-total[b-zvv8hdsua6] {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--rq-near-black);
    white-space: nowrap;
}

.qr-line-qty[b-zvv8hdsua6] {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--rq-slate-grey);
}
/* /Components/Pages/Quotes/QuoteStart.razor.rz.scp.css */
/*
 * Quote-start page scoped styles. Class names use no project prefix —
 * Blazor scoped CSS (per-page [b-xxx] attribute) handles uniqueness.
 *
 * Section bands are full-bleed because MainLayout no longer wraps pages
 * in a constraining MudContainer. Per-section content alignment uses an
 * inner MudContainer.
 */

section.section[b-unitvqbmss] {
    /* Scales 80→40 top/bottom, 24→16 sides across desktop → mobile. */
    padding: clamp(40px, 6vw, 80px) clamp(16px, 4vw, 24px);
}

/* ----- Section A: Hero ----- */
.hero[b-unitvqbmss] {
    background-color: var(--rq-deep-navy);
    color: var(--rq-pure-white);
    text-align: center;
    padding-bottom: clamp(48px, 8vw, 96px);
}

.hero-icon[b-unitvqbmss] {
    width: 56px;
    height: 56px;
    background: var(--rq-overlay-soft);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 32px;
}

.hero h1[b-unitvqbmss] {
    font-size: clamp(2.25rem, 5vw, 3.75rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.5px;
    margin: 0 0 12px;
    color: var(--rq-pure-white);
}

.hero-subhead[b-unitvqbmss] {
    font-size: clamp(1.25rem, 2vw, 1.5rem);
    font-weight: 700;
    color: var(--rq-pure-white);
    margin: 0 0 24px;
}

.hero-body[b-unitvqbmss] {
    font-size: 1rem;
    color: var(--rq-text-on-navy);
    max-width: 720px;
    margin: 0 auto 40px;
    line-height: 1.6;
}

.feature-card[b-unitvqbmss] {
    background: var(--rq-overlay-faint);
    border: 1px solid var(--rq-overlay-soft);
    border-radius: 12px;
    padding: clamp(20px, 4vw, 32px) clamp(16px, 3vw, 24px);
    text-align: center;
    height: 100%;
}

.feature-heading[b-unitvqbmss] {
    font-size: 1.0625rem;
    font-weight: 700;
    color: var(--rq-pure-white);
    margin: 16px 0 8px;
}

.feature-body[b-unitvqbmss] {
    font-size: 0.875rem;
    color: var(--rq-text-on-navy-muted);
    margin: 0;
    line-height: 1.5;
}

/* ----- Section B: Calculator wizard band ----- */
.calc[b-unitvqbmss] {
    background-color: var(--rq-warm-white);
    padding-top: clamp(32px, 5vw, 64px);
    padding-bottom: clamp(32px, 5vw, 64px);
}

/* ----- Section C: Why Choose ----- */
.why[b-unitvqbmss] {
    background-color: var(--rq-pure-white);
    text-align: center;
}

.why h2[b-unitvqbmss] {
    font-size: clamp(1.75rem, 4vw, 2rem);
    font-weight: 800;
    letter-spacing: -0.5px;
    color: var(--rq-near-black);
    margin: 0 0 24px;
}

.why-body[b-unitvqbmss] {
    font-size: 1rem;
    color: var(--rq-slate-grey);
    max-width: 720px;
    margin: 0 auto;
    line-height: 1.7;
}

/* ----- Section D: Disclaimer ----- */
.disclaimer[b-unitvqbmss] {
    background-color: var(--rq-sandstone);
    padding-top: 32px;
    padding-bottom: 32px;
}

.disclaimer-inner[b-unitvqbmss] {
    display: flex;
    gap: 12px;
    align-items: flex-start;
}

/* `::deep` because .disclaimer-icon is forwarded onto MudIcon's rendered element,
   which doesn't carry this page's scope attribute. */
[b-unitvqbmss] .disclaimer-icon {
    color: var(--rq-slate-grey);
    flex-shrink: 0;
    margin-top: 2px;
}

.disclaimer-body[b-unitvqbmss] {
    font-size: 0.8125rem;
    color: var(--rq-slate-grey);
    line-height: 1.6;
    margin: 0;
}

.disclaimer-body strong[b-unitvqbmss] {
    color: var(--rq-near-black);
    font-weight: 700;
}
/* /Components/Pages/Quotes/Wizard/QuoteWizard.razor.rz.scp.css */
/*
 * Quote-wizard scoped styles. Class names use the qw- prefix so they don't collide
 * with QuoteStart.razor's qs- classes — both files share the same scope attribute
 * at runtime, but human readability matters for diffs.
 */

.qw-utility-bar[b-726178uffz] {
    display: flex;
    gap: 8px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

/* .rq-utility-pill is defined in wwwroot/css/brand.css (shared). */

.qw-tab-row[b-726178uffz] {
    display: flex;
    gap: 0;
    background: var(--rq-sandstone);
    border-radius: 8px;
    padding: 4px;
    margin-bottom: 24px;
}

.qw-tab[b-726178uffz] {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px clamp(8px, 2vw, 16px);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--rq-slate-grey);
    border-radius: 6px;
    cursor: not-allowed;
    text-align: center;
    min-width: 0; /* allow shrinking below content size so text can ellipse */
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.qw-tab.qw-tab-active[b-726178uffz] {
    background: var(--rq-pure-white);
    color: var(--rq-near-black);
    font-weight: 600;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
    cursor: default;
}

.qw-step-card[b-726178uffz] {
    background: var(--rq-pure-white);
    border: 1px solid var(--rq-sandstone);
    border-radius: 12px;
    /* Scales 32 → 20 across desktop → narrow mobile so card content has room. */
    padding: clamp(20px, 4vw, 32px);
}

.qw-step-header[b-726178uffz] {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
}

.qw-step-title[b-726178uffz] {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--rq-near-black);
    margin: 0;
    letter-spacing: -0.3px;
}

.qw-progress-row[b-726178uffz] {
    display: flex;
    justify-content: space-between;
    font-size: 0.8125rem;
    color: var(--rq-slate-grey);
    margin-bottom: 8px;
}

.qw-progress-track[b-726178uffz] {
    height: 4px;
    background: var(--rq-sandstone);
    border-radius: 2px;
    overflow: hidden;
    margin-bottom: 32px;
}

.qw-progress-fill[b-726178uffz] {
    height: 100%;
    background: var(--rq-deep-navy);
    transition: width 200ms ease-out;
}

.qw-loading[b-726178uffz] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 64px 16px;
    color: var(--rq-slate-grey);
    font-size: 0.9375rem;
}

.qw-quick-tip[b-726178uffz] {
    display: flex;
    gap: 12px;
    margin-top: 16px;
    padding: 16px 18px;
    background: rgba(59, 130, 246, 0.08);
    border: 1px solid rgba(59, 130, 246, 0.25);
    border-radius: 8px;
    color: var(--rq-info-blue);
    font-size: 0.875rem;
    line-height: 1.5;
}

[b-726178uffz] .qw-quick-tip .mud-icon-root {
    color: var(--rq-info-blue);
    flex-shrink: 0;
    margin-top: 2px;
}

.qw-quick-tip p[b-726178uffz] {
    margin: 0;
}

.qw-quick-tip strong[b-726178uffz] {
    color: var(--rq-info-blue);
    font-weight: 700;
}

.qw-footer[b-726178uffz] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-top: 24px;
}

/* At sub-sm, stack the back/continue buttons full-width so each is a comfortable
   tap target rather than competing for horizontal space. */
@media (max-width: 599.98px) {
    .qw-footer[b-726178uffz] {
        flex-direction: column-reverse; /* Continue stays primary (on top) */
        align-items: stretch;
    }
}

/*
 * Shared step-internal styles. Step components are nested children of the wizard
 * coordinator and don't carry this scope attribute themselves, so we use `::deep`
 * to reach through and style their qs-* classes from here. Keeping these next to
 * the wizard rather than in a global stylesheet bounds them to the wizard surface.
 */

[b-726178uffz] .qs-step-heading {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--rq-near-black);
    margin: 0 0 6px;
    letter-spacing: -0.2px;
}

[b-726178uffz] .qs-step-subhead {
    font-size: 0.875rem;
    color: var(--rq-slate-grey);
    margin: 0 0 24px;
    line-height: 1.5;
}

[b-726178uffz] .qs-step-subhead .qs-emph {
    color: var(--rq-copper-dark);
    font-weight: 600;
}

[b-726178uffz] .qs-card-grid {
    display: grid;
    gap: 12px;
    margin-bottom: 16px;
}

[b-726178uffz] .qs-card-grid-2 {
    grid-template-columns: repeat(2, 1fr);
}

[b-726178uffz] .qs-card-grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

/* 3-up card grids collapse to 1-up below md (960) — 3 cards in a row are too
   tight inside the wizard's MaxWidth.Medium container under desktop width.
   2-up grids hold up to sm (600) before collapsing. */
@media (max-width: 959.98px) {
    [b-726178uffz] .qs-card-grid-3 {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 599.98px) {
    [b-726178uffz] .qs-card-grid-2 {
        grid-template-columns: 1fr;
    }
}

[b-726178uffz] .qs-choice-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 18px 14px;
    background: var(--rq-pure-white);
    border: 1px solid var(--rq-sandstone);
    border-radius: 10px;
    cursor: pointer;
    text-align: center;
    transition: border-color 120ms ease, background-color 120ms ease;
    color: var(--rq-near-black);
    font-family: inherit;
}

[b-726178uffz] .qs-choice-card:hover {
    border-color: var(--rq-copper-dark);
}

[b-726178uffz] .qs-choice-card-tall {
    padding: 24px 16px;
}

[b-726178uffz] .qs-choice-card-selected {
    border: 1.5px solid var(--rq-copper-dark);
    background: var(--rq-warm-white);
}

[b-726178uffz] .qs-choice-icon-block {
    width: 48px;
    height: 48px;
    background: rgba(196, 122, 46, 0.10);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 4px;
}

[b-726178uffz] .qs-choice-label {
    font-size: 0.9375rem;
    font-weight: 600;
}

[b-726178uffz] .qs-choice-headline {
    font-size: 1.0625rem;
    font-weight: 700;
}

[b-726178uffz] .qs-choice-body {
    font-size: 0.8125rem;
    color: var(--rq-slate-grey);
    line-height: 1.4;
}

[b-726178uffz] .qs-choice-check {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 22px;
    height: 22px;
    background: var(--rq-deep-navy);
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

[b-726178uffz] .qs-choice-radio {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 18px;
    height: 18px;
    border: 1.5px solid var(--rq-mid-grey);
    border-radius: 50%;
    background: var(--rq-pure-white);
}

[b-726178uffz] .qs-choice-radio-selected {
    border-color: var(--rq-copper-dark);
    background: radial-gradient(circle, var(--rq-copper-dark) 0 5px, var(--rq-pure-white) 6px 100%);
}

[b-726178uffz] .qs-choice-badge {
    display: inline-block;
    margin-top: 4px;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.04em;
}

[b-726178uffz] .qs-choice-badge-success {
    color: var(--rq-eucalyptus);
    border: 1px solid var(--rq-eucalyptus);
    background: rgba(45, 143, 94, 0.06);
}

[b-726178uffz] .qs-choice-badge-warn {
    color: var(--rq-warning-amber);
    border: 1px solid var(--rq-warning-amber);
    background: rgba(217, 119, 6, 0.06);
}

[b-726178uffz] .qs-choice-floating-badge {
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    padding: 3px 10px;
    background: var(--rq-info-blue);
    color: var(--rq-pure-white);
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    border-radius: 999px;
}

[b-726178uffz] .qs-choice-card-condition {
    align-items: flex-start;
    text-align: left;
    gap: 8px;
}

[b-726178uffz] .qs-choice-multiplier {
    font-size: 0.8125rem;
    font-weight: 600;
    margin-top: 8px;
}

[b-726178uffz] .qs-bullet-list {
    list-style: none;
    padding: 0;
    margin: 8px 0 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-size: 0.8125rem;
    color: var(--rq-slate-grey);
    line-height: 1.4;
}

[b-726178uffz] .qs-bullet-list li {
    display: flex;
    gap: 8px;
    align-items: flex-start;
}

[b-726178uffz] .qs-bullet-list li .mud-icon-root {
    flex-shrink: 0;
    margin-top: 2px;
}

[b-726178uffz] .qs-section-label {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 20px 0 8px;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--rq-near-black);
}

[b-726178uffz] .qs-section-question {
    font-size: 0.875rem;
    color: var(--rq-slate-grey);
    margin: 0 0 16px;
}

[b-726178uffz] .qs-centered-question {
    text-align: center;
    font-size: 0.9375rem;
    color: var(--rq-near-black);
    margin: 0 0 16px;
}

[b-726178uffz] .qs-pill-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}

[b-726178uffz] .qs-pill {
    min-width: 56px;
    padding: 10px 18px;
    border: 1px solid var(--rq-sandstone);
    background: var(--rq-pure-white);
    color: var(--rq-near-black);
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    font-size: 0.9375rem;
    transition: background-color 120ms ease, color 120ms ease;
}

[b-726178uffz] .qs-pill:hover {
    border-color: var(--rq-copper-dark);
}

[b-726178uffz] .qs-pill-selected {
    background: var(--rq-deep-navy);
    color: var(--rq-pure-white);
    border-color: var(--rq-deep-navy);
}

[b-726178uffz] .qs-area-readout {
    margin-top: 20px;
    padding: 16px 20px;
    background: var(--rq-warm-white);
    border: 1px solid var(--rq-sandstone);
    border-radius: 10px;
    display: flex;
    align-items: center;
    gap: 16px;
}

[b-726178uffz] .qs-area-caption {
    display: block;
    font-size: 0.8125rem;
    color: var(--rq-slate-grey);
    margin-bottom: 4px;
}

[b-726178uffz] .qs-area-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--rq-near-black);
}

[b-726178uffz] .qs-postcode-row {
    display: flex;
    gap: 12px;
    align-items: center;
    margin-bottom: 8px;
    flex-wrap: wrap;
}

[b-726178uffz] .qs-postcode-row .mud-input-control {
    flex: 1;
    min-width: 200px;
}

[b-726178uffz] .qs-region-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--rq-eucalyptus);
    border: 1px solid var(--rq-eucalyptus);
    background: rgba(45, 143, 94, 0.06);
}

[b-726178uffz] .qs-region-chip-unknown {
    color: var(--rq-warning-amber);
    border-color: var(--rq-warning-amber);
    background: rgba(217, 119, 6, 0.06);
}

[b-726178uffz] .qs-caption {
    font-size: 0.8125rem;
    color: var(--rq-slate-grey);
    margin: 0 0 8px;
    line-height: 1.4;
}

[b-726178uffz] .qs-caption-faint {
    color: var(--rq-mid-grey);
    margin-top: 4px;
}

[b-726178uffz] .qs-info-box {
    margin-top: 16px;
    padding: 14px 16px;
    background: var(--rq-warm-white);
    border: 1px solid var(--rq-sandstone);
    border-radius: 8px;
    display: flex;
    gap: 10px;
    font-size: 0.875rem;
    line-height: 1.5;
    color: var(--rq-slate-grey);
}

[b-726178uffz] .qs-info-box strong {
    color: var(--rq-near-black);
    font-weight: 700;
}

[b-726178uffz] .qs-field-block {
    margin-top: 16px;
}

[b-726178uffz] .qs-field-block + .qs-field-block {
    margin-top: 24px;
}

[b-726178uffz] .qs-field-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--rq-near-black);
    margin-bottom: 6px;
}

[b-726178uffz] .qs-brand-card {
    padding: 14px 12px;
    background: var(--rq-pure-white);
    border: 1px solid var(--rq-sandstone);
    border-radius: 10px;
    cursor: pointer;
    text-align: center;
    font-family: inherit;
    color: var(--rq-slate-grey);
    transition: border-color 120ms ease;
}

[b-726178uffz] .qs-brand-card:hover {
    border-color: var(--rq-copper-dark);
}

[b-726178uffz] .qs-brand-card-selected {
    border: 1.5px solid var(--rq-copper-dark);
    background: var(--rq-warm-white);
    color: var(--rq-near-black);
    font-weight: 700;
}

[b-726178uffz] .qs-brand-label {
    font-size: 0.9375rem;
}
