/* ============================================================
   legal.css — Strony Regulamin i Polityka Prywatności
   AdresDoNajmu.pl
   ============================================================ */

/* ====================================================
   1. HERO
   ==================================================== */
.legal-hero {
    background: var(--gradient-primary);
    color: var(--color-on-primary);
    padding: var(--space-12) 0 var(--space-16);
}

.legal-breadcrumb {
    margin-bottom: var(--space-6);
    font-size: var(--text-sm);
}

.legal-breadcrumb ol {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    list-style: none;
    margin: 0;
    padding: 0;
    color: rgba(255, 255, 255, 0.75);
}

.legal-breadcrumb li + li::before {
    content: "›";
    margin-right: var(--space-2);
    color: rgba(255, 255, 255, 0.5);
}

.legal-breadcrumb a {
    color: rgba(255, 255, 255, 0.85);
    text-decoration: none;
    transition: color 0.2s;
}

.legal-breadcrumb a:hover {
    color: #fff;
    text-decoration: underline;
}

.legal-breadcrumb [aria-current="page"] {
    color: #fff;
    font-weight: var(--font-weight-medium);
}

.legal-hero-title {
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    font-weight: var(--font-weight-extrabold);
    line-height: 1.15;
    margin: 0 0 var(--space-4);
    color: #fff;
}

.legal-hero-desc {
    max-width: 780px;
    font-size: var(--text-lg);
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.85);
    margin: 0 0 var(--space-6);
}

.legal-hero-meta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-sm);
    color: rgba(255, 255, 255, 0.85);
}

.legal-hero-meta .material-symbols-outlined {
    font-size: 1rem;
}

/* ====================================================
   2. LAYOUT: content + sticky TOC
   ==================================================== */
.legal-body {
    padding: var(--space-12) 0 var(--space-16);
    background: var(--color-surface-base);
}

.legal-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: var(--space-10);
    align-items: start;
}

@media (max-width: 1024px) {
    .legal-layout {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }
}

/* TOC */
.legal-toc {
    position: sticky;
    top: calc(var(--space-6) + 80px);
    background: var(--color-surface-lowest);
    border: 1px solid var(--color-outline-var);
    border-radius: 12px;
    padding: var(--space-5);
    max-height: calc(100vh - 120px);
    overflow-y: auto;
}

@media (max-width: 1024px) {
    .legal-toc {
        position: static;
        max-height: none;
    }
}

.legal-toc-title {
    font-size: var(--text-sm);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-on-surface-var);
    margin: 0 0 var(--space-3);
}

.legal-toc-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.legal-toc-list a {
    display: block;
    padding: var(--space-2) var(--space-3);
    border-radius: 8px;
    color: var(--color-on-surface-var);
    text-decoration: none;
    font-size: var(--text-sm);
    line-height: 1.4;
    transition: background 0.15s, color 0.15s;
}

.legal-toc-list a:hover {
    background: var(--color-primary-fixed);
    color: var(--color-primary);
}

.legal-toc-list a .num {
    display: inline-block;
    min-width: 28px;
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary);
}

/* ====================================================
   3. CONTENT
   ==================================================== */
.legal-content {
    background: var(--color-surface-lowest);
    border: 1px solid var(--color-outline-var);
    border-radius: 16px;
    padding: clamp(var(--space-6), 4vw, var(--space-10));
    color: var(--color-on-surface);
    line-height: 1.7;
    font-size: var(--text-base);
}

.legal-intro {
    font-size: var(--text-lg);
    color: var(--color-on-surface-var);
    padding-bottom: var(--space-6);
    margin-bottom: var(--space-8);
    border-bottom: 1px solid var(--color-outline-var);
}

.legal-section {
    margin-bottom: var(--space-10);
    scroll-margin-top: 100px;
}

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

.legal-section h2 {
    font-size: var(--text-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
    margin: 0 0 var(--space-5);
    display: flex;
    align-items: baseline;
    gap: var(--space-3);
}

.legal-section h2 .num {
    font-size: var(--text-xl);
    color: var(--color-primary-light);
    font-weight: var(--font-weight-extrabold);
    min-width: 3.2ch;
}

.legal-section h3 {
    font-size: var(--text-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-on-surface);
    margin: var(--space-6) 0 var(--space-3);
}

.legal-section p {
    margin: 0 0 var(--space-4);
    color: var(--color-on-surface);
}

.legal-section ol,
.legal-section ul {
    margin: 0 0 var(--space-4) var(--space-5);
    padding-left: var(--space-5);
    color: var(--color-on-surface);
}

.legal-section ol {
    list-style: decimal outside;
}

.legal-section ul {
    list-style: disc outside;
}

.legal-section ol ol {
    list-style: lower-alpha outside;
}

.legal-section ol ol ol {
    list-style: lower-roman outside;
}

.legal-section ol li,
.legal-section ul li {
    margin-bottom: var(--space-2);
    padding-left: var(--space-2);
}

.legal-section ol ol,
.legal-section ul ul,
.legal-section ol ul,
.legal-section ul ol {
    margin-top: var(--space-2);
    margin-bottom: var(--space-2);
}

.legal-section strong {
    color: var(--color-primary-dark);
    font-weight: var(--font-weight-semibold);
}

.legal-section a {
    color: var(--color-primary);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
}

.legal-section a:hover {
    color: var(--color-primary-light);
}

/* Highlight callout (for key §8 wyłączenie, itd.) */
.legal-callout {
    background: var(--color-primary-fixed);
    border-radius: 8px;
    padding: var(--space-4) var(--space-5);
    margin: var(--space-5) 0;
}

.legal-callout p {
    margin: 0;
    color: var(--color-primary-dark);
    font-weight: var(--font-weight-medium);
}

/* Contact block */
.legal-contact-box {
    background: var(--color-surface-low);
    border: 1px solid var(--color-outline-var);
    border-radius: 10px;
    padding: var(--space-5);
    margin: var(--space-5) 0;
    font-size: var(--text-sm);
    line-height: 1.6;
}

.legal-contact-box dl {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: var(--space-2) var(--space-4);
    margin: 0;
}

@media (max-width: 520px) {
    .legal-contact-box dl {
        grid-template-columns: 1fr;
        gap: var(--space-1);
    }
    .legal-contact-box dt { margin-top: var(--space-2); }
}

.legal-contact-box dt {
    font-weight: var(--font-weight-semibold);
    color: var(--color-on-surface-var);
}

.legal-contact-box dd {
    margin: 0;
    color: var(--color-on-surface);
}

/* Attachment / formularz */
.legal-attachment {
    background: var(--color-surface-low);
    border: 1px dashed var(--color-outline);
    border-radius: 12px;
    padding: var(--space-6);
    margin-top: var(--space-10);
}

.legal-attachment h2 {
    margin-top: 0;
}

.legal-attachment .legal-attachment-title {
    font-size: var(--text-lg);
    gap: var(--space-2);
}

.legal-attachment .legal-attachment-title .num {
    font-size: var(--text-base);
}

.legal-attachment pre {
    background: var(--color-surface-lowest);
    border: 1px solid var(--color-outline-var);
    border-radius: 8px;
    padding: var(--space-4);
    font-family: 'Courier New', Courier, monospace;
    font-size: var(--text-sm);
    line-height: 1.6;
    color: var(--color-on-surface);
    white-space: pre-wrap;
    word-break: break-word;
    overflow-x: auto;
}

/* Footer note */
.legal-footer-note {
    margin-top: var(--space-10);
    padding-top: var(--space-6);
    border-top: 1px solid var(--color-outline-var);
    font-size: var(--text-sm);
    color: var(--color-on-surface-var);
}