/* Base Comic Noir Theme and Variables */
:root {
    --primary-color: #f8f9fa;
    --secondary-color: #2a9d8f;
    --accent-color: #9900cc; /* Default Red Hue */
    --hover-color: #c0303b;
    --street-bg: #7C8F86;
    --body-bg: #fff;
    --box-bg: #2a9d8f;
    --font-stack: "Helvetica Neue", Arial, sans-serif;
    --shadow: 0 4px 10px rgba(0, 0, 0, 0.5);
}

/* Color Hues for Comic Noir Theme */
body.red-hue {
    --accent-color: #9900cc;
    --hover-color: #c0303b;
}
body.blue-hue {
    --accent-color: #1a759f;
    --hover-color: #166085;
}
body.green-hue {
    --accent-color: #2a9d8f;
    --hover-color: #218376;
}
body.purple-hue {
    --accent-color: #6a0572;
    --hover-color: #55045a;
}

/* Fairy Fantasy Theme (Specific to Poetry Page) */
body.poetry-page {
    --primary-color: #343a40;
    --secondary-color: #e9e5e3;
    --body-bg: #f5f0f2;
    --box-bg: #fff;
    --shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

body.poetry-page.red-hue {
    --accent-color: #e63946;
    --hover-color: #c0303b;
}
body.poetry-page.blue-hue {
    --accent-color: #4a688b;
    --hover-color: #3c5472;
}
body.poetry-page.green-hue {
    --accent-color: #4CAF50;
    --hover-color: #45a049;
}
body.poetry-page.purple-hue {
    --accent-color: #8a41a4;
    --hover-color: #72348b;
}


/* General Styling */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html, body {
    height: 100%;
}

body {
    font-family: var(--font-stack);
    background-color: var(--body-bg);
    color: var(--primary-color);
    display: flex;
    flex-direction: column;
}

/* Main content wrapper to fill space between header and footer */
main {
    flex-grow: 1;
    padding: 2rem;
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
}

/* Header */
.main-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 2rem;
    background-color: var(--box-bg);
    box-shadow: var(--shadow);
    position: sticky;
    top: 0;
    z-index: 1000;
    flex-wrap: wrap; /* Allow items to wrap on smaller screens */
}

