/* ==========================================================================
   Adise LMS — Shortcodes y páginas de curso
   Cubre: [alms_course_curriculum], [alms_enroll_button], [alms_student_dashboard]
   ========================================================================== */

/* -- Variables compartidas ------------------------------------------------ */
:root {
    --alms-primary:    #6366f1;
    --alms-primary-dk: #4f46e5;
    --alms-success:    #10b981;
    --alms-warning:    #f59e0b;
    --alms-danger:     #ef4444;
    --alms-muted:      #6b7280;
    --alms-border:     #e5e7eb;
    --alms-bg-light:   #f9fafb;
    --alms-radius:     6px;
}

/* ==========================================================================
   BOTÓN DE INSCRIPCIÓN [alms_enroll_button]
   ========================================================================== */

.alms-btn-enroll {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .75rem 2rem;
    border-radius: var(--alms-radius);
    font-size: 1rem;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
    transition: background .15s, transform .1s;
    border: 2px solid transparent;
}

.alms-btn-enroll--buy {
    background: var(--alms-primary);
    color: #fff;
    border-color: var(--alms-primary);
}
.alms-btn-enroll--buy:hover {
    background: var(--alms-primary-dk);
    color: #fff;
    transform: translateY(-1px);
}

.alms-btn-enroll--active {
    background: #f0fdf4;
    color: #15803d;
    border-color: #86efac;
}

.alms-btn-enroll--renew {
    background: #fff7ed;
    color: #c2410c;
    border-color: #fdba74;
}
.alms-btn-enroll--renew:hover {
    background: #ffedd5;
    color: #c2410c;
}

.alms-btn-enroll--login {
    background: var(--alms-bg-light);
    color: var(--alms-primary);
    border-color: var(--alms-primary);
}
.alms-btn-enroll--login:hover {
    background: #ede9fe;
    color: var(--alms-primary-dk);
}

/* ==========================================================================
   CURRICULUM [alms_course_curriculum]
   ========================================================================== */

.alms-curriculum {
    border: 1px solid var(--alms-border);
    border-radius: var(--alms-radius);
    overflow: hidden;
    margin: 1.5rem 0;
    font-size: .9375rem;
}

/* Barra de progreso */
.alms-curriculum__progreso {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
    background: var(--alms-bg-light);
    border-bottom: 1px solid var(--alms-border);
}

.alms-curriculum__progreso-barra-wrap {
    flex: 1;
    height: 8px;
    background: var(--alms-border);
    border-radius: 4px;
    overflow: hidden;
}

.alms-curriculum__progreso-barra {
    height: 100%;
    background: var(--alms-primary);
    border-radius: 4px;
    transition: width .4s ease;
}

.alms-curriculum__progreso-texto {
    font-size: .8125rem;
    color: var(--alms-muted);
    white-space: nowrap;
}

/* Sección */
.alms-curriculum__seccion {
    border-bottom: 1px solid var(--alms-border);
}
.alms-curriculum__seccion:last-child {
    border-bottom: none;
}

.alms-curriculum__seccion-titulo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0;
    padding: .875rem 1.25rem;
    font-size: .9375rem;
    font-weight: 700;
    background: var(--alms-bg-light);
    color: #111827;
    border-bottom: 1px solid var(--alms-border);
}

.alms-curriculum__seccion-count {
    font-size: .8125rem;
    font-weight: 400;
    color: var(--alms-muted);
}

/* Lista de ítems */
.alms-curriculum__lista {
    list-style: none;
    margin: 0;
    padding: 0;
}

