/* ── Slider shell ── */
.prog-slider {
    position: relative;
}

.prog-slider__viewport {
    overflow: hidden;
}

.prog-slider__track {
    display: flex;
    gap: 1.25rem;
    align-items: stretch;
    transition: transform 0.38s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: transform;
}

/* ── Controls — below track, right-aligned (matches video carousel) ── */
.prog-slider__controls {
    display: flex;
    justify-content: flex-end;
    gap: 16px;
    padding: 16px 0 10px;
}

.prog-slider__prev,
.prog-slider__next {
    width: 48px;
    height: 48px;
    padding: 0;
    border-radius: 999px;
    border: 1px solid var(--global-palette3, #dc6614);
    background: transparent;
    color: var(--global-palette3, #dc6614);
    display: grid;
    place-items: center;
    cursor: pointer;
    transition: opacity 140ms ease;
    flex-shrink: 0;
}

.prog-slider__prev svg,
.prog-slider__next svg {
    display: block;
    width: 24px;
    height: 24px;
}

.prog-slider__prev:hover,
.prog-slider__next:hover { opacity: 0.7; }

.prog-slider__prev:disabled,
.prog-slider__next:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

/* ── Card — #ebeef0 background, all padding inside, whole card is the link ── */
.prog-card {
    flex: 0 0 auto; /* width set by JS */
    min-width: 0;
    display: flex;
    flex-direction: column;
    background: #ebeef0;
    border-radius: 1.5rem;
    padding: 0;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: box-shadow 200ms ease, transform 200ms ease;
}

.prog-card:hover {
    transform: translateY(-3px);
}

/* ── Featured image — fills card top, flat bottom ── */
.prog-card__img {
    width: 100%;
    aspect-ratio: 3 / 2;
    background-image: var(--prog-img);
    background-size: cover;
    background-position: center;
    background-color: #c8cdd1;
    border-radius: 1.5rem 1.5rem 0 0;
    flex-shrink: 0;
}

/* ── Icon fallback (no featured image) ── */
.prog-card__icon-wrap {
    display: flex;
    align-items: center;
    padding: 1.1rem 1.1rem 0;
}

.prog-card__icon { display: block; color: var(--global-palette10, #3182CE); }
.prog-card__icon svg { width: 28px; height: 28px; display: block; }

/* ── Card body ── */
.prog-card__body {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    gap: 0.45rem;
    padding: 1rem 1.1rem 1.1rem;
}

.prog-card__title {
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.2;
    margin: 0;
    color: inherit;
}

.prog-card__sub {
    font-size: 0.92rem;
    margin: 0;
    color: inherit;
    opacity: 0.72;
    line-height: 1.45;
}

.prog-card__excerpt {
    font-size: 0.9rem;
    margin: 0;
    opacity: 0.65;
    line-height: 1.5;
}
