/* ===== Sima Gallery Pro - Frontend ===== */

.sgp-gallery {
    --sgp-col-gap: 20px;
    --sgp-row-gap: 20px;

    --sgp-item-width: 360px;
    --sgp-item-height: 520px;

    --sgp-fit-grid: cover;
    --sgp-fit-masonry: cover;
    --sgp-fit-slider: contain;

    --sgp-font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    --sgp-font-size: 16px;
    --sgp-text-color: #222;
    --sgp-overlay-bg: rgba(255, 255, 255, .65);

    --sgp-overlay-pad-x: 20px;
    --sgp-overlay-pad-y: 10px;
    --sgp-overlay-pad-top: var(--sgp-overlay-pad-y);
    --sgp-overlay-pad-right: var(--sgp-overlay-pad-x);
    --sgp-overlay-pad-bottom: var(--sgp-overlay-pad-y);
    --sgp-overlay-pad-left: var(--sgp-overlay-pad-x);
    --sgp-global-text-pad-top: 18px;
    --sgp-global-text-pad-right: 18px;
    --sgp-global-text-pad-bottom: 18px;
    --sgp-global-text-pad-left: 18px;
    --sgp-overlay-radius: 10px;
    --sgp-overlay-speed: 220ms;

    --sgp-text-max-ch: 50;
    --sgp-text-align: center;
    --sgp-text-weight: 400;
    --sgp-text-style: normal;

    --sgp-image-radius: 0px;
    --sgp-media-bg: transparent;

    --sgp-nav-size: 44px;
    --sgp-nav-bg: rgba(255, 255, 255, .85);
    --sgp-nav-color: #222;
    --sgp-nav-radius: 999px;
    --sgp-nav-border-w: 1px;
    --sgp-nav-border: rgba(0, 0, 0, .12);

    --sgp-ot-btn-h: 40px;
    --sgp-ot-btn-fs: 12px;
    --sgp-ot-btn-text: #222;
    --sgp-ot-btn-bg: rgba(255, 255, 255, .75);
    --sgp-ot-btn-radius: 999px;
    --sgp-ot-btn-border-w: 1px;
    --sgp-ot-btn-border: rgba(0, 0, 0, .12);

    --sgp-close-size: 34px;
    --sgp-close-bg: rgba(255, 255, 255, .92);
    --sgp-close-color: #222;
    --sgp-close-radius: 999px;
    --sgp-close-border-w: 1px;
    --sgp-close-border: rgba(0, 0, 0, .15);

    margin: 0 !important;
    padding: 0 !important;
    position: relative;
}

.sgp-gallery,
.sgp-gallery * {
    box-sizing: border-box !important;
}

.sgp-gallery figure {
    margin: 0 !important;
    padding: 0 !important;
}

.sgp-gallery,
.sgp-gallery .sgp-grid,
.sgp-gallery .sgp-masonry,
.sgp-gallery .sgp-slider,
.sgp-gallery .sgp-track,
.sgp-gallery .sgp-track-inner,
.sgp-gallery .sgp-slide,
.sgp-gallery .sgp-item,
.sgp-gallery .sgp-media {
    max-width: 100% !important;
}

.sgp-gallery .sgp-grid,
.sgp-gallery .sgp-slider,
.sgp-gallery .sgp-track,
.sgp-gallery .sgp-slide {
    width: 100% !important;
}

/* GRID */
.sgp-gallery .sgp-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--sgp-item-width)), 1fr)) !important;
    column-gap: var(--sgp-col-gap) !important;
    row-gap: var(--sgp-row-gap) !important;
}

/* Fixed column count (optional) */
.sgp-gallery.sgp-cols-fixed .sgp-grid {
    grid-template-columns: repeat(var(--sgp-columns), minmax(0, 1fr)) !important;
}

.sgp-gallery.sgp-cols-fixed.sgp-type-masonry .sgp-masonry {
    column-count: var(--sgp-columns);
    column-width: auto;
}

/* MASONRY */
.sgp-gallery .sgp-masonry {
    column-width: var(--sgp-item-width);
    column-gap: var(--sgp-col-gap);
}

.sgp-gallery .sgp-masonry .sgp-item {
    display: inline-block !important;
    width: 100% !important;
    break-inside: avoid;
    margin: 0 0 var(--sgp-row-gap) 0 !important;
}

/* MEDIA */
.sgp-gallery .sgp-media {
    position: relative !important;
    overflow: hidden !important;
    border-radius: var(--sgp-image-radius) !important;
    background: var(--sgp-media-bg) !important;
}

.sgp-gallery .sgp-img {
    display: block !important;
    user-select: none;
    -webkit-user-drag: none;
}

/* Grid sizing */
.sgp-gallery.sgp-type-grid .sgp-media {
    height: var(--sgp-item-height) !important;
}

.sgp-gallery.sgp-type-grid .sgp-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: var(--sgp-fit-grid) !important;
}

/* Masonry sizing */
.sgp-gallery.sgp-type-masonry .sgp-media {
    height: auto !important;
}

.sgp-gallery.sgp-type-masonry .sgp-img {
    width: 100% !important;
    height: auto !important;
    object-fit: var(--sgp-fit-masonry) !important;
}

/* Slider */
.sgp-gallery .sgp-slider {
    position: relative;
    padding: 0;
}

.sgp-gallery .sgp-track {
    overflow: hidden;
    position: relative;
    width: 100%;
}

.sgp-gallery .sgp-track-inner {
    display: flex;
    transition: transform 240ms ease;
    will-change: transform;
}

.sgp-gallery .sgp-slide {
    flex: 0 0 100%;
    display: flex;
    justify-content: center;
}

.sgp-gallery.sgp-type-slider .sgp-item {
    width: var(--sgp-slider-w, min(var(--sgp-item-width), 92vw));
}

.sgp-gallery.sgp-type-slider .sgp-media {
    height: var(--sgp-slider-h, var(--sgp-item-height)) !important;
}

.sgp-gallery.sgp-type-slider .sgp-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: var(--sgp-fit-slider) !important;
}

/* contain mode: center without upscale */
.sgp-gallery[data-grid-fit="contain"].sgp-type-grid .sgp-media,
.sgp-gallery[data-slider-fit="contain"].sgp-type-slider .sgp-media {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.sgp-gallery[data-grid-fit="contain"].sgp-type-grid .sgp-img,
.sgp-gallery[data-slider-fit="contain"].sgp-type-slider .sgp-img {
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
}

.sgp-gallery[data-masonry-fit="contain"].sgp-type-masonry .sgp-media {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--sgp-media-bg) !important;
}

.sgp-gallery[data-masonry-fit="contain"].sgp-type-masonry .sgp-img {
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    object-fit: contain !important;
}

/* OVERLAY */
.sgp-gallery .sgp-overlay,
.sgp-viewer .sgp-overlay {
    position: absolute !important;
    top: var(--sgp-overlay-pad-top) !important;
    right: var(--sgp-overlay-pad-right) !important;
    bottom: var(--sgp-overlay-pad-bottom) !important;
    left: var(--sgp-overlay-pad-left) !important;
    padding: 0 !important;
    display: flex !important;
    z-index: 2 !important;
    clip-path: inset(0 round var(--sgp-image-radius));
    pointer-events: none;
}

.sgp-gallery .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner {
    width: 100% !important;
    height: 100% !important;
    background: var(--sgp-overlay-bg) !important;
    color: var(--sgp-text-color) !important;
    font-family: var(--sgp-font-family) !important;
    font-size: var(--sgp-font-size) !important;

    font-weight: var(--sgp-text-weight) !important;
    font-style: var(--sgp-text-style) !important;

    border-radius: var(--sgp-overlay-radius) !important;
    padding-top: var(--sgp-overlay-pad-top) !important;
    padding-right: var(--sgp-overlay-pad-right) !important;
    padding-bottom: var(--sgp-overlay-pad-bottom) !important;
    padding-left: var(--sgp-overlay-pad-left) !important;
    position: relative !important;
    display: flex !important;
    overflow: hidden !important;

    transition:
        opacity var(--sgp-overlay-speed) ease,
        transform var(--sgp-overlay-speed) ease;

    pointer-events: auto;
    touch-action: pan-y;
}

.sgp-gallery .sgp-overlay-content {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;

    max-height: 100% !important;
    overflow: auto !important;
    padding-right: 10px;

    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;

    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;

    pointer-events: auto;

    text-align: var(--sgp-text-align) !important;
}

.sgp-gallery .sgp-overlay-inner--thumb .sgp-overlay-content {
    text-align: var(--sgp-thumb-text-align, var(--sgp-text-align)) !important;
}

.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content {
    text-align: var(--sgp-viewer-text-align, var(--sgp-text-align)) !important;
}

/* Text width limit by characters */
.sgp-gallery .sgp-title,
.sgp-gallery .sgp-excerpt,
.sgp-gallery .sgp-description,
.sgp-gallery .sgp-alt {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.sgp-gallery:not([style*="--sgp-text-max-ch:0"]) .sgp-title,
.sgp-gallery:not([style*="--sgp-text-max-ch:0"]) .sgp-excerpt,
.sgp-gallery:not([style*="--sgp-text-max-ch:0"]) .sgp-description,
.sgp-gallery:not([style*="--sgp-text-max-ch:0"]) .sgp-alt {
    max-width: min(100%, calc(var(--sgp-text-max-ch) * 1ch));
}

.sgp-gallery .sgp-title {
    font-weight: 700;
    font-size: clamp(15px, 1.6vw, 22px);
    line-height: 1.25;
}

.sgp-gallery .sgp-excerpt {
    font-size: clamp(12px, 1.15vw, 15px);
    line-height: 1.5;
}

.sgp-gallery .sgp-description {
    font-size: clamp(12px, 1.1vw, 14px);
    line-height: 1.5;
    opacity: .95;
}

/* Close (X) inside overlay */
.sgp-gallery .sgp-overlay-close,
.sgp-viewer .sgp-overlay-close {
    position: absolute !important;
    top: 10px;
    right: 10px;
    width: var(--sgp-close-size);
    height: var(--sgp-close-size);
    border-radius: var(--sgp-close-radius);
    border: var(--sgp-close-border-w) solid var(--sgp-close-border);
    background: var(--sgp-close-bg);
    color: var(--sgp-close-color);
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    display: none;
    pointer-events: auto;
    z-index: 5;
}

/* Position overlay content alignment (container) */
.sgp-gallery.sgp-pos-center .sgp-overlay-inner {
    align-items: center;
    justify-content: center;
}

.sgp-gallery.sgp-pos-top-left .sgp-overlay-inner {
    align-items: flex-start;
    justify-content: flex-start;
}

.sgp-gallery.sgp-pos-top-right .sgp-overlay-inner {
    align-items: flex-start;
    justify-content: flex-end;
}

.sgp-gallery.sgp-pos-bottom-left .sgp-overlay-inner {
    align-items: flex-end;
    justify-content: flex-start;
}

.sgp-gallery.sgp-pos-bottom-right .sgp-overlay-inner {
    align-items: flex-end;
    justify-content: flex-end;
}

/* Animation direction */
.sgp-gallery.sgp-anim-fade .sgp-overlay-inner {
    transform: none;
}

.sgp-gallery.sgp-anim-left .sgp-overlay-inner {
    transform: translateX(-18px);
}

.sgp-gallery.sgp-anim-right .sgp-overlay-inner {
    transform: translateX(18px);
}

.sgp-gallery.sgp-anim-top .sgp-overlay-inner {
    transform: translateY(-18px);
}

.sgp-gallery.sgp-anim-bottom .sgp-overlay-inner {
    transform: translateY(18px);
}

/* Overlay modes */
.sgp-gallery[data-overlay-mode="always"] .sgp-overlay,
.sgp-viewer[data-overlay-mode="always"] .sgp-overlay {
    pointer-events: auto;
}

.sgp-gallery[data-overlay-mode="always"] .sgp-overlay-inner,
.sgp-viewer[data-overlay-mode="always"] .sgp-overlay-inner {
    opacity: 1 !important;
    transform: none !important;
}

.sgp-gallery[data-overlay-mode="hover"] .sgp-overlay-inner,
.sgp-viewer[data-overlay-mode="hover"] .sgp-overlay-inner {
    opacity: 0 !important;
}

.sgp-gallery[data-overlay-mode="hover"] .sgp-media:hover .sgp-overlay-inner,
.sgp-viewer[data-overlay-mode="hover"] .sgp-media:hover .sgp-overlay-inner {
    opacity: 1 !important;
    transform: none !important;
}

.sgp-gallery[data-overlay-mode="hover"] .sgp-media:hover .sgp-overlay,
.sgp-viewer[data-overlay-mode="hover"] .sgp-media:hover .sgp-overlay {
    pointer-events: auto;
}

/* button toggle state */
.sgp-gallery[data-overlay-mode="button"] .sgp-item.sgp-overlay-off .sgp-overlay-inner,
.sgp-viewer[data-overlay-mode="button"] .sgp-item.sgp-overlay-off .sgp-overlay-inner {
    opacity: 0 !important;
    transform: none !important;
}

.sgp-gallery[data-overlay-mode="button"] .sgp-item.sgp-overlay-off .sgp-overlay,
.sgp-viewer[data-overlay-mode="button"] .sgp-item.sgp-overlay-off .sgp-overlay {
    pointer-events: none;
}

.sgp-gallery[data-overlay-mode="button"] .sgp-item.sgp-overlay-on .sgp-overlay-inner,
.sgp-viewer[data-overlay-mode="button"] .sgp-item.sgp-overlay-on .sgp-overlay-inner {
    opacity: 1 !important;
    transform: none !important;
}

.sgp-gallery[data-overlay-mode="button"] .sgp-item.sgp-overlay-on .sgp-overlay,
.sgp-viewer[data-overlay-mode="button"] .sgp-item.sgp-overlay-on .sgp-overlay {
    pointer-events: auto;
}

.sgp-gallery[data-overlay-mode="button"] .sgp-item.sgp-overlay-on .sgp-overlay-close,
.sgp-viewer[data-overlay-mode="button"] .sgp-item.sgp-overlay-on .sgp-overlay-close {
    display: grid;
    place-items: center;
}

/* Swipe-friendly surfaces */
.sgp-gallery .sgp-track,
.sgp-viewer__stage {
    touch-action: pan-y;
}

/* Overlay toggle button (INFO) */
.sgp-gallery .sgp-overlay-toggle,
.sgp-viewer .sgp-overlay-toggle {
    position: absolute !important;
    z-index: 4 !important;
    height: var(--sgp-ot-btn-h) !important;
    padding: 0 16px !important;
    border-radius: var(--sgp-ot-btn-radius) !important;
    border: var(--sgp-ot-btn-border-w) solid var(--sgp-ot-btn-border) !important;
    background: var(--sgp-ot-btn-bg) !important;
    color: var(--sgp-ot-btn-text) !important;
    cursor: pointer !important;
    font: 600 var(--sgp-ot-btn-fs)/1 var(--sgp-font-family) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    letter-spacing: .04em;
    pointer-events: auto;
}

.sgp-gallery .sgp-overlay-toggle,
.sgp-viewer .sgp-overlay-toggle {
    gap: .55em;
    min-width: 44px;
    white-space: nowrap;
    -webkit-tap-highlight-color: transparent;
}

.sgp-overlay-toggle .sgp-btn__icon {
    display: inline-flex;
    width: 1.15em;
    height: 1.15em;
    flex: 0 0 auto;
}

.sgp-overlay-toggle .sgp-btn__icon svg,
.sgp-gallery .sgp-nav svg,
.sgp-viewer .sgp-viewer__nav svg,
.sgp-viewer .sgp-viewer__close svg,
.sgp-slider__counter-ic svg {
    width: 100%;
    height: 100%;
    display: block;
}

.sgp-overlay-toggle .sgp-btn__label {
    display: inline-block;
}

/* Thumbnail controls below image (Grid/Masonry) */
.sgp-gallery.sgp-thumb-controls-below.sgp-type-grid .sgp-item,
.sgp-gallery.sgp-thumb-controls-below.sgp-type-masonry .sgp-item {
    display: flex;
    flex-direction: column;
}

.sgp-gallery.sgp-thumb-controls-below.sgp-type-grid .sgp-media,
.sgp-gallery.sgp-thumb-controls-below.sgp-type-masonry .sgp-media {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}

.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below {
    display: flex;
    gap: 10px;
    align-items: center;
    padding-top: 20px;
    min-height: calc(var(--sgp-ot-btn-h) + 2px);
}

.sgp-gallery.sgp-thumb-controls-below.sgp-thumb-align-left .sgp-thumb__below {
    justify-content: flex-start;
}

.sgp-gallery.sgp-thumb-controls-below.sgp-thumb-align-center .sgp-thumb__below {
    justify-content: center;
}

.sgp-gallery.sgp-thumb-controls-below.sgp-thumb-align-right .sgp-thumb__below {
    justify-content: flex-end;
}

.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below .sgp-overlay-toggle {
    position: static !important;
    transform: none !important;
    margin: 0 !important;
}

/* INFO button label comes from JS; keep ok */

/* INFO button positions */
.sgp-gallery[data-overlay-btn-pos="bottom-center"] .sgp-overlay-toggle,
.sgp-viewer[data-overlay-btn-pos="bottom-center"] .sgp-overlay-toggle {
    bottom: 12px;
    left: 50%;
    transform: translateX(-50%);
}

/* When admin selects a TOP button position, keep the button OUTSIDE the image: place the below-controls ABOVE the photo with 20px gap. */
.sgp-gallery.sgp-thumb-controls-below[data-overlay-btn-pos^="top-"] .sgp-item {
    display: flex;
    flex-direction: column;
}

.sgp-gallery.sgp-thumb-controls-below[data-overlay-btn-pos^="top-"] .sgp-thumb__below {
    order: -1;
    padding-top: 0;
    padding-bottom: 20px;
}

/* Default (bottom-*): controls stay below the photo with 20px gap */
.sgp-gallery.sgp-thumb-controls-below[data-overlay-btn-pos^="bottom-"] .sgp-thumb__below {
    order: 2;
    padding-top: 20px;
    padding-bottom: 0;
}


.sgp-gallery[data-overlay-btn-pos="bottom-left"] .sgp-overlay-toggle,
.sgp-viewer[data-overlay-btn-pos="bottom-left"] .sgp-overlay-toggle {
    bottom: 12px;
    left: 12px;
    transform: none;
}

.sgp-gallery[data-overlay-btn-pos="bottom-right"] .sgp-overlay-toggle,
.sgp-viewer[data-overlay-btn-pos="bottom-right"] .sgp-overlay-toggle {
    bottom: 12px;
    right: 12px;
    transform: none;
}

.sgp-gallery[data-overlay-btn-pos="top-center"] .sgp-overlay-toggle,
.sgp-viewer[data-overlay-btn-pos="top-center"] .sgp-overlay-toggle {
    top: 12px;
    left: 50%;
    transform: translateX(-50%);
}

.sgp-gallery[data-overlay-btn-pos="top-left"] .sgp-overlay-toggle,
.sgp-viewer[data-overlay-btn-pos="top-left"] .sgp-overlay-toggle {
    top: 12px;
    left: 12px;
    transform: none;
}

.sgp-gallery[data-overlay-btn-pos="top-right"] .sgp-overlay-toggle,
.sgp-viewer[data-overlay-btn-pos="top-right"] .sgp-overlay-toggle {
    top: 12px;
    right: 12px;
    transform: none;
}

/* Slider navigation buttons */
.sgp-gallery .sgp-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 15;
    width: var(--sgp-nav-size);
    height: var(--sgp-nav-size);
    border-radius: var(--sgp-nav-radius);
    border: var(--sgp-nav-border-w) solid var(--sgp-nav-border);
    background: var(--sgp-nav-bg);
    color: var(--sgp-nav-color);
    display: grid;
    place-items: center;
    cursor: pointer;
    border: 0 !important;
    outline: none !important;
    box-shadow: none !important;
    font-size: 0;
    line-height: 1;
    transition: transform .18s ease, opacity .18s ease;
}

.sgp-gallery .sgp-nav svg {
    width: 22px;
    height: 22px;
}

.sgp-gallery .sgp-prev {
    left: calc(50% - (var(--sgp-slider-w, min(var(--sgp-item-width), 92vw)) / 2) + 10px);
}

.sgp-gallery .sgp-next {
    right: calc(50% - (var(--sgp-slider-w, min(var(--sgp-item-width), 92vw)) / 2) + 10px);
}

/* Viewer (fullscreen) */
body.sgp-viewer-open {
    overflow: hidden !important;
}

.sgp-viewer {
    position: fixed;
    inset: 0;
    z-index: 2147483647;
    background: rgba(0, 0, 0, .85);
    display: none;
}

.sgp-viewer[aria-hidden="false"] {
    display: block;
}

.sgp-viewer__stage {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
}

.sgp-viewer__frame {
    width: min(92vw, 1200px);
    max-height: calc(100vh - 84px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    overflow: visible !important;
}

/* Ensure viewer media wraps the image (so INFO button positions correctly) */
.sgp-viewer__media {
    position: relative;
    z-index: 1;
    width: 100%;
    display: flex;
    justify-content: center;
}

.sgp-viewer__media .sgp-item {
    width: fit-content;
    max-width: 100%;
}

.sgp-viewer .sgp-media {
    width: fit-content;
    max-width: 100%;
}

.sgp-viewer__dots-host {
    width: 100%;
    display: flex;
    pointer-events: none;
}

.sgp-viewer__dots-host--top {
    order: 0;
}

.sgp-viewer__media {
    position: relative;
    z-index: 1;
    order: 1;
}

.sgp-viewer__dots-host--bottom {
    order: 2;
}

.sgp-viewer .sgp-media {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: visible !important;
}

.sgp-viewer__img {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: calc(100vh - 140px);
    object-fit: contain !important;
    display: block;
}

/* Viewer dots navigation */
.sgp-viewer__dots {
    display: inline-flex;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 999px;
    background: var(--sgp-dots-bg, rgba(255, 255, 255, .72));
    backdrop-filter: saturate(140%) blur(6px);
    pointer-events: auto;
    z-index: 12;
}

.sgp-viewer__dots.is-left {
    margin-right: auto;
}

.sgp-viewer__dots.is-center {
    margin-left: auto;
    margin-right: auto;
}

.sgp-viewer__dots.is-right {
    margin-left: auto;
}

.sgp-viewer__dot {
    width: 9px;
    height: 9px;
    border-radius: 999px;
    background: var(--sgp-dots-color, #22c55e);
    opacity: .35;
    border: 0;
    padding: 0;
    cursor: pointer;
}

.sgp-viewer__dot.is-active {
    opacity: 1;
}

/* Slider dots – match viewer dots */
.sgp-slider__dots-wrap {
    width: 100%;
    display: flex;
    padding: 12px 0 0;
}

.sgp-slider__dots-wrap.is-left {
    justify-content: flex-start;
}

.sgp-slider__dots-wrap.is-center {
    justify-content: center;
}

.sgp-slider__dots-wrap.is-right {
    justify-content: flex-end;
}

.sgp-slider__dots {
    display: inline-flex;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 999px;
    background: var(--sgp-dots-bg, rgba(255, 255, 255, .72));
    backdrop-filter: saturate(140%) blur(6px);
}

.sgp-slider__dot {
    width: 9px;
    height: 9px;
    border-radius: 999px;
    background: var(--sgp-dots-color, #22c55e);
    opacity: .35;
    border: 0;
    padding: 0;
    cursor: pointer;
}

.sgp-slider__dot.is-active {
    opacity: 1;
}

/* Slider swipe should work on the photo too (avoid native drag/select highlight) */
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-track * {
    -webkit-user-select: none;
    user-select: none;
}

.sgp-gallery.sgp-type-slider img {
    -webkit-user-drag: none;
}

/* Slider INFO button slightly lower */
.sgp-gallery.sgp-type-slider[data-overlay-btn-pos^="bottom"] .sgp-overlay-toggle {
    bottom: 6px;
}

/* Old absolute-positioning rules removed: dots are now rendered outside the image area via dots-host */

/* Slider counter */
.sgp-slider__counter {
    position: absolute;
    z-index: 10;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 999px;
    border: 1px solid rgba(0, 0, 0, .14);
    background: rgba(255, 255, 255, .92);
    color: #111;
    font-size: 13px;
    line-height: 1;
    pointer-events: none;
}

.sgp-slider__counter-ic {
    opacity: .8;
}

.sgp-slider__counter.sgp-counter-top-left {
    top: 10px;
    left: 10px;
    right: auto;
    bottom: auto;
    transform: none;
}

.sgp-slider__counter.sgp-counter-top-center {
    top: 10px;
    left: 50%;
    right: auto;
    bottom: auto;
    transform: translateX(-50%);
}

.sgp-slider__counter.sgp-counter-top-right {
    top: 10px;
    right: 10px;
    left: auto;
    bottom: auto;
    transform: none;
}

.sgp-slider__counter.sgp-counter-bottom-left {
    bottom: 10px;
    left: 10px;
    top: auto;
    right: auto;
    transform: none;
}

.sgp-slider__counter.sgp-counter-bottom-center {
    bottom: 10px;
    left: 50%;
    top: auto;
    right: auto;
    transform: translateX(-50%);
}

.sgp-slider__counter.sgp-counter-bottom-right {
    bottom: 10px;
    right: 10px;
    top: auto;
    left: auto;
    transform: none;
}

/* Prevent INFO button + counter collisions when both share the same corner */
.sgp-viewer[data-overlay-btn-pos="top-left"] .sgp-viewer__counter.sgp-counter-top-left {
    top: 54px;
}

.sgp-viewer[data-overlay-btn-pos="top-center"] .sgp-viewer__counter.sgp-counter-top-center {
    top: 54px;
}

.sgp-viewer[data-overlay-btn-pos="top-right"] .sgp-viewer__counter.sgp-counter-top-right {
    top: 54px;
}

.sgp-viewer[data-overlay-btn-pos="bottom-left"] .sgp-viewer__counter.sgp-counter-bottom-left {
    bottom: 54px;
}

.sgp-viewer[data-overlay-btn-pos="bottom-center"] .sgp-viewer__counter.sgp-counter-bottom-center {
    bottom: 54px;
}

.sgp-viewer[data-overlay-btn-pos="bottom-right"] .sgp-viewer__counter.sgp-counter-bottom-right {
    bottom: 54px;
}

.sgp-gallery.sgp-type-slider[data-overlay-btn-pos="top-left"] .sgp-slider__counter.sgp-counter-top-left {
    top: 54px;
}

.sgp-gallery.sgp-type-slider[data-overlay-btn-pos="top-center"] .sgp-slider__counter.sgp-counter-top-center {
    top: 54px;
}

.sgp-gallery.sgp-type-slider[data-overlay-btn-pos="top-right"] .sgp-slider__counter.sgp-counter-top-right {
    top: 54px;
}

.sgp-gallery.sgp-type-slider[data-overlay-btn-pos="bottom-left"] .sgp-slider__counter.sgp-counter-bottom-left {
    bottom: 54px;
}

.sgp-gallery.sgp-type-slider[data-overlay-btn-pos="bottom-center"] .sgp-slider__counter.sgp-counter-bottom-center {
    bottom: 54px;
}

.sgp-gallery.sgp-type-slider[data-overlay-btn-pos="bottom-right"] .sgp-slider__counter.sgp-counter-bottom-right {
    bottom: 54px;
}

/* Viewer counter */
.sgp-viewer__counter {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 2147483647;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, .22);
    background: rgba(0, 0, 0, .35);
    color: #fff;
    font: 600 12px/1 var(--sgp-font-family);
    letter-spacing: .02em;
    user-select: none;
}

.sgp-viewer__counter-ic,
.sgp-slider__counter-ic {
    display: inline-grid;
    place-items: center;
    width: 18px;
    height: 18px;
    border-radius: 6px;
    background: rgba(255, 255, 255, .12);
    font-size: 12px;
}

/* Viewer counter positions */
.sgp-viewer__counter.sgp-counter-top-left {
    top: 10px;
    left: 10px;
    right: auto;
    bottom: auto;
    transform: none;
}

.sgp-viewer__counter.sgp-counter-top-center {
    top: 10px;
    left: 50%;
    right: auto;
    bottom: auto;
    transform: translateX(-50%);
}

.sgp-viewer__counter.sgp-counter-top-right {
    top: 10px;
    right: 10px;
    left: auto;
    bottom: auto;
    transform: none;
}

.sgp-viewer__counter.sgp-counter-bottom-left {
    bottom: 10px;
    left: 10px;
    top: auto;
    right: auto;
    transform: none;
}

.sgp-viewer__counter.sgp-counter-bottom-center {
    bottom: 10px;
    left: 50%;
    top: auto;
    right: auto;
    transform: translateX(-50%);
}

.sgp-viewer__counter.sgp-counter-bottom-right {
    bottom: 10px;
    right: 10px;
    top: auto;
    left: auto;
    transform: none;
}

.sgp-viewer__close {
    position: fixed;
    top: 12px;
    right: 12px;
    width: 48px;
    height: 48px;
    border-radius: var(--sgp-close-radius);
    border: var(--sgp-close-border-w) solid var(--sgp-close-border);
    background: var(--sgp-close-bg);
    color: var(--sgp-close-color);
    cursor: pointer;
    display: grid;
    place-items: center;
    font-size: 0;
    z-index: 2147483647;
}

.sgp-viewer__close svg {
    width: 20px;
    height: 20px;
}

.sgp-viewer__nav {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    width: 52px;
    height: 52px;
    border-radius: var(--sgp-nav-radius);
    border: var(--sgp-nav-border-w) solid var(--sgp-nav-border);
    background: var(--sgp-nav-bg);
    color: var(--sgp-nav-color);
    display: grid;
    place-items: center;
    cursor: pointer;
    font-size: 0;
    z-index: 2147483647;
}

.sgp-viewer__nav svg {
    width: 24px;
    height: 24px;
}

.sgp-viewer__prev {
    left: 12px;
}

.sgp-viewer__next {
    right: 12px;
}

/* Mobile tweaks */
@media (max-width: 600px) {
    .sgp-gallery {
        --sgp-overlay-pad-x: 14px;
        --sgp-overlay-pad-y: 10px;
    }

    .sgp-gallery .sgp-prev {
        left: 8px;
    }

    .sgp-gallery .sgp-next {
        right: 8px;
    }
}

.sgp-gallery .sgp-nav:focus,
.sgp-gallery .sgp-nav:focus-visible,
.sgp-gallery .sgp-slider:focus,
.sgp-gallery .sgp-track:focus {
    outline: none !important;
    box-shadow: none !important;
}

/* ===== v11 Viewer/Slider below-controls + fixes ===== */
.sgp-viewer__stage {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    overflow-y: auto;
}

.sgp-viewer__frame {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.sgp-viewer__below {
    width: 100%;
    position: relative;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin-top: 14px;
    pointer-events: auto;
}

.sgp-viewer__below .sgp-overlay-toggle {
    position: static !important;
    transform: none !important;
    margin: 0 auto !important;
}

.sgp-viewer__below .sgp-viewer__counter {
    position: static !important;
    transform: none !important;
    margin: 0 auto !important;
}

.sgp-viewer__below .sgp-viewer__dots {
    position: static !important;
    transform: none !important;
    margin: 0 auto;
}

.sgp-viewer__protools {
    position: relative;
    z-index: 10000;
    display: flex;
    gap: 10px;
    overflow-x: auto;
    max-width: 100%;
    padding: 8px 2px 6px;
}

.sgp-viewer__protools::-webkit-scrollbar {
    height: 6px;
}

.sgp-viewer__protools::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, .25);
    border-radius: 999px;
}

.sgp-probtn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .12);
    color: var(--sgp-protools-viewer-text, #fff);
    border: 1px solid rgba(255, 255, 255, .18);
    font: 600 13px/1 var(--sgp-font-family);
    cursor: pointer;
}

.sgp-probtn:hover {
    background: rgba(255, 255, 255, .18);
}

