*{margin:0;padding:0;box-sizing:border-box}
:root{
  --blue:#1a3fa8;
  --blue-dark:#0f2872;
  --gold:#f0a500;
  --gold-light:#ffd166;
  --white:#ffffff;
  --gray-50:#f8f9fc;
  --gray-100:#f0f2f8;
  --gray-200:#e5e7eb;
  --gray-400:#9ca3af;
  --gray-600:#4b5563;
  --gray-800:#1f2937;
  --text:#0c1445;
  --danger:#b91c1c;
  --success:#047857;
}

body{font-family:'DM Sans',sans-serif;color:var(--text);background:#fff;overflow-x:hidden}
a{text-decoration:none;color:inherit}

/* small utility classes used in views */
.hidden{display:none}
.bg-gray-50{background:var(--gray-50)}
.bg-gray-100{background:var(--gray-100)}
.text-slate-800{color:var(--gray-800)}
.btn-block{display:block;width:100%}
.btn-lg{padding:12px 20px;font-size:1rem}
.btn-sm{padding:7px 12px;font-size:.8rem}
@media (min-width:768px){.md\:flex{display:flex}}

/* nav / main layout */
.lms-nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.06);padding:0 5%}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{width:38px;height:38px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}
.logo-text{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--text);line-height:1.1}
.logo-text span,.logo-text small{display:block;font-family:'DM Sans',sans-serif;font-size:.55rem;letter-spacing:2px;color:var(--blue);text-transform:uppercase}
.nav-links{list-style:none;gap:24px}
.nav-links a{color:var(--gray-600);font-size:.9rem;font-weight:500}
.nav-right{display:flex;gap:10px;align-items:center}
.nav-search input{height:36px;min-width:220px;padding:0 10px;border:1px solid var(--gray-200);border-radius:8px;background:#fff;color:var(--gray-800)}
.nav-search input:focus{outline:none;border-color:var(--blue)}

.nav-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:var(--gray-50);border:1px solid var(--gray-100);position:relative}

