/* ══════════════════════════════════════════════════════════════════════════
   JADICC LMS — Frontend Stylesheet
   Scoped under .lms-wrap to avoid theme conflicts
   ══════════════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ── Variables ─────────────────────────────────────────────────────────── */
:root {
    --lf-accent:       #0369a1;
    --lf-accent-dark:  #075985;
    --lf-accent-soft:  rgba(3,105,161,0.08);
    --lf-bg:           #f7f8fa;
    --lf-white:        #ffffff;
    --lf-border:       #e2e5ea;
    --lf-text:         #0f172a;
    --lf-muted:        #64748b;
    --lf-success:      #16a34a;
    --lf-success-bg:   #f0fdf4;
    --lf-danger:       #dc2626;
    --lf-danger-bg:    #fef2f2;
    --lf-warning:      #d97706;
    --lf-radius:       12px;
    --lf-radius-sm:    8px;
    --lf-shadow:       0 1px 3px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.05);
    --lf-shadow-lg:    0 8px 32px rgba(0,0,0,0.10);
    --lf-font:         'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --lf-transition:   all 0.18s ease;
}

/* ── Base wrap ─────────────────────────────────────────────────────────── */
/* Player page — full viewport (bare HTML template, no theme wrapper) */
.lms-wrap.lms-player-wrap {
    padding: 0 !important;
    max-width: 100vw !important;
    width: 100% !important;
    margin: 0 !important;
}

.lms-wrap {
    font-family: var(--lf-font);
    color: var(--lf-text);
    width: 100%;
    padding: 40px 32px;
    line-height: 1.6;
    font-size: 15px;
}

.lms-wrap * { box-sizing: border-box; }

/* ── Buttons ───────────────────────────────────────────────────────────── */
.lms-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 11px 22px;
    border-radius: var(--lf-radius-sm);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--lf-transition);
    border: 2px solid transparent;
    text-decoration: none !important;
    font-family: var(--lf-font);
    white-space: nowrap;
    line-height: 1;
}
.lms-btn-primary {
    background: var(--lf-accent);
    color: #fff !important;
    border-color: var(--lf-accent);
}
.lms-btn-primary:hover {
    background: var(--lf-accent-dark);
    border-color: var(--lf-accent-dark);
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(99,102,241,0.35);
}
.lms-btn-outline {
    background: transparent;
    color: var(--lf-accent) !important;
    border-color: var(--lf-accent);
}
.lms-btn-outline:hover {
    background: var(--lf-accent-soft);
    color: var(--lf-accent) !important;
}
.lms-btn-full  { width: 100%; }
.lms-btn-sm    { padding: 7px 14px; font-size: 13px; }
.lms-btn:disabled { opacity: 0.55; cursor: not-allowed; transform: none !important; }

