/* Legal pages: /offer/ and /personal-data/
   CSS-only polish. No extra header/hero, no template restructuring. */

:root {
    --bb-legal-bg: #f4f6f8;
    --bb-legal-card: #ffffff;
    --bb-legal-text: #111827;
    --bb-legal-soft-text: #374151;
    --bb-legal-muted: #667085;
    --bb-legal-border: rgba(17, 24, 39, 0.10);
    --bb-legal-border-strong: rgba(17, 24, 39, 0.16);
    --bb-legal-red: #dc2626;
    --bb-legal-red-dark: #b91c1c;
    --bb-legal-soft-red: rgba(220, 38, 38, 0.08);
    --bb-legal-shadow: 0 18px 46px rgba(15, 23, 42, 0.08);
}

body.bb-legal-body {
    min-height: 100vh;
    margin: 0;
    color: var(--bb-legal-text);
    background:
        radial-gradient(circle at 8% 0%, rgba(220, 38, 38, 0.06), transparent 28rem),
        linear-gradient(180deg, #ffffff 0%, var(--bb-legal-bg) 42%, #ffffff 100%) !important;
}

/* Override old inline .legal-wrap safely with stronger selector. */
body.bb-legal-body .legal-wrap.bb-legal-page {
    width: min(1120px, calc(100% - 32px)) !important;
    max-width: 1120px !important;
    margin: 0 auto !important;
    padding: 30px 0 64px !important;
}

/* Back link: compact, without adding a second page header. */
/* Main white document card. */
body.bb-legal-body .legal-card {
    overflow: hidden !important;
    border: 1px solid var(--bb-legal-border) !important;
    border-radius: 28px !important;
    background: var(--bb-legal-card) !important;
    box-shadow: var(--bb-legal-shadow) !important;
    padding: 0 !important;
}

/* Single page title, not a second header. */
body.bb-legal-body .legal-card > h1 {
    margin: 0 !important;
    padding: 34px 38px 12px !important;
    color: var(--bb-legal-text) !important;
    background:
        linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%) !important;
    border-bottom: 0 !important;
    font-size: clamp(30px, 3.6vw, 44px) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.045em !important;
}

body.bb-legal-body .legal-card > h1::before {
    content: "Юридическая информация";
    display: inline-flex;
    width: max-content;
    max-width: 100%;
    margin: 0 0 14px;
    padding: 8px 12px;
    border: 1px solid rgba(220, 38, 38, 0.16);
    border-radius: 999px;
    color: var(--bb-legal-red-dark);
    background: var(--bb-legal-soft-red);
    font-size: 12px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

/* Intro under h1. */
body.bb-legal-body .legal-card > .lead {
    max-width: 860px !important;
    margin: 0 !important;
    padding: 0 38px 30px !important;
    color: var(--bb-legal-muted) !important;
    background: #ffffff !important;
    font-size: 16px !important;
    line-height: 1.65 !important;
}

/* Content area. */
body.bb-legal-body .legal-content {
    padding: 6px 38px 40px !important;
    color: var(--bb-legal-soft-text) !important;
    font-size: 16px !important;
    line-height: 1.72 !important;
}

/* Legal text headings. */
body.bb-legal-body .legal-content h2 {
    margin: 26px 0 12px !important;
    padding: 18px 20px !important;
    border: 1px solid var(--bb-legal-border) !important;
    border-left: 5px solid var(--bb-legal-red) !important;
    border-radius: 18px !important;
    color: var(--bb-legal-text) !important;
    background: #fbfcfd !important;
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.045) !important;
    font-size: clamp(20px, 2vw, 26px) !important;
    line-height: 1.22 !important;
    letter-spacing: -0.025em !important;
}

/* First h2 after the intro should not look like another page title. */
body.bb-legal-body .legal-content h2:first-child {
    margin-top: 0 !important;
}

body.bb-legal-body .legal-content h3 {
    margin: 22px 0 10px !important;
    color: var(--bb-legal-text) !important;
    font-size: 18px !important;
    line-height: 1.28 !important;
}

/* Paragraphs should be readable text, not dozens of separate heavy cards. */
body.bb-legal-body .legal-content p,
body.bb-legal-body .legal-content ul,
body.bb-legal-body .legal-content ol {
    margin: 0 0 14px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: var(--bb-legal-soft-text) !important;
    font-size: 16px !important;
    line-height: 1.72 !important;
}