.header-left {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.header-right {
    display: flex;
    align-items: center;
}

.company-logo {
    height: 50px;
}

.color-selector {
    display: flex;
    gap: 0.5rem;
}

.color-selector .color-btn {
    width: 25px;
    height: 25px;
    border-radius: 50%;
    border: 2px solid transparent;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.color-btn[data-color="red"] { background-color: #e63946; }
.color-btn[data-color="blue"] { background-color: #1a759f; }
.color-btn[data-color="green"] { background-color: #2a9d8f; }
.color-btn[data-color="purple"] { background-color: #6a0572; }

/* Highlight for selected color button */
.color-btn.active {
    border-color: var(--accent-color);
    transform: scale(1.1);
}

.hamburger-menu {
    background: none;
    border: none;
    color: var(--primary-color);
    font-size: 1.5rem;
    cursor: pointer;
    display: block; /* Always show on mobile first */
}

.main-nav {
    display: none;
    flex-direction: column;
    position: absolute;
    top: 100%;
    right: 0;
    width: 100%;
    background-color: var(--secondary-color);
    box-shadow: var(--shadow);
    z-index: 999;
}

.main-nav.active {
    display: flex;
}

.nav-link {
    color: var(--primary-color);
    text-decoration: none;
    padding: 1rem 2rem;
    border-bottom: 1px solid var(--body-bg);
    transition: color 0.2s ease;
    text-align: center;
}

.nav-logo {
    color: var(--primary-color);
    text-decoration: none;
    transition: color 0.2s ease;
}

.nav-link:hover {
    color: var(--accent-color);
}

/* Quote container in the middle of the header */
.quote-container {
    display: none; /* Hide on mobile by default */
    text-align: center;
    flex-grow: 1;
    margin: 0 2rem;
    padding: 0 1rem;
}

#quote-text {
    font-size: 1.1rem;
    color: var(--primary-color);
}

.quote-author {
    font-weight: bold;
    font-style: italic;
    color: var(--accent-color);
}


/* Main Body Content */
.new-drops-section h2,
.shop-content h2,
.blog-section h2,
.poetry-section h2,
.street-art-section h2 {
    text-align: center;
    color: var(--accent-color);
    margin-bottom: 2rem;
}

.countdown-section {
    text-align: center;
    margin-bottom: 1rem;
}

.countdown-timer {
    display: flex;
    justify-content: center;
    gap: 1rem;
    color: var(--primary-color);
    padding: 1rem;
}

.countdown-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    font-size: 1.5rem;
    font-weight: bold;
}

.countdown-item span:last-child {
    font-size: 0.6rem;
    font-weight: normal;
    text-transform: uppercase;
    color: var(--accent-color);
}

.product-grid {
    display: grid;
    grid-template-columns: 1fr; /* Default to single column on mobile */
    gap: 2rem;
}

.product-item {
    text-align: center;
    text-decoration: none;
    color: var(--primary-color);
    background-color: var(--box-bg);
    border-radius: 8px;
    box-shadow: var(--shadow);
    transition: transform 0.2s ease;
    cursor: pointer;
}

.product-item:hover {
    transform: translateY(-5px);
}

.product-item img, .product-card img {
    width: 100%;
    height: 250px;
    object-fit: cover;
    border-radius: 8px 8px 0 0;
}

.product-name, .product-card h3 {
    display: block;
    padding: 1rem;
    font-weight: bold;
}

/* Add these styles to your style.css file */
.product-info {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
}

.product-info h3 {
    padding: 0;
}

.buy-now-btn {
    background-color: var(--accent-color);
    color: var(--primary-color);
    border: none;
    padding: 0.5rem 1rem;
    font-size: 0.9rem;
    cursor: pointer;
    border-radius: 5px;
    transition: background-color 0.2s ease;
}

.buy-now-btn:hover {
    background-color: var(--hover-color);
}

/* Update the pop-up image style to ensure it fits the modal */
.shop-popup-image-item {
    max-width: 100%;
    max-height: 80vh;
    object-fit: contain;
    border-radius: 8px;
}

.street-art-section, .shop-art-section {
    background-color: var(--street-bg);
    padding: 2rem;
    border-radius: 8px;
    box-shadow: var(--shadow);
    text-align: center;
    margin-top: 4rem;
}

.street-art-content, .shop-art-content {
    max-width: 800px;
    margin: 0 auto;
}

.street-art-content p, .shop-art-content p {
    margin-bottom: 2rem;
    text-align: left; /* Align text for readability */
}

/* Footer */
.main-footer {
    display: flex;
    flex-direction: column; /* Stack vertically on mobile */
    align-items: center;
    padding: 1rem 2rem;
    background-color: var(--secondary-color);
    color: var(--primary-color);
    box-shadow: var(--shadow);
    width: 100%;
    z-index: 1000;
    text-align: center;
    margin-top: auto; /* Push footer to the bottom */
}

.footer-left, .footer-right {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 1rem;
}

.footer-center {
    margin-bottom: 1rem;
}

.request-btn {
    background-color: var(--accent-color);
    color: var(--primary-color);
    border: none;
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
    cursor: pointer;
    border-radius: 5px;
    transition: background-color 0.2s ease;
}

.request-btn:hover {
    background-color: var(--hover-color);
}

.social-icon {
    color: var(--primary-color);
    font-size: 1.5rem;
    margin: 0 0.5rem;
    transition: color 0.2s ease;
}

.social-icon:hover {
    color: var(--accent-color);
}

.blog-link {
    color: var(--primary-color);
    text-decoration: none;
    font-weight: bold;
    margin: 0 0.5rem;
    transition: color 0.2s ease;
}

.blog-link:hover {
    color: var(--accent-color);
}

.footer-center a {
    border-bottom: none;
}

/* Blog Pop-up (Homepage) */
.blog-popup-overlay, .newsletter-popup-overlay, .shop-popup-overlay, .poetry-popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    display: none; /* default hidden, toggled by .visible */
    justify-content: center;
    align-items: center;
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.35s ease, visibility 0.35s ease;
}

.blog-popup-overlay.visible, .newsletter-popup-overlay.visible, .shop-popup-overlay.visible, .poetry-popup-overlay.visible {
    display: flex;
    opacity: 1;
    visibility: visible;
}

.blog-popup-content, .newsletter-popup-content, .shop-popup-content, .poetry-popup-content {
    background-color: var(--box-bg);
    padding: 1rem; /* reduced padding for small screens */
    border-radius: 10px;
    width: 94%;
    max-width: 920px; /* allow wider content on tablets */
    position: relative;
    box-shadow: var(--shadow);
    text-align: center;
    color: var(--primary-color);
    max-height: 92vh; /* prevent overflow on short mobile viewports */
    overflow: hidden;
}

.close-btn, .newsletter-close-btn, .shop-popup-close-btn, .poetry-close-btn {
    position: absolute;
    top: 10px;
    right: 20px;
    font-size: 2rem;
    font-weight: bold;
    cursor: pointer;
    color: var(--primary-color);
}

.blog-slider-container, .shop-popup-slider-container {
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
    width: 100%;
}

.blog-slider, .shop-popup-slider {
    display: flex;
    transition: transform 0.45s cubic-bezier(.2,.8,.2,1);
    will-change: transform;
}

.blog-post, .shop-popup-image-item {
    flex-shrink: 0;
    width: 100%;
    min-width: 100%; /* ensure each slide matches the visible container */
    text-align: center;
    padding: 0 0.75rem; /* smaller horizontal padding for mobile */
}

.blog-post img, .shop-popup-image-item img {
    width: 100%;
    height: auto;
    max-height: 60vh; /* keep images from overflowing on phones */
    object-fit: cover;
    border-radius: 8px;
    margin-bottom: 0.75rem;
}

.blog-post h4, .shop-popup-content h3 {
    color: var(--accent-color);
}

.blog-post .read-more {
    display: inline-block;
    background-color: var(--accent-color);
    color: var(--primary-color);
    text-decoration: none;
    padding: 0.5rem 1rem;
    margin-top: 1rem;
    border-radius: 5px;
    transition: background-color 0.2s ease;
}

.blog-post .read-more:hover {
    background-color: var(--hover-color);
}

.slider-arrow, .shop-popup-arrow {
    background: none;
    border: none;
    color: var(--primary-color);
    font-size: 2rem;
    padding: 0.5rem;
    cursor: pointer;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
}

.left-arrow, .shop-popup-left-arrow { left: 0; }
.right-arrow, .shop-popup-right-arrow { right: 0; }

/* Blog Page Specific Styles */
.blog-section h2 {
    text-align: center;
    color: var(--accent-color);
    margin-bottom: 2rem;
}

.blog-list {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    max-width: 800px;
    margin: 0 auto;
}

.blog-item {
    background-color: var(--street-bg);
    border-radius: 8px;
    box-shadow: var(--shadow);
    overflow: hidden;
    position: relative;
}

.blog-item details {
    padding: 1.5rem;
}

.blog-item summary h3 {
    color: var(--accent-color);
}

.blog-item .blog-full-content {
    text-align: center;
    padding-top: 1rem;
    color: var(--primary-color);
}

.blog-item .read-more-toggle::after {
    content: "Read More";
}

.blog-item details[open] .read-more-toggle::after {
    content: "Read Less";
}

.blog-image {
    width: 100%; /* Make image responsive */
    height: auto; /* Adjust height automatically */
    object-fit: cover;
}


/* Shop Page Specific Styles */
.shop-content {
    padding: 2rem;
    max-width: 1200px;
    margin: 0 auto;
}

.product-grid {
    display: grid;
    grid-template-columns: 1fr; /* Default to single column on mobile */
    gap: 2rem;
}

.product-card {
    background-color: var(--street-bg);
    border-radius: 8px;
    box-shadow: var(--shadow);
    text-align: center;
    overflow: hidden;
    transition: transform 0.2s ease;
    cursor: pointer;
}

.product-card:hover {
    transform: translateY(-5px);
}

.product-card img {
    width: 100%;
    height: 250px;
    object-fit: cover;
}

.product-card h3 {
    color: var(--primary-color);
    padding: 1rem;
}


/* Poetry Page specific styles */
.poetry-page .main-header,
.poetry-page .main-footer {
    background-color: var(--secondary-color);
    box-shadow: var(--shadow);
}

.poetry-page h2 {
    color: var(--accent-color);
}

.poetry-page .nav-link,
.poetry-page .social-icon,
.poetry-page .blog-link {
    color: var(--primary-color);
}

.poetry-page .poetry-item {
    background-color: var(--box-bg);
    border-radius: 8px;
    box-shadow: var(--shadow);
    overflow: hidden;
    margin-bottom: 2rem;
}

.poetry-page .poetry-image {
    width: 100%;
    max-height: 500px;
    object-fit: contain;
}

.poetry-page .poetry-item details {
    padding: 1.5rem;
}

.poetry-page summary h3 {
    color: var(--accent-color);
    text-align:center;
}

.poetry-page .poetry-full-content {
    padding-top: 1rem;
    color: var(--primary-color);
    text-align:center;
}

/* Newsletter Pop-up */
.newsletter-popup-overlay {
    display: none; /* Hide by default to be controlled by JS */
}

/* Responsive Media Queries */

/* Tablet and larger screens */
@media (min-width: 768px) {
    .main-header {
        flex-wrap: nowrap; /* Prevent wrapping on larger screens */
        justify-content: space-between;
    }

    .header-left, .header-right {
        width: auto;
    }

    .hamburger-menu {
        display: none; /* Hide hamburger menu on desktop */
    }

    .main-nav {
        display: flex;
        flex-direction: row;
        position: static;
        width: auto;
        box-shadow: none;
        background-color: transparent;
    }

    .main-nav .nav-link {
        padding: 0;
        border-bottom: none;
    }
    
    .header-left {
        flex-direction: row;
    }
    
    .company-logo {
        margin-bottom: 0;
    }

    .quote-container {
        display: block; /* Show quote on tablet and desktop */
    }

    .product-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .blog-list, .poetry-list {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
        gap: 2rem;
    }

    .blog-item, .poetry-item {
        flex: 1 1 45%;
        max-width: 45%;
    }

    .blog-image, .poetry-image {
        width: 100%;
        height: 250px;
    }
    
    .blog-item details {
        height: auto;
    }
/* Add these new styles for the blog and poetry popups */
.blog-popup-overlay, .poetry-popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    display: none; /* keep hidden until .visible is added */
    justify-content: center;
    align-items: center;
    z-index: 3000;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.blog-popup-overlay.visible, .poetry-popup-overlay.visible {
    display: flex; /* become modal when visible */
    visibility: visible;
    opacity: 1;
}

.blog-popup-content, .poetry-popup-content {
    background-color: var(--box-bg);
    padding: 1rem;
    border-radius: 10px;
    width: 96%;
    max-width: 920px;
    position: relative;
    box-shadow: var(--shadow);
    color: var(--primary-color);
    max-height: 92vh; /* Limits the height of the modal */
    overflow-y: auto; /* Adds scrolling if content is too long */
}

.blog-close-btn, .poetry-close-btn {
    position: absolute;
    top: 10px;
    right: 20px;
    font-size: 2rem;
    font-weight: bold;
    cursor: pointer;
    color: var(--primary-color);
}

.blog-popup-image, .poetry-popup-image {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin-bottom: 1rem;
}

.blog-item .blog-summary, .poetry-item .poetry-summary {
    padding: 1.5rem;
    text-align: center;
}

.read-more-btn {
    background-color: var(--accent-color);
    color: var(--primary-color);
    border: none;
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
    cursor: pointer;
    border-radius: 5px;
    transition: background-color 0.2s ease;
    margin-top: 1rem;
}

.read-more-btn:hover {
    background-color: var(--hover-color);
}

/* Updated styles for hidden content to prevent it from affecting layout */
#blog-posts-data, #poetry-posts-data {
    display: none;
}
/* This is the only part of your existing CSS that needs to change. Replace everything from this point on. */

/* Responsive Media Queries */

/* Tablet and larger screens */
@media (min-width: 768px) {
    .main-header {
        flex-wrap: nowrap; /* Prevent wrapping on larger screens */
        justify-content: space-between;
    }

    .header-left, .header-right {
        width: auto;
    }

    .hamburger-menu {
        display: none; /* Hide hamburger menu on desktop */
    }

    .main-nav {
        display: flex;
        flex-direction: row;
        position: static;
        width: auto;
        box-shadow: none;
        background-color: transparent;
    }

    .main-nav .nav-link {
        padding: 0;
        border-bottom: none;
    }
    
    .header-left {
        flex-direction: row;
    }
    
    .company-logo {
        margin-bottom: 0;
    }

    .quote-container {
        display: block; /* Show quote on tablet and desktop */
    }

    .product-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .blog-list, .poetry-list {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
        gap: 2rem;
    }

    .blog-item, .poetry-item {
        flex: 1 1 45%;
        max-width: 45%;
    }

    .blog-image, .poetry-image {
        width: 100%;
        height: 250px;
    }
    
    .blog-item details {
        height: auto;
    }
}

/* Desktop and larger screens */
@media (min-width: 1024px) {
    .product-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .blog-item, .poetry-item {
        flex: 1 1 30%;
        max-width: 30%;
    }

    .main-footer {
        flex-direction: row;
        justify-content: space-between;
    }
    
    .footer-left, .footer-right {
        flex-direction: row;
    }
    
    .footer-center {
        margin-bottom: 0;
    }
}

/* Artist Showcase Section */
.artist-showcase-section {
    padding: 2rem;
    text-align: center;
}

.artist-showcase-section h2 {
    color: var(--accent-color);
    margin-bottom: 2rem;
}

.artist-grid {
    display: grid;
    grid-template-columns: 1fr; /* Default to single column on mobile */
    gap: 2rem;
    max-width: 1200px;
    margin: 0 auto;
}

.artist-tile {
    position: relative;
    overflow: hidden;
    cursor: pointer;
    border-radius: 8px;
    box-shadow: var(--shadow);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.artist-tile:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.6);
}

.artist-tile img {
    width: 100%;
    height: 350px;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.artist-tile:hover img {
    transform: scale(1.05);
}

.tile-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    background: rgba(0, 0, 0, 0.7);
    color: var(--primary-color);
    padding: 1rem;
    transform: translateY(100%);
    transition: transform 0.3s ease;
    text-align: left;
}

.artist-tile:hover .tile-overlay {
    transform: translateY(0);
}

.tile-overlay h3 {
    font-size: 1.2rem;
    margin-bottom: 0.5rem;
    color: var(--primary-color);
}

.tile-overlay p {
    font-size: 0.9rem;
    margin: 0;
}

/* New Pop-up for the Showcase Images */
.showcase-popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.9);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 3000;
}

