/* ==========================================================================
   GWP GALLERY GRID - ARCHITECTURAL STYLESHEET
   ========================================================================== */

/* 
   BASE VARIABLES & RESPONSIVE MAPPING
   The PHP provides raw values (numbers/colors) via CSS Variables.
   This stylesheet handles the logic of mapping those to functional properties.
*/

.gwp-gallery {
    /* 1. Global Reset & Container */
    width: 100%;
    max-width: var(--gwp-gallery-width, 1400px);
    margin: var(--gwp-gallery-margin, 0 auto);
    padding: var(--gwp-gallery-padding, 20px);
    box-sizing: border-box;

    /* 2. Style Inheritance Bridge */
    font-family: var(--gwp-design-tokens-fonts-primary, Inter, sans-serif);
    color: var(--gwp-design-tokens-colors-text, #333);

    /* Ratio & Sizing Logic (Mapped from dimensions config) */
    --gallery-w: var(--gwp-gallery-card-image-dimensions-2xl-width, 400);
    --gallery-h: var(--gwp-gallery-card-image-dimensions-2xl-height, 600);

    --gwp-columns: var(--gwp-gallery-grid-columns-2xl, 5);
    --gwp-gap-val: var(--gwp-gallery-grid-gap-2xl, 20);
    --gwp-gap: calc(var(--gwp-gap-val) * 1px);

    /* Functional properties */
    --gwp-card-max-width: calc(var(--gallery-w) * 1px);
    --gwp-image-ratio: var(--gallery-w) / var(--gallery-h);
    --gwp-image-fit: var(--gwp-gallery-card-image-fit, cover);

    /* Typography Logic */
    --gwp-title-size: var(--gwp-gallery-card-title-style-font-size-2xl, 1.5rem);
    --gwp-title-weight: var(--gwp-gallery-card-title-style-font-weight-2xl, 700);
}

/* Responsive Overrides (Mobile First approach logic) */
@media (max-width: 1536px) {
    .gwp-gallery {
        --gallery-w: var(--gwp-gallery-card-image-dimensions-xl-width, 400);
        --gallery-h: var(--gwp-gallery-card-image-dimensions-xl-height, 600);

        --gwp-columns: var(--gwp-gallery-grid-columns-xl, 4);
        --gwp-gap-val: var(--gwp-gallery-grid-gap-xl, 20);
        --gwp-title-size: var(--gwp-gallery-card-title-style-font-size-xl, 1.5rem);
        --gwp-title-weight: var(--gwp-gallery-card-title-style-font-weight-xl, 700);
    }
}

@media (max-width: 1280px) {
    .gwp-gallery {
        --gallery-w: var(--gwp-gallery-card-image-dimensions-lg-width, 400);
        --gallery-h: var(--gwp-gallery-card-image-dimensions-lg-height, 600);

        --gwp-columns: var(--gwp-gallery-grid-columns-lg, 3);
        --gwp-gap-val: var(--gwp-gallery-grid-gap-lg, 20);
        --gwp-title-size: var(--gwp-gallery-card-title-style-font-size-lg, 1.5rem);
        --gwp-title-weight: var(--gwp-gallery-card-title-style-font-weight-lg, 700);
    }
}

@media (max-width: 1024px) {
    .gwp-gallery {
        --gallery-w: var(--gwp-gallery-card-image-dimensions-md-width, 400);
        --gallery-h: var(--gwp-gallery-card-image-dimensions-md-height, 600);

        --gwp-columns: var(--gwp-gallery-grid-columns-md, 2);
        --gwp-gap-val: var(--gwp-gallery-grid-gap-md, 15);
        --gwp-title-size: var(--gwp-gallery-card-title-style-font-size-md, 1.25rem);
        --gwp-title-weight: var(--gwp-gallery-card-title-style-font-weight-md, 700);
    }
}

@media (max-width: 768px) {
    .gwp-gallery {
        --gallery-w: var(--gwp-gallery-card-image-dimensions-sm-width, 300);
        --gallery-h: var(--gwp-gallery-card-image-dimensions-sm-height, 300);

        --gwp-columns: var(--gwp-gallery-grid-columns-sm, 1);
        --gwp-gap-val: var(--gwp-gallery-grid-gap-sm, 10);
        --gwp-title-size: var(--gwp-gallery-card-title-style-font-size-sm, 1.1rem);
        --gwp-title-weight: var(--gwp-gallery-card-title-style-font-weight-sm, 600);
    }
}

/* ==========================================================================
   ELEMENTS
   ========================================================================== */

/* Header Area */
.gwp-gallery__header {
    margin-bottom: 40px;
    text-align: center;
}

.gwp-gallery__header-title {
    font-size: 2.5rem;
    font-weight: 800;
    margin-bottom: 10px;
    color: var(--gwp-design-tokens-colors-brand, #0073aa);
}

.gwp-gallery__header-description {
    font-size: 1.1rem;
    color: var(--gwp-design-tokens-colors-muted, #666);
}

/* Grid Logic - PURE CSS GRID */
.gwp-gallery__grid {
    display: grid;
    /* Use minmax to respect both flexibility and constraints */
    grid-template-columns: repeat(var(--gwp-columns, 4), minmax(0, var(--gwp-card-max-width, 400px)));
    justify-content: center;
    /* Center items if they don't fill the container */
    gap: var(--gwp-gap, 20px);
    width: 100%;
    margin-top: 20px;
}

/* Card Component */
.gwp-gallery__card {
    background: var(--gwp-gallery-card-container-background, #fff);
    width: 100%;
    max-width: var(--gwp-card-max-width, 400px);
    margin: 0 auto;
    /* Keep card centered in its grid cell */

    /* Variable Handling with calc() for units */
    --card-radius: var(--gwp-gallery-card-border-radius-all-lg, 8);
    border-radius: calc(var(--card-radius) * 1px);

    --card-bw: var(--gwp-gallery-card-border-width-lg, 1);
    border: calc(var(--card-bw) * 1px) var(--gwp-gallery-card-border-style, solid) var(--gwp-gallery-card-border-color, #ddd);

    overflow: hidden;
    display: flex;
    flex-direction: column;
    position: relative;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    min-width: 0;
    /* Prevention for grid overflow */
}

/* Card Hover Logic */
.gwp-gallery__card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

/* Media/Image Section */
.gwp-gallery__card-media {
    position: relative;
    width: 100%;
    /* Default behavior: padding-based aspect ratio */
    padding-top: 66.66%;
    /* 3:2 fallback */
    background: #f0f0f0;
    overflow: hidden;
    margin: 0;
}

/* If Aspect Ratio is supported/configured */
@supports (aspect-ratio: 1) {
    .gwp-gallery__card-media {
        padding-top: 0;
        aspect-ratio: var(--gwp-image-ratio);
    }
}

.gwp-gallery__card-picture,
.gwp-gallery__card-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    object-fit: var(--gwp-image-fit, cover);
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.gwp-gallery__card:hover .gwp-gallery__card-image {
    transform: scale(1.1);
}

/* Badges */
.gwp-gallery__card-badges {
    position: absolute;
    top: 15px;
    right: 15px;
    z-index: 10;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.gwp-badge {
    padding: 6px 14px;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    border-radius: 4px;
    color: #fff;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.gwp-badge--vip {
    background: var(--gwp-design-tokens-colors-brand, #FFD700);
}

.gwp-badge--new {
    background: #4CAF50;
}

.gwp-badge--featured {
    background: #2196F3;
}

.gwp-badge--sale {
    background: #f44336;
}

/* Content Padding */
.gwp-gallery__card-content {
    padding: 24px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.gwp-gallery__card-title {
    margin: var(--gwp-gallery-card-title-margin, 0 0 12px 0);
    font-size: var(--gwp-title-size, 1.5rem);
    font-weight: var(--gwp-title-weight, 700);
    color: var(--gwp-gallery-card-title-style-color-2xl, #333);
    line-height: var(--gwp-gallery-card-title-style-line-height, 1.2);
    transition: color 0.3s ease;
    z-index: 5;
}

/* Overlay Logic - When Title is inside Media Container */
.gwp-gallery__card-media .gwp-gallery__card-title {
    position: absolute;
    margin: 0;
    color: #fff;
    /* Forced white for overlay visibility unless overridden */
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.8);
    pointer-events: none;
    /* Let clicks pass through to card/link */

    /* Offset Logic */
    --offset-x: calc(var(--gwp-gallery-card-title-offset-x, 20) * 1px);
    --offset-y: calc(var(--gwp-gallery-card-title-offset-y, 20) * 1px);
}

/* Position Mapping Matrix */
.gwp-gallery__card-media .gwp-gallery__card-title--top-left {
    top: var(--offset-y);
    left: var(--offset-x);
    bottom: auto;
}

.gwp-gallery__card-media .gwp-gallery__card-title--top-center {
    top: var(--offset-y);
    left: 50%;
    transform: translateX(-50%);
    bottom: auto;
}

.gwp-gallery__card-media .gwp-gallery__card-title--top-right {
    top: var(--offset-y);
    right: var(--offset-x);
    left: auto;
    bottom: auto;
}

.gwp-gallery__card-media .gwp-gallery__card-title--center-left {
    top: 50%;
    left: var(--offset-x);
    transform: translateY(-50%);
    bottom: auto;
}

.gwp-gallery__card-media .gwp-gallery__card-title--center {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    bottom: auto;
}

.gwp-gallery__card-media .gwp-gallery__card-title--center-right {
    top: 50%;
    right: var(--offset-x);
    left: auto;
    transform: translateY(-50%);
    bottom: auto;
}

.gwp-gallery__card-media .gwp-gallery__card-title--bottom-left {
    bottom: var(--offset-y);
    left: var(--offset-x);
    top: auto;
}

.gwp-gallery__card-media .gwp-gallery__card-title--bottom-center {
    bottom: var(--offset-y);
    left: 50%;
    transform: translateX(-50%);
    top: auto;
}

.gwp-gallery__card-media .gwp-gallery__card-title--bottom-right {
    bottom: var(--offset-y);
    right: var(--offset-x);
    left: auto;
    top: auto;
}

.gwp-gallery__card-title-link {
    color: inherit;
    text-decoration: none;
}

.gwp-gallery__card-excerpt {
    font-size: 1rem;
    line-height: 1.6;
    color: #555;
    margin-bottom: 24px;
}

/* CTA Area */
.gwp-gallery__card-actions {
    margin-top: auto;
}

.gwp-gallery__card-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 14px 24px;
    background: var(--gwp-gallery-card-button-style-background, #0073aa);
    color: var(--gwp-gallery-card-button-style-text-color, #fff);
    text-decoration: none;
    border-radius: 8px;
    font-weight: 700;
    transition: all 0.2s ease;
}

.gwp-gallery__card-button:hover {
    background: var(--gwp-gallery-card-button-hover-background, #005a87);
    transform: translateY(-2px);
}

/* ==========================================================================
   PAGINATION
   ========================================================================== */

.gwp-gallery__footer {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin-top: 60px;
}

.gwp-gallery__pagination {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: var(--gwp-gallery-pagination-width, 100%);
    margin: var(--gwp-gallery-pagination-margin, 0);
    padding: var(--gwp-gallery-pagination-padding, 0);
    gap: 20px;
}

/* Load More Button */
.gwp-gallery__pagination-load_more {
    display: flex;
    flex-direction: column;
    width: 100%;
    margin: var(--gwp-gallery-pagination-load-more-margin, 0);
    padding: var(--gwp-gallery-pagination-load-more-padding, 0);
    align-items: center;
    justify-content: var(--gwp-gallery-pagination-load-more-align, center);
}

.gwp-gallery__pagination-btn-load_more {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    /* Reset Browser Defaults */
    appearance: none;
    -webkit-appearance: none;
    background: none;
    border: none;
    text-decoration: none;
    outline: none;
    box-sizing: border-box;

    /* Configurable Spacing */
    margin: var(--gwp-gallery-pagination-load-more-button-margin, 20px auto);
    padding: var(--gwp-gallery-pagination-load-more-button-padding, 12px 24px);
    width: var(--gwp-gallery-pagination-load-more-button-width, auto);

    /* Configurable Visuals */
    background: var(--gwp-gallery-pagination-load-more-button-background, var(--gwp-design-tokens-colors-brand, #0073aa));
    color: var(--gwp-gallery-pagination-load-more-button-color, #fff);
    cursor: var(--gwp-gallery-pagination-load-more-button-cursor, pointer);

    /* Responsive Typography */
    font-family: var(--gwp-gallery-pagination-load-more-button-font, var(--gwp-design-tokens-fonts-primary, sans-serif));
    line-height: var(--gwp-gallery-pagination-load-more-button-line-height, 1.4);
    letter-spacing: var(--gwp-gallery-pagination-load-more-button-letter-spacing, normal);
    text-transform: var(--gwp-gallery-pagination-load-more-button-text-transform, none);

    font-size: var(--gwp-gallery-pagination-load-more-button-font-size-sm, 1rem);
    font-weight: var(--gwp-gallery-pagination-load-more-button-font-weight-sm, 700);

    /* Border Styling - Uses enabled variable as primary override */
    border-style: var(--gwp-gallery-pagination-load-more-button-enabled, var(--gwp-gallery-pagination-load-more-button-border-enabled, var(--gwp-gallery-pagination-load-more-button-style, var(--gwp-gallery-pagination-load-more-button-border-style, solid))));
    border-color: var(--gwp-gallery-pagination-load-more-button-color, var(--gwp-gallery-pagination-load-more-button-border-color, #ddd));
    border-width: var(--gwp-gallery-pagination-load-more-button-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-width-enabled, var(--gwp-gallery-pagination-load-more-button-border-width-sm, var(--gwp-gallery-pagination-load-more-button-border-width, var(--gwp-gallery-pagination-load-more-button-width-sm, var(--gwp-gallery-pagination-load-more-button-width, 1px)))))));
    border-radius: var(--gwp-gallery-pagination-load-more-button-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-radius-enabled, var(--gwp-gallery-pagination-load-more-button-border-radius-sm, var(--gwp-gallery-pagination-load-more-button-border-radius, var(--gwp-gallery-pagination-load-more-button-radius-sm, var(--gwp-gallery-pagination-load-more-button-radius, 20px)))))));

    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    outline: none;
}

/* Responsive Overrides for Load More Button */
@media (min-width: 768px) {
    .gwp-gallery__pagination-btn-load_more {
        border-style: var(--gwp-gallery-pagination-load-more-button-enabled-md, var(--gwp-gallery-pagination-load-more-button-border-enabled-md, var(--gwp-gallery-pagination-load-more-button-style-md, var(--gwp-gallery-pagination-load-more-button-border-style-md, var(--gwp-gallery-pagination-load-more-button-enabled, var(--gwp-gallery-pagination-load-more-button-border-enabled, var(--gwp-gallery-pagination-load-more-button-border-style-md, var(--gwp-gallery-pagination-load-more-button-border-style, solid))))))));
        border-width: var(--gwp-gallery-pagination-load-more-button-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-width-enabled, var(--gwp-gallery-pagination-load-more-button-border-width-md, var(--gwp-gallery-pagination-load-more-button-border-width, var(--gwp-gallery-pagination-load-more-button-border-width-sm, 1px))))));
        border-radius: var(--gwp-gallery-pagination-load-more-button-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-radius-enabled, var(--gwp-gallery-pagination-load-more-button-border-radius-md, var(--gwp-gallery-pagination-load-more-button-border-radius, var(--gwp-gallery-pagination-load-more-button-border-radius-sm, 20px))))));
    }
}

@media (min-width: 1024px) {
    .gwp-gallery__pagination-btn-load_more {
        border-style: var(--gwp-gallery-pagination-load-more-button-enabled-lg, var(--gwp-gallery-pagination-load-more-button-border-enabled-lg, var(--gwp-gallery-pagination-load-more-button-style-lg, var(--gwp-gallery-pagination-load-more-button-border-style-lg, var(--gwp-gallery-pagination-load-more-button-enabled-md, var(--gwp-gallery-pagination-load-more-button-border-enabled-md, var(--gwp-gallery-pagination-load-more-button-enabled, var(--gwp-gallery-pagination-load-more-button-border-enabled, var(--gwp-gallery-pagination-load-more-button-border-style-md, var(--gwp-gallery-pagination-load-more-button-border-style, solid))))))))));
        border-width: var(--gwp-gallery-pagination-load-more-button-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-width-enabled, var(--gwp-gallery-pagination-load-more-button-border-width-lg, var(--gwp-gallery-pagination-load-more-button-border-width, var(--gwp-gallery-pagination-load-more-button-border-width-md, 1px))))));
        border-radius: var(--gwp-gallery-pagination-load-more-button-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-radius-enabled, var(--gwp-gallery-pagination-load-more-button-border-radius-lg, var(--gwp-gallery-pagination-load-more-button-border-radius, var(--gwp-gallery-pagination-load-more-button-border-radius-md, 20px))))));
    }
}

@media (min-width: 1280px) {
    .gwp-gallery__pagination-btn-load_more {
        font-size: var(--gwp-gallery-pagination-load-more-button-font-size-xl, var(--gwp-gallery-pagination-load-more-button-font-size-lg));
        font-weight: var(--gwp-gallery-pagination-load-more-button-font-weight-xl, var(--gwp-gallery-pagination-load-more-button-font-weight-lg));
        border-style: var(--gwp-gallery-pagination-load-more-button-enabled-xl, var(--gwp-gallery-pagination-load-more-button-border-enabled-xl, var(--gwp-gallery-pagination-load-more-button-enabled-lg, var(--gwp-gallery-pagination-load-more-button-border-enabled-lg, var(--gwp-gallery-pagination-load-more-button-enabled-md, var(--gwp-gallery-pagination-load-more-button-border-enabled-md, var(--gwp-gallery-pagination-load-more-button-enabled, var(--gwp-gallery-pagination-load-more-button-border-enabled, var(--gwp-gallery-pagination-load-more-button-border-style-xl, solid)))))))));
        border-width: var(--gwp-gallery-pagination-load-more-button-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-width-enabled, var(--gwp-gallery-pagination-load-more-button-border-width-xl, var(--gwp-gallery-pagination-load-more-button-border-width, var(--gwp-gallery-pagination-load-more-button-border-width-lg, 1px))))));
        border-radius: var(--gwp-gallery-pagination-load-more-button-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-radius-enabled, var(--gwp-gallery-pagination-load-more-button-border-radius-xl, var(--gwp-gallery-pagination-load-more-button-border-radius, var(--gwp-gallery-pagination-load-more-button-border-radius-lg, 20px))))));
    }
}

