/* Mobile and Tablet Responsive Design */

/* Prevent horizontal overflow on all devices */
* {
    box-sizing: border-box !important;
}

html, body {
    overflow-x: hidden !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

body {
    position: relative;
}

/* Global container constraints */
section, div, main, article {
    max-width: 100vw !important;
    box-sizing: border-box !important;
}

/* Ensure all iframes and embeds are responsive */
iframe {
    max-width: 100% !important;
    box-sizing: border-box !important;
    width: 100% !important;
    margin: 0 !important;
}

/* Container constraints to prevent overflow */
.container, .hero, .about, .episodes, footer {
    max-width: 100vw;
    overflow-x: hidden;
}

/* Large tablet/small desktop styles */
@media (max-width: 1200px) {
    .episodes-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 25px;
    }
}

/* Tablet styles */
@media (max-width: 1024px) {
    .nav-container {
        padding: 0 30px;
    }
    
    .hero {
        padding: 100px 0 50px;
    }
    
    .about-content {
        gap: 30px;
    }
    
    .footer-content {
        gap: 30px;
    }
}

/* Mobile styles */
@media (max-width: 768px) {
    /* Anti-overflow protection for mobile */
    * {
        max-width: 100vw !important;
    }
    
    /* Navigation */
    nav {
        padding: 15px 20px;
    }
    
    .nav-links {
        display: none;
    }
    
    .mobile-menu-toggle {
        display: block;
    }
    
    /* Hero section */
    .hero {
        padding: 100px 0 50px !important;
        margin: 0 !important;
    }
    
    .hero-content {
        padding: 0 10px !important;
        max-width: 100% !important;
    }
    
    .hero-logo {
        width: 200px;
        max-width: 90vw;
    }
    
    .tagline {
        font-size: 1.3rem;
        padding: 0 10px;
    }
    
    .podcast-subheading {
        font-size: 1.2rem;
        margin-bottom: 25px;
    }
    
    .platform-links {
        flex-direction: column;
        align-items: stretch;
        padding: 0 15px;
    }
    
    /* Main sections */
    .about,
    .episodes {
        padding: 50px 15px;
        margin: 0;
    }
    
    .about-content {
        grid-template-columns: 1fr;
        gap: 30px;
    }
    
    .section-title {
        font-size: 2rem;
        padding: 0 10px;
    }
    
    /* Episodes grid */
    .episodes-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 15px;
        padding: 0 5px;
    }
    
    /* Footer */
    .footer-content {
        grid-template-columns: 1fr;
        gap: 30px;
        padding: 0 15px;
    }
    
    /* Forms and interactive elements */
    .newsletter-form {
        flex-direction: column;
    }
    
    .custom-player {
        flex-direction: column;
        gap: 15px;
        text-align: center;
        margin: 0 10px;
    }
    
    .episode-meta-info {
        flex-direction: column;
        gap: 10px;
    }
    
    .share-buttons {
        flex-wrap: wrap;
        justify-content: center;
        gap: 8px;
    }
    
    /* Page layouts */
    .page-content {
        padding: 100px 15px 50px;
    }
    
    .page-header h1 {
        font-size: 2rem;
    }
    
    .contact-form {
        padding: 20px;
        margin: 0 10px;
    }
    
    /* Ensure all containers respect mobile width */
    .spotify-player-container,
    .episode-card,
    .player-container {
        margin-left: 0;
        margin-right: 0;
        max-width: 100%;
    }
}

