/* ==========================================================================
   asagiri MIST THEATER — Responsive Styles
   ========================================================================== */

/* ── Tablet (768px – 1023px) ────────────────────────────────────────────── */
@media screen and (max-width: 1023px) {
    :root {
        --text-7xl: 3.5rem;
        --text-6xl: 3rem;
        --text-5xl: 2.5rem;
        --text-4xl: 2rem;
    }

    .footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-8);
    }

    .footer-access {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    .performances-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .about-grid,
    .access-grid,
    .contact-grid {
        grid-template-columns: 1fr;
        gap: var(--space-10);
    }

    .features-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .schedule-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .seating-info-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* ── Mobile (< 768px) ──────────────────────────────────────────────────── */
@media screen and (max-width: 767px) {
    :root {
        --text-7xl: 2.5rem;
        --text-6xl: 2.25rem;
        --text-5xl: 2rem;
        --text-4xl: 1.75rem;
        --text-3xl: 1.5rem;
    }

    /* Layout */
    .container {
        padding-left: var(--space-4);
        padding-right: var(--space-4);
    }

    .section {
        padding: var(--space-16) 0;
    }

    .section--compact {
        padding: var(--space-10) 0;
    }

    /* Header */
    .main-nav {
        display: none;
    }

    .mobile-nav__item-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .mobile-nav__toggle-btn {
        background: none;
        border: none;
        color: var(--color-white);
        font-size: 1.5rem;
        cursor: pointer;
        padding: 0 var(--space-4);
    }

    .mobile-nav__dropdown {
        display: none;
        flex-direction: column;
        background: rgba(0, 0, 0, 0.2);
        padding: var(--space-2) 0;
    }

    .mobile-nav__dropdown.is-open {
        display: flex;
    }

    .mobile-nav__dropdown-link {
        color: var(--color-white);
        text-decoration: none;
        padding: var(--space-2) var(--space-6);
        font-size: var(--text-base);
        opacity: 0.8;
    }

    .mobile-nav__dropdown-link:hover {
        opacity: 1;
        color: var(--color-accent);
    }

    .menu-toggle {
        display: flex;
    }

    .site-header {
        padding: var(--space-4) 0;
    }

    .site-header.is-scrolled {
        padding: var(--space-3) 0;
    }

    /* Hero */
    .hero {
        min-height: 500px;
    }

    .hero--compact {
        min-height: 320px;
    }

    .hero__title {
        font-size: var(--text-5xl);
        letter-spacing: var(--tracking-normal);
    }

    .hero__description {
        font-size: var(--text-base);
    }

    .hero__scroll {
        display: none;
    }

    /* Cards */
    .card__body {
        padding: var(--space-4);
    }

    .card__title {
        font-size: var(--text-lg);
    }

    /* Section Titles */
    .section-title {
        font-size: var(--text-3xl);
    }

    /* Footer */
    .footer-grid {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    .footer-access {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    .footer-bottom {
        flex-direction: column;
        gap: var(--space-4);
        text-align: center;
    }

    /* Buttons */
    .btn {
        padding: var(--space-3) var(--space-6);
        font-size: var(--text-xs);
    }

    /* Sub-pages */
    .features-grid,
    .gallery-grid {
        grid-template-columns: 1fr;
    }

    .performances-grid,
    .schedule-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-4);
    }

    .seating-info-grid {
        grid-template-columns: 1fr;
        gap: var(--space-4);
    }

    .news-item {
        grid-template-columns: 1fr;
        gap: var(--space-2);
    }

    .page-header {
        padding: var(--space-24) 0 var(--space-5);
    }

    .access-route {
        flex-direction: column;
        gap: var(--space-1);
    }

    .access-route__station {
        min-width: auto;
    }
}

/* ── Small Mobile (< 480px) ─────────────────────────────────────────────── */
@media screen and (max-width: 479px) {
    :root {
        --text-7xl: 2rem;
        --text-6xl: 1.875rem;
        --text-5xl: 1.75rem;
    }

    .hero__subtitle {
        font-size: var(--text-xs);
    }

    .site-logo__text {
        font-size: var(--text-base);
    }

    .site-logo__sub {
        font-size: 10px;
    }
}

/* ── Wide Desktop (≥ 1400px) ────────────────────────────────────────────── */
@media screen and (min-width: 1400px) {
    .container {
        padding-left: var(--space-8);
        padding-right: var(--space-8);
    }
}

/* ── Print ──────────────────────────────────────────────────────────────── */
@media print {

    .site-header,
    .menu-toggle,
    .mobile-nav,
    .hero__particles,
    .hero__scroll,
    .footer-social {
        display: none !important;
    }

    body {
        background: #ffffff;
        color: #333333;
    }

    a {
        color: #333333;
        text-decoration: underline;
    }
}