/**
 * Legal Pages (Privacy / Terms / Cookies)
 * Keep this file self-contained so legal pages can evolve without touching the main theme too much.
 */

.legal-page .page-hero-content h1 {
    font-family: var(--font-heading);
    letter-spacing: 0.4px;
}

.legal-intro {
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    padding: 26px;
    box-shadow: var(--shadow-sm);
    margin-top: -60px;
    position: relative;
    z-index: 5;
}

@media (max-width: 992px) {
    .legal-intro { margin-top: -40px; }
}

.legal-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 14px;
}

.legal-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: var(--radius-full);
    border: 1px solid rgba(222, 226, 230, 0.9);
    background: linear-gradient(135deg, rgba(255, 107, 53, 0.12), rgba(0, 78, 137, 0.12));
    color: var(--dark);
    font-weight: 700;
    font-size: 0.85rem;
}

.legal-pill i { color: var(--primary); }

.legal-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    color: var(--gray-700);
    font-size: 0.92rem;
}

.legal-meta a { color: var(--secondary); font-weight: 700; }
.legal-meta a:hover { color: var(--primary-dark); }

.legal-layout {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 28px;
    margin-top: 28px;
    align-items: start;
}

@media (max-width: 992px) {
    .legal-layout { grid-template-columns: 1fr; }
}

.legal-toc {
    position: sticky;
    top: 110px;
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    padding: 20px;
    box-shadow: var(--shadow-sm);
}

@media (max-width: 992px) {
    .legal-toc { position: relative; top: 0; }
}

.legal-toc h3 {
    font-size: 1.05rem;
    margin-bottom: 12px;
    color: var(--dark);
}

.legal-toc a {
    display: block;
    padding: 10px 12px;
    border-radius: 12px;
    color: var(--gray-700);
    font-weight: 700;
    font-size: 0.92rem;
}

.legal-toc a:hover {
    background: rgba(255, 107, 53, 0.10);
    color: var(--primary-dark);
}

.legal-content {
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    padding: 34px;
    box-shadow: var(--shadow-sm);
}

@media (max-width: 576px) {
    .legal-content { padding: 24px; }
}

.legal-content section { scroll-margin-top: 120px; }
.legal-content code {
    background: var(--bg-light);
    border: 1px solid var(--gray-200);
    padding: 2px 6px;
    border-radius: 6px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.92em;
}

.legal-content h2 {
    font-size: 1.4rem;
    margin: 28px 0 10px;
    color: var(--dark);
}

.legal-content h2:first-child { margin-top: 0; }

.legal-content h3 {
    font-size: 1.05rem;
    margin: 18px 0 8px;
    color: var(--gray-900);
}

.legal-content p {
    color: var(--gray-700);
    margin: 0 0 14px;
}

.legal-content ul {
    list-style: none;
    padding-left: 0;
    margin: 0 0 14px;
}

.legal-content ul li {
    position: relative;
    padding-left: 26px;
    margin: 10px 0;
    color: var(--gray-700);
}

.legal-content ul li::before {
    content: '';
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--primary);
    position: absolute;
    left: 0;
    top: 8px;
    box-shadow: 0 0 0 4px rgba(255, 107, 53, 0.12);
}

.legal-callout {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 16px 18px;
    border-radius: var(--radius-md);
    border: 1px solid rgba(0, 180, 216, 0.25);
    background: rgba(0, 180, 216, 0.07);
    color: var(--gray-800);
    margin: 16px 0 20px;
}

.legal-callout i {
    color: var(--accent);
    font-size: 1.2rem;
    margin-top: 2px;
}

.legal-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    overflow: hidden;
    border-radius: var(--radius-md);
    border: 1px solid var(--gray-200);
    margin: 14px 0 20px;
}

.legal-table th {
    text-align: left;
    background: var(--bg-light);
    padding: 12px 14px;
    font-size: 0.9rem;
    color: var(--gray-900);
    border-bottom: 1px solid var(--gray-200);
}

.legal-table td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--gray-200);
    color: var(--gray-700);
    font-size: 0.92rem;
    vertical-align: top;
}

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

.legal-footer-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 18px;
}

.legal-muted {
    color: var(--gray-600);
    font-size: 0.9rem;
}
