/* Mobile & production display fixes — load after other stylesheets */

html {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

body {
    overflow-x: clip;
    min-width: 0;
}

img,
video,
iframe {
    max-width: 100%;
    height: auto;
}

/* Anchor targets clear fixed navbar */
section[id],
.page-hero,
.page-shell {
    scroll-margin-top: calc(92px + env(safe-area-inset-top, 0px));
}

/* Prevent iOS zoom on form focus */
input,
select,
textarea {
    font-size: 16px;
}

@media (min-width: 769px) {
    input,
    select,
    textarea {
        font-size: inherit;
    }
}

/* ——— Navigation ——— */
@media (max-width: 768px) {
    .navbar {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
    }

    .hamburger {
        min-width: 44px;
        min-height: 44px;
        align-items: center;
        justify-content: center;
    }

    /* ——— Hero ——— */
    .hero .tab-content {
        max-height: min(50vh, 420px);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        padding-right: 0.25rem;
        margin-bottom: 1.5rem;
        border-radius: 12px;
        background: rgba(255, 255, 255, 0.04);
        padding: 0.75rem 0.85rem;
    }

    .hero .tab-panel p {
        font-size: 0.95rem;
        line-height: 1.65;
    }

    .hero-subtitle {
        margin-bottom: 1.25rem;
    }

    /* ——— Footer ——— */
    .footer {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
    }

    .footer-content {
        grid-template-columns: 1fr;
        text-align: center;
        gap: 1.75rem;
    }

    .footer-section ul {
        padding: 0;
    }

    .footer-section .social-links {
        justify-content: center;
    }

    .footer-bottom {
        padding-bottom: max(1rem, env(safe-area-inset-bottom));
    }

    /* ——— Inner pages ——— */
    .page-hero {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
    }

    .page-hero-card {
        border-radius: 14px;
    }

    .page-hero-media {
        min-height: 200px;
    }

    .page-section-header {
        text-align: left;
    }

    .page-section-header .section-divider {
        margin-left: 0;
    }

    .container {
        padding-left: max(1rem, env(safe-area-inset-left));
        padding-right: max(1rem, env(safe-area-inset-right));
    }

    /* ——— Blog ——— */
    .blog-page-hero .page-hero-copy {
        padding: 1.5rem 1.25rem;
    }

    .blog-card-body {
        padding: 1.15rem 1.2rem;
    }

    .blog-sidebar {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .hero-title {
        font-size: clamp(1.45rem, 7vw, 1.85rem) !important;
    }

    .section-header h2,
    .page-title {
        font-size: clamp(1.35rem, 5.5vw, 1.75rem);
    }

    .landing-preview .preview-body {
        padding: 1.75rem 0;
    }

    .landing-news-card {
        padding: 1rem 1.1rem;
    }

    .tab-btn {
        font-size: 0.85rem;
        padding: 0.55rem 0.95rem;
    }

    .footer-admin-link {
        width: 100%;
        max-width: none;
    }
}

/* Fallback when :has() unsupported — still reorder via flex on wrapper */
@supports not selector(:has(*)) {
    @media (max-width: 768px) {
        .landing-preview .section-entry-image {
            margin-top: 1rem;
        }
    }
}