body.bb-legal-body .legal-content ul,
body.bb-legal-body .legal-content ol {
    padding-left: 24px !important;
}

body.bb-legal-body .legal-content li + li {
    margin-top: 7px !important;
}

body.bb-legal-body .legal-content strong {
    color: var(--bb-legal-text) !important;
    font-weight: 850 !important;
}

body.bb-legal-body .legal-content a {
    color: var(--bb-legal-red-dark) !important;
    font-weight: 800 !important;
    text-decoration: none !important;
    border-bottom: 1px solid rgba(220, 38, 38, 0.28) !important;
}

body.bb-legal-body .legal-content a:hover {
    color: var(--bb-legal-red) !important;
    border-bottom-color: currentColor !important;
}

/* Tables inside legal text. */
body.bb-legal-body .legal-content table {
    width: 100% !important;
    overflow: hidden !important;
    margin: 18px 0 22px !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    border: 1px solid var(--bb-legal-border-strong) !important;
    border-radius: 18px !important;
    background: #ffffff !important;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05) !important;
}

body.bb-legal-body .legal-content th,
body.bb-legal-body .legal-content td {
    padding: 14px 16px !important;
    border-bottom: 1px solid var(--bb-legal-border) !important;
    vertical-align: top !important;
    text-align: left !important;
}

body.bb-legal-body .legal-content tr:last-child th,
body.bb-legal-body .legal-content tr:last-child td {
    border-bottom: 0 !important;
}

body.bb-legal-body .legal-content th {
    color: var(--bb-legal-text) !important;
    background: #f8fafc !important;
    font-weight: 850 !important;
}

@media (max-width: 760px) {
    body.bb-legal-body .legal-wrap.bb-legal-page {
        width: min(100% - 20px, 1120px) !important;
        padding: 18px 0 46px !important;
    }

    body.bb-legal-body .legal-card {
        border-radius: 22px !important;
    }

    body.bb-legal-body .legal-card > h1 {
        padding: 26px 20px 10px !important;
        font-size: clamp(27px, 8vw, 36px) !important;
    }

    body.bb-legal-body .legal-card > .lead {
        padding: 0 20px 24px !important;
        font-size: 15px !important;
    }

    body.bb-legal-body .legal-content {
        padding: 4px 20px 30px !important;
        font-size: 15px !important;
    }

    body.bb-legal-body .legal-content h2 {
        padding: 16px 16px !important;
        border-radius: 16px !important;
        font-size: 21px !important;
    }

    body.bb-legal-body .legal-content p,
    body.bb-legal-body .legal-content ul,
    body.bb-legal-body .legal-content ol {
        font-size: 15px !important;
    }

    body.bb-legal-body .legal-content ul,
    body.bb-legal-body .legal-content ol {
        padding-left: 20px !important;
    }

    body.bb-legal-body .legal-content table {
        display: block !important;
        overflow-x: auto !important;
        white-space: nowrap !important;
    }
}


/* STEP 58I: legal pages readable document polish */
body.bb-legal-body .legal-wrap.bb-legal-page {
    width: min(100% - 40px, 1180px) !important;
    max-width: 1180px !important;
    padding: 34px 0 56px !important;
}

body.bb-legal-body .legal-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 18px;
    padding: clamp(28px, 4vw, 52px) !important;
    border-radius: 34px !important;
}

body.bb-legal-body .legal-card > h1 {
    max-width: 920px;
    margin-bottom: 8px !important;
    font-size: clamp(34px, 4vw, 58px) !important;
    line-height: .98 !important;
    letter-spacing: -.045em !important;
}

body.bb-legal-body .legal-card > .lead {
    max-width: 920px !important;
    font-size: 18px !important;
    line-height: 1.62 !important;
}

body.bb-legal-body .legal-content {
    max-width: none !important;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 14px;
    font-size: 17px !important;
    line-height: 1.72 !important;
}

body.bb-legal-body .legal-content h2 {
    margin-top: 24px !important;
    margin-bottom: 6px !important;
    padding: 18px 20px !important;
    border-radius: 22px !important;
    font-size: clamp(22px, 2.2vw, 30px) !important;
    line-height: 1.18 !important;
}

body.bb-legal-body .legal-content h3 {
    margin-top: 14px !important;
    margin-bottom: 4px !important;
    color: #111827 !important;
    font-size: 20px !important;
    line-height: 1.25 !important;
}