.showcase-popup-overlay.visible {
    display: flex;
    visibility: visible;
    opacity: 1;
}

.showcase-popup-content {
    background-color: var(--box-bg);
    padding: 2rem;
    border-radius: 10px;
    width: 90%;
    max-width: 900px;
    position: relative;
    box-shadow: var(--shadow);
    text-align: center; /* Ensures content inside is centered */
    display: flex; /* Added for flexbox alignment */
    flex-direction: column; /* Stacks items vertically */
    align-items: center; /* Centers items horizontally */
    justify-content: center; /* Centers items vertically if there's extra space */
}

.showcase-popup-image {
    max-width: 100%;
    height: auto;
    max-height: 70vh; /* Added to prevent image from overflowing on smaller screens */
    object-fit: contain; /* Ensures the entire image is visible without cropping */
    border-radius: 8px;
    margin-bottom: 1.5rem; /* Space between image and button */
}

/* Ensure the shop button centers inside the showcase flex column (fallback) */
.showcase-popup-content .shop-now-btn {
    align-self: center !important; /* explicit flex centering */
    width: auto !important;        /* prevent it from expanding full width */
    display: inline-block !important;
}

.shop-now-btn {
    background-color: var(--accent-color);
    color: var(--primary-color);
    border: none;
    padding: 1rem 2rem;
    font-size: 1.2rem;
    cursor: pointer;
    border-radius: 5px;
    text-decoration: none;
    transition: background-color 0.2s ease;
    display: inline-block; /* Treat as a block element for centering with margin */
    margin-top: 1rem; /* Added explicit margin for spacing, though margin-bottom on image helps */
}

