/* Tablet und größer */
@media (min-width: 768px) {
    .md\:block {
        display: block;
    }

    .md\:hidden {
        display: none;
    }

    .md\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .md\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .md\:text-5xl {
        font-size: 3rem;
        line-height: 1;
    }

    .impressum-section .grid, .partner-section .grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Desktop */
@media (min-width: 1024px) {
    .lg\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .impressum-section .grid, .partner-section .grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Mobile Anpassungen */
@media (max-width: 768px) {
    .impressum-section {
        padding: 2rem 0;
    }
    
    .impressum-card {
        padding: 2rem;
    }
    
    .impressum-card h2 {
        font-size: 1.25rem;
    }
    
    .impressum-card p {
        font-size: 1rem;
    }

    .grid-cols-3, .md\:grid-cols-3, .lg\:grid-cols-3 {
        grid-template-columns: 1fr !important;
    }

    .info-section {
        padding: 1rem;
        margin: 16px auto;
    }

    .card, .bg-white {
        padding: 1rem;
        margin-bottom: 1rem;
    }
}

/* Kleine Mobile Geräte */
@media (max-width: 640px) {
    main, section, .max-w-7xl, .max-w-6xl, .max-w-3xl, .max-w-2xl, .bg-white, .card, .info-section {
        width: 100%;
        padding-left: 1rem;
        padding-right: 1rem;
        margin-left: 0;
        margin-right: 0;
    }

    body {
        font-size: 16px;
        line-height: 1.5;
        overflow-x: hidden;
    }

    .container {
        width: 100%;
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .grid-cols-1, .grid-cols-2, .grid-cols-3 {
        grid-template-columns: 1fr;
    }

    .text-5xl {
        font-size: 2rem;
    }

    .text-4xl {
        font-size: 1.75rem;
    }

    .text-3xl {
        font-size: 1.5rem;
    }

    .text-2xl {
        font-size: 1.25rem;
    }

    .text-xl {
        font-size: 1.125rem;
    }

    .p-6, .p-8 {
        padding: 1rem;
    }

    .py-12, .py-16, .py-20, .py-24 {
        padding-top: 2rem;
        padding-bottom: 2rem;
    }

    .px-6, .px-8 {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .gap-8, .gap-12 {
        gap: 1rem;
    }

    .space-x-4 > :not([hidden]) ~ :not([hidden]),
    .space-x-8 > :not([hidden]) ~ :not([hidden]) {
        margin-left: 0.5rem;
    }

    .space-y-4 > :not([hidden]) ~ :not([hidden]),
    .space-y-6 > :not([hidden]) ~ :not([hidden]) {
        margin-top: 0.5rem;
    }

    .rounded-2xl, .rounded-xl {
        border-radius: 0.5rem;
    }

    .shadow-lg, .shadow-xl, .shadow-2xl {
        box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    }
} 