/* Legal/CMS pages — PBI #45359 */
/* Shared layout for FAQ, Safety Data Sheets, Terms & Conditions, Privacy Policy, Consumer Privacy Act */

.legal-page {
    max-width: 900px;
    margin: 0 auto;
    padding: 2rem;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* Card component — uses <article> and <header> to survive unclosed Storyblok <div> tags */
.legal-card {
    border: 1px solid #e5e5e5;
    border-radius: 12px;
    margin-bottom: 20px;
    overflow: hidden;
}

.legal-card__header {
    background: #f8f8f8;
    padding: 14px 20px;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    color: #666;
    border-bottom: 1px solid #e5e5e5;
}

.legal-card__body {
    padding: 20px;
}

/* Rich-text content styling (Storyblok HTML) */
.legal-card__body h1 {
    font-size: 22px;
    font-weight: 600;
    color: #262626;
    margin: 0 0 16px;
    line-height: 1.3;
}

.legal-card__body h2 {
    font-size: 18px;
    font-weight: 600;
    color: #262626;
    margin: 24px 0 12px;
    line-height: 1.3;
}

.legal-card__body h3 {
    font-size: 16px;
    font-weight: 600;
    color: #262626;
    margin: 20px 0 10px;
    line-height: 1.3;
}

.legal-card__body h4,
.legal-card__body h5,
.legal-card__body h6 {
    font-size: 14px;
    font-weight: 600;
    color: #262626;
    margin: 16px 0 8px;
    line-height: 1.4;
}

.legal-card__body p {
    font-size: 14px;
    line-height: 1.65;
    color: #444;
    margin: 0 0 12px;
}

.legal-card__body p:last-child {
    margin-bottom: 0;
}

.legal-card__body a {
    color: #C4112F;
    text-decoration: none;
}

.legal-card__body a:hover {
    text-decoration: underline;
}

.legal-card__body ul,
.legal-card__body ol {
    font-size: 14px;
    line-height: 1.65;
    color: #444;
    margin: 0 0 12px;
    padding-left: 24px;
}

.legal-card__body li {
    margin-bottom: 4px;
}

.legal-card__body li:last-child {
    margin-bottom: 0;
}

.legal-card__body strong {
    font-weight: 600;
    color: #262626;
}

.legal-card__body em {
    font-style: italic;
}

.legal-card__body blockquote {
    border-left: 3px solid #C4112F;
    margin: 16px 0;
    padding: 12px 16px;
    background: #fafafa;
    color: #444;
    font-size: 14px;
    line-height: 1.65;
}

/* Tables */
.legal-card__body table {
    width: 100%;
    border-collapse: collapse;
    margin: 16px 0;
    font-size: 14px;
}

.legal-card__body th {
    background: #f8f8f8;
    font-weight: 600;
    color: #262626;
    text-align: left;
    padding: 10px 14px;
    border: 1px solid #e5e5e5;
}

.legal-card__body td {
    padding: 10px 14px;
    border: 1px solid #e5e5e5;
    color: #444;
    line-height: 1.5;
}

/* Images */
.legal-card__body img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin: 12px 0;
}

/* Catch-all for unexpected elements */
.legal-card__body > *:first-child {
    margin-top: 0;
}

/* Responsive */
@media (max-width: 768px) {
    .legal-page {
        padding: 1rem;
    }

    .legal-card__body {
        padding: 16px;
    }

    .legal-card__body h1 {
        font-size: 20px;
    }

    .legal-card__body h2 {
        font-size: 16px;
    }
}

@media (max-width: 480px) {
    .legal-page {
        padding: 0.75rem;
    }

    .legal-card__body {
        padding: 14px;
    }

    /* Allow wide tables to scroll horizontally */
    .legal-card__body table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}