.shop-now-btn:hover {
    background-color: var(--hover-color);
}

.request-page-section {
    padding: 2rem;
    text-align: center;
}

.request-page-content {
    background-color: var(--box-bg);
    padding: 2rem;
    border-radius: 10px;
    max-width: 800px;
    margin: 0 auto;
    box-shadow: var(--shadow);
    color: #000; /* Updated: The text color is now black */
}

.request-page-content h2 {
    color: var(--accent-color);
    margin-bottom: 1rem;
}

.request-page-content p {
    margin-bottom: 2rem;
}

/* Form Styles */
.form-group {
    margin-bottom: 1.5rem;
    text-align: left;
}

.form-group label {
    display: block;
    font-weight: bold;
    margin-bottom: 0.5rem;
    color: #000; /* Added: Ensures labels are also black */
}

.form-group input[type="text"],
.form-group input[type="email"],
.form-group textarea,
.form-group input[type="file"] {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid var(--secondary-color);
    border-radius: 5px;
    background-color: #fff;
    color: #333; /* Text within the input fields remains a standard dark color */
    font-family: var(--font-stack);
}

.form-group textarea {
    resize: vertical;
}
/* Media Queries for the new grid */
@media (min-width: 768px) {
    .artist-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.signup-form input[type="email"] {
    padding: 0.75rem;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 1rem;
    flex-grow: 1;
    max-width: 300px;
}

/* Balance: ensure all blocks are closed */
}
/* Generic image popup and slider tweaks */
.image-popup-overlay, #image-popup {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    justify-content: center;
    align-items: center;
    background: rgba(0,0,0,0.85);
    z-index: 2500;
}

