/* ========================================
   Mobile Responsive Styles
   ======================================== */

@media (max-width: 1024px) {
    :root {
        --section-padding: 80px 0;
    }
    
    .programs-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    :root {
        --section-padding: 60px 0;
    }
    
    .hero {
        padding: 100px 15px 40px;
    }
    
    .hero-content {
        gap: 40px;
    }
    
    .image-container {
        width: 250px;
        height: 250px;
    }
    
    .programs-grid {
        grid-template-columns: 1fr;
    }
    
    .reviews-slider {
        grid-template-columns: 1fr;
    }
    
    .stats {
        gap: 20px;
    }
    
    .stat-number {
        font-size: 2.2rem;
    }
    
    .contact-form {
        padding: 30px 20px;
    }
}

@media (max-width: 480px) {
    .hero-cta {
        flex-direction: column;
        width: 100%;
    }
    
    .btn {
        width: 100%;
        text-align: center;
    }
    
    .image-container {
        width: 200px;
        height: 200px;
    }
    
    .section-title {
        font-size: 2rem;
    }
    
    .about-text h3 {
        font-size: 1.5rem;
    }
    
    .stats {
        grid-template-columns: 1fr;
        gap: 30px;
    }
    
    .review-card {
        padding: 30px 20px;
    }
}

/* Tablet Landscape */
@media (min-width: 769px) and (max-width: 1024px) {
    .hero-content {
        gap: 40px;
    }
    
    .about-content {
        gap: 50px;
    }
    
    .schedule-list li {
        flex-direction: column;
        gap: 5px;
    }
}

/* Large Desktop */
@media (min-width: 1400px) {
    .container {
        max-width: 1320px;
    }
}
