/* -------------------------------------------------
   FEATURED SECTION (První 3 fotky)
   ------------------------------------------------- */

/* Base featured container */
.mucha-gallery-featured {
    margin-bottom: 30px; /* Default, overridden by data attribute */
    padding: 10px;
    box-sizing: border-box;
}

/* Dynamic margin-bottom via data attribute (0-100px in 5px steps) */
[data-mg-featured-margin="0"] .mucha-gallery-featured { margin-bottom: 0px; }
[data-mg-featured-margin="5"] .mucha-gallery-featured { margin-bottom: 5px; }
[data-mg-featured-margin="10"] .mucha-gallery-featured { margin-bottom: 10px; }
[data-mg-featured-margin="15"] .mucha-gallery-featured { margin-bottom: 15px; }
[data-mg-featured-margin="20"] .mucha-gallery-featured { margin-bottom: 20px; }
[data-mg-featured-margin="25"] .mucha-gallery-featured { margin-bottom: 25px; }
[data-mg-featured-margin="30"] .mucha-gallery-featured { margin-bottom: 30px; }
[data-mg-featured-margin="35"] .mucha-gallery-featured { margin-bottom: 35px; }
[data-mg-featured-margin="40"] .mucha-gallery-featured { margin-bottom: 40px; }
[data-mg-featured-margin="45"] .mucha-gallery-featured { margin-bottom: 45px; }
[data-mg-featured-margin="50"] .mucha-gallery-featured { margin-bottom: 50px; }
[data-mg-featured-margin="60"] .mucha-gallery-featured { margin-bottom: 60px; }
[data-mg-featured-margin="70"] .mucha-gallery-featured { margin-bottom: 70px; }
[data-mg-featured-margin="80"] .mucha-gallery-featured { margin-bottom: 80px; }
[data-mg-featured-margin="90"] .mucha-gallery-featured { margin-bottom: 90px; }
[data-mg-featured-margin="100"] .mucha-gallery-featured { margin-bottom: 100px; }

/* Top/Under layout (default) - Large nahoře na celou šířku, 2 small pod ním */
[data-mg-featured-variant="top"] .mucha-gallery-featured {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    gap: 15px;
}

[data-mg-featured-variant="top"] .mg-featured-big {
    grid-column: 1 / 3;
    grid-row: 1;
}

[data-mg-featured-variant="top"] .mg-featured-small {
    grid-row: 2;
}

[data-mg-featured-variant="top"] .mg-featured-small:first-of-type {
    grid-column: 1;
}

[data-mg-featured-variant="top"] .mg-featured-small:last-of-type {
    grid-column: 2;
}

/* Left/Right layout - Large vlevo přes celou výšku, 2 small vpravo nad sebou */
[data-mg-featured-variant="left"] .mucha-gallery-featured {
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 15px;
}

[data-mg-featured-variant="left"] .mg-featured-big {
    grid-row: 1 / 3;
    grid-column: 1;
}

[data-mg-featured-variant="left"] .mg-featured-small {
    grid-column: 2;
}

/* Inline row layout - všechny 3 vedle sebe */
[data-mg-featured-variant="inline"] .mucha-gallery-featured {
    display: flex;
    flex-direction: row;
    gap: 15px;
}

[data-mg-featured-variant="inline"] .mg-featured-big,
[data-mg-featured-variant="inline"] .mg-featured-small {
    flex: 1;
}

/* Disabled - hide featured */
[data-mg-featured-variant="disabled"] .mucha-gallery-featured {
    display: none;
}

/* Responzivní layout pro mobily */
@media screen and (max-width: 768px) {
    /* Mobile: všechny layouty jako column */
    [data-mg-featured-variant="top"] .mucha-gallery-featured,
    [data-mg-featured-variant="left"] .mucha-gallery-featured,
    [data-mg-featured-variant="inline"] .mucha-gallery-featured {
        display: flex;
        flex-direction: column;
        gap: 15px;
    }

    [data-mg-featured-variant="top"] .mg-featured-big,
    [data-mg-featured-variant="top"] .mg-featured-small,
    [data-mg-featured-variant="left"] .mg-featured-big,
    [data-mg-featured-variant="left"] .mg-featured-small {
        grid-column: auto;
        grid-row: auto;
    }
}