/* ── Badges ────────────────────────────────────────────────────────────── */
.lms-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 100px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.lms-badge-green  { background: #dcfce7; color: #15803d; }
.lms-badge-blue   { background: #dbeafe; color: #1d4ed8; }
.lms-badge-red    { background: #fee2e2; color: #b91c1c; }
.lms-badge-gray   { background: #f3f4f6; color: #6b7280; }

/* ── Alerts ────────────────────────────────────────────────────────────── */
.lms-alert {
    padding: 14px 18px;
    border-radius: var(--lf-radius-sm);
    font-size: 14px;
    margin-bottom: 20px;
    font-weight: 500;
}
.lms-alert-error   { background: var(--lf-danger-bg);  color: var(--lf-danger);  border: 1px solid #fca5a5; }
.lms-alert-success { background: var(--lf-success-bg); color: var(--lf-success); border: 1px solid #86efac; }

/* ── Form ──────────────────────────────────────────────────────────────── */
.lms-form { display: flex; flex-direction: column; gap: 18px; }
.lms-field { display: flex; flex-direction: column; gap: 6px; }
.lms-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.lms-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--lf-text);
}
.lms-required { color: var(--lf-danger); }
.lms-wrap input[type="text"],
.lms-wrap input[type="email"],
.lms-wrap input[type="password"],
.lms-wrap textarea,
.lms-wrap select {
    padding: 11px 14px;
    border: 1.5px solid var(--lf-border);
    border-radius: var(--lf-radius-sm);
    font-size: 14px;
    font-family: var(--lf-font);
    color: var(--lf-text);
    background: var(--lf-white);
    transition: var(--lf-transition);
    width: 100%;
    outline: none;
    box-shadow: none;
}
.lms-wrap input:focus,
.lms-wrap textarea:focus {
    border-color: var(--lf-accent);
    box-shadow: 0 0 0 3px var(--lf-accent-soft);
}

.lms-input-wrap { position: relative; }
.lms-input-wrap input { padding-right: 44px; }
.lms-pw-toggle {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    font-size: 16px;
    padding: 0;
    line-height: 1;
    opacity: 0.6;
}
.lms-pw-toggle:hover { opacity: 1; }

/* ══════════════════════════════════════════════════════════════════════════
   AUTH PAGES (Login / Register)
   ══════════════════════════════════════════════════════════════════════════ */
.lms-auth-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 60vh;
    padding: 40px 24px;
    width: 100%;
}

.lms-auth-box {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 44px 40px;
    width: 100%;
    max-width: 440px;
    box-shadow: var(--lf-shadow-lg);
}

.lms-auth-logo {
    width: 52px; height: 52px;
    background: var(--lf-accent);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    margin: 0 auto 24px;
}

.lms-auth-title {
    font-size: 24px !important;
    font-weight: 800 !important;
    color: var(--lf-text) !important;
    text-align: center;
    margin: 0 0 6px !important;
    border: none !important;
}
.lms-auth-sub {
    font-size: 14px;
    color: var(--lf-muted);
    text-align: center;
    margin: 0 0 28px;
}
.lms-auth-footer {
    text-align: center;
    font-size: 13px;
    color: var(--lf-muted);
    margin: 16px 0 0;
}
.lms-auth-footer a { color: var(--lf-accent); font-weight: 600; }

/* Checkout success */
.lms-success-box { text-align: center; }
.lms-success-icon { font-size: 56px; margin-bottom: 20px; }

/* ══════════════════════════════════════════════════════════════════════════
   COURSE CATALOG
   ══════════════════════════════════════════════════════════════════════════ */
.lms-catalog-header { margin-bottom: 36px; }
.lms-catalog-title {
    font-size: 32px !important;
    font-weight: 800 !important;
    color: var(--lf-text) !important;
    margin: 0 0 6px !important;
}
.lms-catalog-sub { font-size: 15px; color: var(--lf-muted); margin: 0; }

.lms-course-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    width: 100%;
}

.lms-course-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    overflow: hidden;
    transition: var(--lf-transition);
    display: flex;
    flex-direction: column;
}
.lms-course-card:hover {
    box-shadow: var(--lf-shadow-lg);
    transform: translateY(-3px);
}

.lms-card-thumb-link { display: block; aspect-ratio: 16/9; overflow: hidden; }
.lms-card-thumb { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.lms-course-card:hover .lms-card-thumb { transform: scale(1.04); }
.lms-card-thumb-placeholder {
    width: 100%; aspect-ratio: 16/9;
    background: linear-gradient(135deg, #e0f2fe, #bae6fd);
    display: flex; align-items: center; justify-content: center;
    font-size: 40px;
}

.lms-card-body { padding: 20px; display: flex; flex-direction: column; flex: 1; gap: 10px; }
.lms-card-title {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--lf-text) !important;
    margin: 0 !important;
    line-height: 1.35 !important;
}
.lms-card-title a { color: inherit !important; text-decoration: none !important; }
.lms-card-title a:hover { color: var(--lf-accent) !important; }

.lms-card-meta {
    display: flex; flex-wrap: wrap; gap: 8px 14px;
    font-size: 12px; color: var(--lf-muted);
}
.lms-card-footer {
    display: flex; align-items: center; justify-content: space-between;
    padding-top: 14px; border-top: 1px solid var(--lf-border);
    margin-top: auto;
}
.lms-price-free  { font-size: 18px; font-weight: 800; color: var(--lf-success); }
.lms-price-amount { font-size: 20px; font-weight: 800; color: var(--lf-text); }

/* ══════════════════════════════════════════════════════════════════════════
   SINGLE COURSE PAGE
   ══════════════════════════════════════════════════════════════════════════ */
.lms-course-hero {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 0;
    background: linear-gradient(135deg, #0c4a6e 0%, #0369a1 100%);
    border-radius: var(--lf-radius);
    overflow: hidden;
    margin-bottom: 40px;
    min-height: 220px;
    align-items: stretch;
}
.lms-course-hero-content {
    padding: 40px 44px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 16px;
    color: #fff;
}
.lms-hero-badge {
    align-self: flex-start;
    background: rgba(255,255,255,0.15) !important;
    color: #fff !important;
    backdrop-filter: blur(4px);
}
.lms-course-title {
    font-size: 28px !important;
    font-weight: 800 !important;
    color: #fff !important;
    margin: 0 !important;
    line-height: 1.25 !important;
}
.lms-course-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    font-size: 14px;
    color: rgba(255,255,255,0.80);
    align-items: center;
    margin: 0;
}
.lms-course-stats span {
    display: flex;
    align-items: center;
    gap: 5px;
    white-space: nowrap;
}
.lms-course-hero-image {
    position: relative;
    overflow: hidden;
    background: rgba(0,0,0,0.2);
}
.lms-course-hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform 0.4s ease;
}
.lms-course-hero:hover .lms-course-hero-image img {
    transform: scale(1.03);
}
@media (max-width: 768px) {
    .lms-course-hero {
        grid-template-columns: 1fr;
    }
    .lms-course-hero-image {
        height: 200px;
        order: -1;
    }
    .lms-course-hero-content {
        padding: 28px 24px;
    }
    .lms-course-title { font-size: 22px !important; }
}
.lms-course-layout {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 32px;
    align-items: start;
    position: relative;
    width: 100%;
}
.lms-course-main {
    display: flex;
    flex-direction: column;
    gap: 28px;
    min-width: 0;
}
.lms-course-sidebar {
    position: sticky;
    top: 90px;
    align-self: start;
    z-index: 10;
}

/* Progress card */
.lms-progress-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 20px 24px;
}
.lms-progress-header { display: flex; justify-content: space-between; font-size: 14px; font-weight: 600; margin-bottom: 10px; }
.lms-progress-bar-wrap { background: #f3f4f6; border-radius: 100px; height: 8px; overflow: hidden; }
.lms-progress-bar-fill { height: 100%; background: linear-gradient(90deg, var(--lf-accent), #818cf8); border-radius: 100px; transition: width 0.6s ease; }
.lms-progress-sub { font-size: 12px; color: var(--lf-muted); margin-top: 8px; }

/* Description */
.lms-course-description {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 28px 32px;
}
.lms-course-description h2 {
    font-size: 18px !important; font-weight: 700 !important;
    color: var(--lf-text) !important; margin: 0 0 16px !important;
}
.lms-course-description-body { font-size: 14px; line-height: 1.8; color: var(--lf-muted); }

/* Curriculum */
.lms-curriculum {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    overflow: hidden;
}
.lms-curriculum h2 {
    font-size: 18px !important; font-weight: 700 !important;
    color: var(--lf-text) !important; margin: 0 !important;
    padding: 20px 24px;
    border-bottom: 1px solid var(--lf-border);
}
.lms-lesson-row {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 24px;
    border-bottom: 1px solid var(--lf-border);
    transition: var(--lf-transition);
}
.lms-lesson-row:last-child { border-bottom: none; }
.lms-lesson-row:hover { background: #f9fafb; }
.lms-lesson-row.done { background: var(--lf-success-bg); }
.lms-lesson-row.locked { opacity: 0.55; }
.lms-lesson-number {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: #f3f4f6;
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 700; flex-shrink: 0;
    color: var(--lf-muted);
}
.lms-lesson-row.done .lms-lesson-number { background: #dcfce7; color: var(--lf-success); }
.lms-lesson-info { flex: 1; }
.lms-lesson-title-link { font-size: 14px; font-weight: 500; color: var(--lf-text); text-decoration: none; }
.lms-lesson-title-link:hover { color: var(--lf-accent); }
.lms-lesson-title-locked { font-size: 14px; color: var(--lf-muted); }
.lms-lesson-right { display: flex; gap: 6px; align-items: center; margin-left: auto; }
.lms-check { color: var(--lf-success); font-weight: 700; }

/* Enroll card */
.lms-enroll-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 28px 24px;
    box-shadow: var(--lf-shadow-lg);
}
.lms-enroll-price { font-size: 28px; font-weight: 800; color: var(--lf-text); margin-bottom: 18px; }
.lms-enrolled-badge {
    background: var(--lf-success-bg);
    color: var(--lf-success);
    font-size: 13px; font-weight: 700;
    text-align: center;
    padding: 10px;
    border-radius: var(--lf-radius-sm);
    margin-bottom: 12px;
}
.lms-enroll-features {
    list-style: none; margin: 20px 0 0; padding: 0;
    display: flex; flex-direction: column; gap: 10px;
    font-size: 13px; color: var(--lf-muted);
}
.lms-enroll-features li { display: flex; align-items: center; gap: 8px; }

/* ══════════════════════════════════════════════════════════════════════════
   DASHBOARD
   ══════════════════════════════════════════════════════════════════════════ */
.lms-dash-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 32px;
}
.lms-dash-title { font-size: 28px !important; font-weight: 800 !important; margin: 0 0 4px !important; }
.lms-dash-sub { font-size: 15px; color: var(--lf-muted); margin: 0; }

.lms-dash-stats {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 16px; margin-bottom: 40px;
}
.lms-dash-stat {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 24px;
    text-align: center;
}
.lms-dash-stat-num { font-size: 32px; font-weight: 800; color: var(--lf-accent); }
.lms-dash-stat-label { font-size: 13px; color: var(--lf-muted); margin-top: 4px; }

.lms-section-title {
    font-size: 20px !important; font-weight: 700 !important;
    color: var(--lf-text) !important; margin: 0 0 20px !important;
}

.lms-dash-course-list { display: flex; flex-direction: column; gap: 14px; margin-bottom: 40px; }
.lms-dash-course-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 20px 24px;
    display: flex; align-items: center; gap: 20px;
}
.lms-dash-course-thumb {
    width: 80px; height: 56px;
    object-fit: cover;
    border-radius: var(--lf-radius-sm); flex-shrink: 0;
}
.lms-dash-course-thumb-placeholder {
    width: 80px; height: 56px;
    background: linear-gradient(135deg, #e0f2fe, #bae6fd);
    border-radius: var(--lf-radius-sm);
    display: flex; align-items: center; justify-content: center;
    font-size: 24px; flex-shrink: 0;
}
.lms-dash-course-info { flex: 1; min-width: 0; }
.lms-dash-course-title { font-size: 15px !important; font-weight: 700 !important; margin: 0 0 10px !important; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lms-dash-progress { display: flex; flex-direction: column; gap: 4px; }
.lms-progress-label { font-size: 12px; color: var(--lf-muted); }
.lms-dash-course-actions { display: flex; gap: 8px; flex-shrink: 0; }

/* Account */
.lms-dash-account { margin-top: 8px; }
.lms-account-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 20px 24px;
    display: flex; align-items: center; gap: 16px;
}
.lms-account-avatar {
    width: 44px; height: 44px;
    background: var(--lf-accent);
    color: #fff; font-weight: 800; font-size: 18px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.lms-account-info { flex: 1; }
.lms-account-name  { font-size: 15px; font-weight: 700; }
.lms-account-email { font-size: 13px; color: var(--lf-muted); }

/* ══════════════════════════════════════════════════════════════════════════
   LESSON PLAYER
   ══════════════════════════════════════════════════════════════════════════ */
/* ── Lesson Player ──────────────────────────────────────────────────────── */
/* ════════════════════════════════════════════════════════════
   LESSON PLAYER — Tutor-LMS style: sidebar LEFT, video RIGHT
   ════════════════════════════════════════════════════════════ */

/* Reset lms-wrap for player */
.lms-wrap.lms-player-wrap {
    padding: 0 !important;
    max-width: none !important;
    margin: 0 !important;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    background: #f8f9fa;
}

/* ── Top Header ── */
.lp-header {
    height: 56px;
    background: #1e293b;
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 20px;
    position: sticky; top: 0; z-index: 200;
    flex-shrink: 0;
}
.lp-header-left  { display: flex; align-items: center; gap: 12px; overflow: hidden; }
.lp-header-right { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }

.lp-back-btn {
    display: flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; border-radius: 6px;
    color: rgba(255,255,255,.7) !important;
    background: rgba(255,255,255,.08); flex-shrink: 0;
    text-decoration: none !important; transition: background .15s;
}
.lp-back-btn:hover { background: rgba(255,255,255,.15); color: #fff !important; }
.lp-header-course {
    font-size: 13px; font-weight: 600; color: rgba(255,255,255,.9);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    max-width: 400px;
}
.lp-header-progress-wrap {
    display: flex; align-items: center; gap: 8px;
}
.lp-header-progress-bar {
    width: 120px; height: 4px;
    background: rgba(255,255,255,.15); border-radius: 100px; overflow: hidden;
}
.lp-header-progress-fill {
    height: 100%; background: #22c55e; border-radius: 100px; transition: width .4s;
}
.lp-header-progress-label {
    font-size: 11px; font-weight: 600; color: rgba(255,255,255,.6);
    white-space: nowrap;
}
.lp-menu-btn {
    display: none; align-items: center; gap: 6px;
    padding: 7px 12px; font-size: 12px; font-weight: 600;
    background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.15);
    border-radius: 6px; cursor: pointer; color: #fff;
    white-space: nowrap;
}

/* ── Main layout: sidebar LEFT, content RIGHT ── */
.lp-layout {
    display: grid;
    grid-template-columns: 300px 1fr;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

/* ── LEFT Sidebar ── */
.lp-sidebar {
    background: #fff;
    border-right: 1px solid #e2e8f0;
    display: flex; flex-direction: column;
    height: calc(100vh - 56px);
    position: sticky; top: 56px;
    overflow: hidden;
}
.lp-sidebar-head {
    padding: 14px 16px;
    border-bottom: 1px solid #e2e8f0;
    display: flex; justify-content: space-between; align-items: center;
    background: #f8fafc; flex-shrink: 0;
}
.lp-sidebar-title { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .7px; color: #64748b; }
.lp-sidebar-stats { font-size: 11px; font-weight: 700; color: #0369a1; background: #e0f2fe; padding: 2px 8px; border-radius: 100px; }
.lp-sidebar-prog {
    height: 3px; background: #e2e8f0; flex-shrink: 0;
}
.lp-sidebar-prog-fill { height: 100%; background: #22c55e; transition: width .4s; }

.lp-lesson-list {
    flex: 1; overflow-y: auto;
    display: flex; flex-direction: column;
    padding: 4px 0;
}
.lp-lesson-item {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 16px;
    text-decoration: none !important;
    color: #334155 !important;
    border-left: 3px solid transparent;
    transition: all .12s;
    position: relative;
}
.lp-lesson-item:hover { background: #f1f5f9; color: #0f172a !important; }
.lp-lesson-item.active {
    background: #eff6ff; border-left-color: #0369a1;
    color: #0369a1 !important;
}
.lp-lesson-item.done .lp-lesson-title { color: #64748b; }

.lp-lesson-check {
    width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0;
    border: 1.5px solid #cbd5e1;
    display: flex; align-items: center; justify-content: center;
    font-size: 10px; color: #94a3b8;
    background: #f8fafc;
    transition: all .15s;
}
.lp-lesson-item.done .lp-lesson-check { background: #22c55e; border-color: #22c55e; color: #fff; }
.lp-lesson-item.active .lp-lesson-check { border-color: #0369a1; color: #0369a1; }
.lp-lesson-num { font-size: 10px; font-weight: 700; }

.lp-lesson-title { flex: 1; font-size: 13px; font-weight: 500; line-height: 1.4; }
.lp-lesson-item.active .lp-lesson-title { font-weight: 700; color: #0369a1; }
.lp-lesson-type-icon { color: #94a3b8; flex-shrink: 0; }
.lp-lesson-item.active .lp-lesson-type-icon { color: #0369a1; }

/* ── RIGHT Content ── */
.lp-content {
    display: flex; flex-direction: column;
    overflow-y: auto;
    height: calc(100vh - 56px);
    padding-bottom: 80px; /* space for fixed bottom bar */
}

/* Video — edge to edge, black */
.lp-video-wrap {
    width: 100%; aspect-ratio: 16/9;
    background: #000; flex-shrink: 0;
    position: relative;
}
.lp-video-wrap iframe,
.lp-video-wrap video {
    width: 100%; height: 100%; display: block; border: none;
}
.lp-no-video {
    aspect-ratio: 16/9; background: #0f172a;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center; gap: 10px;
    color: rgba(255,255,255,.35); flex-shrink: 0;
}
.lp-no-video svg { opacity: .4; }
.lp-no-video span { font-size: 13px; font-weight: 500; }

/* Body: title, nav, content */
.lp-body { padding: 24px 32px; }
.lp-body-header {
    display: flex; align-items: flex-start;
    justify-content: space-between; gap: 16px;
    margin-bottom: 16px; flex-wrap: wrap;
}
.lp-lesson-heading {
    font-size: 20px !important; font-weight: 700 !important;
    color: #0f172a !important; margin: 0 !important; line-height: 1.3 !important;
    flex: 1;
}
.lp-nav-row { display: flex; gap: 8px; flex-shrink: 0; align-items: center; }
.lp-nav-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 7px 14px; font-size: 12px; font-weight: 600;
    color: #475569 !important; text-decoration: none !important;
    background: #f1f5f9; border: 1px solid #e2e8f0; border-radius: 6px;
    transition: all .15s;
}
.lp-nav-btn:hover { background: #e2e8f0; color: #0f172a !important; }

.lp-lesson-content {
    font-size: 15px; color: #334155; line-height: 1.75;
    border-top: 1px solid #e2e8f0; padding-top: 20px; margin-top: 4px;
}
.lp-lesson-content p   { margin: 0 0 14px; }
.lp-lesson-content img { max-width: 100%; border-radius: 8px; margin: 10px 0; }

/* Review box */
.lp-review-box {
    margin-top: 28px;
    background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 12px;
    padding: 20px 24px;
}
.lp-review-title { font-size: 15px; font-weight: 700; color: #14532d; margin-bottom: 14px; }
.lms-star-picker  { display: flex; gap: 6px; margin-bottom: 12px; cursor: pointer; }
.lms-star { font-size: 30px; color: #d1d5db; transition: color .1s; line-height: 1; }
#lms-review-text {
    width: 100%; font-size: 14px; border: 1px solid #bbf7d0;
    border-radius: 8px; padding: 10px 12px; resize: vertical; min-height: 80px;
    background: #fff; font-family: inherit;
}

/* ── Fixed Bottom Bar ── */
.lp-bottom-bar {
    position: fixed; bottom: 0; left: 300px; right: 0;
    height: 64px; z-index: 150;
    background: #fff; border-top: 1px solid #e2e8f0;
    display: flex; align-items: center;
    justify-content: space-between;
    padding: 0 32px;
    box-shadow: 0 -2px 12px rgba(0,0,0,.06);
}
.lp-bottom-info {
    font-size: 13px; color: #64748b; font-weight: 500;
}
.lp-done-badge {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 13px; font-weight: 700; color: #16a34a;
    background: #dcfce7; padding: 8px 14px; border-radius: 6px;
    border: 1px solid #bbf7d0;
}
.lp-complete-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 11px 24px; font-size: 14px; font-weight: 700;
    background: #0369a1; color: #fff !important;
    border: none; border-radius: 7px; cursor: pointer;
    text-decoration: none !important;
    transition: background .15s;
    box-shadow: 0 2px 8px rgba(3,105,161,.3);
}
.lp-complete-btn:hover { background: #0284c7; color: #fff !important; }
.lp-complete-btn:disabled { opacity: .7; cursor: not-allowed; }

/* ── Responsive ── */
@media (max-width: 960px) {
    .lp-layout { grid-template-columns: 260px 1fr; }
    .lp-bottom-bar { left: 260px; }
    .lp-header-progress-bar { width: 80px; }
}
@media (max-width: 768px) {
    .lp-layout { grid-template-columns: 1fr; }
    .lp-menu-btn { display: flex; }
    .lp-header-progress-bar { display: none; }
    .lp-header-course { max-width: 180px; }

    .lp-sidebar {
        position: fixed; top: 0; left: -105%;
        width: 85%; max-width: 300px;
        height: 100vh; z-index: 9999;
        transition: left .28s cubic-bezier(.4,0,.2,1);
        box-shadow: 4px 0 24px rgba(0,0,0,.18);
    }
    .lp-sidebar.open { left: 0; }

    .lp-content { height: calc(100vh - 56px); }
    .lp-body { padding: 16px; }
    .lp-body-header { flex-direction: column; gap: 10px; }
    .lp-lesson-heading { font-size: 17px !important; }

    .lp-bottom-bar { left: 0; padding: 0 16px; }
    .lp-bottom-info { display: none; }
    .lp-complete-btn { flex: 1; justify-content: center; }
}
@media (max-width: 480px) {
    .lp-header-course { display: none; }
}

/* ══════════════════════════════════════════════════════════════════════════
   EMPTY STATE
   ══════════════════════════════════════════════════════════════════════════ */
.lms-empty-state {
    text-align: center; padding: 80px 32px;
    color: var(--lf-muted);
}
.lms-empty-icon { font-size: 52px; margin-bottom: 16px; opacity: 0.5; display: block; }
.lms-empty-state h3 { font-size: 20px !important; color: var(--lf-text) !important; margin: 0 0 8px !important; }
.lms-empty-state p  { font-size: 14px; margin: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .lms-course-grid    { grid-template-columns: repeat(2, 1fr); }
    .lms-course-hero    { grid-template-columns: 1fr; }
    .lms-course-layout  { grid-template-columns: 1fr; }
    .lms-course-sidebar { position: static; }
    .lms-player-layout  { grid-template-columns: 1fr; }
    .lms-player-sidebar { position: static; max-height: none; }
}
@media (max-width: 640px) {
    .lms-wrap           { padding: 20px 16px; }
    .lms-course-grid    { grid-template-columns: 1fr; }
    .lms-auth-box       { padding: 32px 24px; }
    .lms-field-row      { grid-template-columns: 1fr; }
    .lms-dash-stats     { grid-template-columns: 1fr; }
    .lms-dash-course-card { flex-wrap: wrap; }
    .lms-dash-course-actions { width: 100%; }
    .lms-course-hero    { padding: 32px 24px; }
}

/* ══════════════════════════════════════════════════════════════════════════
   FAQs — Clean accordion design
   ══════════════════════════════════════════════════════════════════════════ */
.lms-faq-section h2 { margin-bottom: 6px !important; }

.lms-faq-subtitle {
    font-size: 14px;
    color: var(--lf-muted);
    margin: 0 0 28px !important;
}

.lms-faq-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    border: 1.5px solid var(--lf-border);
    border-radius: var(--lf-radius);
    overflow: hidden;
}

.lms-faq-item {
    border-bottom: 1.5px solid var(--lf-border);
}
.lms-faq-item:last-child { border-bottom: none; }

.lms-faq-question {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 24px;
    background: #fff;
    border: none;
    cursor: pointer;
    font-family: var(--lf-font);
    text-align: left;
    transition: background 0.15s ease;
}
.lms-faq-question:hover { background: #f9fafb; }
.lms-faq-item.open .lms-faq-question { background: #f5f3ff; }

.lms-faq-q-text {
    font-size: 15px;
    font-weight: 600;
    color: var(--lf-text);
    line-height: 1.45;
    flex: 1;
}
.lms-faq-item.open .lms-faq-q-text { color: var(--lf-accent); }

.lms-faq-chevron {
    flex-shrink: 0;
    color: var(--lf-muted);
    display: flex;
    align-items: center;
    transition: transform 0.25s ease, color 0.15s;
}
.lms-faq-item.open .lms-faq-chevron {
    transform: rotate(180deg);
    color: var(--lf-accent);
}

.lms-faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}
.lms-faq-item.open .lms-faq-answer {
    max-height: 600px;
}

.lms-faq-answer-inner {
    padding: 0 24px 22px;
    font-size: 14px;
    color: var(--lf-muted);
    line-height: 1.8;
    border-top: 1px solid var(--lf-border);
    padding-top: 18px;
}
.lms-faq-answer-inner p { margin: 0 0 10px; }
.lms-faq-answer-inner p:last-child { margin-bottom: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   Attachments
   ══════════════════════════════════════════════════════════════════════════ */
.lms-attachment-list { display: flex; flex-direction: column; gap: 8px; }
.lms-attachment-row {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 18px;
    border: 1px solid var(--lf-border); border-radius: var(--lf-radius-sm);
    background: var(--lf-white); text-decoration: none !important;
    transition: var(--lf-transition); color: var(--lf-text) !important;
}
.lms-attachment-row:hover { border-color: var(--lf-accent); background: var(--lf-accent-soft); }
.lms-attachment-icon { font-size: 24px; flex-shrink: 0; }
.lms-attachment-title { flex: 1; font-size: 14px; font-weight: 600; }
.lms-attachment-dl { font-size: 12px; color: var(--lf-accent); font-weight: 600; flex-shrink: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   Reviews
   ══════════════════════════════════════════════════════════════════════════ */
.lms-review-form {
    background: #f9fafb; border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius); padding: 20px 24px;
    margin-bottom: 24px;
}
.lms-faq-section .lms-star-picker,
.lms-reviews-section .lms-star-picker { display: flex; flex-direction: row-reverse; gap: 4px; margin-bottom: 4px; }
.lms-reviews-section .lms-star-picker input { display: none; }
.lms-reviews-section .lms-star-picker label {
    font-size: 30px; color: #d1d5db; cursor: pointer;
    transition: color 0.15s;
}
.lms-star-picker label:hover,
.lms-star-picker label:hover ~ label,
.lms-star-picker input:checked ~ label { color: #f59e0b; }

.lms-review-list { display: flex; flex-direction: column; gap: 16px; margin-top: 20px; }
.lms-review-item {
    padding: 18px 20px;
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    background: var(--lf-white);
}
.lms-review-header { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 10px; }
.lms-review-avatar {
    width: 38px; height: 38px; border-radius: 50%;
    background: var(--lf-accent); color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: 15px; flex-shrink: 0;
}
.lms-review-name { font-size: 14px; font-weight: 700; }
.lms-review-stars { color: #f59e0b; font-size: 15px; margin-top: 2px; }
.lms-review-date { font-size: 12px; color: var(--lf-muted); margin-left: 8px; vertical-align: middle; }
.lms-review-text { font-size: 14px; color: var(--lf-muted); line-height: 1.7; margin: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   Coupon input on enroll card
   ══════════════════════════════════════════════════════════════════════════ */
.lms-coupon-row { display: flex; gap: 8px; margin-top: 16px; }
.lms-coupon-row input { flex: 1; font-size: 13px; }
.lms-coupon-msg { font-size: 12px; margin-top: 6px; font-weight: 600; }
.lms-coupon-success { color: var(--lf-success); }
.lms-coupon-error   { color: var(--lf-danger); }

/* ══════════════════════════════════════════════════════════════════════════
   Quiz block on lesson player
   ══════════════════════════════════════════════════════════════════════════ */
.lms-quiz-block {
    background: var(--lf-white); border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius); padding: 28px 32px; margin-top: 24px;
}
.lms-quiz-block h3 { font-size: 18px !important; font-weight: 700 !important; margin: 0 0 20px !important; }
.lms-quiz-question { margin-bottom: 24px; }
.lms-quiz-question-text { font-size: 15px; font-weight: 600; margin-bottom: 12px; }
.lms-quiz-option {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 16px; border: 1.5px solid var(--lf-border);
    border-radius: var(--lf-radius-sm); margin-bottom: 8px;
    cursor: pointer; transition: var(--lf-transition); font-size: 14px;
    background: var(--lf-white);
}
.lms-quiz-option:hover { border-color: var(--lf-accent); background: var(--lf-accent-soft); }
.lms-quiz-option.selected { border-color: var(--lf-accent); background: var(--lf-accent-soft); font-weight: 600; }
.lms-quiz-option.correct  { border-color: var(--lf-success); background: var(--lf-success-bg); }
.lms-quiz-option.wrong    { border-color: var(--lf-danger);  background: var(--lf-danger-bg); }
.lms-quiz-result {
    text-align: center; padding: 28px;
    background: #f9fafb; border-radius: var(--lf-radius); margin-top: 20px;
}
.lms-quiz-score { font-size: 48px; font-weight: 800; color: var(--lf-accent); }
.lms-quiz-pass { color: var(--lf-success); }
.lms-quiz-fail { color: var(--lf-danger); }

/* ══════════════════════════════════════════════════════════════════════════
   Resume banner
   ══════════════════════════════════════════════════════════════════════════ */
.lms-resume-banner {
    background: linear-gradient(135deg, var(--lf-accent), var(--lf-accent-dark));
    color: #fff; border-radius: var(--lf-radius);
    padding: 18px 24px;
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    margin-bottom: 28px;
}
.lms-resume-text { font-size: 14px; font-weight: 600; }
.lms-resume-sub  { font-size: 12px; opacity: 0.8; margin-top: 2px; }
.lms-resume-btn  {
    background: rgba(255,255,255,0.2); color: #fff !important;
    border: 1.5px solid rgba(255,255,255,0.4);
    padding: 9px 18px; border-radius: var(--lf-radius-sm);
    font-size: 13px; font-weight: 700; text-decoration: none !important;
    flex-shrink: 0; transition: var(--lf-transition);
}
.lms-resume-btn:hover { background: rgba(255,255,255,0.35); color: #fff !important; }

/* ══════════════════════════════════════════════════════════════════════════
   AUTH TABS (Password / OTP)
   ══════════════════════════════════════════════════════════════════════════ */
.lms-auth-tabs {
    display: flex; gap: 0;
    border-bottom: 2px solid var(--lf-border);
    margin-bottom: 24px;
}
.lms-auth-tab {
    flex: 1; padding: 10px; background: none; border: none;
    border-bottom: 2px solid transparent; margin-bottom: -2px;
    font-size: 14px; font-weight: 600; color: var(--lf-muted);
    cursor: pointer; transition: var(--lf-transition); font-family: var(--lf-font);
}
.lms-auth-tab.active { color: var(--lf-accent); border-bottom-color: var(--lf-accent); }
.lms-auth-tab:hover  { color: var(--lf-text); }

.lms-link-btn {
    background: none; border: none; color: var(--lf-accent);
    font-size: inherit; cursor: pointer; padding: 0; font-family: var(--lf-font);
    text-decoration: underline;
}

/* ══════════════════════════════════════════════════════════════════════════
   STICKY SIDEBAR — force it to work across all themes
   ══════════════════════════════════════════════════════════════════════════ */
.lms-course-layout {
    display: grid !important;
    grid-template-columns: 1fr 340px !important;
    gap: 32px !important;
    align-items: start !important;
}
.lms-course-sidebar {
    position: sticky !important;
    top: 90px !important;
    align-self: start !important;
}
.lms-enroll-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 28px 24px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.10);
}

@media (max-width: 900px) {
    .lms-course-layout {
        grid-template-columns: 1fr !important;
    }
    .lms-course-sidebar {
        position: static !important;
        order: -1; /* Show enroll card ABOVE content on mobile */
    }
}

/* ══════════════════════════════════════════════════════════════════════════
   Course Search & Pagination
   ══════════════════════════════════════════════════════════════════════════ */
.lms-search-form { margin-bottom: 28px; }
.lms-search-wrap {
    display: flex; gap: 10px; align-items: center;
    max-width: 480px;
}
.lms-search-input {
    flex: 1 !important; width: auto !important;
    border: 1.5px solid var(--lf-border) !important;
    border-radius: var(--lf-radius-sm) !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    background: #fff !important;
}
.lms-search-input:focus {
    border-color: var(--lf-accent) !important;
    box-shadow: 0 0 0 3px var(--lf-accent-soft) !important;
}
.lms-search-results-count {
    font-size: 14px; color: var(--lf-muted);
    margin: 12px 0 0 !important;
}
.lms-pagination {
    display: flex; gap: 8px; justify-content: center;
    margin-top: 36px; flex-wrap: wrap;
}
.lms-page-btn {
    width: 38px; height: 38px;
    display: flex; align-items: center; justify-content: center;
    border: 1.5px solid var(--lf-border);
    border-radius: var(--lf-radius-sm);
    font-size: 14px; font-weight: 600;
    color: var(--lf-text) !important;
    text-decoration: none !important;
    transition: var(--lf-transition);
    background: #fff;
}
.lms-page-btn:hover { border-color: var(--lf-accent); color: var(--lf-accent) !important; }
.lms-page-btn.active {
    background: var(--lf-accent); border-color: var(--lf-accent);
    color: #fff !important;
}

/* ══════════════════════════════════════════════════════════════════════════
   Email verification notices
   ══════════════════════════════════════════════════════════════════════════ */
.lms-verify-notice {
    background: #fffbeb; border: 1px solid #fde68a;
    border-radius: var(--lf-radius-sm); padding: 14px 18px;
    font-size: 14px; color: #92400e;
    margin-bottom: 20px;
    display: flex; align-items: flex-start; gap: 10px;
}
.lms-verify-notice strong { color: #78350f; }
.lms-verified-badge {
    background: var(--lf-success-bg); border: 1px solid #86efac;
    border-radius: var(--lf-radius-sm); padding: 14px 18px;
    font-size: 14px; color: var(--lf-success); font-weight: 600;
    margin-bottom: 20px;
}

/* ══════════════════════════════════════════════════════════════════════════
   Email verification block on enroll card
   ══════════════════════════════════════════════════════════════════════════ */
.lms-unverified-block {
    background: #fffbeb;
    border: 1.5px solid #fde68a;
    border-radius: var(--lf-radius-sm);
    padding: 16px;
    display: flex;
    gap: 12px;
    align-items: flex-start;
    font-size: 13px;
    color: #78350f;
    margin-bottom: 4px;
}
.lms-unverified-block span { font-size: 20px; flex-shrink: 0; margin-top: 1px; }
.lms-unverified-block strong { display: block; font-weight: 700; margin-bottom: 3px; color: #92400e; }
.lms-unverified-block small { color: #a16207; }
.lms-unverified-block a { color: #78350f !important; }
.lms-unverified-block a:hover { text-decoration: underline; }

/* ══════════════════════════════════════════════════════════════════════════
   Hero without thumb column (full-width hero)
   ══════════════════════════════════════════════════════════════════════════ */


@media (max-width: 768px) {
    .lms-course-hero { padding: 36px 24px; }
    .lms-course-title { font-size: 24px !important; }
}

/* ══════════════════════════════════════════════════════════════════════════
   Two-Column Dashboard Layout
   ══════════════════════════════════════════════════════════════════════════ */
.lms-dash-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 32px;
    align-items: start;
    width: 100%;
}
.lms-dash-left  { display: flex; flex-direction: column; gap: 28px; min-width: 0; }
.lms-dash-right { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 90px; }

/* Profile card */
.lms-dash-profile-card {
    background: linear-gradient(135deg, #0c4a6e 0%, #0369a1 100%);
    border-radius: var(--lf-radius);
    padding: 28px 22px;
    text-align: center;
    color: #fff;
}
.lms-dash-profile-avatar {
    width: 64px; height: 64px;
    background: rgba(255,255,255,0.15);
    border: 3px solid rgba(255,255,255,0.3);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 26px; font-weight: 800; color: #fff;
    margin: 0 auto 14px;
}
.lms-dash-profile-name  { font-size: 16px; font-weight: 700; margin-bottom: 4px; }
.lms-dash-profile-email { font-size: 12px; opacity: 0.7; word-break: break-all; }
.lms-dash-verified-badge {
    display: inline-block;
    margin-top: 10px;
    background: rgba(34,197,94,0.2);
    border: 1px solid rgba(34,197,94,0.4);
    color: #86efac;
    font-size: 11px; font-weight: 600;
    padding: 3px 10px; border-radius: 100px;
}
.lms-dash-profile-card .lms-btn-outline {
    border-color: rgba(255,255,255,0.35) !important;
    color: rgba(255,255,255,0.9) !important;
}
.lms-dash-profile-card .lms-btn-outline:hover {
    background: rgba(255,255,255,0.1) !important;
}

/* Quick stats */
.lms-dash-quick-stats {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    overflow: hidden;
}
.lms-dash-qstat {
    padding: 16px 8px;
    text-align: center;
    border-right: 1px solid var(--lf-border);
}
.lms-dash-qstat:last-child { border-right: none; }
.lms-dash-qstat-num   { font-size: 22px; font-weight: 800; color: var(--lf-accent); }
.lms-dash-qstat-label { font-size: 11px; color: var(--lf-muted); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.5px; }

/* Quick links */
.lms-dash-quick-links {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    overflow: hidden;
}
.lms-dash-quick-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 13px 18px;
    border-bottom: 1px solid var(--lf-border);
    font-size: 13px; font-weight: 600;
    color: var(--lf-text) !important;
    text-decoration: none !important;
    transition: var(--lf-transition);
}
.lms-dash-quick-link:last-child { border-bottom: none; }
.lms-dash-quick-link:hover { background: var(--lf-accent-soft); color: var(--lf-accent) !important; }
.lms-dash-quick-link span { font-size: 16px; }

/* Remove old stats row from left column (now in right column) */
.lms-dash-left .lms-dash-stats { display: none; }

@media (max-width: 768px) {
    .lms-dash-layout {
        grid-template-columns: 1fr;
    }
    .lms-dash-right {
        position: static;
        order: -1; /* Profile shows first on mobile */
    }
}

/* ══════════════════════════════════════════════════════════════════════════
   Course Completion Overlay
   ══════════════════════════════════════════════════════════════════════════ */
.lms-completion-overlay {
    position: fixed; inset: 0; z-index: 99999;
    background: rgba(0,0,0,0.75);
    display: flex; align-items: center; justify-content: center;
    animation: lmsFadeIn 0.3s ease;
}
@keyframes lmsFadeIn { from { opacity: 0; } to { opacity: 1; } }

.lms-completion-card {
    background: #fff;
    border-radius: var(--lf-radius);
    padding: 52px 48px;
    text-align: center;
    max-width: 480px;
    width: 94%;
    box-shadow: 0 24px 80px rgba(0,0,0,0.3);
    animation: lmsSlideUp 0.35s ease;
}
@keyframes lmsSlideUp {
    from { transform: translateY(30px); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
}
.lms-completion-icon { font-size: 72px; margin-bottom: 20px; }
.lms-completion-card h2 {
    font-size: 26px; font-weight: 800; color: var(--lf-text);
    margin: 0 0 10px !important;
}
.lms-completion-card p {
    font-size: 15px; color: var(--lf-muted);
    margin: 0 0 28px !important;
}
.lms-completion-actions { display: flex; gap: 10px; justify-content: center; }

/* ══════════════════════════════════════════════════════════════════════════
   License Number Card — Dashboard Right Column
   ══════════════════════════════════════════════════════════════════════════ */
.lms-dash-license-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 16px 18px;
}
.lms-dash-license-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--lf-text);
    margin-bottom: 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* ══════════════════════════════════════════════════════════════════════════
   COMPREHENSIVE RESPONSIVE — All LMS pages
   ══════════════════════════════════════════════════════════════════════════ */

/* Tablet (768px–1024px) */
@media (max-width: 1024px) {
    .lms-dash-layout {
        grid-template-columns: 1fr 240px;
        gap: 20px;
    }
    .lms-dash-right { position: static; top: auto; }
    .lms-dash-profile-card { padding: 20px 16px; }
    .lms-course-hero { min-height: auto; }
    .lms-course-hero-content { padding: 32px 36px; }
}

/* Mobile (≤768px) */
@media (max-width: 768px) {
    /* Dashboard two-column → single column */
    .lms-dash-layout {
        grid-template-columns: 1fr !important;
        gap: 16px;
    }
    .lms-dash-right {
        position: static !important;
        order: -1; /* Profile card above courses on mobile */
    }
    .lms-dash-left .lms-dash-stats { display: none; }

    /* Dashboard header */
    .lms-dash-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    /* Course hero single column on mobile */
    .lms-course-hero {
        grid-template-columns: 1fr !important;
    }
    .lms-course-hero-image {
        height: 200px;
        order: -1;
    }
    .lms-course-hero-content { padding: 24px 20px; }
    .lms-course-title { font-size: 20px !important; }
    .lms-course-stats { flex-wrap: wrap; gap: 10px; font-size: 13px; }

    /* Course layout */
    .lms-course-layout {
        grid-template-columns: 1fr !important;
    }
    .lms-course-sidebar {
        position: static !important;
        order: -1; /* Enroll card above content on mobile */
    }
    .lms-enroll-card { padding: 20px 16px; }

    /* Lesson player */
    .lms-player-layout {
        grid-template-columns: 1fr !important;
        gap: 0;
    }
    .lms-player-sidebar {
        position: static !important;
        max-height: 300px;
        overflow-y: auto;
        order: 2;
        border-top: 1px solid var(--lf-border);
    }
    .lms-player-main { padding: 16px; }

    /* Auth pages */
    .lms-auth-wrap { padding: 16px; }
    .lms-auth-box  { padding: 28px 20px; max-width: 100%; }

    /* Catalog */
    .lms-catalog-header { margin-bottom: 20px; }
    .lms-search-wrap { max-width: 100%; }

    /* Quick stats collapse */
    .lms-dash-quick-stats { grid-template-columns: repeat(3, 1fr); }

    /* Dashboard course card */
    .lms-dash-course-card {
        flex-direction: column;
    }
    .lms-dash-course-thumb,
    .lms-dash-course-thumb-placeholder {
        width: 100% !important;
        height: 160px !important;
        border-radius: var(--lf-radius) var(--lf-radius) 0 0 !important;
    }
    .lms-dash-course-actions {
        flex-direction: row;
        justify-content: flex-end;
        width: 100%;
        padding-top: 12px;
        border-top: 1px solid var(--lf-border);
    }

    /* Breadcrumb */
    .lms-breadcrumb { font-size: 13px; }

    /* FAQ */
    .lms-faq-question { padding: 16px; }

    /* Wrap padding */
    .lms-wrap { padding: 16px 14px; }
}

/* Small mobile (≤480px) */
@media (max-width: 480px) {
    .lms-course-grid { grid-template-columns: 1fr !important; }
    .lms-auth-box    { padding: 24px 16px; }
    .lms-course-title { font-size: 18px !important; }

    .lms-dash-profile-card { padding: 20px 14px; }
    .lms-dash-profile-name { font-size: 15px; }

    /* Player controls stack on mobile */
    .lms-player-controls {
        flex-direction: column;
        gap: 10px;
    }
    .lms-player-nav { width: 100%; justify-content: space-between; }

    /* Enroll card */
    .lms-enroll-price { font-size: 28px; }
    .lms-coupon-row { flex-direction: column; }
    .lms-coupon-row input { width: 100%; }

    /* Certificate overlay */
    .lms-completion-card { padding: 36px 24px; }
    .lms-completion-icon { font-size: 52px; }
    .lms-completion-card h2 { font-size: 22px; }
}

/* ══════════════════════════════════════════════════════════════════════════
   COURSE DETAIL PAGE — BeatLab Academy Style
   ══════════════════════════════════════════════════════════════════════════ */

/* Outer wrapper */
.lms-cdp-wrap {
    width: 100%;
    padding: 24px 32px 60px;
}

/* Breadcrumb */
.lms-cdp-breadcrumb {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
    font-size: 13px;
}
.lms-cdp-breadcrumb a {
    color: var(--lc-primary, var(--lf-accent));
    text-decoration: none;
    font-weight: 500;
}
.lms-cdp-breadcrumb a:hover { text-decoration: underline; }
.lms-cdp-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 100px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: var(--lc-accent-soft, rgba(3,105,161,0.08));
    color: var(--lc-primary, var(--lf-accent));
    border: 1px solid var(--lc-accent-soft, rgba(3,105,161,0.15));
}

/* ── Two column layout ── */
.lms-cdp-layout {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 36px;
    align-items: start;
    width: 100%;
}

/* ── LEFT column ── */
.lms-cdp-left { display: flex; flex-direction: column; gap: 0; min-width: 0; }

/* Media / Thumbnail */
.lms-cdp-media {
    border-radius: 14px;
    overflow: hidden;
    background: #0f172a;
    aspect-ratio: 16/9;
    margin-bottom: 24px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.12);
}
.lms-cdp-thumb {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}
.lms-cdp-thumb-placeholder {
    width: 100%; height: 100%;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 16px;
    background: linear-gradient(135deg, var(--lc-primary,#0369a1), var(--lc-primary-dark,#075985));
    color: rgba(255,255,255,0.7);
    font-size: 16px; font-weight: 500;
}

/* Header: title + meta below image */
.lms-cdp-header { margin-bottom: 28px; }
.lms-cdp-title {
    font-size: 32px !important;
    font-weight: 800 !important;
    color: var(--lc-text, var(--lf-text)) !important;
    line-height: 1.2 !important;
    margin: 0 0 16px !important;
    letter-spacing: -0.5px;
}
.lms-cdp-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 20px;
    align-items: center;
}
.lms-cdp-meta-item {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    color: var(--lf-muted);
    font-weight: 500;
}
.lms-cdp-meta-icon {
    display: flex;
    align-items: center;
    color: var(--lc-primary, var(--lf-accent));
}

/* Progress bar */
.lms-cdp-progress {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 16px 20px;
    margin-bottom: 28px;
}
.lms-cdp-progress-top {
    display: flex;
    justify-content: space-between;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--lf-text);
}
.lms-cdp-progress-bar {
    height: 6px;
    background: var(--lf-border);
    border-radius: 100px;
    overflow: hidden;
    margin-bottom: 6px;
}
.lms-cdp-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--lc-primary,#0369a1), var(--lc-accent,#0ea5e9));
    border-radius: 100px;
    transition: width 0.6s ease;
}
.lms-cdp-progress-sub { font-size: 12px; color: var(--lf-muted); }

/* Section headings */
.lms-cdp-section { margin-bottom: 36px; }
.lms-cdp-section-title {
    font-size: 19px !important;
    font-weight: 700 !important;
    color: var(--lc-text, var(--lf-text)) !important;
    margin: 0 0 16px !important;
    display: flex;
    align-items: center;
    gap: 10px;
}
.lms-cdp-section-count {
    font-size: 12px;
    font-weight: 500;
    color: var(--lf-muted);
    background: var(--lf-border);
    padding: 2px 8px;
    border-radius: 100px;
}
.lms-cdp-description {
    font-size: 15px;
    line-height: 1.75;
    color: var(--lf-muted);
}
.lms-cdp-description p { margin-bottom: 12px; }

/* Curriculum */
.lms-cdp-curriculum {
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    overflow: hidden;
}
.lms-cdp-lesson {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--lf-border);
    background: var(--lf-white);
    transition: background 0.15s ease;
}
.lms-cdp-lesson:last-child { border-bottom: none; }
.lms-cdp-lesson:hover { background: var(--lf-bg); }
.lms-cdp-lesson.done { background: rgba(22,163,74,0.03); }
.lms-cdp-lesson.locked { opacity: 0.65; }
.lms-cdp-lesson-num {
    width: 28px; height: 28px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
    font-size: 12px; font-weight: 700;
    flex-shrink: 0;
    background: var(--lf-border);
    color: var(--lf-muted);
}
.lms-cdp-lesson.done .lms-cdp-lesson-num {
    background: rgba(22,163,74,0.12);
    color: #16a34a;
}
.lms-cdp-lesson-info { flex: 1; min-width: 0; }
.lms-cdp-lesson-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--lf-text) !important;
    text-decoration: none !important;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.lms-cdp-lesson-title:hover { color: var(--lc-primary, var(--lf-accent)) !important; }
.lms-cdp-lesson-title.locked { color: var(--lf-muted) !important; }
.lms-cdp-lesson-tags { display: flex; gap: 6px; flex-shrink: 0; }
.lms-cdp-tag {
    font-size: 11px; font-weight: 600; padding: 2px 8px;
    border-radius: 100px;
}
.lms-cdp-tag.preview { background: rgba(22,163,74,0.1); color: #16a34a; }
.lms-cdp-tag.video   { background: rgba(3,105,161,0.08); color: var(--lc-primary,#0369a1); }

/* ── RIGHT column ── */
/* Mobile enroll card hidden on desktop */
.lms-cdp-enroll-mobile-card { display: none; }

.lms-cdp-right {
    position: sticky;
    top: 90px;
}

/* Enroll Card */
.lms-cdp-enroll-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

/* Price block */
.lms-cdp-price-block { margin-bottom: 12px; }
.lms-cdp-price {
    font-size: 22px;
    font-weight: 700;
    color: var(--lc-text, var(--lf-text));
    line-height: 1;
}
.lms-cdp-price.free {
    color: var(--lc-primary, var(--lf-accent));
    font-size: 20px;
}

/* Enroll button */
.lms-cdp-btn-enroll {
    display: block;
    width: 100%;
    padding: 15px 20px;
    background: var(--lc-primary, var(--lf-accent));
    color: #fff !important;
    font-size: 15px;
    font-weight: 700;
    text-align: center;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    text-decoration: none !important;
    transition: all 0.18s ease;
    letter-spacing: 0.3px;
    box-shadow: 0 4px 16px rgba(3,105,161,0.3);
}
.lms-cdp-btn-enroll:hover {
    background: var(--lc-primary-dark, var(--lf-accent-dark));
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(3,105,161,0.4);
    color: #fff !important;
}
.lms-cdp-btn-outline {
    display: block;
    width: 100%;
    padding: 13px 20px;
    background: transparent;
    color: var(--lc-primary, var(--lf-accent)) !important;
    font-size: 14px;
    font-weight: 600;
    text-align: center;
    border: 1.5px solid var(--lc-primary, var(--lf-accent));
    border-radius: 10px;
    cursor: pointer;
    text-decoration: none !important;
    transition: all 0.18s ease;
}
.lms-cdp-btn-outline:hover {
    background: var(--lf-accent-soft);
}
.lms-cdp-enrolled-badge {
    font-size: 14px;
    font-weight: 600;
    color: #16a34a;
    background: rgba(22,163,74,0.08);
    border: 1px solid rgba(22,163,74,0.2);
    border-radius: 8px;
    padding: 10px 16px;
    margin-bottom: 14px;
    text-align: center;
}

/* Coupon */
.lms-cdp-coupon-row {
    display: flex;
    gap: 8px;
    margin-top: 12px;
}
.lms-cdp-coupon-row input {
    flex: 1;
    font-size: 13px;
    text-transform: uppercase;
}
.lms-cdp-coupon-btn {
    padding: 0 14px;
    background: var(--lf-bg);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius-sm);
    font-size: 13px;
    font-weight: 600;
    color: var(--lf-text);
    cursor: pointer;
    white-space: nowrap;
}
.lms-cdp-coupon-btn:hover { background: var(--lf-border); }

/* Verification block */
.lms-cdp-verify-block {
    display: flex; flex-direction: column; gap: 4px;
    background: #fffbeb;
    border: 1px solid #fcd34d;
    border-radius: 8px;
    padding: 12px 14px;
    font-size: 13px;
    margin-bottom: 4px;
}
.lms-cdp-verify-block a { color: var(--lc-primary,#0369a1); font-weight: 600; }

/* Course includes */
.lms-cdp-includes {
    margin-top: 20px;
    padding-top: 18px;
    border-top: 1px solid var(--lf-border);
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.lms-cdp-include-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--lf-muted);
}
.lms-cdp-include-item svg { color: var(--lc-primary,#0369a1); flex-shrink: 0; }

/* What You'll Learn */
.lms-cdp-learn-block {
    margin-top: 20px;
    padding-top: 18px;
    border-top: 1px solid var(--lf-border);
}
.lms-cdp-learn-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--lf-text);
    margin-bottom: 12px;
}
.lms-cdp-learn-list {
    list-style: none;
    padding: 0; margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.lms-cdp-learn-list li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 13px;
    color: var(--lf-muted);
    line-height: 1.4;
}
.lms-cdp-learn-list li svg { color: #16a34a; flex-shrink: 0; margin-top: 1px; }

/* ── Responsive ── */
@media (max-width: 960px) {
    /* Stack to single column */
    .lms-cdp-layout { grid-template-columns: 1fr !important; }

    /* Hide sticky right column (desktop enroll card) */
    .lms-cdp-right  { display: none !important; }

    /* Show the inline mobile enroll card */
    .lms-cdp-enroll-mobile-card { display: block !important; }

    /* Make left column flex so CSS order works */
    .lms-cdp-left {
        display: flex !important;
        flex-direction: column !important;
    }
    /* Section order on mobile */
    .lms-cdp-order-1 { order: 1 !important; }
    .lms-cdp-order-2 { order: 2 !important; }
    .lms-cdp-order-3 { order: 3 !important; }
    .lms-cdp-order-4 { order: 4 !important; }
    .lms-cdp-order-5 { order: 5 !important; }
    .lms-cdp-order-6 { order: 6 !important; }
    .lms-cdp-order-7 { order: 7 !important; }

    /* Style the inline enroll card */
    .lms-cdp-enroll-mobile-card {
        order: 5 !important;
        border: 1.5px solid var(--lf-border);
        border-radius: 14px;
        padding: 20px;
        margin-bottom: 24px;
        background: var(--lf-white);
        box-shadow: 0 2px 8px rgba(0,0,0,.06);
    }
    .lms-cdp-title { font-size: 26px !important; }
}
@media (max-width: 600px) {
    .lms-cdp-wrap   { padding: 16px 14px 40px; }
    .lms-cdp-title  { font-size: 22px !important; }
    .lms-cdp-enroll-card { padding: 20px 16px; }
    .lms-cdp-price  { font-size: 28px; }
}

/* ══════════════════════════════════════════════════════════════════════════
   FEATURE 1: Course Archive Filter Bar
   ══════════════════════════════════════════════════════════════════════════ */
.lms-catalog-page {
    width: 100%;
}
.lms-catalog-header {
    display: flex !important;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 20px;
    flex-wrap: wrap;
    gap: 8px;
}
.lms-catalog-title {
    font-size: 26px !important;
    font-weight: 800 !important;
    color: var(--lf-text) !important;
    margin: 0 !important;
}
.lms-catalog-sub {
    font-size: 13px !important;
    color: var(--lf-muted) !important;
    margin: 4px 0 0 !important;
}

.lms-filter-form { margin-bottom: 28px; }

/* Force flex row — override any theme interference */
.lms-filter-row {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    align-items: center !important;
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: 12px;
    padding: 10px 12px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
    box-sizing: border-box;
}
.lms-filter-row > * {
    display: inline-flex !important;
    align-items: center;
    box-sizing: border-box;
}

.lms-filter-search {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    flex: 1 1 180px !important;
    min-width: 160px;
    max-width: 340px;
}
.lms-filter-search-icon {
    position: absolute;
    left: 10px;
    color: var(--lf-muted);
    pointer-events: none;
    display: flex;
    align-items: center;
}
.lms-filter-search-input {
    width: 100% !important;
    height: 40px !important;
    padding: 0 12px 0 34px !important;
    border: 1px solid var(--lf-border) !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    background: var(--lf-bg) !important;
    color: var(--lf-text) !important;
    box-sizing: border-box !important;
    outline: none;
    display: block !important;
}
.lms-filter-search-input:focus {
    border-color: var(--lf-accent) !important;
    box-shadow: 0 0 0 3px var(--lf-accent-soft) !important;
}

.lms-filter-select {
    display: inline-block !important;
    height: 40px !important;
    padding: 0 10px !important;
    border: 1px solid var(--lf-border) !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    color: var(--lf-text) !important;
    background: var(--lf-bg) !important;
    cursor: pointer;
    min-width: 120px;
    max-width: 160px;
    flex-shrink: 0;
    appearance: auto;
    -webkit-appearance: auto;
}
.lms-filter-select:focus { outline: none; border-color: var(--lf-accent) !important; }

.lms-filter-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 40px !important;
    padding: 0 20px !important;
    background: var(--lf-accent) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    cursor: pointer;
    transition: background 0.15s ease;
    white-space: nowrap;
    flex-shrink: 0;
    text-decoration: none !important;
}
.lms-filter-btn:hover { background: var(--lf-accent-dark) !important; }

.lms-filter-clear {
    display: inline-flex !important;
    align-items: center !important;
    color: var(--lf-muted) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    white-space: nowrap;
    padding: 4px 6px;
    border-radius: 6px;
    flex-shrink: 0;
}
.lms-filter-clear:hover {
    color: var(--lf-danger) !important;
    background: rgba(220,38,38,0.06);
}

/* Active filter chips */
.lms-filter-chips {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px;
    margin-top: 10px;
}
.lms-filter-chip {
    display: inline-flex !important;
    align-items: center;
    gap: 4px;
    padding: 4px 12px;
    background: var(--lf-accent-soft);
    color: var(--lf-accent) !important;
    border: 1px solid rgba(3,105,161,0.2);
    border-radius: 100px;
    font-size: 12px;
    font-weight: 600;
    text-decoration: none !important;
    transition: var(--lf-transition);
}
.lms-filter-chip:hover {
    background: rgba(220,38,38,0.08);
    color: var(--lf-danger) !important;
    border-color: rgba(220,38,38,0.2);
}
.lms-filter-results {
    margin-top: 8px;
    font-size: 13px;
    color: var(--lf-muted);
}

/* Mobile */
@media (max-width: 640px) {
    .lms-filter-row { flex-direction: column !important; padding: 12px; }
    .lms-filter-row > * { width: 100% !important; max-width: 100% !important; }
    .lms-filter-search { max-width: 100%; }
}

/* ══════════════════════════════════════════════════════════════════════════
   FEATURE 5: Instructors List Page
   ══════════════════════════════════════════════════════════════════════════ */
.lms-instructors-grid {
    display: grid;
    grid-template-columns: repeat(var(--lms-cols, 3), 1fr);
    gap: 24px;
}
.lms-instructor-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 28px 20px;
    text-align: center;
    transition: var(--lf-transition);
}
.lms-instructor-card:hover {
    box-shadow: var(--lf-shadow-lg);
    transform: translateY(-3px);
}
.lms-instructor-avatar {
    width: 80px; height: 80px;
    border-radius: 50%;
    overflow: hidden;
    margin: 0 auto 16px;
    background: linear-gradient(135deg, var(--lf-accent), var(--lf-accent-dark));
    display: flex; align-items: center; justify-content: center;
    font-size: 26px; font-weight: 800; color: #fff;
    border: 3px solid var(--lf-border);
}
.lms-instructor-avatar img { width: 100%; height: 100%; object-fit: cover; }
.lms-instructor-name  { font-size: 16px; font-weight: 700; color: var(--lf-text); margin-bottom: 4px; }
.lms-instructor-count { font-size: 12px; color: var(--lf-accent); font-weight: 600; margin-bottom: 14px; }
.lms-instructor-courses {
    list-style: none; padding: 0; margin: 0;
    text-align: left;
    border-top: 1px solid var(--lf-border);
    padding-top: 12px;
    display: flex; flex-direction: column; gap: 6px;
}
.lms-instructor-courses li a {
    font-size: 12px; color: var(--lf-muted) !important;
    text-decoration: none !important;
    display: block;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    transition: color 0.15s ease;
}
.lms-instructor-courses li a:hover { color: var(--lf-accent) !important; }

@media (max-width: 768px) {
    .lms-instructors-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .lms-instructors-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════════════════
   FEATURE 6: Dynamic Progress Bar — Toast Notifications
   ══════════════════════════════════════════════════════════════════════════ */
.lms-toast {
    position: fixed;
    bottom: 28px;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    background: #1e293b;
    color: #fff;
    padding: 12px 22px;
    border-radius: 100px;
    font-size: 14px;
    font-weight: 600;
    box-shadow: 0 8px 32px rgba(0,0,0,0.25);
    z-index: 99999;
    opacity: 0;
    transition: all 0.3s ease;
    white-space: nowrap;
}
.lms-toast.visible {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* Progress bar pulse animation when updated */
.lms-progress-bar-fill,
.lms-cdp-progress-fill {
    transition: width 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}

/* ══════════════════════════════════════════════════════════════════════════
   NEW DASHBOARD REDESIGN — Quyl-style
   ══════════════════════════════════════════════════════════════════════════ */

.lms-db-wrap { width: 100%; padding: 0; font-family: var(--lf-font); }
.lms-wrap.lms-db-wrap { padding: 0 !important; max-width: none !important; margin: 0 !important; }

/* ── Notices ── */
.lms-db-notice {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 20px; font-size: 13px; font-weight: 500;
    margin-bottom: 0; border-radius: 0;
}
.lms-db-notice.success { background: #f0fdf4; color: #166534; border-bottom: 1px solid #bbf7d0; }
.lms-db-notice.warning { background: #fffbeb; color: #92400e; border-bottom: 1px solid #fde68a; }
.lms-db-notice a { color: inherit; font-weight: 700; margin-left: 8px; }

/* ── Header ── */
.lms-db-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 20px 28px; background: var(--lf-white);
    border-bottom: 1px solid var(--lf-border);
    flex-wrap: wrap; gap: 12px;
}
.lms-db-header-left { display: flex; align-items: center; }
.lms-db-greeting    { display: flex; align-items: center; gap: 12px; }
.lms-db-avatar-sm {
    width: 40px; height: 40px; border-radius: 50%;
    background: linear-gradient(135deg, var(--lf-accent), var(--lf-accent-dark));
    color: #fff; font-size: 16px; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.lms-db-welcome { font-size: 12px; color: var(--lf-muted); }
.lms-db-name    { font-size: 18px; font-weight: 700; color: var(--lf-text); }
.lms-db-header-right { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.lms-db-btn-primary {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 18px; background: var(--lf-accent);
    color: #fff !important; font-size: 13px; font-weight: 600;
    border: none; border-radius: 8px; cursor: pointer;
    text-decoration: none !important; transition: background 0.15s;
}
.lms-db-btn-primary:hover { background: var(--lf-accent-dark); }
.lms-db-btn-ghost {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 14px; background: var(--lf-bg);
    color: var(--lf-muted) !important; font-size: 13px; font-weight: 500;
    border: 1px solid var(--lf-border); border-radius: 8px; cursor: pointer;
    text-decoration: none !important; transition: all 0.15s;
}
.lms-db-btn-ghost:hover { color: var(--lf-text) !important; background: var(--lf-border); }

/* ── Stat Cards ── */
.lms-db-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border-bottom: 1px solid var(--lf-border);
}
.lms-db-stat-card {
    display: flex; align-items: center; gap: 14px;
    padding: 22px 24px;
    border-right: 1px solid var(--lf-border);
    background: var(--lf-white);
    transition: background 0.15s;
}
.lms-db-stat-card:last-child { border-right: none; }
.lms-db-stat-card:hover { background: var(--lf-bg); }
.lms-db-stat-icon {
    width: 44px; height: 44px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.lms-db-stat-num   { font-size: 24px; font-weight: 800; color: var(--lf-text); line-height: 1; }
.lms-db-stat-label { font-size: 12px; color: var(--lf-muted); margin-top: 3px; font-weight: 500; }

/* ── Resume Banner ── */
.lms-db-resume {
    display: flex; align-items: center; gap: 16px;
    padding: 16px 28px;
    background: linear-gradient(135deg, var(--lf-accent) 0%, var(--lf-accent-dark) 100%);
    flex-wrap: wrap;
}
.lms-db-resume-icon {
    width: 40px; height: 40px; border-radius: 50%;
    background: rgba(255,255,255,0.15);
    display: flex; align-items: center; justify-content: center;
    color: #fff; flex-shrink: 0;
}
.lms-db-resume-body { flex: 1; min-width: 180px; }
.lms-db-resume-label  { font-size: 11px; color: rgba(255,255,255,0.7); font-weight: 600; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 2px; }
.lms-db-resume-course { font-size: 14px; font-weight: 700; color: #fff; margin-bottom: 6px; }
.lms-db-resume-pct    { font-size: 12px; font-weight: 400; opacity: .8; margin-left: 8px; }
.lms-db-resume-bar {
    height: 4px; background: rgba(255,255,255,0.2); border-radius: 100px; overflow: hidden;
}
.lms-db-resume-bar-fill {
    height: 100%; background: rgba(255,255,255,0.85); border-radius: 100px;
    transition: width .6s ease;
}
.lms-db-resume-btn {
    display: inline-flex; align-items: center;
    padding: 10px 20px;
    background: rgba(255,255,255,0.15); color: #fff !important;
    font-size: 13px; font-weight: 700;
    border: 1.5px solid rgba(255,255,255,0.3); border-radius: 8px;
    text-decoration: none !important; transition: background .15s; white-space: nowrap;
    flex-shrink: 0;
}
.lms-db-resume-btn:hover { background: rgba(255,255,255,0.25); color: #fff !important; }

/* ── Two-column layout ── */
.lms-db-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    align-items: start;
    min-height: calc(100vh - 200px);
}

/* ── Main (left) ── */
.lms-db-main {
    padding: 24px 28px;
    border-right: 1px solid var(--lf-border);
}
.lms-db-section-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 20px; flex-wrap: wrap; gap: 10px;
}
.lms-db-section-title {
    font-size: 17px !important; font-weight: 700 !important;
    color: var(--lf-text) !important; margin: 0 !important;
}
.lms-db-section-tabs { display: flex; gap: 2px; background: var(--lf-bg); border-radius: 8px; padding: 3px; }
.lms-db-tab {
    padding: 6px 16px; font-size: 13px; font-weight: 600;
    border: none; border-radius: 6px; cursor: pointer;
    background: transparent; color: var(--lf-muted); transition: all .15s;
}
.lms-db-tab.active { background: var(--lf-white); color: var(--lf-text); box-shadow: 0 1px 3px rgba(0,0,0,0.1); }

/* ── Course Row ── */
.lms-db-course-row {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid var(--lf-border);
    transition: background .15s;
}
.lms-db-course-row:last-child { border-bottom: none; }
.lms-db-course-row:hover { background: var(--lf-bg); margin: 0 -8px; padding-left: 8px; padding-right: 8px; border-radius: 8px; }
.lms-db-course-thumb {
    width: 52px; height: 52px; border-radius: 10px; overflow: hidden;
    flex-shrink: 0; position: relative;
}
.lms-db-course-thumb img { width: 100%; height: 100%; object-fit: cover; }
.lms-db-course-thumb-ph {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, #e0f2fe, #bae6fd);
    display: flex; align-items: center; justify-content: center;
    color: var(--lf-accent);
}
.lms-db-course-thumb-ph.done { background: linear-gradient(135deg, #dcfce7, #bbf7d0); color: #16a34a; }
.lms-db-completed-badge {
    position: absolute; bottom: -2px; right: -2px;
    width: 18px; height: 18px; border-radius: 50%;
    background: #16a34a; color: #fff;
    font-size: 10px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    border: 2px solid var(--lf-white);
}
.lms-db-course-info { flex: 1; min-width: 0; }
.lms-db-course-name { font-size: 14px; font-weight: 600; color: var(--lf-text); margin-bottom: 3px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lms-db-course-meta { font-size: 12px; color: var(--lf-muted); margin-bottom: 6px; }
.lms-db-progress-wrap { display: flex; align-items: center; gap: 8px; }
.lms-db-progress-bar  { flex: 1; height: 6px; background: var(--lf-border); border-radius: 100px; overflow: hidden; }
.lms-db-progress-fill { height: 100%; background: linear-gradient(90deg, var(--lf-accent), #0ea5e9); border-radius: 100px; transition: width .6s ease; }
.lms-db-progress-pct  { font-size: 11px; font-weight: 700; color: var(--lf-accent); min-width: 32px; text-align: right; }
.lms-db-course-actions { display: flex; gap: 8px; flex-shrink: 0; flex-wrap: wrap; }
.lms-db-btn-sm {
    display: inline-flex; align-items: center;
    padding: 7px 14px; background: var(--lf-accent);
    color: #fff !important; font-size: 12px; font-weight: 600;
    border: none; border-radius: 7px; cursor: pointer;
    text-decoration: none !important; transition: background .15s; white-space: nowrap;
}
.lms-db-btn-sm:hover { background: var(--lf-accent-dark); color: #fff !important; }
.lms-db-btn-sm.outline {
    background: transparent; color: var(--lf-accent) !important;
    border: 1.5px solid var(--lf-accent);
}
.lms-db-btn-sm.outline:hover { background: var(--lf-accent-soft); }
.lms-db-btn-cert {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 7px 12px; background: rgba(245,158,11,0.08);
    color: #b45309 !important; font-size: 12px; font-weight: 600;
    border: 1.5px solid rgba(245,158,11,0.3); border-radius: 7px;
    cursor: pointer; transition: all .15s; white-space: nowrap;
}
.lms-db-btn-cert:hover { background: rgba(245,158,11,0.15); }

/* ── Empty state ── */
.lms-db-empty {
    display: flex; flex-direction: column; align-items: center;
    text-align: center; padding: 48px 20px; gap: 8px;
}
.lms-db-empty-icon { color: var(--lf-border); margin-bottom: 8px; }
.lms-db-empty-title { font-size: 16px; font-weight: 700; color: var(--lf-text); }
.lms-db-empty-sub   { font-size: 13px; color: var(--lf-muted); }

/* ── Sidebar ── */
.lms-db-sidebar {
    padding: 0;
    background: var(--lf-bg);
    border-left: 1px solid var(--lf-border);
    display: flex; flex-direction: column;
}

/* Profile Card */
.lms-db-profile {
    background: var(--lf-white);
    border-bottom: 1px solid var(--lf-border);
    padding: 24px 20px;
    text-align: center;
}
.lms-db-profile-avatar {
    width: 72px; height: 72px; border-radius: 50%;
    background: linear-gradient(135deg, var(--lf-accent), var(--lf-accent-dark));
    color: #fff; font-size: 28px; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 12px;
    border: 3px solid var(--lf-border);
}
.lms-db-profile-name  { font-size: 16px; font-weight: 700; color: var(--lf-text); margin-bottom: 3px; }
.lms-db-profile-email { font-size: 12px; color: var(--lf-muted); word-break: break-all; margin-bottom: 10px; }
.lms-db-verified {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: 11px; font-weight: 600;
    background: rgba(22,163,74,0.1); color: #16a34a;
    border: 1px solid rgba(22,163,74,0.2); border-radius: 100px;
    padding: 3px 10px; margin-bottom: 14px;
}
.lms-db-profile-stats {
    display: grid; grid-template-columns: repeat(3, 1fr);
    border: 1px solid var(--lf-border); border-radius: 10px; overflow: hidden;
    margin-top: 4px;
}
.lms-db-pstat {
    padding: 10px 8px; text-align: center;
    border-right: 1px solid var(--lf-border); font-size: 11px;
    color: var(--lf-muted); font-weight: 500;
}
.lms-db-pstat:last-child { border-right: none; }
.lms-db-pstat span { display: block; font-size: 20px; font-weight: 800; color: var(--lf-accent); margin-bottom: 2px; }

/* Quick Actions */
.lms-db-quick { padding: 12px; border-bottom: 1px solid var(--lf-border); background: var(--lf-white); }
.lms-db-quick-item {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 10px; border-radius: 8px;
    color: var(--lf-text) !important; text-decoration: none !important;
    font-size: 13px; font-weight: 500; transition: background .15s;
}
.lms-db-quick-item:hover { background: var(--lf-bg); }
.lms-db-quick-icon {
    width: 32px; height: 32px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.lms-db-quick-arrow { margin-left: auto; color: var(--lf-muted); }

/* License Card */
.lms-db-license { padding: 16px 20px; background: var(--lf-white); border-top: 1px solid var(--lf-border); }
.lms-db-license-label {
    display: flex; align-items: center; gap: 6px;
    font-size: 11px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .5px; color: var(--lf-muted); margin-bottom: 10px;
}
.lms-db-license-form { display: flex; gap: 8px; margin-bottom: 6px; }
.lms-db-license-form input { flex: 1; font-size: 13px; min-width: 0; }
.lms-db-license-form button {
    padding: 0 12px; background: var(--lf-accent); color: #fff;
    border: none; border-radius: 7px; font-size: 12px; font-weight: 700;
    cursor: pointer; white-space: nowrap;
}
.lms-db-license-form button:hover { background: var(--lf-accent-dark); }
.lms-db-license-hint { font-size: 11px; color: var(--lf-muted); }

/* ── Responsive ── */
@media (max-width: 900px) {
    .lms-db-stats { grid-template-columns: repeat(2, 1fr); }
    .lms-db-stat-card:nth-child(2) { border-right: none; }
    .lms-db-stat-card:nth-child(3) { border-top: 1px solid var(--lf-border); }
    .lms-db-stat-card:nth-child(4) { border-top: 1px solid var(--lf-border); }
    .lms-db-layout { grid-template-columns: 1fr; }
    .lms-db-sidebar { border-left: none; border-top: 1px solid var(--lf-border); }
}
@media (max-width: 600px) {
    .lms-db-header { padding: 14px 16px; }
    .lms-db-header-right .lms-db-btn-ghost span { display: none; }
    .lms-db-stats { grid-template-columns: repeat(2, 1fr); }
    .lms-db-main { padding: 16px; }
    .lms-db-resume { padding: 14px 16px; }
    .lms-db-course-row { flex-wrap: wrap; }
    .lms-db-course-actions { width: 100%; justify-content: flex-end; }
    .lms-db-course-name { font-size: 13px; }
    .lms-db-stat-card { padding: 16px; }
    .lms-db-stat-num { font-size: 20px; }
}
@media (max-width: 400px) {
    .lms-db-stats { grid-template-columns: 1fr 1fr; }
    .lms-db-course-thumb { width: 44px; height: 44px; }
}/* ── Course Detail Page (CDP) — single-column, mobile-first ──────────────── */

.lms-cdp-wrap {
    width: 100%;
    padding: 0;
}

.lms-cdp-single {
    max-width: 780px;
    margin: 0 auto;
    padding: 16px 16px 60px;
    display: flex;
    flex-direction: column;
    gap: 0;
}

/* Breadcrumb */
.lms-cdp-breadcrumb {
    display: flex; align-items: center; gap: 12px;
    padding: 16px 0 12px;
    font-size: 13px;
}
.lms-cdp-breadcrumb a { color: var(--lf-accent); text-decoration: none; font-weight: 500; }
.lms-cdp-breadcrumb a:hover { text-decoration: underline; }
.lms-cdp-badge {
    display: inline-block;
    padding: 3px 12px; border-radius: 100px;
    font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px;
    background: var(--lf-accent-soft); color: var(--lf-accent);
    border: 1px solid rgba(3,105,161,.2);
}

/* 1. Image */
.lms-cdp-media {
    width: 100%; border-radius: 14px; overflow: hidden;
    margin-bottom: 20px;
    aspect-ratio: 16/9;
    background: var(--lf-border);
}
.lms-cdp-thumb {
    width: 100%; height: 100%; object-fit: cover; display: block;
}

/* 2. Title */
.lms-cdp-title {
    font-size: 26px !important; font-weight: 800 !important;
    color: var(--lf-text) !important; line-height: 1.25 !important;
    margin: 0 0 14px !important;
}

/* 3. Meta row */
.lms-cdp-meta-row {
    display: flex; flex-wrap: wrap; gap: 6px 16px;
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--lf-border);
}
.lms-cdp-meta-item {
    display: flex; align-items: center; gap: 5px;
    font-size: 13px; color: var(--lf-muted); font-weight: 500;
}
.lms-cdp-meta-item svg { flex-shrink: 0; color: var(--lf-accent); }

/* 4. About / sections */
.lms-cdp-section { margin-bottom: 28px; }
.lms-cdp-section-title {
    font-size: 18px !important; font-weight: 700 !important;
    color: var(--lf-text) !important; margin: 0 0 14px !important;
    display: flex; align-items: center; gap: 10px;
}
.lms-cdp-section-count {
    font-size: 12px; font-weight: 600;
    background: var(--lf-accent-soft); color: var(--lf-accent);
    padding: 3px 10px; border-radius: 100px;
}
.lms-cdp-description {
    font-size: 15px; color: var(--lf-text); line-height: 1.75;
}
.lms-cdp-description p { margin: 0 0 12px; }
.lms-cdp-description p:last-child { margin-bottom: 0; }

/* 5. Enroll card */
.lms-cdp-enroll-card {
    background: var(--lf-white);
    border: 1.5px solid var(--lf-border);
    border-radius: 16px;
    padding: 24px;
    margin-bottom: 32px;
    box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
.lms-cdp-price-block { margin-bottom: 14px; }
.lms-cdp-price {
    font-size: 32px; font-weight: 800; color: var(--lf-text);
}
.lms-cdp-price.free { color: var(--lf-accent); }

.lms-cdp-enrolled-badge {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(22,163,74,.1); color: #16a34a;
    font-size: 13px; font-weight: 700;
    padding: 8px 16px; border-radius: 8px;
    margin-bottom: 12px; border: 1px solid rgba(22,163,74,.2);
}
.lms-cdp-btn-enroll {
    display: block; width: 100%;
    padding: 14px; text-align: center;
    background: var(--lf-accent); color: #fff !important;
    font-size: 15px; font-weight: 700;
    border: none; border-radius: 10px; cursor: pointer;
    text-decoration: none !important;
    transition: background .15s;
    margin-bottom: 10px;
}
.lms-cdp-btn-enroll:hover { background: var(--lf-accent-dark); }
.lms-cdp-btn-outline {
    display: block; width: 100%;
    padding: 12px; text-align: center;
    background: transparent; color: var(--lf-accent) !important;
    font-size: 14px; font-weight: 600;
    border: 1.5px solid var(--lf-accent); border-radius: 10px;
    text-decoration: none !important; transition: all .15s;
    margin-bottom: 10px;
}
.lms-cdp-btn-outline:hover { background: var(--lf-accent-soft); }

.lms-cdp-coupon-row {
    display: flex; gap: 8px; margin-top: 12px;
}
.lms-cdp-coupon-row input { flex: 1; font-size: 13px; }
.lms-cdp-coupon-btn {
    padding: 0 16px; background: var(--lf-accent); color: #fff;
    border: none; border-radius: 8px; font-size: 13px; font-weight: 600;
    cursor: pointer; white-space: nowrap;
}
.lms-coupon-msg { font-size: 12px; margin-top: 6px; min-height: 18px; }

.lms-cdp-includes {
    margin-top: 18px; padding-top: 16px;
    border-top: 1px solid var(--lf-border);
    display: flex; flex-direction: column; gap: 10px;
}
.lms-cdp-include-item {
    display: flex; align-items: center; gap: 10px;
    font-size: 13px; color: var(--lf-muted);
}
.lms-cdp-include-item svg { color: var(--lf-accent); flex-shrink: 0; }

.lms-cdp-verify-block {
    display: flex; flex-direction: column; gap: 4px;
    background: #fffbeb; border: 1px solid #fde68a;
    border-radius: 10px; padding: 14px; margin-bottom: 10px;
    font-size: 13px; color: #92400e;
}
.lms-cdp-verify-block strong { font-size: 14px; }
.lms-cdp-verify-block a { color: #92400e; font-weight: 700; }

/* Progress */
.lms-cdp-progress {
    margin-bottom: 14px;
}
.lms-cdp-progress-top {
    display: flex; justify-content: space-between;
    font-size: 12px; color: var(--lf-muted); margin-bottom: 6px;
}
.lms-cdp-progress-bar {
    height: 6px; background: var(--lf-border); border-radius: 100px; overflow: hidden;
}
.lms-cdp-progress-fill {
    height: 100%; background: var(--lf-accent); border-radius: 100px;
    transition: width .6s ease;
}

/* 6. Curriculum */
.lms-cdp-curriculum {
    border: 1px solid var(--lf-border); border-radius: 12px; overflow: hidden;
}
.lms-cdp-lesson {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--lf-border);
    transition: background .12s;
}
.lms-cdp-lesson:last-child { border-bottom: none; }
.lms-cdp-lesson:hover { background: var(--lf-bg); }
.lms-cdp-lesson.done { background: rgba(22,163,74,.04); }
.lms-cdp-lesson-num {
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--lf-bg); border: 1px solid var(--lf-border);
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 700; color: var(--lf-muted);
    flex-shrink: 0;
}
.lms-cdp-lesson.done .lms-cdp-lesson-num { background: rgba(22,163,74,.1); border-color: #16a34a; color: #16a34a; }
.lms-cdp-lesson.locked .lms-cdp-lesson-num { color: var(--lf-border); }
.lms-cdp-lesson-info { flex: 1; min-width: 0; }
.lms-cdp-lesson-title {
    font-size: 14px; font-weight: 500; color: var(--lf-text);
    text-decoration: none; display: block;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.lms-cdp-lesson-title.locked { color: var(--lf-muted); }
.lms-cdp-lesson-title:hover { color: var(--lf-accent); }
.lms-cdp-lesson-tags { display: flex; gap: 6px; flex-shrink: 0; }
.lms-cdp-tag {
    font-size: 10px; font-weight: 700; padding: 2px 8px;
    border-radius: 100px; text-transform: uppercase; letter-spacing: .3px;
}
.lms-cdp-tag.preview { background: rgba(3,105,161,.1); color: var(--lf-accent); }
.lms-cdp-tag.video   { background: rgba(239,68,68,.1); color: #dc2626; }

/* Mobile */
@media (max-width: 600px) {
    .lms-cdp-single { padding: 12px 12px 48px; }
    .lms-cdp-title  { font-size: 22px !important; }
    .lms-cdp-enroll-card { padding: 18px; }
    .lms-cdp-price  { font-size: 26px; }
    .lms-cdp-btn-enroll { font-size: 14px; padding: 12px; }
    .lms-cdp-lesson { padding: 12px; }
    .lms-cdp-lesson-title { font-size: 13px; }
}

/* ══════════════════════════════════════════════════════════════════════════
   AUTH PAGES (Login / Register)
   ══════════════════════════════════════════════════════════════════════════ */
.lms-auth-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 60vh;
    padding: 40px 24px;
    width: 100%;
}

.lms-auth-box {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 44px 40px;
    width: 100%;
    max-width: 440px;
    box-shadow: var(--lf-shadow-lg);
}

.lms-auth-logo {
    width: 52px; height: 52px;
    background: var(--lf-accent);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    margin: 0 auto 24px;
}

.lms-auth-title {
    font-size: 24px !important;
    font-weight: 800 !important;
    color: var(--lf-text) !important;
    text-align: center;
    margin: 0 0 6px !important;
    border: none !important;
}
.lms-auth-sub {
    font-size: 14px;
    color: var(--lf-muted);
    text-align: center;
    margin: 0 0 28px;
}
.lms-auth-footer {
    text-align: center;
    font-size: 13px;
    color: var(--lf-muted);
    margin: 16px 0 0;
}
.lms-auth-footer a { color: var(--lf-accent); font-weight: 600; }

/* Checkout success */
.lms-success-box { text-align: center; }
.lms-success-icon { font-size: 56px; margin-bottom: 20px; }

/* ══════════════════════════════════════════════════════════════════════════
   COURSE CATALOG
   ══════════════════════════════════════════════════════════════════════════ */
.lms-catalog-header { margin-bottom: 36px; }
.lms-catalog-title {
    font-size: 32px !important;
    font-weight: 800 !important;
    color: var(--lf-text) !important;
    margin: 0 0 6px !important;
}
.lms-catalog-sub { font-size: 15px; color: var(--lf-muted); margin: 0; }

.lms-course-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    width: 100%;
}

.lms-course-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    overflow: hidden;
    transition: var(--lf-transition);
    display: flex;
    flex-direction: column;
}
.lms-course-card:hover {
    box-shadow: var(--lf-shadow-lg);
    transform: translateY(-3px);
}

.lms-card-thumb-link { display: block; aspect-ratio: 16/9; overflow: hidden; }
.lms-card-thumb { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.lms-course-card:hover .lms-card-thumb { transform: scale(1.04); }
.lms-card-thumb-placeholder {
    width: 100%; aspect-ratio: 16/9;
    background: linear-gradient(135deg, #e0f2fe, #bae6fd);
    display: flex; align-items: center; justify-content: center;
    font-size: 40px;
}

.lms-card-body { padding: 20px; display: flex; flex-direction: column; flex: 1; gap: 10px; }
.lms-card-title {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--lf-text) !important;
    margin: 0 !important;
    line-height: 1.35 !important;
}
.lms-card-title a { color: inherit !important; text-decoration: none !important; }
.lms-card-title a:hover { color: var(--lf-accent) !important; }

.lms-card-meta {
    display: flex; flex-wrap: wrap; gap: 8px 14px;
    font-size: 12px; color: var(--lf-muted);
}
.lms-card-footer {
    display: flex; align-items: center; justify-content: space-between;
    padding-top: 14px; border-top: 1px solid var(--lf-border);
    margin-top: auto;
}
.lms-price-free  { font-size: 18px; font-weight: 800; color: var(--lf-success); }
.lms-price-amount { font-size: 20px; font-weight: 800; color: var(--lf-text); }

/* ══════════════════════════════════════════════════════════════════════════
   SINGLE COURSE PAGE
   ══════════════════════════════════════════════════════════════════════════ */
.lms-course-hero {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 0;
    background: linear-gradient(135deg, #0c4a6e 0%, #0369a1 100%);
    border-radius: var(--lf-radius);
    overflow: hidden;
    margin-bottom: 40px;
    min-height: 220px;
    align-items: stretch;
}
.lms-course-hero-content {
    padding: 40px 44px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 16px;
    color: #fff;
}
.lms-hero-badge {
    align-self: flex-start;
    background: rgba(255,255,255,0.15) !important;
    color: #fff !important;
    backdrop-filter: blur(4px);
}
.lms-course-title {
    font-size: 28px !important;
    font-weight: 800 !important;
    color: #fff !important;
    margin: 0 !important;
    line-height: 1.25 !important;
}
.lms-course-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    font-size: 14px;
    color: rgba(255,255,255,0.80);
    align-items: center;
    margin: 0;
}
.lms-course-stats span {
    display: flex;
    align-items: center;
    gap: 5px;
    white-space: nowrap;
}
.lms-course-hero-image {
    position: relative;
    overflow: hidden;
    background: rgba(0,0,0,0.2);
}
.lms-course-hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform 0.4s ease;
}
.lms-course-hero:hover .lms-course-hero-image img {
    transform: scale(1.03);
}
@media (max-width: 768px) {
    .lms-course-hero {
        grid-template-columns: 1fr;
    }
    .lms-course-hero-image {
        height: 200px;
        order: -1;
    }
    .lms-course-hero-content {
        padding: 28px 24px;
    }
    .lms-course-title { font-size: 22px !important; }
}
.lms-course-layout {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 32px;
    align-items: start;
    position: relative;
    width: 100%;
}
.lms-course-main {
    display: flex;
    flex-direction: column;
    gap: 28px;
    min-width: 0;
}
.lms-course-sidebar {
    position: sticky;
    top: 90px;
    align-self: start;
    z-index: 10;
}

/* Progress card */
.lms-progress-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 20px 24px;
}
.lms-progress-header { display: flex; justify-content: space-between; font-size: 14px; font-weight: 600; margin-bottom: 10px; }
.lms-progress-bar-wrap { background: #f3f4f6; border-radius: 100px; height: 8px; overflow: hidden; }
.lms-progress-bar-fill { height: 100%; background: linear-gradient(90deg, var(--lf-accent), #818cf8); border-radius: 100px; transition: width 0.6s ease; }
.lms-progress-sub { font-size: 12px; color: var(--lf-muted); margin-top: 8px; }

/* Description */
.lms-course-description {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 28px 32px;
}
.lms-course-description h2 {
    font-size: 18px !important; font-weight: 700 !important;
    color: var(--lf-text) !important; margin: 0 0 16px !important;
}
.lms-course-description-body { font-size: 14px; line-height: 1.8; color: var(--lf-muted); }

/* Curriculum */
.lms-curriculum {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    overflow: hidden;
}
.lms-curriculum h2 {
    font-size: 18px !important; font-weight: 700 !important;
    color: var(--lf-text) !important; margin: 0 !important;
    padding: 20px 24px;
    border-bottom: 1px solid var(--lf-border);
}
.lms-lesson-row {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 24px;
    border-bottom: 1px solid var(--lf-border);
    transition: var(--lf-transition);
}
.lms-lesson-row:last-child { border-bottom: none; }
.lms-lesson-row:hover { background: #f9fafb; }
.lms-lesson-row.done { background: var(--lf-success-bg); }
.lms-lesson-row.locked { opacity: 0.55; }
.lms-lesson-number {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: #f3f4f6;
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 700; flex-shrink: 0;
    color: var(--lf-muted);
}
.lms-lesson-row.done .lms-lesson-number { background: #dcfce7; color: var(--lf-success); }
.lms-lesson-info { flex: 1; }
.lms-lesson-title-link { font-size: 14px; font-weight: 500; color: var(--lf-text); text-decoration: none; }
.lms-lesson-title-link:hover { color: var(--lf-accent); }
.lms-lesson-title-locked { font-size: 14px; color: var(--lf-muted); }
.lms-lesson-right { display: flex; gap: 6px; align-items: center; margin-left: auto; }
.lms-check { color: var(--lf-success); font-weight: 700; }

/* Enroll card */
.lms-enroll-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 28px 24px;
    box-shadow: var(--lf-shadow-lg);
}
.lms-enroll-price { font-size: 28px; font-weight: 800; color: var(--lf-text); margin-bottom: 18px; }
.lms-enrolled-badge {
    background: var(--lf-success-bg);
    color: var(--lf-success);
    font-size: 13px; font-weight: 700;
    text-align: center;
    padding: 10px;
    border-radius: var(--lf-radius-sm);
    margin-bottom: 12px;
}
.lms-enroll-features {
    list-style: none; margin: 20px 0 0; padding: 0;
    display: flex; flex-direction: column; gap: 10px;
    font-size: 13px; color: var(--lf-muted);
}
.lms-enroll-features li { display: flex; align-items: center; gap: 8px; }

/* ══════════════════════════════════════════════════════════════════════════
   DASHBOARD
   ══════════════════════════════════════════════════════════════════════════ */
.lms-dash-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 32px;
}
.lms-dash-title { font-size: 28px !important; font-weight: 800 !important; margin: 0 0 4px !important; }
.lms-dash-sub { font-size: 15px; color: var(--lf-muted); margin: 0; }

.lms-dash-stats {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 16px; margin-bottom: 40px;
}
.lms-dash-stat {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 24px;
    text-align: center;
}
.lms-dash-stat-num { font-size: 32px; font-weight: 800; color: var(--lf-accent); }
.lms-dash-stat-label { font-size: 13px; color: var(--lf-muted); margin-top: 4px; }

.lms-section-title {
    font-size: 20px !important; font-weight: 700 !important;
    color: var(--lf-text) !important; margin: 0 0 20px !important;
}

.lms-dash-course-list { display: flex; flex-direction: column; gap: 14px; margin-bottom: 40px; }
.lms-dash-course-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 20px 24px;
    display: flex; align-items: center; gap: 20px;
}
.lms-dash-course-thumb {
    width: 80px; height: 56px;
    object-fit: cover;
    border-radius: var(--lf-radius-sm); flex-shrink: 0;
}
.lms-dash-course-thumb-placeholder {
    width: 80px; height: 56px;
    background: linear-gradient(135deg, #e0f2fe, #bae6fd);
    border-radius: var(--lf-radius-sm);
    display: flex; align-items: center; justify-content: center;
    font-size: 24px; flex-shrink: 0;
}
.lms-dash-course-info { flex: 1; min-width: 0; }
.lms-dash-course-title { font-size: 15px !important; font-weight: 700 !important; margin: 0 0 10px !important; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lms-dash-progress { display: flex; flex-direction: column; gap: 4px; }
.lms-progress-label { font-size: 12px; color: var(--lf-muted); }
.lms-dash-course-actions { display: flex; gap: 8px; flex-shrink: 0; }

/* Account */
.lms-dash-account { margin-top: 8px; }
.lms-account-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 20px 24px;
    display: flex; align-items: center; gap: 16px;
}
.lms-account-avatar {
    width: 44px; height: 44px;
    background: var(--lf-accent);
    color: #fff; font-weight: 800; font-size: 18px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.lms-account-info { flex: 1; }
.lms-account-name  { font-size: 15px; font-weight: 700; }
.lms-account-email { font-size: 13px; color: var(--lf-muted); }

/* ══════════════════════════════════════════════════════════════════════════
   LESSON PLAYER
   ══════════════════════════════════════════════════════════════════════════ */
/* ── Lesson Player ──────────────────────────────────────────────────────── */
/* ════════════════════════════════════════════════════════════
   LESSON PLAYER — Full viewport, Udemy-style
   ════════════════════════════════════════════════════════════ */

/* Break out of lms-wrap constraints */
.lms-player-wrap {
    padding: 0 !important;
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
}

/* ── Top bar ── */
.lms-player-topbar {
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 20px;
    height: 52px;
    background: #1c1d1f;
    border-bottom: 1px solid rgba(255,255,255,.1);
    position: sticky; top: 0; z-index: 100;
}
.lms-breadcrumb {
    display: flex; align-items: center; gap: 6px;
    font-size: 13px; color: rgba(255,255,255,.7);
    flex-wrap: wrap; overflow: hidden;
}
.lms-breadcrumb a {
    color: rgba(255,255,255,.85) !important; text-decoration: none !important;
    font-weight: 500; white-space: nowrap;
}
.lms-breadcrumb a:hover { color: #fff !important; }
.lms-breadcrumb span { color: rgba(255,255,255,.4); }
/* Truncate long course name on breadcrumb */
.lms-breadcrumb > a:nth-child(3) {
    max-width: 260px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.lms-sidebar-toggle {
    display: none;
    padding: 7px 14px; font-size: 12px; font-weight: 600;
    background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
    border-radius: 6px; cursor: pointer; color: #fff; white-space: nowrap;
}

/* ── Main 2-column grid ── */
.lms-player-layout {
    display: grid;
    grid-template-columns: 1fr 340px;
    min-height: calc(100vh - 52px);
    width: 100%;
    background: var(--lf-bg);
}

/* ── Main content column ── */
.lms-player-main {
    display: flex; flex-direction: column;
    background: var(--lf-white);
    overflow: hidden;
}

/* Video — edge-to-edge, black bg, no padding */
.lms-video-container {
    width: 100%;
    aspect-ratio: 16/9;
    background: #000;
    flex-shrink: 0;
}
.lms-video-container iframe,
.lms-video-container video {
    width: 100%; height: 100%; display: block; border: none;
}
.lms-no-video {
    aspect-ratio: 16/9; background: #111;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 10px; color: rgba(255,255,255,.4); font-size: 40px;
}
.lms-no-video p { font-size: 14px; margin: 0; color: rgba(255,255,255,.4); }

/* Below-video content area */
.lms-player-meta {
    padding: 24px 32px 0;
    border-bottom: 1px solid var(--lf-border);
    margin-bottom: 0;
}
.lms-player-title {
    font-size: 20px !important; font-weight: 700 !important;
    color: var(--lf-text) !important; margin: 0 0 16px !important;
    line-height: 1.35 !important;
}
.lms-player-content {
    font-size: 14px; color: var(--lf-muted); line-height: 1.7;
    padding-bottom: 20px;
}

/* Controls bar — attached right below title */
.lms-player-controls {
    display: flex; align-items: center;
    justify-content: space-between;
    padding: 14px 32px;
    background: var(--lf-white);
    border-bottom: 1px solid var(--lf-border);
    gap: 12px; flex-wrap: wrap;
}
.lms-player-nav-left  { display: flex; align-items: center; gap: 8px; }
.lms-player-nav-center { display: flex; align-items: center; gap: 10px; flex: 1; justify-content: center; flex-wrap: wrap; }
.lms-player-nav-right  { display: flex; align-items: center; gap: 8px; }

.lms-player-nav-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 8px 16px; font-size: 13px; font-weight: 600;
    color: var(--lf-text) !important; text-decoration: none !important;
    background: var(--lf-bg); border: 1px solid var(--lf-border);
    border-radius: 6px; transition: all .15s; white-space: nowrap;
}
.lms-player-nav-btn:hover { border-color: var(--lf-accent); color: var(--lf-accent) !important; }

.lms-player-complete-btn {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 10px 24px; font-size: 14px; font-weight: 700;
    background: var(--lf-accent); color: #fff !important;
    border: none; border-radius: 6px; cursor: pointer;
    transition: background .15s; white-space: nowrap;
    box-shadow: 0 2px 8px rgba(3,105,161,.3);
}
.lms-player-complete-btn:hover { background: var(--lf-accent-dark); }
.lms-player-complete-btn:disabled { opacity: .7; cursor: not-allowed; }

.lms-player-next-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 20px; font-size: 13px; font-weight: 700;
    background: #16a34a; color: #fff !important;
    border: none; border-radius: 6px;
    text-decoration: none !important; transition: background .15s;
}
.lms-player-next-btn:hover { background: #15803d; }

.lms-completed-badge {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 13px; font-weight: 700; color: #16a34a;
    background: #f0fdf4; padding: 8px 14px;
    border-radius: 6px; border: 1px solid #bbf7d0;
}

/* Review box */
.lms-player-review-box {
    margin: 24px 32px;
    background: linear-gradient(135deg, #f0f9ff, #e0f2fe);
    border: 1px solid #bae6fd; border-radius: 12px;
    padding: 22px 24px;
}
.lms-player-review-title {
    font-size: 16px; font-weight: 700; color: var(--lf-text);
    margin-bottom: 14px;
}
.lms-star-picker { display: flex; gap: 6px; margin-bottom: 12px; cursor: pointer; }
.lms-star { font-size: 32px; color: #d1d5db; transition: color .1s; line-height: 1; }
#lms-review-text {
    width: 100%; font-size: 14px;
    border: 1px solid var(--lf-border); border-radius: 8px;
    padding: 10px 12px; resize: vertical; min-height: 80px;
    background: var(--lf-white);
}

/* ── Sidebar ── */
.lms-player-sidebar {
    border-left: 1px solid var(--lf-border);
    background: var(--lf-white);
    position: sticky; top: 52px;
    height: calc(100vh - 52px);
    overflow-y: auto;
    display: flex; flex-direction: column;
}
.lms-player-sidebar-header {
    padding: 14px 16px;
    border-bottom: 1px solid var(--lf-border);
    background: #f9fafb;
    display: flex; justify-content: space-between; align-items: center;
    flex-shrink: 0;
}
.lms-player-sidebar-title {
    font-size: 11px; font-weight: 800;
    text-transform: uppercase; letter-spacing: .7px;
    color: var(--lf-muted);
}
.lms-player-sidebar-progress {
    font-size: 12px; color: var(--lf-accent); font-weight: 700;
    background: var(--lf-accent-soft); padding: 2px 8px;
    border-radius: 100px;
}
.lms-player-lesson-list { display: flex; flex-direction: column; }
.lms-player-lesson-item {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--lf-border);
    text-decoration: none !important;
    color: var(--lf-text) !important;
    transition: background .1s;
    position: relative;
}
.lms-player-lesson-item:last-child { border-bottom: none; }
.lms-player-lesson-item:hover  { background: var(--lf-bg); }
.lms-player-lesson-item.active {
    background: var(--lf-accent-soft);
    border-left: 3px solid var(--lf-accent);
}
.lms-player-lesson-item.active .lms-player-lesson-name { color: var(--lf-accent); font-weight: 700; }
.lms-player-lesson-num {
    width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
    background: var(--lf-bg); border: 1.5px solid var(--lf-border);
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 700; color: var(--lf-muted);
    transition: all .15s;
}
.lms-player-lesson-item.active .lms-player-lesson-num {
    background: var(--lf-accent); border-color: var(--lf-accent); color: #fff;
}
.lms-player-lesson-item.done .lms-player-lesson-num {
    background: #16a34a; border-color: #16a34a; color: #fff;
}
.lms-player-lesson-name {
    flex: 1; font-size: 13px; font-weight: 500; line-height: 1.45;
    color: var(--lf-text);
}
.lms-player-lesson-type { color: var(--lf-muted); flex-shrink: 0; }

/* ── MOBILE ── */
@media (max-width: 900px) {
    .lms-player-layout { grid-template-columns: 1fr 280px; }
}
@media (max-width: 768px) {
    .lms-player-topbar { padding: 0 14px; }
    .lms-breadcrumb > a:nth-child(3) { max-width: 140px; }
    .lms-sidebar-toggle { display: flex; align-items: center; gap: 6px; }
    .lms-player-layout { grid-template-columns: 1fr; min-height: auto; }

    /* Sidebar slides in from right as drawer */
    .lms-player-sidebar {
        position: fixed; top: 0; right: -105%;
        width: 88%; max-width: 340px;
        height: 100vh; z-index: 9999;
        transition: right .28s cubic-bezier(.4,0,.2,1);
        box-shadow: -8px 0 32px rgba(0,0,0,.18);
        border-left: none;
    }
    .lms-player-sidebar.open { right: 0; }

    /* Overlay behind drawer */
    .lms-player-sidebar.open::before {
        content: '';
        position: fixed; inset: 0;
        background: rgba(0,0,0,.5);
        z-index: -1;
    }

    .lms-player-meta { padding: 16px 16px 0; }
    .lms-player-controls { padding: 12px 16px; gap: 10px; }
    .lms-player-nav-left, .lms-player-nav-right { display: none; }
    .lms-player-nav-center { justify-content: center; width: 100%; }
    .lms-player-complete-btn { width: 100%; justify-content: center; padding: 13px; }
    .lms-player-title { font-size: 17px !important; }
    .lms-player-review-box { margin: 16px; }
}

/* ══════════════════════════════════════════════════════════════════════════
   EMPTY STATE
   ══════════════════════════════════════════════════════════════════════════ */
.lms-empty-state {
    text-align: center; padding: 80px 32px;
    color: var(--lf-muted);
}
.lms-empty-icon { font-size: 52px; margin-bottom: 16px; opacity: 0.5; display: block; }
.lms-empty-state h3 { font-size: 20px !important; color: var(--lf-text) !important; margin: 0 0 8px !important; }
.lms-empty-state p  { font-size: 14px; margin: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .lms-course-grid    { grid-template-columns: repeat(2, 1fr); }
    .lms-course-hero    { grid-template-columns: 1fr; }
    .lms-course-layout  { grid-template-columns: 1fr; }
    .lms-course-sidebar { position: static; }
    .lms-player-layout  { grid-template-columns: 1fr; }
    .lms-player-sidebar { position: static; max-height: none; }
}
@media (max-width: 640px) {
    .lms-wrap           { padding: 20px 16px; }
    .lms-course-grid    { grid-template-columns: 1fr; }
    .lms-auth-box       { padding: 32px 24px; }
    .lms-field-row      { grid-template-columns: 1fr; }
    .lms-dash-stats     { grid-template-columns: 1fr; }
    .lms-dash-course-card { flex-wrap: wrap; }
    .lms-dash-course-actions { width: 100%; }
    .lms-course-hero    { padding: 32px 24px; }
}

/* ══════════════════════════════════════════════════════════════════════════
   FAQs — Clean accordion design
   ══════════════════════════════════════════════════════════════════════════ */
.lms-faq-section h2 { margin-bottom: 6px !important; }

.lms-faq-subtitle {
    font-size: 14px;
    color: var(--lf-muted);
    margin: 0 0 28px !important;
}

.lms-faq-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    border: 1.5px solid var(--lf-border);
    border-radius: var(--lf-radius);
    overflow: hidden;
}

.lms-faq-item {
    border-bottom: 1.5px solid var(--lf-border);
}
.lms-faq-item:last-child { border-bottom: none; }

.lms-faq-question {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 24px;
    background: #fff;
    border: none;
    cursor: pointer;
    font-family: var(--lf-font);
    text-align: left;
    transition: background 0.15s ease;
}
.lms-faq-question:hover { background: #f9fafb; }
.lms-faq-item.open .lms-faq-question { background: #f5f3ff; }

.lms-faq-q-text {
    font-size: 15px;
    font-weight: 600;
    color: var(--lf-text);
    line-height: 1.45;
    flex: 1;
}
.lms-faq-item.open .lms-faq-q-text { color: var(--lf-accent); }

.lms-faq-chevron {
    flex-shrink: 0;
    color: var(--lf-muted);
    display: flex;
    align-items: center;
    transition: transform 0.25s ease, color 0.15s;
}
.lms-faq-item.open .lms-faq-chevron {
    transform: rotate(180deg);
    color: var(--lf-accent);
}

.lms-faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}
.lms-faq-item.open .lms-faq-answer {
    max-height: 600px;
}

.lms-faq-answer-inner {
    padding: 0 24px 22px;
    font-size: 14px;
    color: var(--lf-muted);
    line-height: 1.8;
    border-top: 1px solid var(--lf-border);
    padding-top: 18px;
}
.lms-faq-answer-inner p { margin: 0 0 10px; }
.lms-faq-answer-inner p:last-child { margin-bottom: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   Attachments
   ══════════════════════════════════════════════════════════════════════════ */
.lms-attachment-list { display: flex; flex-direction: column; gap: 8px; }
.lms-attachment-row {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 18px;
    border: 1px solid var(--lf-border); border-radius: var(--lf-radius-sm);
    background: var(--lf-white); text-decoration: none !important;
    transition: var(--lf-transition); color: var(--lf-text) !important;
}
.lms-attachment-row:hover { border-color: var(--lf-accent); background: var(--lf-accent-soft); }
.lms-attachment-icon { font-size: 24px; flex-shrink: 0; }
.lms-attachment-title { flex: 1; font-size: 14px; font-weight: 600; }
.lms-attachment-dl { font-size: 12px; color: var(--lf-accent); font-weight: 600; flex-shrink: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   Reviews
   ══════════════════════════════════════════════════════════════════════════ */
.lms-review-form {
    background: #f9fafb; border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius); padding: 20px 24px;
    margin-bottom: 24px;
}
.lms-faq-section .lms-star-picker,
.lms-reviews-section .lms-star-picker { display: flex; flex-direction: row-reverse; gap: 4px; margin-bottom: 4px; }
.lms-reviews-section .lms-star-picker input { display: none; }
.lms-reviews-section .lms-star-picker label {
    font-size: 30px; color: #d1d5db; cursor: pointer;
    transition: color 0.15s;
}
.lms-star-picker label:hover,
.lms-star-picker label:hover ~ label,
.lms-star-picker input:checked ~ label { color: #f59e0b; }

.lms-review-list { display: flex; flex-direction: column; gap: 16px; margin-top: 20px; }
.lms-review-item {
    padding: 18px 20px;
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    background: var(--lf-white);
}
.lms-review-header { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 10px; }
.lms-review-avatar {
    width: 38px; height: 38px; border-radius: 50%;
    background: var(--lf-accent); color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: 15px; flex-shrink: 0;
}
.lms-review-name { font-size: 14px; font-weight: 700; }
.lms-review-stars { color: #f59e0b; font-size: 15px; margin-top: 2px; }
.lms-review-date { font-size: 12px; color: var(--lf-muted); margin-left: 8px; vertical-align: middle; }
.lms-review-text { font-size: 14px; color: var(--lf-muted); line-height: 1.7; margin: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   Coupon input on enroll card
   ══════════════════════════════════════════════════════════════════════════ */
.lms-coupon-row { display: flex; gap: 8px; margin-top: 16px; }
.lms-coupon-row input { flex: 1; font-size: 13px; }
.lms-coupon-msg { font-size: 12px; margin-top: 6px; font-weight: 600; }
.lms-coupon-success { color: var(--lf-success); }
.lms-coupon-error   { color: var(--lf-danger); }

/* ══════════════════════════════════════════════════════════════════════════
   Quiz block on lesson player
   ══════════════════════════════════════════════════════════════════════════ */
.lms-quiz-block {
    background: var(--lf-white); border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius); padding: 28px 32px; margin-top: 24px;
}
.lms-quiz-block h3 { font-size: 18px !important; font-weight: 700 !important; margin: 0 0 20px !important; }
.lms-quiz-question { margin-bottom: 24px; }
.lms-quiz-question-text { font-size: 15px; font-weight: 600; margin-bottom: 12px; }
.lms-quiz-option {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 16px; border: 1.5px solid var(--lf-border);
    border-radius: var(--lf-radius-sm); margin-bottom: 8px;
    cursor: pointer; transition: var(--lf-transition); font-size: 14px;
    background: var(--lf-white);
}
.lms-quiz-option:hover { border-color: var(--lf-accent); background: var(--lf-accent-soft); }
.lms-quiz-option.selected { border-color: var(--lf-accent); background: var(--lf-accent-soft); font-weight: 600; }
.lms-quiz-option.correct  { border-color: var(--lf-success); background: var(--lf-success-bg); }
.lms-quiz-option.wrong    { border-color: var(--lf-danger);  background: var(--lf-danger-bg); }
.lms-quiz-result {
    text-align: center; padding: 28px;
    background: #f9fafb; border-radius: var(--lf-radius); margin-top: 20px;
}
.lms-quiz-score { font-size: 48px; font-weight: 800; color: var(--lf-accent); }
.lms-quiz-pass { color: var(--lf-success); }
.lms-quiz-fail { color: var(--lf-danger); }

/* ══════════════════════════════════════════════════════════════════════════
   Resume banner
   ══════════════════════════════════════════════════════════════════════════ */
.lms-resume-banner {
    background: linear-gradient(135deg, var(--lf-accent), var(--lf-accent-dark));
    color: #fff; border-radius: var(--lf-radius);
    padding: 18px 24px;
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    margin-bottom: 28px;
}
.lms-resume-text { font-size: 14px; font-weight: 600; }
.lms-resume-sub  { font-size: 12px; opacity: 0.8; margin-top: 2px; }
.lms-resume-btn  {
    background: rgba(255,255,255,0.2); color: #fff !important;
    border: 1.5px solid rgba(255,255,255,0.4);
    padding: 9px 18px; border-radius: var(--lf-radius-sm);
    font-size: 13px; font-weight: 700; text-decoration: none !important;
    flex-shrink: 0; transition: var(--lf-transition);
}
.lms-resume-btn:hover { background: rgba(255,255,255,0.35); color: #fff !important; }

/* ══════════════════════════════════════════════════════════════════════════
   AUTH TABS (Password / OTP)
   ══════════════════════════════════════════════════════════════════════════ */
.lms-auth-tabs {
    display: flex; gap: 0;
    border-bottom: 2px solid var(--lf-border);
    margin-bottom: 24px;
}
.lms-auth-tab {
    flex: 1; padding: 10px; background: none; border: none;
    border-bottom: 2px solid transparent; margin-bottom: -2px;
    font-size: 14px; font-weight: 600; color: var(--lf-muted);
    cursor: pointer; transition: var(--lf-transition); font-family: var(--lf-font);
}
.lms-auth-tab.active { color: var(--lf-accent); border-bottom-color: var(--lf-accent); }
.lms-auth-tab:hover  { color: var(--lf-text); }

.lms-link-btn {
    background: none; border: none; color: var(--lf-accent);
    font-size: inherit; cursor: pointer; padding: 0; font-family: var(--lf-font);
    text-decoration: underline;
}

/* ══════════════════════════════════════════════════════════════════════════
   STICKY SIDEBAR — force it to work across all themes
   ══════════════════════════════════════════════════════════════════════════ */
.lms-course-layout {
    display: grid !important;
    grid-template-columns: 1fr 340px !important;
    gap: 32px !important;
    align-items: start !important;
}
.lms-course-sidebar {
    position: sticky !important;
    top: 90px !important;
    align-self: start !important;
}
.lms-enroll-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 28px 24px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.10);
}

@media (max-width: 900px) {
    .lms-course-layout {
        grid-template-columns: 1fr !important;
    }
    .lms-course-sidebar {
        position: static !important;
        order: -1; /* Show enroll card ABOVE content on mobile */
    }
}

/* ══════════════════════════════════════════════════════════════════════════
   Course Search & Pagination
   ══════════════════════════════════════════════════════════════════════════ */
.lms-search-form { margin-bottom: 28px; }
.lms-search-wrap {
    display: flex; gap: 10px; align-items: center;
    max-width: 480px;
}
.lms-search-input {
    flex: 1 !important; width: auto !important;
    border: 1.5px solid var(--lf-border) !important;
    border-radius: var(--lf-radius-sm) !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    background: #fff !important;
}
.lms-search-input:focus {
    border-color: var(--lf-accent) !important;
    box-shadow: 0 0 0 3px var(--lf-accent-soft) !important;
}
.lms-search-results-count {
    font-size: 14px; color: var(--lf-muted);
    margin: 12px 0 0 !important;
}
.lms-pagination {
    display: flex; gap: 8px; justify-content: center;
    margin-top: 36px; flex-wrap: wrap;
}
.lms-page-btn {
    width: 38px; height: 38px;
    display: flex; align-items: center; justify-content: center;
    border: 1.5px solid var(--lf-border);
    border-radius: var(--lf-radius-sm);
    font-size: 14px; font-weight: 600;
    color: var(--lf-text) !important;
    text-decoration: none !important;
    transition: var(--lf-transition);
    background: #fff;
}
.lms-page-btn:hover { border-color: var(--lf-accent); color: var(--lf-accent) !important; }
.lms-page-btn.active {
    background: var(--lf-accent); border-color: var(--lf-accent);
    color: #fff !important;
}

/* ══════════════════════════════════════════════════════════════════════════
   Email verification notices
   ══════════════════════════════════════════════════════════════════════════ */
.lms-verify-notice {
    background: #fffbeb; border: 1px solid #fde68a;
    border-radius: var(--lf-radius-sm); padding: 14px 18px;
    font-size: 14px; color: #92400e;
    margin-bottom: 20px;
    display: flex; align-items: flex-start; gap: 10px;
}
.lms-verify-notice strong { color: #78350f; }
.lms-verified-badge {
    background: var(--lf-success-bg); border: 1px solid #86efac;
    border-radius: var(--lf-radius-sm); padding: 14px 18px;
    font-size: 14px; color: var(--lf-success); font-weight: 600;
    margin-bottom: 20px;
}

/* ══════════════════════════════════════════════════════════════════════════
   Email verification block on enroll card
   ══════════════════════════════════════════════════════════════════════════ */
.lms-unverified-block {
    background: #fffbeb;
    border: 1.5px solid #fde68a;
    border-radius: var(--lf-radius-sm);
    padding: 16px;
    display: flex;
    gap: 12px;
    align-items: flex-start;
    font-size: 13px;
    color: #78350f;
    margin-bottom: 4px;
}
.lms-unverified-block span { font-size: 20px; flex-shrink: 0; margin-top: 1px; }
.lms-unverified-block strong { display: block; font-weight: 700; margin-bottom: 3px; color: #92400e; }
.lms-unverified-block small { color: #a16207; }
.lms-unverified-block a { color: #78350f !important; }
.lms-unverified-block a:hover { text-decoration: underline; }

/* ══════════════════════════════════════════════════════════════════════════
   Hero without thumb column (full-width hero)
   ══════════════════════════════════════════════════════════════════════════ */


@media (max-width: 768px) {
    .lms-course-hero { padding: 36px 24px; }
    .lms-course-title { font-size: 24px !important; }
}

/* ══════════════════════════════════════════════════════════════════════════
   Two-Column Dashboard Layout
   ══════════════════════════════════════════════════════════════════════════ */
.lms-dash-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 32px;
    align-items: start;
    width: 100%;
}
.lms-dash-left  { display: flex; flex-direction: column; gap: 28px; min-width: 0; }
.lms-dash-right { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 90px; }

/* Profile card */
.lms-dash-profile-card {
    background: linear-gradient(135deg, #0c4a6e 0%, #0369a1 100%);
    border-radius: var(--lf-radius);
    padding: 28px 22px;
    text-align: center;
    color: #fff;
}
.lms-dash-profile-avatar {
    width: 64px; height: 64px;
    background: rgba(255,255,255,0.15);
    border: 3px solid rgba(255,255,255,0.3);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 26px; font-weight: 800; color: #fff;
    margin: 0 auto 14px;
}
.lms-dash-profile-name  { font-size: 16px; font-weight: 700; margin-bottom: 4px; }
.lms-dash-profile-email { font-size: 12px; opacity: 0.7; word-break: break-all; }
.lms-dash-verified-badge {
    display: inline-block;
    margin-top: 10px;
    background: rgba(34,197,94,0.2);
    border: 1px solid rgba(34,197,94,0.4);
    color: #86efac;
    font-size: 11px; font-weight: 600;
    padding: 3px 10px; border-radius: 100px;
}
.lms-dash-profile-card .lms-btn-outline {
    border-color: rgba(255,255,255,0.35) !important;
    color: rgba(255,255,255,0.9) !important;
}
.lms-dash-profile-card .lms-btn-outline:hover {
    background: rgba(255,255,255,0.1) !important;
}

/* Quick stats */
.lms-dash-quick-stats {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    overflow: hidden;
}
.lms-dash-qstat {
    padding: 16px 8px;
    text-align: center;
    border-right: 1px solid var(--lf-border);
}
.lms-dash-qstat:last-child { border-right: none; }
.lms-dash-qstat-num   { font-size: 22px; font-weight: 800; color: var(--lf-accent); }
.lms-dash-qstat-label { font-size: 11px; color: var(--lf-muted); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.5px; }

/* Quick links */
.lms-dash-quick-links {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    overflow: hidden;
}
.lms-dash-quick-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 13px 18px;
    border-bottom: 1px solid var(--lf-border);
    font-size: 13px; font-weight: 600;
    color: var(--lf-text) !important;
    text-decoration: none !important;
    transition: var(--lf-transition);
}
.lms-dash-quick-link:last-child { border-bottom: none; }
.lms-dash-quick-link:hover { background: var(--lf-accent-soft); color: var(--lf-accent) !important; }
.lms-dash-quick-link span { font-size: 16px; }

/* Remove old stats row from left column (now in right column) */
.lms-dash-left .lms-dash-stats { display: none; }

@media (max-width: 768px) {
    .lms-dash-layout {
        grid-template-columns: 1fr;
    }
    .lms-dash-right {
        position: static;
        order: -1; /* Profile shows first on mobile */
    }
}

/* ══════════════════════════════════════════════════════════════════════════
   Course Completion Overlay
   ══════════════════════════════════════════════════════════════════════════ */
.lms-completion-overlay {
    position: fixed; inset: 0; z-index: 99999;
    background: rgba(0,0,0,0.75);
    display: flex; align-items: center; justify-content: center;
    animation: lmsFadeIn 0.3s ease;
}
@keyframes lmsFadeIn { from { opacity: 0; } to { opacity: 1; } }

.lms-completion-card {
    background: #fff;
    border-radius: var(--lf-radius);
    padding: 52px 48px;
    text-align: center;
    max-width: 480px;
    width: 94%;
    box-shadow: 0 24px 80px rgba(0,0,0,0.3);
    animation: lmsSlideUp 0.35s ease;
}
@keyframes lmsSlideUp {
    from { transform: translateY(30px); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
}
.lms-completion-icon { font-size: 72px; margin-bottom: 20px; }
.lms-completion-card h2 {
    font-size: 26px; font-weight: 800; color: var(--lf-text);
    margin: 0 0 10px !important;
}
.lms-completion-card p {
    font-size: 15px; color: var(--lf-muted);
    margin: 0 0 28px !important;
}
.lms-completion-actions { display: flex; gap: 10px; justify-content: center; }

/* ══════════════════════════════════════════════════════════════════════════
   License Number Card — Dashboard Right Column
   ══════════════════════════════════════════════════════════════════════════ */
.lms-dash-license-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 16px 18px;
}
.lms-dash-license-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--lf-text);
    margin-bottom: 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* ══════════════════════════════════════════════════════════════════════════
   COMPREHENSIVE RESPONSIVE — All LMS pages
   ══════════════════════════════════════════════════════════════════════════ */

/* Tablet (768px–1024px) */
@media (max-width: 1024px) {
    .lms-dash-layout {
        grid-template-columns: 1fr 240px;
        gap: 20px;
    }
    .lms-dash-right { position: static; top: auto; }
    .lms-dash-profile-card { padding: 20px 16px; }
    .lms-course-hero { min-height: auto; }
    .lms-course-hero-content { padding: 32px 36px; }
}

/* Mobile (≤768px) */
@media (max-width: 768px) {
    /* Dashboard two-column → single column */
    .lms-dash-layout {
        grid-template-columns: 1fr !important;
        gap: 16px;
    }
    .lms-dash-right {
        position: static !important;
        order: -1; /* Profile card above courses on mobile */
    }
    .lms-dash-left .lms-dash-stats { display: none; }

    /* Dashboard header */
    .lms-dash-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    /* Course hero single column on mobile */
    .lms-course-hero {
        grid-template-columns: 1fr !important;
    }
    .lms-course-hero-image {
        height: 200px;
        order: -1;
    }
    .lms-course-hero-content { padding: 24px 20px; }
    .lms-course-title { font-size: 20px !important; }
    .lms-course-stats { flex-wrap: wrap; gap: 10px; font-size: 13px; }

    /* Course layout */
    .lms-course-layout {
        grid-template-columns: 1fr !important;
    }
    .lms-course-sidebar {
        position: static !important;
        order: -1; /* Enroll card above content on mobile */
    }
    .lms-enroll-card { padding: 20px 16px; }

    /* Lesson player */
    .lms-player-layout {
        grid-template-columns: 1fr !important;
        gap: 0;
    }
    .lms-player-sidebar {
        position: static !important;
        max-height: 300px;
        overflow-y: auto;
        order: 2;
        border-top: 1px solid var(--lf-border);
    }
    .lms-player-main { padding: 16px; }

    /* Auth pages */
    .lms-auth-wrap { padding: 16px; }
    .lms-auth-box  { padding: 28px 20px; max-width: 100%; }

    /* Catalog */
    .lms-catalog-header { margin-bottom: 20px; }
    .lms-search-wrap { max-width: 100%; }

    /* Quick stats collapse */
    .lms-dash-quick-stats { grid-template-columns: repeat(3, 1fr); }

    /* Dashboard course card */
    .lms-dash-course-card {
        flex-direction: column;
    }
    .lms-dash-course-thumb,
    .lms-dash-course-thumb-placeholder {
        width: 100% !important;
        height: 160px !important;
        border-radius: var(--lf-radius) var(--lf-radius) 0 0 !important;
    }
    .lms-dash-course-actions {
        flex-direction: row;
        justify-content: flex-end;
        width: 100%;
        padding-top: 12px;
        border-top: 1px solid var(--lf-border);
    }

    /* Breadcrumb */
    .lms-breadcrumb { font-size: 13px; }

    /* FAQ */
    .lms-faq-question { padding: 16px; }

    /* Wrap padding */
    .lms-wrap { padding: 16px 14px; }
}

/* Small mobile (≤480px) */
@media (max-width: 480px) {
    .lms-course-grid { grid-template-columns: 1fr !important; }
    .lms-auth-box    { padding: 24px 16px; }
    .lms-course-title { font-size: 18px !important; }

    .lms-dash-profile-card { padding: 20px 14px; }
    .lms-dash-profile-name { font-size: 15px; }

    /* Player controls stack on mobile */
    .lms-player-controls {
        flex-direction: column;
        gap: 10px;
    }
    .lms-player-nav { width: 100%; justify-content: space-between; }

    /* Enroll card */
    .lms-enroll-price { font-size: 28px; }
    .lms-coupon-row { flex-direction: column; }
    .lms-coupon-row input { width: 100%; }

    /* Certificate overlay */
    .lms-completion-card { padding: 36px 24px; }
    .lms-completion-icon { font-size: 52px; }
    .lms-completion-card h2 { font-size: 22px; }
}

/* ══════════════════════════════════════════════════════════════════════════
   COURSE DETAIL PAGE — BeatLab Academy Style
   ══════════════════════════════════════════════════════════════════════════ */

/* Outer wrapper */
.lms-cdp-wrap {
    width: 100%;
    padding: 24px 32px 60px;
}

/* Breadcrumb */
.lms-cdp-breadcrumb {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
    font-size: 13px;
}
.lms-cdp-breadcrumb a {
    color: var(--lc-primary, var(--lf-accent));
    text-decoration: none;
    font-weight: 500;
}
.lms-cdp-breadcrumb a:hover { text-decoration: underline; }
.lms-cdp-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 100px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: var(--lc-accent-soft, rgba(3,105,161,0.08));
    color: var(--lc-primary, var(--lf-accent));
    border: 1px solid var(--lc-accent-soft, rgba(3,105,161,0.15));
}

/* ── Two column layout ── */
.lms-cdp-layout {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 36px;
    align-items: start;
    width: 100%;
}

/* ── LEFT column ── */
.lms-cdp-left { display: flex; flex-direction: column; gap: 0; min-width: 0; }

/* Media / Thumbnail */
.lms-cdp-media {
    border-radius: 14px;
    overflow: hidden;
    background: #0f172a;
    aspect-ratio: 16/9;
    margin-bottom: 24px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.12);
}
.lms-cdp-thumb {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}
.lms-cdp-thumb-placeholder {
    width: 100%; height: 100%;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 16px;
    background: linear-gradient(135deg, var(--lc-primary,#0369a1), var(--lc-primary-dark,#075985));
    color: rgba(255,255,255,0.7);
    font-size: 16px; font-weight: 500;
}

/* Header: title + meta below image */
.lms-cdp-header { margin-bottom: 28px; }
.lms-cdp-title {
    font-size: 32px !important;
    font-weight: 800 !important;
    color: var(--lc-text, var(--lf-text)) !important;
    line-height: 1.2 !important;
    margin: 0 0 16px !important;
    letter-spacing: -0.5px;
}
.lms-cdp-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 20px;
    align-items: center;
}
.lms-cdp-meta-item {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    color: var(--lf-muted);
    font-weight: 500;
}
.lms-cdp-meta-icon {
    display: flex;
    align-items: center;
    color: var(--lc-primary, var(--lf-accent));
}

/* Progress bar */
.lms-cdp-progress {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 16px 20px;
    margin-bottom: 28px;
}
.lms-cdp-progress-top {
    display: flex;
    justify-content: space-between;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--lf-text);
}
.lms-cdp-progress-bar {
    height: 6px;
    background: var(--lf-border);
    border-radius: 100px;
    overflow: hidden;
    margin-bottom: 6px;
}
.lms-cdp-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--lc-primary,#0369a1), var(--lc-accent,#0ea5e9));
    border-radius: 100px;
    transition: width 0.6s ease;
}
.lms-cdp-progress-sub { font-size: 12px; color: var(--lf-muted); }

/* Section headings */
.lms-cdp-section { margin-bottom: 36px; }
.lms-cdp-section-title {
    font-size: 19px !important;
    font-weight: 700 !important;
    color: var(--lc-text, var(--lf-text)) !important;
    margin: 0 0 16px !important;
    display: flex;
    align-items: center;
    gap: 10px;
}
.lms-cdp-section-count {
    font-size: 12px;
    font-weight: 500;
    color: var(--lf-muted);
    background: var(--lf-border);
    padding: 2px 8px;
    border-radius: 100px;
}
.lms-cdp-description {
    font-size: 15px;
    line-height: 1.75;
    color: var(--lf-muted);
}
.lms-cdp-description p { margin-bottom: 12px; }

/* Curriculum */
.lms-cdp-curriculum {
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    overflow: hidden;
}
.lms-cdp-lesson {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--lf-border);
    background: var(--lf-white);
    transition: background 0.15s ease;
}
.lms-cdp-lesson:last-child { border-bottom: none; }
.lms-cdp-lesson:hover { background: var(--lf-bg); }
.lms-cdp-lesson.done { background: rgba(22,163,74,0.03); }
.lms-cdp-lesson.locked { opacity: 0.65; }
.lms-cdp-lesson-num {
    width: 28px; height: 28px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
    font-size: 12px; font-weight: 700;
    flex-shrink: 0;
    background: var(--lf-border);
    color: var(--lf-muted);
}
.lms-cdp-lesson.done .lms-cdp-lesson-num {
    background: rgba(22,163,74,0.12);
    color: #16a34a;
}
.lms-cdp-lesson-info { flex: 1; min-width: 0; }
.lms-cdp-lesson-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--lf-text) !important;
    text-decoration: none !important;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.lms-cdp-lesson-title:hover { color: var(--lc-primary, var(--lf-accent)) !important; }
.lms-cdp-lesson-title.locked { color: var(--lf-muted) !important; }
.lms-cdp-lesson-tags { display: flex; gap: 6px; flex-shrink: 0; }
.lms-cdp-tag {
    font-size: 11px; font-weight: 600; padding: 2px 8px;
    border-radius: 100px;
}
.lms-cdp-tag.preview { background: rgba(22,163,74,0.1); color: #16a34a; }
.lms-cdp-tag.video   { background: rgba(3,105,161,0.08); color: var(--lc-primary,#0369a1); }

/* ── RIGHT column ── */
.lms-cdp-right {
    position: sticky;
    top: 90px;
}

/* Enroll Card */
.lms-cdp-enroll-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

/* Price block */
.lms-cdp-price-block { margin-bottom: 12px; }
.lms-cdp-price {
    font-size: 22px;
    font-weight: 700;
    color: var(--lc-text, var(--lf-text));
    line-height: 1;
}
.lms-cdp-price.free {
    color: var(--lc-primary, var(--lf-accent));
    font-size: 20px;
}

/* Enroll button */
.lms-cdp-btn-enroll {
    display: block;
    width: 100%;
    padding: 15px 20px;
    background: var(--lc-primary, var(--lf-accent));
    color: #fff !important;
    font-size: 15px;
    font-weight: 700;
    text-align: center;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    text-decoration: none !important;
    transition: all 0.18s ease;
    letter-spacing: 0.3px;
    box-shadow: 0 4px 16px rgba(3,105,161,0.3);
}
.lms-cdp-btn-enroll:hover {
    background: var(--lc-primary-dark, var(--lf-accent-dark));
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(3,105,161,0.4);
    color: #fff !important;
}
.lms-cdp-btn-outline {
    display: block;
    width: 100%;
    padding: 13px 20px;
    background: transparent;
    color: var(--lc-primary, var(--lf-accent)) !important;
    font-size: 14px;
    font-weight: 600;
    text-align: center;
    border: 1.5px solid var(--lc-primary, var(--lf-accent));
    border-radius: 10px;
    cursor: pointer;
    text-decoration: none !important;
    transition: all 0.18s ease;
}
.lms-cdp-btn-outline:hover {
    background: var(--lf-accent-soft);
}
.lms-cdp-enrolled-badge {
    font-size: 14px;
    font-weight: 600;
    color: #16a34a;
    background: rgba(22,163,74,0.08);
    border: 1px solid rgba(22,163,74,0.2);
    border-radius: 8px;
    padding: 10px 16px;
    margin-bottom: 14px;
    text-align: center;
}

/* Coupon */
.lms-cdp-coupon-row {
    display: flex;
    gap: 8px;
    margin-top: 12px;
}
.lms-cdp-coupon-row input {
    flex: 1;
    font-size: 13px;
    text-transform: uppercase;
}
.lms-cdp-coupon-btn {
    padding: 0 14px;
    background: var(--lf-bg);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius-sm);
    font-size: 13px;
    font-weight: 600;
    color: var(--lf-text);
    cursor: pointer;
    white-space: nowrap;
}
.lms-cdp-coupon-btn:hover { background: var(--lf-border); }

/* Verification block */
.lms-cdp-verify-block {
    display: flex; flex-direction: column; gap: 4px;
    background: #fffbeb;
    border: 1px solid #fcd34d;
    border-radius: 8px;
    padding: 12px 14px;
    font-size: 13px;
    margin-bottom: 4px;
}
.lms-cdp-verify-block a { color: var(--lc-primary,#0369a1); font-weight: 600; }

/* Course includes */
.lms-cdp-includes {
    margin-top: 20px;
    padding-top: 18px;
    border-top: 1px solid var(--lf-border);
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.lms-cdp-include-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--lf-muted);
}
.lms-cdp-include-item svg { color: var(--lc-primary,#0369a1); flex-shrink: 0; }

/* What You'll Learn */
.lms-cdp-learn-block {
    margin-top: 20px;
    padding-top: 18px;
    border-top: 1px solid var(--lf-border);
}
.lms-cdp-learn-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--lf-text);
    margin-bottom: 12px;
}
.lms-cdp-learn-list {
    list-style: none;
    padding: 0; margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.lms-cdp-learn-list li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 13px;
    color: var(--lf-muted);
    line-height: 1.4;
}
.lms-cdp-learn-list li svg { color: #16a34a; flex-shrink: 0; margin-top: 1px; }

/* ── Responsive ── */
@media (max-width: 960px) {
    /* Stack to single column */
    .lms-cdp-layout { grid-template-columns: 1fr !important; }

    /* Hide sticky right column (desktop enroll card) */
    .lms-cdp-right  { display: none !important; }

    /* Show the inline mobile enroll card */
    .lms-cdp-enroll-mobile-card { display: block !important; }

    /* Make left column flex so CSS order works */
    .lms-cdp-left {
        display: flex !important;
        flex-direction: column !important;
    }
    /* Section order on mobile */
    .lms-cdp-order-1 { order: 1 !important; }
    .lms-cdp-order-2 { order: 2 !important; }
    .lms-cdp-order-3 { order: 3 !important; }
    .lms-cdp-order-4 { order: 4 !important; }
    .lms-cdp-order-5 { order: 5 !important; }
    .lms-cdp-order-6 { order: 6 !important; }
    .lms-cdp-order-7 { order: 7 !important; }

    /* Style the inline enroll card */
    .lms-cdp-enroll-mobile-card {
        order: 5 !important;
        border: 1.5px solid var(--lf-border);
        border-radius: 14px;
        padding: 20px;
        margin-bottom: 24px;
        background: var(--lf-white);
        box-shadow: 0 2px 8px rgba(0,0,0,.06);
    }
    .lms-cdp-title { font-size: 26px !important; }
}
@media (max-width: 600px) {
    .lms-cdp-wrap   { padding: 16px 14px 40px; }
    .lms-cdp-title  { font-size: 22px !important; }
    .lms-cdp-enroll-card { padding: 20px 16px; }
    .lms-cdp-price  { font-size: 28px; }
}

/* ══════════════════════════════════════════════════════════════════════════
   FEATURE 1: Course Archive Filter Bar
   ══════════════════════════════════════════════════════════════════════════ */
.lms-catalog-page {
    width: 100%;
}
.lms-catalog-header {
    display: flex !important;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 20px;
    flex-wrap: wrap;
    gap: 8px;
}
.lms-catalog-title {
    font-size: 26px !important;
    font-weight: 800 !important;
    color: var(--lf-text) !important;
    margin: 0 !important;
}
.lms-catalog-sub {
    font-size: 13px !important;
    color: var(--lf-muted) !important;
    margin: 4px 0 0 !important;
}

.lms-filter-form { margin-bottom: 28px; }

/* Force flex row — override any theme interference */
.lms-filter-row {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    align-items: center !important;
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: 12px;
    padding: 10px 12px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
    box-sizing: border-box;
}
.lms-filter-row > * {
    display: inline-flex !important;
    align-items: center;
    box-sizing: border-box;
}

.lms-filter-search {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    flex: 1 1 180px !important;
    min-width: 160px;
    max-width: 340px;
}
.lms-filter-search-icon {
    position: absolute;
    left: 10px;
    color: var(--lf-muted);
    pointer-events: none;
    display: flex;
    align-items: center;
}
.lms-filter-search-input {
    width: 100% !important;
    height: 40px !important;
    padding: 0 12px 0 34px !important;
    border: 1px solid var(--lf-border) !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    background: var(--lf-bg) !important;
    color: var(--lf-text) !important;
    box-sizing: border-box !important;
    outline: none;
    display: block !important;
}
.lms-filter-search-input:focus {
    border-color: var(--lf-accent) !important;
    box-shadow: 0 0 0 3px var(--lf-accent-soft) !important;
}

.lms-filter-select {
    display: inline-block !important;
    height: 40px !important;
    padding: 0 10px !important;
    border: 1px solid var(--lf-border) !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    color: var(--lf-text) !important;
    background: var(--lf-bg) !important;
    cursor: pointer;
    min-width: 120px;
    max-width: 160px;
    flex-shrink: 0;
    appearance: auto;
    -webkit-appearance: auto;
}
.lms-filter-select:focus { outline: none; border-color: var(--lf-accent) !important; }

.lms-filter-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 40px !important;
    padding: 0 20px !important;
    background: var(--lf-accent) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    cursor: pointer;
    transition: background 0.15s ease;
    white-space: nowrap;
    flex-shrink: 0;
    text-decoration: none !important;
}
.lms-filter-btn:hover { background: var(--lf-accent-dark) !important; }

.lms-filter-clear {
    display: inline-flex !important;
    align-items: center !important;
    color: var(--lf-muted) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    white-space: nowrap;
    padding: 4px 6px;
    border-radius: 6px;
    flex-shrink: 0;
}
.lms-filter-clear:hover {
    color: var(--lf-danger) !important;
    background: rgba(220,38,38,0.06);
}

/* Active filter chips */
.lms-filter-chips {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px;
    margin-top: 10px;
}
.lms-filter-chip {
    display: inline-flex !important;
    align-items: center;
    gap: 4px;
    padding: 4px 12px;
    background: var(--lf-accent-soft);
    color: var(--lf-accent) !important;
    border: 1px solid rgba(3,105,161,0.2);
    border-radius: 100px;
    font-size: 12px;
    font-weight: 600;
    text-decoration: none !important;
    transition: var(--lf-transition);
}
.lms-filter-chip:hover {
    background: rgba(220,38,38,0.08);
    color: var(--lf-danger) !important;
    border-color: rgba(220,38,38,0.2);
}
.lms-filter-results {
    margin-top: 8px;
    font-size: 13px;
    color: var(--lf-muted);
}

/* Mobile */
@media (max-width: 640px) {
    .lms-filter-row { flex-direction: column !important; padding: 12px; }
    .lms-filter-row > * { width: 100% !important; max-width: 100% !important; }
    .lms-filter-search { max-width: 100%; }
}

/* ══════════════════════════════════════════════════════════════════════════
   FEATURE 5: Instructors List Page
   ══════════════════════════════════════════════════════════════════════════ */
.lms-instructors-grid {
    display: grid;
    grid-template-columns: repeat(var(--lms-cols, 3), 1fr);
    gap: 24px;
}
.lms-instructor-card {
    background: var(--lf-white);
    border: 1px solid var(--lf-border);
    border-radius: var(--lf-radius);
    padding: 28px 20px;
    text-align: center;
    transition: var(--lf-transition);
}
.lms-instructor-card:hover {
    box-shadow: var(--lf-shadow-lg);
    transform: translateY(-3px);
}
.lms-instructor-avatar {
    width: 80px; height: 80px;
    border-radius: 50%;
    overflow: hidden;
    margin: 0 auto 16px;
    background: linear-gradient(135deg, var(--lf-accent), var(--lf-accent-dark));
    display: flex; align-items: center; justify-content: center;
    font-size: 26px; font-weight: 800; color: #fff;
    border: 3px solid var(--lf-border);
}
.lms-instructor-avatar img { width: 100%; height: 100%; object-fit: cover; }
.lms-instructor-name  { font-size: 16px; font-weight: 700; color: var(--lf-text); margin-bottom: 4px; }
.lms-instructor-count { font-size: 12px; color: var(--lf-accent); font-weight: 600; margin-bottom: 14px; }
.lms-instructor-courses {
    list-style: none; padding: 0; margin: 0;
    text-align: left;
    border-top: 1px solid var(--lf-border);
    padding-top: 12px;
    display: flex; flex-direction: column; gap: 6px;
}
.lms-instructor-courses li a {
    font-size: 12px; color: var(--lf-muted) !important;
    text-decoration: none !important;
    display: block;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    transition: color 0.15s ease;
}
.lms-instructor-courses li a:hover { color: var(--lf-accent) !important; }

@media (max-width: 768px) {
    .lms-instructors-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .lms-instructors-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════════════════
   FEATURE 6: Dynamic Progress Bar — Toast Notifications
   ══════════════════════════════════════════════════════════════════════════ */
.lms-toast {
    position: fixed;
    bottom: 28px;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    background: #1e293b;
    color: #fff;
    padding: 12px 22px;
    border-radius: 100px;
    font-size: 14px;
    font-weight: 600;
    box-shadow: 0 8px 32px rgba(0,0,0,0.25);
    z-index: 99999;
    opacity: 0;
    transition: all 0.3s ease;
    white-space: nowrap;
}
.lms-toast.visible {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* Progress bar pulse animation when updated */
.lms-progress-bar-fill,
.lms-cdp-progress-fill {
    transition: width 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}

/* ══════════════════════════════════════════════════════════════════════════
   NEW DASHBOARD REDESIGN — Quyl-style
   ══════════════════════════════════════════════════════════════════════════ */

.lms-db-wrap { width: 100%; padding: 0; font-family: var(--lf-font); }

/* ── Notices ── */
.lms-db-notice {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 20px; font-size: 13px; font-weight: 500;
    margin-bottom: 0; border-radius: 0;
}
.lms-db-notice.success { background: #f0fdf4; color: #166534; border-bottom: 1px solid #bbf7d0; }
.lms-db-notice.warning { background: #fffbeb; color: #92400e; border-bottom: 1px solid #fde68a; }
.lms-db-notice a { color: inherit; font-weight: 700; margin-left: 8px; }

/* ── Header ── */
.lms-db-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 20px 28px; background: var(--lf-white);
    border-bottom: 1px solid var(--lf-border);
    flex-wrap: wrap; gap: 12px;
}
.lms-db-header-left { display: flex; align-items: center; }
.lms-db-greeting    { display: flex; align-items: center; gap: 12px; }
.lms-db-avatar-sm {
    width: 40px; height: 40px; border-radius: 50%;
    background: linear-gradient(135deg, var(--lf-accent), var(--lf-accent-dark));
    color: #fff; font-size: 16px; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.lms-db-welcome { font-size: 12px; color: var(--lf-muted); }
.lms-db-name    { font-size: 18px; font-weight: 700; color: var(--lf-text); }
.lms-db-header-right { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.lms-db-btn-primary {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 18px; background: var(--lf-accent);
    color: #fff !important; font-size: 13px; font-weight: 600;
    border: none; border-radius: 8px; cursor: pointer;
    text-decoration: none !important; transition: background 0.15s;
}
.lms-db-btn-primary:hover { background: var(--lf-accent-dark); }
.lms-db-btn-ghost {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 14px; background: var(--lf-bg);
    color: var(--lf-muted) !important; font-size: 13px; font-weight: 500;
    border: 1px solid var(--lf-border); border-radius: 8px; cursor: pointer;
    text-decoration: none !important; transition: all 0.15s;
}
.lms-db-btn-ghost:hover { color: var(--lf-text) !important; background: var(--lf-border); }

/* ── Stat Cards ── */
.lms-db-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border-bottom: 1px solid var(--lf-border);
}
.lms-db-stat-card {
    display: flex; align-items: center; gap: 14px;
    padding: 22px 24px;
    border-right: 1px solid var(--lf-border);
    background: var(--lf-white);
    transition: background 0.15s;
}
.lms-db-stat-card:last-child { border-right: none; }
.lms-db-stat-card:hover { background: var(--lf-bg); }
.lms-db-stat-icon {
    width: 44px; height: 44px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.lms-db-stat-num   { font-size: 24px; font-weight: 800; color: var(--lf-text); line-height: 1; }
.lms-db-stat-label { font-size: 12px; color: var(--lf-muted); margin-top: 3px; font-weight: 500; }

/* ── Resume Banner ── */
.lms-db-resume {
    display: flex; align-items: center; gap: 16px;
    padding: 16px 28px;
    background: linear-gradient(135deg, var(--lf-accent) 0%, var(--lf-accent-dark) 100%);
    flex-wrap: wrap;
}
.lms-db-resume-icon {
    width: 40px; height: 40px; border-radius: 50%;
    background: rgba(255,255,255,0.15);
    display: flex; align-items: center; justify-content: center;
    color: #fff; flex-shrink: 0;
}
.lms-db-resume-body { flex: 1; min-width: 180px; }
.lms-db-resume-label  { font-size: 11px; color: rgba(255,255,255,0.7); font-weight: 600; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 2px; }
.lms-db-resume-course { font-size: 14px; font-weight: 700; color: #fff; margin-bottom: 6px; }
.lms-db-resume-pct    { font-size: 12px; font-weight: 400; opacity: .8; margin-left: 8px; }
.lms-db-resume-bar {
    height: 4px; background: rgba(255,255,255,0.2); border-radius: 100px; overflow: hidden;
}
.lms-db-resume-bar-fill {
    height: 100%; background: rgba(255,255,255,0.85); border-radius: 100px;
    transition: width .6s ease;
}
.lms-db-resume-btn {
    display: inline-flex; align-items: center;
    padding: 10px 20px;
    background: rgba(255,255,255,0.15); color: #fff !important;
    font-size: 13px; font-weight: 700;
    border: 1.5px solid rgba(255,255,255,0.3); border-radius: 8px;
    text-decoration: none !important; transition: background .15s; white-space: nowrap;
    flex-shrink: 0;
}
.lms-db-resume-btn:hover { background: rgba(255,255,255,0.25); color: #fff !important; }

/* ── Two-column layout ── */
.lms-db-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    align-items: start;
    min-height: calc(100vh - 200px);
}

/* ── Main (left) ── */
.lms-db-main {
    padding: 24px 28px;
    border-right: 1px solid var(--lf-border);
}
.lms-db-section-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 20px; flex-wrap: wrap; gap: 10px;
}
.lms-db-section-title {
    font-size: 17px !important; font-weight: 700 !important;
    color: var(--lf-text) !important; margin: 0 !important;
}
.lms-db-section-tabs { display: flex; gap: 2px; background: var(--lf-bg); border-radius: 8px; padding: 3px; }
.lms-db-tab {
    padding: 6px 16px; font-size: 13px; font-weight: 600;
    border: none; border-radius: 6px; cursor: pointer;
    background: transparent; color: var(--lf-muted); transition: all .15s;
}
.lms-db-tab.active { background: var(--lf-white); color: var(--lf-text); box-shadow: 0 1px 3px rgba(0,0,0,0.1); }

/* ── Course Row ── */
.lms-db-course-row {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid var(--lf-border);
    transition: background .15s;
}
.lms-db-course-row:last-child { border-bottom: none; }
.lms-db-course-row:hover { background: var(--lf-bg); margin: 0 -8px; padding-left: 8px; padding-right: 8px; border-radius: 8px; }
.lms-db-course-thumb {
    width: 52px; height: 52px; border-radius: 10px; overflow: hidden;
    flex-shrink: 0; position: relative;
}
.lms-db-course-thumb img { width: 100%; height: 100%; object-fit: cover; }
.lms-db-course-thumb-ph {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, #e0f2fe, #bae6fd);
    display: flex; align-items: center; justify-content: center;
    color: var(--lf-accent);
}
.lms-db-course-thumb-ph.done { background: linear-gradient(135deg, #dcfce7, #bbf7d0); color: #16a34a; }
.lms-db-completed-badge {
    position: absolute; bottom: -2px; right: -2px;
    width: 18px; height: 18px; border-radius: 50%;
    background: #16a34a; color: #fff;
    font-size: 10px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    border: 2px solid var(--lf-white);
}
.lms-db-course-info { flex: 1; min-width: 0; }
.lms-db-course-name { font-size: 14px; font-weight: 600; color: var(--lf-text); margin-bottom: 3px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lms-db-course-meta { font-size: 12px; color: var(--lf-muted); margin-bottom: 6px; }
.lms-db-progress-wrap { display: flex; align-items: center; gap: 8px; }
.lms-db-progress-bar  { flex: 1; height: 6px; background: var(--lf-border); border-radius: 100px; overflow: hidden; }
.lms-db-progress-fill { height: 100%; background: linear-gradient(90deg, var(--lf-accent), #0ea5e9); border-radius: 100px; transition: width .6s ease; }
.lms-db-progress-pct  { font-size: 11px; font-weight: 700; color: var(--lf-accent); min-width: 32px; text-align: right; }
.lms-db-course-actions { display: flex; gap: 8px; flex-shrink: 0; flex-wrap: wrap; }
.lms-db-btn-sm {
    display: inline-flex; align-items: center;
    padding: 7px 14px; background: var(--lf-accent);
    color: #fff !important; font-size: 12px; font-weight: 600;
    border: none; border-radius: 7px; cursor: pointer;
    text-decoration: none !important; transition: background .15s; white-space: nowrap;
}
.lms-db-btn-sm:hover { background: var(--lf-accent-dark); color: #fff !important; }
.lms-db-btn-sm.outline {
    background: transparent; color: var(--lf-accent) !important;
    border: 1.5px solid var(--lf-accent);
}
.lms-db-btn-sm.outline:hover { background: var(--lf-accent-soft); }
.lms-db-btn-cert {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 7px 12px; background: rgba(245,158,11,0.08);
    color: #b45309 !important; font-size: 12px; font-weight: 600;
    border: 1.5px solid rgba(245,158,11,0.3); border-radius: 7px;
    cursor: pointer; transition: all .15s; white-space: nowrap;
}
.lms-db-btn-cert:hover { background: rgba(245,158,11,0.15); }

/* ── Empty state ── */
.lms-db-empty {
    display: flex; flex-direction: column; align-items: center;
    text-align: center; padding: 48px 20px; gap: 8px;
}
.lms-db-empty-icon { color: var(--lf-border); margin-bottom: 8px; }
.lms-db-empty-title { font-size: 16px; font-weight: 700; color: var(--lf-text); }
.lms-db-empty-sub   { font-size: 13px; color: var(--lf-muted); }

/* ── Sidebar ── */
.lms-db-sidebar {
    padding: 0;
    background: var(--lf-bg);
    border-left: 1px solid var(--lf-border);
    display: flex; flex-direction: column;
}

/* Profile Card */
.lms-db-profile {
    background: var(--lf-white);
    border-bottom: 1px solid var(--lf-border);
    padding: 24px 20px;
    text-align: center;
}
.lms-db-profile-avatar {
    width: 72px; height: 72px; border-radius: 50%;
    background: linear-gradient(135deg, var(--lf-accent), var(--lf-accent-dark));
    color: #fff; font-size: 28px; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 12px;
    border: 3px solid var(--lf-border);
}
.lms-db-profile-name  { font-size: 16px; font-weight: 700; color: var(--lf-text); margin-bottom: 3px; }
.lms-db-profile-email { font-size: 12px; color: var(--lf-muted); word-break: break-all; margin-bottom: 10px; }
.lms-db-verified {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: 11px; font-weight: 600;
    background: rgba(22,163,74,0.1); color: #16a34a;
    border: 1px solid rgba(22,163,74,0.2); border-radius: 100px;
    padding: 3px 10px; margin-bottom: 14px;
}
.lms-db-profile-stats {
    display: grid; grid-template-columns: repeat(3, 1fr);
    border: 1px solid var(--lf-border); border-radius: 10px; overflow: hidden;
    margin-top: 4px;
}
.lms-db-pstat {
    padding: 10px 8px; text-align: center;
    border-right: 1px solid var(--lf-border); font-size: 11px;
    color: var(--lf-muted); font-weight: 500;
}
.lms-db-pstat:last-child { border-right: none; }
.lms-db-pstat span { display: block; font-size: 20px; font-weight: 800; color: var(--lf-accent); margin-bottom: 2px; }

/* Quick Actions */
.lms-db-quick { padding: 12px; border-bottom: 1px solid var(--lf-border); background: var(--lf-white); }
.lms-db-quick-item {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 10px; border-radius: 8px;
    color: var(--lf-text) !important; text-decoration: none !important;
    font-size: 13px; font-weight: 500; transition: background .15s;
}
.lms-db-quick-item:hover { background: var(--lf-bg); }
.lms-db-quick-icon {
    width: 32px; height: 32px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.lms-db-quick-arrow { margin-left: auto; color: var(--lf-muted); }

/* License Card */
.lms-db-license { padding: 16px 20px; background: var(--lf-white); border-top: 1px solid var(--lf-border); }
.lms-db-license-label {
    display: flex; align-items: center; gap: 6px;
    font-size: 11px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .5px; color: var(--lf-muted); margin-bottom: 10px;
}
.lms-db-license-form { display: flex; gap: 8px; margin-bottom: 6px; }
.lms-db-license-form input { flex: 1; font-size: 13px; min-width: 0; }
.lms-db-license-form button {
    padding: 0 12px; background: var(--lf-accent); color: #fff;
    border: none; border-radius: 7px; font-size: 12px; font-weight: 700;
    cursor: pointer; white-space: nowrap;
}
.lms-db-license-form button:hover { background: var(--lf-accent-dark); }
.lms-db-license-hint { font-size: 11px; color: var(--lf-muted); }

/* ── Responsive ── */
@media (max-width: 900px) {
    .lms-db-stats { grid-template-columns: repeat(2, 1fr); }
    .lms-db-stat-card:nth-child(2) { border-right: none; }
    .lms-db-stat-card:nth-child(3) { border-top: 1px solid var(--lf-border); }
    .lms-db-stat-card:nth-child(4) { border-top: 1px solid var(--lf-border); }
    .lms-db-layout { grid-template-columns: 1fr; }
    .lms-db-sidebar { border-left: none; border-top: 1px solid var(--lf-border); }
}
@media (max-width: 600px) {
    .lms-db-header { padding: 14px 16px; }
    .lms-db-header-right .lms-db-btn-ghost span { display: none; }
    .lms-db-stats { grid-template-columns: repeat(2, 1fr); }
    .lms-db-main { padding: 16px; }
    .lms-db-resume { padding: 14px 16px; }
    .lms-db-course-row { flex-wrap: wrap; }
    .lms-db-course-actions { width: 100%; justify-content: flex-end; }
    .lms-db-course-name { font-size: 13px; }
    .lms-db-stat-card { padding: 16px; }
    .lms-db-stat-num { font-size: 20px; }
}
@media (max-width: 400px) {
    .lms-db-stats { grid-template-columns: 1fr 1fr; }
    .lms-db-course-thumb { width: 44px; height: 44px; }
}
