/**
 * Pretpot Scroll Effect Style 1 Widget CSS
 */

/* Main container - height set by JS from control */
.pretpot-scroll-effect-style1 {
    position: relative;
    width: 100%;
    height: var(--widget-height, 200vh); /* Controlled by user */
    overflow: visible;
}

/* Sticky wrapper */
.pretpot-ses1-sticky {
    position: sticky;
    top: 0;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: visible;
}

/* Image container - scrolls up and fades */
.pretpot-ses1-image-wrap {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    will-change: transform, opacity;
    z-index: 1;
}

.pretpot-ses1-image {
    max-width: 55%;
    max-height: 75vh;
    object-fit: contain;
    transition: transform 0.15s linear, opacity 0.15s linear;
    will-change: transform, opacity;
}

/* Info box - starts small, grows as it travels to bottom */
.pretpot-ses1-info-box {
    position: absolute;
    width: var(--box-width, 280px);
    padding: var(--box-padding, 24px);
    background: var(--box-bg, rgba(245, 243, 240, 0.95));
    border: var(--box-border-width, 1px) solid var(--box-border-color, rgba(0,0,0,0.1));
    border-radius: var(--box-border-radius, 0px);
    box-shadow: var(--box-shadow, 0 10px 40px rgba(0,0,0,0.1));
    transition: top 0.15s linear, transform 0.15s linear, opacity 0.15s linear;
    will-change: top, transform, opacity;
    z-index: 10;
    /* Starting state - small and faded */
    transform: scale(var(--box-start-scale, 0.7));
    opacity: var(--box-start-opacity, 0.4);
}

/* Position variants - start at top corners */
.pretpot-ses1-info-box.position-right {
    top: var(--box-start-top, 8%);
    right: var(--box-start-side, 5%);
    left: auto;
}

.pretpot-ses1-info-box.position-left {
    top: var(--box-start-top, 8%);
    left: var(--box-start-side, 5%);
    right: auto;
}

/* Box elements */
.pretpot-ses1-elements {
    display: flex;
    flex-direction: column;
    gap: var(--element-gap, 14px);
}

.pretpot-ses1-element {
    opacity: 0;
    transform: translateY(15px);
    transition: opacity 0.5s ease, transform 0.5s ease;
}

.pretpot-ses1-element.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Heading */
.pretpot-ses1-heading {
    font-size: var(--heading-size, 22px);
    font-weight: var(--heading-weight, 600);
    color: var(--heading-color, #2a2a2a);
    line-height: 1.3;
    margin: 0;
    text-align: var(--heading-align, left);
}

.pretpot-ses1-heading .typewriter {
    overflow: hidden;
    white-space: nowrap;
    border-right: 2px solid var(--heading-color, #2a2a2a);
    animation: ses1-typing 0.8s steps(30) forwards, ses1-blink 0.7s step-end 3;
}

@keyframes ses1-typing {
    from { width: 0; }
    to { width: 100%; }
}

@keyframes ses1-blink {
    50% { border-color: transparent; }
}

/* Subtext */
.pretpot-ses1-subtext {
    font-size: var(--subtext-size, 13px);
    line-height: var(--subtext-line-height, 1.6);
    color: var(--subtext-color, #666);
    margin: 0;
    text-align: var(--subtext-align, left);
}

/* Progress bars */
.pretpot-ses1-progress-wrap {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.pretpot-ses1-progress-item {
    display: flex;
    align-items: center;
    gap: 10px;
}

.pretpot-ses1-progress-label {
    width: var(--progress-label-width, 60px);
    font-size: var(--progress-label-size, 10px);
    color: var(--progress-label-color, #888);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    flex-shrink: 0;
    text-align: var(--progress-label-align, left);
}

.pretpot-ses1-progress-track {
    flex: 1;
    height: var(--progress-height, 2px);
    background: var(--progress-track-bg, rgba(0,0,0,0.08));
    border-radius: var(--progress-radius, 1px);
    overflow: hidden;
}

.pretpot-ses1-progress-fill {
    height: 100%;
    width: 0;
    background: var(--progress-fill-color, #c4a77d);
    border-radius: var(--progress-radius, 1px);
    transition: width 0.8s ease;
}

.pretpot-ses1-progress-fill.animate {
    width: var(--progress-value, 50%);
}

/* Footer */
.pretpot-ses1-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: var(--footer-padding-top, 12px);
    border-top: var(--footer-border-width, 1px) solid var(--footer-border-color, rgba(0,0,0,0.08));
    margin-top: var(--footer-margin-top, 6px);
}

.pretpot-ses1-category {
    font-size: var(--category-size, 10px);
    color: var(--category-color, #999);
    letter-spacing: 1px;
    text-transform: uppercase;
}

.pretpot-ses1-price {
    font-size: var(--price-size, 16px);
    font-weight: var(--price-weight, 600);
    color: var(--price-color, #2a2a2a);
}

/* Additional text */
.pretpot-ses1-additional-text {
    font-size: var(--additional-text-size, 10px);
    color: var(--additional-text-color, #888);
    line-height: 1.4;
}

/* Caption */
.pretpot-ses1-caption {
    position: absolute;
    bottom: var(--caption-bottom, 5%);
    left: 50%;
    transform: translateX(-50%);
    font-size: var(--caption-size, 11px);
    color: var(--caption-color, #888);
    text-align: center;
    opacity: 0;
    transition: opacity 0.6s ease;
    z-index: 5;
}

.pretpot-ses1-caption.visible {
    opacity: 1;
}

/* Mobile - respect left/right position with smaller starting size */
@media (max-width: 768px) {
    .pretpot-ses1-info-box {
        width: var(--box-width-mobile, 260px);
        padding: var(--box-padding-mobile, 18px);
        /* Keep left/right position, just smaller */
        transform: scale(var(--box-start-scale-mobile, 0.65));
    }
    
    .pretpot-ses1-info-box.position-right {
        right: var(--box-start-side-mobile, 3%);
        left: auto;
        top: var(--box-start-top-mobile, 5%);
    }
    
    .pretpot-ses1-info-box.position-left {
        left: var(--box-start-side-mobile, 3%);
        right: auto;
        top: var(--box-start-top-mobile, 5%);
    }
    
    .pretpot-ses1-image {
        max-width: 65%;
        max-height: 60vh;
    }
}

/* No border */
.pretpot-ses1-info-box.no-border {
    border: none;
}

/* Gradient */
.pretpot-ses1-info-box.has-gradient {
    background: var(--box-bg-gradient, linear-gradient(135deg, rgba(245,243,240,0.95), rgba(235,232,228,0.95)));
}