.image-popup-overlay.visible, #image-popup.visible {
    display: flex;
}

.image-slider {
    display: flex;
    width: 100%;
    max-width: 920px;
    overflow: hidden;
    transition: transform 0.45s cubic-bezier(.2,.8,.2,1);
}

.image-slider .popup-image {
    flex-shrink: 0;
    width: 100%;
    min-width: 100%;
    object-fit: contain;
}

/* small screen adjustments */

@media (max-width: 480px) {
    .artist-tile img { height: 220px; }
    .blog-post img, .shop-popup-image-item img, .showcase-popup-image { max-height: 50vh; }
    .showcase-popup-content, .blog-popup-content { padding: 0.75rem; }
}

/* Mobile override: force overlays to behave as full-screen modals on phones */
@media (max-width: 767px) {
    .blog-popup-overlay, .newsletter-popup-overlay, .shop-popup-overlay, .poetry-popup-overlay, .showcase-popup-overlay, .image-popup-overlay, #image-popup {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        display: none !important; /* hidden until .visible is added */
        justify-content: center !important;
        align-items: center !important;
        z-index: 99999 !important;
        opacity: 0 !important;
        visibility: hidden !important;
        background-color: rgba(0,0,0,0.85) !important;
    }

    /* Ensure images are centered and fill the viewport width on small devices */
    img, .blog-image, .product-card img, .product-item img, .artist-tile img, .poetry-image {
        display: block;
        width: 100% !important;    /* fill available width */
        max-width: 100% !important; /* don't exceed container */
        height: auto !important;   /* keep aspect ratio */
        margin-left: auto !important;
        margin-right: auto !important;
        object-fit: contain; /* preserve full image */
    }

    /* Remove side paddings from central containers so images can span edge-to-edge */
    main, .artist-showcase-section, .street-art-section, .blog-popup-content, .showcase-popup-content {
        padding-left: 0.75rem !important;
        padding-right: 0.75rem !important;
    }

    /* Ensure slides and popups let the image fill the visible width */
    .blog-slider, .image-slider, .shop-popup-slider, .showcase-popup-content {
        width: 100% !important;
    }

    /* Make sure blog posts and product cards don't keep large fixed heights */
    .blog-post img, .product-card img, .product-item img {
        max-height: none !important;
    }

    /* Center overlays content visually */
    .blog-popup-content, .showcase-popup-content, .image-popup-content {
        margin: 0 auto !important;
        left: 0; right: 0; /* allow centering */
    }

    .blog-popup-overlay.visible, .newsletter-popup-overlay.visible, .shop-popup-overlay.visible, .poetry-popup-overlay.visible, .showcase-popup-overlay.visible, .image-popup-overlay.visible, #image-popup.visible {
        display: flex !important;
        opacity: 1 !important;
        visibility: visible !important;
    }

    .blog-popup-content, .newsletter-popup-content, .shop-popup-content, .poetry-popup-content, .showcase-popup-content {
        width: 95% !important;
        max-width: 940px !important;
        padding: 0.75rem !important;
        max-height: 92vh !important;
        overflow-y: auto !important;
    }

    /* Small gap and centered Shop Now button directly under the image */
    .showcase-popup-image {
        margin-bottom: 3px !important; /* 2-3px gap between image and button */
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        height: auto !important;
    }

    .showcase-popup-content .shop-now-btn {
        margin-top: 3px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        display: inline-block !important;
        text-align: center !important;
        align-self: center !important; /* enforce flex centering on mobile */
    }

    /* Ensure the Shop Now button centers and sits directly under the image on all screens */
    .showcase-popup-content .shop-now-btn {
        display: block !important;
        width: auto !important;
        margin: 3px auto !important;
    }

    /* Restore and emphasize the Shop Now button styling for mobile */
    .shop-now-btn {
        display: inline-block !important;
        background-color: var(--accent-color) !important;
        color: var(--primary-color) !important;
        padding: 0.85rem 1.5rem !important;
        font-size: 1.05rem !important;
        border-radius: 6px !important;
        text-decoration: none !important;
        text-align: center !important;
        box-shadow: 0 6px 14px rgba(0,0,0,0.18) !important;
    }

    .shop-now-btn:hover {
        background-color: var(--hover-color) !important;
    }
}