@media (min-width: 1536px) {
    .gwp-gallery__pagination-btn-load_more {
        font-size: var(--gwp-gallery-pagination-load-more-button-font-size-2xl, var(--gwp-gallery-pagination-load-more-button-font-size-xl));
        font-weight: var(--gwp-gallery-pagination-load-more-button-font-weight-2xl, var(--gwp-gallery-pagination-load-more-button-font-weight-xl));
        border-style: var(--gwp-gallery-pagination-load-more-button-enabled-2xl, var(--gwp-gallery-pagination-load-more-button-border-enabled-2xl, var(--gwp-gallery-pagination-load-more-button-enabled-xl, var(--gwp-gallery-pagination-load-more-button-border-enabled-xl, var(--gwp-gallery-pagination-load-more-button-enabled-lg, var(--gwp-gallery-pagination-load-more-button-border-enabled-lg, var(--gwp-gallery-pagination-load-more-button-enabled-md, var(--gwp-gallery-pagination-load-more-button-border-enabled-md, var(--gwp-gallery-pagination-load-more-button-enabled, var(--gwp-gallery-pagination-load-more-button-border-enabled, var(--gwp-gallery-pagination-load-more-button-border-style-2xl, solid)))))))))));
        border-width: var(--gwp-gallery-pagination-load-more-button-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-width-enabled, var(--gwp-gallery-pagination-load-more-button-border-width-2xl, var(--gwp-gallery-pagination-load-more-button-border-width, var(--gwp-gallery-pagination-load-more-button-border-width-xl, 1px))))));
        border-radius: var(--gwp-gallery-pagination-load-more-button-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-enabled-dim, var(--gwp-gallery-pagination-load-more-button-border-radius-enabled, var(--gwp-gallery-pagination-load-more-button-border-radius-2xl, var(--gwp-gallery-pagination-load-more-button-border-radius, var(--gwp-gallery-pagination-load-more-button-border-radius-xl, 20px))))));
    }
}

