/* ============================================================
   Luna Oracle — Mobile Fix CSS (390px safe)
   Fixes horizontal overflow on all core pages
   ============================================================ */

/* Global overflow guard */
html, body {
    overflow-x: hidden;
    max-width: 100%;
}

*, *::before, *::after {
    box-sizing: border-box;
}

/* ---- Shared Header / Nav ---- */
header,
nav.main-nav {
    padding-left: 16px !important;
    padding-right: 16px !important;
}

.nav-container {
    padding: 0 !important;
}

/* Logo never wraps */
.logo,
.nav-logo {
    flex-shrink: 0;
    min-width: 0;
    white-space: nowrap;
}

.logo img,
.nav-icon {
    flex-shrink: 0;
}

/* Nav links collapse on mobile */
@media (max-width: 600px) {
    header nav,
    .nav-links {
        display: none !important;
    }

    /* Keep Sign In / lang switcher visible */
    .header-actions,
    .nav-actions {
        display: flex !important;
        align-items: center;
        gap: 8px;
    }
}

/* ---- Index page ---- */
@media (max-width: 480px) {
    /* Hero section */
    .hero {
        padding: 100px 16px 60px !important;
    }

    .hero h1 {
        font-size: 2em !important;
        word-break: break-word;
    }

    .hero p {
        font-size: 0.95em !important;
    }

    .cta-buttons {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 12px !important;
    }

    .cta-buttons .btn {
        width: 100% !important;
        text-align: center !important;
    }

    /* Free quota banner */
    .free-quota-banner {
        padding: 20px 16px !important;
        margin: 0 !important;
        border-radius: 0 !important;
    }

    .free-quota-banner h2 {
        font-size: 1.3em !important;
    }

    /* Features grid */
    .features-grid {
        grid-template-columns: 1fr !important;
        padding: 0 16px !important;
    }

    /* Pricing grid */
    .pricing-grid-4,
    .plan-cards-4 {
        grid-template-columns: 1fr !important;
        padding: 0 16px !important;
    }

    /* Systems grid */
    .systems-grid {
        grid-template-columns: 1fr !important;
        padding: 0 16px !important;
    }

    /* Testimonials */
    .testimonials-grid {
        grid-template-columns: 1fr !important;
        padding: 0 16px !important;
    }

    /* Section padding */
    .section,
    section {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    .section-alt {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    /* Meet Luna */
    .character-showcase {
        flex-direction: column !important;
        align-items: center !important;
    }

    .character-img {
        max-width: 200px !important;
    }
}

/* ---- Subscribe page ---- */
@media (max-width: 540px) {
    .plan-cards,
    .plan-cards-4 {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .plan-card {
        padding: 28px 20px !important;
    }

    /* MOST POPULAR ribbon — prevent overflow */
    .plan-card.featured::before {
        font-size: 0.6em !important;
        right: -28px !important;
        padding: 4px 36px !important;
    }

    .plan-price {
        font-size: 2.2em !important;
    }
}

/* ---- Divination page ---- */
@media (max-width: 480px) {
    .divination-grid,
    .services-grid {
        grid-template-columns: 1fr !important;
        padding: 0 16px !important;
    }

    /* Session modal */
    .session-modal,
    #session-modal {
        margin: 0 12px !important;
        width: calc(100% - 24px) !important;
        max-width: none !important;
        padding: 24px 20px !important;
    }

    .session-modal textarea,
    #question-input {
        width: 100% !important;
    }

    /* Quota display */
    .quota-display {
        font-size: 0.85em !important;
    }
}

/* ---- Reading page ---- */
@media (max-width: 480px) {
    .reading-hero {
        padding: 100px 16px 40px !important;
    }

    .reading-features {
        grid-template-columns: 1fr !important;
        padding: 0 16px !important;
    }

    .sample-preview {
        padding: 20px 16px !important;
        margin: 0 16px !important;
    }

    .reading-cta {
        padding: 40px 16px !important;
    }

    .reading-cta .btn {
        width: 100% !important;
        text-align: center !important;
    }
}

/* ---- Blog page ---- */
@media (max-width: 480px) {
    .blog-grid {
        grid-template-columns: 1fr !important;
        padding: 0 16px !important;
    }

    .blog-card {
        margin: 0 !important;
    }
}

/* ---- Horoscope page ---- */
@media (max-width: 480px) {
    .signs-grid {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 8px !important;
        padding: 0 12px !important;
    }

    .sign-btn {
        padding: 8px 4px !important;
        font-size: 0.7em !important;
    }

    .sign-btn .sign-emoji {
        font-size: 1.6em !important;
    }

    .content-tabs {
        gap: 6px !important;
        padding: 0 12px !important;
    }

    .tab-btn {
        padding: 8px 14px !important;
        font-size: 0.85em !important;
    }

    .content-panel {
        padding: 20px 16px !important;
    }
}

/* ---- About / Blog / Reading common ---- */
@media (max-width: 480px) {
    .page-hero {
        padding: 100px 16px 40px !important;
    }

    .page-hero h1 {
        font-size: 2em !important;
    }

    .about-content,
    .mission-section {
        padding: 0 16px !important;
    }

    .team-grid {
        gap: 24px !important;
    }

    .mission-grid {
        grid-template-columns: 1fr !important;
    }
}

/* ---- Privacy / Terms / Disclaimer ---- */
@media (max-width: 480px) {
    .legal-content,
    .policy-content,
    .disclaimer-content {
        padding: 0 16px !important;
    }
}

/* ---- Footer ---- */
@media (max-width: 480px) {
    footer,
    .footer {
        padding: 40px 16px 20px !important;
    }

    .footer-grid,
    .footer-links {
        grid-template-columns: 1fr !important;
        gap: 24px !important;
    }
}

/* ---- Promo bar ---- */
.promo-bar {
    overflow: hidden;
    white-space: nowrap;
}

/* ---- Images ---- */
img {
    max-width: 100%;
    height: auto;
}

/* ---- Tables ---- */
table {
    display: block;
    overflow-x: auto;
    max-width: 100%;
}

/* ── Unified Sign In Button ─────────────────────────────── */
.nav-sign-in-btn {
    background: transparent;
    border: 1.5px solid var(--lavender, #9b7dd4);
    color: var(--lavender, #9b7dd4);
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 0.85em;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
    font-family: inherit;
}
.nav-sign-in-btn:hover {
    background: var(--lavender, #9b7dd4);
    color: #fff;
}
#nav-mobile-sign-in {
    margin-top: 12px;
    width: 100%;
    padding: 12px;
    font-size: 1em;
}