/* Small mobile styles */
@media (max-width: 480px) {
    /* Ultra compact layout for small screens */
    body {
        padding: 0;
        margin: 0;
    }
    
    /* Hero adjustments */
    .hero {
        padding: 80px 0 40px !important;
    }
    
    .hero-content {
        padding: 0 5px !important;
        max-width: 100% !important;
    }
    
    .hero-logo {
        width: 150px;
        max-width: 85vw;
    }
    
    .tagline {
        font-size: 1.1rem;
        padding: 0 5px;
    }
    
    .podcast-subheading {
        font-size: 1.1rem;
        margin-bottom: 20px;
    }
    
    .platform-links {
        padding: 0 10px;
    }
    
    /* Content sections */
    .about,
    .episodes {
        padding: 40px 10px;
    }
    
    .section-title {
        font-size: 1.5rem;
        padding: 0 5px;
    }
    
    .about-text h3 {
        font-size: 1.5rem;
    }
    
    /* Episodes grid - single column on very small screens */
    .episodes-grid {
        grid-template-columns: 1fr !important;
        gap: 12px;
        padding: 0;
    }
    
    .episode-card {
        padding: 15px;
        margin: 0 5px;
        max-width: calc(100vw - 10px);
    }
    
    /* Player and interactive elements */
    .spotify-player-container,
    .player-container {
        padding: 12px 3px;
        margin: 0;
        max-width: 100%;
    }
    
    .custom-player {
        padding: 12px;
        margin: 0 5px;
    }
    
    .share-buttons {
        gap: 6px;
        padding: 0 5px;
    }
    
    /* Footer */
    .footer-content {
        text-align: center;
        padding: 0 10px;
    }
    
    .footer-section {
        padding: 0 5px;
    }
    
    .social-links {
        justify-content: center;
        gap: 15px;
    }
    
    /* Forms */
    .contact-form {
        padding: 15px;
        margin: 0 5px;
        max-width: calc(100vw - 10px);
    }
    
    .form-group input,
    .form-group textarea {
        padding: 10px;
        font-size: 16px; /* Prevents zoom on iOS */
    }
    
    /* Newsletter specific - removed conflicting padding */
}

/* Ultra-small screens protection */
@media (max-width: 320px) {
    /* Override grid minmax to prevent overflow */
    .episodes-grid {
        grid-template-columns: 1fr !important;
        gap: 10px;
    }
    
    /* Remove all min-width constraints that could cause overflow */
    .clip-card {
        min-width: unset !important;
        width: 100%;
    }
    
    /* Additional overflow protection */
    * {
        min-width: unset !important;
        max-width: 100vw !important;
    }
    
    /* Ultra-tight spacing for tiny screens */
    .hero {
        padding: 60px 0 30px;
    }
    
    .about,
    .episodes {
        padding: 30px 5px;
    }
    
    .spotify-player-container,
    .episode-card,
    .player-container {
        margin: 0;
        padding: 8px 4px;
        max-width: 100%;
    }
    
    /* Newsletter container - handled in footer.html */
    
    .footer-content {
        padding: 0 5px;
    }
}

/* Landscape mobile orientation */
@media (max-width: 768px) and (orientation: landscape) {
    .hero {
        min-height: 70vh;
        padding: 80px 0 30px;
    }
    
    .hero-logo {
        width: 180px;
        margin-bottom: 20px;
    }
    
    .tagline {
        font-size: 1.2rem;
        margin-bottom: 25px;
    }
    
    .player-container {
        padding: 20px;
        margin-bottom: 25px;
    }
}

/* Print styles */
@media print {
    .loader,
    nav,
    .mobile-menu-toggle,
    .platform-links,
    .clips,
    footer {
        display: none !important;
    }
    
    body {
        background: white !important;
        color: black !important;
    }
    
    .hero {
        min-height: auto;
        padding: 20px;
        background: white !important;
    }
    
    .about,
    .episodes {
        padding: 20px;
        background: white !important;
    }
    
    .section-title,
    .tagline span,
    .episode-title {
        color: #E91E63 !important;
    }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    :root {
        --black: #000000;
        --white: #FFFFFF;
        --gray: #808080;
    }
    
    .episode-card,
    .player-container,
    .contact-form {
        border-width: 2px;
    }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    
    .loader {
        animation: none;
    }
    
    .bubble1,
    .bubble2 {
        animation: none;
    }
    
    .hero-logo,
    .tagline,
    .player-container,
    .platform-links {
        animation: none;
    }
}

/* Focus indicators for accessibility */
@media (prefers-reduced-motion: no-preference) {
    .nav-links a:focus,
    .platform-btn:focus,
    .play-button:focus,
    .episode-card:focus,
    .social-link:focus,
    .newsletter-form button:focus,
    .submit-btn:focus,
    .share-btn:focus {
        outline: 2px solid var(--yellow);
        outline-offset: 2px;
    }
    
    .newsletter-form input:focus,
    .form-group input:focus,
    .form-group textarea:focus {
        outline: 2px solid var(--yellow);
        outline-offset: 1px;
    }
}