/*
   Jesto Legal Pages – Clean & Simple
   Single-column, professional, aligned with the site design system.
*/

:root {
    --legal-primary: #0030DB;
    --legal-text: #1D1D1F;
    --legal-muted: #6E6E73;
    --legal-bg: #FFFFFF;
    --legal-bg-soft: #F8FAFF;
    --legal-border: #E5E9F2;
}

/* ===== Hero ===== */
.legal-hero {
    padding: 80px 0 56px;
    text-align: center;
    background: var(--legal-bg);
    border-bottom: 1px solid var(--legal-border);
}

.legal-hero-inner {
    max-width: 820px;
    margin: 0 auto;
    padding: 0 24px;
}

.legal-eyebrow {
    display: inline-block;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--legal-primary);
    margin-bottom: 16px;
}

.legal-hero h1 {
    font-size: 48px !important;
    font-weight: 700;
    line-height: 1.15;
    color: var(--legal-text);
    margin: 0 0 16px;
    letter-spacing: -0.02em;
}

.legal-hero p {
    font-size: 18px;
    color: var(--legal-muted);
    line-height: 1.6;
    margin: 0 0 24px;
}

.legal-updated {
    font-size: 14px;
    color: var(--legal-muted);
    font-weight: 500;
}

.legal-updated::before {
    content: "Last updated: ";
    color: var(--legal-text);
    font-weight: 600;
}

/* ===== Body ===== */
.legal-main {
    padding: 64px 0 100px;
    background: var(--legal-bg);
}

.legal-content {
    max-width: 760px;
    margin: 0 auto;
    padding: 0 24px;
    font-size: 16px;
    line-height: 1.75;
    color: var(--legal-text);
}

.legal-lead {
    font-size: 17px;
    line-height: 1.7;
    color: var(--legal-muted);
    margin: 0 0 40px;
}

.legal-content section + section {
    margin-top: 36px;
}

.legal-content h2 {
    font-size: 22px !important;
    font-weight: 700;
    color: var(--legal-text);
    margin: 0 0 16px;
    line-height: 1.35;
    letter-spacing: -0.01em;
}

.legal-content p {
    margin: 0 0 16px;
}

.legal-content p:last-child {
    margin-bottom: 0;
}

.legal-content ul {
    margin: 0 0 20px;
    padding-left: 22px;
    list-style: disc;
}

.legal-content li {
    margin-bottom: 8px;
}

.legal-content li::marker {
    color: var(--legal-primary);
}

.legal-content strong {
    color: var(--legal-text);
    font-weight: 600;
}

.legal-content a {
    color: var(--legal-primary);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    transition: text-decoration-thickness 0.15s ease;
}

.legal-content a:hover {
    text-decoration-thickness: 2px;
}

/* ===== Sub-processors table ===== */
.legal-table-wrapper {
    overflow-x: auto;
    margin: 16px 0 24px;
    border: 1px solid var(--legal-border);
    border-radius: 10px;
}

.legal-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}

.legal-table th {
    text-align: left;
    background: var(--legal-bg-soft);
    padding: 12px 16px;
    font-weight: 600;
    color: var(--legal-text);
    border-bottom: 1px solid var(--legal-border);
    white-space: nowrap;
}

.legal-table td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--legal-border);
    color: var(--legal-text);
}

.legal-table tr:last-child td {
    border-bottom: none;
}

/* ===== Contact box ===== */
.legal-contact-box {
    margin-top: 56px;
    padding: 32px;
    background: var(--legal-bg-soft);
    border: 1px solid var(--legal-border);
    border-radius: 14px;
    text-align: center;
}

.legal-contact-box h3 {
    font-size: 18px !important;
    font-weight: 700;
    color: var(--legal-text);
    margin: 0 0 8px;
}

.legal-contact-box p {
    margin: 0;
    color: var(--legal-muted);
    font-size: 15px;
}

.legal-contact-box a {
    color: var(--legal-primary);
    font-weight: 600;
    text-decoration: none;
}

.legal-contact-box a:hover {
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* ===== Responsive ===== */
@media (max-width: 768px) {
    .legal-hero {
        padding: 56px 0 40px;
    }

    .legal-hero h1 {
        font-size: 32px !important;
    }

    .legal-hero p {
        font-size: 16px;
    }

    .legal-main {
        padding: 40px 0 72px;
    }

    .legal-content {
        font-size: 15px;
    }

    .legal-content h2 {
        font-size: 19px !important;
    }

    .legal-content section + section {
        margin-top: 28px;
    }

    .legal-lead {
        font-size: 15px;
        margin-bottom: 32px;
    }

    .legal-contact-box {
        padding: 24px;
        margin-top: 40px;
    }
}

@media (max-width: 480px) {
    .legal-hero h1 {
        font-size: 28px !important;
    }
}