/* -------------------------------------------------
   GALLERY LAYOUT - WIDTH
   ------------------------------------------------- */

/* Default width - overridden by inline style */
.mucha-gallery-wrapper {
    width: 100%;
    max-width: 100%;
}

/* -------------------------------------------------
   GRID SECTION (4. fotka dál)
   ------------------------------------------------- */
.mucha-gallery-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* Default, overridden by responsive breakpoints */
    gap: 15px;
    padding: 10px;
}

/* When Masonry.js is enabled, disable CSS Grid and let Masonry handle the layout */
[data-mg-masonry-mode="masonry_js"] .mucha-gallery-grid {
    display: block;
    width: calc(100% - 20px); /* Subtract featured section padding to align content */
    padding: 0; /* No padding - Masonry handles layout */
    margin: 10px; /* Match featured section padding visually */
    box-sizing: border-box;
}

[data-mg-masonry-mode="masonry_js"] .mucha-gallery-grid .mg-item {
    width: calc((100% - 45px) / 4); /* 4 columns: (container - 3 gutters of 15px) / 4 */
    margin-right: 0; /* Set via JS to 15px */
    margin-bottom: 0; /* Set via JS to 15px */
    box-sizing: border-box;
}

/* -------------------------------------------------
   RESPONSIVE COLUMNS - DESKTOP (≥1200px)
   ------------------------------------------------- */
@media (min-width: 1200px) {
    [data-mg-columns-desktop="1"] .mucha-gallery-grid {
        grid-template-columns: repeat(1, 1fr);
    }

    [data-mg-columns-desktop="2"] .mucha-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    [data-mg-columns-desktop="3"] .mucha-gallery-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    [data-mg-columns-desktop="4"] .mucha-gallery-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    [data-mg-columns-desktop="5"] .mucha-gallery-grid {
        grid-template-columns: repeat(5, 1fr);
    }

    [data-mg-columns-desktop="6"] .mucha-gallery-grid {
        grid-template-columns: repeat(6, 1fr);
    }

    /* Masonry mode - width calculation (gutters via CSS margins) */
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop="1"] .mucha-gallery-grid .mg-item {
        width: 100%; /* 1 column: no gutters */
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop="2"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 15px) / 2); /* 2 columns: 1 gutter */
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop="2"] .mucha-gallery-grid .mg-item:nth-child(2n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop="3"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 30px) / 3); /* 3 columns: 2 gutters */
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop="3"] .mucha-gallery-grid .mg-item:nth-child(3n) {
        margin-right: 0 !important; /* Remove margin from every 3rd item */
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop="4"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 45px) / 4); /* 4 columns: 3 gutters */
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop="4"] .mucha-gallery-grid .mg-item:nth-child(4n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop="5"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 60px) / 5); /* 5 columns: 4 gutters */
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop="5"] .mucha-gallery-grid .mg-item:nth-child(5n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop="6"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 75px) / 6); /* 6 columns: 5 gutters */
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop="6"] .mucha-gallery-grid .mg-item:nth-child(6n) {
        margin-right: 0 !important;
    }
}

/* -------------------------------------------------
   RESPONSIVE COLUMNS - DESKTOP-MID (900-1199px)
   ------------------------------------------------- */