body.bb-legal-body .legal-content p,
body.bb-legal-body .legal-content li {
    max-width: 960px;
}

body.bb-legal-body .legal-content p {
    margin: 0 0 10px !important;
}

body.bb-legal-body .legal-content ul,
body.bb-legal-body .legal-content ol {
    max-width: 960px;
    margin-top: 0 !important;
    margin-bottom: 12px !important;
    padding-left: 24px !important;
}

body.bb-legal-body .legal-note,
body.bb-legal-body .legal-section-box,
body.bb-legal-body .legal-meta {
    max-width: 960px;
    border-radius: 24px !important;
}

body.bb-legal-body .legal-content table {
    max-width: 100%;
    font-size: 15px;
}

@media (max-width: 720px) {
    body.bb-legal-body .legal-wrap.bb-legal-page {
        width: min(100% - 24px, 1180px) !important;
        padding-top: 20px !important;
    }

    body.bb-legal-body .legal-card {
        padding: 22px 18px !important;
        border-radius: 24px !important;
    }

    body.bb-legal-body .legal-content {
        font-size: 16px !important;
        line-height: 1.65 !important;
    }

    body.bb-legal-body .legal-content h2 {
        padding: 15px 16px !important;
        border-radius: 18px !important;
    }
}


/* STEP 58J: align legal pages header with public site template */
body.bb-legal-body {
    background: #f4f6f8 !important;
}

body.bb-legal-body .bb-public-nav {
    max-width: 1180px;
    margin: 0 auto;
}

body.bb-legal-body .bb-legal-hero {
    margin-top: 0;
    color: #ffffff;
    background:
        radial-gradient(circle at 12% 0%, rgba(220, 38, 38, .18), transparent 28%),
        radial-gradient(circle at 88% 10%, rgba(248, 113, 113, .12), transparent 28%),
        linear-gradient(135deg, #0f172a, #111827);
}

body.bb-legal-body .bb-legal-hero__inner {
    max-width: 1180px;
    margin: 0 auto;
    padding: 48px 18px 86px;
}

body.bb-legal-body .bb-legal-hero__badge {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 13px;
    margin-bottom: 18px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .10);
    border: 1px solid rgba(255, 255, 255, .18);
    color: #fecaca;
    font-size: 13px;
    font-weight: 950;
    letter-spacing: .04em;
    text-transform: uppercase;
}

body.bb-legal-body .bb-legal-hero h1 {
    max-width: 900px;
    margin: 0 0 14px;
    color: #ffffff !important;
    font-size: clamp(38px, 5vw, 64px);
    line-height: .98;
    letter-spacing: -.055em;
}

body.bb-legal-body .bb-legal-hero p {
    max-width: 860px;
    margin: 0;
    color: #d1d5db;
    font-size: 18px;
    line-height: 1.62;
}

body.bb-legal-body .bb-legal-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
}

body.bb-legal-body .bb-legal-hero__actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 16px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, .18);
    background: rgba(255, 255, 255, .08);
    color: #ffffff;
    font-size: 14px;
    font-weight: 900;
    text-decoration: none;
}

body.bb-legal-body .bb-legal-hero__actions a:nth-child(2) {
    border-color: #dc2626;
    background: #dc2626;
    box-shadow: 0 14px 32px rgba(220, 38, 38, .28);
}

body.bb-legal-body .bb-legal-hero__actions a:hover {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, .14);
}

body.bb-legal-body .bb-legal-hero__actions a:nth-child(2):hover {
    background: #b91c1c;
}

body.bb-legal-body .legal-wrap.bb-legal-page {
    width: min(100% - 40px, 1180px) !important;
    max-width: 1180px !important;
    margin: -54px auto 0 !important;
    padding: 0 0 56px !important;
    position: relative;
    z-index: 2;
}

body.bb-legal-body .legal-card {
    border-radius: 34px !important;
    box-shadow: 0 24px 62px rgba(15, 23, 42, .13) !important;
}

body.bb-legal-body .legal-card > h1,
body.bb-legal-body .legal-card > .lead,
@media (max-width: 720px) {
    body.bb-legal-body .bb-legal-hero__inner {
        padding: 34px 14px 70px;
    }

    body.bb-legal-body .bb-legal-hero__actions a {
        width: 100%;
    }

    body.bb-legal-body .legal-wrap.bb-legal-page {
        width: min(100% - 24px, 1180px) !important;
        margin-top: -38px !important;
    }
}


