/* Album Builder Frontend Styles */

/* Container */
.album-builder-container {
    width: 100%;
    margin: 0 auto;
}

/* Controls */
.album-builder-controls {
    /* Reset to allow full-width filter bar */
    display: block;
    margin-bottom: 20px;
    padding: 0;
    background: transparent;
    border-radius: 0;
}

/* Hide filter summary text and hamburger button on desktop (all listings) */
.album-builder-container .filter-summary,
.album-builder-container .album-filter-toggle {
    display: none;
}

/* Desktop: hide only the text label explicitly (in case container is forced visible by theme) */
@media (min-width: 769px) {
    .album-builder-container .filter-summary .summary-text {
        display: none !important
    }
}

/* Show them back on small screens */
@media (max-width: 768px) {
    .album-builder-container .filter-summary,
    .album-builder-container .album-filter-toggle {
        display: inline-flex;
    }
}

.album-builder-search {
    display: flex;
    align-items: center;
    background: white;
    border: 1px solid #ddd;
    border-radius: 4px;
    overflow: hidden;
    min-width: 250px;
}

.album-search-input {
    border: none;
    padding: 10px 15px;
    font-size: 14px;
    flex: 1;
    outline: none;
}

.album-search-button {
    background: #0073aa;
    color: white;
    border: none;
    padding: 10px 15px;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.album-search-button:hover {
    background: #005a87;
}

.album-builder-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    align-items: center;
}

.album-filter-group {
    display: flex;
    align-items: center;
    gap: 8px;
}

.album-filter-label {
    font-weight: 600;
    color: #333;
    white-space: nowrap;
}

.album-filter-select {
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: white;
    font-size: 14px;
    min-width: 150px;
}

/* Grid Layouts */
.album-builder-grid {
    display: grid;
    gap: 20px;
    margin-bottom: 30px;
}

