/* ============================================
   Pretpot Media Sticky-Shrink Animation 1
   ============================================ */

/* ---- Neutralise Elementor ancestor overflow/padding issues ----
   Every ancestor in the Elementor chain must have overflow:visible
   for position:sticky to work. We also zero the 5px widget-container padding. */
.elementor-widget-pretpot-media-sticky-shrink-1,
.elementor-widget-pretpot-media-sticky-shrink-1 .elementor-widget-container {
    padding: 0 !important;
    overflow: visible !important;
}

/* Force overflow:visible up the Elementor column chain so sticky works */
.elementor-widget-pretpot-media-sticky-shrink-1,
.elementor-widget-pretpot-media-sticky-shrink-1 .elementor-widget-container,
.elementor-widget-pretpot-media-sticky-shrink-1 ~ *,
.elementor-element:has(.pretpot-media-sticky-shrink-1),
.elementor-widget-wrap:has(.pretpot-media-sticky-shrink-1),
.elementor-column:has(.pretpot-media-sticky-shrink-1),
.elementor-container:has(.pretpot-media-sticky-shrink-1) {
    overflow: visible !important;
}

/* ---- Outer widget: the scroll-through container ----
   min-height is set inline by PHP: calc(100vh + scrollDistance).
   This is what gives sticky its room to travel. */
.pretpot-media-sticky-shrink-1 {
    position: relative;
    width: 100%;
    min-height: calc(100vh + 800px); /* fallback; overridden inline by PHP */
}

/* Scroll spacer — zero height, exists only for back-compat */
.pretpot-mss-scroll-spacer {
    width: 100%;
    height: 0;
    background: transparent;
}

/* ---- Sticky wrapper: anchored to bottom of viewport ----
   Uses position:sticky bottom:0 — JS also enforces this via
   fixStickyWrapper() if CSS sticky is broken by an ancestor. */
.pretpot-mss-sticky-wrapper {
    position: sticky;
    bottom: 0;
    z-index: 100;
    width: 100%;
    height: 100vh;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    overflow: visible;
    /* Negative horizontal margin breaks out of any residual padding */
    margin-left: 0;
    margin-right: 0;
}

/* ---- Media container: starts full-screen, shrinks from bottom ---- */
.pretpot-mss-media-container {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    height: 100vh;
    overflow: hidden;
    will-change: width, height, border-radius;
}

.pretpot-mss-media-container img,
.pretpot-mss-media-container video {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
    display: block !important;
}

/* Optional Center Text Overlay (Style 1) */
.pretpot-mss-center-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 5;
    text-align: center;
    opacity: 0;
    transition: opacity 0.6s ease;
    pointer-events: none;
}

.pretpot-mss-center-text.visible {
    opacity: 1;
}

.pretpot-mss-center-text .mss-heading {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 3rem;
    font-weight: 700;
    color: #fff;
    text-shadow: 0 2px 20px rgba(0,0,0,0.5);
    margin-bottom: 12px;
    letter-spacing: -0.02em;
}

.pretpot-mss-center-text .mss-subheading {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 1.25rem;
    font-weight: 400;
    color: rgba(255,255,255,0.85);
    text-shadow: 0 1px 10px rgba(0,0,0,0.4);
}

/* Content Overlay Group (Style 2 & 3) */
.pretpot-mss-content-overlay {
    position: absolute;
    left: 0;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.4s ease;
}

.pretpot-mss-content-overlay.active {
    opacity: 1;
}

/* Content Group Wrapper */
.pretpot-mss-content-group {
    display: flex;
    align-items: center;
    gap: var(--mss-gap-image-text, 40px);
    pointer-events: auto;
    will-change: transform, opacity;
}

/* Entrance Animation States */
.pretpot-mss-content-group[data-entrance="fade"] {
    opacity: 0;
    transition: opacity var(--mss-entrance-speed, 0.8s) ease;
}
.pretpot-mss-content-group[data-entrance="fade"].mss-entered {
    opacity: 1;
}

