/* Global mobile layout fixes */
html {
    overflow-x: hidden;
}

body.front-page {
    overflow-x: hidden;
    max-width: 100vw;
}

.site-header {
    max-width: 100vw;
}

.scrollbar-hide {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.scrollbar-hide::-webkit-scrollbar {
    display: none;
}

/* Header dropdowns — fit narrow viewports */
.header-cart-dropdown,
.header-wishlist-dropdown {
    width: min(380px, calc(100vw - 1.25rem));
    max-width: calc(100vw - 1.25rem);
}

@media (max-width: 639px) {
    .header-cart-dropdown,
    .header-wishlist-dropdown {
        position: fixed;
        left: 0.625rem;
        right: 0.625rem;
        width: auto;
        max-width: none;
    }
}

/* Search suggest panel */
.header-search-dropdown {
    max-height: min(60vh, 420px);
    overflow-y: auto;
}

/* Swiper carousels — prevent horizontal page scroll */
.front-page section:has(.swiper) {
    overflow-x: clip;
}

.swiper {
    overflow: hidden;
}

.swiper-wrapper {
    align-items: stretch;
}

.swiper-slide.product-card,
.swiper-slide .product-card {
    height: 100%;
}

.product-card-title {
    word-break: break-word;
    overflow-wrap: anywhere;
}

/* Product card hover — desktop only */
@media (hover: hover) and (pointer: fine) {
    .product-card:hover {
        transform: translateY(-8px) !important;
    }
}

@media (hover: none), (pointer: coarse) {
    .product-card:hover {
        transform: none !important;
    }

    .blog-carousel-card:hover,
    .blog-post-card .group:hover {
        transform: none !important;
    }
}

/* Blog / shop grids on very small screens */
@media (max-width: 399px) {
    .blog-posts-grid {
        grid-template-columns: 1fr;
    }
}

/* Footer stats wrap */
.footer-stats {
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 1rem;
}

@media (max-width: 359px) {
    .footer-stats {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        text-align: center;
    }

    .footer-stats .footer-stat-divider {
        display: none;
    }
}

/* Blog show meta row */
@media (max-width: 767px) {
    .blog-show-meta {
        width: 100%;
        justify-content: center;
        flex-wrap: wrap;
        gap: 0.75rem 1.25rem;
    }

    .blog-show-title-block {
        text-align: center;
    }
}

/* Comment form — textarea first on mobile */
@media (max-width: 767px) {
    .blog-comment-form {
        flex-direction: column-reverse;
    }
}