@media (min-width: 900px) and (max-width: 1199px) {
    [data-mg-columns-desktop-mid="1"] .mucha-gallery-grid {
        grid-template-columns: repeat(1, 1fr);
    }

    [data-mg-columns-desktop-mid="2"] .mucha-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    [data-mg-columns-desktop-mid="3"] .mucha-gallery-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    [data-mg-columns-desktop-mid="4"] .mucha-gallery-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    [data-mg-columns-desktop-mid="5"] .mucha-gallery-grid {
        grid-template-columns: repeat(5, 1fr);
    }

    [data-mg-columns-desktop-mid="6"] .mucha-gallery-grid {
        grid-template-columns: repeat(6, 1fr);
    }

    /* Masonry mode - width calculation (gutters via CSS margins) */
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop-mid="1"] .mucha-gallery-grid .mg-item {
        width: 100%;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop-mid="2"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 15px) / 2);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop-mid="2"] .mucha-gallery-grid .mg-item:nth-child(2n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop-mid="3"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 30px) / 3);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop-mid="3"] .mucha-gallery-grid .mg-item:nth-child(3n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop-mid="4"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 45px) / 4);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop-mid="4"] .mucha-gallery-grid .mg-item:nth-child(4n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop-mid="5"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 60px) / 5);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop-mid="5"] .mucha-gallery-grid .mg-item:nth-child(5n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop-mid="6"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 75px) / 6);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-desktop-mid="6"] .mucha-gallery-grid .mg-item:nth-child(6n) {
        margin-right: 0 !important;
    }
}

/* -------------------------------------------------
   RESPONSIVE COLUMNS - TABLET (600-899px)
   ------------------------------------------------- */
@media (min-width: 600px) and (max-width: 899px) {
    [data-mg-columns-tablet="1"] .mucha-gallery-grid {
        grid-template-columns: repeat(1, 1fr);
    }

    [data-mg-columns-tablet="2"] .mucha-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    [data-mg-columns-tablet="3"] .mucha-gallery-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    [data-mg-columns-tablet="4"] .mucha-gallery-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    [data-mg-columns-tablet="5"] .mucha-gallery-grid {
        grid-template-columns: repeat(5, 1fr);
    }

    [data-mg-columns-tablet="6"] .mucha-gallery-grid {
        grid-template-columns: repeat(6, 1fr);
    }

    /* Masonry mode - width calculation (gutters via CSS margins) */
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-tablet="1"] .mucha-gallery-grid .mg-item {
        width: 100%;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-tablet="2"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 15px) / 2);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-tablet="2"] .mucha-gallery-grid .mg-item:nth-child(2n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-tablet="3"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 30px) / 3);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-tablet="3"] .mucha-gallery-grid .mg-item:nth-child(3n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-tablet="4"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 45px) / 4);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-tablet="4"] .mucha-gallery-grid .mg-item:nth-child(4n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-tablet="5"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 60px) / 5);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-tablet="5"] .mucha-gallery-grid .mg-item:nth-child(5n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-tablet="6"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 75px) / 6);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-tablet="6"] .mucha-gallery-grid .mg-item:nth-child(6n) {
        margin-right: 0 !important;
    }
}

/* -------------------------------------------------
   RESPONSIVE COLUMNS - MOBILE (<600px)
   ------------------------------------------------- */
@media (max-width: 599px) {
    [data-mg-columns-mobile="1"] .mucha-gallery-grid {
        grid-template-columns: repeat(1, 1fr);
    }

    [data-mg-columns-mobile="2"] .mucha-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    [data-mg-columns-mobile="3"] .mucha-gallery-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    [data-mg-columns-mobile="4"] .mucha-gallery-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    [data-mg-columns-mobile="5"] .mucha-gallery-grid {
        grid-template-columns: repeat(5, 1fr);
    }

    [data-mg-columns-mobile="6"] .mucha-gallery-grid {
        grid-template-columns: repeat(6, 1fr);
    }

    /* Masonry mode - width calculation (gutters via CSS margins) */
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-mobile="1"] .mucha-gallery-grid .mg-item {
        width: 100%;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-mobile="2"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 15px) / 2);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-mobile="2"] .mucha-gallery-grid .mg-item:nth-child(2n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-mobile="3"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 30px) / 3);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-mobile="3"] .mucha-gallery-grid .mg-item:nth-child(3n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-mobile="4"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 45px) / 4);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-mobile="4"] .mucha-gallery-grid .mg-item:nth-child(4n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-mobile="5"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 60px) / 5);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-mobile="5"] .mucha-gallery-grid .mg-item:nth-child(5n) {
        margin-right: 0 !important;
    }

    [data-mg-masonry-mode="masonry_js"][data-mg-columns-mobile="6"] .mucha-gallery-grid .mg-item {
        width: calc((100% - 75px) / 6);
    }
    [data-mg-masonry-mode="masonry_js"][data-mg-columns-mobile="6"] .mucha-gallery-grid .mg-item:nth-child(6n) {
        margin-right: 0 !important;
    }
}