.pretpot-mss-content-group[data-entrance="slide-left"] {
    transform: translateX(-100vw);
    transition: transform var(--mss-entrance-speed, 0.8s) cubic-bezier(0.16, 1, 0.3, 1);
}
.pretpot-mss-content-group[data-entrance="slide-left"].mss-entered {
    transform: translateX(0);
}

.pretpot-mss-content-group[data-entrance="slide-right"] {
    transform: translateX(100vw);
    transition: transform var(--mss-entrance-speed, 0.8s) cubic-bezier(0.16, 1, 0.3, 1);
}
.pretpot-mss-content-group[data-entrance="slide-right"].mss-entered {
    transform: translateX(0);
}

.pretpot-mss-content-group[data-entrance="slide-up"] {
    transform: translateY(100px);
    opacity: 0;
    transition: transform var(--mss-entrance-speed, 0.8s) cubic-bezier(0.16, 1, 0.3, 1),
                opacity var(--mss-entrance-speed, 0.8s) ease;
}
.pretpot-mss-content-group[data-entrance="slide-up"].mss-entered {
    transform: translateY(0);
    opacity: 1;
}

.pretpot-mss-content-group[data-entrance="slide-down"] {
    transform: translateY(-100px);
    opacity: 0;
    transition: transform var(--mss-entrance-speed, 0.8s) cubic-bezier(0.16, 1, 0.3, 1),
                opacity var(--mss-entrance-speed, 0.8s) ease;
}
.pretpot-mss-content-group[data-entrance="slide-down"].mss-entered {
    transform: translateY(0);
    opacity: 1;
}

.pretpot-mss-content-group[data-entrance="scale"] {
    transform: scale(0.6);
    opacity: 0;
    transition: transform var(--mss-entrance-speed, 0.8s) cubic-bezier(0.16, 1, 0.3, 1),
                opacity var(--mss-entrance-speed, 0.8s) ease;
}
.pretpot-mss-content-group[data-entrance="scale"].mss-entered {
    transform: scale(1);
    opacity: 1;
}

/* Style 2: Image + Text + Button */
.pretpot-mss-style2-image {
    width: var(--mss-style2-image-width, 200px);
    height: var(--mss-style2-image-height, 200px);
    border-radius: var(--mss-style2-image-radius, 50%);
    object-fit: cover;
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
    flex-shrink: 0;
}

.pretpot-mss-style2-text {
    display: flex;
    flex-direction: column;
    gap: var(--mss-gap-title-button, 20px);
}

