/* ============================================================
   Café do Mestre — Slider Widget
   ============================================================ */

.cafe-slider {
    position: relative;
    width: 100%;
    line-height: 0;
    overflow: hidden;
}

/* ── TRACK ───────────────────────────────────────────────── */
.cafe-slider__track {
    position: relative;
    width: 100%;
}

/* ── SLIDES: o primeiro fica no fluxo e define a altura ──── */
.cafe-slider__slide {
    position: absolute;
    top: 0; left: 0;
    width: 100%;
    opacity: 0;
    pointer-events: none;
    will-change: opacity, transform;
}

/* Slide "âncora" — fica no fluxo para definir a altura do track */
.cafe-slider__slide--anchor {
    position: relative !important;
    visibility: hidden; /* ocupa espaço mas não aparece */
    pointer-events: none;
    z-index: 0;
    opacity: 0 !important;
    transform: none !important;
}

.cafe-slider__slide.active {
    opacity: 1;
    pointer-events: auto;
    z-index: 2;
}

.cafe-slider__slide.prev {
    z-index: 1;
}

/* ── IMAGENS ─────────────────────────────────────────────── */
.cafe-slider__img {
    width: 100%;
    height: auto;
    display: block;
}

.cafe-slider__img--desktop { display: block; }
.cafe-slider__img--mobile  { display: none;  }

@media (max-width: 1024px) {
    .cafe-slider__img--desktop { display: none;  }
    .cafe-slider__img--mobile  { display: block; }
}

/* ── LINK OVERLAY ────────────────────────────────────────── */
.cafe-slider__link {
    position: absolute;
    inset: 0;
    z-index: 3;
}

/* ── VISIBILIDADE POR DISPOSITIVO ────────────────────────── */
@media (min-width: 1025px) {
    .cafe-slider__slide:not(.cafe-slide--show-desktop) { display: none !important; }
}
@media (min-width: 768px) and (max-width: 1024px) {
    .cafe-slider__slide:not(.cafe-slide--show-tablet)  { display: none !important; }
}
@media (max-width: 767px) {
    .cafe-slider__slide:not(.cafe-slide--show-mobile)  { display: none !important; }
}

/* ============================================================
   TRANSIÇÕES
   ============================================================ */

/* ── FADE ───────────────────────────────────────────────── */
.cafe-slider--fade .cafe-slider__slide {
    transition: opacity var(--cafe-slider-speed, 800ms) ease;
}
.cafe-slider--fade .cafe-slider__slide.active { opacity: 1; }

/* ── FADE + ZOOM ────────────────────────────────────────── */
.cafe-slider--fade-zoom .cafe-slider__slide {
    transform: scale(1.04);
    transition:
        opacity  var(--cafe-slider-speed, 800ms) cubic-bezier(0.4, 0, 0.2, 1),
        transform var(--cafe-slider-speed, 800ms) cubic-bezier(0.4, 0, 0.2, 1);
}
.cafe-slider--fade-zoom .cafe-slider__slide.active {
    opacity: 1;
    transform: scale(1);
}
.cafe-slider--fade-zoom .cafe-slider__slide.prev {
    opacity: 0;
    transform: scale(0.97);
}
/* âncora não deve sofrer transform */
.cafe-slider--fade-zoom .cafe-slider__slide--anchor {
    transform: none !important;
    transition: none !important;
}

/* ── SLIDE HORIZONTAL ───────────────────────────────────── */
.cafe-slider--slide .cafe-slider__track {
    display: flex;
    transition: transform var(--cafe-slider-speed, 800ms) cubic-bezier(0.77, 0, 0.175, 1);
}
.cafe-slider--slide .cafe-slider__slide {
    position: relative !important;
    flex-shrink: 0;
    width: 100%;
    opacity: 1 !important;
    transform: none !important;
    visibility: visible !important;
}
.cafe-slider--slide .cafe-slider__slide--anchor { display: none; }

/* ── KEN BURNS ──────────────────────────────────────────── */
.cafe-slider--kenburns .cafe-slider__slide {
    transition: opacity var(--cafe-slider-speed, 800ms) ease;
}
.cafe-slider--kenburns .cafe-slider__slide.active { opacity: 1; }
.cafe-slider--kenburns .cafe-slider__slide.active .cafe-slider__img {
    animation: cafe-kenburns var(--cafe-slider-autoplay, 5000ms) ease-out forwards;
}
@keyframes cafe-kenburns {
    0%   { transform: scale(1)    translate(0, 0); }
    100% { transform: scale(1.08) translate(-1%, -1%); }
}

/* ============================================================
   SETAS — reset total, só ícone
   ============================================================ */