/* STEP 58K-R: polish legal hero action block */
body.bb-legal-body .bb-legal-hero__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 24px;
    max-width: 760px;
}

body.bb-legal-body .bb-legal-hero__actions a {
    min-height: 44px;
    padding: 0 16px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, .20);
    background: rgba(255, 255, 255, .08);
    color: #ffffff;
    font-size: 14px;
    font-weight: 900;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
    box-shadow: 0 10px 24px rgba(15, 23, 42, .16);
    transition: transform .16s ease, background .16s ease, border-color .16s ease, box-shadow .16s ease;
}

body.bb-legal-body .bb-legal-hero__actions a:first-child {
    background: rgba(255, 255, 255, .12);
}

body.bb-legal-body .bb-legal-hero__actions a:nth-child(2) {
    border-color: #dc2626;
    background: #dc2626;
    box-shadow: 0 14px 32px rgba(220, 38, 38, .30);
}

body.bb-legal-body .bb-legal-hero__actions a:nth-child(3) {
    color: #fecaca;
}

body.bb-legal-body .bb-legal-hero__actions a:hover {
    transform: translateY(-1px);
    border-color: rgba(255, 255, 255, .34);
    background: rgba(255, 255, 255, .16);
}

body.bb-legal-body .bb-legal-hero__actions a:nth-child(2):hover {
    background: #b91c1c;
    border-color: #b91c1c;
}

body.bb-legal-body .bb-public-links a[href="/delivery/"] {
    border-color: rgba(220, 38, 38, .22);
    background: rgba(220, 38, 38, .06);
    color: #991b1b;
}

@media (max-width: 720px) {
    body.bb-legal-body .bb-legal-hero__actions {
        display: grid;
        grid-template-columns: 1fr;
        max-width: none;
        gap: 9px;
    }

    body.bb-legal-body .bb-legal-hero__actions a {
        width: 100%;
        justify-content: center;
        min-height: 48px;
        white-space: normal;
        text-align: center;
    }
}


/* STEP 66B: final mobile legal rescue
   Purpose: fix /offer/ and /personal-data/ mobile layout without touching catalog/cart pages. */