.pretpot-mss-style2-title {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: var(--mss-title-size, 1.6rem);
    font-weight: 700;
    color: var(--mss-title-color, #fff);
    letter-spacing: 0.05em;
    line-height: 1.2;
}

.pretpot-mss-style2-button {
    display: inline-block;
    padding: var(--mss-button-padding-y, 14px) var(--mss-button-padding-x, 36px);
    background: var(--mss-button-bg, #e67e22);
    color: var(--mss-button-color, #fff);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: var(--mss-button-size, 1rem);
    font-weight: 600;
    text-decoration: none;
    border-radius: var(--mss-button-radius, 50px);
    border: none;
    cursor: pointer;
    pointer-events: auto;
    transition: all 0.3s ease;
    box-shadow: 0 8px 24px rgba(230, 126, 34, 0.4);
    align-self: flex-start;
}

.pretpot-mss-style2-button:hover {
    background: var(--mss-button-hover-bg, #d35400);
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(230, 126, 34, 0.5);
}

/* Style 3: Centered Text Only */
.pretpot-mss-style3-group {
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: var(--mss-gap-heading-subheading, 16px);
}

.pretpot-mss-style3-heading {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: var(--mss-heading-size, 2.5rem);
    font-weight: 700;
    color: var(--mss-heading-color, #fff);
    letter-spacing: -0.02em;
    line-height: 1.2;
    text-shadow: 0 2px 20px rgba(0,0,0,0.5);
}

.pretpot-mss-style3-subheading {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: var(--mss-subheading-size, 1.125rem);
    font-weight: 400;
    color: var(--mss-subheading-color, rgba(255,255,255,0.85));
    line-height: 1.5;
    text-shadow: 0 1px 10px rgba(0,0,0,0.4);
}

/* Responsive */
@media (max-width: 767px) {
    .pretpot-mss-content-group {
        flex-direction: column;
        gap: var(--mss-gap-image-text-mobile, 24px);
    }
    .pretpot-mss-style2-image {
        width: var(--mss-style2-image-width-mobile, 150px);
        height: var(--mss-style2-image-height-mobile, 150px);
    }
    .pretpot-mss-style2-title {
        font-size: var(--mss-title-size-mobile, 1.25rem);
    }
    .pretpot-mss-style3-heading {
        font-size: var(--mss-heading-size-mobile, 1.75rem);
    }
    .pretpot-mss-style3-subheading {
        font-size: var(--mss-subheading-size-mobile, 1rem);
    }
    .pretpot-mss-center-text .mss-heading {
        font-size: 2rem;
    }
    .pretpot-mss-center-text .mss-subheading {
        font-size: 1rem;
    }
}

.pretpot-mss-media-container img,
.pretpot-mss-media-container video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transform-origin: bottom center;
}

/* Optional Center Text Overlay (Style 1) */
.pretpot-mss-center-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 5;
    text-align: center;
    opacity: 0;
    transition: opacity 0.6s ease;
    pointer-events: none;
}

.pretpot-mss-center-text.visible {
    opacity: 1;
}

.pretpot-mss-center-text .mss-heading {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 3rem;
    font-weight: 700;
    color: #fff;
    text-shadow: 0 2px 20px rgba(0,0,0,0.5);
    margin-bottom: 12px;
    letter-spacing: -0.02em;
}

.pretpot-mss-center-text .mss-subheading {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 1.25rem;
    font-weight: 400;
    color: rgba(255,255,255,0.85);
    text-shadow: 0 1px 10px rgba(0,0,0,0.4);
}

/* Content Overlay Group (Style 2 & 3) */
.pretpot-mss-content-overlay {
    position: absolute;
    left: 0;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.4s ease;
}

.pretpot-mss-content-overlay.active {
    opacity: 1;
}

/* Content Group Wrapper */
.pretpot-mss-content-group {
    display: flex;
    align-items: center;
    gap: var(--mss-gap-image-text, 40px);
    pointer-events: auto;
    will-change: transform, opacity;
}

/* Entrance Animation States */
.pretpot-mss-content-group[data-entrance="fade"] {
    opacity: 0;
    transition: opacity var(--mss-entrance-speed, 0.8s) ease;
}

.pretpot-mss-content-group[data-entrance="fade"].mss-entered {
    opacity: 1;
}

.pretpot-mss-content-group[data-entrance="slide-left"] {
    transform: translateX(-100vw);
    transition: transform var(--mss-entrance-speed, 0.8s) cubic-bezier(0.16, 1, 0.3, 1);
}

.pretpot-mss-content-group[data-entrance="slide-left"].mss-entered {
    transform: translateX(0);
}

.pretpot-mss-content-group[data-entrance="slide-right"] {
    transform: translateX(100vw);
    transition: transform var(--mss-entrance-speed, 0.8s) cubic-bezier(0.16, 1, 0.3, 1);
}

.pretpot-mss-content-group[data-entrance="slide-right"].mss-entered {
    transform: translateX(0);
}

.pretpot-mss-content-group[data-entrance="slide-up"] {
    transform: translateY(100px);
    opacity: 0;
    transition: transform var(--mss-entrance-speed, 0.8s) cubic-bezier(0.16, 1, 0.3, 1),
                opacity var(--mss-entrance-speed, 0.8s) ease;
}

.pretpot-mss-content-group[data-entrance="slide-up"].mss-entered {
    transform: translateY(0);
    opacity: 1;
}

.pretpot-mss-content-group[data-entrance="slide-down"] {
    transform: translateY(-100px);
    opacity: 0;
    transition: transform var(--mss-entrance-speed, 0.8s) cubic-bezier(0.16, 1, 0.3, 1),
                opacity var(--mss-entrance-speed, 0.8s) ease;
}

.pretpot-mss-content-group[data-entrance="slide-down"].mss-entered {
    transform: translateY(0);
    opacity: 1;
}

.pretpot-mss-content-group[data-entrance="scale"] {
    transform: scale(0.6);
    opacity: 0;
    transition: transform var(--mss-entrance-speed, 0.8s) cubic-bezier(0.16, 1, 0.3, 1),
                opacity var(--mss-entrance-speed, 0.8s) ease;
}

.pretpot-mss-content-group[data-entrance="scale"].mss-entered {
    transform: scale(1);
    opacity: 1;
}

/* Style 2: Image + Text + Button */
.pretpot-mss-style2-image {
    width: var(--mss-style2-image-width, 200px);
    height: var(--mss-style2-image-height, 200px);
    border-radius: var(--mss-style2-image-radius, 50%);
    object-fit: cover;
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
    flex-shrink: 0;
}

.pretpot-mss-style2-text {
    display: flex;
    flex-direction: column;
    gap: var(--mss-gap-title-button, 20px);
}

.pretpot-mss-style2-title {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: var(--mss-title-size, 1.6rem);
    font-weight: 700;
    color: var(--mss-title-color, #fff);
    letter-spacing: 0.05em;
    line-height: 1.2;
}

.pretpot-mss-style2-button {
    display: inline-block;
    padding: var(--mss-button-padding-y, 14px) var(--mss-button-padding-x, 36px);
    background: var(--mss-button-bg, #e67e22);
    color: var(--mss-button-color, #fff);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: var(--mss-button-size, 1rem);
    font-weight: 600;
    text-decoration: none;
    border-radius: var(--mss-button-radius, 50px);
    border: none;
    cursor: pointer;
    pointer-events: auto;
    transition: all 0.3s ease;
    box-shadow: 0 8px 24px rgba(230, 126, 34, 0.4);
    align-self: flex-start;
}

.pretpot-mss-style2-button:hover {
    background: var(--mss-button-hover-bg, #d35400);
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(230, 126, 34, 0.5);
}

/* Style 3: Centered Text Only */
.pretpot-mss-style3-group {
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: var(--mss-gap-heading-subheading, 16px);
}

.pretpot-mss-style3-heading {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: var(--mss-heading-size, 2.5rem);
    font-weight: 700;
    color: var(--mss-heading-color, #fff);
    letter-spacing: -0.02em;
    line-height: 1.2;
    text-shadow: 0 2px 20px rgba(0,0,0,0.5);
}

.pretpot-mss-style3-subheading {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: var(--mss-subheading-size, 1.125rem);
    font-weight: 400;
    color: var(--mss-subheading-color, rgba(255,255,255,0.85));
    line-height: 1.5;
    text-shadow: 0 1px 10px rgba(0,0,0,0.4);
}

/* Responsive */
@media (max-width: 767px) {
    .pretpot-mss-content-group {
        flex-direction: column;
        gap: var(--mss-gap-image-text-mobile, 24px);
    }
    
    .pretpot-mss-style2-image {
        width: var(--mss-style2-image-width-mobile, 150px);
        height: var(--mss-style2-image-height-mobile, 150px);
    }
    
    .pretpot-mss-style2-title {
        font-size: var(--mss-title-size-mobile, 1.25rem);
    }
    
    .pretpot-mss-style3-heading {
        font-size: var(--mss-heading-size-mobile, 1.75rem);
    }
    
    .pretpot-mss-style3-subheading {
        font-size: var(--mss-subheading-size-mobile, 1rem);
    }
    
    .pretpot-mss-center-text .mss-heading {
        font-size: 2rem;
    }
    
    .pretpot-mss-center-text .mss-subheading {
        font-size: 1rem;
    }
}