/* =========================================================
   Responsive Navigation
   ========================================================= */

@media (max-width: 768px) {

    /* Show hamburger */
    .hamburger {
        display: flex;
        z-index: 1100;
    }

    /* Dropdown */
    .nav-inner {
        position: absolute;
        top: 70%;
        right: 24px;

        background: rgba(20, 20, 20, 0.95);
        padding: 26px 24px;

        border-radius: 18px;
        box-shadow: 0 20px 50px rgba(0,0,0,0.4);

        display: none;
        flex-direction: column;
        align-items: center;
        gap: 18px;

        width: 210px;
        animation: fadeSlide 0.2s ease;
    }

    .nav-inner.open {
        display: flex;
    }

    .nav-inner a {
        color: white !important;
        font-size: 18px;
        font-weight: 500;
    }

    /* Shows page */

    .event-card {
        flex-direction: column;
    }

    .event-image img {
        width: 100%;
    }
}


/* =========================================================
   Home Page — Mobile Hero
   ========================================================= */

@media (max-width: 768px) {

    /* Scale down hero title */
    .hero-title h1 {
        font-size: 36px;
    }

    .hero-title p {
        font-size: 16px;
    }

    .hero-title {
        bottom: 80px;
        right: 5%;
        left: 5%;
        text-align: center;
    }

    .listen-btn {
        font-size: 14px;
        padding: 8px 24px;
    }

    /* Hide floating text on mobile */
    .float-text {
        display: none;
    }

    /* Logo size on mobile */
    .logo img {
        height: 50px;
    }

    /* Header padding */
    #siteHeader {
        padding: 16px 20px;
    }

    #siteHeader.inner {
        padding: 10px 20px;
    }
}


/* =========================================================
   Home Shows Section — Mobile
   ========================================================= */

@media (max-width: 640px) {

    .home-show-row {
        grid-template-columns: 70px 1fr;
        grid-template-rows: auto auto auto;
        gap: 6px 14px;
    }

    .home-show-time {
        grid-column: 2;
        grid-row: 2;
        font-size: 12px;
        opacity: 0.7;
        letter-spacing: 0.5px;
        white-space: nowrap;
    }

    .home-show-actions {
        grid-column: 1 / -1;
        grid-row: 3;
        justify-content: flex-start;
        padding-top: 4px;
        padding-bottom: 6px;
    }

    .home-shows-inner {
        padding: 0 20px;
    }

    .home-shows-section {
        padding: 60px 0 40px;
    }
}


/* =========================================================
   Shows — Mobile
   ========================================================= */

@media (max-width: 768px) {

    .show-detail-container {
        grid-template-columns: 1fr;
        margin: 40px auto;
    }

    .events-grid {
        grid-template-columns: 1fr;
    }

    .event-card {
        grid-template-columns: 90px 1fr;
    }
}


/* =========================================================
   Calendar — Mobile
   ========================================================= */

@media (max-width: 768px) {

    .calendar-grid {
        grid-template-columns: repeat(7, 1fr);
        gap: 3px;
    }

    .calendar-cell {
        min-height: 60px;
        padding: 4px;
    }

    .calendar-day-head {
        font-size: 10px;
        padding: 4px 0;
    }

    .calendar-date {
        font-size: 11px;
    }

    .calendar-event {
        font-size: 9px;
    }

    .calendar-time {
        display: none;
    }
}


/* =========================================================
   Story Box — Mobile
   ========================================================= */

@media (max-width: 768px) {

    .story-box {
        padding: 36px 28px;
        max-width: 100%;
    }

    .story-box h2 {
        font-size: 28px;
    }

    .story-box p {
        font-size: 16px;
    }

    .parallax-content {
        justify-content: center;
        padding: 60px 5%;
    }
}


/* =========================================================
   Fanclub + Contact Box — Mobile
   ========================================================= */

@media (max-width: 768px) {

    .fanclub-box,
    .contact-box {
        width: 90%;
        max-width: 100%;
        margin: 0 auto;
    }

    .contact-section {
        justify-content: center;
        padding-left: 0;
    }
}


/* =========================================================
   Album — Mobile
   ========================================================= */

@media (max-width: 768px) {

    .album-overlay h1 {
        font-size: 36px;
    }

    .stream-links {
        flex-direction: column;
        gap: 16px;
        align-items: center;
    }
}


/* =========================================================
   Book Me — Mobile
   ========================================================= */

@media (max-width: 768px) {

    .booking-card {
        margin: 20px 16px;
        padding: 28px 20px;
    }

    .booking-form {
        grid-template-columns: 1fr;
    }
}


/* =========================================================
   Sticky Social — Hide on mobile
   ========================================================= */

@media (max-width: 768px) {
    .sticky-social {
        display: none;
    }
}


/* =========================================================
   Responsive Animation
   ========================================================= */

@keyframes fadeSlide {
    from {
        opacity: 0;
        transform: translateY(-6px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}