.mg-item {
    position: relative;
}

.mg-image-wrapper {
    position: relative;
    overflow: hidden;
    border-radius: 0px; /* Default, overridden by data attribute */
}

/* position:absolute makes img fill the wrapper regardless of
   Elementor's .elementor img { height:auto } override.
   The wrapper's size comes from aspect-ratio, not from img flow. */
.mucha-gallery-wrapper .mg-image-wrapper img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    cursor: pointer;
    transition: transform 0.2s ease;
    object-fit: cover;
}

/* Fill box setting - contain mode (no crop) */
[data-mg-fill-box="0"] .mg-image-wrapper img {
    object-fit: contain;
    background-color: #f5f5f5;
}

/* -------------------------------------------------
   CORNER RADIUS (0-24px)
   ------------------------------------------------- */
[data-mg-corner-radius="0"] .mg-image-wrapper {
    border-radius: 0px;
}

[data-mg-corner-radius="1"] .mg-image-wrapper {
    border-radius: 1px;
}

[data-mg-corner-radius="2"] .mg-image-wrapper {
    border-radius: 2px;
}

[data-mg-corner-radius="3"] .mg-image-wrapper {
    border-radius: 3px;
}

[data-mg-corner-radius="4"] .mg-image-wrapper {
    border-radius: 4px;
}

[data-mg-corner-radius="5"] .mg-image-wrapper {
    border-radius: 5px;
}

[data-mg-corner-radius="6"] .mg-image-wrapper {
    border-radius: 6px;
}

[data-mg-corner-radius="7"] .mg-image-wrapper {
    border-radius: 7px;
}

[data-mg-corner-radius="8"] .mg-image-wrapper {
    border-radius: 8px;
}

[data-mg-corner-radius="9"] .mg-image-wrapper {
    border-radius: 9px;
}

[data-mg-corner-radius="10"] .mg-image-wrapper {
    border-radius: 10px;
}

[data-mg-corner-radius="11"] .mg-image-wrapper {
    border-radius: 11px;
}

[data-mg-corner-radius="12"] .mg-image-wrapper {
    border-radius: 12px;
}

[data-mg-corner-radius="13"] .mg-image-wrapper {
    border-radius: 13px;
}

[data-mg-corner-radius="14"] .mg-image-wrapper {
    border-radius: 14px;
}

[data-mg-corner-radius="15"] .mg-image-wrapper {
    border-radius: 15px;
}

[data-mg-corner-radius="16"] .mg-image-wrapper {
    border-radius: 16px;
}

[data-mg-corner-radius="17"] .mg-image-wrapper {
    border-radius: 17px;
}

[data-mg-corner-radius="18"] .mg-image-wrapper {
    border-radius: 18px;
}

[data-mg-corner-radius="19"] .mg-image-wrapper {
    border-radius: 19px;
}

[data-mg-corner-radius="20"] .mg-image-wrapper {
    border-radius: 20px;
}

[data-mg-corner-radius="21"] .mg-image-wrapper {
    border-radius: 21px;
}

[data-mg-corner-radius="22"] .mg-image-wrapper {
    border-radius: 22px;
}

[data-mg-corner-radius="23"] .mg-image-wrapper {
    border-radius: 23px;
}

[data-mg-corner-radius="24"] .mg-image-wrapper {
    border-radius: 24px;
}

/* -------------------------------------------------
   CORNER RADIUS ON PARENT CONTAINERS
   Featured big/small and grid items need overflow:hidden
   + border-radius on the parent to ensure proper clipping,
   especially in CSS Grid layouts.
   ------------------------------------------------- */
