/* ============================================================
   A Project Manager — Slider
   ============================================================ */

.apm-slider-wrap {
    position: relative;
    --apm-sl-gap: 10px;
}

/* ── Viewport clips the track ── */
.apm-slider-viewport {
    overflow: hidden;
    width: 100%;
}

/* ── Track: flex row, moves via translateX ── */
.apm-slider-track {
    display: flex;
    transition: transform 0.28s ease-out;
    will-change: transform;
}

/* ── Each slide ── */
.apm-slide {
    flex: 0 0 calc(100% / var(--apm-sl-cols, 3));
    padding: 0 calc(var(--apm-sl-gap) / 2);
    box-sizing: border-box;
    height: 420px;
}
/* First / last slide: remove outer padding to align with container edge */
.apm-slide:first-child { padding-left: 0; }
.apm-slide:last-child  { padding-right: 0; }

/* Item fills slide */
.apm-slide .apm-item {
    height: 100% !important;
    width: 100%;
    display: block;
}
.apm-slide .apm-cover {
    width: 100% !important;
    height: 100% !important;
}
.apm-slide .apm-cover-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
}
.apm-slide .apm-ba       { width: 100%; height: 100%; }
.apm-slide .apm-ba-after,
.apm-slide .apm-ba-before { width: 100%; height: 100%; object-fit: cover; }

/* ================================================================
   NATURAL MODE — chiều cao cố định, chiều ngang theo tỉ lệ ảnh
   ================================================================ */
.apm-slider-wrap.apm-sl-natural .apm-slide {
    /* JS set flex: 0 0 totalW — CSS chỉ cần bỏ flex cứng */
    flex: 0 0 auto;
    /* height được Elementor set inline: height:{{SIZE}}px — không override */
}
.apm-slider-wrap.apm-sl-natural .apm-slide .apm-item,
.apm-slider-wrap.apm-sl-natural .apm-slide .apm-cover {
    width: 100% !important;
    height: 100% !important;
}
.apm-slider-wrap.apm-sl-natural .apm-slide .apm-cover-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

/* ── Navigation arrows — dùng !important để override Elementor/theme ── */
button.apm-sl-prev,
button.apm-sl-next {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 10 !important;
    background: #ffffff !important;
    background-color: #ffffff !important;
    background-image: none !important;
    width: 44px !important;
    height: 44px !important;
    min-width: unset !important;
    min-height: unset !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    box-shadow: 0 2px 14px rgba(0,0,0,0.18) !important;
    color: #111111 !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    outline: none !important;
    text-decoration: none !important;
    transition: background 0.18s, color 0.18s, opacity 0.2s !important;
    line-height: 1 !important;
    font-size: inherit !important;
}
button.apm-sl-prev { left: 12px !important; }
button.apm-sl-next { right: 12px !important; }
button.apm-sl-prev:hover,
button.apm-sl-next:hover {
    background: #111111 !important;
    background-color: #111111 !important;
    color: #ffffff !important;
}
button.apm-sl-prev[disabled],
button.apm-sl-next[disabled] { opacity: 0.28 !important; pointer-events: none !important; }

/* ── Dots ── */
.apm-sl-dots {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 8px !important;
    margin-top: 14px !important;
    padding: 0 !important;
    list-style: none !important;
}
button.apm-sl-dot {
    display: block !important;
    width: 7px !important;
    height: 7px !important;
    min-width: unset !important;
    min-height: unset !important;
    border-radius: 50% !important;
    background: rgba(0,0,0,0.2) !important;
    background-color: rgba(0,0,0,0.2) !important;
    background-image: none !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    cursor: pointer !important;
    transition: background 0.2s, transform 0.2s !important;
    flex-shrink: 0 !important;
    box-shadow: none !important;
}
button.apm-sl-dot.active {
    background: #111111 !important;
    background-color: #111111 !important;
    transform: scale(1.4) !important;
}
button.apm-sl-dot:hover:not(.active) {
    background: rgba(0,0,0,0.45) !important;
    background-color: rgba(0,0,0,0.45) !important;
}

/* ── Responsive: swap CSS vars for slide width ── */
@media (max-width: 1024px) {
    .apm-slide { flex: 0 0 calc(100% / var(--apm-sl-cols-tablet, 1)); }
}

@media (max-width: 767px) {
    .apm-slide { flex: 0 0 calc(100% / var(--apm-sl-cols-mobile, 1)); }
    .apm-sl-prev { left: 6px; }
    .apm-sl-next { right: 6px; }

    /* ── Peek: chỉ hiện phần slide kế bên ở BÊN PHẢI ── */
    .apm-slider-wrap {
        overflow: hidden;
    }
    .apm-slider-viewport {
        overflow: visible;
        padding-right: var(--apm-sl-peek, 0px); /* chỉ peek phải, không peek trái */
        padding-left: 0;
    }
    /* Giữ nguyên padding-left: 0 cho slide đầu (không tạo khoảng trắng trái) */
    .apm-slide:first-child { padding-left: 0; }
    .apm-slide:last-child  { padding-right: calc(var(--apm-sl-gap) / 2); }
}
