:root {
    --legal-max: 72rem;
}

.page-legal .p-contact__page-header .p-legal__header-cta {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
    margin-top: 1rem;
}

.page-legal .p-legal__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    border-radius: var(--radius-md, 8px);
    background: var(--color-secondary, #e94560);
    color: #fff;
    text-decoration: none;
    font-weight: 600;
    transition: var(--transition, 0.25s ease);
}

.page-legal .p-legal__btn:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(0,0,0,.08));
}

.page-legal .p-legal__btn--ghost {
    background: transparent;
    color: var(--color-text, #111827);
    border: 1px solid var(--color-border, #e5e7eb);
}

.page-legal .p-legal__grid {
    display: block;
    padding: 1.5rem 0 2.5rem;
}

.page-legal .p-legal__grid-inner {
    width: min(var(--legal-max), calc(100% - 2 * var(--container-padding, 1.5rem)));
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.page-legal .p-legal__card {
    display: block;
    padding: 1.25rem;
    background: var(--color-bg, #ffffff);
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-lg, 16px);
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(0,0,0,.08));
}

.page-legal .p-legal__card-title {
    margin: 0 0 0.5rem;
    font-size: 1.125rem;
    line-height: 1.25;
}

.page-legal .p-legal__card-link {
    color: var(--color-text, #111827);
    text-decoration: none;
}

.page-legal .p-legal__card-link:hover {
    text-decoration: underline;
}

.page-legal .p-legal__card-excerpt {
    margin: 0 0 1rem;
    color: var(--color-text-muted, #6b7280);
}

.page-legal .p-legal__card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.page-legal .p-legal__empty {
    padding: 1.25rem;
    border: 1px dashed var(--color-border, #e5e7eb);
    border-radius: var(--radius-lg, 16px);
    background: var(--color-bg, #ffffff);
}

.page-legal .p-legal__empty h2 {
    margin: 0 0 0.5rem;
    font-size: 1.125rem;
}

.page-legal .p-legal__content {
    display: block;
    padding: 1.5rem 0 3rem;
}

.page-legal .p-legal__content-inner {
    width: min(var(--legal-max), calc(100% - 2 * var(--container-padding, 1.5rem)));
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

.page-legal .p-legal__article {
    display: block;
    padding: 1.25rem;
    background: var(--color-bg, #ffffff);
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-lg, 16px);
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(0,0,0,.08));
}

.page-legal .p-legal__richtext :where(h2) {
    margin: 1.25rem 0 0.75rem;
    font-size: 1.25rem;
}

.page-legal .p-legal__richtext :where(h3) {
    margin: 1rem 0 0.5rem;
    font-size: 1.125rem;
}

.page-legal .p-legal__richtext :where(p) {
    margin: 0.75rem 0;
    line-height: 1.65;
    color: var(--color-text, #111827);
}

.page-legal .p-legal__richtext :where(ul, ol) {
    margin: 0.75rem 0 0.75rem 1.25rem;
}

.page-legal .p-legal__richtext :where(a) {
    color: var(--color-secondary, #e94560);
}

.page-legal .p-legal__aside {
    display: block;
}

.page-legal .p-legal__disclaimer {
    margin-top: 1.5rem;
    padding: 1rem 1.25rem;
    border-radius: var(--radius-md, 8px);
    border: 1px solid var(--color-border, #e5e7eb);
    background: var(--color-bg-alt, #f8f9fa);
}

.page-legal .p-legal__disclaimer h2 {
    margin: 0 0 0.5rem;
    font-size: 1rem;
}

.page-legal .p-legal__disclaimer p {
    margin: 0;
    font-size: 0.875rem;
    color: var(--color-text-muted, #6b7280);
    line-height: 1.6;
}

@media (min-width: 768px) {
    .page-legal .p-legal__grid-inner {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1.25rem;
    }

    .page-legal .p-legal__content-inner {
        grid-template-columns: minmax(0, 1fr) 22rem;
        align-items: start;
    }
}

@media (min-width: 1024px) {
    .page-legal .p-legal__grid-inner {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (prefers-reduced-motion: reduce) {
    .page-legal .p-legal__btn {
        transition: none;
    }

    .page-legal .p-legal__btn:hover {
        transform: none;
    }
}