.cafe-slider .cafe-slider__arrow {
    all: unset !important;
    box-sizing: border-box !important;
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 10 !important;
    width: 36px !important;
    height: 36px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    color: #fff !important;
    opacity: 0.8 !important;
    background: none !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    outline: none !important;
    box-shadow: none !important;
    filter: drop-shadow(0 1px 4px rgba(0,0,0,0.6)) !important;
    transition: opacity 0.2s ease !important;
}

.cafe-slider .cafe-slider__arrow--prev { left: 10px !important; }
.cafe-slider .cafe-slider__arrow--next { right: 10px !important; }

.cafe-slider .cafe-slider__arrow:hover {
    opacity: 1 !important;
    background: none !important;
    border: none !important;
    box-shadow: none !important;
}

.cafe-slider .cafe-slider__arrow svg {
    width: 26px !important;
    height: 26px !important;
    display: block !important;
    flex-shrink: 0 !important;
    pointer-events: none !important;
}

@media (max-width: 767px) {
    .cafe-slider .cafe-slider__arrow { width: 28px !important; height: 28px !important; }
    .cafe-slider .cafe-slider__arrow svg { width: 20px !important; height: 20px !important; }
    .cafe-slider .cafe-slider__arrow--prev { left: 5px !important; }
    .cafe-slider .cafe-slider__arrow--next { right: 5px !important; }
}

/* ============================================================
   DOTS
   ============================================================ */
.cafe-slider .cafe-slider__dots {
    all: unset !important;
    position: absolute !important;
    bottom: 14px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index: 10 !important;
    display: flex !important;
    gap: 7px !important;
    align-items: center !important;
}

.cafe-slider .cafe-slider__dot {
    all: unset !important;
    box-sizing: border-box !important;
    display: block !important;
    width: 8px !important;
    height: 8px !important;
    border-radius: 50% !important;
    background: rgba(0,0,0,0.35) !important;
    border: 2px solid rgba(255,255,255,0.8) !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
    transition: width 0.3s ease, border-radius 0.3s ease, background 0.3s ease !important;
}

.cafe-slider .cafe-slider__dot.active {
    background: #fff !important;
    width: 22px !important;
    border-radius: 4px !important;
    border-color: #fff !important;
}

@media (max-width: 767px) {
    .cafe-slider .cafe-slider__dots { bottom: 8px !important; gap: 5px; }
    .cafe-slider .cafe-slider__dot { width: 7px !important; height: 7px !important; }
    .cafe-slider .cafe-slider__dot.active { width: 16px !important; }
}

/* ── KEN BURNS extras ───────────────────────────────────── */
.cafe-slider--kenburns-out .cafe-slider__slide { transition: opacity var(--cafe-slider-speed, 800ms) ease; }
.cafe-slider--kenburns-out .cafe-slider__slide.active { opacity: 1; }
.cafe-slider--kenburns-out .cafe-slider__slide.active .cafe-slider__img {
    animation: cafe-kb-out var(--cafe-slider-autoplay, 5000ms) ease-out forwards;
}
@keyframes cafe-kb-out {
    0%   { transform: scale(1.08) translate(0, 0); }
    100% { transform: scale(1)    translate(0, 0); }
}

.cafe-slider--kenburns-left .cafe-slider__slide { transition: opacity var(--cafe-slider-speed, 800ms) ease; }
.cafe-slider--kenburns-left .cafe-slider__slide.active { opacity: 1; }
.cafe-slider--kenburns-left .cafe-slider__slide.active .cafe-slider__img {
    animation: cafe-kb-left var(--cafe-slider-autoplay, 5000ms) ease-out forwards;
}
@keyframes cafe-kb-left {
    0%   { transform: scale(1.06) translateX(0); }
    100% { transform: scale(1.06) translateX(-3%); }
}

.cafe-slider--kenburns-right .cafe-slider__slide { transition: opacity var(--cafe-slider-speed, 800ms) ease; }
.cafe-slider--kenburns-right .cafe-slider__slide.active { opacity: 1; }
.cafe-slider--kenburns-right .cafe-slider__slide.active .cafe-slider__img {
    animation: cafe-kb-right var(--cafe-slider-autoplay, 5000ms) ease-out forwards;
}
@keyframes cafe-kb-right {
    0%   { transform: scale(1.06) translateX(0); }
    100% { transform: scale(1.06) translateX(3%); }
}

.cafe-slider--kenburns-diag .cafe-slider__slide { transition: opacity var(--cafe-slider-speed, 800ms) ease; }
.cafe-slider--kenburns-diag .cafe-slider__slide.active { opacity: 1; }
.cafe-slider--kenburns-diag .cafe-slider__slide.active .cafe-slider__img {
    animation: cafe-kb-diag var(--cafe-slider-autoplay, 5000ms) ease-out forwards;
}
@keyframes cafe-kb-diag {
    0%   { transform: scale(1)    translate(0, 0); }
    100% { transform: scale(1.08) translate(-2%, -1.5%); }
}
