/* Canvas Frontend Styles */

.mgwpp-canvas-container, .mgwpp-canvas-slider {
    width: 100%;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
}

.mgwpp-slides-track {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.mgwpp-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
    pointer-events: none;
    z-index: 1;
}

.mgwpp-slide.active {
    opacity: 1;
    pointer-events: auto;
    z-index: 2;
}

.mgwpp-canvas-item {
    position: absolute;
    box-sizing: border-box;
}

/* Image Items */
.mgwpp-canvas-item-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.mgwpp-canvas-item-image a {
    display: block;
    width: 100%;
    height: 100%;
}

/* Text Items */
.mgwpp-canvas-item-text {
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.mgwpp-canvas-text {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
}

/* Button Items */
.mgwpp-canvas-item-button {
    width: 100%;
    height: 100%;
}

.mgwpp-canvas-button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    text-decoration: none;
    font-weight: 500;
    text-align: center;
    cursor: pointer;
    transition: opacity 0.2s, transform 0.2s;
}

.mgwpp-canvas-button:hover {
    opacity: 0.9;
    transform: scale(1.02);
}

/* Shape Items */
.mgwpp-canvas-item-shape {
    width: 100%;
    height: 100%;
}

.mgwpp-canvas-shape {
    width: 100%;
    height: 100%;
}

/* Navigation - Arrows */
.mgwpp-slider-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    background: rgba(0,0,0,0.5);
    color: #fff;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    z-index: 10;
    font-size: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.3s;
}
.mgwpp-slider-arrow:hover {
    background: rgba(0,0,0,0.8);
}
.mgwpp-slider-arrow.prev { left: 10px; }
.mgwpp-slider-arrow.next { right: 10px; }

/* Navigation - Dots */
.mgwpp-slider-dots {
    position: absolute;
    bottom: 15px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 10;
}
.mgwpp-slider-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255,255,255,0.5);
    border: none;
    cursor: pointer;
    padding: 0;
    transition: background 0.3s;
}
.mgwpp-slider-dot.active {
    background: #fff;
    transform: scale(1.2);
}

/* -----------------------------------------------------------
   ANIMATION EFFECTS
   ----------------------------------------------------------- */

/* Base Slide Setup */
.mgwpp-slides-track {
    perspective: 1000px; /* Needed for 3D effects */
    transform-style: preserve-3d;
}

.mgwpp-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    visibility: hidden;
    transition: all 0.5s ease-in-out;
    backface-visibility: hidden; /* Hide back for 3D */
    transform-origin: center center;
    z-index: 1;
}

.mgwpp-slide.active {
    opacity: 1;
    visibility: visible;
    z-index: 10;
    transform: none;
}

/* === EFFECT: FADE (Default) === */
.mgwpp-effect-fade .mgwpp-slide {
    transform: none !important; /* No movement */
    transition: opacity 0.6s ease;
}

/* === EFFECT: SLIDE === */
/* We need 'next' and 'prev' logic from JS to make this true 'sliding' */
/* For now, we simulate a simple push logic if JS handles classes correctly */

.mgwpp-effect-slide .mgwpp-slide.prev-slide {
    transform: translateX(-100%);
    opacity: 1;
    visibility: visible;
}
.mgwpp-effect-slide .mgwpp-slide.next-slide {
    transform: translateX(100%);
    opacity: 1;
    visibility: visible;
}
.mgwpp-effect-slide .mgwpp-slide.active {
    transform: translateX(0);
}

/* === EFFECT: CUBE === */
.mgwpp-effect-cube .mgwpp-slides-track {
    overflow: visible; /* Allow 3D overflow */
    perspective: 1500px;
}
.mgwpp-effect-cube .mgwpp-slide {
    transition: transform 0.8s ease, opacity 0.8s ease;
    backface-visibility: hidden;
    opacity: 0;
}
.mgwpp-effect-cube .mgwpp-slide.active {
    transform: rotateY(0deg) translateZ(0); 
    opacity: 1;
    visibility: visible;
    z-index: 10;
}
.mgwpp-effect-cube .mgwpp-slide.prev-slide {
    transform: rotateY(-90deg) translateZ(200px); /* Pushed back and rotated */
    opacity: 1; /* Keep visible during turn */
    visibility: visible;
    transform-origin: center right; /* Anchor to right edge for prev */
}
.mgwpp-effect-cube .mgwpp-slide.next-slide {
    transform: rotateY(90deg) translateZ(200px);
    opacity: 1;
    visibility: visible;
    transform-origin: center left;
}

/* === EFFECT: COVERFLOW === */
.mgwpp-effect-coverflow .mgwpp-slide {
    transition: all 0.6s ease;
}
.mgwpp-effect-coverflow .mgwpp-slide.active {
    transform: rotateY(0deg) scale(1);
    opacity: 1;
    z-index: 10;
}
.mgwpp-effect-coverflow .mgwpp-slide.prev-slide {
    transform: rotateY(45deg) scale(0.8) translateX(-50%);
    opacity: 0.5;
    z-index: 5;
    visibility: visible; /* Visible but faded */
}
.mgwpp-effect-coverflow .mgwpp-slide.next-slide {
    transform: rotateY(-45deg) scale(0.8) translateX(50%);
    opacity: 0.5;
    z-index: 5;
    visibility: visible;
}


/* Responsive Handling */
@media (max-width: 768px) {
    .mgwpp-canvas-container, .mgwpp-canvas-slider {
        max-width: 100% !important;
    }
    
    .mgwpp-canvas-text {
        font-size: 0.8em !important;
    }
}