@media (max-width: 760px) {
    html,
    body.bb-legal-body {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
    }

    body.bb-legal-body * {
        box-sizing: border-box !important;
    }

    body.bb-legal-body {
        background:
            radial-gradient(circle at 0% 0%, rgba(220, 38, 38, 0.06), transparent 18rem),
            linear-gradient(180deg, #ffffff 0%, #f5f7fb 44%, #ffffff 100%) !important;
    }

    /* Compact legal-page navigation on mobile. */
    body.bb-legal-body .bb-public-nav {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 12px 14px 10px !important;
        border-radius: 0 !important;
        background: rgba(255, 255, 255, 0.98) !important;
        border-bottom: 1px solid rgba(15, 23, 42, 0.08) !important;
        box-shadow: 0 8px 20px rgba(15, 23, 42, 0.05) !important;
        overflow: hidden !important;
    }

    body.bb-legal-body .bb-public-logo {
        width: 100% !important;
        min-width: 0 !important;
        margin: 0 0 10px !important;
        padding: 0 !important;
    }

    body.bb-legal-body .bb-public-logo strong {
        display: block !important;
        max-width: 100% !important;
        overflow: hidden !important;
        color: #0f172a !important;
        font-size: 28px !important;
        line-height: 1.02 !important;
        letter-spacing: -0.055em !important;
        white-space: nowrap !important;
        text-overflow: ellipsis !important;
    }

    body.bb-legal-body .bb-public-logo span {
        display: block !important;
        max-width: 100% !important;
        margin-top: 2px !important;
        overflow: hidden !important;
        color: #64748b !important;
        font-size: 14px !important;
        line-height: 1.25 !important;
        font-weight: 800 !important;
        white-space: nowrap !important;
        text-overflow: ellipsis !important;
    }

    body.bb-legal-body .bb-public-links {
        width: 100% !important;
        max-width: 100% !important;
        display: flex !important;
        flex-flow: row nowrap !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 8px !important;
        margin: 0 !important;
        padding: 0 0 4px !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: none !important;
    }

    body.bb-legal-body .bb-public-links::-webkit-scrollbar {
        display: none !important;
    }

    body.bb-legal-body .bb-public-links a {
        flex: 0 0 auto !important;
        width: auto !important;
        min-width: max-content !important;
        max-width: none !important;
        min-height: 36px !important;
        margin: 0 !important;
        padding: 0 13px !important;
        border-radius: 999px !important;
        font-size: 13px !important;
        line-height: 36px !important;
        font-weight: 900 !important;
        text-align: center !important;
        white-space: nowrap !important;
    }

    body.bb-legal-body .bb-public-links a[href="/catalog/sale/"] {
        padding-left: 16px !important;
        padding-right: 16px !important;
        background: #dc2626 !important;
        color: #ffffff !important;
    }

    /* On mobile the dark hero duplicates the document title and creates overflow.
       Keep the document card as the main page content. */
    body.bb-legal-body .bb-legal-hero {
        display: none !important;
    }

    body.bb-legal-body .legal-wrap.bb-legal-page {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 14px 10px 42px !important;
        overflow: hidden !important;
    }

    body.bb-legal-body .legal-card {
        width: 100% !important;
        max-width: 100% !important;
        display: block !important;
        margin: 0 !important;
        padding: 24px 18px 28px !important;
        overflow: hidden !important;
        border-radius: 28px !important;
        border: 1px solid rgba(15, 23, 42, 0.08) !important;
        background: #ffffff !important;
        box-shadow: 0 16px 38px rgba(15, 23, 42, 0.08) !important;
    }

    body.bb-legal-body .legal-card > h1 {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 0 14px !important;
        padding: 0 !important;
        overflow-wrap: anywhere !important;
        color: #0f172a !important;
        background: transparent !important;
        font-size: clamp(34px, 11vw, 48px) !important;
        line-height: 0.98 !important;
        letter-spacing: -0.06em !important;
    }

    body.bb-legal-body .legal-card > h1::before {
        display: inline-flex !important;
        max-width: 100% !important;
        margin: 0 0 14px !important;
        padding: 8px 12px !important;
        border-radius: 999px !important;
        border: 1px solid rgba(220, 38, 38, 0.16) !important;
        color: #b91c1c !important;
        background: rgba(220, 38, 38, 0.08) !important;
        font-size: 12px !important;
        line-height: 1 !important;
        letter-spacing: 0.08em !important;
        text-transform: uppercase !important;
        white-space: normal !important;
    }

    body.bb-legal-body .legal-card > .lead {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 0 22px !important;
        padding: 0 !important;
        color: #667085 !important;
        background: transparent !important;
        font-size: 17px !important;
        line-height: 1.55 !important;
        overflow-wrap: anywhere !important;
    }

    body.bb-legal-body .legal-content {
        width: 100% !important;
        max-width: 100% !important;
        display: block !important;
        padding: 0 !important;
        color: #374151 !important;
        font-size: 16px !important;
        line-height: 1.65 !important;
        overflow: hidden !important;
    }

    body.bb-legal-body .legal-content h2 {
        width: 100% !important;
        max-width: 100% !important;
        margin: 20px 0 12px !important;
        padding: 15px 16px !important;
        border-radius: 18px !important;
        border: 1px solid rgba(15, 23, 42, 0.10) !important;
        border-left: 5px solid #dc2626 !important;
        background: #fbfcfd !important;
        color: #111827 !important;
        font-size: clamp(21px, 6vw, 28px) !important;
        line-height: 1.16 !important;
        letter-spacing: -0.035em !important;
        overflow-wrap: anywhere !important;
    }

    body.bb-legal-body .legal-content h3 {
        margin: 18px 0 8px !important;
        color: #111827 !important;
        font-size: 19px !important;
        line-height: 1.25 !important;
        overflow-wrap: anywhere !important;
    }

    body.bb-legal-body .legal-content p,
    body.bb-legal-body .legal-content li {
        max-width: 100% !important;
        color: #4b5563 !important;
        font-size: 16px !important;
        line-height: 1.65 !important;
        overflow-wrap: anywhere !important;
        word-break: normal !important;
    }

    body.bb-legal-body .legal-content p {
        margin: 0 0 12px !important;
    }

    body.bb-legal-body .legal-content ul,
    body.bb-legal-body .legal-content ol {
        max-width: 100% !important;
        margin: 0 0 14px !important;
        padding-left: 20px !important;
    }

    body.bb-legal-body .legal-note,
    body.bb-legal-body .legal-section-box,
    body.bb-legal-body .legal-meta {
        max-width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        border-radius: 20px !important;
        overflow: hidden !important;
    }

    body.bb-legal-body .legal-content table {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: auto !important;
        white-space: nowrap !important;
        -webkit-overflow-scrolling: touch !important;
    }

    body.bb-legal-body img,
    body.bb-legal-body svg,
    body.bb-legal-body iframe,
    body.bb-legal-body video {
        max-width: 100% !important;
        height: auto !important;
    }

    /* Chat / accessibility floating widgets must not visually crush CTA/content. */
    body.bb-legal-body [style*="position: fixed"],
    body.bb-legal-body .b24-widget-button-wrapper,
    body.bb-legal-body .b24-widget-button-position-bottom-right {
        max-width: calc(100vw - 20px) !important;
    }
}

@media (max-width: 380px) {
    body.bb-legal-body .bb-public-logo strong {
        font-size: 25px !important;
    }

    body.bb-legal-body .bb-public-logo span {
        font-size: 13px !important;
    }

    body.bb-legal-body .legal-card {
        padding: 22px 15px 26px !important;
        border-radius: 24px !important;
    }

    body.bb-legal-body .legal-card > h1 {
        font-size: clamp(30px, 10.5vw, 42px) !important;
    }
}

/* STEP 66B desktop safety: prevent accidental horizontal scroll on legal pages. */
body.bb-legal-body {
    overflow-x: hidden !important;
}

body.bb-legal-body .bb-legal-page,
body.bb-legal-body .legal-card,
body.bb-legal-body .legal-content {
    max-width: 100% !important;
}

/* STEP 66C: desktop legal pages polish
   Desktop keeps the dark hero as the main title and turns the white card into document content. */
@media (min-width: 761px) {
    body.bb-legal-body {
        overflow-x: hidden !important;
        background:
            linear-gradient(180deg, #ffffff 0%, #f4f6f8 48%, #ffffff 100%) !important;
    }

    body.bb-legal-body .bb-public-nav {
        width: min(1180px, calc(100% - 64px)) !important;
        max-width: 1180px !important;
        min-height: 58px !important;
        margin: 0 auto !important;
        padding: 8px 0 !important;
        border-radius: 0 !important;
        background: rgba(255, 255, 255, 0.98) !important;
        box-shadow: none !important;
    }

    body.bb-legal-body .bb-public-logo strong {
        font-size: 26px !important;
        line-height: 1 !important;
        letter-spacing: -0.045em !important;
    }

    body.bb-legal-body .bb-public-logo span {
        font-size: 14px !important;
        line-height: 1.15 !important;
    }

    body.bb-legal-body .bb-public-links {
        align-items: center !important;
        gap: 12px !important;
    }

    body.bb-legal-body .bb-public-links a {
        min-height: 38px !important;
        padding: 0 18px !important;
        border-radius: 12px !important;
        font-size: 14px !important;
        line-height: 38px !important;
        font-weight: 900 !important;
    }

    /* Legal pages must not show Delivery as active by default. */
    body.bb-legal-body .bb-public-links a[href="/delivery/"] {
        color: #334155 !important;
        background: transparent !important;
        border: 1px solid transparent !important;
        box-shadow: none !important;
    }

    body.bb-legal-body .bb-public-links a[href="/delivery/"]:hover {
        color: #dc2626 !important;
        background: rgba(220, 38, 38, 0.06) !important;
        border-color: rgba(220, 38, 38, 0.12) !important;
    }

    body.bb-legal-body .bb-public-links a[href="/catalog/sale/"] {
        color: #ffffff !important;
        background: #dc2626 !important;
        border-color: #dc2626 !important;
        box-shadow: 0 10px 24px rgba(220, 38, 38, 0.22) !important;
    }

    body.bb-legal-body .bb-legal-hero {
        display: block !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 58px 0 96px !important;
        overflow: hidden !important;
        background:
            radial-gradient(circle at 18% 0%, rgba(220, 38, 38, 0.22), transparent 28rem),
            radial-gradient(circle at 88% 24%, rgba(59, 130, 246, 0.12), transparent 26rem),
            linear-gradient(135deg, #170f1f 0%, #101827 52%, #09111f 100%) !important;
    }

    body.bb-legal-body .bb-legal-hero__inner {
        width: min(1180px, calc(100% - 64px)) !important;
        max-width: 1180px !important;
        margin: 0 auto !important;
    }

    body.bb-legal-body .bb-legal-hero__badge {
        width: max-content !important;
        max-width: 100% !important;
        margin: 0 0 18px !important;
        padding: 10px 18px !important;
        border-radius: 999px !important;
        color: #fecaca !important;
        background: rgba(255, 255, 255, 0.10) !important;
        border: 1px solid rgba(255, 255, 255, 0.16) !important;
        font-size: 13px !important;
        line-height: 1 !important;
        font-weight: 950 !important;
        letter-spacing: 0.08em !important;
        text-transform: uppercase !important;
    }

    body.bb-legal-body .bb-legal-hero h1 {
        max-width: 850px !important;
        margin: 0 0 22px !important;
        color: #ffffff !important;
        font-size: clamp(54px, 5.5vw, 86px) !important;
        line-height: 0.94 !important;
        letter-spacing: -0.065em !important;
    }

    body.bb-legal-body .bb-legal-hero p {
        max-width: 760px !important;
        margin: 0 0 26px !important;
        color: rgba(226, 232, 240, 0.82) !important;
        font-size: 18px !important;
        line-height: 1.55 !important;
    }

    body.bb-legal-body .bb-legal-hero__actions {
        width: auto !important;
        max-width: 100% !important;
        display: flex !important;
        flex-wrap: wrap !important;
        align-items: center !important;
        gap: 14px !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    body.bb-legal-body .bb-legal-hero__actions a {
        flex: 0 0 auto !important;
        width: auto !important;
        min-width: 0 !important;
        min-height: 48px !important;
        padding: 0 22px !important;
        border-radius: 14px !important;
        font-size: 15px !important;
        line-height: 48px !important;
        font-weight: 950 !important;
        text-align: center !important;
        white-space: nowrap !important;
    }

    body.bb-legal-body .bb-legal-hero__actions a:first-child,
    body.bb-legal-body .bb-legal-hero__actions a:nth-child(3) {
        color: #ffffff !important;
        background: rgba(255, 255, 255, 0.12) !important;
        border: 1px solid rgba(255, 255, 255, 0.18) !important;
        box-shadow: none !important;
    }

    body.bb-legal-body .bb-legal-hero__actions a:nth-child(2) {
        color: #ffffff !important;
        background: #dc2626 !important;
        border: 1px solid #dc2626 !important;
        box-shadow: 0 18px 34px rgba(220, 38, 38, 0.28) !important;
    }

    body.bb-legal-body .legal-wrap.bb-legal-page {
        width: min(1180px, calc(100% - 64px)) !important;
        max-width: 1180px !important;
        margin: -58px auto 0 !important;
        padding: 0 0 76px !important;
        position: relative !important;
        z-index: 2 !important;
    }

    body.bb-legal-body .legal-card {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 54px 70px 64px !important;
        border-radius: 36px !important;
        background: #ffffff !important;
        border: 1px solid rgba(15, 23, 42, 0.08) !important;
        box-shadow: 0 24px 62px rgba(15, 23, 42, 0.10) !important;
        overflow: hidden !important;
    }

    /* The title already exists in the hero on desktop. Avoid double H1. */
    body.bb-legal-body .legal-card > h1,
    body.bb-legal-body .legal-card > .lead {
        display: none !important;
    }

    body.bb-legal-body .legal-content {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 14px !important;
    }

    body.bb-legal-body .legal-content h2:first-child {
        margin-top: 0 !important;
    }

    body.bb-legal-body .legal-content h2 {
        max-width: 960px !important;
        margin: 24px 0 6px !important;
        padding: 20px 24px !important;
        border-radius: 22px !important;
        font-size: clamp(24px, 2.4vw, 34px) !important;
        line-height: 1.14 !important;
        letter-spacing: -0.04em !important;
    }

    body.bb-legal-body .legal-content h3 {
        max-width: 960px !important;
        margin: 16px 0 4px !important;
        font-size: 21px !important;
        line-height: 1.25 !important;
    }

    body.bb-legal-body .legal-content p,
    body.bb-legal-body .legal-content ul,
    body.bb-legal-body .legal-content ol,
    body.bb-legal-body .legal-note,
    body.bb-legal-body .legal-section-box,
    body.bb-legal-body .legal-meta {
        max-width: 960px !important;
    }

    body.bb-legal-body .legal-content p,
    body.bb-legal-body .legal-content li {
        font-size: 17px !important;
        line-height: 1.72 !important;
    }
}
