/* ========================================
   RESPONSIVE DESIGN
   Consolidated Media Queries
   ======================================== */

/* ========================================
   TABLET & MOBILE (768px and below)
   ======================================== */

@media (max-width: 768px) {
    /* Base */
    :root {
        --section-padding: var(--section-padding-mobile);
    }

    .container {
        padding: 0 var(--space-sm);
    }

    /* Typography */
    .hero-title {
        font-size: var(--text-4xl);
    }

    .hero-description {
        font-size: var(--text-lg);
    }

    .heading-1 {
        font-size: var(--text-4xl);
        word-wrap: break-word;
    }

    .heading-2 {
        font-size: var(--text-3xl);
        word-wrap: break-word;
        flex-wrap: wrap;
    }

    .heading-3 {
        font-size: var(--text-2xl);
        word-wrap: break-word;
    }

    /* Navigation */
    .navbar {
        position: fixed;
        left: 0;
        right: 0;
    }

    .nav-links {
        display: flex;
        position: fixed;
        top: 80px;
        left: 0;
        width: 100vw;
        max-width: 100vw;
        height: calc(100vh - 80px);
        background: white;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        z-index: var(--z-fixed);
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
        transform: translateX(100%);
        transition: transform 0.3s ease;
        visibility: hidden;
    }

    .nav-links.active {
        transform: translateX(0);
        visibility: visible;
    }

    .nav-links li {
        margin: var(--space-md) 0;
    }

    .nav-links a {
        color: var(--text-black) !important;
        font-size: var(--text-xl);
    }

    .mobile-menu-toggle {
        display: flex;
    }

    /* Layout */
    .grid--2,
    .grid--3,
    .grid--4 {
        grid-template-columns: 1fr;
    }

    .section {
        padding: var(--space-md) 0;
    }

    .section-grid {
        grid-template-columns: 1fr;
        gap: var(--space-xl);
        min-height: auto;
    }

    .content-block {
        padding: var(--space-lg);
        text-align: center;
    }

    .media-block {
        order: -1;
    }

    .media-block img {
        width: 100%;
        height: auto;
    }

    .section-full-bleed .content-block {
        padding: var(--space-xl);
        text-align: center;
    }

    .section-full-bleed .media-block img {
        height: 300px;
    }

    /* Forms */
    .contact-form {
        padding: var(--space-xl);
    }

    .form-container {
        margin-bottom: var(--space-2xl);
    }

    .contact-info-grid {
        grid-template-columns: 1fr;
    }

    .form-input,
    .form-textarea {
        font-size: 16px; /* Prevents iOS zoom on focus */
    }

    .btn {
        min-height: 44px; /* Touch-friendly size */
    }

    /* Footer */
    .footer-columns {
        flex-direction: column;
        gap: var(--space-md);
    }

    .footer-column {
        flex: 1 1 auto;
        max-width: 100%;
    }

    .footer-column:last-child {
        margin-left: 0;
        text-align: left;
    }

    .footer-top {
        padding: var(--space-md) 0;
    }

    /* Testimonials */
    .testimonial-carousel {
        padding: 0 var(--space-xl);
    }

    .testimonial-card {
        padding: var(--space-2xl) var(--space-lg);
    }

    .testimonial-quote {
        font-size: 80px;
    }

    .testimonial-text {
        font-size: var(--text-base);
    }

    .testimonial-btn {
        width: 40px;
        height: 40px;
        font-size: 24px;
    }

    /* Footer */
    .footer {
        padding-top: 0px;
    }

    /* Portfolio */
    .portfolio-hero {
        height: 60vh;
        min-height: 400px;
        margin-top: 80px;
    }

    .portfolio-grid--two-col,
    .portfolio-grid--three-col {
        grid-template-columns: 1fr;
    }

    .portfolio-image--tall {
        aspect-ratio: 4 / 5;
    }

    .portfolio-comment h3 {
        font-size: var(--text-3xl);
    }

    .portfolio-testimonial {
        padding: var(--space-2xl) var(--space-lg);
    }

    /* Quiz */
    .quiz-container {
        margin: 0 auto;
        border-radius: 0;
        min-height: 100vh;
    }

    .content-below {
        padding: var(--space-xl) var(--space-lg) var(--space-2xl);
    }

    .quiz-step:not(.quiz-step-with-image) {
        padding: var(--space-xl) var(--space-lg);
    }

    .question-title {
        font-size: var(--text-4xl);
        line-height: 1.1;
        margin-bottom: var(--space-lg);
    }

    .question {
        font-size: var(--text-2xl);
        margin-bottom: var(--space-xl);
    }

    .button-group {
        gap: var(--space-xs);
    }

    .option-btn {
        padding: var(--space-sm) var(--space-lg);
    }

    .choices {
        grid-template-columns: 1fr;
        gap: var(--space-sm);
        margin-bottom: var(--space-lg);
    }

    .choice img {
        height: 160px;
    }

    .choice-label {
        padding: var(--space-sm);
    }

    .email-step {
        padding: var(--space-xl) var(--space-lg) var(--space-2xl);
    }

    .input-group input {
        padding: var(--space-sm) var(--space-md);
    }

    .submit-btn {
        padding: var(--space-sm);
    }

    .thank-you {
        padding: var(--space-3xl) var(--space-lg);
    }

    .thank-you h2 {
        font-size: var(--text-3xl);
    }

    /* Venue Guides */
    .venue-hero h1 {
        font-size: 2.5rem;
    }

    .guide-comparison {
        grid-template-columns: 1fr;
    }

    .guide-card--featured::before {
        font-size: 10px;
        padding: 6px 40px;
    }

    /* Cookie Consent */
    .cookie-consent-container {
        flex-direction: column;
        gap: 1rem;
    }

    .cookie-consent-actions {
        width: 100%;
    }

    .cookie-consent-btn {
        flex: 1;
        min-width: 0;
    }

    .cookie-consent-modal-content {
        max-height: 100vh;
        border-radius: 0;
        height: 100%;
    }

    .cookie-consent-modal-footer {
        flex-direction: column;
    }

    .cookie-consent-modal-footer .cookie-consent-btn {
        width: 100%;
    }
}

