/* ===================================
   Legal Pages CSS (Impressum & Datenschutz)
   =================================== */

/* === Legal Hero === */
.legal-hero {
    background: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-bg-light) 100%);
    padding: var(--spacing-lg) 0;
    text-align: center;
}

/* === Legal Content === */
.legal-content {
    padding: var(--spacing-xl) 0;
    background: var(--color-bg);
}

.legal-box {
    max-width: 900px;
    margin: 0 auto;
    background: var(--color-bg-light);
    padding: var(--spacing-lg);
    border-radius: 15px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.08);
}

.legal-box h2 {
    color: var(--color-primary);
    font-size: 1.875rem;
    margin-top: var(--spacing-lg);
    margin-bottom: var(--spacing-sm);
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--color-secondary);
}

.legal-box h2:first-of-type {
    margin-top: 0;
}

.legal-box h3 {
    color: var(--color-dark);
    font-size: 1.375rem;
    margin-top: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.info-block {
    background: var(--color-bg);
    padding: var(--spacing-md);
    border-radius: 10px;
    margin-bottom: var(--spacing-md);
    line-height: 1.8;
}

.info-block:last-child {
    margin-bottom: 0;
}

.info-block p {
    color: var(--color-text);
    margin-bottom: var(--spacing-sm);
}

.info-block p:last-child {
    margin-bottom: 0;
}

.info-block ul {
    margin: var(--spacing-sm) 0;
    padding-left: var(--spacing-md);
}

.info-block li {
    color: var(--color-text);
    margin-bottom: 0.5rem;
    line-height: 1.7;
}

.info-block a {
    color: var(--color-primary);
    text-decoration: underline;
    transition: var(--transition);
}

.info-block a:hover {
    color: var(--color-accent);
}

/* === Notice Boxes === */
.notice-box {
    padding: var(--spacing-md);
    border-radius: 10px;
    margin-bottom: var(--spacing-lg);
    display: flex;
    gap: var(--spacing-sm);
    align-items: start;
    border-left: 4px solid;
}

.notice-box i {
    font-size: 1.5rem;
    flex-shrink: 0;
    margin-top: 0.25rem;
}

.notice-box p {
    flex: 1;
    margin: 0;
    line-height: 1.7;
}

.notice-box.warning {
    background: #FFF9E6;
    border-color: #F39C12;
}

.notice-box.warning i {
    color: #F39C12;
}

.notice-box.info {
    background: #E8F4F8;
    border-color: #3498DB;
}

.notice-box.info i {
    color: #3498DB;
}

.notice-box.contact {
    background: linear-gradient(135deg, var(--color-secondary), var(--color-bg));
    border-color: var(--color-primary);
    flex-direction: column;
    text-align: center;
    align-items: center;
}

.notice-box.contact i {
    font-size: 2.5rem;
    color: var(--color-accent);
    margin-bottom: var(--spacing-sm);
}

.notice-box.contact h3 {
    color: var(--color-primary);
    margin: var(--spacing-sm) 0;
}

.notice-box.contact p {
    margin-bottom: var(--spacing-md);
}

.notice-box a {
    color: var(--color-primary);
    font-weight: 600;
}

.notice-box a:hover {
    color: var(--color-accent);
}

/* === Responsive === */
@media (max-width: 768px) {
    .legal-box {
        padding: var(--spacing-md);
    }
    
    .legal-box h2 {
        font-size: 1.5rem;
    }
    
    .legal-box h3 {
        font-size: 1.25rem;
    }
    
    .info-block {
        padding: var(--spacing-sm);
    }
    
    .notice-box {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }
}

@media (max-width: 480px) {
    .legal-content {
        padding: var(--spacing-md) 0;
    }
    
    .notice-box i {
        font-size: 1.25rem;
    }
}