@import url(https://fonts.googleapis.com/css2?family=Hanuman:wght@400;700;900&display=swap);*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1d4ed8;--primary-light:#eff6ff;--primary-dark:#1e40af;--success:#16a34a;--warning:#ca8a04;--danger:#dc2626;--sidebar-bg:#1e293b;--sidebar-text:#cbd5e1;--sidebar-active:#3b82f6;--content-bg:#f8fafc;--card-bg:#fff;--border:#e2e8f0;--text-primary:#1e293b;--text-secondary:#64748b;--shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012,0 2px 4px #0000000f;--radius:8px;--font-kh:"Hanuman","Khmer",sans-serif}body{background:#f8fafc;background:var(--content-bg);color:#1e293b;color:var(--text-primary);font-family:Hanuman,Khmer,sans-serif;font-family:var(--font-kh);line-height:1.6}.app-layout{display:flex;min-height:100vh}.main-content{flex:1 1;margin-left:260px;min-height:100vh}.app-loading{align-items:center;color:#64748b;color:var(--text-secondary);gap:16px;justify-content:center;min-height:100vh}.app-loading,.sidebar{display:flex;flex-direction:column}.sidebar{background:#1e293b;background:var(--sidebar-bg);box-shadow:2px 0 8px #00000026;height:100vh;left:0;position:fixed;top:0;width:260px;z-index:100}.sidebar-header{border-bottom:1px solid #ffffff14;padding:20px}.logo-container{align-items:center;display:flex;gap:12px}.logo-icon{font-size:2rem}.logo-text{display:flex;flex-direction:column}.logo-name{color:#f8fafc;font-size:1.1rem;font-weight:900;letter-spacing:.5px}.logo-sub{color:#cbd5e1;color:var(--sidebar-text);font-size:.7rem;opacity:.7}.sidebar-nav{flex:1 1;overflow-y:auto;padding:16px 12px}.nav-section-label{color:#475569;font-size:.65rem;letter-spacing:1px;padding:8px 8px 4px;text-transform:uppercase}.nav-item{align-items:center;border-radius:8px;color:#cbd5e1;color:var(--sidebar-text);display:flex;font-size:.9rem;gap:12px;margin-bottom:2px;padding:10px 12px;text-decoration:none;transition:all .2s}.nav-item:hover{background:#ffffff12;color:#f1f5f9}.nav-item-active{background:#3b82f6!important;background:var(--sidebar-active)!important;color:#fff!important;font-weight:700}.nav-icon{font-size:1.1rem;text-align:center;width:22px}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px}.sidebar-footer,.user-info{align-items:center;display:flex;gap:10px}.user-info{flex:1 1;min-width:0}.user-avatar{align-items:center;background:#3b82f6;background:var(--sidebar-active);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:36px;justify-content:center;width:36px}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{color:#f1f5f9;font-size:.85rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#cbd5e1;color:var(--sidebar-text);font-size:.7rem;opacity:.7}.logout-btn{background:none;border:none;border-radius:6px;cursor:pointer;font-size:1.2rem;padding:4px;transition:background .2s}.logout-btn:hover{background:#ef444433}.page{max-width:1400px;padding:28px}.page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.page-title{color:#1e293b;color:var(--text-primary);font-size:1.6rem;font-weight:900}.page-desc{font-size:.9rem;margin-top:4px}.page-desc,.page-loading{color:#64748b;color:var(--text-secondary)}.page-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:24px}.stat-card{align-items:center;background:#fff;background:var(--card-bg);border:1px solid;border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;box-shadow:var(--shadow);display:flex;gap:16px;padding:20px;transition:transform .2s}.stat-card:hover{box-shadow:0 4px 6px #00000012,0 2px 4px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:1.5rem;height:52px;justify-content:center;width:52px}.stat-title{color:#64748b;color:var(--text-secondary);font-size:.8rem;margin-bottom:4px}.stat-value{color:#1e293b;color:var(--text-primary);font-size:1.5rem;font-weight:900}.stat-subtitle{color:#64748b;color:var(--text-secondary);font-size:.75rem;margin-top:2px}.stat-trend{font-size:.75rem;font-weight:600;margin-top:4px}.trend-up{color:#16a34a;color:var(--success)}.trend-down{color:#dc2626;color:var(--danger)}.dashboard-section{background:#fff;background:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;box-shadow:var(--shadow);margin-bottom:24px;padding:20px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.section-title{color:#1e293b;color:var(--text-primary);font-size:1rem;font-weight:700}.section-link{color:#1d4ed8;color:var(--primary);font-size:.85rem;text-decoration:none}.section-link:hover{text-decoration:underline}.recent-payments{display:flex;flex-direction:column;gap:8px}.payment-item{align-items:center;background:#f8fafc;background:var(--content-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;display:flex;justify-content:space-between;padding:12px}.payment-info{display:flex;flex-direction:column}.payment-name{font-size:.9rem;font-weight:700}.payment-code{color:#64748b;color:var(--text-secondary);font-size:.78rem}.payment-right{align-items:flex-end;display:flex;flex-direction:column}.payment-amount{color:#16a34a;color:var(--success);font-weight:900}.payment-date{color:#64748b;color:var(--text-secondary);font-size:.75rem}.quick-actions{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-top:12px}.quick-action{align-items:center;border-radius:12px;display:flex;flex-direction:column;gap:8px;padding:20px;text-decoration:none;transition:transform .2s}.quick-action:hover{transform:translateY(-3px)}.quick-action-blue{background:#eff6ff;color:#1d4ed8;color:var(--primary)}.quick-action-green{background:#f0fdf4;color:#16a34a;color:var(--success)}.quick-action-purple{background:#faf5ff;color:#7c3aed}.quick-action-orange{background:#fff7ed;color:#ea580c}.quick-icon{font-size:1.8rem}.quick-label{font-size:.85rem;font-weight:700;text-align:center}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:Hanuman,Khmer,sans-serif;font-family:var(--font-kh);font-size:.875rem;font-weight:700;gap:6px;padding:9px 18px;transition:all .2s}.btn-primary{background:#1d4ed8;background:var(--primary);color:#fff}.btn-primary:hover{background:#1e40af;background:var(--primary-dark)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-outline{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);color:#1e293b;color:var(--text-primary)}.btn-outline:hover{background:#f8fafc;background:var(--content-bg)}.btn-outline:disabled{cursor:not-allowed;opacity:.5}.btn-full{justify-content:center;padding:12px;width:100%}.btn-sm{font-size:.8rem;padding:5px 10px}.btn-icon{background:none;border:none;border-radius:6px;cursor:pointer;font-size:1rem;padding:4px 8px;transition:background .2s}.btn-edit:hover{background:#eff6ff}.btn-delete:hover{background:#fef2f2}.form-group{margin-bottom:16px}.form-label{display:block;font-size:.85rem;font-weight:700;margin-bottom:6px}.form-input,.form-label{color:#1e293b;color:var(--text-primary)}.form-input{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;font-family:Hanuman,Khmer,sans-serif;font-family:var(--font-kh);font-size:.9rem;padding:9px 12px;transition:border-color .2s;width:100%}.form-input:focus{border-color:#1d4ed8;border-color:var(--primary);box-shadow:0 0 0 3px #1d4ed81a;outline:none}.form-grid{grid-gap:0 16px;display:grid;gap:0 16px;grid-template-columns:1fr 1fr}.form-actions{border-top:1px solid #e2e8f0;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:16px}.form-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.875rem;margin-bottom:16px;padding:10px 14px}.table-wrapper{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);overflow-x:auto}.data-table{border-collapse:collapse;font-size:.875rem;width:100%}.data-table thead{background:#f8fafc;background:var(--content-bg)}.data-table th{color:#64748b;color:var(--text-secondary);font-size:.8rem;font-weight:700;letter-spacing:.5px;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table td,.data-table th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);padding:12px 16px}.data-table td{vertical-align:middle}.table-row:hover{background:#fafafa}.table-empty{color:#64748b;color:var(--text-secondary);padding:40px!important;text-align:center}.table-empty span{display:block;font-size:2rem;margin-bottom:8px}.table-loading{align-items:center;color:#64748b;color:var(--text-secondary);display:flex;flex-direction:column;gap:12px;padding:60px}.dashboard-welcome{align-items:center;background:linear-gradient(135deg,#1e40af,#1d4ed8);background:linear-gradient(135deg,var(--primary-dark) 0,var(--primary) 100%);border-radius:16px;box-shadow:0 10px 30px #1d4ed833;color:#fff;display:flex;justify-content:space-between;margin-bottom:24px;padding:32px}.welcome-text h1{color:#fff;font-size:1.8rem;font-weight:900;margin-bottom:8px}.welcome-text p{color:#ffffffd9;font-size:.95rem}.welcome-actions{align-items:center;display:flex;gap:24px}.welcome-icon{font-size:4rem;opacity:.9;text-shadow:2px 4px 10px #0003;transform:rotate(10deg)}.dashboard-columns{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:2fr 1fr;margin-bottom:24px}.dashboard-col-left,.dashboard-col-right{display:flex;flex-direction:column;gap:24px;height:100%}.filters{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.search-input{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;flex:1 1;font-family:Hanuman,Khmer,sans-serif;font-family:var(--font-kh);font-size:.875rem;min-width:250px;padding:9px 14px}.search-input:focus{border-color:#1d4ed8;border-color:var(--primary);outline:none}.filter-select{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;cursor:pointer;font-family:Hanuman,Khmer,sans-serif;font-family:var(--font-kh);font-size:.875rem;padding:9px 14px}.badge{border-radius:20px;display:inline-block;font-size:.75rem;font-weight:700;padding:3px 10px}.bg-green-100{background:#dcfce7}.text-green-800{color:#166534}.bg-red-100{background:#fee2e2}.text-red-800{color:#991b1b}.bg-blue-100{background:#dbeafe}.text-blue-800{color:#1e40af}.bg-yellow-100{background:#fef9c3}.text-yellow-800{color:#854d0e}.bg-gray-100{background:#f1f5f9}.text-gray-800{color:#1e293b}.badge-green{background:#dcfce7;color:#166534}.badge-yellow{background:#fef9c3;color:#854d0e}.badge-red{background:#fee2e2;color:#991b1b}.badge-blue{background:#dbeafe;color:#1e40af}.pagination{align-items:center;display:flex;gap:16px;justify-content:center;margin-top:20px}.page-info{color:#64748b;color:var(--text-secondary);font-size:.875rem}.modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal-container{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;max-height:90vh;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px}.modal-title{font-size:1.1rem;font-weight:900}.modal-close{background:none;border:none;border-radius:6px;cursor:pointer;font-size:1.1rem;padding:4px 8px}.modal-close:hover{background:#f8fafc;background:var(--content-bg)}.modal-body{overflow-y:auto;padding:24px}.login-page{align-items:center;background:linear-gradient(135deg,#1e293b,#1d4ed8);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.login-bg{inset:0;position:absolute}.login-shapes{height:100%;position:relative;width:100%}.shape{background:#fff;border-radius:50%;opacity:.08;position:absolute}.shape-1{height:300px;right:-80px;top:-100px;width:300px}.shape-2{bottom:-60px;height:200px;left:-50px;width:200px}.shape-3{height:150px;left:10%;top:50%;width:150px}.login-card{background:#fff;border-radius:16px;box-shadow:0 25px 60px #0000004d;max-width:420px;padding:40px;position:relative;width:100%}.login-logo{margin-bottom:32px;text-align:center}.login-logo-icon{font-size:3rem;margin-bottom:12px}.login-title{color:#1e293b;color:var(--text-primary);font-size:1.4rem;font-weight:900}.login-subtitle{color:#64748b;color:var(--text-secondary);font-size:.9rem;margin-top:4px}.login-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;display:flex;font-size:.875rem;gap:8px;margin-bottom:16px;padding:10px 14px}.login-footer{color:#64748b;color:var(--text-secondary);font-size:.75rem;margin-top:24px;text-align:center}.courses-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.course-card{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;box-shadow:var(--shadow);padding:20px;transition:transform .2s}.course-card:hover{box-shadow:0 4px 6px #00000012,0 2px 4px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.course-card-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.course-name{color:#1e293b;color:var(--text-primary);font-size:1rem;font-weight:900}.course-name-en{font-size:.8rem}.course-description,.course-name-en{color:#64748b;color:var(--text-secondary)}.course-description{font-size:.85rem;margin-bottom:12px}.course-details{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.course-detail-item{align-items:center;color:#64748b;color:var(--text-secondary);font-size:.85rem}.course-actions,.course-detail-item{display:flex;gap:8px}.spinner{border:3px solid #e2e8f0;border-top-color:#1d4ed8;border:3px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:24px;width:24px}.spinner,.spinner-large{animation:spin .7s linear infinite}.spinner-large{border:4px solid #e2e8f0;border-top-color:#1d4ed8;border:4px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{align-items:center;color:#64748b;color:var(--text-secondary);display:flex;flex-direction:column;gap:8px;justify-content:center;padding:40px}.empty-icon{font-size:2.5rem}.coming-soon{align-items:center;color:#64748b;color:var(--text-secondary);display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.coming-soon-icon{font-size:4rem}.coming-soon h2{font-size:1.4rem;font-weight:700}.font-bold{font-weight:700}.text-sm{font-size:.875rem}.text-gray-500{color:#6b7280}.text-green-600{color:#16a34a}.action-buttons{display:flex;gap:4px}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.main-content{margin-left:0}.form-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.page{padding:16px}.dashboard-columns{grid-template-columns:1fr}.dashboard-welcome{flex-direction:column;gap:20px;padding:24px;text-align:center}.welcome-icon{display:none}}
/*# sourceMappingURL=main.6371ce7c.css.map*/