/**
 * Training Provider Program & Learn Platform – responsive styles
 * Mobile-first; covers training/ provider portal, learn/ student pages, training-directory/
 */

/* ----- Variables ----- */
:root {
    --training-nav-bg: linear-gradient(135deg, #065f46 0%, #047857 100%);
    --training-accent: #10b981;
    --training-accent-light: #d1fae5;
    --training-text: #111827;
    --training-muted: #6b7280;
    --training-border: #e5e7eb;
    --training-card-bg: #fff;
    --training-nav-link: #a7f3d0;
    --training-nav-hover: #fff;
    --training-touch-min: 44px;
    --training-success: #059669;
    --training-warning: #d97706;
    --training-danger: #dc2626;
    --training-gold: #f59e0b;
}

/* ----- Training Provider Portal Layout ----- */
.training-wrap {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1rem 1rem 2rem;
}
@media (min-width: 768px) { .training-wrap { padding: 1.5rem 1.5rem 2.5rem; } }

/* ----- Nav ----- */
.training-nav {
    background: var(--training-nav-bg);
    color: var(--training-nav-hover);
    padding: 0.75rem 1rem;
    margin: -1rem -1rem 1.5rem -1rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.75rem;
    border-bottom: 3px solid var(--training-accent);
    position: relative;
}
@media (min-width: 768px) {
    .training-nav { margin: -1rem -1.5rem 2rem -1.5rem; padding: 0.75rem 1.5rem; gap: 0.75rem 1rem; }
}
.training-brand-wrap {
    display: flex; align-items: center; gap: 0.5rem; text-decoration: none;
    color: #fff; font-weight: 700;
}
.training-nav-icon { font-size: 1.4rem; }
.training-brand { font-size: 1.1rem; }
.training-program-badge {
    background: rgba(255,255,255,0.15); border-radius: 20px;
    padding: 0.15rem 0.6rem; font-size: 0.7rem; font-weight: 600;
    color: #d1fae5; letter-spacing: 0.04em;
}
.training-spacer { flex: 1; }
.training-nav-links { display: flex; flex-wrap: wrap; gap: 0.25rem; }
.training-nav-links a {
    color: var(--training-nav-link); text-decoration: none; font-weight: 500;
    display: inline-flex; align-items: center; gap: 0.35rem;
    padding: 0.35rem 0.6rem; border-radius: 8px; font-size: 0.875rem;
    min-height: var(--training-touch-min);
    transition: background 0.15s, color 0.15s;
}
.training-nav-links a:hover, .training-nav-links a.active {
    background: rgba(255,255,255,0.15); color: #fff;
}
.training-nav-toggle {
    display: none; background: none; border: none;
    color: #fff; font-size: 1.4rem; cursor: pointer;
    padding: 0.4rem; border-radius: 6px;
    min-width: var(--training-touch-min); min-height: var(--training-touch-min);
}
@media (max-width: 900px) {
    .training-nav-toggle { display: flex; align-items: center; justify-content: center; }
    .training-nav-links { display: none; width: 100%; flex-direction: column; padding: 0.5rem 0; }
    .training-nav-links.is-open { display: flex; }
    .training-nav-links a { min-height: 2.75rem; padding: 0.5rem 0.75rem; }
}

/* ----- Page Header ----- */
.training-page-header {
    display: flex; align-items: flex-start; justify-content: space-between;
    flex-wrap: wrap; gap: 1rem; margin-bottom: 1.5rem;
}
.training-page-header h1 { margin: 0 0 0.25rem; font-size: 1.6rem; color: var(--training-text); }
.training-subtitle { color: var(--training-muted); margin: 0; font-size: 0.9rem; }
.training-header-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; align-items: center; }