.sgp-probtn__ic {
    color: var(--sgp-protools-viewer-icon, #fff);
}

.sgp-probtn__tx {
    color: inherit;
}

/* Slider tools use separate colors (typically dark on light backgrounds) */
.sgp-protools--slider .sgp-probtn {
    color: var(--sgp-protools-slider-text, #111);
    background: rgba(0, 0, 0, .04);
    border: 1px solid rgba(0, 0, 0, .10);
}

.sgp-protools--slider .sgp-probtn:hover {
    background: rgba(0, 0, 0, .06);
}

.sgp-protools--slider .sgp-probtn__ic {
    color: var(--sgp-protools-slider-icon, #111);
}

.sgp-meta-panel {
    width: min(680px, 92vw);
    max-height: 38vh;
    overflow: auto;
    background: rgba(0, 0, 0, .65);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 14px;
    padding: 14px 16px;
}

.sgp-meta-panel__row {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    padding: 6px 0;
    border-bottom: 1px solid rgba(255, 255, 255, .10);
}

.sgp-meta-panel__row:last-child {
    border-bottom: none;
}

.sgp-meta-panel__k {
    opacity: .8;
}

.sgp-meta-panel__v {
    font-weight: 600;
    text-align: right;
}

/* Focus mode: hide UI except focus button */
.sgp-viewer.is-focus .sgp-viewer__nav,
.sgp-viewer.is-focus .sgp-viewer__below> :not(.sgp-viewer__protools) {
    display: none !important;
}

.sgp-viewer.is-focus .sgp-viewer__close {
    display: inline-flex !important;
    position: fixed;
    top: 22px;
    right: 22px;
    z-index: 10000;
}

.sgp-viewer.is-focus .sgp-viewer__protools {
    justify-content: flex-end;
}

.sgp-viewer.is-focus .sgp-viewer__protools .sgp-probtn {
    display: none;
}

.sgp-viewer.is-focus .sgp-viewer__protools .sgp-probtn--focus {
    display: inline-flex;
    position: fixed;
    right: 22px;
    bottom: 22px;
    z-index: 10000;
}

/* Pro tools alignment */
.sgp-viewer__protools.is-left {
    justify-content: flex-start;
}

.sgp-viewer__protools.is-center {
    justify-content: center;
}

.sgp-viewer__protools.is-right {
    justify-content: flex-end;
}

/* Slider close button (visible ONLY in fullscreen and focus) */
.sgp-slider__close {
    position: absolute;
    top: 12px;
    right: 12px;
    width: var(--sgp-close-size);
    height: var(--sgp-close-size);
    border-radius: var(--sgp-close-radius);
    border: var(--sgp-close-border-w) solid var(--sgp-close-border);
    background: var(--sgp-close-bg);
    color: var(--sgp-close-color);
    display: none;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
    z-index: 10;
}

.sgp-gallery.sgp-slider-focus .sgp-slider__close,
.sgp-gallery.sgp-slider-fs .sgp-slider__close {
    display: inline-flex;
}

/* Slider below controls */
.sgp-slider__below {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin-top: 12px;
}

.sgp-slider__below .sgp-overlay-toggle {
    position: static !important;
    transform: none !important;
    margin: 0 auto !important;
}

.sgp-slider__below .sgp-slider__counter {
    position: static !important;
    transform: none !important;
    margin: 0 auto !important;
}

.sgp-slider__below .sgp-slider__dots-wrap {
    position: static !important;
    transform: none !important;
    margin: 0 auto !important;
}

.sgp-slider__below .sgp-viewer__protools {
    /* reuse */
    display: flex;
    gap: 10px;
    overflow-x: auto;
    max-width: 100%;
    padding: 8px 2px 6px;
}


/* --- Grid/Masonry: controls below image --- */
.sgp-thumb-controls-below .sgp-item {
    display: flex;
    flex-direction: column;
}

.sgp-thumb-controls-below .sgp-media {
    width: 100%;
}

.sgp-thumb-controls-below .sgp-thumb__below {
    width: 100%;
    display: flex;
    gap: 10px;
    margin-top: 10px;
    align-items: center;
}

.sgp-thumb-controls-below.sgp-thumb-align-left .sgp-thumb__below {
    justify-content: flex-start;
}

.sgp-thumb-controls-below.sgp-thumb-align-center .sgp-thumb__below {
    justify-content: center;
}

.sgp-thumb-controls-below.sgp-thumb-align-right .sgp-thumb__below {
    justify-content: flex-end;
}

/* Override default absolute positioning */
.sgp-thumb-controls-below .sgp-thumb__below .sgp-overlay-toggle {
    position: static !important;
    transform: none !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    margin: 0 !important;
}

/* Small image adjustment so button is visible comfortably */
.sgp-type-grid.sgp-thumb-controls-below .sgp-item {
    padding-bottom: 6px;
}



/* --- FINAL FIX: Thumbnail "INFO" button below image (Grid/Masonry) --- */
.sgp-gallery.sgp-thumb-controls-below .sgp-overlay-toggle {
    position: static !important;
    inset: auto !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    margin: 10px auto 0 !important;
}

.sgp-gallery.sgp-thumb-controls-below .sgp-item {
    display: flex;
    flex-direction: column;
}

.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below {
    width: 100%;
    display: flex;
}

.sgp-gallery.sgp-thumb-controls-below.sgp-thumb-align-left .sgp-thumb__below {
    justify-content: flex-start;
}

.sgp-gallery.sgp-thumb-controls-below.sgp-thumb-align-center .sgp-thumb__below {
    justify-content: center;
}

.sgp-gallery.sgp-thumb-controls-below.sgp-thumb-align-right .sgp-thumb__below {
    justify-content: flex-end;
}

/* --- FINAL FIX: Viewer (opened from Grid/Masonry) must look like Slider: all controls below image --- */
.sgp-viewer__frame {
    justify-content: flex-start;
}

.sgp-viewer__img {
    max-height: calc(100vh - 230px);
}

.sgp-viewer__below {
    margin-top: 18px;
}

.sgp-viewer__below .sgp-viewer__counter {
    background: rgba(255, 255, 255, .92) !important;
    border: 1px solid rgba(0, 0, 0, .14) !important;
    color: #111 !important;
    font: 600 13px/1 var(--sgp-font-family) !important;
    pointer-events: none;
}

.sgp-viewer__below .sgp-viewer__counter-ic {
    background: rgba(0, 0, 0, .06) !important;
    color: #111 !important;
}



/* Responsive column clamp: prevent 4+ columns on small screens */
@media (max-width: 900px) {
    .sgp-gallery.sgp-cols-fixed .sgp-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }

    .sgp-gallery.sgp-cols-fixed.sgp-type-masonry .sgp-masonry {
        column-count: 3;
    }
}

@media (max-width: 640px) {
    .sgp-gallery.sgp-cols-fixed .sgp-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .sgp-gallery.sgp-cols-fixed.sgp-type-masonry .sgp-masonry {
        column-count: 2;
    }
}

@media (max-width: 380px) {
    .sgp-gallery.sgp-cols-fixed .sgp-grid {
        grid-template-columns: 1fr !important;
    }

    .sgp-gallery.sgp-cols-fixed.sgp-type-masonry .sgp-masonry {
        column-count: 1;
    }
}

/* ===== v7 viewer structure ===== */
.sgp-viewer__topbar {
    width: min(1100px, 94vw);
    display: flex;
    justify-content: flex-end;
    margin-bottom: 12px;
}

.sgp-viewer__main {
    width: min(1100px, 94vw);
    display: grid;
    grid-template-columns: 56px minmax(0, 1fr) 56px;
    align-items: center;
    column-gap: 16px;
}

.sgp-viewer__mediawrap {
    min-width: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

.sgp-viewer__navcol {
    display: flex;
    align-items: center;
}

.sgp-viewer__navcol--prev {
    justify-content: flex-start;
}

.sgp-viewer__navcol--next {
    justify-content: flex-end;
}

.sgp-viewer .sgp-viewer__topbar .sgp-viewer__close,
.sgp-viewer .sgp-viewer__navcol .sgp-viewer__nav {
    position: static;
    transform: none;
    inset: auto;
    z-index: 3;
}

.sgp-viewer .sgp-viewer__below {
    width: min(1100px, 94vw);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin-top: 16px;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__below {
    margin-top: 26px;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main {
    margin-bottom: 4px;
}

.sgp-viewer .sgp-viewer__below .sgp-slider__dots-wrap,
.sgp-viewer .sgp-viewer__below .sgp-slider__counter,
.sgp-viewer .sgp-viewer__below .sgp-viewer__protools,
.sgp-viewer .sgp-viewer__below .sgp-social,
.sgp-viewer .sgp-viewer__below .sgp-overlay-toggle {
    position: static;
    transform: none;
    margin: 0;
}

.sgp-viewer .sgp-viewer__img {
    display: block;
    max-width: 100%;
    max-height: 72vh;
    width: auto;
    height: auto;
    object-fit: contain;
    margin: 0 auto;
}

.sgp-viewer .sgp-viewer__media {
    display: flex;
    justify-content: center;
    align-items: center;
}

.sgp-social {
    width: 100%;
    display: flex;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
}

.sgp-social__link {
    width: 38px;
    height: 38px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    background: rgba(0, 0, 0, .04);
    border: 1px solid rgba(0, 0, 0, .10);
    color: var(--sgp-protools-slider-icon, #111);
    font: 700 13px/1 var(--sgp-font-family);
}

.sgp-social__link:hover {
    background: rgba(0, 0, 0, .07);
}

.sgp-social__ic {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

@media (max-width: 700px) {
    .sgp-viewer__main {
        grid-template-columns: 44px minmax(0, 1fr) 44px;
        column-gap: 10px;
        width: min(96vw, 1100px);
    }

    .sgp-viewer__topbar,
    .sgp-viewer .sgp-viewer__below {
        width: min(96vw, 1100px);
    }

    .sgp-viewer .sgp-viewer__img {
        max-height: 60vh;
    }
}

/* ===== v12 frontend fixes ===== */
.sgp-thumb-controls-below .sgp-thumb__below,
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below,
.sgp-slider__below,
.sgp-viewer .sgp-viewer__below {
    flex-direction: column;
}

.sgp-thumb-controls-below .sgp-thumb__below {
    margin-top: 14px;
    gap: 8px;
}

.sgp-thumb-controls-below .sgp-thumb__below .sgp-viewer__protools {
    width: 100%;
    justify-content: center;
    padding-top: 0;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__below {
    margin-top: 34px !important;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main {
    margin-bottom: 10px;
}

.sgp-viewer .sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer .sgp-viewer__below .sgp-viewer__protools,
.sgp-viewer .sgp-viewer__below .sgp-social,
.sgp-viewer .sgp-viewer__below .sgp-slider__dots-wrap,
.sgp-viewer .sgp-viewer__below .sgp-slider__counter {
    width: auto;
    max-width: 100%;
}

.sgp-social__link--tiktok .sgp-social__ic {
    transform: translateY(.5px);
}

.sgp-thumb__below .sgp-viewer__protools {
    display: flex !important;
}

.sgp-thumb__below .sgp-viewer__protools .sgp-probtn {
    display: inline-flex !important;
}

/* ===== v5 recovery overrides ===== */
.sgp-gallery.sgp-type-grid .sgp-grid {
    display: grid !important;
}

.sgp-gallery.sgp-type-grid .sgp-item {
    width: auto !important;
    display: block !important;
}

.sgp-gallery.sgp-type-grid .sgp-media {
    width: 100% !important;
    height: var(--sgp-item-height) !important;
}

.sgp-gallery.sgp-type-grid .sgp-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: var(--sgp-fit-grid) !important;
}

.sgp-gallery.sgp-type-masonry .sgp-masonry {
    column-width: var(--sgp-item-width) !important;
    column-gap: var(--sgp-col-gap) !important;
}

.sgp-gallery.sgp-type-masonry .sgp-item {
    display: inline-block !important;
    width: 100% !important;
    break-inside: avoid !important;
    vertical-align: top !important;
    margin: 0 0 var(--sgp-row-gap) 0 !important;
}

.sgp-gallery.sgp-type-masonry .sgp-media {
    height: auto !important;
}

.sgp-gallery.sgp-type-masonry .sgp-img {
    width: 100% !important;
    height: auto !important;
    object-fit: var(--sgp-fit-masonry) !important;
}

.sgp-gallery.sgp-type-slider .sgp-slide .sgp-overlay-toggle {
    display: none !important;
}

.sgp-gallery .sgp-overlay {
    width: var(--sgp-overlay-w, auto);
    height: var(--sgp-overlay-h, auto);
    max-width: calc(100% - 24px);
    border-radius: var(--sgp-overlay-radius);
    border: var(--sgp-overlay-border-w, 0px) solid var(--sgp-overlay-border, transparent);
}

.sgp-gallery .sgp-overlay-inner {
    width: 100%;
    height: 100%;
}

.sgp-gallery .sgp-thumb__below,
.sgp-gallery .sgp-slider__below,
.sgp-viewer .sgp-viewer__below {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
}

.sgp-gallery .sgp-thumb__below {
    margin-top: 12px !important;
}

.sgp-thumb__below .sgp-viewer__protools,
.sgp-slider__below .sgp-viewer__protools,
.sgp-viewer__below .sgp-viewer__protools {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 8px !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.sgp-probtn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.sgp-social {
    display: flex !important;
}

.sgp-social__ic svg {
    width: 18px;
    height: 18px;
    display: block;
}

.sgp-viewer__stage {
    padding: 20px 56px 18px !important;
}

.sgp-viewer__frame {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: min(96vw, 1360px) !important;
    max-width: min(96vw, 1360px) !important;
}

.sgp-viewer__media {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
}

.sgp-viewer__img {
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 80vh !important;
    object-fit: contain !important;
}

.sgp-viewer__below {
    margin-top: 10px !important;
    padding-bottom: 8px !important;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__below,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__below {
    margin-top: 12px !important;
}

.sgp-viewer__nav,
.sgp-gallery .sgp-nav {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
    padding: 0 !important;
    font-size: 28px !important;
}

.sgp-viewer__nav {
    width: var(--sgp-nav-size) !important;
    height: var(--sgp-nav-size) !important;
}

.sgp-viewer__close {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
}

@media (max-width: 700px) {
    .sgp-viewer__stage {
        padding: 18px 16px 20px !important;
    }

    .sgp-viewer__frame {
        max-width: min(96vw, 1100px);
    }

    .sgp-viewer__img {
        max-height: 62vh !important;
    }
}

/* ===== v16 viewer fixes ===== */
.sgp-viewer__below,
.sgp-viewer__below *,
.sgp-viewer__protools,
.sgp-viewer__protools *,
.sgp-social,
.sgp-social * {
  pointer-events: auto !important;
}
.sgp-viewer__below,
.sgp-viewer__protools,
.sgp-social { position: relative; z-index: 2147483646 !important; }
.sgp-toast {
  position: fixed; left: 50%; bottom: 28px; transform: translateX(-50%) translateY(12px);
  display:flex; align-items:center; gap:10px; padding:12px 16px; border-radius:16px;
  background: linear-gradient(135deg,#7c3aed,#9333ea); color:#fff; font-weight:700;
  box-shadow: 0 16px 32px rgba(91,33,182,.28); opacity:0; transition:all .2s ease; z-index:2147483647;
}
.sgp-toast.is-visible { opacity:1; transform: translateX(-50%) translateY(0); }
.sgp-toast__ic {
  width:22px; height:22px; border-radius:999px; display:grid; place-items:center;
  background:rgba(255,255,255,.18);
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__stage {
  align-items: flex-start !important;
  padding-top: 56px !important;
  padding-bottom: 28px !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame {
  margin-top: 48px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__below {
  margin-top: 18px !important;
  padding-bottom: 24px !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img {
  max-height: 68vh !important;
}
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame {
  width: min(1100px, calc(100vw - 176px)) !important;
}
@media (max-width: 700px) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__stage {
    align-items:flex-start !important; padding: 22px 14px 24px !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame {
    width: min(96vw, 1100px) !important; margin-top: 26px !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
    max-width: calc(100vw - 28px) !important;
    max-height: 58vh !important;
    margin: 0 auto !important;
  }
}


/* ===== v17 grid viewer alignment ===== */
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__stage {
  align-items: center !important;
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame {
  margin-top: 0 !important;
  width: min(1100px, calc(100vw - 176px)) !important;
  justify-content: center !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__below {
  margin-top: 12px !important;
  padding-bottom: 12px !important;
}
@media (max-width: 700px) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__stage {
    align-items: center !important;
    padding: 18px 16px 20px !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame {
    margin-top: 0 !important;
    width: min(96vw, 1100px) !important;
  }
}

/* ===== v37 navigation usability fixes ===== */
.sgp-gallery.sgp-type-slider .sgp-slider {
  display: grid;
  grid-template-columns: var(--sgp-nav-size) minmax(0, min(92vw, var(--sgp-slider-w, var(--sgp-item-width)))) var(--sgp-nav-size);
  align-items: center;
  justify-content: center;
  column-gap: 12px;
}

.sgp-gallery.sgp-type-slider .sgp-track {
  grid-column: 2;
  width: min(92vw, var(--sgp-slider-w, var(--sgp-item-width)));
  margin: 0 auto;
}

.sgp-gallery.sgp-type-slider .sgp-prev,
.sgp-gallery.sgp-type-slider .sgp-next {
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  transform: none;
  z-index: 2;
  pointer-events: auto;
}

.sgp-gallery.sgp-type-slider .sgp-prev { grid-column: 1; }
.sgp-gallery.sgp-type-slider .sgp-next { grid-column: 3; }

.sgp-viewer__main {
  grid-template-columns: var(--sgp-nav-size) minmax(0, 1fr) var(--sgp-nav-size);
}

.sgp-viewer__navcol {
  position: relative;
  z-index: 2;
  pointer-events: auto;
}

.sgp-viewer__mediawrap,
.sgp-viewer__media {
  min-width: 0;
}

.sgp-viewer__mediawrap {
  display: flex;
  align-items: center;
  justify-content: center;
}

.sgp-viewer__media .sgp-media,
.sgp-viewer__img {
  margin-left: auto;
  margin-right: auto;
}

.sgp-viewer .sgp-viewer__navcol .sgp-viewer__nav,
.sgp-gallery .sgp-nav {
  pointer-events: auto;
}

@media (max-width: 700px) {
  .sgp-gallery.sgp-type-slider .sgp-slider {
    grid-template-columns: 44px minmax(0, min(92vw, var(--sgp-slider-w, var(--sgp-item-width)))) 44px;
    column-gap: 8px;
  }

  .sgp-gallery.sgp-type-slider .sgp-track {
    width: min(92vw, var(--sgp-slider-w, var(--sgp-item-width)));
  }
}


/* ===== v38 responsive hardening ===== */
.sgp-gallery,
.sgp-viewer {
  --sgp-mobile-side-gap: clamp(8px, 2.4vw, 14px);
}

.sgp-gallery .sgp-media,
.sgp-viewer__media {
  min-width: 0;
}

.sgp-gallery .sgp-overlay {
  max-width: calc(100% - 12px);
  max-height: calc(100% - 12px);
}

.sgp-gallery .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner {
  max-width: min(100%, var(--sgp-overlay-w, 100%));
  max-height: min(100%, var(--sgp-overlay-h, 100%));
}

@media (max-width: 900px) {
  .sgp-gallery.sgp-type-slider .sgp-slider {
    grid-template-columns: 48px minmax(0, min(94vw, var(--sgp-slider-w, var(--sgp-item-width)))) 48px;
    column-gap: 10px;
  }

  .sgp-gallery.sgp-type-slider .sgp-track {
    width: min(94vw, var(--sgp-slider-w, var(--sgp-item-width)));
  }
}

@media (max-width: 700px) {
  .sgp-gallery .sgp-overlay-toggle,
  .sgp-viewer .sgp-overlay-toggle {
    max-width: calc(100vw - 32px);
    padding: 0 14px !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-slider {
    grid-template-columns: 40px minmax(0, min(100vw - 96px, var(--sgp-slider-w, var(--sgp-item-width)))) 40px;
    column-gap: 8px;
  }

  .sgp-gallery.sgp-type-slider .sgp-track {
    width: min(calc(100vw - 96px), var(--sgp-slider-w, var(--sgp-item-width)));
  }

  .sgp-viewer__stage {
    padding: 12px 10px 16px;
  }

  .sgp-viewer__frame {
    width: min(100vw - 20px, 1100px);
    max-height: calc(100vh - 32px);
    gap: 10px;
  }

  .sgp-viewer__nav,
  .sgp-gallery .sgp-nav {
    width: var(--sgp-nav-size) !important;
    height: var(--sgp-nav-size) !important;
  }

  .sgp-viewer__close {
    width: var(--sgp-close-size) !important;
    height: var(--sgp-close-size) !important;
  }

  .sgp-viewer__nav svg,
  .sgp-gallery .sgp-nav svg {
    width: var(--sgp-nav-icon-size) !important;
    height: var(--sgp-nav-icon-size) !important;
  }

  .sgp-viewer__close svg {
    width: var(--sgp-close-icon-size) !important;
    height: var(--sgp-close-icon-size) !important;
  }

  .sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below,
  .sgp-slider__below,
  .sgp-viewer__below {
    gap: 10px;
    padding-left: 4px;
    padding-right: 4px;
  }
}

@media (max-width: 480px) {
  .sgp-gallery .sgp-overlay-toggle,
  .sgp-viewer .sgp-overlay-toggle {
    font-size: max(11px, calc(var(--sgp-ot-btn-fs) - 1px)) !important;
    letter-spacing: .03em;
  }

  .sgp-gallery .sgp-overlay-toggle .sgp-btn__label,
  .sgp-viewer .sgp-overlay-toggle .sgp-btn__label {
    max-width: 16ch;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .sgp-gallery.sgp-type-slider .sgp-slider {
    grid-template-columns: 36px minmax(0, calc(100vw - 84px)) 36px;
    column-gap: 6px;
  }

  .sgp-gallery.sgp-type-slider .sgp-track {
    width: calc(100vw - 84px);
  }

  .sgp-viewer__navcol--prev .sgp-viewer__nav,
  .sgp-viewer__prev {
    left: 6px;
  }

  .sgp-viewer__navcol--next .sgp-viewer__nav,
  .sgp-viewer__next {
    right: 6px;
  }

  .sgp-viewer__close {
    top: 6px;
    right: 6px;
  }
}


/* ===== v39 mobile alignment + share tool ===== */
.sgp-probtn__ic svg {
  width: 16px;
  height: 16px;
  display: block;
}

.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-track-inner,
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  min-width: 0;
}

.sgp-gallery.sgp-type-slider .sgp-slide {
  align-items: center;
}

.sgp-gallery.sgp-type-slider .sgp-item {
  max-width: min(100%, var(--sgp-slider-w, var(--sgp-item-width)));
  margin-left: auto;
  margin-right: auto;
}

.sgp-gallery.sgp-type-slider .sgp-media,
.sgp-gallery.sgp-type-slider .sgp-img {
  object-position: center center !important;
}

@media (max-width: 900px) and (min-width: 641px) {
  .sgp-gallery.sgp-type-masonry .sgp-masonry {
    column-count: 2 !important;
    column-width: auto !important;
  }

  .sgp-gallery.sgp-type-masonry .sgp-item {
    display: inline-block !important;
    width: 100% !important;
  }
}

@media (max-width: 640px) {
  .sgp-gallery.sgp-type-masonry .sgp-masonry,
  .sgp-gallery.sgp-cols-fixed.sgp-type-masonry .sgp-masonry {
    column-count: 1 !important;
    column-width: auto !important;
  }

  .sgp-gallery.sgp-type-grid .sgp-grid,
  .sgp-gallery.sgp-cols-fixed .sgp-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 700px) {
  .sgp-gallery.sgp-type-slider {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-slider {
    width: 100% !important;
    max-width: 100% !important;
    grid-template-columns: minmax(34px, 40px) minmax(0, 1fr) minmax(34px, 40px) !important;
    column-gap: 6px !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-track {
    width: 100% !important;
    max-width: 100% !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-slide {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-item {
    width: 100% !important;
    max-width: 100% !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-media {
    width: 100% !important;
  }
}

@media (max-width: 480px) {
  .sgp-gallery.sgp-type-slider .sgp-slider {
    grid-template-columns: 34px minmax(0, 1fr) 34px !important;
    column-gap: 4px !important;
  }
}


/* ===== v40 mobile viewer centering + photographer tools ===== */
.sgp-probtn__ic svg {
  width: 16px;
  height: 16px;
  display: block;
}

@media (max-width: 700px) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main {
    grid-template-columns: 40px minmax(0, 1fr) 40px !important;
    column-gap: 6px !important;
    align-items: center !important;
  }

  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media {
    width: 100% !important;
    max-width: 100% !important;
    justify-content: center !important;
    align-items: center !important;
    margin: 0 auto !important;
  }

  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__frame {
    width: min(100vw - 20px, 1100px) !important;
    margin: 0 auto !important;
  }

  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
    display: block !important;
    max-width: min(100%, calc(100vw - 108px)) !important;
    width: auto !important;
    margin-left: auto !important;
    margin-right: auto !important;
    object-position: center center !important;
  }

  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__navcol,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__navcol {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
}

@media (max-width: 480px) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main {
    grid-template-columns: 34px minmax(0, 1fr) 34px !important;
    column-gap: 4px !important;
  }

  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
    max-width: calc(100vw - 88px) !important;
  }
}


/* ===== v41 sizing + watermark + mobile landscape fixes ===== */
.sgp-gallery {
  --sgp-nav-icon-size: clamp(8px, calc(var(--sgp-nav-size) * 0.48), 22px);
  --sgp-close-icon-size: clamp(8px, calc(var(--sgp-close-size) * 0.54), 20px);
}
.sgp-gallery .sgp-nav svg,
.sgp-viewer__nav svg {
  width: var(--sgp-nav-icon-size) !important;
  height: var(--sgp-nav-icon-size) !important;
}
.sgp-viewer__close svg,
.sgp-gallery .sgp-overlay-close svg {
  width: var(--sgp-close-icon-size) !important;
  height: var(--sgp-close-icon-size) !important;
}
.sgp-viewer__nav {
  width: var(--sgp-nav-size) !important;
  height: var(--sgp-nav-size) !important;
}
.sgp-viewer__close,
.sgp-gallery .sgp-overlay-close {
  width: var(--sgp-close-size) !important;
  height: var(--sgp-close-size) !important;
}
@media (max-width: 700px) {
  .sgp-viewer__nav,
  .sgp-gallery .sgp-nav,
  .sgp-viewer__close {
    width: var(--sgp-nav-size) !important;
    height: var(--sgp-nav-size) !important;
  }
  .sgp-viewer__close {
    width: var(--sgp-close-size) !important;
    height: var(--sgp-close-size) !important;
  }
}
.sgp-watermark {
  position: absolute;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: .42em;
  max-width: calc(100% - 20px);
  padding: .38em .72em;
  border-radius: 999px;
  background: rgba(17,17,17,.18);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  color: var(--sgp-watermark-color);
  font-size: var(--sgp-watermark-size);
  line-height: 1;
  opacity: var(--sgp-watermark-opacity);
  pointer-events: none;
  white-space: nowrap;
}
.sgp-watermark__ic { width: 1.05em; height: 1.05em; display:inline-flex; flex:0 0 auto; }
.sgp-watermark__ic svg { width: 100%; height: 100%; display:block; }
.sgp-watermark--top-left { top: 12px; left: 12px; }
.sgp-watermark--top-right { top: 12px; right: 12px; }
.sgp-watermark--top-center { top: 12px; left: 50%; transform: translateX(-50%); }
.sgp-watermark--bottom-left { bottom: 12px; left: 12px; }
.sgp-watermark--bottom-center { bottom: 12px; left: 50%; transform: translateX(-50%); }
.sgp-watermark--bottom-right { bottom: 12px; right: 12px; }
@media (max-width: 700px) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__frame {
    width: 100% !important;
    max-width: 100% !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
    max-width: min(100%, calc(100vw - (var(--sgp-nav-size) * 2) - 36px)) !important;
    max-height: calc(100dvh - 190px) !important;
  }
}
@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer .sgp-viewer__stage {
    padding: 10px 8px 12px !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main,
  .sgp-gallery.sgp-type-slider .sgp-slider {
    grid-template-columns: var(--sgp-nav-size) minmax(0, 1fr) var(--sgp-nav-size) !important;
    column-gap: 6px !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
  .sgp-gallery.sgp-type-slider .sgp-item .sgp-img {
    max-width: min(100%, calc(100vw - (var(--sgp-nav-size) * 2) - 56px)) !important;
    max-height: calc(100dvh - 92px) !important;
    object-fit: contain !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}


/* ===== v42 viewer centering + watermark options ===== */
.sgp-gallery {
  --sgp-watermark-bg: rgba(17,17,17,.18);
}
.sgp-watermark {
  background: var(--sgp-watermark-bg);
}

.sgp-proof-badge {
  position: absolute;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  gap: .42em;
  max-width: calc(100% - 20px);
  padding: .4em .74em;
  border-radius: 999px;
  background: var(--sgp-proof-badge-bg, rgba(124,58,237,.92));
  color: var(--sgp-proof-badge-color, #fff);
  font-size: var(--sgp-proof-badge-size, 12px);
  font-weight: 700;
  line-height: 1;
  letter-spacing: .02em;
  pointer-events: none;
  white-space: nowrap;
  box-shadow: 0 10px 24px rgba(17, 17, 17, .18);
}
.sgp-proof-badge__ic { width: 1.05em; height: 1.05em; display:inline-flex; flex:0 0 auto; }
.sgp-proof-badge__ic svg { width: 100%; height: 100%; display:block; }
.sgp-proof-badge--top-left { top: 12px; left: 12px; }
.sgp-proof-badge--top-right { top: 12px; right: 12px; }
.sgp-proof-badge--top-center { top: 12px; left: 50%; transform: translateX(-50%); }
.sgp-proof-badge--bottom-left { bottom: 12px; left: 12px; }
.sgp-proof-badge--bottom-center { bottom: 12px; left: 50%; transform: translateX(-50%); }
.sgp-proof-badge--bottom-right { bottom: 12px; right: 12px; }
@media (max-width: 900px) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media {
    width: min(100%, var(--sgp-viewer-between-nav, 100%)) !important;
    max-width: min(100%, var(--sgp-viewer-between-nav, 100%)) !important;
    flex: 0 1 auto !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
    max-width: min(100%, var(--sgp-viewer-between-nav, 100%)) !important;
    width: auto !important;
    object-fit: contain !important;
    object-position: center center !important;
  }
}
@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__frame {
    width: min(100%, calc(var(--sgp-viewer-stage-width, 100vw) - 8px)) !important;
    max-width: min(100%, calc(var(--sgp-viewer-stage-width, 100vw) - 8px)) !important;
  }

  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
    max-width: min(100%, var(--sgp-viewer-between-nav, 100%)) !important;
    max-height: calc(var(--sgp-viewer-stage-height, 100dvh) - 96px) !important;
  }
}


/* ===== v6 safe bounds + mobile landscape centering ===== */
.sgp-viewer {
  --sgp-safe-left: 10px;
  --sgp-safe-right: 10px;
  --sgp-safe-width: calc(100vw - 20px);
}
.sgp-viewer__stage {
  padding-left: max(18px, var(--sgp-safe-left)) !important;
  padding-right: max(18px, var(--sgp-safe-right)) !important;
}
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer .sgp-viewer__below {
  width: min(1100px, var(--sgp-safe-width)) !important;
  max-width: min(1100px, var(--sgp-safe-width)) !important;
}
.sgp-viewer__frame {
  width: min(1100px, var(--sgp-safe-width)) !important;
  max-width: min(1100px, var(--sgp-safe-width)) !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media {
  min-width: 0;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media {
  width: min(100%, var(--sgp-viewer-between-nav, var(--sgp-safe-width))) !important;
  max-width: min(100%, var(--sgp-viewer-between-nav, var(--sgp-safe-width))) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
  display: block;
  width: auto !important;
  max-width: min(100%, var(--sgp-viewer-between-nav, var(--sgp-safe-width))) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer__stage {
    padding-top: 10px !important;
    padding-bottom: 12px !important;
    padding-left: max(10px, var(--sgp-safe-left)) !important;
    padding-right: max(10px, var(--sgp-safe-right)) !important;
  }
  .sgp-viewer__frame,
  .sgp-viewer__topbar,
  .sgp-viewer__main,
  .sgp-viewer .sgp-viewer__below {
    width: min(var(--sgp-safe-width), calc(100vw - var(--sgp-safe-left) - var(--sgp-safe-right))) !important;
    max-width: min(var(--sgp-safe-width), calc(100vw - var(--sgp-safe-left) - var(--sgp-safe-right))) !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
  .sgp-gallery.sgp-type-slider .sgp-item .sgp-img {
    max-width: min(100%, calc(var(--sgp-viewer-between-nav, var(--sgp-safe-width)) - 2px)) !important;
    max-height: calc(100dvh - 108px) !important;
  }
}

/* ===== v7 content-column safe viewer fix ===== */
.sgp-viewer__stage {
  justify-content: flex-start !important;
}
.sgp-viewer__frame {
  margin-left: var(--sgp-safe-left) !important;
  margin-right: auto !important;
}
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer .sgp-viewer__below,
.sgp-viewer__frame {
  box-sizing: border-box !important;
}
.sgp-viewer__main {
  grid-template-columns: var(--sgp-nav-col, 56px) minmax(0, var(--sgp-viewer-between-nav, 1fr)) var(--sgp-nav-col, 56px) !important;
  column-gap: var(--sgp-main-gap, 16px) !important;
  width: min(var(--sgp-safe-width), var(--sgp-viewer-main-width, var(--sgp-safe-width))) !important;
  max-width: min(var(--sgp-safe-width), var(--sgp-viewer-main-width, var(--sgp-safe-width))) !important;
  justify-content: start !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  width: 100% !important;
  max-width: 100% !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-media {
  width: var(--sgp-viewer-between-nav, 100%) !important;
  max-width: var(--sgp-viewer-between-nav, 100%) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
  width: auto !important;
  max-width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-viewer.is-focus .sgp-viewer__img {
  max-height: calc(100dvh - 48px) !important;
}
@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer__frame {
    max-width: var(--sgp-safe-width) !important;
  }
  .sgp-viewer__main {
    width: min(var(--sgp-safe-width), var(--sgp-viewer-main-width, var(--sgp-safe-width))) !important;
    max-width: min(var(--sgp-safe-width), var(--sgp-viewer-main-width, var(--sgp-safe-width))) !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
    max-height: calc(100dvh - 128px) !important;
  }
}

/* ===== v8 content-safe centering fix ===== */
.sgp-viewer__stage {
  left: var(--sgp-stage-left, 0) !important;
  right: var(--sgp-stage-right, 0) !important;
  inset-inline-start: var(--sgp-stage-left, 0) !important;
  inset-inline-end: var(--sgp-stage-right, 0) !important;
  justify-content: center !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
  box-sizing: border-box !important;
}

.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer .sgp-viewer__below {
  width: min(1100px, 100%) !important;
  max-width: min(1100px, 100%) !important;
}

.sgp-viewer__frame {
  margin-left: auto !important;
  margin-right: auto !important;
}

.sgp-viewer__main {
  margin-left: auto !important;
  margin-right: auto !important;
  justify-content: center !important;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-media {
  width: 100% !important;
  max-width: 100% !important;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
  max-width: min(100%, var(--sgp-viewer-between-nav, 100%)) !important;
}

@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer__stage {
    padding-top: 10px !important;
    padding-bottom: 12px !important;
  }

  .sgp-viewer__frame,
  .sgp-viewer__topbar,
  .sgp-viewer__main,
  .sgp-viewer .sgp-viewer__below {
    width: 100% !important;
    max-width: 100% !important;
  }
}


/* ===== v9 strict content-column / sidebar-safe viewer fix ===== */
.sgp-viewer__stage {
  left: var(--sgp-stage-left, 10px) !important;
  right: var(--sgp-stage-right, 10px) !important;
  inset-inline-start: var(--sgp-stage-left, 10px) !important;
  inset-inline-end: var(--sgp-stage-right, 10px) !important;
  width: auto !important;
  max-width: none !important;
  justify-content: center !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box !important;
}

.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer .sgp-viewer__below {
  width: var(--sgp-safe-width, min(1100px, 100%)) !important;
  max-width: var(--sgp-safe-width, min(1100px, 100%)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box !important;
}

.sgp-viewer__frame {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.sgp-viewer__main {
  display: grid !important;
  grid-template-columns: var(--sgp-nav-col, 56px) minmax(0, calc(var(--sgp-safe-width, 100%) - (var(--sgp-nav-col, 56px) * 2) - (var(--sgp-main-gap, 16px) * 2))) var(--sgp-nav-col, 56px) !important;
  column-gap: var(--sgp-main-gap, 16px) !important;
  align-items: center !important;
  justify-content: center !important;
}

.sgp-viewer__navcol,
.sgp-viewer__navcol--prev,
.sgp-viewer__navcol--next {
  width: var(--sgp-nav-col, 56px) !important;
  min-width: var(--sgp-nav-col, 56px) !important;
}

.sgp-viewer__navcol--prev {
  justify-content: center !important;
}

.sgp-viewer__navcol--next {
  justify-content: center !important;
}

.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
  margin-left: auto !important;
  margin-right: auto !important;
  max-width: 100% !important;
}

@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer__frame,
  .sgp-viewer__topbar,
  .sgp-viewer__main,
  .sgp-viewer .sgp-viewer__below {
    width: var(--sgp-safe-width, 100%) !important;
    max-width: var(--sgp-safe-width, 100%) !important;
  }
}


/* ===== v10 Firefox + mobile landscape sidebar-safe hard bounds ===== */
.sgp-viewer__stage {
  left: var(--sgp-stage-left, 10px) !important;
  right: auto !important;
  inset-inline-start: var(--sgp-stage-left, 10px) !important;
  inset-inline-end: auto !important;
  width: var(--sgp-safe-width, calc(100vw - 20px)) !important;
  max-width: var(--sgp-safe-width, calc(100vw - 20px)) !important;
  justify-content: center !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box !important;
}
.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer .sgp-viewer__below {
  width: var(--sgp-safe-width, min(1100px, 100%)) !important;
  max-width: var(--sgp-safe-width, min(1100px, 100%)) !important;
}
.sgp-viewer__main {
  justify-content: center !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  min-width: 0 !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="slider"] .sgp-viewer__img {
  max-width: var(--sgp-viewer-between-nav, 100%) !important;
}
@supports (-moz-appearance:none) {
  .sgp-viewer__stage {
    overflow-x: hidden !important;
  }
}


/* ===== v42 sidebar-safe viewer fixes ===== */
.sgp-viewer__stage,
.sgp-viewer__frame,
.sgp-viewer__main,
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-media {
  max-width: 100%;
  box-sizing: border-box;
}
.sgp-viewer__media,
.sgp-viewer__media .sgp-media,
.sgp-viewer__img {
  overflow: hidden;
}
@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer__stage,
  .sgp-viewer__frame,
  .sgp-viewer__main {
    max-width: var(--sgp-safe-width, 100vw) !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
    max-width: var(--sgp-viewer-between-nav, calc(100vw - 120px)) !important;
    width: min(var(--sgp-viewer-between-nav, calc(100vw - 120px)), 100%) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}


/* ===== v12 final viewer centering + new layouts ===== */
.sgp-viewer__stage{
  left: var(--sgp-stage-left, 10px) !important;
  right: auto !important;
  width: var(--sgp-safe-width, calc(100vw - 20px)) !important;
  max-width: var(--sgp-safe-width, calc(100vw - 20px)) !important;
  padding-inline: 0 !important;
  justify-content: center !important;
  overflow-x: hidden !important;
}
.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer .sgp-viewer__below{
  width: 100% !important;
  max-width: 100% !important;
  margin-inline: auto !important;
}
.sgp-viewer__main{
  justify-content: center !important;
  align-items: center !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media{
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
}
.sgp-viewer__img{
  display:block !important;
  margin-inline:auto !important;
  max-width:100% !important;
}
@media (max-width: 900px) and (orientation: landscape){
  .sgp-viewer__stage{
    width: var(--sgp-safe-width, calc(100vw - 20px)) !important;
    max-width: var(--sgp-safe-width, calc(100vw - 20px)) !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__img{
    width: auto !important;
    max-width: min(100%, var(--sgp-viewer-between-nav, calc(100vw - 120px))) !important;
    max-height: calc(100dvh - 128px) !important;
    object-position: center center !important;
  }
}

/* Layout cards */
.sgp-gallery.sgp-type-polaroid .sgp-grid,
.sgp-gallery.sgp-type-fusion .sgp-grid,
.sgp-gallery.sgp-type-mosaic .sgp-grid{
  display:grid;
  gap:var(--sgp-row-gap) var(--sgp-col-gap);
}

.sgp-gallery.sgp-type-polaroid .sgp-grid{
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
}
.sgp-gallery.sgp-type-polaroid .sgp-item{
  background:#fff;
  border-radius:18px;
  padding:14px 14px 52px;
  box-shadow:0 14px 38px rgba(17, 24, 39, .10);
  transform:rotate(var(--sgp-polaroid-rot, 0deg));
}
.sgp-gallery.sgp-type-polaroid .sgp-item:nth-child(odd){ --sgp-polaroid-rot:-1.4deg; }
.sgp-gallery.sgp-type-polaroid .sgp-item:nth-child(even){ --sgp-polaroid-rot:1.2deg; }
.sgp-gallery.sgp-type-polaroid .sgp-media{ background:#fff; }
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below{
  margin-top:12px;
}
.sgp-gallery.sgp-type-polaroid .sgp-item::after{
  content: attr(data-title);
  display:block;
  margin-top:14px;
  color:#6d28d9;
  font-weight:600;
  font-size:14px;
  text-align:center;
}

.sgp-gallery.sgp-type-fusion .sgp-grid{
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-flow:dense;
}
.sgp-gallery.sgp-type-fusion .sgp-item{
  grid-column: span 4;
  border-radius:20px;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(192,132,252,.12), rgba(255,255,255,.98));
  box-shadow:0 12px 32px rgba(109,40,217,.12);
}
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(5n+1){ grid-column: span 8; }
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(5n+4),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(5n+5){ grid-column: span 6; }
.sgp-gallery.sgp-type-fusion .sgp-media{ min-height:100%; }
.sgp-gallery.sgp-type-fusion .sgp-thumb__below{ padding-bottom:4px; }

.sgp-gallery.sgp-type-mosaic .sgp-grid{
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-flow:dense;
}
.sgp-gallery.sgp-type-mosaic .sgp-item{
  grid-column: span 3;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 10px 26px rgba(17,24,39,.08);
}
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+1){ grid-column: span 6; grid-row: span 2; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+2){ grid-column: span 3; grid-row: span 2; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+3){ grid-column: span 3; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+4){ grid-column: span 4; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+5){ grid-column: span 5; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+6){ grid-column: span 3; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+7){ grid-column: span 4; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+8){ grid-column: span 5; }

.sgp-gallery.sgp-type-polaroid .sgp-img,
.sgp-gallery.sgp-type-fusion .sgp-img,
.sgp-gallery.sgp-type-mosaic .sgp-img{
  width:100%;
  height:100%;
  object-fit:cover;
}

@media (max-width: 1024px){
  .sgp-gallery.sgp-type-fusion .sgp-item{ grid-column: span 6; }
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(5n+1),
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(5n+4),
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(5n+5){ grid-column: span 6; }
  .sgp-gallery.sgp-type-mosaic .sgp-item,
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(n){ grid-column: span 4; grid-row: span 1; }
}
@media (max-width: 767px){
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid{
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
  .sgp-gallery.sgp-type-fusion .sgp-item,
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(n),
  .sgp-gallery.sgp-type-mosaic .sgp-item,
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(n){
    grid-column: span 1;
    grid-row: span 1;
  }
  .sgp-gallery.sgp-type-polaroid .sgp-grid{
    grid-template-columns: 1fr;
  }
}

/* ===== v13 final viewer/sidebar centering fix ===== */
.sgp-viewer {
  --sgp-safe-left: 10px;
  --sgp-safe-right: 10px;
  --sgp-safe-width: calc(100vw - 20px);
  --sgp-viewer-between-nav: calc(var(--sgp-safe-width) - (var(--sgp-nav-size) * 2) - 24px);
}
.sgp-viewer__stage {
  position: absolute !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 10px !important;
  box-sizing: border-box !important;
}
.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer .sgp-viewer__below {
  width: var(--sgp-safe-width) !important;
  max-width: var(--sgp-safe-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box !important;
}
.sgp-viewer__frame {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
}
.sgp-viewer__main {
  display: grid !important;
  grid-template-columns: var(--sgp-nav-col, 56px) minmax(0, var(--sgp-viewer-between-nav)) var(--sgp-nav-col, 56px) !important;
  column-gap: var(--sgp-main-gap, 12px) !important;
  justify-content: center !important;
  justify-items: center !important;
  align-items: center !important;
}
.sgp-viewer__navcol {
  width: var(--sgp-nav-col, 56px) !important;
  min-width: var(--sgp-nav-col, 56px) !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  grid-column: 2 !important;
  justify-self: center !important;
  align-self: center !important;
  width: var(--sgp-viewer-between-nav) !important;
  max-width: var(--sgp-viewer-between-nav) !important;
  min-width: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}
.sgp-viewer__img {
  display: block !important;
  max-width: var(--sgp-viewer-between-nav) !important;
  width: auto;
  height: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
  margin-left: auto !important;
  margin-right: auto !important;
  transform: translateX(0) !important;
}
body.sgp-viewer-open {
  overflow: hidden !important;
}
@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer__stage {
    padding: 10px !important;
  }
  .sgp-viewer__img {
    max-height: calc(100dvh - 120px) !important;
  }
}

/* ===== v13 professional layout refresh ===== */
.sgp-gallery.sgp-type-polaroid .sgp-grid,
.sgp-gallery.sgp-type-fusion .sgp-grid,
.sgp-gallery.sgp-type-mosaic .sgp-grid {
  display: grid;
  gap: clamp(14px, 2vw, 24px);
}

.sgp-gallery.sgp-type-polaroid .sgp-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 250px), 1fr));
}
.sgp-gallery.sgp-type-polaroid .sgp-item {
  background: #fff;
  border: 1px solid rgba(192,132,252,.22);
  border-radius: 18px;
  padding: 14px 14px 18px;
  box-shadow: 0 18px 38px rgba(17,24,39,.10);
  transform: none !important;
  transition: transform .18s ease, box-shadow .18s ease;
}
.sgp-gallery.sgp-type-polaroid .sgp-item:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 22px 46px rgba(109,40,217,.14);
}
.sgp-gallery.sgp-type-polaroid .sgp-media {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
}
.sgp-gallery.sgp-type-polaroid .sgp-item::after {
  content: '' !important;
  display: none !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below {
  margin-top: 12px;
  padding: 0 4px;
}
.sgp-gallery.sgp-type-polaroid .sgp-title {
  color: #6d28d9;
  font-weight: 700;
}

.sgp-gallery.sgp-type-fusion .sgp-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-flow: dense;
}
.sgp-gallery.sgp-type-fusion .sgp-item {
  grid-column: span 4;
  border-radius: 22px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(192,132,252,.14), rgba(255,255,255,.98));
  border: 1px solid rgba(192,132,252,.16);
  box-shadow: 0 16px 36px rgba(109,40,217,.12);
}
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+1),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+4) {
  grid-column: span 7;
}
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+2),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+3),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+5),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+6) {
  grid-column: span 5;
}
.sgp-gallery.sgp-type-fusion .sgp-media {
  min-height: 100%;
}
.sgp-gallery.sgp-type-fusion .sgp-thumb__below {
  padding: 10px 12px 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.70), rgba(255,255,255,.96));
}

.sgp-gallery.sgp-type-mosaic .sgp-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-flow: dense;
}
.sgp-gallery.sgp-type-mosaic .sgp-item {
  grid-column: span 4;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(17,24,39,.06);
  box-shadow: 0 12px 28px rgba(17,24,39,.08);
}
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+1) { grid-column: span 6; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+2) { grid-column: span 3; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+3) { grid-column: span 3; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+4) { grid-column: span 5; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+5) { grid-column: span 4; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+6) { grid-column: span 3; }
.sgp-gallery.sgp-type-mosaic .sgp-media,
.sgp-gallery.sgp-type-polaroid .sgp-media,
.sgp-gallery.sgp-type-fusion .sgp-media {
  position: relative;
}
.sgp-gallery.sgp-type-mosaic .sgp-thumb__below {
  padding: 10px 12px 14px;
  background: rgba(255,255,255,.96);
}
.sgp-gallery.sgp-type-polaroid .sgp-img,
.sgp-gallery.sgp-type-fusion .sgp-img,
.sgp-gallery.sgp-type-mosaic .sgp-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 1024px) {
  .sgp-gallery.sgp-type-fusion .sgp-item,
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(n),
  .sgp-gallery.sgp-type-mosaic .sgp-item,
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(n) {
    grid-column: span 6;
  }
}
@media (max-width: 767px) {
  .sgp-gallery.sgp-type-polaroid .sgp-grid,
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid {
    grid-template-columns: 1fr 1fr;
  }
  .sgp-gallery.sgp-type-polaroid .sgp-item,
  .sgp-gallery.sgp-type-fusion .sgp-item,
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(n),
  .sgp-gallery.sgp-type-mosaic .sgp-item,
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(n) {
    grid-column: span 1;
  }
}
@media (max-width: 520px) {
  .sgp-gallery.sgp-type-polaroid .sgp-grid,
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid {
    grid-template-columns: 1fr;
  }
}

/* ===== v14 final sidebar-safe viewer + polished layouts ===== */
.sgp-viewer {
  --sgp-viewer-card-bg: rgba(255,255,255,.94);
  --sgp-viewer-card-border: rgba(167,139,250,.22);
}
.sgp-viewer__stage {
  left: var(--sgp-safe-left, 10px) !important;
  right: auto !important;
  width: var(--sgp-safe-width, calc(100vw - 20px)) !important;
  max-width: var(--sgp-safe-width, calc(100vw - 20px)) !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}
.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer__below {
  max-width: var(--sgp-safe-width, calc(100vw - 20px)) !important;
  box-sizing: border-box !important;
}
.sgp-viewer__main {
  justify-content: center !important;
  align-items: center !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  max-width: min(var(--sgp-viewer-between-nav, calc(100vw - 160px)), calc(var(--sgp-safe-width, 100vw) - 96px)) !important;
  box-sizing: border-box !important;
}
.sgp-viewer__img {
  display: block;
  margin-inline: auto !important;
}
@media (max-width: 980px) and (orientation: landscape) {
  .sgp-viewer__stage {
    padding-block: 8px !important;
  }
  .sgp-viewer__img {
    max-height: calc(100dvh - 116px) !important;
  }
}

/* Polaroid layout like reference screenshot */
.sgp-gallery.sgp-type-polaroid {
  --sgp-polaroid-paper: #f7f7f5;
  --sgp-polaroid-edge: #e9e6df;
  --sgp-polaroid-shadow: 0 8px 22px rgba(15, 23, 42, .12);
  --sgp-polaroid-tape: rgba(202, 180, 135, .45);
}
.sgp-gallery.sgp-type-polaroid .sgp-grid {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)) !important;
  gap: clamp(24px, 3vw, 48px) !important;
  align-items: start;
}
.sgp-gallery.sgp-type-polaroid .sgp-item {
  position: relative;
  background: var(--sgp-polaroid-paper);
  border: 1px solid var(--sgp-polaroid-edge);
  border-radius: 2px !important;
  padding: 12px 12px 52px !important;
  box-shadow: var(--sgp-polaroid-shadow) !important;
  transform: none !important;
  overflow: visible !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-item::before {
  content: '';
  position: absolute;
  top: -10px;
  left: 50%;
  width: 58px;
  height: 26px;
  transform: translateX(-50%);
  background: var(--sgp-polaroid-tape);
  border: 1px solid rgba(182, 154, 96, .20);
  border-radius: 2px;
  box-shadow: 0 1px 0 rgba(255,255,255,.45) inset;
  z-index: 3;
}
.sgp-gallery.sgp-type-polaroid .sgp-item::after {
  display: none !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-item:hover {
  transform: translateY(-4px) rotate(.3deg) !important;
  box-shadow: 0 14px 28px rgba(109,40,217,.16) !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-media {
  background: #fff;
  border-radius: 0 !important;
  overflow: hidden;
  aspect-ratio: 1 / 0.82;
}
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 14px;
  min-height: 28px;
  margin: 0 !important;
  padding: 0 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: transparent !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-title {
  font-family: "Segoe Print", "Bradley Hand", "Comic Sans MS", cursive;
  font-size: clamp(18px, 1.35vw, 24px);
  font-weight: 400;
  line-height: 1.1;
  color: #7c6f5a;
}
.sgp-gallery.sgp-type-polaroid .sgp-excerpt,
.sgp-gallery.sgp-type-polaroid .sgp-description {
  display: none !important;
}

/* Fusion: cleaner editorial collage */
.sgp-gallery.sgp-type-fusion .sgp-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  gap: clamp(14px, 1.8vw, 24px) !important;
  align-items: stretch;
}
.sgp-gallery.sgp-type-fusion .sgp-item {
  grid-column: span 4;
  position: relative;
  border-radius: 22px !important;
  overflow: hidden !important;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,243,255,.96));
  border: 1px solid rgba(167,139,250,.20);
  box-shadow: 0 16px 36px rgba(88, 28, 135, .10);
}
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+1),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+4) {
  grid-column: span 7;
}
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+2),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+3),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+5),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+6) {
  grid-column: span 5;
}
.sgp-gallery.sgp-type-fusion .sgp-media {
  aspect-ratio: 1 / .82;
  min-height: auto !important;
}
.sgp-gallery.sgp-type-fusion .sgp-thumb__below {
  padding: 14px 16px 16px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.74), rgba(255,255,255,.96));
  backdrop-filter: blur(6px);
}
.sgp-gallery.sgp-type-fusion .sgp-title {
  font-size: clamp(16px, 1.2vw, 20px);
  font-weight: 700;
  color: #3b0764;
}
.sgp-gallery.sgp-type-fusion .sgp-excerpt,
.sgp-gallery.sgp-type-fusion .sgp-description {
  color: rgba(76, 29, 149, .74);
}