.mg-featured-big,
.mg-featured-small,
.mg-item {
    overflow: hidden;
    border-radius: var(--mg-corner-radius, 0px);
}

/* -------------------------------------------------
   SQUIRCLE (SUPERELLIPSE) CORNER STYLE
   Applied via CSS mask-image with SVG data URI.
   JS generates the mask and sets --mg-squircle-mask.
   border-radius remains as fallback.
   ------------------------------------------------- */
/* Squircle mask only on .mg-image-wrapper (not parent containers)
   to avoid double-masking that crops featured-big bottom */

[data-mg-corner-style="squircle"] .mg-image-wrapper {
    -webkit-mask-image: var(--mg-squircle-mask);
    mask-image: var(--mg-squircle-mask);
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
}

/* -------------------------------------------------
   ASPECT RATIOS
   ------------------------------------------------- */

/* Grid thumbnails - dynamic aspect ratio */
.mucha-gallery-grid .mg-image-wrapper {
    aspect-ratio: 4 / 3; /* Default */
}

/* Grid aspect ratios from settings */
[data-mg-grid-ratio="16:9"] .mucha-gallery-grid .mg-image-wrapper {
    aspect-ratio: 16 / 9;
}

[data-mg-grid-ratio="4:3"] .mucha-gallery-grid .mg-image-wrapper {
    aspect-ratio: 4 / 3;
}

[data-mg-grid-ratio="1:1"] .mucha-gallery-grid .mg-image-wrapper {
    aspect-ratio: 1 / 1;
}

[data-mg-grid-ratio="3:2"] .mucha-gallery-grid .mg-image-wrapper {
    aspect-ratio: 3 / 2;
}

[data-mg-grid-ratio="21:9"] .mucha-gallery-grid .mg-image-wrapper {
    aspect-ratio: 21 / 9;
}

/* When Masonry.js is enabled, use original image proportions (no aspect-ratio) */
[data-mg-masonry-mode="masonry_js"] .mucha-gallery-grid .mg-image-wrapper {
    aspect-ratio: auto !important;
}

[data-mg-masonry-mode="masonry_js"] .mucha-gallery-grid .mg-image-wrapper img {
    position: static;
    height: auto;
}

/* Featured large thumbnail */
.mucha-gallery-featured .mg-featured-big .mg-image-wrapper {
    aspect-ratio: 16 / 9; /* Default */
}

[data-mg-featured-large-ratio="16:9"] .mucha-gallery-featured .mg-featured-big .mg-image-wrapper {
    aspect-ratio: 16 / 9;
}

[data-mg-featured-large-ratio="4:3"] .mucha-gallery-featured .mg-featured-big .mg-image-wrapper {
    aspect-ratio: 4 / 3;
}

[data-mg-featured-large-ratio="1:1"] .mucha-gallery-featured .mg-featured-big .mg-image-wrapper {
    aspect-ratio: 1 / 1;
}

[data-mg-featured-large-ratio="3:2"] .mucha-gallery-featured .mg-featured-big .mg-image-wrapper {
    aspect-ratio: 3 / 2;
}

[data-mg-featured-large-ratio="21:9"] .mucha-gallery-featured .mg-featured-big .mg-image-wrapper {
    aspect-ratio: 21 / 9;
}

/* Featured small thumbnails */
.mucha-gallery-featured .mg-featured-small .mg-image-wrapper {
    aspect-ratio: 4 / 3; /* Default */
}

[data-mg-featured-small-ratio="16:9"] .mucha-gallery-featured .mg-featured-small .mg-image-wrapper {
    aspect-ratio: 16 / 9;
}

[data-mg-featured-small-ratio="4:3"] .mucha-gallery-featured .mg-featured-small .mg-image-wrapper {
    aspect-ratio: 4 / 3;
}

[data-mg-featured-small-ratio="1:1"] .mucha-gallery-featured .mg-featured-small .mg-image-wrapper {
    aspect-ratio: 1 / 1;
}