/* ----- Buttons ----- */
.training-btn {
    display: inline-flex; align-items: center; gap: 0.35rem;
    padding: 0.5rem 1.1rem; border-radius: 8px; font-weight: 600;
    font-size: 0.9rem; text-decoration: none; cursor: pointer;
    border: none; transition: opacity 0.15s, background 0.15s;
    min-height: 40px;
}
.training-btn:hover { opacity: 0.88; }
.training-btn-primary { background: var(--training-accent); color: #fff; }
.training-btn-secondary { background: #f3f4f6; color: var(--training-text); border: 1px solid var(--training-border); }
.training-btn-success  { background: #059669; color: #fff; }
.training-btn-warning  { background: #d97706; color: #fff; }
.training-btn-danger   { background: #dc2626; color: #fff; }
.training-btn-disabled { background: #d1d5db; color: #6b7280; cursor: not-allowed; pointer-events: none; }
.training-btn-sm { padding: 0.3rem 0.7rem; font-size: 0.8rem; min-height: 32px; }
.training-btn-full { width: 100%; justify-content: center; }

/* ----- Alerts ----- */
.training-alert { padding: 0.85rem 1rem; border-radius: 8px; margin-bottom: 1.25rem; font-size: 0.9rem; }
.training-alert-success { background: #d1fae5; color: #065f46; border: 1px solid #6ee7b7; }
.training-alert-danger  { background: #fee2e2; color: #7f1d1d; border: 1px solid #fca5a5; }
.training-alert-warning { background: #fef3c7; color: #78350f; border: 1px solid #fcd34d; }

/* ----- Stats Grid ----- */
.training-stats-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 1rem; margin-bottom: 1.75rem;
}
.training-stat-card {
    background: #fff; border: 1px solid var(--training-border); border-radius: 12px;
    padding: 1.25rem 1rem; text-align: center;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.training-stat-highlight { border-color: var(--training-accent); box-shadow: 0 0 0 3px var(--training-accent-light); }
.training-stat-icon { font-size: 1.6rem; margin-bottom: 0.5rem; }
.training-stat-value { font-size: 1.6rem; font-weight: 700; color: var(--training-text); }
.training-stat-label { font-size: 0.8rem; color: var(--training-muted); margin-top: 0.2rem; }
.training-stat-sub { font-size: 0.75rem; color: var(--training-muted); margin-top: 0.25rem; }

/* ----- Cards ----- */
.training-card {
    background: #fff; border: 1px solid var(--training-border); border-radius: 12px;
    padding: 1.25rem; margin-bottom: 1.25rem;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
.training-card h3, .training-card h4 { margin: 0 0 1rem; font-size: 1rem; color: var(--training-text); }
.training-card-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 1rem;
}
.training-card-header h3 { margin: 0; }
.training-card-header a { font-size: 0.85rem; color: var(--training-accent); }

/* ----- Dashboard Grid ----- */
.training-dashboard-grid {
    display: grid; grid-template-columns: 1fr; gap: 1.25rem;
}
@media (min-width: 768px) {
    .training-dashboard-grid { grid-template-columns: 2fr 1fr; }
}

/* ----- Tables ----- */
.training-table-wrap { overflow-x: auto; }
.training-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.training-table th { background: #f9fafb; font-weight: 600; padding: 0.6rem 0.75rem; text-align: left; border-bottom: 2px solid var(--training-border); color: var(--training-muted); font-size: 0.8rem; white-space: nowrap; }
.training-table td { padding: 0.65rem 0.75rem; border-bottom: 1px solid var(--training-border); vertical-align: middle; }
.training-table tr:last-child td { border-bottom: none; }
.training-table tr:hover td { background: #f9fafb; }

/* ----- Badges ----- */
.training-badge {
    display: inline-flex; align-items: center; padding: 0.15rem 0.55rem;
    border-radius: 20px; font-size: 0.72rem; font-weight: 600; white-space: nowrap;
}
.training-badge-success { background: #d1fae5; color: #065f46; }
.training-badge-warning { background: #fef3c7; color: #78350f; }
.training-badge-danger  { background: #fee2e2; color: #7f1d1d; }
.training-badge-neutral { background: #f3f4f6; color: #374151; }
.training-badge-info    { background: #dbeafe; color: #1e40af; }
.training-badge-gold    { background: #fef3c7; color: #78350f; border: 1px solid #fcd34d; }
.training-badge-published  { background: #d1fae5; color: #065f46; }
.training-badge-draft      { background: #fef3c7; color: #78350f; }
.training-badge-archived   { background: #f3f4f6; color: #374151; }

/* ----- Forms ----- */
.training-input {
    width: 100%; padding: 0.55rem 0.75rem; border: 1px solid var(--training-border);
    border-radius: 8px; font-size: 0.9rem; color: var(--training-text);
    background: #fff; box-sizing: border-box;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.training-input:focus { border-color: var(--training-accent); box-shadow: 0 0 0 3px var(--training-accent-light); outline: none; }
.training-input-sm { width: auto; }
.training-input-price { max-width: 140px; }
.training-editor { font-family: inherit; resize: vertical; min-height: 200px; }
.training-field { margin-bottom: 1rem; }
.training-field label { display: block; font-weight: 600; font-size: 0.875rem; margin-bottom: 0.35rem; color: var(--training-text); }
.training-field-row { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 1rem; }
.training-help { display: block; font-size: 0.78rem; color: var(--training-muted); margin-top: 0.3rem; }
.required { color: #dc2626; }
.training-form-grid { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 900px) { .training-form-grid { grid-template-columns: 2fr 1fr; } }
.training-form-sidebar { display: flex; flex-direction: column; gap: 1.25rem; }
.training-form-actions { margin-top: 1.5rem; display: flex; gap: 0.75rem; flex-wrap: wrap; }
.training-inline-form { display: inline-flex; gap: 0.35rem; flex-wrap: wrap; }
.training-input-group { display: flex; align-items: stretch; }
.training-input-prefix { background: #f3f4f6; border: 1px solid var(--training-border); border-right: none; border-radius: 8px 0 0 8px; padding: 0.55rem 0.75rem; font-size: 0.85rem; color: var(--training-muted); white-space: nowrap; }
.training-input-group .training-input { border-radius: 0 8px 8px 0; }
.training-checkbox-inline { display: inline-flex; align-items: center; gap: 0.4rem; cursor: pointer; font-size: 0.875rem; }

/* ----- Filter Tabs ----- */
.training-filters { margin-bottom: 1.5rem; display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: center; justify-content: space-between; }
.training-filter-tabs { display: flex; gap: 0.25rem; }
.training-filter-tab { padding: 0.4rem 0.85rem; border-radius: 20px; font-size: 0.85rem; font-weight: 600; text-decoration: none; color: var(--training-muted); background: #f3f4f6; transition: background 0.15s, color 0.15s; }
.training-filter-tab.active { background: var(--training-accent); color: #fff; }
.training-search-form { display: flex; gap: 0.5rem; }

/* ----- Course Cards (provider portal) ----- */
.training-courses-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.25rem; }
.training-course-card { background: #fff; border: 1px solid var(--training-border); border-radius: 12px; overflow: hidden; display: flex; flex-direction: column; box-shadow: 0 1px 3px rgba(0,0,0,0.06); }
.training-course-card.training-course-archived { opacity: 0.7; }
.training-course-thumb { aspect-ratio: 16/9; overflow: hidden; background: #f3f4f6; display: flex; align-items: center; justify-content: center; }
.training-course-thumb img { width: 100%; height: 100%; object-fit: cover; }
.training-course-thumb-placeholder { font-size: 3rem; aspect-ratio: 16/9; }
.training-course-body { padding: 1rem; flex: 1; }
.training-course-meta { display: flex; flex-wrap: wrap; gap: 0.25rem; margin-bottom: 0.5rem; }
.training-course-title { margin: 0 0 0.35rem; font-size: 1rem; color: var(--training-text); }
.training-course-title a { text-decoration: none; color: inherit; }
.training-course-title a:hover { color: var(--training-accent); }
.training-course-desc { font-size: 0.82rem; color: var(--training-muted); margin: 0 0 0.5rem; }
.training-course-stats { display: flex; flex-wrap: wrap; gap: 0.5rem 1rem; font-size: 0.8rem; color: var(--training-muted); }
.training-course-actions { padding: 0.75rem 1rem; border-top: 1px solid var(--training-border); display: flex; flex-wrap: wrap; gap: 0.35rem; background: #fafafa; }

/* ----- Modules Builder ----- */
.training-modules-layout { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 900px) { .training-modules-layout { grid-template-columns: 2fr 1fr; } }
.training-modules-sidebar { display: flex; flex-direction: column; gap: 1.25rem; }
.training-module-block { background: #fff; border: 1px solid var(--training-border); border-radius: 12px; margin-bottom: 1rem; overflow: hidden; }
.training-module-header { background: #f9fafb; padding: 0.75rem 1rem; display: flex; align-items: center; gap: 0.5rem; border-bottom: 1px solid var(--training-border); }
.training-module-title-input { flex: 1; font-size: 0.95rem; font-weight: 600; }
.training-lessons-list { padding: 0.5rem; }
.training-lesson-row { display: flex; align-items: center; gap: 0.5rem; padding: 0.5rem 0.75rem; border-radius: 6px; font-size: 0.875rem; flex-wrap: wrap; }
.training-lesson-row:hover { background: #f9fafb; }
.training-lesson-type-icon { font-size: 1rem; }
.training-lesson-title { flex: 1; font-weight: 500; }
.training-lesson-actions { display: flex; gap: 0.25rem; margin-left: auto; }
.training-add-lesson { padding: 0.75rem 1rem; border-top: 1px solid var(--training-border); background: #fafafa; }
.training-add-lesson-form { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; }
.training-add-module { margin-top: 1rem; }
.training-add-module-form { display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap; }
.training-empty-sm { color: var(--training-muted); font-size: 0.85rem; padding: 0.5rem; }
.training-tips-list { margin: 0; padding-left: 0; list-style: none; font-size: 0.85rem; color: var(--training-muted); }
.training-tips-list li { padding: 0.3rem 0; border-bottom: 1px solid var(--training-border); }
.training-tips-list li:last-child { border-bottom: none; }
.training-quick-links { list-style: none; padding: 0; margin: 0; }
.training-quick-links li { padding: 0.3rem 0; border-bottom: 1px solid var(--training-border); }
.training-quick-links li:last-child { border-bottom: none; }
.training-quick-links a { text-decoration: none; color: var(--training-accent); font-size: 0.875rem; font-weight: 500; }
.training-dl { margin: 0; }
.training-dl dt { font-weight: 600; font-size: 0.82rem; color: var(--training-muted); margin-top: 0.5rem; }
.training-dl dd { margin: 0 0 0.25rem; font-size: 0.9rem; }

/* ----- Progress Bar ----- */
.training-progress-bar { background: #e5e7eb; border-radius: 6px; height: 6px; overflow: hidden; margin-bottom: 0.2rem; }
.training-progress-fill { background: var(--training-accent); height: 100%; border-radius: 6px; transition: width 0.4s; }

/* ----- Empty States ----- */
.training-empty-state { text-align: center; padding: 3rem 2rem; }
.training-empty-icon { font-size: 3rem; margin-bottom: 1rem; }
.training-empty-state h3 { margin: 0 0 0.5rem; color: var(--training-text); }
.training-empty-state p { color: var(--training-muted); margin: 0 0 1.25rem; }
.training-empty { color: var(--training-muted); font-style: italic; padding: 0.75rem 0; }

/* ----- Bar Chart (earnings) ----- */
.training-bar-chart { display: flex; align-items: flex-end; gap: 4px; height: 160px; padding: 0.5rem 0; }
.training-bar-col { display: flex; flex-direction: column; align-items: center; gap: 4px; flex: 1; min-width: 0; }
.training-bar { background: var(--training-accent); border-radius: 4px 4px 0 0; width: 100%; transition: height 0.4s; min-height: 2px; }
.training-bar-label { font-size: 0.7rem; color: var(--training-muted); }
.training-bar-value { font-size: 0.7rem; color: var(--training-text); font-weight: 600; }

/* ----- Reviews ----- */
.training-reviews-list { display: flex; flex-direction: column; gap: 1rem; }
.training-review-card { background: #fff; border: 1px solid var(--training-border); border-radius: 10px; padding: 1rem; }
.training-review-pending { border-color: #fcd34d; background: #fffbeb; }
.training-review-header { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; margin-bottom: 0.5rem; }
.training-review-stars { color: #f59e0b; font-size: 1.1rem; }
.training-review-course { font-weight: 600; font-size: 0.85rem; flex: 1; }
.training-review-author { color: var(--training-muted); font-size: 0.82rem; }
.training-review-date { color: var(--training-muted); font-size: 0.82rem; }
.training-review-text { margin: 0 0 0.5rem; font-size: 0.875rem; color: var(--training-text); }
.training-review-actions { display: flex; gap: 0.35rem; }

/* ----- Quick Actions ----- */
.training-quick-actions { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 0.75rem; }
.training-quick-action {
    display: flex; flex-direction: column; align-items: center; gap: 0.4rem;
    padding: 0.85rem 0.5rem; border-radius: 10px; background: #f9fafb;
    border: 1px solid var(--training-border); text-decoration: none;
    color: var(--training-text); font-size: 0.82rem; font-weight: 600;
    transition: background 0.15s, border-color 0.15s;
}
.training-quick-action:hover { background: var(--training-accent-light); border-color: var(--training-accent); }
.training-quick-action span:first-child { font-size: 1.4rem; }
.training-quick-action.training-locked { opacity: 0.6; cursor: not-allowed; pointer-events: none; }

/* ----- Tier Info ----- */
.training-tier-info { text-align: center; color: var(--training-muted); font-size: 0.85rem; padding: 0.75rem; }
.training-commission-info { background: #f0fdf4; border-color: #a7f3d0; }

/* ----- Login Page ----- */
.training-login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: #f9fafb; }
.training-login-card { background: #fff; border: 1px solid var(--training-border); border-radius: 16px; padding: 2.5rem 2rem; max-width: 380px; width: 100%; text-align: center; box-shadow: 0 4px 24px rgba(0,0,0,0.08); }
.training-login-icon { font-size: 3rem; margin-bottom: 0.75rem; }
.training-login-card h1 { margin: 0 0 0.5rem; font-size: 1.4rem; }
.training-login-card p { color: var(--training-muted); margin: 0 0 1.5rem; font-size: 0.9rem; }
.training-login-note { font-size: 0.82rem; color: var(--training-muted); margin-top: 1rem; }

/* ===== LEARN (Student-Facing) Styles ===== */

/* ----- Hero ----- */
.learn-hero { background: linear-gradient(135deg, #065f46 0%, #047857 100%); color: #fff; padding: 3rem 1.5rem; text-align: center; }
.learn-hero-inner { max-width: 680px; margin: 0 auto; }
.learn-hero h1 { margin: 0 0 0.5rem; font-size: 2rem; }
.learn-hero p { color: #a7f3d0; margin: 0 0 1.5rem; }
.learn-hero-sub { margin: -0.75rem 0 1.25rem !important; font-size: 0.95rem; }
.learn-hero-sub a { color: #fff; text-decoration: underline; text-underline-offset: 2px; }
.learn-hero-sub a:hover { color: #ecfdf5; }
.learn-search-form { display: flex; gap: 0; max-width: 520px; margin: 0 auto; }
.learn-search-input { flex: 1; padding: 0.75rem 1rem; border: none; border-radius: 8px 0 0 8px; font-size: 1rem; outline: none; }
.learn-search-btn { background: var(--training-accent); color: #fff; border: none; padding: 0.75rem 1.5rem; border-radius: 0 8px 8px 0; font-weight: 700; cursor: pointer; font-size: 1rem; white-space: nowrap; }
.learn-search-btn:hover { background: #059669; }

/* ----- Browse Layout ----- */
.learn-browse-layout { display: flex; gap: 1.5rem; max-width: 1200px; margin: 0 auto; padding: 1.5rem; align-items: flex-start; }
@media (max-width: 900px) { .learn-browse-layout { flex-direction: column; padding: 1rem; } }
.learn-filters-sidebar { width: 220px; flex-shrink: 0; }
@media (max-width: 900px) { .learn-filters-sidebar { width: 100%; } }
.learn-results { flex: 1; min-width: 0; }
.learn-results-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; gap: 0.5rem; flex-wrap: wrap; }
.learn-results-header p { color: var(--training-muted); font-size: 0.9rem; margin: 0; }
.learn-sort-form { display: flex; align-items: center; gap: 0.35rem; font-size: 0.875rem; }
.learn-sort-select { padding: 0.3rem 0.5rem; border: 1px solid var(--training-border); border-radius: 6px; font-size: 0.875rem; }

/* ----- Filters ----- */
.learn-filter-section { margin-bottom: 1.25rem; }
.learn-filter-section h4 { font-size: 0.82rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--training-muted); margin: 0 0 0.5rem; }
.learn-filter-options { display: flex; flex-direction: column; gap: 0.3rem; }
.learn-filter-option { display: flex; align-items: center; gap: 0.5rem; cursor: pointer; font-size: 0.875rem; color: var(--training-text); padding: 0.2rem 0; }
.learn-filter-option input { cursor: pointer; }

/* ----- Course Cards (browse) ----- */
.learn-course-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1.25rem; }
.learn-course-card { background: #fff; border: 1px solid var(--training-border); border-radius: 12px; overflow: hidden; text-decoration: none; color: inherit; display: flex; flex-direction: column; transition: box-shadow 0.15s, transform 0.15s; box-shadow: 0 1px 3px rgba(0,0,0,0.06); }
.learn-course-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,0.1); transform: translateY(-2px); }
.learn-course-thumb { aspect-ratio: 16/9; overflow: hidden; background: #f3f4f6; position: relative; display: flex; align-items: center; justify-content: center; }
.learn-course-thumb img { width: 100%; height: 100%; object-fit: cover; }
.learn-course-thumb-placeholder { font-size: 2.5rem; }
.learn-badge-free { position: absolute; top: 0.5rem; left: 0.5rem; background: #059669; color: #fff; font-size: 0.72rem; font-weight: 700; padding: 0.15rem 0.5rem; border-radius: 4px; }
.learn-course-info { padding: 0.85rem; flex: 1; display: flex; flex-direction: column; }
.learn-course-category { font-size: 0.72rem; color: var(--training-accent); font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 0.3rem; }
.learn-course-title { font-size: 0.95rem; font-weight: 700; margin: 0 0 0.25rem; color: var(--training-text); line-height: 1.35; }
.learn-course-provider { font-size: 0.78rem; color: var(--training-muted); margin: 0 0 0.35rem; }
.learn-course-rating { display: flex; align-items: center; gap: 0.3rem; font-size: 0.8rem; margin-bottom: 0.3rem; }
.learn-stars { color: #f59e0b; letter-spacing: -1px; }
.learn-review-count { color: var(--training-muted); }
.learn-course-meta { display: flex; flex-wrap: wrap; gap: 0.25rem 0.6rem; font-size: 0.75rem; color: var(--training-muted); margin-bottom: 0.5rem; }
.learn-course-price { margin-top: auto; font-size: 1rem; font-weight: 700; color: var(--training-text); }
.learn-price-free { color: #059669; }
.learn-empty { text-align: center; padding: 3rem 1rem; }
.learn-empty-icon { font-size: 3rem; margin-bottom: 1rem; }

/* ----- Course Landing Page ----- */
.learn-course-hero { background: #1e293b; color: #fff; padding: 2.5rem 1.5rem; display: flex; gap: 2rem; max-width: 1200px; margin: 0 auto; align-items: flex-start; }
@media (max-width: 768px) { .learn-course-hero { flex-direction: column; padding: 1.5rem; } }
.learn-course-hero-inner { flex: 1; }
.learn-course-breadcrumb { font-size: 0.8rem; color: #94a3b8; margin-bottom: 0.75rem; }
.learn-course-breadcrumb a { color: #94a3b8; text-decoration: none; }
.learn-course-hero h1 { margin: 0 0 0.5rem; font-size: 1.8rem; }
.learn-course-short-desc { color: #94a3b8; font-size: 1rem; margin: 0 0 1rem; }
.learn-course-hero-meta { display: flex; flex-wrap: wrap; gap: 0.4rem 1rem; font-size: 0.85rem; color: #a7f3d0; margin-bottom: 0.75rem; }
.learn-stars-lg { color: #f59e0b; font-size: 1rem; }
.learn-course-provider-line { font-size: 0.85rem; color: #a7f3d0; margin: 0; }
.learn-course-provider-line a { color: #6ee7b7; }
.learn-course-hero-thumb { width: 280px; flex-shrink: 0; border-radius: 8px; overflow: hidden; }
.learn-course-hero-thumb img { width: 100%; display: block; }
.learn-course-layout { display: flex; gap: 1.5rem; max-width: 1200px; margin: 0 auto; padding: 1.5rem; align-items: flex-start; }
@media (max-width: 900px) { .learn-course-layout { flex-direction: column; padding: 1rem; } }
.learn-course-main { flex: 1; min-width: 0; }
.learn-section { margin-bottom: 2rem; }
.learn-section h2 { font-size: 1.25rem; margin: 0 0 1rem; }
.learn-course-description { font-size: 0.9rem; line-height: 1.7; color: var(--training-text); white-space: pre-line; }
.learn-video-embed { position: relative; aspect-ratio: 16/9; background: #000; border-radius: 8px; overflow: hidden; }
.learn-iframe { position: absolute; inset: 0; width: 100%; height: 100%; }
.learn-video { width: 100%; border-radius: 8px; }
.learn-curriculum { border: 1px solid var(--training-border); border-radius: 10px; overflow: hidden; }
.learn-module { border-bottom: 1px solid var(--training-border); }
.learn-module:last-child { border-bottom: none; }
.learn-module-header { display: flex; justify-content: space-between; align-items: center; background: #f9fafb; padding: 0.75rem 1rem; cursor: pointer; }
.learn-module-header strong { font-size: 0.9rem; }
.learn-module-header span { font-size: 0.8rem; color: var(--training-muted); }
.learn-lesson-list { padding: 0.25rem 0; }
.learn-lesson-item { display: flex; align-items: center; gap: 0.5rem; padding: 0.5rem 1rem; font-size: 0.875rem; border-bottom: 1px solid #f3f4f6; }
.learn-lesson-item:last-child { border-bottom: none; }
.learn-lesson-type-icon { font-size: 0.9rem; }
.learn-lesson-name { flex: 1; }
.learn-free-preview-link { color: var(--training-accent); font-size: 0.78rem; font-weight: 600; text-decoration: none; }
.learn-locked { color: var(--training-muted); font-size: 0.85rem; }
.learn-duration { color: var(--training-muted); font-size: 0.78rem; margin-left: auto; }
.learn-reviews { display: flex; flex-direction: column; gap: 1rem; }
.learn-review { background: #f9fafb; border-radius: 8px; padding: 1rem; }
.learn-review-stars { color: #f59e0b; margin-bottom: 0.25rem; }
.learn-review p { margin: 0 0 0.25rem; font-size: 0.875rem; }
.learn-review small { color: var(--training-muted); font-size: 0.78rem; }

/* ----- Enrollment Sidebar ----- */
.learn-course-sidebar { width: 320px; flex-shrink: 0; position: sticky; top: 1rem; }
@media (max-width: 900px) { .learn-course-sidebar { width: 100%; position: static; } }
.learn-enroll-card { background: #fff; border: 1px solid var(--training-border); border-radius: 12px; overflow: hidden; box-shadow: 0 4px 16px rgba(0,0,0,0.08); }
.learn-enroll-thumb { width: 100%; display: block; aspect-ratio: 16/9; object-fit: cover; }
.learn-enroll-price { padding: 1rem 1rem 0.5rem; text-align: center; }
.learn-price-lg { font-size: 1.8rem; font-weight: 700; color: var(--training-text); }
.learn-price-free-lg { font-size: 1.8rem; font-weight: 700; color: #059669; }
.learn-btn-enroll {
    display: block; background: var(--training-accent); color: #fff; text-decoration: none;
    text-align: center; padding: 0.85rem 1rem; margin: 0.75rem 1rem; border-radius: 8px;
    font-weight: 700; font-size: 1rem; transition: background 0.15s;
}
.learn-btn-enroll:hover { background: #059669; }
.learn-enroll-features { list-style: none; padding: 0 1rem 1rem; margin: 0; font-size: 0.85rem; color: var(--training-muted); }
.learn-enroll-features li { padding: 0.3rem 0; border-bottom: 1px solid var(--training-border); }
.learn-enroll-features li:last-child { border-bottom: none; }

/* ----- Lesson Viewer ----- */
.learn-lesson-layout { display: flex; height: 100vh; overflow: hidden; }
@media (max-width: 768px) { .learn-lesson-layout { flex-direction: column; height: auto; } }
.learn-lesson-sidebar { width: 280px; flex-shrink: 0; border-right: 1px solid var(--training-border); overflow-y: auto; background: #1e293b; color: #fff; }
@media (max-width: 768px) { .learn-lesson-sidebar { width: 100%; height: auto; max-height: 40vh; overflow-y: auto; border-right: none; border-bottom: 1px solid var(--training-border); } }
.learn-lesson-sidebar-header { padding: 1rem; border-bottom: 1px solid rgba(255,255,255,0.1); }
.learn-lesson-sidebar-header a { color: #a7f3d0; font-size: 0.85rem; text-decoration: none; display: block; margin-bottom: 0.5rem; }
.learn-progress-mini { background: rgba(255,255,255,0.15); height: 5px; border-radius: 3px; margin: 0.35rem 0; overflow: hidden; }
.learn-progress-mini .learn-progress-fill { background: var(--training-accent); height: 100%; }
.learn-lesson-sidebar-header small { font-size: 0.75rem; color: #94a3b8; }
.learn-sidebar-module { border-bottom: 1px solid rgba(255,255,255,0.08); }
.learn-sidebar-module-title { padding: 0.6rem 1rem; font-size: 0.78rem; font-weight: 700; color: #94a3b8; text-transform: uppercase; letter-spacing: 0.05em; }
.learn-sidebar-lesson { display: flex; align-items: center; gap: 0.5rem; padding: 0.5rem 1rem; font-size: 0.82rem; text-decoration: none; color: #a7f3d0; transition: background 0.1s; }
.learn-sidebar-lesson:hover { background: rgba(255,255,255,0.06); }
.learn-sidebar-lesson.active { background: rgba(16,185,129,0.15); color: #fff; font-weight: 600; }
.learn-sidebar-lesson.completed .learn-sidebar-lesson-icon { color: #6ee7b7; }
.learn-sidebar-lesson.locked { color: #475569; cursor: not-allowed; }
.learn-sidebar-lesson-icon { font-size: 0.9rem; flex-shrink: 0; }
.learn-lesson-main { flex: 1; overflow-y: auto; padding: 2rem; background: #fff; }
@media (max-width: 768px) { .learn-lesson-main { padding: 1.25rem 1rem; } }
.learn-lesson-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 0.5rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.learn-lesson-header h1 { margin: 0; font-size: 1.4rem; flex: 1; }
.learn-lesson-type-badge { background: #f3f4f6; color: var(--training-muted); font-size: 0.78rem; padding: 0.25rem 0.6rem; border-radius: 20px; font-weight: 600; white-space: nowrap; }
.learn-video-player { margin-bottom: 1.5rem; position: relative; aspect-ratio: 16/9; background: #000; border-radius: 8px; overflow: hidden; }
.learn-lesson-content { line-height: 1.75; font-size: 0.95rem; color: var(--training-text); margin-bottom: 1.5rem; }
.learn-document-section { margin-bottom: 1.5rem; }
.learn-btn-download { display: inline-flex; align-items: center; gap: 0.5rem; background: #f3f4f6; color: var(--training-text); text-decoration: none; padding: 0.65rem 1.25rem; border-radius: 8px; font-weight: 600; font-size: 0.9rem; border: 1px solid var(--training-border); }
.learn-complete-form { margin-top: 1.5rem; }
.learn-btn-complete { background: var(--training-accent); color: #fff; border: none; padding: 0.75rem 1.5rem; border-radius: 8px; font-weight: 700; font-size: 1rem; cursor: pointer; min-height: 48px; }
.learn-btn-complete:hover { background: #059669; }
.learn-lesson-done { color: #059669; font-weight: 700; margin-top: 1.5rem; font-size: 1rem; }
.learn-course-complete-banner { background: #d1fae5; border: 1px solid #6ee7b7; color: #065f46; padding: 1.25rem 1.5rem; border-radius: 10px; margin-top: 1.5rem; display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.learn-btn-certificate { background: #f59e0b; color: #fff; text-decoration: none; padding: 0.5rem 1.1rem; border-radius: 8px; font-weight: 700; font-size: 0.9rem; white-space: nowrap; }

/* ----- My Courses ----- */
.learn-my-courses-wrap { max-width: 1100px; margin: 0 auto; padding: 1.5rem; }
.learn-page-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.5rem; flex-wrap: wrap; gap: 0.75rem; }
.learn-page-header h1 { margin: 0; font-size: 1.5rem; }
.learn-btn-browse { background: var(--training-accent); color: #fff; text-decoration: none; padding: 0.5rem 1.1rem; border-radius: 8px; font-weight: 600; font-size: 0.875rem; }
.learn-my-courses-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.25rem; }
.learn-my-course-card { background: #fff; border: 1px solid var(--training-border); border-radius: 12px; overflow: hidden; }
.learn-my-course-thumb { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.learn-my-course-thumb-placeholder { font-size: 3rem; background: #f3f4f6; aspect-ratio: 16/9; display: flex; align-items: center; justify-content: center; }
.learn-my-course-body { padding: 1rem; }
.learn-my-course-body h3 { margin: 0 0 0.25rem; font-size: 1rem; }
.learn-my-course-provider { color: var(--training-muted); font-size: 0.82rem; margin: 0 0 0.75rem; }
.learn-my-course-actions { display: flex; gap: 0.5rem; margin-top: 0.75rem; flex-wrap: wrap; }
.learn-btn-continue { background: var(--training-accent); color: #fff; text-decoration: none; padding: 0.4rem 0.85rem; border-radius: 6px; font-size: 0.85rem; font-weight: 600; }
.learn-btn-cert { background: #f59e0b; color: #fff; text-decoration: none; padding: 0.4rem 0.85rem; border-radius: 6px; font-size: 0.85rem; font-weight: 600; }

/* ----- Certificate ----- */
.learn-certificate-page { max-width: 800px; margin: 0 auto; padding: 2rem 1.5rem; }
.learn-certificate { margin-bottom: 1.5rem; }
.learn-certificate-border { border: 3px solid #d97706; border-radius: 16px; padding: 3rem; text-align: center; background: #fff; }
.learn-certificate-header { margin-bottom: 1.5rem; }
.learn-cert-logo { font-size: 3rem; display: block; margin-bottom: 0.5rem; }
.learn-cert-title { font-size: 1.8rem; font-weight: 700; margin: 0; color: #d97706; }
.learn-cert-body { margin-bottom: 2rem; }
.learn-cert-presented { color: var(--training-muted); margin: 0; }
.learn-cert-name { font-size: 2.2rem; font-weight: 700; color: var(--training-text); margin: 0.5rem 0; }
.learn-cert-text { color: var(--training-muted); margin: 0; }
.learn-cert-course { font-size: 1.3rem; font-weight: 700; color: #065f46; margin: 0.5rem 0; }
.learn-cert-provider { margin: 0; color: var(--training-muted); }
.learn-cert-footer { display: flex; justify-content: center; gap: 3rem; flex-wrap: wrap; padding-top: 1.5rem; border-top: 1px solid var(--training-border); }
.learn-cert-date, .learn-cert-number { text-align: center; font-size: 0.85rem; }
.learn-cert-date strong, .learn-cert-number strong { display: block; margin-bottom: 0.25rem; color: var(--training-muted); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; }
.learn-cert-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; align-items: center; justify-content: center; }
.learn-btn-print { background: #1e293b; color: #fff; border: none; padding: 0.5rem 1.1rem; border-radius: 8px; font-weight: 600; cursor: pointer; font-size: 0.9rem; }
.learn-cert-verify { font-size: 0.78rem; color: var(--training-muted); width: 100%; text-align: center; margin-top: 0.5rem; }

/* ----- Enroll Page ----- */
.learn-enroll-page { max-width: 580px; margin: 0 auto; padding: 2rem 1.5rem; }
.learn-enroll-header { text-align: center; margin-bottom: 1.5rem; }
.learn-enroll-header h1 { margin: 0 0 0.25rem; font-size: 1.5rem; }
.learn-enroll-header h2 { margin: 0 0 0.25rem; font-size: 1.1rem; font-weight: 600; }
.learn-enroll-form-wrap { background: #fff; border: 1px solid var(--training-border); border-radius: 12px; padding: 1.5rem; }
.learn-enroll-summary { margin-bottom: 1.25rem; }
.learn-btn-enroll-lg { display: block; background: var(--training-accent); color: #fff; text-decoration: none; text-align: center; padding: 1rem; border-radius: 8px; font-weight: 700; font-size: 1.1rem; margin-top: 1rem; }
.learn-paid-enroll { margin-top: 0.5rem; }
.learn-discount-form { display: flex; gap: 0.5rem; align-items: center; margin-bottom: 1rem; flex-wrap: wrap; }
.learn-discount-form label { font-size: 0.875rem; font-weight: 600; }
.learn-enroll-note { font-size: 0.78rem; color: var(--training-muted); margin-top: 0.75rem; text-align: center; }

/* ----- Training Directory ----- */
.training-dir-category-bar { display: flex; flex-wrap: wrap; gap: 0.5rem; padding: 1rem 1.5rem; background: #fff; border-bottom: 1px solid var(--training-border); max-width: 1200px; margin: 0 auto; }
.training-dir-cat-pill { padding: 0.35rem 0.85rem; border-radius: 20px; font-size: 0.82rem; font-weight: 600; text-decoration: none; color: var(--training-muted); background: #f3f4f6; transition: background 0.15s, color 0.15s; white-space: nowrap; }
.training-dir-cat-pill.active { background: var(--training-accent); color: #fff; }
.training-dir-provider-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1.25rem; }
.training-dir-provider-card { background: #fff; border: 1px solid var(--training-border); border-radius: 12px; padding: 1.25rem; text-decoration: none; color: inherit; display: flex; flex-direction: column; transition: box-shadow 0.15s, transform 0.15s; position: relative; }
.training-dir-provider-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,0.1); transform: translateY(-2px); }
.training-dir-featured { border-color: #f59e0b; box-shadow: 0 0 0 2px #fef3c7; }
.training-dir-featured-label { position: absolute; top: 0.75rem; right: 0.75rem; background: #f59e0b; color: #fff; font-size: 0.72rem; font-weight: 700; padding: 0.15rem 0.5rem; border-radius: 4px; }
.training-dir-provider-logo { width: 60px; height: 60px; border-radius: 8px; overflow: hidden; margin-bottom: 0.75rem; background: #f3f4f6; display: flex; align-items: center; justify-content: center; }
.training-dir-provider-logo img { width: 100%; height: 100%; object-fit: cover; }
.training-dir-logo-placeholder { font-size: 2rem; }
.training-dir-provider-body h3 { margin: 0 0 0.25rem; font-size: 1rem; color: var(--training-text); }
.training-dir-tagline { color: var(--training-muted); font-size: 0.82rem; margin: 0 0 0.35rem; }
.training-dir-location { color: var(--training-muted); font-size: 0.78rem; margin: 0 0 0.35rem; }
.training-dir-stats { display: flex; flex-wrap: wrap; gap: 0.3rem 0.75rem; font-size: 0.78rem; color: var(--training-muted); margin-bottom: 0.5rem; }
.training-dir-tags { display: flex; flex-wrap: wrap; gap: 0.25rem; margin-top: 0.35rem; }
.training-dir-tag { background: var(--training-accent-light); color: #065f46; font-size: 0.72rem; padding: 0.1rem 0.45rem; border-radius: 4px; font-weight: 600; }
.training-provider-hero { background: #1e293b; color: #fff; }
.training-provider-hero-inner { display: flex; gap: 1.5rem; max-width: 1200px; margin: 0 auto; padding: 2rem 1.5rem; align-items: flex-start; flex-wrap: wrap; }
.training-provider-logo-wrap { flex-shrink: 0; }
.training-provider-logo { width: 80px; height: 80px; border-radius: 12px; object-fit: cover; }
.training-provider-logo-placeholder { width: 80px; height: 80px; font-size: 3rem; background: rgba(255,255,255,0.1); border-radius: 12px; display: flex; align-items: center; justify-content: center; }
.training-provider-info { flex: 1; min-width: 200px; }
.training-provider-info h1 { margin: 0 0 0.35rem; font-size: 1.6rem; }
.training-provider-tagline { color: #a7f3d0; margin: 0 0 0.5rem; font-size: 1rem; }
.training-provider-stats { display: flex; flex-wrap: wrap; gap: 0.5rem 1.25rem; font-size: 0.875rem; color: #a7f3d0; margin: 0.5rem 0 0.75rem; }
.training-provider-layout { display: flex; gap: 1.5rem; max-width: 1200px; margin: 0 auto; padding: 1.5rem; align-items: flex-start; }
@media (max-width: 900px) { .training-provider-layout { flex-direction: column; padding: 1rem; } }
.training-provider-main { flex: 1; min-width: 0; }
.training-provider-sidebar { width: 280px; flex-shrink: 0; }
@media (max-width: 900px) { .training-provider-sidebar { width: 100%; } }
.training-section { margin-bottom: 2rem; }
.training-section h2 { font-size: 1.25rem; margin: 0 0 1rem; }
.training-provider-bio { font-size: 0.9rem; line-height: 1.75; white-space: pre-line; }

/* ----- YouTube / Server Video Promotion Panel ----- */
.training-youtube-promo {
    background: linear-gradient(135deg, #f0fdf4 0%, #ecfdf5 100%);
    border: 1px solid #6ee7b7;
    border-left: 4px solid #059669;
    border-radius: 8px;
    margin-bottom: 1rem;
    overflow: hidden;
}
.training-youtube-promo-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.7rem 1rem;
    background: rgba(5, 150, 105, 0.08);
    border-bottom: 1px solid #a7f3d0;
    font-size: 0.95rem;
    color: #065f46;
}
.training-youtube-promo-icon { font-size: 1.2rem; flex-shrink: 0; }
.training-youtube-promo-body {
    padding: 0.75rem 1rem;
    font-size: 0.875rem;
    color: #1f2937;
    line-height: 1.6;
}
.training-youtube-promo-body ul {
    margin: 0.5rem 0;
    padding-left: 1.1rem;
}
.training-youtube-promo-body li { margin-bottom: 0.25rem; }
.training-youtube-promo-body p { margin: 0 0 0.4rem; }
.training-youtube-promo-fee {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1.25rem;
    align-items: center;
    padding: 0.6rem 1rem;
    background: #fef9c3;
    border-top: 1px solid #fde68a;
    font-size: 0.875rem;
    color: #92400e;
}

/* ----- Print Certificate ----- */
@media print {
    body { margin: 0; }
    .learn-certificate-border { border: 3px solid #d97706; border-radius: 0; }
    .learn-cert-actions, header, footer, nav { display: none !important; }
    .learn-certificate-page { padding: 0; max-width: none; }
}