/* Mosaic: premium balanced blocks */
.sgp-gallery.sgp-type-mosaic .sgp-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  gap: clamp(12px, 1.6vw, 20px) !important;
  grid-auto-flow: dense;
}
.sgp-gallery.sgp-type-mosaic .sgp-item {
  grid-column: span 4;
  border-radius: 18px !important;
  overflow: hidden !important;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, .06);
  box-shadow: 0 12px 28px rgba(15, 23, 42, .08);
}
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+1) { grid-column: span 5; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+2) { grid-column: span 4; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+3) { grid-column: span 3; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+4) { grid-column: span 3; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+5) { grid-column: span 6; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+6) { grid-column: span 3; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+7) { grid-column: span 4; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(8n+8) { grid-column: span 5; }
.sgp-gallery.sgp-type-mosaic .sgp-media {
  aspect-ratio: 1 / .78;
}
.sgp-gallery.sgp-type-mosaic .sgp-thumb__below {
  padding: 12px 14px 14px !important;
  background: rgba(255,255,255,.96);
  border-top: 1px solid rgba(167,139,250,.14);
}
.sgp-gallery.sgp-type-mosaic .sgp-title {
  color: #4c1d95;
  font-size: clamp(15px, 1.1vw, 18px);
  font-weight: 700;
}

/* Nicer viewer style for the three new layouts */
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__frame {
  background: transparent !important;
}
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__media .sgp-item {
  background: var(--sgp-viewer-card-bg);
  border: 1px solid var(--sgp-viewer-card-border);
  border-radius: 22px;
  padding: 14px;
  box-shadow: 0 24px 64px rgba(15, 23, 42, .18);
}
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__media .sgp-media {
  border-radius: 16px;
  overflow: hidden;
}
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__below,
.sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__below,
.sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__below {
  margin-top: 12px;
  padding: 12px 16px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(167,139,250,.18);
  border-radius: 18px;
  box-shadow: 0 16px 40px rgba(15,23,42,.08);
}

@media (max-width: 1024px) {
  .sgp-gallery.sgp-type-fusion .sgp-item,
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(n),
  .sgp-gallery.sgp-type-mosaic .sgp-item,
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(n) {
    grid-column: span 6 !important;
  }
}
@media (max-width: 767px) {
  .sgp-gallery.sgp-type-polaroid .sgp-grid,
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid {
    grid-template-columns: 1fr 1fr !important;
  }
  .sgp-gallery.sgp-type-polaroid .sgp-item,
  .sgp-gallery.sgp-type-fusion .sgp-item,
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(n),
  .sgp-gallery.sgp-type-mosaic .sgp-item,
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(n) {
    grid-column: span 1 !important;
  }
}
@media (max-width: 520px) {
  .sgp-gallery.sgp-type-polaroid .sgp-grid,
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid {
    grid-template-columns: 1fr !important;
  }
}


/* v15 targeted fixes */
.sgp-gallery.sgp-type-polaroid .sgp-item {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-media {
  flex: 0 0 auto;
}
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below {
  position: static !important;
  inset: auto !important;
  min-height: 0 !important;
  padding: 14px 8px 2px !important;
  margin: 0 !important;
  background: transparent !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below .sgp-title {
  margin: 0;
}
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below .sgp-overlay-toggle {
  min-width: 132px;
}
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item {
  background: #f7f7f5;
  border-radius: 4px;
  padding: 14px 14px 22px;
}
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item::before {
  content: '';
  position: absolute;
  top: -10px;
  left: 50%;
  width: 60px;
  height: 24px;
  transform: translateX(-50%);
  background: rgba(202, 180, 135, .45);
  border-radius: 2px;
}
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__below {
  background: rgba(255,255,255,.96);
}
.sgp-gallery.sgp-type-fusion .sgp-thumb__below,
.sgp-gallery.sgp-type-mosaic .sgp-thumb__below {
  align-items: flex-start !important;
  text-align: left !important;
}
.sgp-gallery.sgp-type-fusion .sgp-title,
.sgp-gallery.sgp-type-mosaic .sgp-title {
  width: 100%;
}
@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer__stage {
    padding-inline: 10px !important;
  }
  .sgp-viewer__frame,
  .sgp-viewer__main,
  .sgp-viewer__below {
    max-width: 100% !important;
  }
}


/* ===== v17 strict viewer centering + fixed custom columns ===== */
.sgp-viewer__stage,
.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer .sgp-viewer__below,
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media,
.sgp-viewer__img {
  box-sizing: border-box !important;
}
.sgp-viewer__main {
  justify-items: center !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  justify-self: center !important;
  align-self: center !important;
  margin-inline: auto !important;
  inset-inline: auto !important;
}
.sgp-viewer__img {
  display: block !important;
  margin-inline: auto !important;
  object-position: center center !important;
}
@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer__stage {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}
.sgp-gallery.sgp-cols-fixed.sgp-type-polaroid .sgp-grid,
.sgp-gallery.sgp-cols-fixed.sgp-type-fusion .sgp-grid,
.sgp-gallery.sgp-cols-fixed.sgp-type-mosaic .sgp-grid {
  grid-template-columns: repeat(var(--sgp-columns), minmax(0, 1fr)) !important;
}
.sgp-gallery.sgp-cols-fixed.sgp-type-fusion .sgp-item,
.sgp-gallery.sgp-cols-fixed.sgp-type-fusion .sgp-item:nth-child(n),
.sgp-gallery.sgp-cols-fixed.sgp-type-mosaic .sgp-item,
.sgp-gallery.sgp-cols-fixed.sgp-type-mosaic .sgp-item:nth-child(n) {
  grid-column: span 1 !important;
  grid-row: auto !important;
}
.sgp-gallery.sgp-cols-fixed.sgp-type-polaroid .sgp-item {
  transform: none !important;
}


/* v18 viewer hard-centering and swipe support */
.sgp-viewer[aria-hidden="false"] .sgp-viewer__stage,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__main,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__mediawrap,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-item,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-media,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__img {
  margin-left: auto !important;
  margin-right: auto !important;
  left: auto !important;
  right: auto !important;
  transform: translateX(0) !important;
  translate: none !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__stage,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__img {
  max-inline-size: 100% !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__stage,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__mediawrap,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__img {
  touch-action: none !important;
}


/* v19 final viewer + special layout corrections */
.sgp-viewer {
  overflow: hidden !important;
}
.sgp-viewer__stage {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 10px !important;
  box-sizing: border-box !important;
}
.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer__below {
  width: min(var(--sgp-safe-width, 94vw), calc(100vw - 20px)) !important;
  max-width: min(var(--sgp-safe-width, 94vw), calc(100vw - 20px)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-viewer__main {
  grid-template-columns: var(--sgp-nav-col, 56px) minmax(0, 1fr) var(--sgp-nav-col, 56px) !important;
  column-gap: var(--sgp-main-gap, 16px) !important;
  justify-items: center !important;
  align-items: center !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  width: 100% !important;
  max-width: var(--sgp-viewer-between-nav, calc(100vw - 160px)) !important;
  min-width: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
  justify-self: center !important;
}
.sgp-viewer__img {
  display: block !important;
  width: auto !important;
  max-width: min(100%, var(--sgp-viewer-between-nav, calc(100vw - 160px))) !important;
  height: auto !important;
  margin-left: auto !important;
  margin-right: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
}
.sgp-viewer__navcol {
  width: var(--sgp-nav-col, 56px) !important;
  min-width: var(--sgp-nav-col, 56px) !important;
}
.sgp-viewer__navcol--prev { justify-content: flex-start !important; }
.sgp-viewer__navcol--next { justify-content: flex-end !important; }

.sgp-gallery.sgp-type-fusion .sgp-grid,
.sgp-gallery.sgp-type-mosaic .sgp-grid {
  display: grid !important;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: clamp(12px, 1.6vw, 18px);
}
.sgp-gallery.sgp-type-fusion .sgp-item,
.sgp-gallery.sgp-type-mosaic .sgp-item {
  grid-column: span 4;
  border-radius: calc(var(--sgp-image-radius) + 10px) !important;
  overflow: hidden !important;
}
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+1),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+4),
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+1),
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+4) {
  grid-column: span 6;
}
.sgp-gallery.sgp-type-fusion .sgp-media,
.sgp-gallery.sgp-type-mosaic .sgp-media {
  min-height: 100%;
  background: #fff;
}
.sgp-gallery.sgp-cols-fixed.sgp-type-fusion .sgp-grid,
.sgp-gallery.sgp-cols-fixed.sgp-type-mosaic .sgp-grid {
  grid-template-columns: repeat(var(--sgp-columns), minmax(0, 1fr)) !important;
}
/* cancel old v18 flattening */
.sgp-gallery.sgp-cols-fixed.sgp-type-fusion .sgp-item,
.sgp-gallery.sgp-cols-fixed.sgp-type-fusion .sgp-item:nth-child(n),
.sgp-gallery.sgp-cols-fixed.sgp-type-mosaic .sgp-item,
.sgp-gallery.sgp-cols-fixed.sgp-type-mosaic .sgp-item:nth-child(n) {
  grid-row: auto !important;
}
@media (max-width: 900px) {
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  }
  .sgp-gallery.sgp-type-fusion .sgp-item,
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(n),
  .sgp-gallery.sgp-type-mosaic .sgp-item,
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(n) {
    grid-column: span 3;
  }
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+1),
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+4),
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+1),
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+4) {
    grid-column: span 6;
  }
}
@media (max-width: 640px) {
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .sgp-gallery.sgp-type-fusion .sgp-item,
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(n),
  .sgp-gallery.sgp-type-mosaic .sgp-item,
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(n) {
    grid-column: span 1 !important;
  }
}


/* v20 final corrections */
.sgp-viewer,
.sgp-viewer__stage,
.sgp-viewer__frame,
.sgp-viewer__main,
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media,
.sgp-viewer__img {
  transform: none !important;
  translate: none !important;
}

.sgp-viewer__stage {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 10px !important;
  box-sizing: border-box !important;
}

.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer__below {
  width: min(var(--sgp-viewer-main-width, var(--sgp-safe-width, calc(100vw - 20px))), calc(100vw - 20px)) !important;
  max-width: min(var(--sgp-viewer-main-width, var(--sgp-safe-width, calc(100vw - 20px))), calc(100vw - 20px)) !important;
  margin-inline: auto !important;
}

.sgp-viewer__main {
  grid-template-columns: var(--sgp-nav-col, 56px) minmax(0, var(--sgp-viewer-between-nav, calc(100vw - 160px))) var(--sgp-nav-col, 56px) !important;
  column-gap: var(--sgp-main-gap, 16px) !important;
  justify-content: center !important;
  justify-items: center !important;
  align-items: center !important;
}

.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  width: 100% !important;
  max-width: var(--sgp-viewer-between-nav, calc(100vw - 160px)) !important;
  min-width: 0 !important;
  margin-inline: auto !important;
  justify-self: center !important;
  align-self: center !important;
}

.sgp-viewer__img {
  display: block !important;
  width: auto !important;
  max-width: min(100%, var(--sgp-viewer-between-nav, calc(100vw - 160px))) !important;
  max-height: calc(100dvh - 132px) !important;
  margin-inline: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img {
  max-height: calc(100dvh - 132px) !important;
}

.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__img {
  touch-action: pan-y !important;
}

/* make the three new layouts look distinct again */
.sgp-gallery.sgp-type-fusion .sgp-grid,
.sgp-gallery.sgp-type-mosaic .sgp-grid {
  grid-auto-flow: dense !important;
  gap: clamp(12px, 1.4vw, 18px) !important;
}

.sgp-gallery.sgp-type-fusion .sgp-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
}
.sgp-gallery.sgp-type-fusion .sgp-item {
  grid-column: span 4;
  background: #fff !important;
  border-radius: 18px !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, .10) !important;
}
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+1),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+4) { grid-column: span 8 !important; }
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+2),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+3),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+5),
.sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+6) { grid-column: span 4 !important; }

.sgp-gallery.sgp-type-mosaic .sgp-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
}
.sgp-gallery.sgp-type-mosaic .sgp-item {
  background: #fff !important;
  border-radius: 18px !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, .10) !important;
}
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+1) { grid-column: span 6 !important; grid-row: span 2 !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+2) { grid-column: span 3 !important; grid-row: span 2 !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+3) { grid-column: span 3 !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+4) { grid-column: span 5 !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+5) { grid-column: span 4 !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+6) { grid-column: span 3 !important; }

.sgp-gallery.sgp-type-fusion .sgp-media,
.sgp-gallery.sgp-type-mosaic .sgp-media,
.sgp-gallery.sgp-type-polaroid .sgp-media {
  min-height: 100% !important;
}

@media (max-width: 980px) {
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  }
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+1),
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+4),
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+1) { grid-column: span 6 !important; }
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(n),
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(n) { grid-row: span 1 !important; }
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+2),
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+3),
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+4),
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+5),
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(6n+6),
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+2),
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+3),
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+5),
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(6n+6) { grid-column: span 3 !important; }
}

@media (max-width: 640px) {
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid {
    grid-template-columns: 1fr !important;
  }
  .sgp-gallery.sgp-type-fusion .sgp-item:nth-child(n),
  .sgp-gallery.sgp-type-mosaic .sgp-item:nth-child(n) {
    grid-column: span 1 !important;
    grid-row: span 1 !important;
  }
}


/* v21 final repairs */
.sgp-viewer,
.sgp-viewer__stage,
.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media,
.sgp-viewer__img {
  transform: none !important;
  translate: none !important;
}
.sgp-viewer__stage {
  position: fixed !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding-left: var(--sgp-stage-left, 10px) !important;
  padding-right: var(--sgp-stage-right, 10px) !important;
  padding-top: 10px !important;
  padding-bottom: 10px !important;
  box-sizing: border-box !important;
}
.sgp-viewer__frame {
  width: min(var(--sgp-viewer-main-width, calc(100vw - 20px)), calc(100vw - var(--sgp-stage-left, 10px) - var(--sgp-stage-right, 10px))) !important;
  max-width: min(var(--sgp-viewer-main-width, calc(100vw - 20px)), calc(100vw - var(--sgp-stage-left, 10px) - var(--sgp-stage-right, 10px))) !important;
  margin-inline: auto !important;
}
.sgp-viewer__main {
  display: grid !important;
  grid-template-columns: var(--sgp-nav-col, 48px) minmax(0, var(--sgp-viewer-between-nav, calc(100vw - 160px))) var(--sgp-nav-col, 48px) !important;
  column-gap: var(--sgp-main-gap, 16px) !important;
  align-items: center !important;
  justify-items: center !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  width: var(--sgp-viewer-between-nav, calc(100vw - 160px)) !important;
  max-width: var(--sgp-viewer-between-nav, calc(100vw - 160px)) !important;
  min-width: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-inline: auto !important;
  overflow: hidden !important;
}
.sgp-viewer__img {
  display: block !important;
  width: auto !important;
  max-width: min(100%, var(--sgp-viewer-between-nav, calc(100vw - 160px))) !important;
  height: auto !important;
  max-height: calc(100dvh - 132px) !important;
  margin-inline: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
  user-select: none !important;
  -webkit-user-drag: none !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__img { touch-action: pan-y !important; }
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__frame {
  border-radius: 22px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(250,247,255,.94)) !important;
  box-shadow: 0 30px 80px rgba(23, 16, 48, .22) !important;
}
.sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__below,
.sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__below,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__below {
  padding-top: 14px !important;
}

.sgp-gallery.sgp-type-fusion .sgp-grid {
  display: grid !important;
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  grid-auto-flow: dense !important;
  gap: clamp(12px, 1.3vw, 18px) !important;
}
.sgp-gallery.sgp-type-fusion .sgp-item {
  overflow: hidden !important;
  border-radius: 20px !important;
  background: #fff !important;
  box-shadow: 0 12px 34px rgba(15,23,42,.10) !important;
}
.sgp-gallery.sgp-type-fusion .sgp-item[data-sgp-shape="wide"] { grid-column: span 8 !important; }
.sgp-gallery.sgp-type-fusion .sgp-item[data-sgp-shape="card"] { grid-column: span 4 !important; }
.sgp-gallery.sgp-type-fusion .sgp-media { aspect-ratio: 4 / 5; }
.sgp-gallery.sgp-type-fusion .sgp-item[data-sgp-shape="wide"] .sgp-media { aspect-ratio: 16 / 10; }

.sgp-gallery.sgp-type-mosaic .sgp-grid {
  display: grid !important;
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  grid-auto-flow: dense !important;
  gap: clamp(12px, 1.3vw, 18px) !important;
}
.sgp-gallery.sgp-type-mosaic .sgp-item {
  overflow: hidden !important;
  border-radius: 20px !important;
  background: #fff !important;
  box-shadow: 0 12px 34px rgba(15,23,42,.10) !important;
}
.sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="hero"] { grid-column: span 6 !important; grid-row: span 2 !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="tall"] { grid-column: span 3 !important; grid-row: span 2 !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="landscape"] { grid-column: span 5 !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="card"] { grid-column: span 3 !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="hero"] .sgp-media { aspect-ratio: 4 / 5; }
.sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="tall"] .sgp-media { aspect-ratio: 3 / 5; }
.sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="landscape"] .sgp-media { aspect-ratio: 16 / 10; }
.sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="card"] .sgp-media { aspect-ratio: 4 / 5; }

.sgp-gallery.sgp-cols-fixed.sgp-type-fusion .sgp-grid,
.sgp-gallery.sgp-cols-fixed.sgp-type-mosaic .sgp-grid {
  grid-template-columns: repeat(var(--sgp-columns), minmax(0,1fr)) !important;
}
@media (max-width: 900px) {
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid { grid-template-columns: repeat(6, minmax(0, 1fr)) !important; }
  .sgp-gallery.sgp-type-fusion .sgp-item[data-sgp-shape="wide"],
  .sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="hero"] { grid-column: span 6 !important; }
  .sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="tall"],
  .sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="landscape"],
  .sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="card"],
  .sgp-gallery.sgp-type-fusion .sgp-item[data-sgp-shape="card"] { grid-column: span 3 !important; grid-row: span 1 !important; }
}
@media (max-width: 640px) {
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .sgp-gallery.sgp-type-fusion .sgp-item,
  .sgp-gallery.sgp-type-fusion .sgp-item[data-sgp-shape],
  .sgp-gallery.sgp-type-mosaic .sgp-item,
  .sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape] { grid-column: span 1 !important; grid-row: span 1 !important; }
  .sgp-gallery.sgp-type-fusion .sgp-media,
  .sgp-gallery.sgp-type-mosaic .sgp-media { aspect-ratio: 4 / 5 !important; }
}


