⏳ Loading...

If nothing appears, check the database connection.

Test DB Connection position: fixed; top: 20px; right: 20px; padding: 15px 20px; border-radius: 8px; color: white; box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3); z-index: 2000; animation: slideIn 0.3s ease; } .notification.success { background: var(--success); } .notification.error { background: var(--error); } @keyframes slideIn { from { transform: translateX(400px); opacity: 0; } to { transform: translateX(0); opacity: 1; } } .loading, .no-results { text-align: center; padding: 60px 20px; color: var(--text-light); } .pagination { display: flex; justify-content: center; align-items: center; gap: 16px; margin-top: 24px; flex-wrap: wrap; } .selection-bar { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); background: var(--text); color: var(--bg); padding: 12px 24px; border-radius: 50px; display: flex; align-items: center; gap: 24px; box-shadow: 0 10px 25px rgba(0, 0, 0, 0.4); z-index: 100; animation: slideUp 0.3s ease; } @keyframes slideUp { from { transform: translate(-50%, 100%); opacity: 0; } to { transform: translate(-50%, 0); opacity: 1; } } @media (max-width: 1024px) { .main-layout { grid-template-columns: 1fr; } .side-panel { position: fixed; top: 0; right: 0; width: 100%; max-width: 400px; height: 100vh; max-height: 100vh; border-radius: 0; z-index: 999; transform: translateX(100%); transition: transform 0.3s; } .side-panel.show { transform: translateX(0); } } @media (max-width: 768px) { .header-content { flex-direction: column; align-items: stretch; } .filter-row { flex-direction: column; } .selection-bar { width: 90%; flex-direction: column; gap: 12px; border-radius: 16px; } table { font-size: 14px; } th, td { padding: 12px 8px; } .side-panel { max-width: 100%; } } @media (max-width: 1024px) { .main-layout { grid-template-columns: 1fr; } .side-panel { position: fixed; top: 0; right: 0; width: 100%; max-width: 400px; height: 100vh; max-height: 100vh; border-radius: 0; z-index: 999; transform: translateX(100%); transition: transform 0.3s; } .side-panel.show { transform: translateX(0); } } @media (max-width: 768px) { .header-content { flex-direction: column; align-items: stretch; } .filter-row { flex-direction: column; } .selection-bar { width: 90%; flex-direction: column; gap: 12px; border-radius: 16px; } table { font-size: 14px; } th, td { padding: 12px 8px; } .side-panel { max-width: 100%; } }

⏳ Loading...

If nothing appears, check the database connection.

Test DB Connection

top: 20px; right: 20px; padding: 15px 20px; border-radius: 8px; color: white; box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3); z-index: 2000; animation: slideIn 0.3s ease; } .notification.success { background: var(--success); } .notification.error { background: var(--error); } @keyframes slideIn { from { transform: translateX(400px); opacity: 0; } to { transform: translateX(0); opacity: 1; } } .loading, .no-results { text-align: center; padding: 60px 20px; color: var(--text-light); } .pagination { display: flex; justify-content: center; align-items: center; gap: 16px; margin-top: 24px; flex-wrap: wrap; } .selection-bar { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); background: var(--text); color: var(--bg); padding: 12px 24px; border-radius: 50px; display: flex; align-items: center; gap: 24px; box-shadow: 0 10px 25px rgba(0, 0, 0, 0.4); z-index: 100; animation: slideUp 0.3s ease; } @keyframes slideUp { from { transform: translate(-50%, 100%); opacity: 0; } to { transform: translate(-50%, 0); opacity: 1; } } @media (max-width: 1024px) { .main-layout { grid-template-columns: 1fr; } .side-panel { position: fixed; top: 0; right: 0; width: 100%; max-width: 400px; height: 100vh; max-height: 100vh; border-radius: 0; z-index: 999; transform: translateX(100%); transition: transform 0.3s; } .side-panel.show { transform: translateX(0); } } @media (max-width: 768px) { .header-content { flex-direction: column; align-items: stretch; } .filter-row { flex-direction: column; } .selection-bar { width: 90%; flex-direction: column; gap: 12px; border-radius: 16px; } table { font-size: 14px; } th, td { padding: 12px 8px; } .side-panel { max-width: 100%; } } @media (max-width: 1024px) { .main-layout { grid-template-columns: 1fr; } .side-panel { position: fixed; top: 0; right: 0; width: 100%; max-width: 400px; height: 100vh; max-height: 100vh; border-radius: 0; z-index: 999; transform: translateX(100%); transition: transform 0.3s; } .side-panel.show { transform: translateX(0); } } @media (max-width: 768px) { .header-content { flex-direction: column; align-items: stretch; } .filter-row { flex-direction: column; } .selection-bar { width: 90%; flex-direction: column; gap: 12px; border-radius: 16px; } table { font-size: 14px; } th, td { padding: 12px 8px; } .side-panel { max-width: 100%; } }

⏳ Loading...

If nothing appears, check the database connection.

Test DB Connection