.alms-curriculum__item {
    display: flex;
    align-items: center;
    gap: .625rem;
    padding: .75rem 1.25rem;
    border-bottom: 1px dashed var(--alms-border);
    transition: background .1s;
}
.alms-curriculum__item:last-child { border-bottom: none; }
.alms-curriculum__item:hover { background: #fafafa; }

.alms-curriculum__item--completado {
    color: var(--alms-muted);
}

.alms-curriculum__item-icono {
    font-size: .875rem;
    flex-shrink: 0;
    width: 20px;
    text-align: center;
}

.alms-curriculum__item-titulo {
    flex: 1;
    color: #374151;
    text-decoration: none;
}
.alms-curriculum__item-titulo:hover { color: var(--alms-primary); }

.alms-curriculum__item-titulo--bloqueado {
    color: var(--alms-muted);
}

.alms-curriculum__item-meta {
    flex-shrink: 0;
    font-size: .8125rem;
}

.alms-curriculum__item-check {
    color: var(--alms-success);
    font-weight: 700;
}

.alms-curriculum__item-preview {
    background: #ede9fe;
    color: var(--alms-primary);
    padding: .125rem .5rem;
    border-radius: 9999px;
    font-size: .75rem;
    font-weight: 600;
}

.alms-curriculum__item-lock {
    color: #9ca3af;
}

/* Mensaje vacío */
.alms-curriculum-vacio {
    padding: 2rem;
    text-align: center;
    color: var(--alms-muted);
}

/* ==========================================================================
   DASHBOARD DEL ALUMNO [alms_student_dashboard]
   ========================================================================== */

.alms-dashboard__titulo {
    font-size: 1.375rem;
    margin: 0 0 1.25rem;
    color: #111827;
}

.alms-dashboard__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.25rem;
}

/* Tarjeta de curso */
.alms-dashboard__tarjeta {
    border: 1px solid var(--alms-border);
    border-radius: var(--alms-radius);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: box-shadow .15s;
}
.alms-dashboard__tarjeta:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,.08);
}

.alms-dashboard__tarjeta--caducada {
    opacity: .75;
}

.alms-dashboard__tarjeta-imagen-link {
    display: block;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: var(--alms-border);
}

.alms-dashboard__tarjeta-imagen {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .25s;
}
.alms-dashboard__tarjeta:hover .alms-dashboard__tarjeta-imagen {
    transform: scale(1.03);
}

.alms-dashboard__tarjeta-body {
    padding: 1rem 1.25rem .75rem;
    flex: 1;
}

.alms-dashboard__tarjeta-titulo {
    font-size: 1rem;
    font-weight: 700;
    margin: 0 0 .75rem;
    line-height: 1.35;
}
.alms-dashboard__tarjeta-titulo a {
    color: #111827;
    text-decoration: none;
}
.alms-dashboard__tarjeta-titulo a:hover { color: var(--alms-primary); }

/* Barra de progreso en tarjeta */
.alms-dashboard__barra-wrap {
    height: 6px;
    background: var(--alms-border);
    border-radius: 3px;
    overflow: hidden;
    margin-bottom: .5rem;
}

.alms-dashboard__barra {
    height: 100%;
    background: var(--alms-primary);
    border-radius: 3px;
    transition: width .4s ease;
}

.alms-dashboard__porcentaje {
    font-size: .8125rem;
    color: var(--alms-muted);
    margin: 0;
}

.alms-dashboard__tarjeta-aviso {
    font-size: .875rem;
    color: var(--alms-danger);
    font-weight: 600;
    margin: 0;
}

.alms-dashboard__tarjeta-footer {
    padding: .75rem 1.25rem 1rem;
    border-top: 1px solid var(--alms-border);
}

/* Botones del dashboard */
.alms-btn--continuar,
.alms-btn--repasar,
.alms-btn--renew {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: .5rem 1rem;
    border-radius: var(--alms-radius);
    font-size: .875rem;
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    transition: background .15s;
}

.alms-btn--continuar {
    background: var(--alms-primary);
    color: #fff;
}
.alms-btn--continuar:hover { background: var(--alms-primary-dk); color: #fff; }

.alms-btn--repasar {
    background: var(--alms-bg-light);
    color: var(--alms-primary);
    border: 1px solid var(--alms-primary);
}
.alms-btn--repasar:hover { background: #ede9fe; }

.alms-btn--renew {
    background: #fff7ed;
    color: #c2410c;
    border: 1px solid #fdba74;
}
.alms-btn--renew:hover { background: #ffedd5; }

/* Sin cursos / sin sesión */
.alms-dashboard-vacio,
.alms-dashboard-sin-sesion {
    padding: 2rem;
    text-align: center;
    color: var(--alms-muted);
    border: 1px dashed var(--alms-border);
    border-radius: var(--alms-radius);
}

/* Responsive */
@media (max-width: 600px) {
    .alms-dashboard__grid {
        grid-template-columns: 1fr;
    }
}