[data-mg-featured-small-ratio="3:2"] .mucha-gallery-featured .mg-featured-small .mg-image-wrapper {
    aspect-ratio: 3 / 2;
}

/* -------------------------------------------------
   ASPECT RATIO ADJUSTMENTS WITH GAP
   ------------------------------------------------- */

/*
   Left/Right layout: Large thumbnail height = 2 × small height + gap
   Small thumbnails need to be sized so: height_small = (height_large - gap) / 2

   Top/Under layout: Large thumbnail width = 2 × small width + gap
   Small thumbnails automatically fill 50% each in grid
*/

/* Left/Right: Výška 2 small + gap = výška large */
[data-mg-featured-variant="left"] .mucha-gallery-featured .mg-featured-small .mg-image-wrapper {
    /* Každý small má poloviční výšku large mínus polovina gap */
    height: calc((100% - 15px) / 2);
}

/* Top/Under: Šířka 2 small + gap = šířka large (grid se o to postará automaticky) */
/* Grid se o správné proporce postará sám díky grid-template-columns: 1fr 1fr */

.mg-image-wrapper img:hover {
    transform: scale(1.02);
}

.mg-rating-overlay {
    position: absolute;
    bottom: 8px;
    left: 8px;
    right: 8px;
    padding: 6px 8px;
    background: rgba(0,0,0,0.6);
    border-radius: 6px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 8px;
    opacity: 0;
    transform: translateY(8px);
    transition: all 0.25s ease;
    pointer-events: auto;
}

.mg-rating-display {
    color: #ffffff;
    font-size: 12px;
    font-weight: 600;
}

.mg-rating-stars {
    display: flex;
    justify-content: center;
    gap: 4px;
}

/* Desktop hover - grid items */
.mg-item:hover .mg-rating-overlay {
    opacity: 1;
    transform: translateY(0);
}

/* Desktop hover - featured items */
.mg-featured-big:hover .mg-rating-overlay,
.mg-featured-small:hover .mg-rating-overlay {
    opacity: 1;
    transform: translateY(0);
}

/* Mobile/Touch - vždy viditelný */
@media (hover: none) and (pointer: coarse) {
    .mg-rating-overlay {
        opacity: 1;
        transform: translateY(0);
    }
}

.mg-rating-stars span {
    color: #ffd95c;
    font-size: 16px;
    cursor: pointer;
    transition: transform .15s ease;
    opacity: 0.3;
}

.mg-rating-stars span.mg-star-filled {
    opacity: 1;
    color: #ffd700;
}

.mg-rating-stars span:hover {
    transform: scale(1.25);
}

.mg-rated {
    pointer-events: none;
    background: rgba(102, 126, 234, 0.5);
}

.mg-rated span.mg-star-filled {
    opacity: 1 !important;
    color: #ffd700;
    text-shadow: 0 0 8px rgba(255, 215, 0, 0.6);
}

.mucha-gallery-loader {
    text-align: center;
    padding: 20px;
    font-size: 16px;
    opacity: 0.7;
}

.mg-rating-overlay {
    z-index: 10;
}


/* -------------------------------------------------
   FILTER BAR & SORTING
   ------------------------------------------------- */
.mg-filter-bar {
    display: flex;
    gap: 20px;
    align-items: center;
    margin-bottom: 30px;
    padding: 15px;
    background: #f5f5f5;
    border-radius: 8px;
}

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

.mg-filter-group label {
    font-size: 14px;
    font-weight: 500;
    color: #333;
    margin: 0;
}

#mg-event-filter,
#mg-sort-filter {
    padding: 8px 12px;
    border: 2px solid #ddd;
    border-radius: 6px;
    font-size: 14px;
    background: #ffffff;
    cursor: pointer;
    transition: border-color 0.2s ease;
    min-width: 180px;
}

#mg-event-filter:hover,
#mg-event-filter:focus,
#mg-sort-filter:hover,
#mg-sort-filter:focus {
    border-color: #999;
    outline: none;
}