.album-builder-grid.album-grid-layout {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.album-builder-grid.album-carousel-layout {
    grid-auto-flow: column;
    grid-auto-columns: 300px;
    overflow-x: auto;
    scroll-behavior: smooth;
    padding-bottom: 10px;
}

.album-builder-grid.album-justified-layout {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

/* Column-specific styles */

/* Prevent column utility from overriding featured grid */
.layout-featured_grid.columns-1 .album-builder-grid,
.layout-featured_grid.columns-2 .album-builder-grid,
.layout-featured_grid.columns-3 .album-builder-grid,
.layout-featured_grid.columns-4 .album-builder-grid,
.layout-featured_grid.columns-5 .album-builder-grid,
.layout-featured_grid.columns-6 .album-builder-grid {
    grid-template-columns: 1fr 1fr;
}

.columns-1 .album-builder-grid {
    grid-template-columns: 1fr;
}

.columns-2 .album-builder-grid {
    grid-template-columns: repeat(2, 1fr);
}

.columns-3 .album-builder-grid {
    grid-template-columns: repeat(3, 1fr);
}

.columns-4 .album-builder-grid {
    grid-template-columns: repeat(4, 1fr);
}

.columns-5 .album-builder-grid {
    grid-template-columns: repeat(5, 1fr);
}

.columns-6 .album-builder-grid {
    grid-template-columns: repeat(6, 1fr);
}

/* Album Items */
.album-builder-item {
    background: white;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    display: flex;
    flex-direction: column;
}

.album-builder-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

.album-builder-cover {
    position: relative;
    overflow: hidden;
    aspect-ratio: 4/3;
}

/* Play icon for video cards (featured and normal) */
.ab-video-play-icon{
    position:absolute; top:50%; left:50%; transform:translate(-50%, -50%);
    width:48px; height:48px; z-index:2;
    background:url('../img/video-play-icon.png') no-repeat center center / contain;
    pointer-events:none;
}

.album-cover-link {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
}

.album-cover-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.album-builder-item:hover .album-cover-image {
    transform: scale(1.05);
}

.album-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.album-builder-item:hover .album-overlay {
    opacity: 1;
}

.album-image-count {
    background: rgba(255, 255, 255, 0.9);
    padding: 8px 12px;
    border-radius: 20px;
    display: flex;
    align-items: center;
    gap: 6px;
    font-weight: 600;
    color: #333;
}

.album-image-count .dashicons,
.album-image-count i {
    font-size: 16px;
}

/* Content */
.album-builder-content {
    padding: 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
    background: #EBEBEBB2;
}

.album-builder-title {
    margin: 0 0 10px 0;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.4;
}

.album-builder-title a {
    color: #333;
    text-decoration: none;
    transition: color 0.2s ease;
}

.album-builder-title a:hover {
    color: #0073aa;
}

.album-builder-excerpt {
    margin: 0 0 15px 0;
    color: #666;
    line-height: 1.6;
    flex: 1;
}

.album-builder-excerpt p {
    margin: 0;
}

.album-builder-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
    color: #888;
    margin-top: auto;
}

.album-builder-meta span {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Pagination */
.album-builder-pagination {
    text-align: center;
    margin-top: 30px;
}

.album-load-more {
    background: #FF5500 !important;
    color: white;
    border: none;
    width: 142px;
    height: 32px;
    padding: 0 !important;
    border-radius: 999px !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 14px !important;
    font-weight: 700;
    text-transform: uppercase;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

/* Align text and icon */
.album-load-more .load-more-text{margin-right:8px}
.album-load-more .load-more-icon{width:10px;height:7px}

.album-load-more:hover {
    background: #FF5500;
}

.album-builder-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 20px;
    font-size: 16px;
    color: #666;
}

.album-builder-loading .spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid #f3f3f3;
    border-top: 2px solid #0073aa;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* No Results */
.album-builder-no-results {
    text-align: center;
    padding: 60px 20px;
    color: #666;
}
.album-builder-grid .album-builder-no-results{grid-column:1 / -1;justify-self:center;width:100%}

.album-builder-no-results p {
    font-size: 18px;
    margin: 0;
}

/* Single Album Gallery */
.album-single-container {
    width: 100%;
    margin: 0 auto;
}

.album-single-header {
    text-align: center;
    margin-bottom: 40px;
}

.album-single-title {
    font-size: 32px;
    font-weight: 700;
    margin: 0 0 15px 0;
    color: #333;
}

.album-single-description {
    font-size: 18px;
    color: #666;
    line-height: 1.6;
    max-width: 600px;
    margin: 0 auto;
}

.album-single-gallery,
.album-frontend-gallery {
    display: grid;
    gap: 20px;
}

.album-gallery-item {
    position: relative;
    overflow: hidden;
    border-radius: 8px;
    background: #f5f5f5;
}

.album-gallery-image-wrapper {
    position: relative;
    overflow: hidden;
}

.album-gallery-image {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.3s ease;
}

.album-gallery-item:hover .album-gallery-image {
    transform: scale(1.02);
}

.album-image-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.album-gallery-item:hover .album-image-overlay {
    opacity: 1;
}

.album-zoom-icon {
    color: white;
    font-size: 24px;
    background: rgba(0, 0, 0, 0.5);
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.album-gallery-caption {
    padding: 15px;
    background: white;
}

.album-image-title {
    margin: 0 0 8px 0;
    font-size: 16px;
    font-weight: 600;
    color: #333;
}

.album-image-description {
    margin: 0;
    font-size: 14px;
    color: #666;
    line-height: 1.5;
}

/* Layout-specific styles */
.layout-grid .album-single-gallery,
.layout-grid .album-frontend-gallery {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.layout-masonry .album-single-gallery,
.layout-masonry .album-frontend-gallery {
    column-count: 3;
    column-gap: 20px;
}

.layout-masonry .album-gallery-item {
    break-inside: avoid;
    margin-bottom: 20px;
}

/* Column-specific gallery styles */
.columns-1 .album-single-gallery,
.columns-1 .album-frontend-gallery {
    grid-template-columns: 1fr;
}

.columns-2 .album-single-gallery,
.columns-2 .album-frontend-gallery {
    grid-template-columns: repeat(2, 1fr);
}

.columns-3 .album-single-gallery,
.columns-3 .album-frontend-gallery {
    grid-template-columns: repeat(3, 1fr);
}

.columns-4 .album-single-gallery,
.columns-4 .album-frontend-gallery {
    grid-template-columns: repeat(4, 1fr);
}

.columns-5 .album-single-gallery,
.columns-5 .album-frontend-gallery {
    grid-template-columns: repeat(5, 1fr);
}

.columns-6 .album-single-gallery,
.columns-6 .album-frontend-gallery {
    grid-template-columns: repeat(6, 1fr);
}

/* Carousel Navigation */
.album-carousel-nav {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 20px;
}

.album-carousel-prev,
.album-carousel-next {
    background: #0073aa;
    color: white;
    border: none;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s ease;
}

.album-carousel-prev:hover,
.album-carousel-next:hover {
    background: #005a87;
}

/* Lightbox */
.album-lightbox-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    animation: fadeIn 0.3s ease forwards;
}

.album-lightbox-container {
    position: relative;
    max-width: 90vw;
    max-height: 90vh;
    background: white;
    border-radius: 8px;
    overflow: hidden;
    transform: scale(0.8);
    animation: scaleIn 0.3s ease forwards;
}

.album-lightbox-close {
    position: absolute;
    top: 15px;
    right: 15px;
    background: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    font-size: 24px;
    cursor: pointer;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s ease;
}

.album-lightbox-close:hover {
    background: rgba(0, 0, 0, 0.7);
}

.album-lightbox-content {
    display: flex;
    flex-direction: column;
    max-height: 80vh;
}

.album-lightbox-image {
    max-width: 100%;
    max-height: 60vh;
    object-fit: contain;
    display: block;
}

.album-lightbox-info {
    padding: 20px;
    max-height: 20vh;
    overflow-y: auto;
}

.album-lightbox-title {
    margin: 0 0 10px 0;
    font-size: 20px;
    font-weight: 600;
    color: #333;
}

.album-lightbox-description {
    margin: 0;
    color: #666;
    line-height: 1.6;
}

.album-lightbox-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 20px;
    background: #f5f5f5;
    border-top: 1px solid #ddd;
}

.album-lightbox-prev,
.album-lightbox-next {
    background: #0073aa;
    color: white;
    border: none;
    width: 40px;
    height: 40px;
    border-radius: 4px;
    font-size: 18px;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.album-lightbox-prev:hover,
.album-lightbox-next:hover {
    background: #005a87;
}

.album-lightbox-prev:disabled,
.album-lightbox-next:disabled {
    background: #ccc;
    cursor: not-allowed;
}

.album-lightbox-counter {
    font-size: 14px;
    color: #666;
    font-weight: 600;
}

/* Animations */
@keyframes fadeIn {
    to { opacity: 1; }
}

@keyframes scaleIn {
    to { transform: scale(1); }
}

/* Body class when lightbox is open */
body.album-lightbox-open {
    overflow: hidden;
}

/* Error Messages */
.album-builder-error {
    position: fixed;
    top: 20px;
    right: 20px;
    background: #d63638;
    color: white;
    padding: 15px 20px;
    border-radius: 4px;
    z-index: 9998;
    font-size: 14px;
    max-width: 300px;
    animation: slideInRight 0.3s ease;
}

@keyframes slideInRight {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

/* Lazy Loading */
.album-lazy {
    opacity: 0;
    transition: opacity 0.3s ease;
}

.album-lazy.loaded {
    opacity: 1;
}

/* Responsive Design */
@media (max-width: 1200px) {
    .columns-6 .album-builder-grid {
        grid-template-columns: repeat(4, 1fr);
    }
    
    .columns-5 .album-builder-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 992px) {
    .columns-5 .album-builder-grid,
    .columns-4 .album-builder-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .layout-masonry .album-single-gallery,
    .layout-masonry .album-frontend-gallery {
        column-count: 2;
    }

    /* Video listing: hide the text label for Reset Filters on mobile only */
    .ab-video-container .filter-actions .reset span { display: none; }

    /* Photo listing: hide the text label for Reset Filters on mobile only */
    .album-builder-container:not(.ab-video-container) .filter-actions .reset span { display: none; }
}

@media (max-width: 768px) {
    .album-builder-controls {
        flex-direction: column;
        align-items: stretch;
        gap: 15px;
        /* Ensure filter bar is visible on mobile like news listing */
        display:block !important;
    }
    
    .album-builder-search {
        min-width: auto;
    }
    
    .album-builder-filters {
        justify-content: center;
        margin-top: 10px !important;
    }
    
    .album-filter-group {
        flex-direction: column;
        align-items: stretch;
        gap: 5px;
    }
    
    .columns-4 .album-builder-grid,
    .columns-3 .album-builder-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .columns-4 .album-single-gallery,
    .columns-3 .album-single-gallery,
    .columns-4 .album-frontend-gallery,
    .columns-3 .album-frontend-gallery {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .album-single-title {
        font-size: 24px;
    }
    
    .album-lightbox-container {
        max-width: 95vw;
        max-height: 95vh;
    }
    
    .album-lightbox-content {
        max-height: 85vh;
    }
    
    .album-lightbox-image {
        max-height: 50vh;
    }
    
    .layout-masonry .album-single-gallery,
    .layout-masonry .album-frontend-gallery {
        column-count: 2;
    }

    /* Album Gallery – moved to single-album-figma.css */
}

@media (max-width: 576px) {
    .album-builder-grid {
        gap: 15px;
    }
    
    .columns-2 .album-builder-grid,
    .columns-3 .album-builder-grid,
    .columns-4 .album-builder-grid,
    .columns-5 .album-builder-grid,
    .columns-6 .album-builder-grid {
        grid-template-columns: 1fr;
    }
    
    .columns-2 .album-single-gallery,
    .columns-3 .album-single-gallery,
    .columns-4 .album-single-gallery,
    .columns-5 .album-single-gallery,
    .columns-6 .album-single-gallery,
    .columns-2 .album-frontend-gallery,
    .columns-3 .album-frontend-gallery,
    .columns-4 .album-frontend-gallery,
    .columns-5 .album-frontend-gallery,
    .columns-6 .album-frontend-gallery {
        grid-template-columns: 1fr;
    }
    
    .album-builder-content {
        padding: 15px;
    }
    
    .album-builder-meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 5px;
    }
    
    .layout-masonry .album-single-gallery,
    .layout-masonry .album-frontend-gallery {
        column-count: 1;
    }
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
    .album-builder-item {
        border: 2px solid #000;
    }
    
    .album-overlay {
        background: rgba(0, 0, 0, 0.8);
    }
    
    .album-lightbox-overlay {
        background: rgba(0, 0, 0, 0.95);
    }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
    .album-builder-item,
    .album-cover-image,
    .album-gallery-image,
    .album-overlay,
    .album-image-overlay {
        transition: none;
    }
    
    .album-lightbox-overlay,
    .album-lightbox-container {
        animation: none;
    }
}

/* Dark Mode Support 
@media (prefers-color-scheme: dark) {
    .album-builder-item {
        background: #1e1e1e;
        color: #fff;
    }
    
    .album-builder-title a {
        color: #fff;
    }
    
    .album-builder-title a:hover {
        color: #4a9eff;
    }
    
    .album-builder-controls {
        background: #2a2a2a;
    }
    
    .album-search-input,
    .album-filter-select {
        background: #1e1e1e;
        color: #fff;
        border-color: #444;
    }
    
    .album-lightbox-container {
        background: #1e1e1e;
    }
    
    .album-lightbox-title {
        color: #fff;
    }
    
    .album-lightbox-nav {
        background: #2a2a2a;
        border-color: #444;
    }
}

*/

/* ===========================
   FEATURED GRID LAYOUT (2+4)
   =========================== */

.layout-featured_grid .album-builder-grid {
    display: grid !important;
    gap: 20px;
    grid-template-columns: 1fr 1fr;
    width: 100%;
}

/* Override any existing grid styles */
.layout-featured_grid .album-builder-grid .album-builder-item {
    width: 100% !important;
    margin: 0 !important;
    float: none !important;
    box-sizing: border-box;
}

/* Debug: Make sure featured grid is visible */
/* Remove debug borders (ensure clean UI) */
.layout-featured_grid { border: 0; }
.layout-featured_grid .album-builder-grid { border: 0; }

/* Featured items (first 2) - large size */
.layout-featured_grid .album-builder-item.featured-item {
    grid-row: 1;
    position: relative;
    background: transparent;
    box-shadow: none;
    overflow: hidden;
}

.layout-featured_grid .album-builder-item.featured-item:first-of-type {
    grid-column: 1;
}

.layout-featured_grid .album-builder-item.featured-item:nth-of-type(2) {
    grid-column: 2;
}

/* Featured items styling */
.layout-featured_grid .featured-item .album-builder-cover { position: relative; width: 100%; height: 325px; margin: 0; }
.layout-featured_grid .featured-item .album-cover-image { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; border-radius: 12px; }

.layout-featured_grid .featured-item .album-builder-title {
    font-size: 24px;
    font-weight: 700;
    margin: 15px 0 10px 0;
    line-height: 1.3;
}

/* Featured overlay content */
.layout-featured_grid .featured-overlay-content {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 16px;
    color: #fff;
    background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.55) 60%, rgba(0,0,0,0.7) 100%);
}

/* Always show overlay content on featured cards (no hover required) */
.layout-featured_grid .album-builder-item.is-featured.featured-item .album-overlay {
    opacity: 1;
}

.layout-featured_grid .featured-overlay-content .album-tags {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 6px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 14px;
    font-weight: 400;
}

.layout-featured_grid .featured-overlay-content .album-tag {
    color: #E4E4E4;
    padding: 0;
    margin: 0;
    line-height: 1.4;
}

.layout-featured_grid .featured-overlay-content .album-title-overlay {
    font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 20px;
    font-weight: 700;
    color: #FFFFFF;
    margin: 0 0 6px 0;
}

.layout-featured_grid .featured-overlay-content .album-date-overlay {
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 14px;
    font-weight: 400;
    color: #E4E4E4;
}

/* Hide standard card content for featured items (overlay shows content) */
.layout-featured_grid .album-builder-content.hide-on-featured {
    display: none;
}

.layout-featured_grid .featured-item .album-builder-excerpt {
    font-size: 16px;
    line-height: 1.5;
    margin-bottom: 15px;
}

.layout-featured_grid .featured-item .album-builder-meta {
    font-size: 14px;
    font-weight: 500;
}

/* Regular grid items (items 3-6) - smaller size */
.layout-featured_grid .album-builder-grid-row {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 15px;
}

/* Regular card sizing for desktop */
.layout-featured_grid .regular-item {
    width: auto;
    height: 323px;
}

.layout-featured_grid .regular-item .album-builder-cover { position: relative; width: 100%; height: 211px; margin: 0; overflow: hidden; }
.layout-featured_grid .regular-item .album-cover-image { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; object-position: center}

.layout-featured_grid .regular-item .album-builder-title {
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 16px;
    font-weight: 700;
    color: #252525;
    margin: 10px 0 6px 0;
    line-height: 1.4;
}

.layout-featured_grid .regular-item .album-builder-excerpt {
    font-size: 14px;
    line-height: 1.4;
    margin-bottom: 8px;
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.layout-featured_grid .regular-item .album-builder-meta {
    font-size: 14px;
    font-weight: 400;
}
.layout-featured_grid .regular-item .album-date {
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 14px;
    font-weight: 400;
    color: #464646;
}

/* Video listing specific sizing (normal cards) */
.ab-video-container .album-builder-grid-row {
    grid-template-columns: repeat(4, 275px);
    justify-content: space-between;
}
.ab-video-container .album-builder-grid-row.ab-first-row {
    grid-template-columns: 1fr 275px 275px;
    align-items: start;
    gap: 15px;
}
.ab-video-container .ab-first-row .featured-item { grid-column: 1; }
.ab-video-container .ab-first-row .regular-item:nth-child(2) { grid-column: 2; }
.ab-video-container .ab-first-row .regular-item:nth-child(3) { grid-column: 3; }

/* Responsive: Video grid */
@media (max-width: 1200px) {
    .ab-video-container .album-builder-grid-row { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; justify-content: initial; }
    .ab-video-container .album-builder-grid-row.ab-first-row { grid-template-columns: 1fr !important; }
}
@media (max-width: 992px) {
    .ab-video-container .album-builder-grid { grid-template-columns: 1fr !important; gap: 15px !important; width: 375px; margin: 0 auto; }
    .ab-video-container .ab-video-grid { display: block !important; width: 375px; margin-left: auto; margin-right: auto; }
    .ab-video-container .ab-video-grid .ab-first-row,
    .ab-video-container .ab-video-grid .album-builder-grid-row { display: grid !important; grid-template-columns: repeat(2, 164px) !important; gap: 12px !important; justify-content: space-between; }
    .ab-video-container .ab-video-grid .album-builder-item { width: 164px !important; }
    .ab-video-container .album-builder-grid-row { grid-template-columns: 1fr !important; }
    .ab-video-container .album-builder-grid-row.ab-first-row { grid-template-columns: 1fr !important; display: block !important; }
    .ab-video-container .album-builder-grid-row .album-builder-item { width: 100% !important; }
}
@media (max-width: 768px) {
    /* Force single column grid on mobile */
    .ab-video-container .album-builder-grid { grid-template-columns: 1fr !important; gap: 15px !important; }
    .ab-video-container .album-builder-grid-row { grid-template-columns: 1fr !important; }
    .ab-video-container .album-builder-grid-row.ab-first-row { grid-template-columns: 1fr !important; display: block !important; }

    /* Featured item container above filters */
    .ab-video-container .ab-featured-mobile { display: block; margin: 0 0 12px 0; width: 375px; margin-left: auto; margin-right: auto; }
    /* Featured item - Figma spec: 375 x 500 */
    .ab-video-container .ab-featured-mobile .album-builder-item.featured-item { width: 375px !important; margin: 0 auto !important; }
    .ab-video-container .ab-featured-mobile .album-builder-item.featured-item .album-builder-cover { width: 375px !important; height: 500px !important; }
    .ab-video-container .ab-featured-mobile .album-builder-item.featured-item .album-cover-image { width: 100% !important; height: 100% !important; object-fit: cover; max-width: 375px !important;}
    .ab-video-container .ab-featured-mobile .album-builder-item.featured-item .ab-video-play-icon{ width:48px; height:48px; }

    /* Regular items - horizontal card layout like photos, but fluid */
    /* Normal card grid: two per row */
    .ab-video-container .album-builder-grid-row { display: grid !important; grid-template-columns: 164px 164px !important; grid-auto-rows: 215px !important; gap: 12px !important; justify-content: center; }
    /* Normal card - Figma spec: 164 x 215 (strict). Add crisp border to avoid blurry edges */
    .ab-video-container .album-builder-item.regular-item { width: 164px !important; height: 215px !important; display: block !important; margin: 0 !important; box-sizing: border-box; overflow: hidden; border-radius: 8px !important; background: #fff; border: 1px solid #E6E6E6 !important; box-shadow: none !important; }
    .ab-video-container .album-builder-item.regular-item .album-builder-cover { position: relative; width: 164px !important; height: 120px !important; border-radius: 0 !important; overflow: hidden; margin: 0; }
    .ab-video-container .album-builder-item.regular-item .ab-video-play-icon{ width:32px; height:32px; }
    .ab-video-container .album-builder-item.regular-item .album-cover-image { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; transform: none !important; -webkit-transform: none !important; image-rendering: -webkit-optimize-contrast; }
    .ab-video-container .album-builder-item.regular-item .album-builder-content { width: 164px !important; height: 95px !important; padding: 8px 6px 6px 0 !important; display: flex; flex-direction: column; justify-content: space-between; background: transparent; color:#252525; box-sizing: border-box; }
    .ab-video-container .album-builder-item.regular-item .album-builder-title { font-size: 13px; line-height: 1.25; margin: 2px 0 2px 0; font-weight: 700; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
    .ab-video-container .album-builder-item.regular-item .album-builder-meta { font-size: 12px; color: #666; }
    .ab-video-container .album-builder-item.regular-item .album-builder-title a { color: #252525; text-decoration: none; }
    .ab-video-container .album-builder-item.regular-item .album-builder-meta { font-size: 12px; color: #666; margin-top: 2px; }
    .ab-video-container .album-builder-item.regular-item .album-tags-inline { margin: 0 0 0px 0; gap: 6px; }
    .ab-video-container .album-builder-item.regular-item .album-tag-inline { font-size: 12px; color: #FF5500; margin: 6px;}
}
.ab-video-container .ab-video-item--regular {
    width: 275px !important;
    height: 325px;
}

/* Inline tags for regular cards */
.layout-featured_grid .album-tags-inline {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 6px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 14px;
    font-weight: 400;
}
.layout-featured_grid .album-tag-inline {
    color: #FF5500;
    padding: 0;
    margin: 0;
    line-height: 1.4;
}

/* Load More Button for Featured Grid */
.layout-featured_grid .album-load-more {
    grid-column: 1 / -1;
    text-align: center;
    margin-top: 30px;
}

.layout-featured_grid .album-load-more-button {
    background: #FF5500;
    color: white;
    border: none;
    width: 142px;
    height: 32px;
    padding: 0;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 14px;
    font-weight: 700;
    border-radius: 999px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.layout-featured_grid .album-load-more-button:hover {
    background: #FF5500;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 115, 170, 0.3);
}

.layout-featured_grid .album-load-more-button:disabled {
    background: #ccc;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* Photo gallery (desktop and all breakpoints)
   Hide the below-card content block for featured items so the featured
   card displays as a pure cover image with overlay */
.album-builder-container.layout-featured_grid .album-builder-item.is-featured.featured-item .album-builder-content {
    display: none !important;
    padding: 0 !important;
    margin: 0 !important;
    height: 0 !important;
}

/* Responsive Design for Featured Grid */
@media (max-width: 1024px) {
    .layout-featured_grid .album-builder-grid-row {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }
    
    .layout-featured_grid .featured-item .album-cover-image {
        height: 300px;
    }
    
    .layout-featured_grid .regular-item .album-cover-image {
        height: 180px;
    }
}

@media (max-width: 768px) {
    .layout-featured_grid .album-builder-grid { grid-template-columns: 1fr; gap: 15px; }
    /* Mobile: 16px page gutters */
    /* Filter bar gutters 16px */
    .album-builder-container .filter-bar{width:calc(100% - 32px); margin:0 16px}
    
    /* Featured card: 343x192, aligned with 16px gutters (left and right) */
    .layout-featured_grid .album-builder-item.featured-item { width:343px !important; margin:0 16px !important; grid-row:auto !important; }
    .layout-featured_grid .album-builder-item.featured-item:nth-child(2) { grid-column: 1; }
    
    .layout-featured_grid .album-builder-grid-row { grid-template-columns: 1fr; justify-items:center; width:100%; }
    
    .layout-featured_grid .featured-item .album-builder-cover { height: 192px; width:343px !important; margin:0; }
    .layout-featured_grid .featured-item .album-cover-image { height:192px !important; width:343px !important; max-width:343px !important; object-fit:cover !important; }
    .layout-featured_grid .album-builder-item.is-featured.featured-item .album-builder-content { display:none !important; padding:0 !important; margin:0 !important; height:0 !important; }
    
    /* Mobile horizontal card for regular items */
    /* Normal card: 343x92 with 16px gutters */
    .layout-featured_grid .regular-item {height: 92px; display: flex; gap: 12px; justify-self: initial; margin:0 16px; }
    .layout-featured_grid .regular-item .album-builder-cover { position: relative; width: 164px; height: 92px; flex: 0 0 164px; border-radius: 8px; overflow: hidden; }
    .layout-featured_grid .regular-item .album-cover-image { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; }
    .layout-featured_grid .regular-item .album-builder-content { padding: 0; display: flex; flex-direction: column; justify-content: center; background: transparent; color:#252525; flex:1; min-width:0; }
    .layout-featured_grid .regular-item .album-builder-title{display:block}
    .layout-featured_grid .regular-item .album-builder-meta{display:block}
    /* Ensure content is placed to the right of the cover, not overlaying it */
    .layout-featured_grid .regular-item{position:relative}
    .layout-featured_grid .regular-item .album-builder-cover{position:relative; z-index:1}
    .layout-featured_grid .regular-item .album-builder-content{position:relative; z-index:2}
    .layout-featured_grid .regular-item .album-tags-inline{ margin:0 0 4px 0; }
    .layout-featured_grid .regular-item .album-date{ color:#464646; font-size:12px; margin:6px;}

    /* Stronger override to ensure 16px gutters on regular items */
    .layout-featured_grid .album-builder-grid .album-builder-item.regular-item {justify-self:center; margin:0 16px !important;}
        
    .layout-featured_grid .featured-item .album-builder-title {
        font-size: 20px;
    }
    
    .layout-featured_grid .regular-item .album-builder-title {
        font-size: 14px;
    }

        .album-builder-item {
            background: white !important;
            border-radius: 8px !important;
            overflow: hidden !important;
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
            transition: transform 0.2s ease, box-shadow 0.2s ease;
            display: flex !important;
            flex-direction: row !important;
        }
}

/* --- Mobile alignment hardening for Photo listing (Featured Grid) --- */
@media (max-width: 768px) {

    /* One column, no horizontal drift */
    .layout-featured_grid .album-builder-grid {
        grid-template-columns: 1fr !important
    }

    .layout-featured_grid .album-builder-grid-row {
        grid-template-columns: 1fr !important;
        justify-items: stretch !important;
        width: 100%;
        padding-inline: 16px;
    }
	
	/* Do NOT add side padding for video gallery rows */
    .ab-video-container .album-builder-grid-row { padding-inline: 0 !important; }

    /* Featured card spans full content width minus 16px gutters */
    .layout-featured_grid .album-builder-item.featured-item {
        width: calc(100% - 32px) !important;
        margin: 0 16px !important
    }

    .layout-featured_grid .featured-item .album-builder-cover {
        width: 100% !important;
        height: auto !important;
        aspect-ratio: 343/192
    }

    .layout-featured_grid .featured-item .album-cover-image {
        width: 100% !important;
        height: 100% !important;
        max-width: none !important;
        object-fit: cover
    }

    /* Normal cards match the same gutters and fill line */
    .layout-featured_grid .regular-item {
        width: calc(100% - 32px) !important;
        margin: 0 16px !important
    }

    #album-builder-c6bc762 {
        margin-left: -9px;
    }
}

@media (max-width: 480px) {
    .layout-featured_grid .album-builder-grid-row {
        grid-template-columns: 1fr;
    }
    
    /* Height overrides for very small screens were removed to avoid conflicts */
}

/* ===========================
   Album Builder – Filter Bar (Figma spec)
   =========================== */
.album-builder-container{
    --border:#e6e6e6;
    --label:#8f8f8f;
    --text:#222222;
    --icon:#2c2c2c;
    --reset:#ff5a00;
    --bg:#ffffff;
}

.album-builder-container .filter-bar{
    width:100%;
    background:var(--bg);
    border:1px solid var(--border);
    border-radius:2px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    height:44px;
    padding:4px 10px; /* slim bar */
}

.album-builder-container .filter-summary{display:flex;align-items:center;gap:8px;margin-left:0}
.album-builder-container .filter-summary .summary-text{font-size:13px;color:#222}
.album-builder-container .filter-summary .album-filter-toggle{background:none;border:0;padding:6px;cursor:pointer;color:#666;display:inline-flex;align-items:center}
.album-builder-container .filter-summary .album-filter-toggle svg{width:18px;height:18px}
.album-builder-container .filter-summary .album-filter-toggle:hover{color:#111}

/* Right side actions (hamburger + reset) */
.album-builder-container .filter-actions{margin-left:auto;display:flex;align-items:center;gap:12px}
.album-builder-container .filter-actions .album-filter-toggle{background:none;border:0;padding:6px;cursor:pointer;color:#666;display:inline-flex;align-items:center}
.album-builder-container .filter-actions .album-filter-toggle svg{width:18px;height:18px}
.album-builder-container .filter-actions .album-filter-toggle .ab-filter-hamburger{display:none}
.album-builder-container .filter-actions .album-filter-toggle:hover{color:#111}

/* Fullscreen drawer */
.album-filter-drawer{position:fixed;inset:0;z-index:9999;background:#fff;transform:translateY(100%);transition:transform .25s ease;display:flex;flex-direction:column}
.album-filter-drawer.open{transform:translateY(0)}
.album-filter-drawer .drawer-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:0;position:sticky;top:0;background:#0B0B42;z-index:1}
.album-filter-drawer .drawer-title{font-size:16px;font-weight:600;color:#fff}
.album-filter-drawer .album-filter-close{background:none;border:0;padding:6px;cursor:pointer;color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.album-filter-drawer .album-filter-close .drawer-cancel-text{color:#fff;font-weight:700}
.album-filter-drawer .album-filter-close svg{width:20px;height:20px;color:#ff5a00;fill:none}
.album-filter-drawer .drawer-body{padding:16px;display:flex;flex-direction:column;gap:14px;overflow:auto}
.album-filter-drawer .drawer-label{font-size:12px;color:#666}
.album-filter-drawer .album-filter-select{font-weight:700}
.album-filter-drawer .album-filter-select option{font-weight:700}
.album-filter-drawer .drawer-actions{margin-top:auto;padding:12px 16px;border-top:1px solid #eee;display:flex;gap:10px;justify-content:space-between}
.album-filter-drawer .drawer-actions .album-filter-apply{background:#ff5a00;border:0;color:#fff;font-weight:700;border-radius:999px;height:32px;width:164px;padding:0 16px;letter-spacing:.3px}
.album-filter-drawer .drawer-actions .album-filters-reset{background:transparent;border:2px solid #ff5a00;color:#ff5a00;font-weight:700;border-radius:999px;height:32px;width:164px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.album-filter-drawer .drawer-actions .album-filters-reset svg{width:16px;height:16px}

.album-builder-container .filters{
    display:flex;
    align-items:stretch;
    gap:28px;
    min-width:0;
}
/* Hide inline selects on small screens to show compact summary + reset */
@media (max-width:768px){
    .album-builder-container .filters{display:none}
    /* Use PNG hamburger on mobile */
    .album-builder-container .filter-actions .album-filter-toggle .ab-filter-hamburger{display:inline-block;width:18px;height:18px}
    .album-builder-container .filter-actions .album-filter-toggle svg{display:none}
}

.album-builder-container .filter{
    position:relative; /* for overlay select */
    min-width:170px;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

.album-builder-container .filter-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:8px;
    line-height:1;
}

.album-builder-container .filter-label{
    font-size:11px;
    color:var(--label);
    letter-spacing:.2px;
    white-space:nowrap;
}

.album-builder-container .chevron{
    width:15px;
    height:8px;
    flex:0 0 auto;
    opacity:.9;
    display:block;
    margin-bottom: -22px;
}

/* Desktop emphasis and arrow sizing */
@media (min-width: 769px){
  .album-builder-container .filter-value{font-weight:700;color:var(--text)}
  .album-builder-container .chevron{width:15px;height:8px}
}

.album-builder-container .filter-value{
    margin-top:6px;
    font-size:12px;
    color:var(--text);
}

.album-builder-container .reset{
    display:flex;
    align-items:center;
    gap:10px;
    padding-left:14px;
    margin-left:8px;
    border-left:1px solid var(--border);
    white-space:nowrap;
    font-size:12px;
    font-weight:600;
    color:var(--reset);
    cursor:pointer;
    user-select:none;
}

.album-builder-container .reset svg{
    width:14px;
    height:14px;
    stroke:var(--reset);
    fill:none;
    stroke-width:1.5;
}

/* Hide the native select visually but keep it operable */
.album-builder-container .filter select.album-filter-select{
    position:absolute; inset:0; opacity:0; width:100%; height:100%; cursor:pointer;
}

@media (max-width:520px){
    .album-builder-container .filter{min-width:140px}
    .album-builder-container .filters{gap:16px}
}