/* Note: Visibility is now handled by DOM injection + data-has-more for btn state */
.gwp-gallery[data-has-more="false"] .gwp-gallery__pagination-btn-load_more {
    display: none;
}

.gwp-gallery__pagination-btn-load_more:hover {
    background: var(--gwp-design-tokens-colors-brand-dark, #005a87);
    transform: translateY(-3px);
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

.gwp-gallery__pagination-load_more.is-loading .gwp-gallery__pagination-btn-load_more {
    opacity: 0.7;
    pointer-events: none;
    cursor: wait;
}

/* Infinite Scroll Loader */
.gwp-gallery__pagination-infinite_scroll {
    display: flex;
    flex-direction: column;
    width: 100%;
    margin: var(--gwp-gallery-pagination-infinite-scroll-margin, 0);
    padding: var(--gwp-gallery-pagination-infinite-scroll-padding, 0);
    text-align: var(--gwp-gallery-pagination-infinite-scroll-align, center);
}

.gwp-gallery__pagination-loader {
    display: inline-block;
    margin: var(--gwp-gallery-pagination-infinite-scroll-loader-margin, 0);
    padding: var(--gwp-gallery-pagination-infinite-scroll-loader-padding, 0);
}

/* ==========================================================================
   STATS & COUNTER
   ========================================================================== */

/* Stats Container - Handles its own internal templates */
.gwp-gallery__stats {
    display: flex;
    flex-direction: column;
    width: var(--gwp-gallery-stats-width, 100%);
    margin: var(--gwp-gallery-stats-margin, 0 0 20px 0);
    padding: var(--gwp-gallery-stats-padding, 0);
    justify-content: center;
}

.gwp-gallery__pagination-counter {
    /* Responsive Typography */
    font-family: var(--gwp-gallery-pagination-gallery-pagination-counter-font, var(--gwp-design-tokens-fonts-primary, sans-serif));
    color: var(--gwp-gallery-pagination-gallery-pagination-counter-color, #666);
    line-height: var(--gwp-gallery-pagination-gallery-pagination-counter-line-height, 1.4);
    letter-spacing: var(--gwp-gallery-pagination-gallery-pagination-counter-letter-spacing, normal);
    text-transform: var(--gwp-gallery-pagination-gallery-pagination-counter-text-transform, none);

    /* Alignment & Spacing */
    text-align: var(--gwp-gallery-pagination-gallery-pagination-counter-align, center);
    margin: var(--gwp-gallery-pagination-gallery-pagination-counter-margin, 0);
    padding: var(--gwp-gallery-pagination-gallery-pagination-counter-padding, 0);

    /* Default sizes (will be overridden by BP variables if JS/CSS adds them to :root or .gwp-gallery) */
    font-size: var(--gwp-counter-font-size, 1rem);
    font-weight: var(--gwp-counter-font-weight, 600);
}

/* Mapping Responsive Counter Vars */
.gwp-gallery {
    --gwp-counter-font-size: var(--gwp-gallery-pagination-gallery-pagination-counter-font-size-2xl, 1rem);
    --gwp-counter-font-weight: var(--gwp-gallery-pagination-gallery-pagination-counter-font-weight-2xl, 600);
}

@media (max-width: 1536px) {
    .gwp-gallery {
        --gwp-counter-font-size: var(--gwp-gallery-pagination-gallery-pagination-counter-font-size-xl, 1rem);
        --gwp-counter-font-weight: var(--gwp-gallery-pagination-gallery-pagination-counter-font-weight-xl, 600);
    }
}

@media (max-width: 1280px) {
    .gwp-gallery {
        --gwp-counter-font-size: var(--gwp-gallery-pagination-gallery-pagination-counter-font-size-lg, 1rem);
        --gwp-counter-font-weight: var(--gwp-gallery-pagination-gallery-pagination-counter-font-weight-lg, 600);
    }
}

@media (max-width: 1024px) {
    .gwp-gallery {
        --gwp-counter-font-size: var(--gwp-gallery-pagination-gallery-pagination-counter-font-size-md, 1rem);
        --gwp-counter-font-weight: var(--gwp-gallery-pagination-gallery-pagination-counter-font-weight-md, 600);
    }
}

@media (max-width: 768px) {
    .gwp-gallery {
        --gwp-counter-font-size: var(--gwp-gallery-pagination-gallery-pagination-counter-font-size-sm, 1rem);
        --gwp-counter-font-weight: var(--gwp-gallery-pagination-gallery-pagination-counter-font-weight-sm, 600);
    }
}

/* Numbered Pagination */
.gwp-gallery__pagination-numbers {
    display: flex;
    align-items: center;
    justify-content: var(--gwp-gallery-pagination-numbers-align, center);
    gap: 10px;
    width: 100%;
}

.gwp-gallery__pagination-numbers .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 45px;
    height: 45px;
    padding: 0 15px;
    border-radius: 8px;
    background: #fff;
    border: 1px solid #eee;
    color: #333;
    text-decoration: none;
    font-weight: 600;
    transition: all 0.2s ease;
}

.gwp-gallery__pagination-numbers .page-numbers:hover {
    border-color: var(--gwp-design-tokens-colors-brand, #0073aa);
    color: var(--gwp-design-tokens-colors-brand, #0073aa);
}

.gwp-gallery__pagination-numbers .page-numbers.current {
    background: var(--gwp-design-tokens-colors-brand, #0073aa);
    color: #fff;
    border-color: var(--gwp-design-tokens-colors-brand, #0073aa);
}

.gwp-a11y-announcer {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}