.cdl-figure-card--no-video .cdl-figure-card__thumb-wrap--no-video,
.cdl-figure-card__thumb-wrap--fallback {
position: relative;
display: block;
aspect-ratio: 16 / 9;
border-radius: var(--cdl-radius-md, 10px);
overflow: hidden;
background: linear-gradient(145deg, #f4f0eb 0%, #e8e2da 100%);
}
.cdl-figure-card__no-video-art {
display: block;
width: 100%;
height: 100%;
min-height: 120px;
background:
radial-gradient(circle at 30% 40%, rgba(120, 80, 160, 0.12), transparent 55%),
radial-gradient(circle at 70% 60%, rgba(40, 120, 140, 0.1), transparent 50%);
}
.cdl-figure-card__thumb-wrap--style-salsa .cdl-figure-card__no-video-art {
background-color: #f9efe8;
background-image: radial-gradient(circle at 50% 30%, rgba(200, 90, 50, 0.15), transparent 60%);
}
.cdl-figure-card__thumb-wrap--style-bachata .cdl-figure-card__no-video-art {
background-color: #f5eef5;
background-image: radial-gradient(circle at 50% 30%, rgba(140, 60, 120, 0.12), transparent 60%);
}
.cdl-figure-card__thumb-wrap--style-kizomba .cdl-figure-card__no-video-art,
.cdl-figure-card__thumb-wrap--style-urban-kiz .cdl-figure-card__no-video-art {
background-color: #eeeef5;
background-image: radial-gradient(circle at 50% 30%, rgba(60, 70, 140, 0.12), transparent 60%);
}
.cdl-figure-card__thumb-wrap--style-afro-cubain .cdl-figure-card__no-video-art {
background: linear-gradient(145deg, #1a0a0a 0%, #6b1f1f 45%, #c9a227 100%);
}
.cdl-figure-card__thumb-wrap--style-son-cubano .cdl-figure-card__no-video-art {
background-color: #f5ebe0;
background-image: radial-gradient(circle at 50% 30%, rgba(192, 57, 43, 0.14), transparent 60%);
}
.cdl-figure-card__thumb-wrap--style-merengue .cdl-figure-card__no-video-art {
background: linear-gradient(145deg, #0d4f4f 0%, #1db7b7 42%, #f5c542 100%);
}
.cdl-figure-card__badge--preparing,
.cdl-figure-card__badge--video-ready {
background: rgba(255, 255, 255, 0.92);
color: #3d3a36;
font-size: 0.72rem;
font-weight: 600;
letter-spacing: 0.02em;
}
.cdl-figure-card--no-video .cdl-figure-card__play,
.cdl-figure-card__thumb-wrap--fallback .cdl-figure-card__play {
display: none !important;
}
.cdl-figure-card__suggest-wrap {
margin: 0.35rem 0.75rem 0.65rem;
padding: 0;
}
.cdl-figure-card__suggest {
font-size: 0.8rem;
color: var(--cdl-accent, #6b4c9a);
text-decoration: underline;
text-underline-offset: 2px;
}
.cdl-figure-card--premium-locked .cdl-figure-card__thumb-wrap--no-video .cdl-figure-card__lock,
.cdl-figure-card--premium-locked .cdl-figure-card__thumb-wrap--fallback .cdl-figure-card__lock {
display: block;
} .cdl-figure-card--v5 {
transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.cdl-figure-card--v5:hover {
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}
.cdl-figure-card--v5 .cdl-figure-card__title {
font-weight: 600;
line-height: 1.3;
}
.cdl-figure-card--v5 .cdl-figure-card__tag--level {
font-weight: 600;
} .cdl-modal--v5 .cdl-modal__pedagogy {
display: grid;
gap: 1rem;
margin: 1rem 0;
}
.cdl-modal__relation-list {
list-style: none;
margin: 0;
padding: 0;
display: grid;
gap: 0.5rem;
}
.cdl-modal__relation-item {
display: flex;
flex-wrap: wrap;
align-items: baseline;
gap: 0.35rem 0.75rem;
padding: 0.5rem 0.65rem;
border-radius: 8px;
background: #f8f6f3;
}
.cdl-modal__relation-item.is-locked {
opacity: 0.85;
}
.cdl-modal__relation-link {
font-weight: 600;
color: var(--cdl-accent, #6b4c9a);
}
.cdl-modal__relation-reason {
font-size: 0.78rem;
color: #6b6560;
}
.cdl-modal__section--locked .cdl-modal__locked-teaser {
padding: 0.75rem;
border-radius: 8px;
background: #faf8f5;
border: 1px dashed #d8d2ca;
} .cdl-learning-dashboard--v5 .button:not(.cdl-btn),
.cdl-playlists--v5 .button:not(.cdl-btn) {
display: inline-flex;
align-items: center;
padding: 0.5rem 1rem;
border-radius: 8px;
border: 1px solid #d8d2ca;
background: #fff;
color: #2a2622;
font: inherit;
cursor: pointer;
text-decoration: none;
}
.cdl-learning-dashboard__overview {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 1rem;
margin-bottom: 1.5rem;
}
.cdl-learning-overview-card {
padding: 1rem 1.15rem;
border-radius: 12px;
background: linear-gradient(135deg, #faf8f5 0%, #f0ebe4 100%);
border: 1px solid #e8e2da;
}
.cdl-learning-overview-card__label {
display: block;
font-size: 0.78rem;
text-transform: uppercase;
letter-spacing: 0.06em;
color: #6b6560;
margin-bottom: 0.25rem;
}
.cdl-learning-overview-card__value {
font-size: 1.75rem;
font-weight: 700;
color: #2a2622;
line-height: 1.1;
}
.cdl-learning-overview-card__meta {
margin: 0.5rem 0 0;
font-size: 0.85rem;
color: #5c5650;
}
.cdl-learning-style-progress {
list-style: none;
margin: 0;
padding: 0;
display: grid;
gap: 0.75rem;
}
.cdl-learning-style-progress li {
display: grid;
grid-template-columns: 1fr auto;
grid-template-rows: auto auto;
gap: 0.25rem 0.75rem;
align-items: center;
}
.cdl-learning-style-progress__name {
font-weight: 600;
}
.cdl-learning-style-progress__pct {
font-size: 0.85rem;
color: #6b6560;
}
.cdl-learning-style-progress .cdl-learning-progress-bar {
grid-column: 1 / -1;
}
.cdl-learning-dashboard__hint,
.cdl-empty-state__hint {
font-size: 0.9rem;
color: #6b6560;
margin-top: 0.35rem;
} .cdl-playlist-hints {
margin-bottom: 1rem;
}
.cdl-playlist-hint {
margin: 0 0 0.65rem;
padding: 0.65rem 0.85rem;
border-radius: 10px;
background: #f8f6f3;
border: 1px solid #ebe6df;
}
.cdl-playlist-hint__label {
display: block;
font-size: 0.75rem;
text-transform: uppercase;
letter-spacing: 0.05em;
color: #6b6560;
margin-bottom: 0.35rem;
}
.cdl-playlist-row--v5 {
display: grid;
grid-template-columns: 88px 1fr auto;
gap: 0.85rem;
align-items: center;
padding: 0.85rem;
border-radius: 10px;
border: 1px solid #ebe6df;
margin-bottom: 0.65rem;
}
.cdl-playlist-row__thumb {
display: block;
border-radius: 6px;
overflow: hidden;
aspect-ratio: 16 / 9;
background: #eeeae4;
}
.cdl-playlist-row__thumb img {
width: 100%;
height: 100%;
object-fit: cover;
}
.cdl-playlist-row__thumb--empty {
min-height: 50px;
background: linear-gradient(135deg, #f0ebe4, #e4ddd4);
}
.cdl-btn--small {
padding: 0.35rem 0.75rem;
font-size: 0.82rem;
}
.cdl-empty-state {
padding: 1.25rem;
text-align: center;
border-radius: 10px;
background: #faf8f5;
} .cdl-btn:focus-visible,
.cdl-figure-card__link:focus-visible,
.cdl-modal__relation-link:focus-visible,
.cdl-learning-suggest-open:focus-visible {
outline: 2px solid var(--cdl-accent, #6b4c9a);
outline-offset: 2px;
}
@media (max-width: 640px) {
.cdl-playlist-row--v5 {
grid-template-columns: 72px 1fr;
}
.cdl-playlist-row__actions {
grid-column: 1 / -1;
display: flex;
flex-wrap: wrap;
gap: 0.35rem;
}
.cdl-smart-path__hub-cards {
grid-template-columns: 1fr;
}
.cdl-smart-path__step {
grid-template-columns: 2rem 1fr;
}
} .cdl-smart-path {
margin: 1.5rem 0;
padding: 1.25rem 0;
border-top: 1px solid rgba(0, 0, 0, 0.08);
}
.cdl-smart-path__title {
font-size: 1.25rem;
margin: 0 0 0.5rem;
color: var(--cdl-blue, #1e3a5f);
}
.cdl-smart-path__title--single {
font-size: 1.1rem;
}
.cdl-smart-path__lead,
.cdl-smart-path__path-desc,
.cdl-smart-path__guest-note,
.cdl-smart-path__relations-note {
font-size: 0.92rem;
color: #555;
margin: 0 0 0.75rem;
line-height: 1.45;
}
.cdl-smart-path__hub-cards {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
gap: 0.75rem;
margin: 1rem 0 1.5rem;
}
.cdl-smart-path__hub-card {
display: flex;
flex-direction: column;
gap: 0.35rem;
padding: 1rem 1.1rem;
border-radius: 12px;
border: 1px solid var(--cdl-blue-border, #d4e4f4);
background: linear-gradient(145deg, #f8fbff 0%, #fff 100%);
text-decoration: none;
color: inherit;
transition: box-shadow 0.15s ease, transform 0.15s ease;
}
.cdl-smart-path__hub-card:hover {
box-shadow: 0 6px 18px rgba(30, 58, 95, 0.1);
transform: translateY(-1px);
}
.cdl-smart-path__hub-card-title {
font-weight: 700;
font-size: 1rem;
color: var(--cdl-blue, #1e3a5f);
}
.cdl-smart-path__hub-card-desc {
font-size: 0.85rem;
color: #555;
flex: 1;
}
.cdl-smart-path__hub-card-cta {
font-size: 0.82rem;
font-weight: 600;
color: var(--cdl-accent, #6b4c9a);
}
.cdl-smart-path__preset {
margin-bottom: 1.5rem;
padding-bottom: 1rem;
border-bottom: 1px dashed rgba(0, 0, 0, 0.08);
}
.cdl-smart-path__preset:last-child {
border-bottom: 0;
}
.cdl-smart-path__path-title {
font-size: 1.05rem;
margin: 0 0 0.35rem;
}
.cdl-smart-path__user-note {
font-size: 0.82rem;
color: var(--cdl-accent, #6b4c9a);
margin: 0 0 0.75rem;
}
.cdl-smart-path__steps {
list-style: none;
margin: 0;
padding: 0;
display: grid;
gap: 0.5rem;
}
.cdl-smart-path__step {
display: grid;
grid-template-columns: 2.25rem 1fr;
gap: 0.65rem;
align-items: start;
padding: 0.65rem 0.75rem;
border-radius: 10px;
background: #faf8f5;
border: 1px solid rgba(0, 0, 0, 0.05);
}
.cdl-smart-path__step-num {
display: flex;
align-items: center;
justify-content: center;
width: 2.25rem;
height: 2.25rem;
border-radius: 50%;
background: var(--cdl-accent, #6b4c9a);
color: #fff;
font-weight: 700;
font-size: 0.85rem;
}
.cdl-smart-path__step-link {
font-weight: 600;
color: var(--cdl-blue, #1e3a5f);
text-decoration: none;
}
.cdl-smart-path__step-link:hover {
text-decoration: underline;
}
.cdl-smart-path__step-badges {
display: flex;
flex-wrap: wrap;
gap: 0.3rem;
margin-top: 0.25rem;
}
.cdl-smart-path__badge {
display: inline-block;
font-size: 0.72rem;
padding: 0.12rem 0.45rem;
border-radius: 999px;
background: #eee;
color: #444;
}
.cdl-smart-path__badge--level {
background: #e8f0fe;
color: #1e3a5f;
}
.cdl-smart-path__badge--family {
background: #f3eef9;
color: #5a4080;
}
.cdl-smart-path__badge--video {
background: #e6f6ed;
color: #1e7e34;
}
.cdl-smart-path__badge--state-mastered {
background: #d4edda;
color: #155724;
}
.cdl-smart-path__badge--state-seen {
background: #fff3cd;
color: #856404;
}
.cdl-smart-path__badge--state-practice {
background: #fde8f0;
color: #9b2c5a;
}
.cdl-smart-path__badge--state-new {
background: #e8f4fd;
color: #0c5460;
}
.cdl-smart-path__explore,
.cdl-smart-path__single-footer {
margin: 0.75rem 0 0;
font-size: 0.88rem;
}
.cdl-smart-path__explore-link {
color: var(--cdl-accent, #6b4c9a);
font-weight: 600;
}
.cdl-smart-path__subtitle {
font-size: 0.95rem;
margin: 0.75rem 0 0.5rem;
}
.cdl-smart-path__current-state {
font-size: 0.9rem;
margin: 0 0 0.5rem;
}
.cdl-smart-path__empty {
font-style: italic;
color: #666;
}
.cdl-smart-path__progress-summary {
margin: 0.75rem 0 1rem;
padding: 0.75rem 0.85rem;
background: var(--cdl-surface-muted, #f7f8fa);
border: 1px solid var(--cdl-border, #e4e8ee);
border-radius: 8px;
}
.cdl-smart-path__progress-text {
margin: 0 0 0.45rem;
font-size: 0.92rem;
}
.cdl-smart-path__progress-pct {
margin: 0.35rem 0 0;
font-size: 0.82rem;
color: var(--cdl-text-muted, #666);
}