/* ==========================================================================
   COMPONENT: bkd-carousel (home dorama zone — Seoul Dusk)
   Carrossel horizontal pros blocos "no radar" e "recaps fresquinhos" da home.
   Mantém os cards .bkd-dorama-card intactos — só o container vira track de
   scroll. Mobile-first: arrasto + scroll-snap; setas só no desktop. Espelha o
   mecanismo de .bc-cat-section (front-page) com Alpine (atStart/atEnd).
   ========================================================================== */

.bkd-carousel {
    /* Isola o overflow do track pra nada vazar a largura da página. */
    min-width: 0;
}

/* --------------------------------------------------------------------------
   HEAD — título + controles (setas e link "todos os doramas →")
   -------------------------------------------------------------------------- */
.bkd-carousel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    margin-bottom: var(--space-5);
    flex-wrap: wrap;
}
.bkd-carousel__controls {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

/* --------------------------------------------------------------------------
   ARROWS — círculo gold-on-hover; some no mobile (arrasto resolve)
   -------------------------------------------------------------------------- */
.bkd-carousel__arrow {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-pill);
    background: var(--bg-surface-1);
    border: 1px solid var(--border-default);
    color: var(--text-primary);
    cursor: pointer;
    transition: transform var(--duration-fast) var(--ease-out),
                background var(--duration-fast) var(--ease-out),
                color var(--duration-fast) var(--ease-out),
                border-color var(--duration-fast) var(--ease-out);
}
.bkd-carousel__arrow:hover:not(:disabled) {
    background: var(--accent-primary);
    color: #fffcf8;
    border-color: var(--accent-primary);
    transform: translateY(-1px);
}
.bkd-carousel__arrow:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* --------------------------------------------------------------------------
   TRACK — scroll horizontal por arrasto, snap por item, sem barra feia
   -------------------------------------------------------------------------- */
.bkd-carousel__track {
    list-style: none;
    margin: 0;
    padding: 0 0 var(--space-2);
    display: flex;
    gap: var(--space-6);
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    /* esconde a barra de scroll em todos os engines */
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.bkd-carousel__track::-webkit-scrollbar {
    display: none;
}

/* Cada item: largura fixa que deixa "espiar" o próximo + snap no início. */
.bkd-carousel__track > .bkd-dorama-grid__item {
    flex: 0 0 auto;
    width: min(72vw, 230px);
    scroll-snap-align: start;
}

/* --------------------------------------------------------------------------
   DESKTOP — largura de card coerente e fixa
   -------------------------------------------------------------------------- */
@media (min-width: 768px) {
    .bkd-carousel__track > .bkd-dorama-grid__item {
        width: 200px;
    }
}

/* --------------------------------------------------------------------------
   MOBILE — sem setas (<768px); o arrasto resolve
   -------------------------------------------------------------------------- */
@media (max-width: 767px) {
    .bkd-carousel__arrow {
        display: none;
    }
}

/* --------------------------------------------------------------------------
   REDUCED MOTION — sem scroll suave forçado nas setas
   -------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    .bkd-carousel__track {
        scroll-behavior: auto;
    }
    .bkd-carousel__arrow {
        transition: none;
    }
    .bkd-carousel__arrow:hover:not(:disabled) {
        transform: none;
    }
}