/* ========================================
   MOBILE ONLY (480px and below)
   ======================================== */

@media (max-width: 480px) {
    /* Base */
    .hero-title {
        font-size: var(--text-3xl);
    }

    .hero-content {
        padding: var(--space-sm);
    }

    /* .card {
        padding: var(--space-lg);
    } */

    /* Forms */
    .contact-form {
        padding: var(--space-lg);
    }

    .btn--large {
        width: 100%;
        padding: var(--space-md) var(--space-lg);
        min-height: 48px;
    }

    /* Testimonials */
    .testimonial-carousel {
        padding: 0 var(--space-md);
    }

    .testimonial-card {
        padding: var(--space-xl) var(--space-md);
    }

    .testimonial-controls {
        flex-direction: column;
        gap: var(--space-md);
    }

    .testimonial-btn--prev,
    .testimonial-btn--next {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
    }

    .testimonial-btn--prev {
        left: 0;
    }

    .testimonial-btn--next {
        right: 0;
    }

    /* Portfolio */
    .portfolio-hero {
        height: 50vh;
        min-height: 350px;
    }

    .portfolio-testimonial {
        padding: var(--space-xl) var(--space-md);
    }

    /* Cookie Consent */
    .cookie-consent-banner {
        padding: 1rem;
    }

    .cookie-consent-title {
        font-size: 1.125rem;
    }

    .cookie-consent-text {
        font-size: 0.813rem;
    }

    .cookie-consent-actions {
        flex-direction: column;
    }

    .cookie-consent-btn {
        width: 100%;
    }
}

@media (min-width: 480px) {
    .footer-column-title {
        height: 48px;
    }

    .grid--2 {
        margin-top: var(--space-3xl); gap: var(--space-xl);
    }

    .guide-comparison {
        margin-top: var(--space-3xl);
    }
    
}