/* ===== v22 final viewer cleanup + layout fixes ===== */
.sgp-viewer,
.sgp-viewer * { box-sizing: border-box !important; }
.sgp-viewer { background: rgba(17,17,17,.82) !important; }
.sgp-viewer__stage,
.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__below {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}
.sgp-viewer__frame {
  width: min(var(--sgp-safe-width, 92vw), 1320px) !important;
  max-width: min(var(--sgp-safe-width, 92vw), 1320px) !important;
  gap: 14px !important;
}
.sgp-viewer__main {
  width: min(var(--sgp-safe-width, 92vw), 1320px) !important;
  max-width: min(var(--sgp-safe-width, 92vw), 1320px) !important;
  grid-template-columns: var(--sgp-nav-col,48px) minmax(0,var(--sgp-viewer-between-nav,900px)) var(--sgp-nav-col,48px) !important;
  column-gap: var(--sgp-main-gap,14px) !important;
  align-items: center !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer .sgp-media {
  width: var(--sgp-viewer-between-nav,900px) !important;
  max-width: var(--sgp-viewer-between-nav,900px) !important;
  justify-self: center !important;
  align-self: center !important;
}
.sgp-viewer__img {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: var(--sgp-viewer-between-nav,900px) !important;
  max-height: var(--sgp-viewer-img-maxh,calc(100vh - 160px)) !important;
  margin: 0 auto !important;
  object-fit: contain !important;
}
.sgp-viewer__below { gap: 10px !important; }
.sgp-viewer__protools {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding-top: 2px !important;
}
.sgp-viewer .sgp-overlay-inner {
  background: rgba(255,255,255,.18) !important;
  color: #fff !important;
}
.sgp-viewer__nav { box-shadow: 0 6px 20px rgba(0,0,0,.18) !important; }
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__frame {
  width: min(var(--sgp-safe-width,92vw),1320px) !important;
  max-width: min(var(--sgp-safe-width,92vw),1320px) !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-grid {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
  gap: max(22px, var(--sgp-row-gap)) max(22px, var(--sgp-col-gap)) !important;
  align-items: start !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-item {
  padding: 12px 12px 16px !important;
  background: #fff !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.10) !important;
  transform: none !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-media { background: #fff !important; border-radius: 0 !important; }
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below { margin-top: 10px !important; padding: 0 !important; min-height: 0 !important; }
.sgp-gallery.sgp-type-polaroid .sgp-title { margin: 0 !important; }
.sgp-gallery.sgp-type-fusion .sgp-grid,
.sgp-gallery.sgp-type-mosaic .sgp-grid {
  display: grid !important;
  align-items: stretch !important;
  gap: var(--sgp-row-gap) var(--sgp-col-gap) !important;
}
.sgp-gallery.sgp-type-fusion .sgp-item,
.sgp-gallery.sgp-type-mosaic .sgp-item {
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
}
.sgp-gallery.sgp-type-fusion .sgp-item[data-sgp-shape="wide"] { grid-column: span 2 !important; }
.sgp-gallery.sgp-type-fusion .sgp-item[data-sgp-shape="card"] { grid-column: span 1 !important; }
.sgp-gallery.sgp-type-fusion .sgp-media,
.sgp-gallery.sgp-type-mosaic .sgp-media { height: clamp(240px, 34vw, var(--sgp-item-height)) !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="hero"] { grid-column: span 2 !important; grid-row: span 2 !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="tall"] { grid-row: span 2 !important; }
.sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape="landscape"] { grid-column: span 2 !important; }
@media (max-width: 900px) {
  .sgp-gallery.sgp-type-fusion .sgp-grid,
  .sgp-gallery.sgp-type-mosaic .sgp-grid { grid-template-columns: repeat(var(--sgp-columns, 2), minmax(0, 1fr)) !important; }
  .sgp-gallery.sgp-type-fusion .sgp-item[data-sgp-shape],
  .sgp-gallery.sgp-type-mosaic .sgp-item[data-sgp-shape] { grid-column: span 1 !important; grid-row: span 1 !important; }
}
@media (max-width: 700px) {
  .sgp-viewer__stage { padding-top: 14px !important; padding-bottom: 14px !important; }
  .sgp-viewer__frame,
  .sgp-viewer__main,
  .sgp-viewer__topbar,
  .sgp-viewer__below {
    width: min(var(--sgp-safe-width,100vw), calc(100vw - var(--sgp-safe-left,10px) - var(--sgp-safe-right,10px))) !important;
    max-width: min(var(--sgp-safe-width,100vw), calc(100vw - var(--sgp-safe-left,10px) - var(--sgp-safe-right,10px))) !important;
  }
}


/* ===== v24 final viewer + responsive column fixes ===== */
.sgp-gallery.sgp-cols-fixed .sgp-grid {
  grid-template-columns: repeat(var(--sgp-effective-columns, var(--sgp-columns)), minmax(0, 1fr)) !important;
}
.sgp-gallery.sgp-cols-fixed.sgp-type-masonry .sgp-masonry {
  column-count: var(--sgp-effective-columns, var(--sgp-columns)) !important;
}

.sgp-viewer {
  background: rgba(15, 23, 42, .78) !important;
}
.sgp-viewer__stage {
  inset: 0 !important;
  padding: 18px 10px !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  background: transparent !important;
}
.sgp-viewer__frame,
.sgp-viewer__topbar,
.sgp-viewer__main,
.sgp-viewer .sgp-viewer__below,
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}
.sgp-viewer__frame {
  width: min(1240px, calc(100vw - 20px)) !important;
  max-width: min(1240px, calc(100vw - 20px)) !important;
}
.sgp-viewer__main {
  width: 100% !important;
  align-items: center !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  min-height: 0 !important;
  width: 100% !important;
}
.sgp-viewer__img {
  display: block !important;
  margin: 0 auto !important;
  max-width: 100% !important;
  max-height: min(78vh, 920px) !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
  border-radius: 16px !important;
}
.sgp-viewer .sgp-viewer__below {
  width: 100% !important;
  max-width: 100% !important;
  padding-top: 14px !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img {
  max-height: min(80vh, 940px) !important;
}
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item::before,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item::after {
  content: none !important;
  display: none !important;
}
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item {
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-grid {
  grid-template-columns: repeat(var(--sgp-effective-columns, auto-fit), minmax(min(100%, 220px), 1fr)) !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-item {
  transform: none !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below {
  margin-top: 12px !important;
}
@media (max-width: 1024px) {
  .sgp-gallery.sgp-cols-fixed .sgp-grid {
    grid-template-columns: repeat(var(--sgp-effective-columns, 3), minmax(0, 1fr)) !important;
  }
}
@media (max-width: 780px) {
  .sgp-gallery.sgp-cols-fixed .sgp-grid {
    grid-template-columns: repeat(var(--sgp-effective-columns, 2), minmax(0, 1fr)) !important;
  }
  .sgp-gallery.sgp-cols-fixed.sgp-type-masonry .sgp-masonry {
    column-count: var(--sgp-effective-columns, 2) !important;
  }
  .sgp-viewer__frame {
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
  }
}
@media (max-width: 520px) {
  .sgp-gallery.sgp-cols-fixed .sgp-grid {
    grid-template-columns: 1fr !important;
  }
  .sgp-gallery.sgp-cols-fixed.sgp-type-masonry .sgp-masonry {
    column-count: 1 !important;
  }
}

/* ===== v25 grid viewer must match masonry viewer ===== */
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__frame {
  width: min(1240px, calc(100vw - 20px)) !important;
  max-width: min(1240px, calc(100vw - 20px)) !important;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__main {
  width: 100% !important;
  max-width: 100% !important;
  display: grid !important;
  grid-template-columns: var(--sgp-nav-col, 56px) minmax(0, var(--sgp-viewer-between-nav, 1fr)) var(--sgp-nav-col, 56px) !important;
  gap: var(--sgp-main-gap, 16px) !important;
  align-items: center !important;
  justify-content: center !important;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-media {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  justify-content: center !important;
  align-items: center !important;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img {
  width: auto !important;
  height: auto !important;
  max-width: min(100%, var(--sgp-viewer-between-nav, calc(100vw - 140px))) !important;
  max-height: min(80vh, 940px) !important;
  object-fit: contain !important;
  object-position: center center !important;
  margin-inline: auto !important;
}

@media (max-width: 780px) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__main {
    grid-template-columns: 40px minmax(0, 1fr) 40px !important;
    gap: 10px !important;
  }

  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img {
    max-width: min(100%, calc(100vw - 120px)) !important;
    max-height: min(74vh, 760px) !important;
  }
}


/* v26: grid viewer uses masonry viewer sizing, independent from item width */
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__stage,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__stage,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__stage {
  padding: 18px 14px 20px !important;
}
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__frame {
  width: min(1100px, calc(100vw - 120px)) !important;
  max-width: min(1100px, calc(100vw - 120px)) !important;
}
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img {
  width: auto !important;
  max-width: min(100%, calc(100vw - 160px)) !important;
  max-height: min(72vh, calc(100vh - 220px)) !important;
  object-fit: contain !important;
}
@media (max-width: 700px) {
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__frame,
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__frame {
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
  }
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img {
    max-width: calc(100vw - 96px) !important;
    max-height: calc(100vh - 180px) !important;
  }
}


/* ===== v27 final: grid viewer must match masonry viewer and ignore thumb custom size ===== */
.sgp-viewer[data-gallery-type="grid"],
.sgp-viewer[data-gallery-type="masonry"],
.sgp-viewer[data-gallery-type="polaroid"] {
  --sgp-gridlike-viewer-maxw: min(1320px, var(--sgp-safe-width, calc(100vw - 20px)));
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__main {
  width: var(--sgp-gridlike-viewer-maxw) !important;
  max-width: var(--sgp-gridlike-viewer-maxw) !important;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-media {
  width: var(--sgp-viewer-between-nav, calc(100vw - 160px)) !important;
  max-width: var(--sgp-viewer-between-nav, calc(100vw - 160px)) !important;
  min-width: 0 !important;
}

.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  max-width: var(--sgp-viewer-between-nav, calc(100vw - 160px)) !important;
  max-height: min(82vh, var(--sgp-viewer-img-maxh, calc(100vh - 160px))) !important;
  margin-inline: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
}


/* ===== v28 final viewer + grid/masonry parity ===== */
/* Use one clean viewer style for masonry, grid and polaroid. */
.sgp-viewer[data-gallery-type="grid"],
.sgp-viewer[data-gallery-type="masonry"],
.sgp-viewer[data-gallery-type="polaroid"] {
  --sgp-viewer-clean-width: min(1180px, calc(100vw - 20px));
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__topbar,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__below,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__topbar,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__below,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__topbar,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__main,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__below {
  width: var(--sgp-viewer-clean-width) !important;
  max-width: var(--sgp-viewer-clean-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__main {
  grid-template-columns: var(--sgp-nav-size, 48px) minmax(0, 1fr) var(--sgp-nav-size, 48px) !important;
  column-gap: clamp(8px, 1.2vw, 16px) !important;
  align-items: center !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__frame,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__mediawrap,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-media {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img {
  width: auto !important;
  max-width: min(100%, calc(100vw - (var(--sgp-nav-size, 48px) * 2) - 54px)) !important;
  max-height: calc(100dvh - 150px) !important;
  height: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
  margin: 0 auto !important;
  background: transparent !important;
}
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item::before,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item::after {
  content: none !important;
  display: none !important;
}
.sgp-viewer .sgp-viewer__below {
  align-items: stretch !important;
}
.sgp-viewer .sgp-viewer__below .sgp-viewer__protools,
.sgp-viewer .sgp-viewer__below .sgp-social,
.sgp-viewer .sgp-viewer__below .sgp-slider__dots-wrap,
.sgp-viewer .sgp-viewer__below .sgp-slider__counter,
.sgp-viewer .sgp-viewer__below .sgp-overlay-toggle {
  align-self: center !important;
}
.sgp-viewer .sgp-meta-panel {
  width: min(100%, 860px) !important;
  margin: 10px auto 0 !important;
  max-height: min(38dvh, 320px) !important;
  overflow: auto !important;
}
@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img {
    max-width: min(100%, calc(100vw - (var(--sgp-nav-size, 44px) * 2) - 64px)) !important;
    max-height: calc(100dvh - 96px) !important;
  }
}


/* ===== v29 targeted viewer fixes ===== */
.sgp-viewer {
  --sgp-viewer-surface: transparent;
}

.sgp-viewer .sgp-viewer__stage {
  align-items: flex-start !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}

.sgp-viewer .sgp-viewer__frame,
.sgp-viewer .sgp-viewer__topbar,
.sgp-viewer .sgp-viewer__main,
.sgp-viewer .sgp-viewer__below,
.sgp-viewer .sgp-viewer__mediawrap,
.sgp-viewer .sgp-viewer__media,
.sgp-viewer .sgp-viewer__media .sgp-item,
.sgp-viewer .sgp-viewer__media .sgp-media {
  background: transparent !important;
  box-shadow: none !important;
}

.sgp-viewer .sgp-viewer__media .sgp-item,
.sgp-viewer .sgp-viewer__media .sgp-media {
  width: min(var(--sgp-viewer-between-nav, 1100px), 100%) !important;
  max-width: min(var(--sgp-viewer-between-nav, 1100px), 100%) !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: var(--sgp-viewer-img-maxh, 72vh) !important;
  overflow: visible !important;
  align-self: center !important;
}

.sgp-viewer .sgp-viewer__media .sgp-img,
.sgp-viewer .sgp-viewer__img {
  width: 100% !important;
  max-width: min(var(--sgp-viewer-between-nav, 1100px), 100%) !important;
  height: auto !important;
  max-height: var(--sgp-viewer-img-maxh, 72vh) !important;
  object-fit: contain !important;
  object-position: center center !important;
}

.sgp-viewer .sgp-viewer__below {
  max-height: none !important;
  overflow: visible !important;
}

.sgp-viewer .sgp-viewer__below .sgp-meta-panel {
  width: min(var(--sgp-viewer-between-nav, 1100px), 100%) !important;
  max-width: 100% !important;
  overflow: auto !important;
  -webkit-overflow-scrolling: touch;
}

.sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__main,
.sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__below {
  width: min(var(--sgp-safe-width, 1100px), 100%) !important;
  max-width: min(var(--sgp-safe-width, 1100px), 100%) !important;
}

.sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__media .sgp-item,
.sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__media .sgp-media,
.sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__img {
  width: min(var(--sgp-viewer-between-nav, 1100px), 100%) !important;
  max-width: min(var(--sgp-viewer-between-nav, 1100px), 100%) !important;
}

.sgp-viewer[data-source-gallery-type="polaroid"] .sgp-viewer__media .sgp-item::before,
.sgp-viewer[data-source-gallery-type="polaroid"] .sgp-viewer__media .sgp-item::after,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item::before,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item::after {
  display: none !important;
  content: none !important;
}


/* ===== v43 layout safety + polaroid spacing ===== */
.sgp-gallery {
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden !important;
}
.sgp-gallery.sgp-type-slider .sgp-item {
  width: min(100%, var(--sgp-slider-w, min(var(--sgp-item-width), 92vw))) !important;
}
.sgp-viewer__stage {
  padding-top: max(26px, env(safe-area-inset-top, 0px) + 18px) !important;
}
.sgp-viewer .sgp-viewer__main {
  margin-top: 8px !important;
}
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__main {
  margin-top: 18px !important;
}
@media (max-width: 900px) and (orientation: landscape) {
  .sgp-gallery,
  .sgp-gallery .sgp-grid,
  .sgp-gallery .sgp-masonry,
  .sgp-gallery .sgp-slider,
  .sgp-gallery .sgp-track,
  .sgp-gallery .sgp-slide {
    max-width: 100% !important;
    width: 100% !important;
  }
  .sgp-viewer .sgp-viewer__main {
    margin-top: 10px !important;
  }
}

.sgp-usage-badge {
  position: absolute;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  gap: .5em;
  padding: .55em .8em;
  border-radius: 999px;
  background: var(--sgp-usage-badge-bg, rgba(15,23,42,.9));
  color: var(--sgp-usage-badge-color, #fff);
  font-size: var(--sgp-usage-badge-size, 12px);
  font-weight: 700;
  line-height: 1;
  box-shadow: 0 10px 24px rgba(15,23,42,.18);
  pointer-events: none;
  white-space: nowrap;
}
.sgp-usage-badge__ic { width: 1.05em; height: 1.05em; display:inline-flex; flex:0 0 auto; }
.sgp-usage-badge__ic svg { width: 100%; height: 100%; display:block; }
.sgp-usage-badge--top-left { top: 12px; left: 12px; }
.sgp-usage-badge--top-right { top: 12px; right: 12px; }
.sgp-usage-badge--top-center { top: 12px; left: 50%; transform: translateX(-50%); }
.sgp-usage-badge--bottom-left { bottom: 12px; left: 12px; }
.sgp-usage-badge--bottom-center { bottom: 12px; left: 50%; transform: translateX(-50%); }
.sgp-usage-badge--bottom-right { bottom: 12px; right: 12px; }

/* ===== v5 viewer landscape centering + credit line ===== */
@media (max-width: 900px) and (orientation: landscape) {
  .sgp-viewer .sgp-viewer__stage {
    align-items: center !important;
    justify-content: center !important;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }
  .sgp-viewer .sgp-viewer__main,
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__main {
    margin-top: 0 !important;
  }
  .sgp-viewer .sgp-viewer__img {
    max-height: calc(100dvh - 72px) !important;
  }
}

.sgp-credit-line {
  position: absolute;
  z-index: 6;
  display: inline-flex;
  align-items: center;
  gap: .55em;
  max-width: calc(100% - 24px);
  padding: .66em .95em;
  border-radius: 14px;
  background: var(--sgp-credit-line-bg, rgba(17,24,39,.9));
  color: var(--sgp-credit-line-color, #fff);
  font-size: var(--sgp-credit-line-size, 12px);
  line-height: 1.2;
  font-weight: 600;
  letter-spacing: .01em;
  box-shadow: 0 10px 30px rgba(0,0,0,.16);
  backdrop-filter: blur(8px);
}
.sgp-credit-line__ic { width: 1.05em; height: 1.05em; display:inline-flex; flex:0 0 auto; }
.sgp-credit-line__ic svg { width: 100%; height: 100%; display:block; }
.sgp-credit-line__tx { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sgp-credit-line--top-left { top: 12px; left: 12px; }
.sgp-credit-line--top-right { top: 12px; right: 12px; }
.sgp-credit-line--top-center { top: 12px; left: 50%; transform: translateX(-50%); }
.sgp-credit-line--bottom-left { bottom: 12px; left: 12px; }
.sgp-credit-line--bottom-center { bottom: 12px; left: 50%; transform: translateX(-50%); }
.sgp-credit-line--bottom-right { bottom: 12px; right: 12px; }
.sgp-slider .sgp-credit-line,
.sgp-viewer .sgp-credit-line { z-index: 8; }


/* ===== v6 mobile landscape viewer centering + scroll-safe controls ===== */
@media (max-width: 980px) and (orientation: landscape) {
  .sgp-viewer {
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  .sgp-viewer .sgp-viewer__stage {
    min-height: 100dvh !important;
    align-items: center !important;
    justify-content: center !important;
    overflow-y: auto !important;
    padding-top: 12px !important;
    padding-bottom: 12px !important;
  }
  .sgp-viewer .sgp-viewer__frame {
    min-height: calc(100dvh - 24px) !important;
    margin-top: auto !important;
    margin-bottom: auto !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
  }
  .sgp-viewer .sgp-viewer__main {
    flex: 0 0 auto !important;
    align-items: center !important;
    margin-top: 0 !important;
    margin-bottom: 8px !important;
  }
  .sgp-viewer .sgp-viewer__media,
  .sgp-viewer .sgp-viewer__mediawrap,
  .sgp-viewer .sgp-viewer__media .sgp-item,
  .sgp-viewer .sgp-viewer__media .sgp-media {
    align-items: center !important;
    justify-content: center !important;
  }
  .sgp-viewer .sgp-viewer__img {
    max-height: calc(100dvh - 132px) !important;
    object-position: center center !important;
  }
  .sgp-viewer .sgp-viewer__below {
    flex: 0 0 auto !important;
    max-height: 28dvh !important;
    overflow-y: auto !important;
    overscroll-behavior: contain;
    padding-bottom: 6px !important;
  }
}


/* ===== v8 independent admin panels + mobile landscape viewer stability ===== */
@media (max-width: 980px) and (orientation: landscape) {
  .sgp-viewer {
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  .sgp-viewer .sgp-viewer__stage {
    min-height: 100dvh !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .sgp-viewer .sgp-viewer__frame {
    min-height: calc(100dvh - 16px) !important;
    display: grid !important;
    grid-template-rows: auto minmax(0,1fr) auto !important;
    align-items: center !important;
    justify-items: center !important;
  }
  .sgp-viewer .sgp-viewer__main {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    align-self: center !important;
  }
  .sgp-viewer .sgp-viewer__mediawrap,
  .sgp-viewer .sgp-viewer__media,
  .sgp-viewer .sgp-viewer__media .sgp-item,
  .sgp-viewer .sgp-viewer__media .sgp-media {
    height: 100% !important;
    min-height: 0 !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .sgp-viewer .sgp-viewer__img {
    width: auto !important;
    max-width: 100% !important;
    max-height: calc(100dvh - 172px) !important;
    object-fit: contain !important;
    object-position: center center !important;
  }
  .sgp-viewer .sgp-viewer__below {
    width: 100% !important;
    max-height: 108px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    padding-top: 8px !important;
    padding-bottom: 4px !important;
  }
}


/* v9 targeted fixes */
.sgp-inline-link{
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
  cursor: pointer;
  pointer-events: auto;
}
.sgp-watermark,
.sgp-proof-badge,
.sgp-usage-badge,
.sgp-credit-line{
  pointer-events: auto;
}
@media (max-width: 980px) and (orientation: landscape) {
  .sgp-viewer__stage{
    align-items: center !important;
    justify-content: center !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
    overflow: hidden !important;
  }
  .sgp-viewer__frame{
    height: calc(100dvh - 16px) !important;
    max-height: calc(100dvh - 16px) !important;
    display: grid !important;
    grid-template-rows: auto minmax(0,1fr) auto !important;
    align-items: center !important;
  }
  .sgp-viewer__main{
    align-items: center !important;
    align-content: center !important;
  }
  .sgp-viewer__below{
    max-height: min(26dvh, 118px) !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
  }
  .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img{
    max-height: calc(100dvh - 124px) !important;
    object-fit: contain !important;
    object-position: center center !important;
  }
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-item,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media .sgp-media{
    transform: none !important;
  }
}


/* v10 cleanup + stable mobile landscape viewer */
.sgp-proof-badge,
.sgp-usage-badge,
.sgp-credit-line,
.sgp-watermark { pointer-events: auto; }
.sgp-inline-link{ color:inherit; text-decoration:underline; text-underline-offset:2px; }
@media (max-width: 980px) and (orientation: landscape) {
  .sgp-viewer,
  .sgp-viewer__stage{ overflow:hidden !important; }
  .sgp-viewer__stage{ min-height:100dvh !important; height:100dvh !important; padding-top:6px !important; padding-bottom:6px !important; align-items:center !important; justify-content:center !important; }
  .sgp-viewer__frame{ height:calc(100dvh - 12px) !important; max-height:calc(100dvh - 12px) !important; display:grid !important; grid-template-rows:auto minmax(0,1fr) auto !important; align-items:stretch !important; }
  .sgp-viewer__main{ align-self:center !important; align-items:center !important; margin:0 !important; }
  .sgp-viewer__mediawrap, .sgp-viewer__media, .sgp-viewer__media .sgp-item, .sgp-viewer__media .sgp-media{ height:100% !important; min-height:0 !important; align-items:center !important; justify-content:center !important; transform:none !important; }
  .sgp-viewer__img, .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img, .sgp-viewer[data-source-gallery-type="polaroid"] .sgp-viewer__img{ width:auto !important; max-width:100% !important; max-height:calc(100dvh - 152px) !important; object-fit:contain !important; object-position:center center !important; }
  .sgp-viewer__below{ width:100% !important; max-height:88px !important; min-height:44px !important; overflow-y:auto !important; overflow-x:hidden !important; -webkit-overflow-scrolling:touch !important; overscroll-behavior:contain !important; padding-top:6px !important; padding-bottom:2px !important; }
}


/* ===== v11 repair: separate admin sections + stable viewer landscape ===== */
.sgp-inline-link {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
  pointer-events: auto;
}
.sgp-watermark,
.sgp-proof-badge,
.sgp-usage-badge,
.sgp-credit-line {
  pointer-events: auto;
}
@media (max-width: 980px) and (orientation: landscape) {
  .sgp-viewer[aria-hidden="false"] {
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__stage {
    min-height: 100dvh !important;
    height: 100dvh !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
    align-items: center !important;
    justify-content: center !important;
    overflow-y: auto !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__frame {
    min-height: calc(100dvh - 16px) !important;
    max-height: calc(100dvh - 16px) !important;
    height: auto !important;
    display: grid !important;
    grid-template-rows: auto minmax(0, 1fr) auto !important;
    align-items: stretch !important;
    justify-items: center !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__main {
    min-height: 0 !important;
    height: auto !important;
    align-self: center !important;
    align-items: center !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__mediawrap,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__media,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-item,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-media {
    min-height: 0 !important;
    height: auto !important;
    max-height: calc(100dvh - 140px) !important;
    align-items: center !important;
    justify-content: center !important;
    transform: none !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__img,
  .sgp-viewer[aria-hidden="false"][data-gallery-type="polaroid"] .sgp-viewer__img,
  .sgp-viewer[aria-hidden="false"][data-source-gallery-type="polaroid"] .sgp-viewer__img {
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: calc(100dvh - 140px) !important;
    object-fit: contain !important;
    object-position: center center !important;
    margin-inline: auto !important;
    transform: none !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__below {
    width: 100% !important;
    min-height: 44px !important;
    max-height: 96px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    padding-top: 6px !important;
    padding-bottom: 4px !important;
  }
}

/* ===== v15 frontend repair: safe overlays + mobile landscape viewer ===== */
.sgp-gallery .sgp-media,
.sgp-slider .sgp-media,
.sgp-viewer .sgp-media,
.sgp-gallery .sgp-item,
.sgp-slider .sgp-item,
.sgp-viewer .sgp-item {
  position: relative !important;
}

.sgp-watermark,
.sgp-proof-badge,
.sgp-usage-badge,
.sgp-credit-line {
  --sgp-mark-scale: 1;
  --sgp-mark-gap: calc(.45em * var(--sgp-mark-scale));
  --sgp-mark-pad-y: calc(.42em * var(--sgp-mark-scale));
  --sgp-mark-pad-x: calc(.72em * var(--sgp-mark-scale));
  position: absolute !important;
  z-index: 8 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--sgp-mark-gap) !important;
  width: auto !important;
  max-width: calc(100% - 24px) !important;
  min-width: 0 !important;
  padding: var(--sgp-mark-pad-y) var(--sgp-mark-pad-x) !important;
  border-radius: 999px !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  text-overflow: ellipsis !important;
  line-height: 1.15 !important;
  pointer-events: none !important;
}
.sgp-watermark { font-size: calc(var(--sgp-watermark-size, 13px) * var(--sgp-mark-scale, 1)) !important; }
.sgp-proof-badge { font-size: calc(var(--sgp-proof-badge-size, 12px) * var(--sgp-mark-scale, 1)) !important; }
.sgp-usage-badge { font-size: calc(var(--sgp-usage-badge-size, 12px) * var(--sgp-mark-scale, 1)) !important; }
.sgp-credit-line { font-size: calc(var(--sgp-credit-line-size, 12px) * var(--sgp-mark-scale, 1)) !important; }

.sgp-watermark__ic,
.sgp-proof-badge__ic,
.sgp-usage-badge__ic,
.sgp-credit-line__ic {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 1em !important;
  width: 1em !important;
  height: 1em !important;
  min-width: 1em !important;
  min-height: 1em !important;
  max-width: 1em !important;
  max-height: 1em !important;
  overflow: hidden !important;
}
.sgp-watermark__ic svg,
.sgp-proof-badge__ic svg,
.sgp-usage-badge__ic svg,
.sgp-credit-line__ic svg {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}
.sgp-watermark__tx,
.sgp-proof-badge__tx,
.sgp-usage-badge__tx,
.sgp-credit-line__tx,
.sgp-inline-link {
  display: inline-block !important;
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.sgp-watermark a,
.sgp-proof-badge a,
.sgp-usage-badge a,
.sgp-credit-line a {
  pointer-events: auto !important;
}

.sgp-watermark--top-left,.sgp-proof-badge--top-left,.sgp-usage-badge--top-left,.sgp-credit-line--top-left { top: 12px !important; left: 12px !important; right: auto !important; bottom: auto !important; transform: none !important; }
.sgp-watermark--top-right,.sgp-proof-badge--top-right,.sgp-usage-badge--top-right,.sgp-credit-line--top-right { top: 12px !important; right: 12px !important; left: auto !important; bottom: auto !important; transform: none !important; }
.sgp-watermark--top-center,.sgp-proof-badge--top-center,.sgp-usage-badge--top-center,.sgp-credit-line--top-center { top: 12px !important; left: 50% !important; right: auto !important; bottom: auto !important; transform: translateX(-50%) !important; }
.sgp-watermark--bottom-left,.sgp-proof-badge--bottom-left,.sgp-usage-badge--bottom-left,.sgp-credit-line--bottom-left { bottom: 12px !important; left: 12px !important; top: auto !important; right: auto !important; transform: none !important; }
.sgp-watermark--bottom-right,.sgp-proof-badge--bottom-right,.sgp-usage-badge--bottom-right,.sgp-credit-line--bottom-right { bottom: 12px !important; right: 12px !important; top: auto !important; left: auto !important; transform: none !important; }
.sgp-watermark--bottom-center,.sgp-proof-badge--bottom-center,.sgp-usage-badge--bottom-center,.sgp-credit-line--bottom-center { bottom: 12px !important; left: 50% !important; top: auto !important; right: auto !important; transform: translateX(-50%) !important; }

@media (max-width: 980px) and (orientation: landscape) {
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__stage {
    padding: 0 !important;
    overflow: hidden !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__frame {
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: 100dvh !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    grid-template-rows: minmax(0,1fr) auto !important;
    padding: 0 !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__topbar {
    position: absolute !important;
    top: 8px !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 15 !important;
    padding-inline: 8px !important;
    pointer-events: none !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__topbar > * { pointer-events: auto !important; }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__main,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__mediawrap,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-item,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-media {
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: calc(100dvh - 62px) !important;
    height: calc(100dvh - 62px) !important;
    max-height: calc(100dvh - 62px) !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__navcol {
    display: contents !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__nav {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 14 !important;
    width: 42px !important;
    height: 42px !important;
    margin: 0 !important;
    background: rgba(17,17,17,.62) !important;
    border-color: rgba(255,255,255,.24) !important;
    color: #fff !important;
    backdrop-filter: blur(6px) !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__prev { left: 6px !important; right: auto !important; }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__next { right: 6px !important; left: auto !important; }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__img,
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="polaroid"] .sgp-viewer__img,
  .sgp-viewer.sgp-mobile-overlay-nav[data-source-gallery-type="polaroid"] .sgp-viewer__img {
    width: auto !important;
    height: auto !important;
    max-width: calc(100vw - 18px) !important;
    max-height: calc(100dvh - 70px) !important;
    object-fit: contain !important;
    object-position: center center !important;
    margin-inline: auto !important;
    transform: none !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__below {
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: 42px !important;
    max-height: 68px !important;
    margin-top: 0 !important;
    padding: 2px 0 6px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
  }
}


/* v16 hard fixes: standalone 10-14 safe overlays + mobile photo size */
.sgp-gallery .sgp-media,
.sgp-slider .sgp-media,
.sgp-viewer .sgp-viewer__media,
.sgp-viewer .sgp-viewer__media .sgp-item,
.sgp-gallery.sgp-type-polaroid .sgp-item,
.sgp-gallery.sgp-type-fusion .sgp-item,
.sgp-gallery.sgp-type-mosaic .sgp-item {
  position: relative !important;
}

.sgp-gallery .sgp-media > .sgp-watermark,
.sgp-gallery .sgp-media > .sgp-proof-badge,
.sgp-gallery .sgp-media > .sgp-usage-badge,
.sgp-gallery .sgp-media > .sgp-credit-line,
.sgp-viewer .sgp-viewer__media > .sgp-watermark,
.sgp-viewer .sgp-viewer__media > .sgp-proof-badge,
.sgp-viewer .sgp-viewer__media > .sgp-usage-badge,
.sgp-viewer .sgp-viewer__media > .sgp-credit-line {
  position: absolute !important;
  inset: auto !important;
  z-index: 12 !important;
}


.sgp-gallery.sgp-type-polaroid .sgp-item > img:not(.sgp-img),
.sgp-gallery.sgp-type-fusion .sgp-item > img:not(.sgp-img),
.sgp-gallery.sgp-type-mosaic .sgp-item > img:not(.sgp-img) {
  display: none !important;
}

@media (max-width: 980px) and (orientation: landscape) {
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__frame {
    grid-template-rows: minmax(0,1fr) auto !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__main {
    min-height: 0 !important;
    height: auto !important;
    align-self: stretch !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__mediawrap,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-item,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-media {
    min-height: 0 !important;
    height: 100% !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__img,
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="polaroid"] .sgp-viewer__img,
  .sgp-viewer.sgp-mobile-overlay-nav[data-source-gallery-type="polaroid"] .sgp-viewer__img {
    width: auto !important;
    max-width: calc(100vw - 16px) !important;
    max-height: calc(100dvh - 86px) !important;
    object-fit: contain !important;
    object-position: center center !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__nav {
    top: 50% !important;
    transform: translateY(-50%) !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__below {
    max-height: 74px !important;
    min-height: 40px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }
}


/* v18 overlay icon repair: scope icon sizing without hardcoding */
.sgp-watermark,
.sgp-proof-badge,
.sgp-usage-badge,
.sgp-credit-line {
  display: inline-flex !important;
  align-items: center !important;
  width: auto !important;
  max-width: calc(100% - 24px) !important;
}
.sgp-watermark__ic,
.sgp-proof-badge__ic,
.sgp-usage-badge__ic,
.sgp-credit-line__ic {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  inline-size: 1em !important;
  block-size: 1em !important;
  min-inline-size: 1em !important;
  min-block-size: 1em !important;
  overflow: hidden !important;
}
.sgp-mark-icon,
.sgp-watermark__ic > svg,
.sgp-proof-badge__ic > svg,
.sgp-usage-badge__ic > svg,
.sgp-credit-line__ic > svg {
  display: block !important;
  inline-size: 1em !important;
  block-size: 1em !important;
  width: 1em !important;
  height: 1em !important;
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: none !important;
  max-height: none !important;
  flex: none !important;
  aspect-ratio: 1 / 1 !important;
}
.sgp-watermark__tx,
.sgp-proof-badge__tx,
.sgp-usage-badge__tx,
.sgp-credit-line__tx,
.sgp-inline-link {
  min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.sgp-watermark > *, .sgp-proof-badge > *, .sgp-usage-badge > *, .sgp-credit-line > * { box-sizing: border-box; }


/* ===== v19 cleanup: fix overlay badge icon scaling without hardcoded pixels ===== */
.sgp-gallery .sgp-media > .sgp-watermark,
.sgp-gallery .sgp-media > .sgp-proof-badge,
.sgp-gallery .sgp-media > .sgp-usage-badge,
.sgp-gallery .sgp-media > .sgp-credit-line,
.sgp-viewer .sgp-viewer__media .sgp-watermark,
.sgp-viewer .sgp-viewer__media .sgp-proof-badge,
.sgp-viewer .sgp-viewer__media .sgp-usage-badge,
.sgp-viewer .sgp-viewer__media .sgp-credit-line {
  position: absolute !important;
  z-index: 12 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: .5em !important;
  width: auto !important;
  max-width: calc(100% - 24px) !important;
  min-width: 0 !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  box-sizing: border-box !important;
}

.sgp-gallery .sgp-media > .sgp-watermark .sgp-watermark__ic,
.sgp-gallery .sgp-media > .sgp-proof-badge .sgp-proof-badge__ic,
.sgp-gallery .sgp-media > .sgp-usage-badge .sgp-usage-badge__ic,
.sgp-gallery .sgp-media > .sgp-credit-line .sgp-credit-line__ic,
.sgp-viewer .sgp-viewer__media .sgp-watermark .sgp-watermark__ic,
.sgp-viewer .sgp-viewer__media .sgp-proof-badge .sgp-proof-badge__ic,
.sgp-viewer .sgp-viewer__media .sgp-usage-badge .sgp-usage-badge__ic,
.sgp-viewer .sgp-viewer__media .sgp-credit-line .sgp-credit-line__ic {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 1em !important;
  inline-size: 1em !important;
  block-size: 1em !important;
  min-inline-size: 1em !important;
  min-block-size: 1em !important;
  max-inline-size: 1em !important;
  max-block-size: 1em !important;
  overflow: hidden !important;
  font-size: 1em !important;
  line-height: 1 !important;
}

.sgp-gallery .sgp-media > .sgp-watermark .sgp-watermark__ic > svg,
.sgp-gallery .sgp-media > .sgp-proof-badge .sgp-proof-badge__ic > svg,
.sgp-gallery .sgp-media > .sgp-usage-badge .sgp-usage-badge__ic > svg,
.sgp-gallery .sgp-media > .sgp-credit-line .sgp-credit-line__ic > svg,
.sgp-viewer .sgp-viewer__media .sgp-watermark .sgp-watermark__ic > svg,
.sgp-viewer .sgp-viewer__media .sgp-proof-badge .sgp-proof-badge__ic > svg,
.sgp-viewer .sgp-viewer__media .sgp-usage-badge .sgp-usage-badge__ic > svg,
.sgp-viewer .sgp-viewer__media .sgp-credit-line .sgp-credit-line__ic > svg {
  display: block !important;
  inline-size: 100% !important;
  block-size: 100% !important;
  width: 100% !important;
  height: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: 100% !important;
  max-height: 100% !important;
  flex: none !important;
}

.sgp-gallery .sgp-media > .sgp-watermark .sgp-watermark__tx,
.sgp-gallery .sgp-media > .sgp-proof-badge .sgp-proof-badge__tx,
.sgp-gallery .sgp-media > .sgp-usage-badge .sgp-usage-badge__tx,
.sgp-gallery .sgp-media > .sgp-credit-line .sgp-credit-line__tx,
.sgp-viewer .sgp-viewer__media .sgp-watermark .sgp-watermark__tx,
.sgp-viewer .sgp-viewer__media .sgp-proof-badge .sgp-proof-badge__tx,
.sgp-viewer .sgp-viewer__media .sgp-usage-badge .sgp-usage-badge__tx,
.sgp-viewer .sgp-viewer__media .sgp-credit-line .sgp-credit-line__tx {
  display: inline-block !important;
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

@media (max-width: 980px) and (orientation: landscape) {
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__main,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__mediawrap,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-item,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-media {
    min-height: calc(100dvh - 58px) !important;
    height: calc(100dvh - 58px) !important;
    max-height: calc(100dvh - 58px) !important;
  }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__img,
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="polaroid"] .sgp-viewer__img,
  .sgp-viewer.sgp-mobile-overlay-nav[data-source-gallery-type="polaroid"] .sgp-viewer__img {
    max-height: calc(100dvh - 60px) !important;
    max-width: calc(100vw - 12px) !important;
  }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__below {
    max-height: 56px !important;
    min-height: 36px !important;
  }
}


/* v21: respect selected overlay positions + give mobile image more room */
.sgp-gallery .sgp-media > .sgp-watermark[data-pos],
.sgp-gallery .sgp-media > .sgp-proof-badge[data-pos],
.sgp-gallery .sgp-media > .sgp-usage-badge[data-pos],
.sgp-gallery .sgp-media > .sgp-credit-line[data-pos],
.sgp-viewer .sgp-viewer__media .sgp-watermark[data-pos],
.sgp-viewer .sgp-viewer__media .sgp-proof-badge[data-pos],
.sgp-viewer .sgp-viewer__media .sgp-usage-badge[data-pos],
.sgp-viewer .sgp-viewer__media .sgp-credit-line[data-pos] {
  inset: unset !important;
}

.sgp-gallery .sgp-media > [data-pos="top-left"],
.sgp-viewer .sgp-viewer__media [data-pos="top-left"] {
  top: 12px !important; left: 12px !important; right: auto !important; bottom: auto !important; transform: none !important;
}
.sgp-gallery .sgp-media > [data-pos="top-right"],
.sgp-viewer .sgp-viewer__media [data-pos="top-right"] {
  top: 12px !important; right: 12px !important; left: auto !important; bottom: auto !important; transform: none !important;
}
.sgp-gallery .sgp-media > [data-pos="top-center"],
.sgp-viewer .sgp-viewer__media [data-pos="top-center"] {
  top: 12px !important; left: 50% !important; right: auto !important; bottom: auto !important; transform: translateX(-50%) !important;
}
.sgp-gallery .sgp-media > [data-pos="bottom-left"],
.sgp-viewer .sgp-viewer__media [data-pos="bottom-left"] {
  bottom: 12px !important; left: 12px !important; top: auto !important; right: auto !important; transform: none !important;
}
.sgp-gallery .sgp-media > [data-pos="bottom-right"],
.sgp-viewer .sgp-viewer__media [data-pos="bottom-right"] {
  bottom: 12px !important; right: 12px !important; top: auto !important; left: auto !important; transform: none !important;
}
.sgp-gallery .sgp-media > [data-pos="bottom-center"],
.sgp-viewer .sgp-viewer__media [data-pos="bottom-center"] {
  bottom: 12px !important; left: 50% !important; top: auto !important; right: auto !important; transform: translateX(-50%) !important;
}

@media (max-width: 980px) and (orientation: landscape) {
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__mediawrap,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-item,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-media {
    min-height: calc(100dvh - 34px) !important;
    height: calc(100dvh - 34px) !important;
    max-height: calc(100dvh - 34px) !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__img,
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="polaroid"] .sgp-viewer__img,
  .sgp-viewer.sgp-mobile-overlay-nav[data-source-gallery-type="polaroid"] .sgp-viewer__img {
    max-width: calc(100vw - 4px) !important;
    max-height: calc(100dvh - 44px) !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__below {
    max-height: 42px !important;
    min-height: 28px !important;
  }
}

/* v22 final repair: explicit overlay positions for 11-14 + slightly larger mobile landscape image */
.sgp-gallery .sgp-media,
.sgp-viewer .sgp-viewer__media,
.sgp-viewer .sgp-viewer__media .sgp-item,
.sgp-viewer .sgp-viewer__media .sgp-media {
  position: relative !important;
}

.sgp-gallery .sgp-media > .sgp-watermark,
.sgp-gallery .sgp-media > .sgp-proof-badge,
.sgp-gallery .sgp-media > .sgp-usage-badge,
.sgp-gallery .sgp-media > .sgp-credit-line,
.sgp-viewer .sgp-viewer__media .sgp-watermark,
.sgp-viewer .sgp-viewer__media .sgp-proof-badge,
.sgp-viewer .sgp-viewer__media .sgp-usage-badge,
.sgp-viewer .sgp-viewer__media .sgp-credit-line {
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  margin: 0 !important;
  transform: none !important;
}

.sgp-gallery .sgp-media > .sgp-watermark[data-pos="top-left"],
.sgp-gallery .sgp-media > .sgp-proof-badge[data-pos="top-left"],
.sgp-gallery .sgp-media > .sgp-usage-badge[data-pos="top-left"],
.sgp-gallery .sgp-media > .sgp-credit-line[data-pos="top-left"],
.sgp-viewer .sgp-viewer__media .sgp-watermark[data-pos="top-left"],
.sgp-viewer .sgp-viewer__media .sgp-proof-badge[data-pos="top-left"],
.sgp-viewer .sgp-viewer__media .sgp-usage-badge[data-pos="top-left"],
.sgp-viewer .sgp-viewer__media .sgp-credit-line[data-pos="top-left"] {
  top: 12px !important;
  left: 12px !important;
}

.sgp-gallery .sgp-media > .sgp-watermark[data-pos="top-right"],
.sgp-gallery .sgp-media > .sgp-proof-badge[data-pos="top-right"],
.sgp-gallery .sgp-media > .sgp-usage-badge[data-pos="top-right"],
.sgp-gallery .sgp-media > .sgp-credit-line[data-pos="top-right"],
.sgp-viewer .sgp-viewer__media .sgp-watermark[data-pos="top-right"],
.sgp-viewer .sgp-viewer__media .sgp-proof-badge[data-pos="top-right"],
.sgp-viewer .sgp-viewer__media .sgp-usage-badge[data-pos="top-right"],
.sgp-viewer .sgp-viewer__media .sgp-credit-line[data-pos="top-right"] {
  top: 12px !important;
  right: 12px !important;
}

.sgp-gallery .sgp-media > .sgp-watermark[data-pos="top-center"],
.sgp-gallery .sgp-media > .sgp-proof-badge[data-pos="top-center"],
.sgp-gallery .sgp-media > .sgp-usage-badge[data-pos="top-center"],
.sgp-gallery .sgp-media > .sgp-credit-line[data-pos="top-center"],
.sgp-viewer .sgp-viewer__media .sgp-watermark[data-pos="top-center"],
.sgp-viewer .sgp-viewer__media .sgp-proof-badge[data-pos="top-center"],
.sgp-viewer .sgp-viewer__media .sgp-usage-badge[data-pos="top-center"],
.sgp-viewer .sgp-viewer__media .sgp-credit-line[data-pos="top-center"] {
  top: 12px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
}

.sgp-gallery .sgp-media > .sgp-watermark[data-pos="bottom-left"],
.sgp-gallery .sgp-media > .sgp-proof-badge[data-pos="bottom-left"],
.sgp-gallery .sgp-media > .sgp-usage-badge[data-pos="bottom-left"],
.sgp-gallery .sgp-media > .sgp-credit-line[data-pos="bottom-left"],
.sgp-viewer .sgp-viewer__media .sgp-watermark[data-pos="bottom-left"],
.sgp-viewer .sgp-viewer__media .sgp-proof-badge[data-pos="bottom-left"],
.sgp-viewer .sgp-viewer__media .sgp-usage-badge[data-pos="bottom-left"],
.sgp-viewer .sgp-viewer__media .sgp-credit-line[data-pos="bottom-left"] {
  bottom: 12px !important;
  left: 12px !important;
}

.sgp-gallery .sgp-media > .sgp-watermark[data-pos="bottom-right"],
.sgp-gallery .sgp-media > .sgp-proof-badge[data-pos="bottom-right"],
.sgp-gallery .sgp-media > .sgp-usage-badge[data-pos="bottom-right"],
.sgp-gallery .sgp-media > .sgp-credit-line[data-pos="bottom-right"],
.sgp-viewer .sgp-viewer__media .sgp-watermark[data-pos="bottom-right"],
.sgp-viewer .sgp-viewer__media .sgp-proof-badge[data-pos="bottom-right"],
.sgp-viewer .sgp-viewer__media .sgp-usage-badge[data-pos="bottom-right"],
.sgp-viewer .sgp-viewer__media .sgp-credit-line[data-pos="bottom-right"] {
  bottom: 12px !important;
  right: 12px !important;
}

.sgp-gallery .sgp-media > .sgp-watermark[data-pos="bottom-center"],
.sgp-gallery .sgp-media > .sgp-proof-badge[data-pos="bottom-center"],
.sgp-gallery .sgp-media > .sgp-usage-badge[data-pos="bottom-center"],
.sgp-gallery .sgp-media > .sgp-credit-line[data-pos="bottom-center"],
.sgp-viewer .sgp-viewer__media .sgp-watermark[data-pos="bottom-center"],
.sgp-viewer .sgp-viewer__media .sgp-proof-badge[data-pos="bottom-center"],
.sgp-viewer .sgp-viewer__media .sgp-usage-badge[data-pos="bottom-center"],
.sgp-viewer .sgp-viewer__media .sgp-credit-line[data-pos="bottom-center"] {
  bottom: 12px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
}

@media (max-width: 980px) and (orientation: landscape) {
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__stage {
    padding-top: 2px !important;
    padding-bottom: 2px !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__mediawrap,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-item,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-media {
    min-height: calc(100dvh - 22px) !important;
    height: calc(100dvh - 22px) !important;
    max-height: calc(100dvh - 22px) !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__img,
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="polaroid"] .sgp-viewer__img,
  .sgp-viewer.sgp-mobile-overlay-nav[data-source-gallery-type="polaroid"] .sgp-viewer__img {
    max-width: calc(100vw - 2px) !important;
    max-height: calc(100dvh - 30px) !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__below {
    max-height: 34px !important;
    min-height: 24px !important;
    padding-top: 2px !important;
    padding-bottom: 0 !important;
  }
}

/* ===== v23 compact display alignment ===== */
@media (max-width: 1024px) {
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__main {
    grid-template-columns: minmax(0,1fr) !important;
    column-gap: 0 !important;
    position: relative !important;
  }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__mediawrap,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-item,
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-media {
    margin: 0 auto !important;
    overflow: visible !important;
  }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__nav {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 20 !important;
  }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__prev {
    left: 5px !important;
    right: auto !important;
  }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__next {
    right: 5px !important;
    left: auto !important;
  }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-watermark[data-pos="top-left"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-proof-badge[data-pos="top-left"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-usage-badge[data-pos="top-left"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-credit-line[data-pos="top-left"] { top: 5px !important; left: 5px !important; }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-watermark[data-pos="top-right"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-proof-badge[data-pos="top-right"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-usage-badge[data-pos="top-right"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-credit-line[data-pos="top-right"] { top: 5px !important; right: 5px !important; }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-watermark[data-pos="top-center"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-proof-badge[data-pos="top-center"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-usage-badge[data-pos="top-center"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-credit-line[data-pos="top-center"] { top: 5px !important; left: 50% !important; transform: translateX(-50%) !important; }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-watermark[data-pos="bottom-left"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-proof-badge[data-pos="bottom-left"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-usage-badge[data-pos="bottom-left"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-credit-line[data-pos="bottom-left"] { bottom: 5px !important; left: 5px !important; }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-watermark[data-pos="bottom-right"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-proof-badge[data-pos="bottom-right"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-usage-badge[data-pos="bottom-right"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-credit-line[data-pos="bottom-right"] { bottom: 5px !important; right: 5px !important; }

  .sgp-viewer.sgp-mobile-overlay-nav .sgp-watermark[data-pos="bottom-center"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-proof-badge[data-pos="bottom-center"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-usage-badge[data-pos="bottom-center"],
  .sgp-viewer.sgp-mobile-overlay-nav .sgp-credit-line[data-pos="bottom-center"] { bottom: 5px !important; left: 50% !important; transform: translateX(-50%) !important; }
}


/* ===== v23 mobile nav over image ===== */
.sgp-viewer__mediawrap {
    position: relative;
}

.sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__mediawrap {
    overflow: visible !important;
}

.sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 12;
}

.sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__prev {
    left: 5px;
    right: auto;
}

.sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__next {
    right: 5px;
    left: auto;
}

@media (max-width: 1024px) {
    .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__stage {
        padding-left: 8px !important;
        padding-right: 8px !important;
    }

    .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__frame,
    .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__main,
    .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__mediawrap,
    .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media,
    .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-item,
    .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__media .sgp-media {
        width: 100% !important;
        max-width: 100% !important;
    }

    .sgp-viewer.sgp-mobile-overlay-nav .sgp-viewer__img {
        max-width: 100% !important;
    }
}

/* ===== v27 mobile slider nav + image fill fix ===== */
@media (max-width: 767px) {
  .sgp-gallery.sgp-type-slider {
    --sgp-mobile-side-gap: 3px;
  }

  .sgp-gallery.sgp-type-slider .sgp-slider {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    padding-left: var(--sgp-mobile-side-gap) !important;
    padding-right: var(--sgp-mobile-side-gap) !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-track-inner,
  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-img {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    margin: 0 auto !important;
    object-fit: contain !important;
    object-position: center center !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-nav,
  .sgp-gallery.sgp-type-slider .sgp-prev,
  .sgp-gallery.sgp-type-slider .sgp-next {
    position: absolute !important;
    top: 50% !important;
    bottom: auto !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
    z-index: 30 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-prev {
    left: var(--sgp-mobile-side-gap) !important;
    right: auto !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-next {
    right: var(--sgp-mobile-side-gap) !important;
    left: auto !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-media,
  .sgp-gallery.sgp-type-slider .sgp-item {
    position: relative !important;
    overflow: hidden !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-overlay {
    max-width: calc(100% - 6px) !important;
    max-height: calc(100% - 6px) !important;
  }
}


/* ===== v30 mobile slider viewer matches grid viewer ===== */
.sgp-viewer[data-gallery-type="slider"] .sgp-viewer__stage {
  align-items: center !important;
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}
.sgp-viewer[data-gallery-type="slider"] .sgp-viewer__frame {
  margin-top: 0 !important;
  width: min(1100px, calc(100vw - 176px)) !important;
  justify-content: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-viewer[data-gallery-type="slider"] .sgp-viewer__below {
  margin-top: 12px !important;
  padding-bottom: 12px !important;
}
.sgp-viewer[data-gallery-type="slider"] .sgp-viewer__img {
  max-height: 68vh !important;
}
@media (max-width: 700px) {
  .sgp-viewer[data-gallery-type="slider"] .sgp-viewer__stage {
    align-items: center !important;
    padding: 18px 16px 20px !important;
  }
  .sgp-viewer[data-gallery-type="slider"] .sgp-viewer__frame {
    margin-top: 0 !important;
    width: min(96vw, 1100px) !important;
  }
  .sgp-viewer[data-gallery-type="slider"] .sgp-viewer__img {
    max-width: calc(100vw - 28px) !important;
    max-height: 58vh !important;
    margin: 0 auto !important;
  }
}
@media (max-width: 1024px) {
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] .sgp-viewer__nav {
    top: 50% !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] .sgp-viewer__prev {
    left: 5px !important;
    right: auto !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] .sgp-viewer__next {
    right: 5px !important;
    left: auto !important;
  }
}
@media (max-width: 767px) {
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] {
    --sgp-safe-width: calc(100vw - 6px) !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] .sgp-viewer__stage {
    padding-left: 3px !important;
    padding-right: 3px !important;
  }
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] .sgp-viewer__frame,
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] .sgp-viewer__main,
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] .sgp-viewer__mediawrap,
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] .sgp-viewer__media,
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] .sgp-viewer__media .sgp-item,
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] .sgp-viewer__media .sgp-media,
  .sgp-viewer.sgp-mobile-overlay-nav[data-gallery-type="slider"] .sgp-viewer__img {
    width: calc(100vw - 6px) !important;
    max-width: calc(100vw - 6px) !important;
  }
}


/* ===== v31 mobile slider matches mobile grid layout ===== */
@media (max-width: 767px) {
  .sgp-gallery.sgp-type-slider {
    --sgp-mobile-side-gap: 3px !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-slider {
    position: relative !important;
    width: calc(100vw - 6px) !important;
    max-width: calc(100vw - 6px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    overflow: visible !important;
    box-sizing: border-box !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-track-inner,
  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-slide {
    justify-content: stretch !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-item {
    width: 100% !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-media {
    position: relative !important;
    overflow: hidden !important;
    height: auto !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: none !important;
    object-fit: cover !important;
    object-position: center center !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-nav,
  .sgp-gallery.sgp-type-slider .sgp-prev,
  .sgp-gallery.sgp-type-slider .sgp-next {
    position: absolute !important;
    top: 50% !important;
    bottom: auto !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
    z-index: 35 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-prev {
    left: 3px !important;
    right: auto !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-next {
    right: 3px !important;
    left: auto !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-overlay {
    max-width: calc(100% - 6px) !important;
    max-height: calc(100% - 6px) !important;
  }
}


/* ===== v32 mobile slider inside image bounds ===== */
@media (max-width: 767px) {
  .sgp-gallery.sgp-type-slider .sgp-slider {
    width: calc(100% - 6px) !important;
    max-width: calc(100% - 6px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    overflow: visible !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-track-inner,
  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    width: 100% !important;
    max-width: 100% !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-media {
    position: relative !important;
    overflow: hidden !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-prev,
  .sgp-gallery.sgp-type-slider .sgp-next {
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 40 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-prev {
    left: 3px !important;
    right: auto !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-next {
    right: 3px !important;
    left: auto !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-badge,
  .sgp-gallery.sgp-type-slider .sgp-watermark,
  .sgp-gallery.sgp-type-slider .sgp-proof-badge,
  .sgp-gallery.sgp-type-slider .sgp-usage-label,
  .sgp-gallery.sgp-type-slider .sgp-credit-line {
    max-width: calc(100% - 12px) !important;
  }
}


/* v39: toggle nav / close visibility */
.sgp-gallery .sgp-nav,
.sgp-viewer .sgp-viewer__nav { display: var(--sgp-nav-display, flex) !important; }
.sgp-viewer .sgp-viewer__close,
.sgp-gallery .sgp-slider__close { display: none !important; }


@media (min-width: 1180px) and (max-width: 1700px) {
    .sgp-viewer__stage {
        padding: 16px 40px 14px !important;
    }

    .sgp-viewer__frame {
        width: min(97vw, 1420px) !important;
        max-width: min(97vw, 1420px) !important;
    }

    .sgp-viewer .sgp-viewer__img {
        max-height: 84vh !important;
    }

    .sgp-viewer__below {
        margin-top: 8px !important;
    }
}


/* ===== v43 final: transparent nav + larger centered media ===== */
.sgp-gallery[style*="--sgp-nav-transparent:1;"] .sgp-nav,
.sgp-viewer[style*="--sgp-nav-transparent:1;"] .sgp-viewer__nav {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}

.sgp-gallery[style*="--sgp-nav-transparent:1;"] .sgp-nav:hover,
.sgp-gallery[style*="--sgp-nav-transparent:1;"] .sgp-nav:focus-visible,
.sgp-viewer[style*="--sgp-nav-transparent:1;"] .sgp-viewer__nav:hover,
.sgp-viewer[style*="--sgp-nav-transparent:1;"] .sgp-viewer__nav:focus-visible {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

.sgp-viewer {
  --sgp-viewer-desktop-side-gap: clamp(16px, 2vw, 28px);
}

.sgp-viewer__stage {
  padding-left: var(--sgp-viewer-desktop-side-gap) !important;
  padding-right: var(--sgp-viewer-desktop-side-gap) !important;
}

.sgp-viewer__frame {
  width: min(calc(100vw - (var(--sgp-viewer-desktop-side-gap) * 2)), 1560px) !important;
  max-width: min(calc(100vw - (var(--sgp-viewer-desktop-side-gap) * 2)), 1560px) !important;
  justify-content: center !important;
}

.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.sgp-viewer .sgp-viewer__img {
  width: auto !important;
  height: auto !important;
  max-width: min(calc(100vw - 120px), 1480px) !important;
  max-height: min(calc(100vh - 150px), 88vh) !important;
  object-fit: contain !important;
  object-position: center center !important;
  margin-inline: auto !important;
}

.sgp-gallery.sgp-type-slider .sgp-slider {
  grid-template-columns: var(--sgp-nav-size) minmax(0, min(calc(100vw - 88px), var(--sgp-slider-w, var(--sgp-item-width)))) var(--sgp-nav-size) !important;
}

.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-track-inner,
.sgp-gallery.sgp-type-slider .sgp-item {
  width: min(calc(100vw - 88px), var(--sgp-slider-w, var(--sgp-item-width))) !important;
  max-width: min(calc(100vw - 88px), var(--sgp-slider-w, var(--sgp-item-width))) !important;
}

.sgp-gallery.sgp-type-slider .sgp-img {
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: min(calc(100vh - 180px), calc(var(--sgp-slider-h, var(--sgp-item-height)) + 180px)) !important;
  object-fit: contain !important;
  object-position: center center !important;
  margin-inline: auto !important;
}

@media (max-width: 980px) {
  .sgp-viewer {
    --sgp-viewer-desktop-side-gap: 10px;
  }

  .sgp-viewer .sgp-viewer__img {
    max-width: calc(100vw - 24px) !important;
    max-height: min(calc(100vh - 130px), 82vh) !important;
  }
}


/* ===== v45 fixes: metadata auto-import + true transparent nav/close + larger centered viewer ===== */
.sgp-gallery[data-nav-transparent="1"] .sgp-nav,
.sgp-viewer[data-nav-transparent="1"] .sgp-viewer__nav {
  background: transparent !important;
  background-color: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}
.sgp-gallery[data-close-transparent="1"] .sgp-overlay-close,
.sgp-viewer[data-close-transparent="1"] .sgp-viewer__close {
  background: transparent !important;
  background-color: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}
.sgp-viewer__stage {
  padding-left: max(10px, var(--sgp-safe-left, 10px)) !important;
  padding-right: max(10px, var(--sgp-safe-right, 10px)) !important;
}
.sgp-viewer__frame,
.sgp-viewer__main,
.sgp-viewer__mediawrap,
.sgp-viewer__media {
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-viewer__img {
  object-position: center center !important;
}
@media (min-width: 900px) {
  .sgp-viewer__stage {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }
  .sgp-viewer__below {
    margin-top: 8px !important;
  }
}


/* ===== v46 fixes: separate overlay styles + larger centered viewer + real transparent nav/close ===== */
.sgp-gallery {
  --sgp-thumb-text-color: var(--sgp-text-color);
  --sgp-thumb-overlay-bg: var(--sgp-overlay-bg);
  --sgp-viewer-text-color: var(--sgp-text-color);
  --sgp-viewer-overlay-bg: var(--sgp-overlay-bg);
}

/* thumbnail overlays only */
.sgp-gallery:not(.sgp-type-slider) .sgp-overlay-inner {
  color: var(--sgp-thumb-text-color) !important;
  background: var(--sgp-thumb-overlay-bg) !important;
}

/* slider + viewer overlays share the same settings */
.sgp-gallery.sgp-type-slider .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner {
  color: var(--sgp-viewer-text-color) !important;
  background: var(--sgp-viewer-overlay-bg) !important;
}

/* actually transparent nav/close when enabled */
.sgp-gallery[data-nav-transparent="1"] .sgp-nav,
.sgp-gallery[data-nav-transparent="1"] .sgp-viewer__nav,
.sgp-viewer[data-nav-transparent="1"] .sgp-viewer__nav {
  background: transparent !important;
  background-color: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.sgp-gallery[data-close-transparent="1"] .sgp-viewer__close,
.sgp-viewer[data-close-transparent="1"] .sgp-viewer__close {
  background: transparent !important;
  background-color: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* bigger viewer image with centered stage and only 10px side spacing */
.sgp-viewer[aria-hidden="false"] .sgp-viewer__stage {
  width: min(1800px, calc(100vw - 20px)) !important;
  max-width: calc(100vw - 20px) !important;
  margin: 0 auto !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__frame {
  width: 100% !important;
  max-width: none !important;
  margin: 0 auto !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__main {
  width: 100% !important;
  max-width: none !important;
  margin: 0 auto !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: min(84vh, 1080px) !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__navcol {
  flex: 0 0 auto !important;
  width: auto !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__mediawrap,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-item,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-media {
  width: 100% !important;
  max-width: 100% !important;
  height: 100% !important;
  min-height: min(78vh, 980px) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__img {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: min(100%, calc(100vw - 20px)) !important;
  max-height: min(78vh, 980px) !important;
  object-fit: contain !important;
  margin: 0 auto !important;
}

/* larger rectangular images in slider when large dimensions are configured */
.sgp-gallery.sgp-type-slider .sgp-slide {
  padding-left: 10px !important;
  padding-right: 10px !important;
}
.sgp-gallery.sgp-type-slider .sgp-item {
  width: min(calc(100% - 20px), var(--sgp-slider-w, min(var(--sgp-item-width), 92vw))) !important;
}
.sgp-gallery.sgp-type-slider .sgp-media {
  width: 100% !important;
}

/* ===== v47 fixes: working metadata import, true transparent nav/close, larger centered viewer ===== */
.sgp-gallery[data-nav-transparent="1"] .sgp-nav,
.sgp-viewer[data-nav-transparent="1"] .sgp-viewer__nav {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.sgp-gallery[data-close-transparent="1"] .sgp-slider__close,
.sgp-gallery[data-close-transparent="1"] .sgp-overlay-close,
.sgp-viewer[data-close-transparent="1"] .sgp-viewer__close,
.sgp-viewer[data-close-transparent="1"] .sgp-overlay-close {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__stage {
  width: calc(100vw - 20px) !important;
  max-width: calc(100vw - 20px) !important;
  margin: 0 auto !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__frame,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__main,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__mediawrap,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-item,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-media {
  margin-left: auto !important;
  margin-right: auto !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__img {
  object-fit: contain !important;
  object-position: center center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}


/* ===== v48 final fixes ===== */
.sgp-viewer[data-nav-transparent="1"] .sgp-viewer__nav,
.sgp-gallery[data-nav-transparent="1"] .sgp-nav {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.sgp-viewer[data-close-transparent="1"] .sgp-viewer__close,
.sgp-gallery[data-close-transparent="1"] .sgp-viewer__close {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.sgp-viewer {
  --sgp-safe-left: 10px !important;
  --sgp-safe-right: 10px !important;
  --sgp-stage-left: 10px !important;
  --sgp-stage-right: 10px !important;
}

.sgp-viewer__stage {
  left: 10px !important;
  right: 10px !important;
  inset-inline-start: 10px !important;
  inset-inline-end: 10px !important;
  width: auto !important;
  max-width: none !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
  justify-items: stretch !important;
}

.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
}

.sgp-viewer__media {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.sgp-viewer__img,
.sgp-viewer .sgp-viewer__img,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="slider"] .sgp-viewer__img {
  display: block !important;
  margin: 0 auto !important;
  width: auto !important;
  max-width: min(100%, calc(100vw - 20px)) !important;
  max-height: calc(100vh - 120px) !important;
  object-fit: contain !important;
}

.sgp-viewer .sgp-overlay-inner,
.sgp-gallery.sgp-type-slider .sgp-overlay-inner {
  color: var(--sgp-viewer-text-color, var(--sgp-text-color)) !important;
  background: var(--sgp-viewer-overlay-bg, var(--sgp-overlay-bg)) !important;
}

.sgp-gallery:not(.sgp-type-slider) .sgp-overlay-inner {
  color: var(--sgp-thumb-text-color, var(--sgp-text-color)) !important;
  background: var(--sgp-thumb-overlay-bg, var(--sgp-overlay-bg)) !important;
}

@media (max-width: 1024px) {
  .sgp-viewer__img,
  .sgp-viewer .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="slider"] .sgp-viewer__img {
    max-height: calc(100vh - 110px) !important;
  }
}

/* ===== v51: viewer sizing controls + strict overlay scope separation ===== */
.sgp-gallery:not(.sgp-type-slider) .sgp-overlay-inner {
  color: var(--sgp-thumb-text-color, var(--sgp-text-color)) !important;
  background: var(--sgp-thumb-overlay-bg, var(--sgp-overlay-bg)) !important;
}

.sgp-gallery.sgp-type-slider .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner {
  color: var(--sgp-viewer-text-color, var(--sgp-text-color)) !important;
  background: var(--sgp-viewer-overlay-bg, var(--sgp-overlay-bg)) !important;
}

.sgp-viewer__stage {
  left: 10px !important;
  right: 10px !important;
  inset-inline-start: 10px !important;
  inset-inline-end: 10px !important;
  width: auto !important;
  max-width: none !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.sgp-viewer__frame {
  width: min(var(--sgp-viewer-max-w, min(calc(100vw - 20px), 1560px)), calc(100vw - 20px)) !important;
  max-width: min(var(--sgp-viewer-max-w, min(calc(100vw - 20px), 1560px)), calc(100vw - 20px)) !important;
  margin-inline: auto !important;
}

.sgp-viewer__main,
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  min-width: 0 !important;
}

.sgp-viewer__main {
  align-items: center !important;
  justify-content: center !important;
}

.sgp-viewer__media {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.sgp-viewer__img,
.sgp-viewer .sgp-viewer__img,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="slider"] .sgp-viewer__img {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: min(100%, var(--sgp-viewer-max-w, calc(100vw - 20px))) !important;
  max-height: var(--sgp-viewer-max-h, min(calc(100vh - 110px), 90vh)) !important;
  object-fit: contain !important;
  object-position: center center !important;
  margin-inline: auto !important;
}

.sgp-gallery[data-nav-transparent="1"] .sgp-nav,
.sgp-viewer[data-nav-transparent="1"] .sgp-viewer__nav,
.sgp-gallery[data-close-transparent="1"] .sgp-slider__close,
.sgp-gallery[data-close-transparent="1"] .sgp-overlay-close,
.sgp-viewer[data-close-transparent="1"] .sgp-viewer__close,
.sgp-viewer[data-close-transparent="1"] .sgp-overlay-close {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}


/* ===== v52: strict overlay scope split + viewer auto/custom sizing ===== */
.sgp-gallery:not(.sgp-type-slider) > .sgp-grid .sgp-overlay-inner,
.sgp-gallery:not(.sgp-type-slider) > .sgp-masonry .sgp-overlay-inner {
  color: var(--sgp-thumb-text-color, var(--sgp-text-color)) !important;
  background: var(--sgp-thumb-overlay-bg, var(--sgp-overlay-bg)) !important;
}

.sgp-gallery.sgp-type-slider > .sgp-slider .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner {
  color: var(--sgp-viewer-text-color, var(--sgp-text-color)) !important;
  background: var(--sgp-viewer-overlay-bg, var(--sgp-overlay-bg)) !important;
}

.sgp-viewer {
  --sgp-viewer-side-gap: 10px;
}

.sgp-viewer__stage {
  width: calc(100vw - (var(--sgp-viewer-side-gap, 10px) * 2)) !important;
  max-width: calc(100vw - (var(--sgp-viewer-side-gap, 10px) * 2)) !important;
  left: var(--sgp-viewer-side-gap, 10px) !important;
  right: var(--sgp-viewer-side-gap, 10px) !important;
  inset-inline-start: var(--sgp-viewer-side-gap, 10px) !important;
  inset-inline-end: var(--sgp-viewer-side-gap, 10px) !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin: 0 auto !important;
}

.sgp-viewer__frame {
  width: min(var(--sgp-viewer-max-w, calc(100vw - 20px)), calc(100vw - (var(--sgp-viewer-side-gap, 10px) * 2))) !important;
  max-width: min(var(--sgp-viewer-max-w, calc(100vw - 20px)), calc(100vw - (var(--sgp-viewer-side-gap, 10px) * 2))) !important;
  max-height: var(--sgp-viewer-max-h, calc(100vh - 110px)) !important;
  margin-inline: auto !important;
}

.sgp-viewer__main,
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  height: 100% !important;
}

.sgp-viewer__img,
.sgp-viewer .sgp-viewer__img,
.sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="fusion"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="mosaic"] .sgp-viewer__img,
.sgp-viewer[data-gallery-type="slider"] .sgp-viewer__img {
  max-width: 100% !important;
  max-height: min(100%, var(--sgp-viewer-max-h, calc(100vh - 110px))) !important;
  margin: auto !important;
}


/* ===== v53: real overlay split + centered custom viewer sizing ===== */
.sgp-gallery .sgp-overlay-inner--thumb {
  color: var(--sgp-thumb-text-color, var(--sgp-text-color)) !important;
  background: var(--sgp-thumb-overlay-bg, var(--sgp-overlay-bg)) !important;
}
.sgp-gallery .sgp-overlay-inner--viewer,
.sgp-viewer .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner--viewer {
  color: var(--sgp-viewer-text-color, var(--sgp-text-color)) !important;
  background: var(--sgp-viewer-overlay-bg, var(--sgp-overlay-bg)) !important;
}
.sgp-gallery .sgp-overlay-inner--thumb * {
  color: inherit;
}
.sgp-gallery .sgp-overlay-inner--viewer *,
.sgp-viewer .sgp-overlay-inner *,
.sgp-viewer .sgp-overlay-inner--viewer * {
  color: inherit;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__stage {
  inset: 0 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  min-height: 100vh !important;
  margin: 0 !important;
  padding: 10px !important;
  box-sizing: border-box !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.sgp-viewer[aria-hidden="false"] .sgp-viewer__frame {
  margin: auto !important;
  max-width: min(var(--sgp-viewer-max-w, calc(100vw - 20px)), calc(100vw - 20px)) !important;
  max-height: min(var(--sgp-viewer-max-h, calc(100vh - 20px)), calc(100vh - 20px)) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
}
.sgp-viewer[aria-hidden="false"] .sgp-viewer__main {
  width: 100% !important;
  flex: 0 1 auto !important;
  min-height: 0 !important;
  display: grid !important;
  place-items: center !important;
}
.sgp-viewer[aria-hidden="false"] .sgp-viewer__mediawrap,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-item,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-media {
  margin: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.sgp-viewer[aria-hidden="false"] .sgp-viewer__img {
  margin: auto !important;
  object-position: center center !important;
}


/* ===== v56 viewer overlay centering + below-controls hard fix ===== */
.sgp-viewer.sgp-pos-center .sgp-overlay-inner { align-items:center !important; justify-content:center !important; }
.sgp-viewer.sgp-pos-top-left .sgp-overlay-inner { align-items:flex-start !important; justify-content:flex-start !important; }
.sgp-viewer.sgp-pos-top-right .sgp-overlay-inner { align-items:flex-start !important; justify-content:flex-end !important; }
.sgp-viewer.sgp-pos-bottom-left .sgp-overlay-inner { align-items:flex-end !important; justify-content:flex-start !important; }
.sgp-viewer.sgp-pos-bottom-right .sgp-overlay-inner { align-items:flex-end !important; justify-content:flex-end !important; }
.sgp-viewer.sgp-anim-fade .sgp-overlay-inner { transform:none !important; }
.sgp-viewer.sgp-anim-left .sgp-overlay-inner { transform:translateX(-18px) !important; }
.sgp-viewer.sgp-anim-right .sgp-overlay-inner { transform:translateX(18px) !important; }
.sgp-viewer.sgp-anim-top .sgp-overlay-inner { transform:translateY(-18px) !important; }
.sgp-viewer.sgp-anim-bottom .sgp-overlay-inner { transform:translateY(18px) !important; }

.sgp-viewer .sgp-viewer__mediawrap,
.sgp-viewer .sgp-viewer__media,
.sgp-viewer .sgp-viewer__media .sgp-item,
.sgp-viewer .sgp-viewer__media .sgp-media {
  overflow: visible !important;
}

.sgp-viewer .sgp-viewer__below,
.sgp-viewer .sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer .sgp-viewer__below .sgp-viewer__protools,
.sgp-viewer .sgp-viewer__below .sgp-social,
.sgp-viewer .sgp-viewer__below .sgp-slider__dots-wrap,
.sgp-viewer .sgp-viewer__below .sgp-slider__counter {
  position: static !important;
  inset: auto !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  transform: none !important;
  translate: none !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__stage {
  overflow-y: auto !important;
  align-items: flex-start !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__frame {
  height: auto !important;
  max-height: none !important;
}

.sgp-viewer[aria-hidden="false"] .sgp-viewer__below {
  width: 100% !important;
  max-height: none !important;
  overflow: visible !important;
  padding-top: 8px !important;
  padding-bottom: 12px !important;
  z-index: 20 !important;
}

.sgp-viewer[data-overlay-size-mode="custom"] .sgp-overlay {
  inset: auto !important;
  top: 0 !important;
  left: 0 !important;
  right: auto !important;
  bottom: auto !important;
  width: min(var(--sgp-overlay-w, 100%), 100%) !important;
  height: min(var(--sgp-overlay-h, 100%), 100%) !important;
  max-width: 100% !important;
  max-height: 100% !important;
  padding: 0 !important;
  transform: none !important;
  clip-path: none !important;
}

.sgp-viewer[data-overlay-size-mode="auto"] .sgp-overlay,
.sgp-viewer:not([data-overlay-size-mode]) .sgp-overlay {
  inset: 0 !important;
  width: auto !important;
  height: auto !important;
  transform: none !important;
}

/* ===== v57 slider custom-size centering hardening ===== */
.sgp-gallery.sgp-type-slider {
  --sgp-slider-shell-gap: clamp(8px, 1.2vw, 12px);
  --sgp-slider-effective-w: min(
    var(--sgp-slider-w, var(--sgp-item-width)),
    max(0px, calc(100% - (var(--sgp-nav-size) * 2) - (var(--sgp-slider-shell-gap) * 2)))
  );
}

.sgp-gallery.sgp-type-slider .sgp-slider {
  grid-template-columns: var(--sgp-nav-size) minmax(0, var(--sgp-slider-effective-w)) var(--sgp-nav-size) !important;
  column-gap: var(--sgp-slider-shell-gap) !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
}

.sgp-gallery.sgp-type-slider .sgp-track {
  grid-column: 2 !important;
  width: var(--sgp-slider-effective-w) !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow: hidden !important;
}

.sgp-gallery.sgp-type-slider .sgp-track-inner {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
}

.sgp-gallery.sgp-type-slider .sgp-slide {
  flex: 0 0 100% !important;
  width: 100% !important;
  min-width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: stretch !important;
  overflow: hidden !important;
}

.sgp-gallery.sgp-type-slider .sgp-item {
  width: min(100%, var(--sgp-slider-w, var(--sgp-item-width))) !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sgp-gallery.sgp-type-slider .sgp-media {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sgp-gallery.sgp-type-slider .sgp-img {
  display: block !important;
  margin-left: auto !important;
  margin-right: auto !important;
  object-position: center center !important;
}

@media (max-width: 900px) {
  .sgp-gallery.sgp-type-slider {
    --sgp-slider-shell-gap: 10px;
    --sgp-slider-effective-w: min(
      var(--sgp-slider-w, var(--sgp-item-width)),
      max(0px, calc(100% - 96px - 20px))
    );
  }
}

@media (max-width: 700px) {
  .sgp-gallery.sgp-type-slider {
    --sgp-slider-shell-gap: 8px;
    --sgp-slider-effective-w: min(
      var(--sgp-slider-w, var(--sgp-item-width)),
      max(0px, calc(100% - 80px - 16px))
    );
  }
}

/* ===== v58 slider custom-size clamp + contain-safe centering ===== */
.sgp-gallery.sgp-type-slider[data-slider-width-mode="custom"],
.sgp-gallery.sgp-type-slider[data-slider-height-mode="custom"] {
  --sgp-slider-effective-h: var(--sgp-slider-h, var(--sgp-item-height));
}

.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slider {
  grid-template-columns: var(--sgp-nav-size) minmax(0, var(--sgp-slider-effective-w, min(100%, var(--sgp-slider-w, var(--sgp-item-width))))) var(--sgp-nav-size) !important;
  justify-content: center !important;
  align-items: center !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-track {
  width: var(--sgp-slider-effective-w, min(100%, var(--sgp-slider-w, var(--sgp-item-width)))) !important;
  max-width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow: hidden !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slide {
  justify-content: center !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-item {
  width: min(100%, var(--sgp-slider-effective-w, var(--sgp-slider-w, var(--sgp-item-width)))) !important;
  max-width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media {
  width: 100% !important;
  max-width: 100% !important;
  height: var(--sgp-slider-effective-h, var(--sgp-slider-h, var(--sgp-item-height))) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-img {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
}


/* ===== v59 slider overlay-nav + clean swipe track ===== */
.sgp-gallery.sgp-type-slider {
  --sgp-slider-shell-gap: clamp(8px, 1.2vw, 12px);
  --sgp-slider-side-pad: clamp(8px, 1.6vw, 16px);
  --sgp-slider-nav-inset: clamp(10px, 1.6vw, 18px);
  --sgp-slider-effective-w: min(
    var(--sgp-slider-w, var(--sgp-item-width)),
    max(220px, calc(100% - (var(--sgp-slider-side-pad) * 2)))
  );
}

.sgp-gallery.sgp-type-slider .sgp-slider {
  display: block !important;
  position: relative !important;
  width: 100% !important;
  padding-left: var(--sgp-slider-side-pad) !important;
  padding-right: var(--sgp-slider-side-pad) !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

.sgp-gallery.sgp-type-slider .sgp-track {
  grid-column: auto !important;
  width: var(--sgp-slider-effective-w) !important;
  max-width: 100% !important;
  margin: 0 auto !important;
  overflow: hidden !important;
  position: relative !important;
}

.sgp-gallery.sgp-type-slider .sgp-track-inner {
  display: flex !important;
  flex-wrap: nowrap !important;
  width: auto;
  will-change: transform !important;
  backface-visibility: hidden !important;
  transform: translateZ(0);
}

.sgp-gallery.sgp-type-slider .sgp-slide {
  overflow: hidden !important;
  position: relative !important;
}

.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  width: 100% !important;
  max-width: 100% !important;
}

.sgp-gallery.sgp-type-slider .sgp-prev,
.sgp-gallery.sgp-type-slider .sgp-next {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 5 !important;
  pointer-events: auto !important;
}

.sgp-gallery.sgp-type-slider .sgp-prev {
  left: max(var(--sgp-slider-side-pad), calc(50% - (var(--sgp-slider-effective-w) / 2) + var(--sgp-slider-nav-inset))) !important;
}

.sgp-gallery.sgp-type-slider .sgp-next {
  right: max(var(--sgp-slider-side-pad), calc(50% - (var(--sgp-slider-effective-w) / 2) + var(--sgp-slider-nav-inset))) !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slider {
  grid-template-columns: none !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-track {
  width: var(--sgp-slider-effective-w, min(100%, var(--sgp-slider-w, var(--sgp-item-width)))) !important;
}

@media (max-width: 900px) {
  .sgp-gallery.sgp-type-slider {
    --sgp-slider-side-pad: 12px;
    --sgp-slider-nav-inset: 12px;
  }
}

@media (max-width: 700px) {
  .sgp-gallery.sgp-type-slider {
    --sgp-slider-side-pad: 8px;
    --sgp-slider-nav-inset: 8px;
  }
}


/* ===== v60 slider overlay sync with rendered image ===== */
.sgp-gallery.sgp-type-slider .sgp-media {
  position: relative !important;
}

.sgp-gallery.sgp-type-slider .sgp-overlay {
  inset: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: stretch !important;
  justify-content: stretch !important;
}

.sgp-gallery.sgp-type-slider .sgp-overlay-inner {
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}

/* v66 photo border/background controls */
.sgp-gallery .sgp-media,
.sgp-viewer__media .sgp-media,
.sgp-viewer__mediawrap .sgp-media {
  border-radius: var(--sgp-image-radius) !important;
  border-width: var(--sgp-image-border-w, 0px) !important;
  border-style: var(--sgp-image-border-style, solid) !important;
  border-color: var(--sgp-image-border-color, transparent) !important;
  background: var(--sgp-media-bg, transparent) !important;
  box-sizing: border-box !important;
}

.sgp-gallery .sgp-img,
.sgp-viewer__img,
.sgp-viewer__media .sgp-img {
  border-radius: var(--sgp-image-inner-radius, var(--sgp-image-radius, 0px)) !important;
}

.sgp-gallery .sgp-overlay,
.sgp-viewer .sgp-overlay {
  clip-path: inset(0 round var(--sgp-image-inner-radius, var(--sgp-image-radius))) !important;
}

.sgp-gallery[data-grid-fit="contain"].sgp-type-grid .sgp-media,
.sgp-gallery[data-slider-fit="contain"].sgp-type-slider .sgp-media,
.sgp-gallery[data-masonry-fit="contain"].sgp-type-masonry .sgp-media,
.sgp-viewer .sgp-media {
  background: var(--sgp-media-bg, transparent) !important;
}


/* v67 viewer/slider border + mobile centering + thumbnail overlay sync */
.sgp-gallery.sgp-type-slider .sgp-media,
.sgp-viewer .sgp-media {
  border-width: var(--sgp-image-border-w, 0px) !important;
  border-style: var(--sgp-image-border-style, solid) !important;
  border-color: var(--sgp-image-border-color, transparent) !important;
  border-radius: var(--sgp-image-radius, 0px) !important;
  background: var(--sgp-media-bg, transparent) !important;
  box-sizing: border-box !important;
}

.sgp-gallery .sgp-media > .sgp-overlay,
.sgp-viewer .sgp-media > .sgp-overlay {
  clip-path: inset(0 round var(--sgp-image-inner-radius, var(--sgp-image-radius, 0px))) !important;
}

@media (max-width: 700px) {
  .sgp-viewer,
  .sgp-viewer__stage,
  .sgp-viewer__frame,
  .sgp-viewer__main,
  .sgp-viewer__mediawrap,
  .sgp-viewer__media {
    box-sizing: border-box !important;
  }

  .sgp-viewer__stage {
    width: 100vw !important;
    max-width: 100vw !important;
    padding: 12px 10px 16px !important;
    overflow-x: hidden !important;
  }

  .sgp-viewer__frame {
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .sgp-viewer__main,
  .sgp-viewer__mediawrap,
  .sgp-viewer__media {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    justify-content: center !important;
    align-items: center !important;
  }
}


/* ===== v69 small-display slider clipping fix ===== */
.sgp-gallery.sgp-type-slider {
  overflow-x: hidden !important;
}

.sgp-gallery.sgp-type-slider .sgp-slider {
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.sgp-gallery.sgp-type-slider .sgp-track {
  width: var(--sgp-slider-safe-w, var(--sgp-slider-effective-w, min(100%, var(--sgp-slider-w, var(--sgp-item-width))))) !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media,
.sgp-gallery.sgp-type-slider .sgp-img {
  box-sizing: border-box !important;
}

.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  max-width: 100% !important;
  overflow: hidden !important;
}

.sgp-gallery.sgp-type-slider .sgp-img {
  max-width: 100% !important;
}

@media (max-width: 700px) {
  .sgp-gallery.sgp-type-slider {
    --sgp-slider-side-pad: 6px;
    --sgp-slider-nav-inset: 6px;
  }

  .sgp-gallery.sgp-type-slider .sgp-slider {
    padding-left: var(--sgp-slider-side-pad) !important;
    padding-right: var(--sgp-slider-side-pad) !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    width: var(--sgp-slider-safe-w, 100%) !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-prev {
    left: max(2px, calc(var(--sgp-slider-side-pad) + 2px)) !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-next {
    right: max(2px, calc(var(--sgp-slider-side-pad) + 2px)) !important;
  }
}


/* ===== v70 responsive slider safety + polaroid below+viewer ===== */
.sgp-gallery.sgp-type-slider {
  --sgp-slider-responsive-max-h: min(72vh, var(--sgp-slider-h, var(--sgp-item-height)));
}

.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-track-inner,
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  min-width: 0 !important;
}

.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  width: min(100%, var(--sgp-slider-safe-w, var(--sgp-slider-effective-w, 100%))) !important;
  max-width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-fit-safe .sgp-media {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  height: min(var(--sgp-slider-effective-h, var(--sgp-slider-h, var(--sgp-item-height))), var(--sgp-slider-responsive-max-h)) !important;
  max-height: var(--sgp-slider-responsive-max-h) !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-fit-safe .sgp-img {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
}

@media (max-width: 1024px) {
  .sgp-gallery.sgp-type-slider {
    --sgp-slider-side-pad: clamp(4px, 1vw, 10px);
    --sgp-slider-nav-inset: clamp(4px, 1vw, 10px);
  }

  .sgp-gallery.sgp-type-slider .sgp-slider,
  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-track {
    width: min(100%, var(--sgp-slider-safe-w, var(--sgp-slider-effective-w, 100%))) !important;
  }
}

@media (max-width: 767px) {
  .sgp-gallery.sgp-type-slider {
    --sgp-slider-responsive-max-h: min(58vh, var(--sgp-slider-effective-h, var(--sgp-slider-h, var(--sgp-item-height))));
  }

  .sgp-gallery.sgp-type-slider .sgp-slider {
    padding-left: max(2px, var(--sgp-slider-side-pad, 6px)) !important;
    padding-right: max(2px, var(--sgp-slider-side-pad, 6px)) !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    width: min(100%, var(--sgp-slider-safe-w, var(--sgp-slider-effective-w, 100%))) !important;
  }
}

.sgp-viewer__caption--polaroid {
  width: min(100%, var(--sgp-btn-w, 100%)) !important;
  max-width: min(100%, var(--sgp-btn-w, 100%)) !important;
  box-sizing: border-box !important;
  padding: 12px 14px !important;
  border-radius: 12px !important;
  background: var(--sgp-viewer-overlay-bg, rgba(0,0,0,.06)) !important;
  color: var(--sgp-viewer-text-color, inherit) !important;
  text-align: left !important;
}

.sgp-viewer__caption--polaroid > * + * {
  margin-top: 8px !important;
}

/* ===== v72: verified responsive + polaroid below-viewer fixes ===== */
.sgp-gallery.sgp-type-slider {
  overflow-x: hidden !important;
}
.sgp-gallery.sgp-type-slider .sgp-slider,
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-track-inner,
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  box-sizing: border-box !important;
}
.sgp-gallery.sgp-type-slider .sgp-slider {
  width: min(100%, var(--sgp-slider-effective-w, 100%)) !important;
  max-width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-gallery.sgp-type-slider .sgp-track {
  width: min(100%, var(--sgp-slider-effective-w, 100%)) !important;
  max-width: 100% !important;
  overflow: hidden !important;
}
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  max-width: 100% !important;
}
.sgp-gallery.sgp-type-slider .sgp-img {
  display: block !important;
  max-width: 100% !important;
  height: auto !important;
  margin-left: auto !important;
  margin-right: auto !important;
  object-position: center center !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-safe .sgp-img,
.sgp-gallery.sgp-type-slider.sgp-slider-width-clamped .sgp-img,
.sgp-gallery.sgp-type-slider.sgp-slider-height-clamped .sgp-img {
  object-fit: contain !important;
}

.sgp-viewer .sgp-viewer__stage,
.sgp-viewer .sgp-viewer__frame,
.sgp-viewer .sgp-viewer__main,
.sgp-viewer .sgp-viewer__mediawrap,
.sgp-viewer .sgp-viewer__media,
.sgp-viewer .sgp-viewer__media .sgp-item,
.sgp-viewer .sgp-viewer__media .sgp-media {
  box-sizing: border-box !important;
}

@media (max-width: 1024px) {
  .sgp-gallery.sgp-type-slider .sgp-slider,
  .sgp-gallery.sgp-type-slider .sgp-track {
    width: min(100%, var(--sgp-slider-effective-w, 100%)) !important;
    max-width: 100% !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-img {
    object-fit: contain !important;
  }
}

@media (max-width: 767px) {
  .sgp-viewer .sgp-viewer__stage {
    padding-left: 12px !important;
    padding-right: 12px !important;
    justify-content: center !important;
    align-items: center !important;
  }
  .sgp-viewer .sgp-viewer__frame,
  .sgp-viewer .sgp-viewer__main,
  .sgp-viewer .sgp-viewer__below {
    width: min(100%, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .sgp-viewer .sgp-viewer__mediawrap,
  .sgp-viewer .sgp-viewer__media,
  .sgp-viewer .sgp-viewer__media .sgp-item,
  .sgp-viewer .sgp-viewer__media .sgp-media,
  .sgp-viewer .sgp-viewer__img {
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}


/* ===== v75 viewer overlay 9-point alignment + mobile centering ===== */
.sgp-viewer.sgp-pos-top-center .sgp-overlay-inner { align-items:flex-start !important; justify-content:center !important; }
.sgp-viewer.sgp-pos-middle-left .sgp-overlay-inner { align-items:center !important; justify-content:flex-start !important; }
.sgp-viewer.sgp-pos-middle-center .sgp-overlay-inner,
.sgp-viewer.sgp-pos-center .sgp-overlay-inner { align-items:center !important; justify-content:center !important; }
.sgp-viewer.sgp-pos-middle-right .sgp-overlay-inner { align-items:center !important; justify-content:flex-end !important; }
.sgp-viewer.sgp-pos-bottom-center .sgp-overlay-inner { align-items:flex-end !important; justify-content:center !important; }
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content[data-align="left"] { align-items:flex-start !important; }
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content[data-align="center"] { align-items:center !important; }
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content[data-align="right"] { align-items:flex-end !important; }
@media (max-width: 767px) {
  .sgp-viewer .sgp-viewer__stage {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
  .sgp-viewer .sgp-viewer__topbar,
  .sgp-viewer .sgp-viewer__frame,
  .sgp-viewer .sgp-viewer__main,
  .sgp-viewer .sgp-viewer__below {
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .sgp-viewer .sgp-viewer__close {
    right: 8px !important;
    top: 8px !important;
  }
}


/* ===== v76: viewer text alignment override uses 9-point positions ===== */
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content {
  justify-content: flex-start !important;
}
.sgp-viewer.sgp-pos-top-left .sgp-overlay-inner,
.sgp-viewer.sgp-pos-top-center .sgp-overlay-inner,
.sgp-viewer.sgp-pos-top-right .sgp-overlay-inner {
  align-items: flex-start !important;
}
.sgp-viewer.sgp-pos-middle-left .sgp-overlay-inner,
.sgp-viewer.sgp-pos-middle-center .sgp-overlay-inner,
.sgp-viewer.sgp-pos-middle-right .sgp-overlay-inner,
.sgp-viewer.sgp-pos-center .sgp-overlay-inner {
  align-items: center !important;
}
.sgp-viewer.sgp-pos-bottom-left .sgp-overlay-inner,
.sgp-viewer.sgp-pos-bottom-center .sgp-overlay-inner,
.sgp-viewer.sgp-pos-bottom-right .sgp-overlay-inner {
  align-items: flex-end !important;
}
@media (max-width: 767px) {
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__stage {
    padding-left: 12px !important;
    padding-right: 18px !important;
    justify-content: center !important;
    align-items: center !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__frame {
    width: calc(100vw - 30px) !important;
    max-width: calc(100vw - 30px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__topbar,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__main,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__below {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__media,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__mediawrap,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__img {
    margin-left: auto !important;
    margin-right: auto !important;
  }
}


/* ===== v77: thumbnail text alignment override + mobile viewer centering ===== */
.sgp-gallery[data-thumb-text-align="left"] .sgp-overlay-inner--thumb .sgp-overlay-content {
  text-align: left !important;
  align-items: flex-start !important;
}
.sgp-gallery[data-thumb-text-align="center"] .sgp-overlay-inner--thumb .sgp-overlay-content {
  text-align: center !important;
  align-items: center !important;
}
.sgp-gallery[data-thumb-text-align="right"] .sgp-overlay-inner--thumb .sgp-overlay-content {
  text-align: right !important;
  align-items: flex-end !important;
}
.sgp-gallery[data-thumb-text-align="left"] .sgp-overlay-inner--thumb .sgp-title,
.sgp-gallery[data-thumb-text-align="left"] .sgp-overlay-inner--thumb .sgp-excerpt,
.sgp-gallery[data-thumb-text-align="left"] .sgp-overlay-inner--thumb .sgp-description,
.sgp-gallery[data-thumb-text-align="left"] .sgp-overlay-inner--thumb .sgp-alt,
.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below .sgp-title,
.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below .sgp-excerpt,
.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below .sgp-description,
.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below .sgp-alt {
  text-align: left !important;
  margin-left: 0 !important;
  margin-right: auto !important;
  align-self: flex-start !important;
}
.sgp-gallery[data-thumb-text-align="center"] .sgp-overlay-inner--thumb .sgp-title,
.sgp-gallery[data-thumb-text-align="center"] .sgp-overlay-inner--thumb .sgp-excerpt,
.sgp-gallery[data-thumb-text-align="center"] .sgp-overlay-inner--thumb .sgp-description,
.sgp-gallery[data-thumb-text-align="center"] .sgp-overlay-inner--thumb .sgp-alt,
.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below .sgp-title,
.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below .sgp-excerpt,
.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below .sgp-description,
.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below .sgp-alt {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
  align-self: center !important;
}
.sgp-gallery[data-thumb-text-align="right"] .sgp-overlay-inner--thumb .sgp-title,
.sgp-gallery[data-thumb-text-align="right"] .sgp-overlay-inner--thumb .sgp-excerpt,
.sgp-gallery[data-thumb-text-align="right"] .sgp-overlay-inner--thumb .sgp-description,
.sgp-gallery[data-thumb-text-align="right"] .sgp-overlay-inner--thumb .sgp-alt,
.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below .sgp-title,
.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below .sgp-excerpt,
.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below .sgp-description,
.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below .sgp-alt {
  text-align: right !important;
  margin-left: auto !important;
  margin-right: 0 !important;
  align-self: flex-end !important;
}
.sgp-gallery[data-thumb-text-align] .sgp-thumb__below {
  width: 100% !important;
}
@media (max-width: 767px) {
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__stage {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__frame {
    width: calc(100vw - 24px) !important;
    max-width: calc(100vw - 24px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}


/* v78 fixes: thumbnail text alignment + slider custom width centering */
.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below {
  text-align: left !important;
  align-items: flex-start !important;
}
.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below {
  text-align: center !important;
  align-items: center !important;
}
.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below {
  text-align: right !important;
  align-items: flex-end !important;
}
.sgp-gallery[data-thumb-text-align] .sgp-thumb__below .sgp-title,
.sgp-gallery[data-thumb-text-align] .sgp-thumb__below .sgp-excerpt,
.sgp-gallery[data-thumb-text-align] .sgp-thumb__below .sgp-description,
.sgp-gallery[data-thumb-text-align] .sgp-thumb__below .sgp-alt {
  width: 100% !important;
  max-width: 100% !important;
}
.sgp-gallery.sgp-type-slider .sgp-slider,
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-track-inner {
  box-sizing: border-box !important;
}
.sgp-gallery.sgp-type-slider .sgp-track {
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-slide .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-slide .sgp-media {
  box-sizing: border-box !important;
}


/* v79 fixes: slider right-edge border clipping + thumbnail below text alignment */
.sgp-gallery.sgp-type-slider .sgp-slider,
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  box-sizing: border-box !important;
}

.sgp-gallery.sgp-type-slider .sgp-track {
  margin-left: auto !important;
  margin-right: auto !important;
}

.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  margin-left: auto !important;
  margin-right: auto !important;
}

.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below,
.sgp-gallery .sgp-thumb__below.sgp-thumb-align-left,
.sgp-gallery.sgp-thumb-align-left .sgp-thumb__below {
  text-align: left !important;
  align-items: flex-start !important;
}

.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below,
.sgp-gallery .sgp-thumb__below.sgp-thumb-align-center,
.sgp-gallery.sgp-thumb-align-center .sgp-thumb__below {
  text-align: center !important;
  align-items: center !important;
}

.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below,
.sgp-gallery .sgp-thumb__below.sgp-thumb-align-right,
.sgp-gallery.sgp-thumb-align-right .sgp-thumb__below {
  text-align: right !important;
  align-items: flex-end !important;
}

.sgp-gallery .sgp-thumb__below,
.sgp-gallery .sgp-thumb__below .sgp-title,
.sgp-gallery .sgp-thumb__below .sgp-excerpt,
.sgp-gallery .sgp-thumb__below .sgp-description,
.sgp-gallery .sgp-thumb__below .sgp-alt {
  box-sizing: border-box !important;
}

.sgp-gallery .sgp-thumb__below .sgp-title,
.sgp-gallery .sgp-thumb__below .sgp-excerpt,
.sgp-gallery .sgp-thumb__below .sgp-description,
.sgp-gallery .sgp-thumb__below .sgp-alt {
  display: block !important;
}


/* v81: remove unintended extra slider close button */
.sgp-gallery .sgp-slider__close{display:none !important; visibility:hidden !important; pointer-events:none !important;}

/* v87 responsive slider + polaroid safety */
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media,
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-slide {
  box-sizing: border-box !important;
}
.sgp-gallery.sgp-type-slider .sgp-media {
  overflow: hidden !important;
}
.sgp-gallery.sgp-type-slider .sgp-img {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-media {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-img {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
}
.sgp-viewer .sgp-viewer__mediawrap {
  overflow: visible !important;
}
.sgp-viewer .sgp-viewer__nav {
  margin: 0 !important;
}


/* v82 stronger global text alignment reliability */
.sgp-gallery .sgp-overlay-content > .sgp-title,
.sgp-gallery .sgp-overlay-content > .sgp-excerpt,
.sgp-gallery .sgp-overlay-content > .sgp-description,
.sgp-gallery .sgp-overlay-content > .sgp-alt,
.sgp-gallery .sgp-thumb__below > .sgp-title,
.sgp-gallery .sgp-thumb__below > .sgp-excerpt,
.sgp-gallery .sgp-thumb__below > .sgp-description,
.sgp-gallery .sgp-thumb__below > .sgp-alt {
  box-sizing: border-box !important;
}


/* v84 stronger global text field inheritance + visible left/right alignment */
.sgp-gallery[data-global-text-style="1"][data-global-apply-title="1"] .sgp-title,
.sgp-viewer [data-global-text-style="1"][data-global-apply-title="1"] .sgp-title {
  font-family: var(--sgp-font-family) !important;
  font-size: var(--sgp-font-size) !important;
  color: var(--sgp-text-color) !important;
  font-weight: var(--sgp-text-weight) !important;
  font-style: var(--sgp-text-style) !important;
  line-height: var(--sgp-global-line-height) !important;
  letter-spacing: var(--sgp-global-letter-spacing) !important;
  text-transform: var(--sgp-global-transform) !important;
}

.sgp-gallery[data-global-text-style="1"][data-global-apply-excerpt="1"] .sgp-excerpt,
.sgp-gallery[data-global-text-style="1"][data-global-apply-description="1"] .sgp-description,
.sgp-gallery[data-global-text-style="1"][data-global-apply-alt="1"] .sgp-alt {
  font-family: var(--sgp-font-family) !important;
  font-size: var(--sgp-font-size) !important;
  color: var(--sgp-text-color) !important;
  font-weight: var(--sgp-text-weight) !important;
  font-style: var(--sgp-text-style) !important;
  line-height: var(--sgp-global-line-height) !important;
  letter-spacing: var(--sgp-global-letter-spacing) !important;
  text-transform: var(--sgp-global-transform) !important;
}

.sgp-gallery[data-text-align="left"] .sgp-overlay-content > .sgp-title,
.sgp-gallery[data-text-align="left"] .sgp-overlay-content > .sgp-excerpt,
.sgp-gallery[data-text-align="left"] .sgp-overlay-content > .sgp-description,
.sgp-gallery[data-text-align="left"] .sgp-overlay-content > .sgp-alt,
.sgp-gallery[data-text-align="left"] .sgp-thumb__below > .sgp-title,
.sgp-gallery[data-text-align="left"] .sgp-thumb__below > .sgp-excerpt,
.sgp-gallery[data-text-align="left"] .sgp-thumb__below > .sgp-description,
.sgp-gallery[data-text-align="left"] .sgp-thumb__below > .sgp-alt {
  width: auto !important;
  min-width: 0 !important;
  margin-left: 0 !important;
  margin-right: auto !important;
  align-self: flex-start !important;
  text-align: left !important;
}

.sgp-gallery[data-text-align="right"] .sgp-overlay-content > .sgp-title,
.sgp-gallery[data-text-align="right"] .sgp-overlay-content > .sgp-excerpt,
.sgp-gallery[data-text-align="right"] .sgp-overlay-content > .sgp-description,
.sgp-gallery[data-text-align="right"] .sgp-overlay-content > .sgp-alt,
.sgp-gallery[data-text-align="right"] .sgp-thumb__below > .sgp-title,
.sgp-gallery[data-text-align="right"] .sgp-thumb__below > .sgp-excerpt,
.sgp-gallery[data-text-align="right"] .sgp-thumb__below > .sgp-description,
.sgp-gallery[data-text-align="right"] .sgp-thumb__below > .sgp-alt {
  width: auto !important;
  min-width: 0 !important;
  margin-left: auto !important;
  margin-right: 0 !important;
  align-self: flex-end !important;
  text-align: right !important;
}

.sgp-gallery[data-text-align="center"] .sgp-overlay-content > .sgp-title,
.sgp-gallery[data-text-align="center"] .sgp-overlay-content > .sgp-excerpt,
.sgp-gallery[data-text-align="center"] .sgp-overlay-content > .sgp-description,
.sgp-gallery[data-text-align="center"] .sgp-overlay-content > .sgp-alt,
.sgp-gallery[data-text-align="center"] .sgp-thumb__below > .sgp-title,
.sgp-gallery[data-text-align="center"] .sgp-thumb__below > .sgp-excerpt,
.sgp-gallery[data-text-align="center"] .sgp-thumb__below > .sgp-description,
.sgp-gallery[data-text-align="center"] .sgp-thumb__below > .sgp-alt {
  width: auto !important;
  min-width: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
  align-self: center !important;
  text-align: center !important;
}

/* v86 global text only affects selected fields */
.sgp-gallery[data-global-text-style="1"][data-global-apply-title="1"] .sgp-title[data-sgp-text-field="title"] span[style],
.sgp-gallery[data-global-text-style="1"][data-global-apply-excerpt="1"] .sgp-excerpt[data-sgp-text-field="excerpt"] span[style],
.sgp-gallery[data-global-text-style="1"][data-global-apply-description="1"] .sgp-description[data-sgp-text-field="description"] span[style],
.sgp-gallery[data-global-text-style="1"][data-global-apply-alt="1"] .sgp-alt[data-sgp-text-field="alt"] span[style] {
  color: inherit !important;
  font: inherit !important;
  letter-spacing: inherit !important;
  text-transform: inherit !important;
}
.sgp-gallery[data-text-align]:not([data-text-align=""]) .sgp-overlay-content > .sgp-title,
.sgp-gallery[data-text-align]:not([data-text-align=""]) .sgp-overlay-content > .sgp-excerpt,
.sgp-gallery[data-text-align]:not([data-text-align=""]) .sgp-overlay-content > .sgp-description,
.sgp-gallery[data-text-align]:not([data-text-align=""]) .sgp-overlay-content > .sgp-alt,
.sgp-gallery[data-text-align]:not([data-text-align=""]) .sgp-thumb__below > .sgp-title,
.sgp-gallery[data-text-align]:not([data-text-align=""]) .sgp-thumb__below > .sgp-excerpt,
.sgp-gallery[data-text-align]:not([data-text-align=""]) .sgp-thumb__below > .sgp-description,
.sgp-gallery[data-text-align]:not([data-text-align=""]) .sgp-thumb__below > .sgp-alt {
  width: -moz-fit-content !important;
  width: fit-content !important;
}


/* v87 stronger global text alignment rules */
.sgp-gallery[data-text-align="left"] .sgp-overlay-content,
.sgp-gallery[data-text-align="left"] .sgp-thumb__below {
  text-align: left !important;
  align-items: flex-start !important;
}
.sgp-gallery[data-text-align="center"] .sgp-overlay-content,
.sgp-gallery[data-text-align="center"] .sgp-thumb__below {
  text-align: center !important;
  align-items: center !important;
}
.sgp-gallery[data-text-align="right"] .sgp-overlay-content,
.sgp-gallery[data-text-align="right"] .sgp-thumb__below {
  text-align: right !important;
  align-items: flex-end !important;
}
.sgp-gallery[data-text-align="left"] .sgp-overlay-content .sgp-title,
.sgp-gallery[data-text-align="left"] .sgp-overlay-content .sgp-excerpt,
.sgp-gallery[data-text-align="left"] .sgp-overlay-content .sgp-description,
.sgp-gallery[data-text-align="left"] .sgp-overlay-content .sgp-alt,
.sgp-gallery[data-text-align="left"] .sgp-thumb__below .sgp-title,
.sgp-gallery[data-text-align="left"] .sgp-thumb__below .sgp-excerpt,
.sgp-gallery[data-text-align="left"] .sgp-thumb__below .sgp-description,
.sgp-gallery[data-text-align="left"] .sgp-thumb__below .sgp-alt {
  margin-left: 0 !important;
  margin-right: auto !important;
  align-self: flex-start !important;
  text-align: left !important;
}
.sgp-gallery[data-text-align="center"] .sgp-overlay-content .sgp-title,
.sgp-gallery[data-text-align="center"] .sgp-overlay-content .sgp-excerpt,
.sgp-gallery[data-text-align="center"] .sgp-overlay-content .sgp-description,
.sgp-gallery[data-text-align="center"] .sgp-overlay-content .sgp-alt,
.sgp-gallery[data-text-align="center"] .sgp-thumb__below .sgp-title,
.sgp-gallery[data-text-align="center"] .sgp-thumb__below .sgp-excerpt,
.sgp-gallery[data-text-align="center"] .sgp-thumb__below .sgp-description,
.sgp-gallery[data-text-align="center"] .sgp-thumb__below .sgp-alt {
  margin-left: auto !important;
  margin-right: auto !important;
  align-self: center !important;
  text-align: center !important;
}
.sgp-gallery[data-text-align="right"] .sgp-overlay-content .sgp-title,
.sgp-gallery[data-text-align="right"] .sgp-overlay-content .sgp-excerpt,
.sgp-gallery[data-text-align="right"] .sgp-overlay-content .sgp-description,
.sgp-gallery[data-text-align="right"] .sgp-overlay-content .sgp-alt,
.sgp-gallery[data-text-align="right"] .sgp-thumb__below .sgp-title,
.sgp-gallery[data-text-align="right"] .sgp-thumb__below .sgp-excerpt,
.sgp-gallery[data-text-align="right"] .sgp-thumb__below .sgp-description,
.sgp-gallery[data-text-align="right"] .sgp-thumb__below .sgp-alt {
  margin-left: auto !important;
  margin-right: 0 !important;
  align-self: flex-end !important;
  text-align: right !important;
}

/* RC60 frontend modal + slider polish */
.sgp-meta-modal[hidden]{display:none !important;}
.sgp-meta-modal{position:fixed;inset:0;z-index:100000;display:flex;align-items:center;justify-content:center;padding:20px;}
.sgp-meta-modal__backdrop{position:absolute;inset:0;background:rgba(18,13,32,.70);backdrop-filter:blur(2px);}
.sgp-meta-modal__panel{position:relative;z-index:1;width:min(760px,calc(100vw - 28px));max-height:min(82vh,860px);overflow:auto;border-radius:24px;background:#fff;border:1px solid rgba(124,58,237,.16);box-shadow:0 32px 80px rgba(19,12,34,.34);padding:22px;}
.sgp-meta-modal__head{display:flex;flex-direction:column;gap:4px;padding-right:44px;margin-bottom:14px;}
.sgp-meta-modal__head strong{font-size:18px;line-height:1.25;color:#2f1c54;}
.sgp-meta-modal__head small{color:#75658f;}
.sgp-meta-modal__close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:999px;border:1px solid rgba(124,58,237,.18);background:linear-gradient(135deg,#f4eeff,#ede3ff);color:#7c3aed;font-size:24px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;}
.sgp-meta-modal__body .sgp-meta-panel{max-width:none;margin:0;border:none;box-shadow:none;padding:0;background:transparent;}
.sgp-gallery.sgp-type-slider .sgp-slider,
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-track-inner,
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media{overflow:hidden;}
.sgp-gallery.sgp-type-slider .sgp-media{display:flex;align-items:center;justify-content:center;}
.sgp-gallery.sgp-type-slider .sgp-img{display:block;margin:0 auto;}

/* ===== v61 targeted fixes ===== */
.sgp-meta-modal{position:fixed;inset:0;z-index:99999;display:grid;place-items:center;padding:18px;}
.sgp-meta-modal[hidden]{display:none !important;}
.sgp-meta-modal__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.70);backdrop-filter:blur(1px);}
.sgp-meta-modal__panel{
  position:relative;z-index:1;width:min(520px,calc(100vw - 32px));max-height:min(82vh,860px);overflow:auto;
  background:#18181f !important;color:#f8fafc !important;border-radius:20px;border:1px solid rgba(168,85,247,.28) !important;
  box-shadow:0 24px 64px rgba(2,6,23,.45) !important;padding:22px !important;
}
.sgp-meta-modal__head{display:flex;align-items:flex-start;gap:10px;margin:0 44px 18px 0;color:#f8fafc;}
.sgp-meta-modal__head strong{display:block;font-size:18px;line-height:1.2;}
.sgp-meta-modal__head small{display:block;margin-top:2px;color:#ddd6fe;}
.sgp-meta-modal__close{position:absolute;top:12px;right:12px;width:38px;height:38px;border:0;border-radius:999px;background:rgba(139,92,246,.12);color:#c4b5fd;display:grid;place-items:center;cursor:pointer;font-size:24px;line-height:1;}
.sgp-meta-modal__close:hover{background:rgba(139,92,246,.18);color:#ede9fe;}
.sgp-meta-modal__body{color:#f8fafc;}
.sgp-meta-panel{display:grid;gap:10px;}
.sgp-meta-panel__row{display:grid;grid-template-columns:minmax(110px,160px) 1fr;gap:12px;padding:10px 12px;border-radius:14px;background:#0f1220;border:1px solid rgba(196,181,253,.16);}
.sgp-meta-panel__k{color:#c4b5fd;font-weight:700;}
.sgp-meta-panel__v{color:#f8fafc;word-break:break-word;}

.sgp-gallery[data-slider-width-mode="fit"] .sgp-media,
.sgp-gallery[data-slider-height-mode="fit"] .sgp-media{
  width:100% !important;height:100% !important;max-width:none !important;max-height:none !important;overflow:hidden !important;
}
.sgp-gallery[data-slider-width-mode="fit"] .sgp-img,
.sgp-gallery[data-slider-height-mode="fit"] .sgp-img{
  width:100% !important;height:100% !important;max-width:none !important;max-height:none !important;object-fit:cover !important;object-position:center center !important;
}

/* ==== RC63 frontend hard fixes ==== */
.sgp-viewer__stage{background:var(--sgp-viewer-backdrop, rgba(15,23,42,.78)) !important;}
.sgp-probtn{color:var(--sgp-protools-slider-text,#111) !important;background:var(--sgp-protools-slider-bg, rgba(255,255,255,.92)) !important;border-color:transparent !important;}
.sgp-probtn .sgp-mark-icon,.sgp-probtn .sgp-btn__icon,.sgp-probtn svg{color:var(--sgp-protools-slider-icon,#111) !important;}
.sgp-viewer .sgp-probtn{color:var(--sgp-protools-viewer-text,#fff) !important;background:var(--sgp-protools-viewer-bg, rgba(17,24,39,.88)) !important;}
.sgp-viewer .sgp-probtn .sgp-mark-icon,.sgp-viewer .sgp-probtn .sgp-btn__icon,.sgp-viewer .sgp-probtn svg{color:var(--sgp-protools-viewer-icon,#fff) !important;}
.sgp-social__link{background:var(--sgp-social-bg, rgba(17,24,39,.88)) !important;color:var(--sgp-social-icon,#fff) !important;border-color:transparent !important;}
.sgp-social__link .sgp-social__ic,.sgp-social__link .sgp-social__ic svg{color:var(--sgp-social-icon,#fff) !important;fill:currentColor;}
.sgp-social__label,.sgp-social__text{color:var(--sgp-social-text,#fff) !important;}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slider,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-track,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media{width:100% !important;max-width:100% !important;}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media{height:var(--sgp-slider-effective-h) !important;overflow:hidden !important;}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-img{width:100% !important;height:100% !important;max-width:none !important;max-height:none !important;object-fit:contain !important;object-position:center center !important;display:block !important;}
.sgp-meta-modal__backdrop{background:rgba(15,23,42,.70) !important;backdrop-filter:blur(1px);}
.sgp-meta-modal__panel{background:linear-gradient(180deg,rgba(14,20,41,.98),rgba(9,14,31,.98)) !important;border:1px solid rgba(139,92,246,.18) !important;box-shadow:0 32px 80px rgba(12,18,34,.46) !important;color:#f8fafc !important;}
.sgp-meta-modal__head strong,.sgp-meta-modal__body{color:#f8fafc !important;}
.sgp-meta-modal__head small{color:#ddd6fe !important;}
.sgp-meta-modal__close{background:rgba(139,92,246,.14) !important;border:0 !important;color:#ddd6fe !important;display:grid !important;place-items:center !important;}
.sgp-meta-modal__close:hover{background:rgba(139,92,246,.22) !important;color:#fff !important;}


/* RC64 modal + fit display + viewer ui hard fixes */
.sgp-meta-modal{z-index:2147483647 !important;}
.sgp-meta-modal__backdrop{z-index:2147483647 !important;}
.sgp-meta-modal__panel{z-index:2147483648 !important;}
body.sgp-meta-open .sgp-viewer__protools,
body.sgp-meta-open .sgp-social,
body.sgp-meta-open .sgp-viewer__below,
body.sgp-meta-open .sgp-thumb__below,
body.sgp-meta-open .sgp-slider__below{z-index:1 !important;}

.sgp-gallery.sgp-slider-fit-display .sgp-slider,
.sgp-gallery.sgp-slider-fit-display .sgp-track,
.sgp-gallery.sgp-slider-fit-display .sgp-track-inner,
.sgp-gallery.sgp-slider-fit-display .sgp-slide,
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-item,
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-media{
  width:100% !important;
  max-width:100% !important;
}
.sgp-gallery.sgp-slider-fit-display .sgp-slide,
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-item,
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-media{
  height:var(--sgp-slider-effective-h, min(78vh, 900px)) !important;
  max-height:none !important;
  overflow:hidden !important;
}
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-img{
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  max-height:none !important;
  object-fit:cover !important;
  object-position:center center !important;
  display:block !important;
}
.sgp-viewer__below [data-tool],
.sgp-viewer__below .sgp-social__link{pointer-events:auto !important;}


/* RC65 slider fill + modal + viewer ui fixes */
.sgp-meta-modal{padding:20px !important;box-sizing:border-box !important;}
.sgp-meta-modal__panel{width:min(560px,calc(100vw - 40px)) !important;max-width:calc(100vw - 40px) !important;box-sizing:border-box !important;overflow:auto !important;}
@media (max-width:640px){.sgp-meta-modal{padding:12px !important;}.sgp-meta-modal__panel{width:calc(100vw - 24px) !important;max-width:calc(100vw - 24px) !important;border-radius:18px !important;}}
body.sgp-meta-open .sgp-viewer__below,
body.sgp-meta-open .sgp-viewer__protools,
body.sgp-meta-open .sgp-social,
body.sgp-meta-open .sgp-slider__below,
body.sgp-meta-open .sgp-thumb__below{visibility:hidden !important;}
body.sgp-meta-open .sgp-meta-modal,
body.sgp-meta-open .sgp-meta-modal *{visibility:visible !important;}

.sgp-gallery.sgp-slider-fit-display .sgp-slider{position:relative !important;display:block !important;max-width:100% !important;width:100% !important;}
.sgp-gallery.sgp-slider-fit-display .sgp-track,
.sgp-gallery.sgp-slider-fit-display .sgp-track-inner,
.sgp-gallery.sgp-slider-fit-display .sgp-slide,
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-item,
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-media{width:100% !important;max-width:100% !important;}
.sgp-gallery.sgp-slider-fit-display .sgp-track{margin:0 auto !important;}
.sgp-gallery.sgp-slider-fit-display .sgp-slider > .sgp-nav{position:absolute !important;top:50% !important;transform:translateY(-50%) !important;z-index:8 !important;}
.sgp-gallery.sgp-slider-fit-display .sgp-slider > .sgp-prev{left:12px !important;}
.sgp-gallery.sgp-slider-fit-display .sgp-slider > .sgp-next{right:12px !important;}
.sgp-gallery.sgp-slider-fit-display .sgp-slider > .sgp-track{width:100% !important;max-width:100% !important;}
.sgp-gallery.sgp-slider-fit-display .sgp-track-inner{width:100% !important;display:flex !important;}
.sgp-gallery.sgp-slider-fit-display .sgp-slide{flex:0 0 100% !important;min-width:100% !important;max-width:100% !important;}
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-item,
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-media,
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-img{display:block !important;}
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-media{overflow:hidden !important;}
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-img{width:100% !important;height:100% !important;object-fit:cover !important;object-position:center center !important;}

/* ===== RC67 targeted fixes ===== */
.sgp-meta-modal{padding:16px !important;box-sizing:border-box !important;}
.sgp-meta-modal__panel{
  width:min(680px, calc(100vw - 32px)) !important;
  max-width:calc(100vw - 32px) !important;
  max-height:min(86vh, 920px) !important;
  overflow:auto !important;
  box-sizing:border-box !important;
  border-radius:24px !important;
}
.sgp-meta-modal__body{overflow:visible !important;}
.sgp-meta-panel{display:grid !important;gap:12px !important;}
.sgp-meta-panel__row{
  display:block !important;
  padding:0 !important;
  background:transparent !important;
  border:none !important;
}
.sgp-meta-panel__k{
  display:block !important;
  margin:0 0 6px !important;
  color:#c4b5fd !important;
  font-weight:700 !important;
  font-size:13px !important;
}
.sgp-meta-panel__v{
  display:block !important;
  width:100% !important;
  min-height:46px !important;
  padding:12px 14px !important;
  border-radius:10px !important;
  border:1px solid rgba(139,92,246,.45) !important;
  background:rgba(255,255,255,.02) !important;
  color:#f8fafc !important;
  box-sizing:border-box !important;
}
.sgp-meta-panel__empty{color:#ddd6fe !important; opacity:.9;}

.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-track,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-track,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-track{
  width:100% !important;
  max-width:100% !important;
}
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-slide,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slide,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-item,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-item,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-media,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media{
  width:100% !important;
  max-width:100% !important;
}
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-media,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media{
  overflow:hidden !important;
}
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-img,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-img,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-img{
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  max-height:none !important;
  min-width:100% !important;
  min-height:100% !important;
  object-fit:cover !important;
  object-position:center center !important;
  display:block !important;
}
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media,
.sgp-gallery.sgp-type-slider .sgp-track-inner{
  box-sizing:border-box !important;
}


/* ===== RC68 layout + hover + meta interaction fixes ===== */
.sgp-gallery .sgp-grid,
.sgp-gallery .sgp-masonry,
.sgp-gallery .sgp-slider,
.sgp-gallery .sgp-track,
.sgp-gallery .sgp-track-inner,
.sgp-gallery .sgp-slide,
.sgp-gallery .sgp-item,
.sgp-gallery .sgp-media,
.sgp-gallery .sgp-img,
.sgp-gallery .sgp-thumb__below{
  min-width:0 !important;
}
.sgp-gallery.sgp-type-grid .sgp-grid,
.sgp-gallery.sgp-type-polaroid .sgp-grid{
  width:100% !important;
  max-width:100% !important;
  overflow:visible !important;
  align-items:start !important;
}
.sgp-gallery:not(.sgp-cols-fixed).sgp-type-grid .sgp-grid,
.sgp-gallery:not(.sgp-cols-fixed).sgp-type-polaroid .sgp-grid{
  grid-template-columns:repeat(auto-fit, minmax(min(100%, var(--sgp-item-width, 360px)), 1fr)) !important;
}
.sgp-gallery.sgp-type-grid .sgp-item,
.sgp-gallery.sgp-type-polaroid .sgp-item{
  width:100% !important;
  max-width:100% !important;
}
.sgp-gallery.sgp-type-grid .sgp-media,
.sgp-gallery.sgp-type-polaroid .sgp-media{
  width:100% !important;
}
.sgp-gallery.sgp-type-grid .sgp-img,
.sgp-gallery.sgp-type-polaroid .sgp-img{
  width:100% !important;
  max-width:100% !important;
  display:block !important;
}
.sgp-gallery.sgp-type-grid .sgp-thumb__below,
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below{
  width:100% !important;
  padding-left:0 !important;
  padding-right:0 !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slider,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-track,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-track-inner,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-slider,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-track,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-track-inner,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-slide,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-item,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-media{
  width:100% !important;
  max-width:100% !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide .sgp-img,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-slide .sgp-img{
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  object-fit:cover !important;
  object-position:center center !important;
  transform:translateZ(0) !important;
}
.sgp-meta-modal .sgp-meta-panel__k,
.sgp-meta-modal .sgp-meta-panel__v,
.sgp-meta-modal .sgp-meta-panel__empty{
  text-align:left !important;
}
.sgp-probtn,
.sgp-social__link{
  transition:background-color .18s ease,color .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease,opacity .18s ease !important;
}
.sgp-probtn:hover,
.sgp-probtn:focus-visible{
  background:var(--sgp-protools-hover-bg, rgba(124,58,237,.94)) !important;
  color:var(--sgp-protools-hover-text, #fff) !important;
  border-color:transparent !important;
  box-shadow:0 10px 24px rgba(15,23,42,.16) !important;
  transform:translateY(-1px);
}
.sgp-probtn:hover .sgp-mark-icon,
.sgp-probtn:hover .sgp-btn__icon,
.sgp-probtn:hover svg,
.sgp-probtn:focus-visible .sgp-mark-icon,
.sgp-probtn:focus-visible .sgp-btn__icon,
.sgp-probtn:focus-visible svg{
  color:var(--sgp-protools-hover-icon, #fff) !important;
}
.sgp-social__link:hover,
.sgp-social__link:focus-visible{
  background:var(--sgp-social-hover-bg, rgba(124,58,237,.94)) !important;
  color:var(--sgp-social-hover-text, #fff) !important;
  border-color:transparent !important;
  box-shadow:0 10px 24px rgba(15,23,42,.16) !important;
  transform:translateY(-1px);
}
.sgp-social__link:hover .sgp-social__ic,
.sgp-social__link:hover .sgp-social__ic svg,
.sgp-social__link:focus-visible .sgp-social__ic,
.sgp-social__link:focus-visible .sgp-social__ic svg{
  color:var(--sgp-social-hover-icon, #fff) !important;
  fill:currentColor !important;
}
.sgp-viewer__below [data-tool],
.sgp-thumb__below [data-tool],
.sgp-slider__below [data-tool],
.sgp-viewer__below .sgp-social__link,
.sgp-thumb__below .sgp-social__link,
.sgp-slider__below .sgp-social__link{
  pointer-events:auto !important;
}


/* ===== RC69 responsive + fit-display fixes ===== */
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slider,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-track,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-track-inner,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-slider,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-track,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-track-inner,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-slide,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-item,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-media,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-slider,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-track,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-track-inner,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-slide,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-item,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-media{
  max-width:100% !important;
  min-width:0 !important;
  overflow:hidden !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide .sgp-img,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-slide .sgp-img,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-slide .sgp-img{
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  max-height:100% !important;
  min-width:0 !important;
  min-height:0 !important;
  object-fit:contain !important;
  object-position:center center !important;
  transform:translateZ(0) !important;
}
.sgp-slider__below,
.sgp-thumb__below,
.sgp-viewer__below,
.sgp-social,
.sgp-viewer__protools{
  width:100% !important;
  max-width:100% !important;
  flex-wrap:wrap !important;
}
.sgp-gallery .sgp-grid,
.sgp-gallery .sgp-masonry,
.sgp-gallery .sgp-slider,
.sgp-gallery .sgp-track,
.sgp-gallery .sgp-track-inner,
.sgp-gallery .sgp-slide,
.sgp-gallery .sgp-item,
.sgp-gallery .sgp-media,
.sgp-gallery .sgp-img{
  max-inline-size:100% !important;
}
.sgp-gallery:not(.sgp-cols-fixed).sgp-type-grid .sgp-grid,
.sgp-gallery:not(.sgp-cols-fixed).sgp-type-polaroid .sgp-grid{
  grid-template-columns:repeat(auto-fit, minmax(min(100%, var(--sgp-item-width, 360px)), 1fr)) !important;
}
@media (max-width: 1024px){
  .sgp-gallery.sgp-cols-fixed.sgp-type-grid .sgp-grid,
  .sgp-gallery.sgp-cols-fixed.sgp-type-polaroid .sgp-grid{
    grid-template-columns:repeat(3, minmax(0,1fr)) !important;
  }
}
@media (max-width: 767px), (orientation: portrait){
  .sgp-gallery.sgp-cols-fixed.sgp-type-grid .sgp-grid,
  .sgp-gallery.sgp-cols-fixed.sgp-type-polaroid .sgp-grid{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
  }
  .sgp-gallery .sgp-masonry{
    column-width:min(100%, var(--sgp-item-width, 360px)) !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-slider,
  .sgp-gallery.sgp-type-slider .sgp-track{
    max-width:100% !important;
  }
}
@media (max-width: 560px){
  .sgp-gallery.sgp-cols-fixed.sgp-type-grid .sgp-grid,
  .sgp-gallery.sgp-cols-fixed.sgp-type-polaroid .sgp-grid{
    grid-template-columns:1fr !important;
  }
}


/* ===== RC70 final slider/admin/modal responsiveness fixes ===== */
.sgp-gallery.sgp-type-slider,
.sgp-gallery.sgp-type-slider .sgp-slider,
.sgp-gallery.sgp-type-slider .sgp-track{
  box-sizing:border-box !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slider,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-slider,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-slider{
  width:min(100%, var(--sgp-slider-effective-w, calc(100vw - 20px))) !important;
  max-width:min(100%, var(--sgp-slider-effective-w, calc(100vw - 20px))) !important;
  margin-left:auto !important;
  margin-right:auto !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-track,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-track,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-track{
  width:var(--sgp-slider-effective-w, calc(100vw - 20px)) !important;
  max-width:100% !important;
  margin-left:auto !important;
  margin-right:auto !important;
  overflow:hidden !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-track-inner,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-track-inner,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-track-inner{
  max-width:none !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-slide,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-item,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-media,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-slide,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-item,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-media{
  width:var(--sgp-slider-effective-w, 100%) !important;
  max-width:100% !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-media,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-media{
  height:var(--sgp-slider-effective-h, calc(100vh - 110px)) !important;
  max-height:var(--sgp-slider-effective-h, calc(100vh - 110px)) !important;
  min-height:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  overflow:hidden !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-img,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="fit"] .sgp-img,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="fit"] .sgp-img{
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  max-height:100% !important;
  min-width:0 !important;
  min-height:0 !important;
  object-fit:contain !important;
  object-position:center center !important;
  margin:0 auto !important;
  transform:none !important;
}
.sgp-gallery.sgp-type-slider .sgp-prev{left:max(10px, calc(50% - (var(--sgp-slider-effective-w, var(--sgp-slider-w, 92vw)) / 2) + 10px)) !important;}
.sgp-gallery.sgp-type-slider .sgp-next{right:max(10px, calc(50% - (var(--sgp-slider-effective-w, var(--sgp-slider-w, 92vw)) / 2) + 10px)) !important;}

.sgp-meta-modal{
  padding:16px !important;
  box-sizing:border-box !important;
}
.sgp-meta-modal__panel{
  width:min(760px, calc(100vw - 32px)) !important;
  max-width:calc(100vw - 32px) !important;
  max-height:min(88vh, 920px) !important;
  padding:22px !important;
  box-sizing:border-box !important;
  overflow-x:hidden !important;
}
.sgp-meta-modal__body,
.sgp-meta-panel,
.sgp-meta-panel__row{
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box !important;
}
.sgp-meta-panel__v{
  width:100% !important;
  max-width:100% !important;
  overflow-wrap:anywhere !important;
  box-sizing:border-box !important;
}

@media (max-width: 1024px){
  .sgp-gallery,
  .sgp-gallery .sgp-grid,
  .sgp-gallery .sgp-masonry,
  .sgp-gallery .sgp-slider,
  .sgp-gallery .sgp-track,
  .sgp-gallery .sgp-track-inner,
  .sgp-gallery .sgp-slide,
  .sgp-gallery .sgp-item,
  .sgp-gallery .sgp-media,
  .sgp-gallery .sgp-img{
    max-width:100% !important;
  }
}
@media (max-width: 640px){
  .sgp-meta-modal{padding:12px !important;}
  .sgp-meta-modal__panel{width:calc(100vw - 24px) !important;max-width:calc(100vw - 24px) !important;padding:16px !important;border-radius:18px !important;}
  .sgp-gallery.sgp-type-slider .sgp-prev{left:8px !important;}
  .sgp-gallery.sgp-type-slider .sgp-next{right:8px !important;}
}


/* RC71 responsive / slider / viewer safeguards */
.sgp-gallery.sgp-type-slider .sgp-slider,
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  max-width: 100% !important;
}

.sgp-gallery.sgp-type-slider .sgp-slide {
  justify-content: center !important;
  align-items: center !important;
}

.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  margin-left: auto !important;
  margin-right: auto !important;
}

.sgp-gallery.sgp-type-slider[data-slider-fit="contain"] .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.sgp-gallery.sgp-type-slider[data-slider-fit="contain"] .sgp-img,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-img {
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
}

.sgp-viewer .sgp-viewer__below {
  width: min(100%, var(--sgp-safe-width, 100%)) !important;
  max-width: min(100%, var(--sgp-safe-width, 100%)) !important;
  overflow-x: visible !important;
}

.sgp-viewer .sgp-viewer__below .sgp-viewer__protools,
.sgp-viewer .sgp-viewer__below .sgp-social,
.sgp-viewer .sgp-viewer__below .sgp-slider__counter,
.sgp-viewer .sgp-viewer__below .sgp-slider__dots-wrap,
.sgp-viewer .sgp-viewer__below .sgp-overlay-toggle {
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.sgp-viewer .sgp-meta-panel,
.sgp-meta-modal .sgp-meta-panel {
  width: 100% !important;
  max-width: 100% !important;
  overflow: visible !important;
}

.sgp-viewer .sgp-meta-panel__row,
.sgp-meta-modal .sgp-meta-panel__row {
  width: 100% !important;
  max-width: 100% !important;
  grid-template-columns: minmax(100px, 160px) minmax(0, 1fr) !important;
}

.sgp-viewer .sgp-meta-panel__v,
.sgp-meta-modal .sgp-meta-panel__v {
  min-width: 0 !important;
  width: 100% !important;
}

/* RC72 targeted fixes */
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size:not(.sgp-slider-fit-display) .sgp-media,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="custom"]:not(.sgp-slider-fit-display) .sgp-media,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="custom"]:not(.sgp-slider-fit-display) .sgp-media{
  overflow:hidden !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size:not(.sgp-slider-fit-display) .sgp-img,
.sgp-gallery.sgp-type-slider[data-slider-width-mode="custom"]:not(.sgp-slider-fit-display) .sgp-img,
.sgp-gallery.sgp-type-slider[data-slider-height-mode="custom"]:not(.sgp-slider-fit-display) .sgp-img{
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  max-height:none !important;
  object-fit:cover !important;
  object-position:center center !important;
}
.sgp-viewer .sgp-viewer__below,
.sgp-viewer .sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer .sgp-viewer__below [data-tool],
.sgp-viewer .sgp-viewer__below .sgp-social,
.sgp-viewer .sgp-viewer__below .sgp-social__link{
  position:relative !important;
  z-index:2147483647 !important;
  pointer-events:auto !important;
}

/* ===== RC73 responsive interaction fixes ===== */
.sgp-gallery.sgp-type-slider .sgp-slider,
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-track-inner,
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-item {
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.sgp-gallery.sgp-type-slider .sgp-prev {
  left: calc(50% - (var(--sgp-slider-effective-w, var(--sgp-slider-w, min(var(--sgp-item-width), 92vw))) / 2) + 10px) !important;
}

.sgp-gallery.sgp-type-slider .sgp-next {
  right: calc(50% - (var(--sgp-slider-effective-w, var(--sgp-slider-w, min(var(--sgp-item-width), 92vw))) / 2) + 10px) !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-img,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-img {
  object-position: center center !important;
}

.sgp-gallery .sgp-nav,
.sgp-viewer__nav {
  -webkit-tap-highlight-color: transparent;
  filter: none !important;
}

.sgp-gallery .sgp-nav:hover,
.sgp-gallery .sgp-nav:active,
.sgp-gallery .sgp-nav:focus,
.sgp-gallery .sgp-nav:focus-visible,
.sgp-viewer__nav:hover,
.sgp-viewer__nav:active,
.sgp-viewer__nav:focus,
.sgp-viewer__nav:focus-visible {
  background: var(--sgp-nav-bg) !important;
  color: var(--sgp-nav-color) !important;
  opacity: 1 !important;
  box-shadow: none !important;
  filter: none !important;
}

.sgp-viewer__below,
.sgp-viewer__below *,
.sgp-viewer__protools,
.sgp-viewer__protools *,
.sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer__below .sgp-probtn,
.sgp-viewer__below .sgp-social__link,
.sgp-meta-panel,
.sgp-meta-panel * {
  pointer-events: auto !important;
}

.sgp-viewer__below {
  position: relative !important;
  z-index: 2147483646 !important;
}

.sgp-viewer__protools,
.sgp-viewer__below .sgp-social,
.sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer__below .sgp-slider__counter,
.sgp-viewer__below .sgp-slider__dots-wrap {
  position: relative !important;
  z-index: 2147483646 !important;
}

.sgp-gallery .sgp-overlay,
.sgp-viewer .sgp-overlay,
.sgp-gallery .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner {
  box-sizing: border-box !important;
}


/* RC74 targeted responsive fixes */
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slider,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-track,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-track-inner,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media{
  width:var(--sgp-slider-effective-w, var(--sgp-slider-w, 100%)) !important;
  max-width:100% !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media{
  height:var(--sgp-slider-effective-h, auto) !important;
  max-height:var(--sgp-slider-responsive-max-h, none) !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  overflow:hidden !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-img{
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  max-height:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
}
.sgp-viewer__below .sgp-probtn,
.sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer__below .sgp-social__link,
.sgp-viewer__below [data-tool]{
  pointer-events:auto !important;
  touch-action:manipulation !important;
}
.sgp-viewer__nav:active,
.sgp-viewer__nav:focus,
.sgp-viewer__nav:focus-visible,
.sgp-gallery .sgp-nav:active,
.sgp-gallery .sgp-nav:focus,
.sgp-gallery .sgp-nav:focus-visible{
  filter:none !important;
  opacity:1 !important;
}


/* RC75 targeted interaction and slider sizing fixes */
.sgp-viewer .sgp-viewer__below,
.sgp-viewer .sgp-viewer__below *,
.sgp-viewer .sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer .sgp-viewer__below [data-tool],
.sgp-viewer .sgp-viewer__below .sgp-social,
.sgp-viewer .sgp-viewer__below .sgp-social__link,
.sgp-viewer .sgp-viewer__protools,
.sgp-viewer .sgp-viewer__protools * {
  pointer-events: auto !important;
}
.sgp-viewer .sgp-viewer__below,
.sgp-viewer .sgp-viewer__protools,
.sgp-viewer .sgp-viewer__below .sgp-social,
.sgp-viewer .sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer .sgp-viewer__below [data-tool] {
  position: relative !important;
  z-index: 60 !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media {
  max-width: 100% !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-fit-display:not(.sgp-slider-height-clamped) .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size:not(.sgp-slider-height-clamped) .sgp-media {
  height: auto !important;
  max-height: none !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-fit-display:not(.sgp-slider-height-clamped) .sgp-img,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size:not(.sgp-slider-height-clamped) .sgp-img {
  width: 100% !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: none !important;
  object-fit: contain !important;
  object-position: center center !important;
  display: block !important;
}

.sgp-gallery.sgp-type-slider.sgp-slider-fit-display.sgp-slider-height-clamped .sgp-img,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size.sgp-slider-height-clamped .sgp-img {
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
}

.sgp-gallery.sgp-type-slider .sgp-prev,
.sgp-gallery.sgp-type-slider .sgp-next {
  z-index: 12 !important;
}


.sgp-viewer[aria-hidden="false"] .sgp-viewer__below{
  position:relative !important;
  z-index:2147482000 !important;
  pointer-events:auto !important;
}
.sgp-viewer[aria-hidden="false"] .sgp-viewer__below .sgp-viewer__protools,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__below .sgp-social,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer[aria-hidden="false"] .sgp-viewer__below [data-tool],
.sgp-viewer[aria-hidden="false"] .sgp-viewer__below .sgp-social__link{
  position:relative !important;
  z-index:2147482001 !important;
  pointer-events:auto !important;
}

/* RC77 targeted interaction + sizing fixes */
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slider,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-track,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slider,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-track,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media{
  max-width:100% !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media{
  overflow:hidden !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-img,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-img{
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  max-height:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
}
.sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer__below [data-tool],
.sgp-viewer__below .sgp-social__link{
  cursor:pointer !important;
  pointer-events:auto !important;
  touch-action:manipulation !important;
}
.sgp-viewer__nav,
.sgp-gallery .sgp-nav{
  transition:background-color .12s ease,color .12s ease,opacity .12s ease,filter .12s ease,box-shadow .12s ease !important;
}
.sgp-viewer__nav:not(:active):not(:focus):not(:focus-visible),
.sgp-gallery .sgp-nav:not(:active):not(:focus):not(:focus-visible){
  filter:none !important;
  opacity:1 !important;
}


/* RC79 responsive slider + focus polish */
.sgp-gallery.sgp-type-slider,
.sgp-gallery.sgp-type-slider .sgp-slider,
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-slide .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-slide .sgp-media,
.sgp-gallery.sgp-type-slider .sgp-slide .sgp-img {
  box-sizing: border-box !important;
}
.sgp-gallery.sgp-type-slider .sgp-slide .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-slide .sgp-media {
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slide .sgp-img,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide .sgp-img {
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
}
@media (max-width: 1024px) {
  .sgp-gallery.sgp-type-slider .sgp-slider,
  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-slide .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-slide .sgp-media {
    max-width: 100% !important;
  }
}
.sgp-viewer.is-focus .sgp-viewer__protools .sgp-probtn--focus {
  position: static !important;
  right: auto !important;
  bottom: auto !important;
  z-index: auto !important;
}
.sgp-viewer.is-focus .sgp-viewer__close {
  top: 16px !important;
  right: 16px !important;
}


/* RC80 targeted overrides */
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slider,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slider{
  width:min(100%, var(--sgp-slider-effective-w, 100%)) !important;
  max-width:min(100%, var(--sgp-slider-effective-w, 100%)) !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-track,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-track{
  width:var(--sgp-slider-effective-w, 100%) !important;
  max-width:100% !important;
  margin-left:auto !important;
  margin-right:auto !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-item,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media{
  width:var(--sgp-slider-effective-w, 100%) !important;
  max-width:100% !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media{
  height:var(--sgp-slider-effective-h, auto) !important;
  max-height:none !important;
  overflow:hidden !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-img,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-img{
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  max-height:none !important;
  object-fit:fill !important;
  object-position:center center !important;
  display:block !important;
}
.sgp-viewer__below,
.sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer__below [data-tool],
.sgp-viewer__below .sgp-social,
.sgp-viewer__below .sgp-social__link{
  pointer-events:auto !important;
}
.sgp-viewer__below{ z-index: 2147482000 !important; }
.sgp-viewer__below .sgp-viewer__protools,
.sgp-viewer__below .sgp-overlay-toggle,
.sgp-viewer__below .sgp-social{ position:relative !important; z-index:2 !important; }
.sgp-viewer.is-focus .sgp-viewer__close{
  position:fixed !important;
  top:16px !important;
  right:16px !important;
  z-index:2147483000 !important;
}


/* ===== RC83 mobile micro-fixes: tighter marks + centered slider ===== */
@media (max-width: 767px) {
  .sgp-slider .sgp-watermark--top-left,
  .sgp-slider .sgp-proof-badge--top-left,
  .sgp-slider .sgp-usage-badge--top-left,
  .sgp-slider .sgp-credit-line--top-left {
    top: 6px !important;
    left: 6px !important;
  }

  .sgp-slider .sgp-watermark--top-right,
  .sgp-slider .sgp-proof-badge--top-right,
  .sgp-slider .sgp-usage-badge--top-right,
  .sgp-slider .sgp-credit-line--top-right {
    top: 6px !important;
    right: 6px !important;
  }

  .sgp-slider .sgp-watermark--bottom-left,
  .sgp-slider .sgp-proof-badge--bottom-left,
  .sgp-slider .sgp-usage-badge--bottom-left,
  .sgp-slider .sgp-credit-line--bottom-left {
    bottom: 6px !important;
    left: 6px !important;
  }

  .sgp-slider .sgp-watermark--bottom-right,
  .sgp-slider .sgp-proof-badge--bottom-right,
  .sgp-slider .sgp-usage-badge--bottom-right,
  .sgp-slider .sgp-credit-line--bottom-right {
    bottom: 6px !important;
    right: 6px !important;
  }

  .sgp-slider .sgp-watermark--top-center,
  .sgp-slider .sgp-proof-badge--top-center,
  .sgp-slider .sgp-usage-badge--top-center,
  .sgp-slider .sgp-credit-line--top-center {
    top: 6px !important;
  }

  .sgp-slider .sgp-watermark--bottom-center,
  .sgp-slider .sgp-proof-badge--bottom-center,
  .sgp-slider .sgp-usage-badge--bottom-center,
  .sgp-slider .sgp-credit-line--bottom-center {
    bottom: 6px !important;
  }

  .sgp-gallery.sgp-type-slider,
  .sgp-gallery.sgp-type-slider .sgp-slider,
  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-track-inner {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-slider {
    justify-content: center !important;
    align-items: center !important;
  }
}


/* RC85 slider containment hardening */
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-track-inner,
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-slide .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-slide .sgp-media {
  overflow: hidden !important;
  min-width: 0;
}

.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-slide .sgp-item {
  box-sizing: border-box;
}



/* RC94 refined overlay alignment + professional tab-2 text layout support */
.sgp-gallery .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner{
  box-sizing:border-box !important;
}
.sgp-gallery .sgp-overlay-content[data-align="justify"],
.sgp-viewer .sgp-overlay-content[data-align="justify"]{
  align-items:stretch !important;
  text-align:justify !important;
  text-justify:inter-word;
}
.sgp-gallery .sgp-overlay-content[data-align="justify"] > .sgp-title,
.sgp-gallery .sgp-overlay-content[data-align="justify"] > .sgp-excerpt,
.sgp-gallery .sgp-overlay-content[data-align="justify"] > .sgp-description,
.sgp-gallery .sgp-overlay-content[data-align="justify"] > .sgp-alt,
.sgp-viewer .sgp-overlay-content[data-align="justify"] > .sgp-title,
.sgp-viewer .sgp-overlay-content[data-align="justify"] > .sgp-excerpt,
.sgp-viewer .sgp-overlay-content[data-align="justify"] > .sgp-description,
.sgp-viewer .sgp-overlay-content[data-align="justify"] > .sgp-alt{
  width:100% !important;
  max-width:100% !important;
  text-align:justify !important;
  margin-left:0 !important;
  margin-right:0 !important;
  align-self:stretch !important;
  text-justify:inter-word;
}
.sgp-gallery[data-text-align="justify"] .sgp-overlay-content,
.sgp-viewer[data-text-align="justify"] .sgp-overlay-content{
  text-align:justify !important;
  align-items:stretch !important;
}


/* RC95 global text padding + stronger responsive text layout */
.sgp-gallery[data-global-text-style="1"] .sgp-overlay-inner,
.sgp-viewer[data-global-text-style="1"] .sgp-overlay-inner{
  padding-top: var(--sgp-global-text-pad-top) !important;
  padding-right: var(--sgp-global-text-pad-right) !important;
  padding-bottom: var(--sgp-global-text-pad-bottom) !important;
  padding-left: var(--sgp-global-text-pad-left) !important;
}
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content{
  overflow-wrap: anywhere;
  word-break: normal;
  hyphens: auto;
}
.sgp-gallery[data-text-align="left"] .sgp-overlay-content,
.sgp-viewer[data-text-align="left"] .sgp-overlay-content{
  text-align:left !important; align-items:flex-start !important;
}
.sgp-gallery[data-text-align="right"] .sgp-overlay-content,
.sgp-viewer[data-text-align="right"] .sgp-overlay-content{
  text-align:right !important; align-items:flex-end !important;
}
.sgp-gallery[data-text-align="center"] .sgp-overlay-content,
.sgp-viewer[data-text-align="center"] .sgp-overlay-content{
  text-align:center !important; align-items:center !important;
}

/* RC96 mobile slider sizing + padding cleanup */
.sgp-gallery .sgp-overlay,
.sgp-viewer .sgp-overlay,
.sgp-gallery .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner{
  box-sizing:border-box !important;
}
.sgp-gallery[data-global-text-style="0"] .sgp-overlay-inner,
.sgp-viewer[data-global-text-style="0"] .sgp-overlay-inner{
  padding:0 !important;
}
.sgp-gallery[data-global-text-style="1"] .sgp-overlay-content,
.sgp-viewer[data-global-text-style="1"] .sgp-overlay-content{
  padding-top: var(--sgp-global-text-pad-top) !important;
  padding-right: var(--sgp-global-text-pad-right) !important;
  padding-bottom: var(--sgp-global-text-pad-bottom) !important;
  padding-left: var(--sgp-global-text-pad-left) !important;
  box-sizing:border-box !important;
}
.sgp-gallery[data-global-text-style="0"] .sgp-overlay-content,
.sgp-viewer[data-global-text-style="0"] .sgp-overlay-content{
  padding:0 !important;
}
@media (max-width: 767px) and (orientation: portrait){
  .sgp-gallery.sgp-type-slider{
    --sgp-safe-width: calc(100vw - 18px) !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-slider{
    width:min(calc(100vw - 18px), 100%) !important;
    max-width:calc(100vw - 18px) !important;
    margin-left:auto !important;
    margin-right:auto !important;
    grid-template-columns:36px minmax(0,1fr) 36px !important;
    justify-content:center !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-track-inner,
  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-img{
    width:100% !important;
    max-width:100% !important;
    height:auto !important;
    max-height:min(72vh, calc(100svh - 240px)) !important;
    object-fit:contain !important;
  }
}

/* RC98 mobile slider sizing */
@media (max-width: 767px) {
  .sgp-gallery.sgp-type-slider {
    --sgp-mobile-side-gap: 0px;
  }
  .sgp-gallery.sgp-type-slider .sgp-slider,
  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-track-inner,
  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-track {
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-img {
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
  }
}


/* RC99 mobile slider stronger fit */
@media (max-width: 767px){
  .sgp-gallery.sgp-type-slider{--sgp-mobile-side-gap:0px !important;}
  .sgp-gallery.sgp-type-slider .sgp-slider{width:calc(100vw - 12px) !important;max-width:calc(100vw - 12px) !important;grid-template-columns:34px minmax(0, calc(100vw - 80px)) 34px !important;margin-left:auto !important;margin-right:auto !important;}
  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-track-inner,
  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media{width:100% !important;max-width:100% !important;}
  .sgp-gallery.sgp-type-slider .sgp-img{width:100% !important;max-width:100% !important;max-height:min(78svh, calc(100svh - 220px)) !important;}
}

/* RC100 mobile slider sizing */
@media (max-width: 782px){
  .sgp-gallery.sgp-type-slider .sgp-item{
    width:min(calc(100vw - 18px), var(--sgp-slider-w, 100vw)) !important;
    max-width:calc(100vw - 18px) !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-slider,
  .sgp-gallery.sgp-type-slider .sgp-track{max-width:100% !important;}
  .sgp-gallery .sgp-prev{left:10px !important;}
  .sgp-gallery .sgp-next{right:10px !important;}
}


/* RC102 final text-alignment and padding corrections */
.sgp-gallery .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner{
  box-sizing:border-box !important;
}
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  box-sizing:border-box !important;
  padding:0 !important;
  padding-right:0 !important;
  overflow-x:hidden !important;
}
.sgp-gallery[data-global-text-style="1"] .sgp-overlay-inner,
.sgp-viewer[data-global-text-style="1"] .sgp-overlay-inner{
  padding-top:var(--sgp-global-text-pad-top) !important;
  padding-right:var(--sgp-global-text-pad-right) !important;
  padding-bottom:var(--sgp-global-text-pad-bottom) !important;
  padding-left:var(--sgp-global-text-pad-left) !important;
}
.sgp-gallery[data-global-text-style="1"] .sgp-overlay-content,
.sgp-viewer[data-global-text-style="1"] .sgp-overlay-content{
  padding:0 !important;
}
.sgp-gallery .sgp-overlay-inner--thumb .sgp-overlay-content,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content{
  align-items:stretch !important;
}
.sgp-gallery .sgp-overlay-inner--thumb .sgp-title,
.sgp-gallery .sgp-overlay-inner--thumb .sgp-excerpt,
.sgp-gallery .sgp-overlay-inner--thumb .sgp-description,
.sgp-gallery .sgp-overlay-inner--thumb .sgp-alt,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-title,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-excerpt,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-description,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-alt{
  box-sizing:border-box !important;
  max-width:100% !important;
}
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below{
  width:100% !important;
  box-sizing:border-box !important;
  padding-top:20px !important;
  padding-right:var(--sgp-global-text-pad-right) !important;
  padding-bottom:0 !important;
  padding-left:var(--sgp-global-text-pad-left) !important;
  align-items:stretch !important;
}
.sgp-gallery.sgp-thumb-controls-below[data-overlay-btn-pos^="top-"] .sgp-thumb__below{
  padding-top:0 !important;
  padding-right:var(--sgp-global-text-pad-right) !important;
  padding-bottom:20px !important;
  padding-left:var(--sgp-global-text-pad-left) !important;
}
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below .sgp-title,
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below .sgp-excerpt,
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below .sgp-description,
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below .sgp-alt{
  box-sizing:border-box !important;
  max-width:100% !important;
}
.sgp-viewer.sgp-pos-top-left .sgp-overlay-inner{align-items:flex-start !important;justify-content:flex-start !important;}
.sgp-viewer.sgp-pos-top-center .sgp-overlay-inner{align-items:flex-start !important;justify-content:center !important;}
.sgp-viewer.sgp-pos-top-right .sgp-overlay-inner{align-items:flex-start !important;justify-content:flex-end !important;}
.sgp-viewer.sgp-pos-middle-left .sgp-overlay-inner{align-items:center !important;justify-content:flex-start !important;}
.sgp-viewer.sgp-pos-middle-center .sgp-overlay-inner,
.sgp-viewer.sgp-pos-center .sgp-overlay-inner{align-items:center !important;justify-content:center !important;}
.sgp-viewer.sgp-pos-middle-right .sgp-overlay-inner{align-items:center !important;justify-content:flex-end !important;}
.sgp-viewer.sgp-pos-bottom-left .sgp-overlay-inner{align-items:flex-end !important;justify-content:flex-start !important;}
.sgp-viewer.sgp-pos-bottom-center .sgp-overlay-inner{align-items:flex-end !important;justify-content:center !important;}
.sgp-viewer.sgp-pos-bottom-right .sgp-overlay-inner{align-items:flex-end !important;justify-content:flex-end !important;}


/* RC103 text alignment and viewer position stability */
.sgp-gallery .sgp-overlay-inner--thumb .sgp-overlay-content,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  padding:0 !important;
  padding-right:0 !important;
  overflow:visible !important;
  overflow-x:visible !important;
  box-sizing:border-box !important;
  align-items:stretch !important;
}
.sgp-gallery .sgp-overlay-inner--thumb .sgp-title,
.sgp-gallery .sgp-overlay-inner--thumb .sgp-excerpt,
.sgp-gallery .sgp-overlay-inner--thumb .sgp-description,
.sgp-gallery .sgp-overlay-inner--thumb .sgp-alt,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-title,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-excerpt,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-description,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-alt,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-title,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-excerpt,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-description,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-alt,
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below .sgp-title,
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below .sgp-excerpt,
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below .sgp-description,
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below .sgp-alt{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  margin-left:0 !important;
  margin-right:0 !important;
  box-sizing:border-box !important;
  align-self:stretch !important;
}
.sgp-gallery[data-thumb-text-align="left"] .sgp-overlay-inner--thumb .sgp-overlay-content,
.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below,
.sgp-gallery:not([data-thumb-text-align]),
.sgp-gallery[data-thumb-text-align=""] .sgp-thumb__below{
  text-align:left;
}
.sgp-gallery[data-thumb-text-align="center"] .sgp-overlay-inner--thumb .sgp-overlay-content,
.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below{
  text-align:center !important;
}
.sgp-gallery[data-thumb-text-align="right"] .sgp-overlay-inner--thumb .sgp-overlay-content,
.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below{
  text-align:right !important;
}
.sgp-viewer .sgp-overlay-inner--viewer{
  padding-top:var(--sgp-global-text-pad-top,var(--sgp-overlay-pad-top)) !important;
  padding-right:var(--sgp-global-text-pad-right,var(--sgp-overlay-pad-right)) !important;
  padding-bottom:var(--sgp-global-text-pad-bottom,var(--sgp-overlay-pad-bottom)) !important;
  padding-left:var(--sgp-global-text-pad-left,var(--sgp-overlay-pad-left)) !important;
}


/* RC104 overlay geometry + export UI fixes */
.sgp-gallery .sgp-overlay,
.sgp-viewer .sgp-overlay{
  top:0 !important;
  right:0 !important;
  bottom:0 !important;
  left:0 !important;
}
.sgp-gallery .sgp-overlay-inner--thumb,
.sgp-gallery .sgp-overlay-inner--viewer,
.sgp-viewer .sgp-overlay-inner--viewer{
  display:grid !important;
  width:100% !important;
  height:100% !important;
  box-sizing:border-box !important;
  padding-top:var(--sgp-global-text-pad-top,var(--sgp-overlay-pad-top)) !important;
  padding-right:var(--sgp-global-text-pad-right,var(--sgp-overlay-pad-right)) !important;
  padding-bottom:var(--sgp-global-text-pad-bottom,var(--sgp-overlay-pad-bottom)) !important;
  padding-left:var(--sgp-global-text-pad-left,var(--sgp-overlay-pad-left)) !important;
}
.sgp-gallery .sgp-overlay-inner--thumb .sgp-overlay-content,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content{
  width:auto !important;
  max-width:100% !important;
  min-width:0 !important;
  justify-self:start !important;
  align-self:center !important;
  overflow:visible !important;
  overflow-x:visible !important;
}
.sgp-gallery .sgp-overlay-content[data-sgp-overlay-pos="top-left"],
.sgp-viewer .sgp-overlay-content[data-sgp-overlay-pos="top-left"]{place-self:start start !important;}
.sgp-gallery .sgp-overlay-content[data-sgp-overlay-pos="top-center"],
.sgp-viewer .sgp-overlay-content[data-sgp-overlay-pos="top-center"]{place-self:start center !important;}
.sgp-gallery .sgp-overlay-content[data-sgp-overlay-pos="top-right"],
.sgp-viewer .sgp-overlay-content[data-sgp-overlay-pos="top-right"]{place-self:start end !important;}
.sgp-gallery .sgp-overlay-content[data-sgp-overlay-pos="middle-left"],
.sgp-viewer .sgp-overlay-content[data-sgp-overlay-pos="middle-left"]{place-self:center start !important;}
.sgp-gallery .sgp-overlay-content[data-sgp-overlay-pos="middle-center"],
.sgp-viewer .sgp-overlay-content[data-sgp-overlay-pos="middle-center"]{place-self:center center !important;}
.sgp-gallery .sgp-overlay-content[data-sgp-overlay-pos="middle-right"],
.sgp-viewer .sgp-overlay-content[data-sgp-overlay-pos="middle-right"]{place-self:center end !important;}
.sgp-gallery .sgp-overlay-content[data-sgp-overlay-pos="bottom-left"],
.sgp-viewer .sgp-overlay-content[data-sgp-overlay-pos="bottom-left"]{place-self:end start !important;}
.sgp-gallery .sgp-overlay-content[data-sgp-overlay-pos="bottom-center"],
.sgp-viewer .sgp-overlay-content[data-sgp-overlay-pos="bottom-center"]{place-self:end center !important;}
.sgp-gallery .sgp-overlay-content[data-sgp-overlay-pos="bottom-right"],
.sgp-viewer .sgp-overlay-content[data-sgp-overlay-pos="bottom-right"]{place-self:end end !important;}
.sgp-gallery .sgp-overlay-inner--thumb .sgp-title,
.sgp-gallery .sgp-overlay-inner--thumb .sgp-excerpt,
.sgp-gallery .sgp-overlay-inner--thumb .sgp-description,
.sgp-gallery .sgp-overlay-inner--thumb .sgp-alt,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-title,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-excerpt,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-description,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-alt,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-title,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-excerpt,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-description,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-alt{
  width:auto !important;
  max-width:100% !important;
  margin-left:0 !important;
  margin-right:0 !important;
}
.sgp-gallery[data-thumb-text-align="left"] .sgp-overlay-inner--thumb .sgp-overlay-content,
.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below,
.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below .sgp-title,
.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below .sgp-excerpt,
.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below .sgp-description,
.sgp-gallery[data-thumb-text-align="left"] .sgp-thumb__below .sgp-alt{
  text-align:left !important;
}
.sgp-gallery[data-thumb-text-align="center"] .sgp-overlay-inner--thumb .sgp-overlay-content,
.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below,
.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below .sgp-title,
.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below .sgp-excerpt,
.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below .sgp-description,
.sgp-gallery[data-thumb-text-align="center"] .sgp-thumb__below .sgp-alt{
  text-align:center !important;
}
.sgp-gallery[data-thumb-text-align="right"] .sgp-overlay-inner--thumb .sgp-overlay-content,
.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below,
.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below .sgp-title,
.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below .sgp-excerpt,
.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below .sgp-description,
.sgp-gallery[data-thumb-text-align="right"] .sgp-thumb__below .sgp-alt{
  text-align:right !important;
}


/* RC105: definitive overlay positioning and field alignment */
.sgp-gallery .sgp-overlay,
.sgp-viewer .sgp-overlay{
  inset:auto !important;
}
.sgp-gallery .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner{
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  justify-content:center !important;
}
.sgp-gallery.sgp-pos-top-left .sgp-overlay-inner,
.sgp-viewer.sgp-pos-top-left .sgp-overlay-inner{align-items:flex-start !important;justify-content:flex-start !important;}
.sgp-gallery.sgp-pos-top-center .sgp-overlay-inner,
.sgp-viewer.sgp-pos-top-center .sgp-overlay-inner{align-items:flex-start !important;justify-content:center !important;}
.sgp-gallery.sgp-pos-top-right .sgp-overlay-inner,
.sgp-viewer.sgp-pos-top-right .sgp-overlay-inner{align-items:flex-start !important;justify-content:flex-end !important;}
.sgp-gallery.sgp-pos-middle-left .sgp-overlay-inner,
.sgp-viewer.sgp-pos-middle-left .sgp-overlay-inner{align-items:center !important;justify-content:flex-start !important;}
.sgp-gallery.sgp-pos-middle-center .sgp-overlay-inner,
.sgp-gallery.sgp-pos-center .sgp-overlay-inner,
.sgp-viewer.sgp-pos-middle-center .sgp-overlay-inner,
.sgp-viewer.sgp-pos-center .sgp-overlay-inner{align-items:center !important;justify-content:center !important;}
.sgp-gallery.sgp-pos-middle-right .sgp-overlay-inner,
.sgp-viewer.sgp-pos-middle-right .sgp-overlay-inner{align-items:center !important;justify-content:flex-end !important;}
.sgp-gallery.sgp-pos-bottom-left .sgp-overlay-inner,
.sgp-viewer.sgp-pos-bottom-left .sgp-overlay-inner{align-items:flex-end !important;justify-content:flex-start !important;}
.sgp-gallery.sgp-pos-bottom-center .sgp-overlay-inner,
.sgp-viewer.sgp-pos-bottom-center .sgp-overlay-inner{align-items:flex-end !important;justify-content:center !important;}
.sgp-gallery.sgp-pos-bottom-right .sgp-overlay-inner,
.sgp-viewer.sgp-pos-bottom-right .sgp-overlay-inner{align-items:flex-end !important;justify-content:flex-end !important;}
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content{
  width:auto !important;
  max-width:100% !important;
  max-height:100% !important;
  padding-right:0 !important;
  overflow:auto !important;
}
.sgp-gallery .sgp-overlay-content .sgp-title,
.sgp-gallery .sgp-overlay-content .sgp-excerpt,
.sgp-gallery .sgp-overlay-content .sgp-description,
.sgp-gallery .sgp-overlay-content .sgp-alt,
.sgp-viewer .sgp-overlay-content .sgp-title,
.sgp-viewer .sgp-overlay-content .sgp-excerpt,
.sgp-viewer .sgp-overlay-content .sgp-description,
.sgp-viewer .sgp-overlay-content .sgp-alt{
  max-width:100% !important;
}


/* RC106 overlay alignment + selected-field global text fixes */
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content {
  width:auto !important;
  max-width:100% !important;
  flex:0 1 auto !important;
}
.sgp-gallery .sgp-overlay-content > .sgp-title,
.sgp-gallery .sgp-overlay-content > .sgp-excerpt,
.sgp-gallery .sgp-overlay-content > .sgp-description,
.sgp-gallery .sgp-overlay-content > .sgp-alt,
.sgp-viewer .sgp-overlay-content > .sgp-title,
.sgp-viewer .sgp-overlay-content > .sgp-excerpt,
.sgp-viewer .sgp-overlay-content > .sgp-description,
.sgp-viewer .sgp-overlay-content > .sgp-alt,
.sgp-gallery .sgp-thumb__below > .sgp-title,
.sgp-gallery .sgp-thumb__below > .sgp-excerpt,
.sgp-gallery .sgp-thumb__below > .sgp-description,
.sgp-gallery .sgp-thumb__below > .sgp-alt {
  width:100% !important;
  max-width:100% !important;
  margin-left:0 !important;
  margin-right:0 !important;
  align-self:stretch !important;
}
.sgp-gallery[data-global-text-style="1"] .sgp-overlay-content > :not(.sgp-uses-global-text),
.sgp-gallery[data-global-text-style="1"] .sgp-thumb__below > :not(.sgp-uses-global-text),
.sgp-viewer .sgp-overlay-content > :not(.sgp-uses-global-text) {
  text-align:initial !important;
}


/* RC108 targeted frontend fixes */
.sgp-gallery .sgp-overlay,
.sgp-viewer .sgp-overlay{
  inset:0 !important;
}
.sgp-gallery .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner{
  width:100% !important;
  height:100% !important;
  box-sizing:border-box !important;
  padding-top:var(--sgp-global-text-pad-top,var(--sgp-overlay-pad-top)) !important;
  padding-right:var(--sgp-global-text-pad-right,var(--sgp-overlay-pad-right)) !important;
  padding-bottom:var(--sgp-global-text-pad-bottom,var(--sgp-overlay-pad-bottom)) !important;
  padding-left:var(--sgp-global-text-pad-left,var(--sgp-overlay-pad-left)) !important;
  overflow:hidden !important;
}
.sgp-gallery .sgp-overlay-inner--viewer,
.sgp-viewer .sgp-overlay-inner--viewer{
  background:transparent !important;
}
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content{
  display:flex !important;
  flex-direction:column !important;
  width:auto !important;
  max-width:min(100%, 42ch) !important;
  max-height:100% !important;
  overflow:auto !important;
  overflow-x:hidden !important;
  padding-right:6px !important;
  box-sizing:border-box !important;
}
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content .sgp-title,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content .sgp-excerpt,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content .sgp-description,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content .sgp-alt,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content .sgp-title,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content .sgp-excerpt,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content .sgp-description,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content .sgp-alt{
  width:auto !important;
  max-width:100% !important;
}
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content[data-align="left"],
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content[data-align="left"]{text-align:left !important;align-items:flex-start !important;}
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content[data-align="center"],
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content[data-align="center"]{text-align:center !important;align-items:center !important;}
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content[data-align="right"],
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content[data-align="right"]{text-align:right !important;align-items:flex-end !important;}
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content[data-align="justify"],
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content[data-align="justify"]{text-align:justify !important;align-items:stretch !important;}
.sgp-meta-panel{padding-bottom:10px !important;}
.sgp-meta-panel__row:last-child{margin-bottom:6px !important;}


/* RC119: thumbnail overlay should cover the full miniature and keep text padding inside */
.sgp-gallery:not(.sgp-type-slider) .sgp-media > .sgp-overlay {
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
}

.sgp-gallery:not(.sgp-type-slider) .sgp-media > .sgp-overlay .sgp-overlay-inner--thumb {
  width: 100% !important;
  height: 100% !important;
  box-sizing: border-box !important;
}


/* RC121: keep overlay scroll at the overlay edge and avoid centered scrollbar */
.sgp-gallery[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer,
.sgp-viewer[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer,
.sgp-gallery[data-overlay-size-mode="custom"] .sgp-overlay-inner--thumb{
  overflow-y:auto !important;
  overflow-x:hidden !important;
  scrollbar-gutter:stable !important;
}
.sgp-gallery[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer .sgp-overlay-content,
.sgp-viewer[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer .sgp-overlay-content,
.sgp-gallery[data-overlay-size-mode="custom"] .sgp-overlay-inner--thumb .sgp-overlay-content{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  justify-self:stretch !important;
  align-self:stretch !important;
  overflow:visible !important;
  overflow-x:visible !important;
  overflow-y:visible !important;
  padding-right:0 !important;
  margin-right:0 !important;
  box-sizing:border-box !important;
}
.sgp-gallery[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer .sgp-overlay-content > .sgp-title,
.sgp-gallery[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer .sgp-overlay-content > .sgp-excerpt,
.sgp-gallery[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer .sgp-overlay-content > .sgp-description,
.sgp-gallery[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer .sgp-overlay-content > .sgp-alt,
.sgp-viewer[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer .sgp-overlay-content > .sgp-title,
.sgp-viewer[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer .sgp-overlay-content > .sgp-excerpt,
.sgp-viewer[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer .sgp-overlay-content > .sgp-description,
.sgp-viewer[data-overlay-size-mode="custom"] .sgp-overlay-inner--viewer .sgp-overlay-content > .sgp-alt{
  max-width:100% !important;
}


/* v5 stability + responsive fixes */
.sgp-gallery .sgp-overlay-toggle,
.sgp-viewer .sgp-overlay-toggle{
  width:auto !important;
  min-width:0 !important;
  max-width:100% !important;
  padding:0 12px !important;
  inline-size:fit-content !important;
}

.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content{
  width:100% !important;
  max-width:100% !important;
  scrollbar-gutter: stable both-edges;
}

.sgp-gallery.sgp-type-polaroid .sgp-thumb__below{
  gap:8px !important;
  padding-top:4px !important;
}

.sgp-gallery.sgp-type-polaroid .sgp-thumb__below .sgp-overlay-toggle{
  min-width:0 !important;
  margin-top:0 !important;
}

.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below{
  align-items:flex-start !important;
}

.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below .sgp-overlay-toggle{
  margin-top:0 !important;
}


/* ===== v6 alignment and viewer overlay fixes ===== */
.sgp-gallery .sgp-overlay-toggle,
.sgp-viewer .sgp-overlay-toggle {
  min-width: 0 !important;
  width: auto !important;
  max-width: 100% !important;
  inline-size: max-content !important;
  padding: 0 14px !important;
}
.sgp-gallery .sgp-overlay-toggle .sgp-btn__label,
.sgp-viewer .sgp-overlay-toggle .sgp-btn__label {
  flex: 0 1 auto !important;
  min-width: 0 !important;
}
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below {
  padding-top: 10px !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below .sgp-overlay-toggle,
.sgp-gallery.sgp-thumb-controls-below .sgp-thumb__below .sgp-overlay-toggle,
.sgp-viewer .sgp-viewer__below .sgp-overlay-toggle {
  min-width: 0 !important;
  width: auto !important;
  max-width: 100% !important;
  margin-top: 0 !important;
}
.sgp-viewer .sgp-viewer__below {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
}
.sgp-viewer .sgp-viewer__below .sgp-overlay-toggle { align-self: center !important; }
.sgp-viewer[data-overlay-btn-pos$="left"] .sgp-viewer__below .sgp-overlay-toggle { align-self: flex-start !important; }
.sgp-viewer[data-overlay-btn-pos$="center"] .sgp-viewer__below .sgp-overlay-toggle { align-self: center !important; }
.sgp-viewer[data-overlay-btn-pos$="right"] .sgp-viewer__below .sgp-overlay-toggle { align-self: flex-end !important; }
.sgp-gallery.sgp-thumb-controls-below[data-overlay-btn-pos$="left"] .sgp-thumb__below .sgp-overlay-toggle { align-self: flex-start !important; }
.sgp-gallery.sgp-thumb-controls-below[data-overlay-btn-pos$="center"] .sgp-thumb__below .sgp-overlay-toggle { align-self: center !important; }
.sgp-gallery.sgp-thumb-controls-below[data-overlay-btn-pos$="right"] .sgp-thumb__below .sgp-overlay-toggle { align-self: flex-end !important; }
.sgp-viewer .sgp-overlay,
.sgp-viewer .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-content {
  box-sizing: border-box !important;
}
.sgp-viewer .sgp-overlay-content {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  scrollbar-gutter: stable both-edges !important;
}
.sgp-viewer .sgp-overlay-inner--viewer {
  width: 100% !important;
  height: 100% !important;
}


/* RC41 v10 targeted fixes */
.sgp-gallery.sgp-type-slider .sgp-track{
  touch-action: pan-y !important;
}
.sgp-gallery.sgp-type-slider .sgp-track-inner{
  transition: transform 180ms cubic-bezier(.22,.61,.36,1) !important;
  will-change: transform !important;
  backface-visibility: hidden !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-img,
.sgp-gallery.sgp-type-slider.sgp-slider-custom-size .sgp-img{
  object-fit: contain !important;
  object-position: center center !important;
  box-sizing: border-box !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide,
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-item{
  overflow: hidden !important;
}
.sgp-viewer .sgp-viewer__media .sgp-overlay{
  transform: none !important;
  translate: none !important;
}


/* RC111 overlay + slider fit stability */
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-img,
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-img,
.sgp-gallery[data-slider-width-mode="fit"] .sgp-img,
.sgp-gallery[data-slider-height-mode="fit"] .sgp-img{
  object-fit:contain !important;
  object-position:center center !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-media,
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-media,
.sgp-gallery[data-slider-width-mode="fit"] .sgp-media,
.sgp-gallery[data-slider-height-mode="fit"] .sgp-media{
  overflow:hidden !important;
}
.sgp-gallery .sgp-overlay,
.sgp-viewer .sgp-overlay{
  inset:unset !important;
}
.sgp-viewer[data-overlay-size-mode="custom"] .sgp-overlay,
.sgp-viewer[data-overlay-size-mode="auto"] .sgp-overlay,
.sgp-viewer:not([data-overlay-size-mode]) .sgp-overlay{
  transform:none !important;
}


/* RC116: hard fixes for fit-display, viewer centering, and overlay positioning */
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-track,
.sgp-gallery.sgp-slider-fit-display .sgp-track{
  width: min(100%, var(--sgp-slider-effective-w, 100%)) !important;
  max-width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow: hidden !important;
}
.sgp-gallery.sgp-type-slider.sgp-slider-fit-display .sgp-slide .sgp-img,
.sgp-gallery.sgp-slider-fit-display .sgp-slide .sgp-img{
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
}
.sgp-viewer .sgp-viewer__frame,
.sgp-viewer .sgp-viewer__main,
.sgp-viewer .sgp-viewer__mediawrap,
.sgp-viewer .sgp-viewer__media{
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-viewer .sgp-viewer__stage{
  justify-content: center !important;
  align-items: center !important;
}
.sgp-gallery .sgp-overlay,
.sgp-viewer .sgp-overlay{
  right: auto !important;
  bottom: auto !important;
  inset: unset !important;
  transform: none !important;
  translate: none !important;
}


/* ===== v14 targeted fixes: mobile slider, viewer title color, transparent info button, scrollbar edge ===== */
/* 1) Mobile portrait: let slider use almost the full device width */
@media (max-width: 700px) and (orientation: portrait) {
  .sgp-gallery.sgp-type-slider {
    --sgp-mobile-side-gap: 0px !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-slider {
    width: calc(100vw - 4px) !important;
    max-width: calc(100vw - 4px) !important;
    grid-template-columns: 30px minmax(0, calc(100vw - 64px)) 30px !important;
    column-gap: 2px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-track-inner,
  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    width: calc(100vw - 64px) !important;
    max-width: calc(100vw - 64px) !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-media,
  .sgp-gallery.sgp-type-slider .sgp-img {
    object-fit: contain !important;
    object-position: center center !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-prev { left: 2px !important; }
  .sgp-gallery.sgp-type-slider .sgp-next { right: 2px !important; }
}

/* 2) Viewer must honor global title color from tab 3 exactly like thumbnail/slider */
.sgp-viewer[data-global-text-style="1"][data-global-apply-title="1"] .sgp-title {
  font-family: var(--sgp-font-family) !important;
  font-size: var(--sgp-font-size) !important;
  color: var(--sgp-text-color) !important;
  font-weight: var(--sgp-text-weight) !important;
  font-style: var(--sgp-text-style) !important;
  line-height: var(--sgp-global-line-height) !important;
  letter-spacing: var(--sgp-global-letter-spacing) !important;
  text-transform: var(--sgp-global-transform) !important;
}
.sgp-viewer[data-global-text-style="1"][data-global-apply-excerpt="1"] .sgp-excerpt,
.sgp-viewer[data-global-text-style="1"][data-global-apply-description="1"] .sgp-description,
.sgp-viewer[data-global-text-style="1"][data-global-apply-alt="1"] .sgp-alt {
  font-family: var(--sgp-font-family) !important;
  font-size: var(--sgp-font-size) !important;
  color: var(--sgp-text-color) !important;
  font-weight: var(--sgp-text-weight) !important;
  font-style: var(--sgp-text-style) !important;
  line-height: var(--sgp-global-line-height) !important;
  letter-spacing: var(--sgp-global-letter-spacing) !important;
  text-transform: var(--sgp-global-transform) !important;
}

/* 3) Transparent INFO button must also stay fully transparent under thumbnails */
.sgp-gallery .sgp-overlay-toggle,
.sgp-viewer .sgp-overlay-toggle {
  background-color: var(--sgp-ot-btn-bg) !important;
  background-image: none !important;
  border-color: var(--sgp-ot-btn-border) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}
.sgp-gallery[style*="--sgp-ot-btn-bg:rgba(0,0,0,0)"] .sgp-thumb__below .sgp-overlay-toggle,
.sgp-gallery[style*="--sgp-ot-btn-bg:transparent"] .sgp-thumb__below .sgp-overlay-toggle,
.sgp-gallery[style*="--sgp-ot-btn-border:rgba(0,0,0,0)"] .sgp-thumb__below .sgp-overlay-toggle {
  background: transparent !important;
  background-color: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  outline: none !important;
  backdrop-filter: none !important;
}

/* 4) Allow smaller INFO text sizes than before */
.sgp-gallery .sgp-overlay-toggle,
.sgp-viewer .sgp-overlay-toggle {
  font-size: var(--sgp-ot-btn-fs) !important;
}
@media (max-width: 480px) {
  .sgp-gallery .sgp-overlay-toggle,
  .sgp-viewer .sgp-overlay-toggle {
    font-size: max(8px, calc(var(--sgp-ot-btn-fs) - 1px)) !important;
  }
}

/* 5) Keep overlay scrollbar at the outer edge, not in the middle of the overlay */
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content {
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scrollbar-gutter: stable !important;
  padding-right: 10px !important;
  margin-right: 0 !important;
  box-sizing: border-box !important;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar {
  width: 8px;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar-track,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar-track {
  background: transparent;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar-thumb,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,.18);
  border-radius: 999px;
}

/* ===== v15 slider width + mobile portrait edge-to-edge ===== */
.sgp-gallery.sgp-type-slider {
  width: 100% !important;
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box !important;
}

.sgp-gallery.sgp-type-slider .sgp-slider {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto !important;
}

.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-track-inner,
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  width: 100% !important;
  max-width: 100% !important;
}

.sgp-gallery.sgp-type-slider .sgp-track {
  margin: 0 auto !important;
}

.sgp-gallery.sgp-type-slider .sgp-prev,
.sgp-gallery.sgp-type-slider .sgp-next {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 14 !important;
}

.sgp-gallery.sgp-type-slider .sgp-prev {
  left: max(8px, env(safe-area-inset-left, 0px)) !important;
  right: auto !important;
}

.sgp-gallery.sgp-type-slider .sgp-next {
  right: max(8px, env(safe-area-inset-right, 0px)) !important;
  left: auto !important;
}

.sgp-gallery.sgp-type-slider .sgp-media,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-slide {
  position: relative !important;
  overflow: hidden !important;
}

.sgp-gallery.sgp-type-slider .sgp-img {
  width: 100% !important;
  max-width: 100% !important;
  object-position: center center !important;
}

@media (max-width: 700px) and (orientation: portrait) {
  .sgp-gallery.sgp-type-slider {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-slider,
  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-track-inner,
  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    width: 100% !important;
    max-width: 100% !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-prev,
  .sgp-gallery.sgp-type-slider .sgp-next {
    width: 38px !important;
    height: 38px !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-prev {
    left: 6px !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-next {
    right: 6px !important;
  }
}

/* ===== v16 mobile portrait slider expansion + overlay nav ===== */
@media (max-width: 700px) and (orientation: portrait) {
  .sgp-gallery.sgp-type-slider {
    --sgp-slider-side-pad: 2px;
    --sgp-slider-shell-gap: 0px;
  }

  .sgp-gallery.sgp-type-slider .sgp-slider {
    display: block !important;
    position: relative !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    width: 100% !important;
    max-width: 100% !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-media {
    min-height: min(78svh, var(--sgp-slider-responsive-max-h, 78svh)) !important;
    height: auto !important;
    max-height: none !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-item .sgp-img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: min(78svh, var(--sgp-slider-responsive-max-h, 78svh)) !important;
    object-fit: contain !important;
    object-position: center center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-nav {
    position: absolute !important;
    top: 50% !important;
    bottom: auto !important;
    transform: translateY(-50%) !important;
    z-index: 12 !important;
    margin: 0 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-prev {
    left: 6px !important;
    right: auto !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-next {
    right: 6px !important;
    left: auto !important;
  }
}

/* Let full-width themes give the slider the full available row width */
.sgp-gallery.sgp-type-slider,
.sgp-gallery.sgp-type-slider .sgp-slider,
.sgp-gallery.sgp-type-slider .sgp-track {
  max-width: 100% !important;
  box-sizing: border-box !important;
}


/* ===== v17 mobile portrait + centering hardening ===== */
.sgp-gallery.sgp-type-slider {
  width: 100% !important;
  max-width: 100% !important;
}

.sgp-gallery.sgp-type-slider .sgp-slider,
.sgp-gallery.sgp-type-slider .sgp-track,
.sgp-gallery.sgp-type-slider .sgp-slide,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-media {
  box-sizing: border-box !important;
}

.sgp-gallery.sgp-type-slider .sgp-media,
.sgp-gallery.sgp-type-slider .sgp-item,
.sgp-gallery.sgp-type-slider .sgp-slide {
  overflow: hidden !important;
}

.sgp-gallery.sgp-type-slider .sgp-img,
.sgp-viewer__img {
  display: block !important;
}

.sgp-viewer__stage,
.sgp-viewer__frame,
.sgp-viewer__main,
.sgp-viewer__mediawrap,
.sgp-viewer__media {
  box-sizing: border-box !important;
}

.sgp-viewer__frame,
.sgp-viewer__main,
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__img {
  margin-left: auto !important;
  margin-right: auto !important;
}

@media (max-width: 700px) and (orientation: portrait) {
  .sgp-gallery.sgp-type-slider {
    --sgp-slider-side-pad: 0px;
    --sgp-slider-shell-gap: 0px;
  }

  .sgp-gallery.sgp-type-slider .sgp-slider {
    display: block !important;
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-track {
    width: min(100vw, 100%) !important;
    max-width: 100vw !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    width: 100% !important;
    max-width: 100% !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-prev,
  .sgp-gallery.sgp-type-slider .sgp-next {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 7 !important;
  }

  .sgp-gallery.sgp-type-slider .sgp-prev { left: 8px !important; }
  .sgp-gallery.sgp-type-slider .sgp-next { right: 8px !important; }

  .sgp-gallery.sgp-type-slider .sgp-prev svg,
  .sgp-gallery.sgp-type-slider .sgp-next svg {
    opacity: 1 !important;
  }

  .sgp-viewer__stage {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  .sgp-viewer__frame {
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
  }
}

/* ===== v18 / 9.84.92: mobile slider fill + tighter image-box overlay sync ===== */
@media (max-width: 700px) and (orientation: portrait) {
  .sgp-gallery.sgp-type-slider {
    --sgp-slider-shell-gap: 0px !important;
    --sgp-slider-side-pad: 0px !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-slider {
    grid-template-columns: 0 minmax(0, 100%) 0 !important;
    column-gap: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-track,
  .sgp-gallery.sgp-type-slider .sgp-track-inner,
  .sgp-gallery.sgp-type-slider .sgp-slide,
  .sgp-gallery.sgp-type-slider .sgp-item,
  .sgp-gallery.sgp-type-slider .sgp-media {
    width: 100% !important;
    max-width: 100% !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-slide {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .sgp-gallery.sgp-type-slider .sgp-img {
    object-fit: contain !important;
    object-position: center center !important;
  }
}

.sgp-slider .sgp-overlay,
.sgp-viewer .sgp-overlay,
.sgp-gallery:not(.sgp-type-slider) .sgp-item .sgp-overlay {
  margin: 0 !important;
}

.sgp-slider .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner,
.sgp-gallery:not(.sgp-type-slider) .sgp-item .sgp-overlay-inner {
  box-sizing: border-box !important;
}


/* ===== v19 targeted fixes ===== */
.sgp-viewer .sgp-viewer__close,
.sgp-gallery .sgp-overlay-close {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  line-height: 1 !important;
  text-align: center !important;
}
.sgp-viewer .sgp-viewer__close svg,
.sgp-gallery .sgp-overlay-close svg,
.sgp-viewer .sgp-viewer__close > svg,
.sgp-gallery .sgp-overlay-close > svg {
  display: block !important;
  margin: auto !important;
  flex: 0 0 auto !important;
}
.sgp-proof-badge,
.sgp-usage-badge,
.sgp-credit-line,
.sgp-watermark {
  justify-content: center !important;
}
.sgp-proof-badge__ic,
.sgp-usage-badge__ic,
.sgp-credit-line__ic,
.sgp-watermark__ic {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content {
  padding-right: 0 !important;
  scrollbar-gutter: stable both-edges !important;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar {
  width: 10px;
}
@media (max-width: 1024px) {
  .sgp-gallery.sgp-type-grid .sgp-media {
    height: auto !important;
    min-height: 0 !important;
  }
  .sgp-gallery.sgp-type-grid .sgp-img {
    height: auto !important;
    max-width: 100% !important;
    object-fit: cover !important;
  }
}
@media (max-width: 1200px) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__main,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__main,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__main,
  .sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__main,
  .sgp-viewer[data-source-gallery-type="masonry"] .sgp-viewer__main,
  .sgp-viewer[data-source-gallery-type="polaroid"] .sgp-viewer__main {
    width: min(98vw, 1400px) !important;
    max-width: min(98vw, 1400px) !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-source-gallery-type="masonry"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-source-gallery-type="polaroid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media,
  .sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__media,
  .sgp-viewer[data-source-gallery-type="masonry"] .sgp-viewer__media,
  .sgp-viewer[data-source-gallery-type="polaroid"] .sgp-viewer__media {
    width: 100% !important;
    max-width: 100% !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__img,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__img,
  .sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__img,
  .sgp-viewer[data-source-gallery-type="masonry"] .sgp-viewer__img,
  .sgp-viewer[data-source-gallery-type="polaroid"] .sgp-viewer__img {
    margin-left: auto !important;
    margin-right: auto !important;
    object-position: center center !important;
  }
}


/* ===== v20 targeted fixes: overlay scrollbar edge, viewer centering, responsive borders, hide overlay close ===== */
.sgp-gallery .sgp-overlay-close,
.sgp-viewer .sgp-overlay-close {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content {
  padding-right: 16px !important;
  scrollbar-gutter: stable !important;
  background-clip: padding-box !important;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar {
  width: 8px !important;
}

@media (max-width: 1200px) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-source-gallery-type="masonry"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-source-gallery-type="polaroid"] .sgp-viewer__mediawrap {
    left: 50% !important;
    right: auto !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    transform: translateX(-50%) !important;
  }
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__media,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__media,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__media,
  .sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__media,
  .sgp-viewer[data-source-gallery-type="masonry"] .sgp-viewer__media,
  .sgp-viewer[data-source-gallery-type="polaroid"] .sgp-viewer__media {
    margin-left: auto !important;
    margin-right: auto !important;
    justify-content: center !important;
  }
}

@media (max-width: 1024px) {
  .sgp-gallery.sgp-type-grid .sgp-media,
  .sgp-gallery.sgp-type-polaroid .sgp-media {
    border-width: clamp(1px, calc(var(--sgp-image-border-w, 0px) * 0.72), var(--sgp-image-border-w, 0px)) !important;
  }
  .sgp-gallery.sgp-type-polaroid .sgp-item::before {
    inset: clamp(6px, 1.8vw, 12px) clamp(6px, 1.8vw, 12px) clamp(16px, 4vw, 26px) !important;
  }
}


/* v21 centering and overlay-scroll fixes */
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content {
  padding-right: 14px !important;
  scrollbar-gutter: stable both-edges !important;
  box-sizing: border-box !important;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar {
  width: 10px;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar-track,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar-track {
  background: transparent;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar-thumb,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar-thumb {
  background: rgba(15, 23, 42, .22);
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: padding-box;
}

.sgp-gallery .sgp-overlay-close,
.sgp-viewer .sgp-overlay-close {
  display: none !important;
}

@media (max-width: 1024px) {
  .sgp-gallery.sgp-type-polaroid .sgp-item {
    padding: 10px 10px 14px !important;
    border-width: 1px !important;
    box-shadow: 0 6px 18px rgba(0,0,0,.09) !important;
  }
}

@media (max-width: 780px) {
  .sgp-gallery.sgp-type-polaroid .sgp-item {
    padding: 8px 8px 12px !important;
    border-width: 1px !important;
    box-shadow: 0 5px 14px rgba(0,0,0,.08) !important;
  }
  .sgp-gallery.sgp-type-polaroid .sgp-thumb__below {
    margin-top: 8px !important;
  }
}


/* ===== v22 portrait viewer centering + wider overlay scroll spacing ===== */
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content{
  scrollbar-gutter: stable both-edges !important;
  padding-right: max(14px, var(--sgp-overlay-scroll-gap, 18px)) !important;
  background-clip: padding-box !important;
}
.sgp-gallery .sgp-overlay-content > .sgp-title,
.sgp-gallery .sgp-overlay-content > .sgp-excerpt,
.sgp-gallery .sgp-overlay-content > .sgp-description,
.sgp-gallery .sgp-overlay-content > .sgp-alt,
.sgp-viewer .sgp-overlay-content > .sgp-title,
.sgp-viewer .sgp-overlay-content > .sgp-excerpt,
.sgp-viewer .sgp-overlay-content > .sgp-description,
.sgp-viewer .sgp-overlay-content > .sgp-alt{
  padding-right: 0 !important;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar {
  width: 12px;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar-track,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar-track {
  background: transparent;
  margin-block: 4px;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar-thumb,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar-thumb {
  border-width: 3px !important;
}
@media (max-width: 1024px) {
  .sgp-gallery.sgp-type-polaroid .sgp-item {
    padding: 8px 8px 12px !important;
    border-width: 1px !important;
    box-shadow: 0 5px 14px rgba(0,0,0,.08) !important;
  }
}
@media (max-width: 780px) {
  .sgp-gallery.sgp-type-polaroid .sgp-item {
    padding: 6px 6px 10px !important;
    border-width: 1px !important;
    box-shadow: 0 4px 12px rgba(0,0,0,.07) !important;
  }
  .sgp-gallery.sgp-type-polaroid .sgp-thumb__below {
    margin-top: 6px !important;
  }
}

/* RC99 viewer centering + overlay gutter + polaroid thumb fit */
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content{
  scrollbar-gutter: stable both-edges !important;
  padding-inline-end: 20px !important;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar{
  width: 12px !important;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar-track,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar-track{
  margin-block: 4px !important;
}

.sgp-viewer .sgp-viewer__topbar{
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
}
.sgp-viewer .sgp-viewer__close{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
}
.sgp-viewer .sgp-viewer__close svg,
.sgp-viewer .sgp-viewer__close::before{
  margin:0 auto !important;
}

/* Keep thumbnails tight to the actual photo in polaroid mode. */
.sgp-gallery.sgp-type-polaroid .sgp-item{
  padding: 10px 10px 44px !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-media{
  aspect-ratio: auto !important;
  height: auto !important;
  min-height: 0 !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-img{
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-width:100% !important;
  max-height:none !important;
  object-fit:contain !important;
  object-position:center center !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below{
  left: 10px !important;
  right: 10px !important;
  bottom: 10px !important;
}
@media (max-width: 900px){
  .sgp-gallery.sgp-type-polaroid .sgp-item{
    padding: 8px 8px 38px !important;
  }
  .sgp-gallery.sgp-type-polaroid .sgp-thumb__below{
    left: 8px !important;
    right: 8px !important;
    bottom: 8px !important;
  }
}

/* Align the actual polaroid defaults with the admin hint. */
.sgp-gallery.sgp-type-polaroid .sgp-title{
  font-family: "Patrick Hand", "Segoe Print", "Bradley Hand", "Comic Sans MS", cursive !important;
  color: #7c6f5a !important;
}


/* ===== v26 fixes: viewer centering, close placement, grid border scaling, polaroid tape/color, scrollbar gap ===== */
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content,
.sgp-gallery .sgp-overlay-inner--viewer .sgp-overlay-content,
.sgp-viewer .sgp-overlay-inner--viewer .sgp-overlay-content {
  padding-right: 24px !important;
  scrollbar-gutter: stable both-edges !important;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar {
  width: 12px !important;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar-track,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar-track {
  background: transparent !important;
  border-left: 6px solid transparent !important;
}
.sgp-gallery .sgp-overlay-content::-webkit-scrollbar-thumb,
.sgp-viewer .sgp-overlay-content::-webkit-scrollbar-thumb {
  border-left: 6px solid transparent !important;
  background-clip: padding-box !important;
}

/* Keep viewer media truly centered on all screen sizes */
.sgp-viewer__stage {
  justify-content: center !important;
  align-items: center !important;
}
.sgp-viewer__frame {
  position: relative !important;
  margin-left: auto !important;
  margin-right: auto !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
}
.sgp-viewer__topbar {
  position: absolute !important;
  inset: 0 0 auto 0 !important;
  width: 100% !important;
  height: 0 !important;
  margin: 0 !important;
  pointer-events: none !important;
  z-index: 6 !important;
}
.sgp-viewer .sgp-viewer__topbar .sgp-viewer__close {
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  inset: auto 10px auto auto !important;
  margin: 0 !important;
  transform: none !important;
  z-index: 7 !important;
  pointer-events: auto !important;
}
.sgp-viewer__main,
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media,
.sgp-viewer__img {
  margin-left: auto !important;
  margin-right: auto !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
}

/* Undo older mobile left/translate centering hack that shifted portrait devices */
@media (max-width: 1200px) {
  .sgp-viewer[data-gallery-type="grid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="masonry"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-gallery-type="polaroid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-source-gallery-type="grid"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-source-gallery-type="masonry"] .sgp-viewer__mediawrap,
  .sgp-viewer[data-source-gallery-type="polaroid"] .sgp-viewer__mediawrap {
    left: auto !important;
    right: auto !important;
    transform: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
@media (max-width: 1180px), (orientation: portrait) {
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__frame {
    width: min(calc(100vw - 18px), 1120px) !important;
    max-width: min(calc(100vw - 18px), 1120px) !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__main,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__topbar,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__below {
    width: 100% !important;
    max-width: 100% !important;
  }
}
@media (max-width: 820px), (max-width: 1180px) and (orientation: portrait) {
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__stage {
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__main {
    grid-template-columns: minmax(0,1fr) !important;
    width: 100% !important;
    max-width: 100% !important;
    column-gap: 0 !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__navcol {
    position: static !important;
    width: 0 !important;
    min-width: 0 !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__mediawrap {
    width: 100% !important;
    max-width: 100% !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__media,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-item,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__media .sgp-media,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__img {
    width: 100% !important;
    max-width: 100% !important;
    object-position: center center !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__prev,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__next {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 7 !important;
  }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__prev { left: 10px !important; }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__next { right: 10px !important; }
  .sgp-viewer[aria-hidden="false"] .sgp-viewer .sgp-viewer__topbar .sgp-viewer__close,
  .sgp-viewer[aria-hidden="false"] .sgp-viewer__topbar .sgp-viewer__close {
    top: 8px !important;
    right: 8px !important;
  }
}

/* Polaroid tape and border sizing */
.sgp-gallery.sgp-type-polaroid .sgp-item::before {
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
}
@media (max-width: 1024px) {
  .sgp-gallery.sgp-type-grid .sgp-item {
    padding-left: clamp(6px, 1.6vw, 10px) !important;
    padding-right: clamp(6px, 1.6vw, 10px) !important;
  }
  .sgp-gallery.sgp-type-grid .sgp-media {
    width: calc(100% - (clamp(6px, 1.6vw, 10px) * 0)) !important;
  }
  .sgp-gallery.sgp-type-polaroid .sgp-item {
    padding: 8px !important;
  }
  .sgp-gallery.sgp-type-polaroid .sgp-thumb__below {
    margin-top: 4px !important;
    padding-top: 6px !important;
    padding-bottom: 0 !important;
  }
}
@media (max-width: 780px) {
  .sgp-gallery.sgp-type-grid .sgp-item {
    padding-left: 4px !important;
    padding-right: 4px !important;
  }
  .sgp-gallery.sgp-type-polaroid .sgp-item {
    padding: 6px !important;
  }
  .sgp-gallery.sgp-type-polaroid .sgp-thumb__below {
    margin-top: 2px !important;
  }
}


/* v9.84.101 targeted fixes */
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content {
  padding-right: 18px !important;
  scrollbar-gutter: stable both-edges;
}
.sgp-gallery .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner {
  padding-right: calc(var(--sgp-overlay-pad-right, 20px) + 12px) !important;
}
.sgp-gallery.sgp-type-grid .sgp-item {
  align-items: stretch !important;
}
.sgp-gallery.sgp-type-grid .sgp-media {
  width: 100% !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.sgp-gallery.sgp-type-grid .sgp-img {
  display: block !important;
  margin-left: auto !important;
  margin-right: auto !important;
  object-position: center center !important;
}
.sgp-gallery.sgp-type-grid .sgp-overlay {
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
}
.sgp-viewer__topbar {
  justify-content: flex-end !important;
  align-items: flex-start !important;
}
.sgp-viewer .sgp-viewer__topbar .sgp-viewer__close {
  top: 12px !important;
  right: 12px !important;
  left: auto !important;
  transform: none !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-item::before {
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-media {
  margin-bottom: 0 !important;
}
.sgp-gallery.sgp-type-polaroid .sgp-thumb__below {
  margin-top: 0 !important;
}


/* v9.84.102 targeted fixes */
.sgp-viewer__main,
.sgp-viewer__frame,
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media {
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-viewer__mediawrap,
.sgp-viewer__media,
.sgp-viewer__media .sgp-item,
.sgp-viewer__media .sgp-media,
.sgp-viewer__topbar {
  left: auto !important;
  right: auto !important;
  transform: none !important;
  translate: none !important;
}
.sgp-viewer .sgp-viewer__topbar .sgp-viewer__close {
  top: 10px !important;
  right: -18px !important;
  left: auto !important;
  transform: none !important;
}
@media (max-width: 700px) {
  .sgp-viewer .sgp-viewer__topbar .sgp-viewer__close {
    right: -14px !important;
  }
}
.sgp-gallery.sgp-type-polaroid .sgp-item::before {
  top: -13px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
}
.sgp-gallery.sgp-type-grid .sgp-overlay {
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}
.sgp-gallery .sgp-overlay-content,
.sgp-viewer .sgp-overlay-content {
  padding-right: 28px !important;
}
.sgp-gallery .sgp-overlay-inner,
.sgp-viewer .sgp-overlay-inner {
  padding-right: calc(var(--sgp-overlay-pad-right, 20px) + 18px) !important;
}


/* v29 final viewer centering + grid overlay cover */
.sgp-viewer .sgp-viewer__stage,
.sgp-viewer .sgp-viewer__frame,
.sgp-viewer .sgp-viewer__main {
  justify-content: center !important;
  justify-items: center !important;
  align-items: center !important;
}
.sgp-viewer .sgp-viewer__mediawrap,
.sgp-viewer .sgp-viewer__media,
.sgp-viewer .sgp-viewer__media .sgp-item,
.sgp-viewer .sgp-viewer__media .sgp-media {
  overflow: visible !important;
}
.sgp-viewer .sgp-viewer__topbar {
  overflow: visible !important;
}
.sgp-viewer .sgp-viewer__close {
  top: -18px !important;
  right: -18px !important;
  left: auto !important;
  bottom: auto !important;
}
.sgp-gallery.sgp-type-grid .sgp-overlay,
.sgp-gallery.sgp-type-grid .sgp-item .sgp-overlay,
.sgp-gallery.sgp-type-masonry .sgp-overlay,
.sgp-gallery.sgp-type-polaroid .sgp-overlay {
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  margin: 0 !important;
}
@media (max-width: 1024px) {
  .sgp-viewer .sgp-viewer__close {
    top: -16px !important;
    right: -16px !important;
  }
}


/* v9.84.107 viewer centering and swipe access fixes */
.sgp-viewer__stage {
  overflow-x: visible !important;
}
.sgp-viewer__frame,
.sgp-viewer__main,
.sgp-viewer__mediawrap,
.sgp-viewer__media {
  margin-left: auto !important;
  margin-right: auto !important;
}
.sgp-viewer__mediawrap {
  touch-action: pan-y pinch-zoom !important;
}

/* v9.84.110 viewer centering and swipe-start fixes */