.btn-ghost{padding:8px 16px;border:1.5px solid var(--blue);color:var(--blue);border-radius:8px;font-size:.875rem;font-weight:600;background:transparent}
.btn-primary{padding:9px 18px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.badge,.badge-sm{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:999px;background:#dc2626;color:#fff;font-size:.7rem;margin-left:4px}

.user-menu{position:relative}
.user-btn{width:36px;height:36px;border:none;border-radius:999px;background:var(--blue);color:#fff;font-weight:700;cursor:pointer}
.dropdown-menu{position:absolute;right:0;top:44px;background:#fff;border:1px solid var(--gray-200);border-radius:10px;min-width:200px;padding:8px;box-shadow:0 8px 24px rgba(0,0,0,.1)}
.dropdown-menu a{display:block;padding:8px 10px;border-radius:8px;color:var(--gray-800)}
.dropdown-menu a:hover{background:var(--gray-50)}

main{min-height:60vh}

/* flash */
.flash{margin:12px auto;max-width:1200px;padding:12px 16px;border-radius:8px;position:relative}
.flash-success{background:#ecfdf5;color:var(--success);border:1px solid #a7f3d0}
.flash-error{background:#fef2f2;color:var(--danger);border:1px solid #fecaca}
.flash-close{position:absolute;right:10px;top:8px;border:none;background:transparent;font-size:1.1rem;cursor:pointer}

/* footer */
.lms-footer{background:var(--text);color:rgba(255,255,255,.75);padding:56px 5% 24px}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:28px}
.footer-col h5{color:#fff;margin-bottom:10px}
.footer-links{list-style:none}
.footer-links li{margin:6px 0}
.footer-links a{color:rgba(255,255,255,.7);font-size:.86rem}
.footer-disclaimer{font-size:.78rem;opacity:.85;border-top:1px solid rgba(255,255,255,.12);padding-top:16px;margin-top:14px}
.footer-bottom{margin-top:16px;display:flex;justify-content:space-between;align-items:center}
.social-btn{width:34px;height:34px;background:rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;border-radius:8px}

/* dashboard/admin */
.dash-layout{display:grid;grid-template-columns:270px 1fr;min-height:100vh}
.dash-sidebar{background:#0f172a;color:#e2e8f0;padding:18px 12px}
.admin-sidebar{background:#111827}
.sidebar-header{margin-bottom:14px}
.sidebar-nav{display:flex;flex-direction:column;gap:4px}
.sidebar-nav a{padding:10px 12px;border-radius:8px;color:#cbd5e1;font-size:.9rem}
.sidebar-nav a:hover,.sidebar-nav a.active{background:rgba(255,255,255,.08);color:#fff}
.sidebar-section-label{font-size:.72rem;letter-spacing:1px;opacity:.7;margin:10px 8px 4px}
.sidebar-divider{border:0;border-top:1px solid rgba(255,255,255,.1);margin:10px 0}
.sidebar-logout{color:#fecaca !important}

.dash-main{display:flex;flex-direction:column}
.dash-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#fff;border-bottom:1px solid var(--gray-200)}
.dash-page-title{font-family:'Playfair Display',serif;font-size:1.4rem}
.dash-header-right{display:flex;gap:12px;align-items:center}
.dash-user{font-size:.9rem;color:var(--gray-600)}
.admin-badge{font-size:.72rem;background:#fee2e2;color:#b91c1c;padding:4px 10px;border-radius:999px;font-weight:700}
.dash-content{padding:20px}
.dash-footer{padding:14px 20px;border-top:1px solid var(--gray-200);font-size:.78rem;color:var(--gray-600);background:#fff}

@media (max-width: 900px){
  .dash-layout{grid-template-columns:1fr}
  .dash-sidebar{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
}

/* =====================================================
   Homepage styles (synced to root homepage.html look)
   ===================================================== */

.section-inner{max-width:1200px;margin:0 auto}

.hero-section{
  min-height:calc(100vh - 72px);
  background:linear-gradient(135deg,#0c1b5e 0%,#1a3fa8 50%,#0c1445 100%);
  position:relative;
  display:flex;
  align-items:center;
  overflow:hidden;
  padding:32px 5%;
}

.hero-bg{position:absolute;inset:0;pointer-events:none;opacity:.45}
.hero-bg::before,
.hero-bg::after{content:"";position:absolute;border-radius:999px}
.hero-bg::before{width:560px;height:560px;background:var(--gold);right:-120px;top:-220px;opacity:.12}
.hero-bg::after{width:260px;height:260px;background:#60a5fa;left:4%;bottom:-60px;opacity:.14}

.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;position:relative;z-index:2}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(240,165,0,.15);border:1px solid rgba(240,165,0,.3);color:var(--gold-light);padding:6px 16px;border-radius:999px;font-size:.78rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:24px}

.hero-text h1{font-family:'Playfair Display',serif;font-size:3.4rem;font-weight:900;color:#fff;line-height:1.12;margin-bottom:20px}
.hero-text h1 .accent{color:var(--gold-light)}
.hero-sub{color:rgba(255,255,255,.75);font-size:1.02rem;line-height:1.7;margin-bottom:34px;max-width:520px}

.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:42px}
.btn-hero{padding:14px 28px;background:linear-gradient(135deg,var(--gold),#e09000);color:var(--text);border-radius:10px;font-size:1rem;font-weight:700;border:none;display:inline-flex;align-items:center;justify-content:center}
.btn-hero-outline{padding:14px 28px;background:rgba(255,255,255,.1);color:#fff;border-radius:10px;font-size:1rem;font-weight:600;border:1.5px solid rgba(255,255,255,.25);backdrop-filter:blur(10px)}

.hero-stats{display:flex;gap:34px}
.hero-stat .stat-num{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:900;color:#fff;display:block}
.hero-stat .stat-label{font-size:.78rem;color:rgba(255,255,255,.6);font-weight:500;letter-spacing:.5px}

.hero-visual{position:relative}
.hero-card{background:rgba(255,255,255,.08);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:26px}
.hero-card h4{color:#fff;font-size:.95rem;margin-bottom:6px}
.hero-card p{color:rgba(255,255,255,.65);font-size:.82rem;line-height:1.55}
.card-icon{font-size:1.35rem;margin-bottom:8px}
.progress-bar{height:5px;background:rgba(255,255,255,.18);border-radius:999px;overflow:hidden;margin-top:12px}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-light));border-radius:999px}
.hero-card small{color:rgba(255,255,255,.65);font-size:.72rem;display:block;margin-top:6px}

.disclaimer-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;background:linear-gradient(135deg,var(--gold),#e09000);color:var(--text);padding:10px 5%;font-size:.82rem;font-weight:600}
.disclaimer-bar a{font-weight:800;text-decoration:underline}

.section-light{padding:84px 5%;background:#fff}
.section-white{padding:84px 5%;background:var(--gray-50)}

.section-header{text-align:center;margin-bottom:56px}
.section-tag{display:inline-block;background:rgba(26,63,168,.08);color:var(--blue);padding:5px 14px;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:14px}
.section-header h2{font-family:'Playfair Display',serif;font-size:2.4rem;font-weight:900;color:var(--text);line-height:1.2;margin-bottom:14px}
.section-header h2 .gold{color:var(--blue)}
.section-sub{color:var(--gray-600);font-size:1rem;max-width:620px;margin:0 auto;line-height:1.7}

.categories-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cat-card{background:var(--gray-50);border:1.5px solid var(--gray-100);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:14px;transition:all .25s}
.cat-card:hover{border-color:var(--blue);background:rgba(26,63,168,.04);transform:translateY(-2px)}
.cat-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.cat-info h4{font-size:.9rem;font-weight:600;color:var(--text);margin-bottom:2px}
.cat-info span{font-size:.75rem;color:var(--gray-400)}

.courses-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.course-card{background:#fff;border:1.5px solid var(--gray-100);border-radius:16px;overflow:hidden;transition:all .25s}
.course-card:hover{border-color:rgba(26,63,168,.2);transform:translateY(-4px);box-shadow:0 16px 48px rgba(26,63,168,.1)}
.course-thumb-wrap{position:relative;display:block;aspect-ratio:16/9;overflow:hidden}
.course-thumb-img,.course-thumb-placeholder{width:100%;height:100%;object-fit:cover;background:linear-gradient(135deg,#e0e7ff,#bfdbfe);display:flex;align-items:center;justify-content:center;font-size:3rem}
.course-badge{position:absolute;top:10px;left:10px;background:var(--blue);color:#fff;font-size:.65rem;font-weight:700;padding:3px 10px;border-radius:999px;letter-spacing:.5px;text-transform:uppercase}
.course-badge.free{background:#10b981}
.ce-badge{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.92);color:var(--blue);font-size:.68rem;font-weight:800;padding:4px 8px;border-radius:999px}
.course-body{padding:18px}
.course-cat{font-size:.7rem;color:var(--blue);font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.course-title{font-size:.85rem;font-weight:700;color:var(--text);line-height:1.4;margin-bottom:8px}
.course-instructor{font-size:.78rem;color:var(--gray-400);margin-bottom:10px}
.course-rating{display:flex;align-items:center;gap:6px;margin-bottom:12px}
.rating-num{font-size:.82rem;font-weight:700;color:#92400e}
.rating-count{font-size:.73rem;color:var(--gray-400)}
.ce-info-row{font-size:.74rem;color:var(--gray-600);margin-bottom:10px}
.course-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--gray-100)}
.course-price{font-size:1.1rem;font-weight:800;color:var(--blue)}
.free-label{color:#10b981}
.course-price-orig{font-size:.8rem;color:var(--gray-400);text-decoration:line-through;margin-left:6px;font-weight:400}
.course-meta{display:flex;gap:12px;font-size:.73rem;color:var(--gray-400)}

.section-cta{text-align:center;margin-top:40px}

.how-section{padding:90px 5%;background:linear-gradient(135deg,#0c1b5e,#1a3fa8)}
.how-section .section-header h2{color:#fff}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;position:relative}
.steps-grid::before{content:"";position:absolute;top:30px;left:calc(12.5% + 20px);right:calc(12.5% + 20px);height:2px;background:rgba(255,255,255,.1)}
.step-card{text-align:center;position:relative}
.step-num{width:60px;height:60px;background:rgba(255,255,255,.1);border:2px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:900;color:#fff;position:relative;z-index:2}
.step-icon{font-size:1.6rem;margin-bottom:12px}
.step-card h4{color:#fff;font-size:.95rem;font-weight:700;margin-bottom:8px}
.step-card p{color:rgba(255,255,255,.6);font-size:.82rem;line-height:1.6}

.full-disclaimer-section{background:#fff;padding:40px 5% 70px}
.full-disclaimer-section h3{font-family:'Playfair Display',serif;font-size:1.45rem;color:var(--text);margin-bottom:10px}
.full-disclaimer-section p{font-size:.9rem;color:var(--gray-600);line-height:1.7}

/* =====================================================
   Premium Course Detail (v2 Redesign)
   ===================================================== */
.course-hero-v2 {
    background: linear-gradient(135deg, #f8fafc 0%, #eff6ff 100%);
    padding: 80px 0;
    position: relative;
    border-bottom: 1px solid var(--gray-200);
}

.course-hero-v2 .hero-content-grid {
    display: grid;
    grid-template-columns: 1fr 450px;
    gap: 60px;
    align-items: center;
}

.course-hero-v2 .premium-title {
    font-family: 'Playfair Display', serif;
    font-size: 3.2rem;
    line-height: 1.1;
    margin-bottom: 20px;
    color: var(--text);
}

.course-hero-v2 .premium-subtitle {
    font-size: 1.25rem;
    line-height: 1.6;
    margin-bottom: 30px;
    color: var(--gray-600);
    max-width: 650px;
}

.course-hero-v2 .hero-image-wrap {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 20px 50px rgba(0,0,0,0.1);
}

.course-hero-v2 .hero-image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.course-hero-v2 .badge-item {
    font-weight: 600;
    color: var(--gray-800);
}

.course-hero-v2 .stars {
    color: var(--gold);
}

.course-hero-v2 .rating-val {
    font-weight: 800;
    color: var(--text);
}

.course-hero-v2 .btn-get-started {
    padding: 16px 32px;
    background: var(--blue);
    color: #fff;
    border-radius: 12px;
    font-weight: 700;
    font-size: 1.1rem;
    display: inline-block;
    margin-top: 20px;
    transition: transform 0.2s;
}

.course-hero-v2 .btn-get-started:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(26,63,168,0.2);
}

/* Updated Sidebar for Redesign */
.v2-sidebar-card {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 20px;
    padding: 30px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
    position: sticky;
    top: 100px;
}

.v2-sidebar-card .price-wrap {
    margin-bottom: 24px;
}

.v2-sidebar-card .current-price {
    font-size: 2.5rem;
    font-weight: 900;
    color: var(--text);
}

.v2-sidebar-card .old-price {
    font-size: 1.2rem;
    color: var(--gray-400);
    text-decoration: line-through;
    margin-left: 10px;
}

.v2-sidebar-card .discount-tag {
    background: #fef2f2;
    color: var(--danger);
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 0.85rem;
    font-weight: 800;
    margin-left: 10px;
}

.v2-sidebar-card .btn-buy-now {
    background: var(--success);
    color: #fff;
    width: 100%;
    padding: 18px;
    border-radius: 12px;
    font-weight: 800;
    font-size: 1.1rem;
    margin-bottom: 12px;
    text-align: center;
    border: none;
    cursor: pointer;
}

.v2-sidebar-card .btn-add-cart {
    background: #fff;
    color: var(--text);
    width: 100%;
    padding: 16px;
    border-radius: 12px;
    font-weight: 700;
    border: 2px solid var(--gray-200);
    margin-bottom: 24px;
    cursor: pointer;
}

.v2-sidebar-card .feature-list {
    list-style: none;
    margin-top: 20px;
}

.v2-sidebar-card .feature-list li {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.95rem;
    color: var(--gray-600);
    margin-bottom: 12px;
}

.main-layout-grid-v2 {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 50px;
    padding: 60px 0;
}

.v2-content-block {
    background: #fff;
    border: 1px solid var(--gray-100);
    border-radius: 20px;
    padding: 40px;
    margin-bottom: 30px;
}

.v2-content-block h2 {
    font-family: 'Playfair Display', serif;
    font-size: 1.8rem;
    margin-bottom: 25px;
    color: var(--text);
}

.v2-objectives-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px 30px;
}

.v2-obj-item {
    display: flex;
    gap: 12px;
    font-size: 1rem;
    color: var(--gray-700);
}

.v2-obj-icon {
    color: var(--success);
    font-weight: 900;
}

.v2-accordion {
    border: 1px solid var(--gray-200);
    border-radius: 12px;
    overflow: hidden;
}

.v2-accordion-item {
    border-bottom: 1px solid var(--gray-200);
}

.v2-accordion-item:last-child {
    border-bottom: none;
}

.v2-accordion-header {
    padding: 20px;
    background: var(--gray-50);
    cursor: pointer;
    font-weight: 700;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.v2-accordion-content {
    padding: 0 20px 20px;
}

.v2-lesson-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 0;
    border-bottom: 1px solid var(--gray-100);
}

.v2-lesson-row:last-child {
    border-bottom: none;
}

.v2-lesson-info {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.95rem;
}

.v2-lesson-meta {
    font-size: 0.85rem;
    color: var(--gray-400);
}

@media (max-width: 1100px) {
    .course-hero-v2 .hero-content-grid, .main-layout-grid-v2 {
        grid-template-columns: 1fr;
    }
    .course-hero-v2 .hero-image-wrap {
        order: -1;
        margin-bottom: 30px;
    }
    .v2-sidebar-card {
        position: static;
        width: 100%;
    }
}

/* =====================================================
   Redesign styles cleaned
   ===================================================== */
.hero-text-area {
    display: flex;
    flex-direction: column;
}


.page-hero-sm h1{font-family:'Playfair Display',serif;font-size:2rem;color:var(--text);margin-bottom:8px}
.page-hero-sm p{color:var(--gray-600)}

.catalog-layout{display:grid;grid-template-columns:280px 1fr;gap:20px;padding:24px 0 50px}
.filter-sidebar{background:#fff;border:1px solid var(--gray-100);border-radius:12px;padding:16px;height:fit-content;position:sticky;top:86px}
.filter-sidebar h3{font-size:1rem;margin-bottom:10px}
.filter-group{margin-bottom:12px}
.filter-group label{display:block;font-size:.8rem;color:var(--gray-600);margin-bottom:5px}
.filter-group input,.filter-group select{width:100%;height:38px;border:1px solid var(--gray-200);border-radius:8px;padding:0 10px}
.toggle-label{display:flex;align-items:center;gap:8px}

.catalog-main{min-width:0}
.catalog-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;color:var(--gray-600)}
.courses-grid-catalog{grid-template-columns:repeat(2,1fr)}

.pagination{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap}
.page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 10px;border-radius:8px;border:1px solid var(--gray-200);background:#fff;color:var(--gray-600)}
.page-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}

.empty-state{background:#fff;border:1px dashed var(--gray-200);border-radius:12px;padding:28px;text-align:center}
.empty-icon{font-size:1.8rem;margin-bottom:8px}

.auth-page{padding:40px 5%;display:flex;justify-content:center}
.auth-card{width:100%;max-width:520px;background:#fff;border:1px solid var(--gray-100);border-radius:14px;padding:24px}
.auth-card-wide{max-width:760px}
.auth-logo{font-size:1.4rem;margin-bottom:8px}
.auth-title{font-family:'Playfair Display',serif;font-size:1.8rem;color:var(--text);margin-bottom:4px}
.auth-sub{color:var(--gray-600);margin-bottom:16px}
.auth-form .form-group{margin-bottom:12px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.auth-form label{display:block;font-size:.82rem;color:var(--gray-600);margin-bottom:6px}
.auth-form input{width:100%;height:40px;border:1px solid var(--gray-200);border-radius:8px;padding:0 10px}
.form-group-row{display:flex;justify-content:flex-end;margin-bottom:12px}
.link-sm{font-size:.8rem;color:var(--blue)}
.auth-footer{margin-top:12px;font-size:.9rem;color:var(--gray-600)}
.auth-disclaimer{margin-top:14px;color:var(--gray-400);font-size:.72rem}

.alert{padding:10px 12px;border-radius:8px;margin-bottom:12px;font-size:.9rem}
.alert-success{background:#ecfdf5;color:var(--success);border:1px solid #a7f3d0}
.alert-error{background:#fef2f2;color:var(--danger);border:1px solid #fecaca}
.alert-warning{background:#fffbeb;color:#92400e;border:1px solid #fde68a}

.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}
.stat-card{background:#fff;border:1px solid var(--gray-100);border-radius:12px;padding:14px;display:flex;gap:10px;align-items:center}
.stat-num{font-size:1.3rem;font-weight:800;color:var(--text)}
.stat-label{font-size:.8rem;color:var(--gray-600)}

.dash-card{background:#fff;border:1px solid var(--gray-100);border-radius:12px;padding:16px;margin-bottom:16px}
.dash-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.dash-card-header h2{font-size:1rem}

.ce-summary-table{display:flex;flex-direction:column;gap:8px}
.ce-summary-row{display:grid;grid-template-columns:70px 1fr 120px 120px;gap:8px;padding:10px;border:1px solid var(--gray-100);border-radius:8px;align-items:center}

.enrolled-courses-list{display:flex;flex-direction:column;gap:10px}
.enrolled-course-row{display:grid;grid-template-columns:56px 1fr auto auto;gap:10px;align-items:center;padding:10px;border:1px solid var(--gray-100);border-radius:10px}
.enroll-thumb-sm,.enroll-thumb-placeholder{width:56px;height:56px;border-radius:10px;object-fit:cover;background:var(--gray-100);display:flex;align-items:center;justify-content:center}
.enrolled-course-info a{font-weight:700;color:var(--text)}


/* =====================================================
   Modern Premium Admin Dashboard Redesign
   ===================================================== */
.admin-container {
    padding: 0 30px 30px;
}

.admin-page-hero {
    background: linear-gradient(135deg, #f8fafc 0%, #eff6ff 100%);
    border-radius: 16px;
    padding: 40px;
    margin-bottom: 32px;
    border: 1px solid var(--gray-200);
}

.admin-page-hero h1 {
    font-family: 'Playfair Display', serif;
    font-size: 2.2rem;
    font-weight: 900;
    color: var(--text);
    margin-bottom: 8px;
}

.admin-page-hero p {
    color: var(--gray-600);
    font-size: 1rem;
}

.admin-stats-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 18px;
    margin-bottom: 32px;
}

.admin-stat-card {
    background: #fff;
    border: 1.5px solid var(--gray-100);
    border-radius: 16px;
    padding: 28px;
    text-align: center;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.admin-stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--blue), var(--blue-dark));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease;
}

.admin-stat-card:hover {
    border-color: var(--blue);
    box-shadow: 0 12px 24px rgba(26, 63, 168, 0.08);
    transform: translateY(-2px);
}

.admin-stat-card:hover::before {
    transform: scaleX(1);
}

.admin-stat-card.highlight {
    border-color: var(--gold);
    background: linear-gradient(135deg, rgba(240, 165, 0, 0.02), rgba(240, 165, 0, 0.01));
}

.stat-icon {
    font-size: 2.4rem;
    margin-bottom: 12px;
    display: block;
}

.stat-value {
    font-size: 1.8rem;
    font-weight: 900;
    color: var(--text);
    margin-bottom: 8px;
    font-family: 'Playfair Display', serif;
}

.stat-label {
    font-size: 0.9rem;
    color: var(--gray-600);
    font-weight: 500;
}

.admin-alert {
    background: linear-gradient(135deg, #fffbeb, #fef3c7);
    border: 1.5px solid #fde68a;
    border-radius: 14px;
    padding: 18px 24px;
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 32px;
    font-weight: 600;
    color: #92400e;
}

.admin-alert a {
    color: var(--blue);
    text-decoration: none;
    font-weight: 700;
    margin-left: auto;
}

.admin-alert a:hover {
    text-decoration: underline;
}

.admin-quick-links {
    background: #fff;
    border: 1.5px solid var(--gray-100);
    border-radius: 16px;
    padding: 32px;
}

.admin-quick-links h3 {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 24px;
    font-family: 'Playfair Display', serif;
}

.quick-link-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.quick-link-card {
    background: linear-gradient(135deg, #f8fafc, #f0f2f8);
    border: 1.5px solid var(--gray-100);
    border-radius: 12px;
    padding: 24px;
    text-align: center;
    font-weight: 700;
    color: var(--text);
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    font-size: 1.4rem;
}

.quick-link-card:hover {
    border-color: var(--blue);
    background: linear-gradient(135deg, rgba(26, 63, 168, 0.04), rgba(26, 63, 168, 0.02));
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(26, 63, 168, 0.1);
}

/* Admin Page Headers */
.admin-page-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 28px;
    padding-bottom: 20px;
    border-bottom: 2px solid var(--gray-100);
}

.admin-page-header h1 {
    font-family: 'Playfair Display', serif;
    font-size: 2rem;
    font-weight: 900;
    color: var(--text);
}

.admin-page-header .header-actions {
    display: flex;
    gap: 12px;
}

/* Modern Data Tables */
.table-container {
    background: #fff;
    border: 1.5px solid var(--gray-100);
    border-radius: 14px;
    overflow: hidden;
    margin-bottom: 24px;
}

.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
}

.data-table thead {
    background: linear-gradient(135deg, #f8fafc, #f0f2f8);
    border-bottom: 2px solid var(--gray-200);
}

.data-table th {
    padding: 16px 18px;
    text-align: left;
    font-weight: 700;
    color: var(--gray-800);
    letter-spacing: 0.5px;
    font-size: 0.85rem;
    text-transform: uppercase;
}

.data-table td {
    padding: 16px 18px;
    border-bottom: 1px solid var(--gray-100);
    color: var(--gray-800);
}

.data-table tbody tr {
    transition: all 0.2s ease;
}

.data-table tbody tr:hover {
    background: #f8fafc;
}

.data-table tbody tr.row-banned {
    opacity: 0.6;
    background: #fef2f2;
}

.data-table .badge {
    display: inline-block;
    padding: 5px 12px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.badge-success {
    background: #ecfdf5;
    color: var(--success);
    border: 1px solid #a7f3d0;
}

.badge-warning {
    background: #fffbeb;
    color: #92400e;
    border: 1px solid #fde68a;
}

.badge-danger {
    background: #fef2f2;
    color: var(--danger);
    border: 1px solid #fecaca;
}

.badge-info {
    background: #eff6ff;
    color: var(--blue);
    border: 1px solid #bfdbfe;
}

.badge-secondary {
    background: #f3f4f6;
    color: var(--gray-600);
    border: 1px solid #d1d5db;
}

/* Form Elements in Tables */
.inline-form {
    display: inline;
}

.role-select {
    padding: 6px 10px;
    border: 1px solid var(--gray-200);
    border-radius: 6px;
    background: #fff;
    color: var(--text);
    font-size: 0.9rem;
    cursor: pointer;
}

.role-select:focus {
    outline: none;
    border-color: var(--blue);
    box-shadow: 0 0 0 3px rgba(26, 63, 168, 0.1);
}

/* Action Buttons */
.action-btns {
    display: flex;
    gap: 8px;
}

.btn-sm {
    padding: 7px 14px;
    font-size: 0.8rem;
    border-radius: 6px;
    border: none;
    cursor: pointer;
    font-weight: 600;
    transition: all 0.2s ease;
    display: inline-block;
    text-align: center;
}

.btn-success {
    background: var(--success);
    color: #fff;
}

.btn-success:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

.btn-danger {
    background: var(--danger);
    color: #fff;
}

.btn-danger:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

.btn-warning {
    background: #f59e0b;
    color: #fff;
}

.btn-warning:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

.btn-primary {
    background: var(--blue);
    color: #fff;
}

.btn-primary:hover {
    background: var(--blue-dark);
    transform: translateY(-1px);
}

/* Alert Messages */
.alert {
    padding: 14px 18px;
    border-radius: 10px;
    margin-bottom: 20px;
    font-size: 0.95rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 12px;
}

.alert-success {
    background: #ecfdf5;
    color: var(--success);
    border: 1.5px solid #a7f3d0;
}

.alert-error {
    background: #fef2f2;
    color: var(--danger);
    border: 1.5px solid #fecaca;
}

.alert-warning {
    background: #fffbeb;
    color: #92400e;
    border: 1.5px solid #fde68a;
}

/* Pagination */
.pagination {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 24px;
    flex-wrap: wrap;
}

.pagination a, .pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 8px;
    border-radius: 8px;
    border: 1.5px solid var(--gray-200);
    background: #fff;
    color: var(--gray-600);
    font-weight: 600;
    transition: all 0.2s ease;
}

.pagination a:hover {
    border-color: var(--blue);
    color: var(--blue);
}

.pagination .active {
    background: var(--blue);
    border-color: var(--blue);
    color: #fff;
}

@media(max-width:900px){
  .hero-content{grid-template-columns:1fr;gap:34px}
  .hero-visual{display:none}
  .hero-text h1{font-size:2.3rem}
  .categories-grid{grid-template-columns:repeat(2,1fr)}
  .courses-grid,.courses-grid-catalog{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:repeat(2,1fr)}
  .steps-grid::before{display:none}
  .catalog-layout{grid-template-columns:1fr}
  .filter-sidebar{position:static}
  .form-row-2{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .enrolled-course-row{grid-template-columns:48px 1fr;gap:8px}
  .admin-stats-grid{grid-template-columns:repeat(2,1fr)}
  .quick-link-grid{grid-template-columns:repeat(2,1fr)}
}