/* -------------------------------------------------
   EVENT DESCRIPTION
   ------------------------------------------------- */
.mg-event-description {
    padding: 12px 15px;
    line-height: 1.6;
    word-wrap: break-word;
}
.mg-event-description p { margin: 0 0 0.5em 0; }
.mg-event-description p:last-child { margin-bottom: 0; }

/* Sticky Filter Bar */
.mg-filter-bar--sticky {
    position: sticky;
    top: var(--mg-filter-sticky-offset, 0px);
    z-index: var(--mg-filter-z-index, 100);
    background: var(--mg-filter-bg-color, #f5f5f5);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    margin-left: -15px;
    margin-right: -15px;
    padding-left: 30px;
    padding-right: 30px;
    border-radius: 0;
    transition: box-shadow 0.2s ease;
}

/* When sticky is active and scrolled */
.mg-filter-bar--sticky.mg-filter-bar--scrolled {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Responzivní layout pro menší obrazovky */
@media screen and (max-width: 600px) {
    .mg-filter-bar {
        flex-direction: column;
        gap: 12px;
        align-items: stretch;
    }

    .mg-filter-group {
        flex-direction: column;
        align-items: flex-start;
        gap: 6px;
    }

    #mg-event-filter,
    #mg-sort-filter {
        width: 100%;
    }

    /* Sticky on mobile - full width */
    .mg-filter-bar--sticky {
        margin-left: -10px;
        margin-right: -10px;
        padding-left: 20px;
        padding-right: 20px;
    }
}


/* -------------------------------------------------
   TOAST NOTIFICATIONS
   ------------------------------------------------- */
.mg-toast {
    position: fixed;
    bottom: 30px;
    right: 30px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: #ffffff;
    padding: 16px 24px;
    border-radius: 12px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
    font-size: 15px;
    font-weight: 500;
    z-index: 9999;
    display: flex;
    align-items: center;
    gap: 10px;
    opacity: 0;
    transform: translateY(20px);
    animation: mg-toast-in 0.3s ease forwards;
}

.mg-toast.mg-toast-success {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}

.mg-toast.mg-toast-error {
    background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
}

.mg-toast.mg-toast-out {
    animation: mg-toast-out 0.3s ease forwards;
}

@keyframes mg-toast-in {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes mg-toast-out {
    to {
        opacity: 0;
        transform: translateY(20px);
    }
}

/* Responzivní toast na mobilech */
@media screen and (max-width: 600px) {
    .mg-toast {
        bottom: 20px;
        right: 20px;
        left: 20px;
        text-align: center;
    }
}


/* -------------------------------------------------
   PAGINATION CONTROLS
   ------------------------------------------------- */
.mucha-gallery-pagination {
    display: flex;
    justify-content: center;
    padding: 30px 10px;
}

.mg-pagination-inner {
    display: flex;
    gap: 8px;
    align-items: center;
}

.mg-page-btn {
    min-width: 40px;
    height: 40px;
    padding: 8px 12px;
    border: 1px solid #ddd;
    background: #fff;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.2s ease;
}

.mg-page-btn:hover {
    border-color: #999;
    background: #f5f5f5;
}

.mg-page-btn.mg-page-active {
    background: #667eea;
    border-color: #667eea;
    color: #fff;
    cursor: default;
}

.mg-page-btn.mg-page-active:hover {
    background: #667eea;
}

.mg-page-prev,
.mg-page-next {
    font-weight: 600;
}

.mg-page-dots {
    padding: 0 8px;
    color: #999;
}

/* Load More button */
.mucha-gallery-loadmore {
    text-align: center;
    padding: 30px 10px;
}

.mg-loadmore-btn {
    min-width: 150px;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.mg-loadmore-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.mg-loadmore-btn:active {
    transform: translateY(0);
}

@media screen and (max-width: 600px) {
    .mg-page-btn {
        min-width: 36px;
        height: 36px;
        padding: 6px 10px;
        font-size: 13px;
    }

    .mg-pagination-inner {
        gap: 6px;
    }
}

/* -------------------------------------------------
   PHOTOSWIPE LIGHTBOX RATING PANEL
   ------------------------------------------------- */
.pswp__rating-panel {
    position: fixed;
    top: 80px;
    bottom: auto;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1100;
    pointer-events: auto;
}

.pswp__rating-overlay {
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(10px);
    padding: 8px 16px;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    gap: 12px;
    transition: all 0.3s ease;
}

.pswp__rating-overlay:hover {
    background: rgba(0, 0, 0, 0.75);
    box-shadow: 0 6px 25px rgba(0, 0, 0, 0.4);
}

.pswp__rating-display {
    font-size: 14px;
    font-weight: 600;
    color: #ffffff;
    min-width: 40px;
    text-align: center;
}

.pswp__rating-stars {
    display: flex;
    gap: 4px;
}

.pswp__rating-star {
    font-size: 24px;
    color: #ddd;
    cursor: pointer;
    transition: all 0.2s ease;
    user-select: none;
    opacity: 0.3;
}

.pswp__rating-star:hover {
    transform: scale(1.2);
    opacity: 1;
}

.pswp__rating-star.mg-star-filled {
    color: #ffd700;
    opacity: 1;
    text-shadow: 0 0 8px rgba(255, 215, 0, 0.6);
}

/* Already rated state */
.pswp__rating-rated {
    background: rgba(102, 126, 234, 0.6) !important;
}

.pswp__rating-rated .pswp__rating-star {
    cursor: not-allowed;
}

.pswp__rating-rated .pswp__rating-star:hover {
    transform: none;
}

/* Mobile responsive */
@media screen and (max-width: 600px) {
    .pswp__rating-panel {
        bottom: 60px; /* Move up to avoid controls */
    }

    .pswp__rating-overlay {
        padding: 10px 16px;
        gap: 8px;
    }

    .pswp__rating-star {
        font-size: 20px;
    }

    .pswp__rating-display {
        font-size: 12px;
        min-width: 35px;
    }
}

/* -------------------------------------------------
   PHOTOSWIPE DOWNLOAD BUTTON
   ------------------------------------------------- */

.pswp__button--download-button {
    display: flex !important;
    align-items: center;
    justify-content: center;
}

/* -------------------------------------------------
   PHOTOSWIPE CURSOR STYLES
   ------------------------------------------------- */

/* Prevent image drag (download via drag) */
.pswp__img {
    -webkit-user-drag: none;
    user-drag: none;
    -webkit-user-select: none;
    user-select: none;
    pointer-events: auto;
}

/* Background (outside image) - arrow cursor, clickable to close */
.pswp__container {
    cursor: default;
}

/* Default state for image - arrow cursor (no zoom available / non-zoomable) */
.pswp__img {
    cursor: default;
}

/* When zoom is available - zoom in cursor (magnifying glass) */
.pswp--zoom-allowed .pswp__img {
    cursor: zoom-in;
}

/* When zoomed in - zoom out cursor */
.pswp--zoomed-in .pswp__img {
    cursor: zoom-out;
}

/* When image is zoomed and can be panned - move cursor */
.pswp--zoomed-in.pswp--allow-pan .pswp__img {
    cursor: move;
}

/* When actively dragging/panning zoomed image */
.pswp--zoomed-in.pswp--allow-pan .pswp__img:active {
    cursor: grabbing;
}

/* -------------------------------------------------
   PHOTOSWIPE BUTTON FIXES
   Fix Elementor/theme global button styles that override PhotoSwipe:
   [type=button], button { border: 1px solid #c36; padding: .5rem 1rem; }
   ------------------------------------------------- */
.pswp__button {
    padding: 0 !important;
    width: 50px !important;
    height: 60px !important;
    border: none !important;
    border-radius: 0 !important;
    background-color: transparent !important;
    color: inherit !important;
}

.pswp__button:hover,
.pswp__button:focus,
.pswp__button:active {
    padding: 0 !important;
    width: 50px !important;
    height: 60px !important;
    border: none !important;
    background-color: transparent !important;
}

