/* ── Scroll Snap ──────────────────────────────────────────── */
.wpmd-scroll-snap {
    position: relative;
    width: 100%;
}

/* Full-width support */
.wpmd-scroll-snap.alignfull {
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    max-width: 100vw !important;
    width: 100vw !important;
}

/* ── Sticky wrapper — pinned to viewport ─────────────────── */
.wpmd-ss-sticky {
    position: sticky;
    top: 0;
    height: 100vh;
    overflow: hidden;
    width: 100%;
}

/* ── Track — translates vertically ───────────────────────── */
.wpmd-ss-track {
    display: flex;
    flex-direction: column;
    will-change: transform;
}

/* ── Panels — always 100vh ───────────────────────────────── */
.wpmd-ss-panel {
    position: relative;
    flex: 0 0 100vh;
    min-height: 100vh;
    box-sizing: border-box;
    overflow: hidden;
    margin: 0 !important;
    padding: 0;
}

/* ── Slide-over mode: panels stacked, each slides over previous ── */
.wpmd-ss--slideover .wpmd-ss-track {
    position: relative;
    height: 100vh !important;
}
.wpmd-ss--slideover .wpmd-ss-panel {
    position: absolute !important;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    will-change: transform;
}

/* ── Dots Navigation ─────────────────────────────────────── */
.wpmd-ss-dots {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 10px;
    z-index: 100;
    pointer-events: auto;
}
.wpmd-ss-dots--right { right: 20px; }
.wpmd-ss-dots--left  { left: 20px;  }

.wpmd-ss-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 2px solid var(--wpmd-ss-dot, #fff);
    background: transparent;
    cursor: pointer;
    padding: 0;
    transition: background 0.3s ease, transform 0.3s ease, border-color 0.3s ease;
}
.wpmd-ss-dot:hover {
    transform: scale(1.3);
}
.wpmd-ss-dot.is-active {
    background: var(--wpmd-ss-dot-active, #6B5FE8);
    border-color: var(--wpmd-ss-dot-active, #6B5FE8);
    transform: scale(1.2);
}

/* ── Overlay ─────────────────────────────────────────────── */
.wpmd-ss-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
}
.wpmd-ss-content {
    position: relative;
    z-index: 1;
}
