/* ==================== */
/* COMPLEMENT PARTNERS - Responsive Stylesheet */
/* ==================== */

/* ==================== */
/* TABLET (max 1024px) */
/* ==================== */

@media (max-width: 1024px) {
    nav {
        padding: 15px 30px;
    }
    
    nav.scrolled {
        padding: 10px 30px;
    }
    
    .hero {
        padding: 120px 30px 80px;
    }
    
    section {
        padding: 80px 30px;
    }
    
    .unterschied-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .service-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* ==================== */
/* SMALL TABLET (max 900px) */
/* ==================== */

@media (max-width: 900px) {
    .nav-links {
        display: none;
        position: fixed;
        top: 70px;
        left: 0;
        right: 0;
        background: var(--weiss);
        flex-direction: column;
        padding: 30px;
        gap: 20px;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    }
    
    .nav-links.active {
        display: flex;
    }
    
    .mobile-menu-btn {
        display: block;
    }
    
    .team-grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }
    
    .solutions-grid {
        grid-template-columns: 1fr;
    }
}

/* ==================== */
/* MOBILE (max 768px) */
/* ==================== */

@media (max-width: 768px) {
    nav {
        padding: 15px 20px;
    }
    
    nav.scrolled {
        padding: 10px 20px;
    }
    
    .logo img {
        height: 38px;
    }
    
    .hero {
        padding: 100px 20px 60px;
        min-height: auto;
    }
    
    .hero h1 {
        font-size: 2rem;
    }
    
    .hero-text {
        font-size: 1.1rem;
    }
    
    .hero-cta {
        flex-direction: column;
    }
    
    .hero-cta .btn-primary,
    .hero-cta .btn-secondary {
        width: 100%;
        justify-content: center;
    }
    
    section {
        padding: 60px 20px;
    }
    
    .section-header {
        margin-bottom: 40px;
    }
    
    .section-title {
        font-size: 1.8rem;
    }
    
    .unterschied-grid {
        grid-template-columns: 1fr;
    }
    
    .unterschied-card {
        padding: 25px;
    }
    
    .service-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
    }
    
    .service-card {
        padding: 20px 15px;
    }
    
    .service-card h4 {
        font-size: 0.9rem;
    }
    
    .quote-box {
        padding: 30px 20px;
    }
    
    .quote-box p {
        font-size: 1.2rem;
    }
    
    .zielgruppe-tags {
        flex-direction: column;
        align-items: center;
    }
    
    .zielgruppe-tag {
        width: 100%;
        max-width: 280px;
        text-align: center;
    }
    
    .team-card-header {
        padding: 25px;
    }
    
    .team-card-header h3 {
        font-size: 1.5rem;
    }
    
    .team-card-body {
        padding: 25px;
    }
    
    .kontakt-section {
        padding: 60px 20px;
    }
    
    .kontakt-cta {
        width: 100%;
        justify-content: center;
    }
    
    footer {
        padding: 25px 20px;
        font-size: 0.9rem;
    }
}

/* ==================== */
/* SMALL MOBILE (max 480px) */
/* ==================== */

@media (max-width: 480px) {
    .hero h1 {
        font-size: 1.7rem;
    }
    
    .hero-tagline {
        font-size: 12px;
        padding: 8px 15px;
    }
    
    .service-grid {
        grid-template-columns: 1fr;
    }
    
    .btn-primary,
    .btn-secondary {
        padding: 14px 24px;
        font-size: 15px;
    }
    
    .unterschied-card .icon {
        font-size: 32px;
    }
    
    .section-label {
        font-size: 12px;
    }
}

/* ==================== */
/* HOVER STATES - Touch Devices */
/* ==================== */

@media (hover: none) {
    .unterschied-card:hover,
    .service-card:hover,
    .solution-card:hover,
    .team-card:hover,
    .card:hover {
        transform: none;
    }
    
    .btn-primary:hover,
    .btn-secondary:hover,
    .nav-cta:hover,
    .kontakt-cta:hover {
        transform: none;
    }
}

/* ==================== */
/* PRINT STYLES */
/* ==================== */

@media print {
    nav,
    .mobile-menu-btn,
    footer {
        display: none;
    }
    
    body {
        font-size: 12pt;
    }
    
    .hero {
        min-height: auto;
        padding: 20px 0;
    }
    
    section {
        padding: 30px 0;
        page-break-inside: avoid;
    }
    
    .unterschied-grid,
    .service-grid,
    .solutions-grid,
    .team-grid {
        display: block;
    }
    
    .unterschied-card,
    .service-card,
    .solution-card,
    .team-card {
        margin-bottom: 20px;
        box-shadow: none;
        border: 1px solid #ddd;
    }
}
