:root {
    --bg: #0f172a;
    --card: #111827;
    --muted: #94a3b8;
    --text: #e5e7eb;
    --accent: #22d3ee;
    --accent-2: #a78bfa;
    --border: #1f2937;
    --success: #10b981;
    --warning: #f59e0b;
    --danger: #ef4444;
}

#userAccessLevel,
#userAccessLevel option {
    color: #fff !important;
}

.glass { background: rgba(255, 255, 255, 0.05); backdrop-filter: blur(8px); border: 1px solid rgba(255, 255, 255, 0.1); }
.glow { box-shadow: 0 0 16px rgba(59, 130, 246, 0.5), 0 0 10px rgba(79, 70, 229, 0.5); }
.animate-fadeIn { animation: fadeIn 0.3s ease-out forwards; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(-20px); } to { opacity: 1; transform: translateY(0); } }

.controls { display: grid; grid-template-columns: 3fr repeat(2, max-content); gap: 12px; align-items: end; background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.0)); border: 1px solid var(--border); border-radius: 14px; padding: 12px; margin-bottom: 14px; backdrop-filter: blur(6px); }
.control-group { display: grid; gap: 6px; }
.control-group label { color: var(--muted); font-size: 12px; }
.control-group input[type="search"], .control-group select { appearance: none; border: 1px solid var(--border); background: #0b1220; color: var(--text); border-radius: 10px; padding: 10px 12px; outline: none; transition: border-color 0.2s, box-shadow 0.2s; }
.control-group input[type="search"]:focus, .control-group select:focus { border-color: rgba(34, 211, 238, 0.6); box-shadow: 0 0 0 3px rgba(34, 211, 238, 0.15); }
.control-group input[type="search"].searching { border-color: rgba(167, 139, 250, 0.6); box-shadow: 0 0 0 3px rgba(167, 139, 250, 0.15); background: linear-gradient(135deg, #0b1220, rgba(167, 139, 250, 0.05)); }

.search-wrapper { position: relative; display: flex; align-items: center; }
.search-icon { position: absolute; left: 12px; color: var(--muted); font-size: 14px; pointer-events: none; transition: color 0.2s ease; }
.search-wrapper input[type="search"] { padding-left: 40px; min-width: 300px; font-size: 14px; }
.search-wrapper input[type="search"]:focus + .search-icon { color: var(--accent); }
.search-wrapper input[type="search"].searching + .search-icon { color: var(--accent-2); animation: pulse 1s infinite; }
.search-counter { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); background: var(--accent); color: white; font-size: 11px; padding: 2px 6px; border-radius: 10px; font-weight: 500; opacity: 0; transition: opacity 0.2s ease; }
.search-counter.show { opacity: 1; }
.clear-search-btn { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); background: var(--muted); color: var(--text); border: none; width: 20px; height: 20px; border-radius: 50%; cursor: pointer; font-size: 14px; font-weight: bold; display: flex; align-items: center; justify-content: center; opacity: 0; transition: all 0.2s ease; }
.clear-search-btn:hover { background: var(--danger); color: white; }
.clear-search-btn.show { opacity: 1; }

.btn-secondary { border: 1px solid var(--border); background: linear-gradient(180deg, #101827, #0b1220); color: var(--text); border-radius: 10px; padding: 10px 12px; cursor: pointer; transition: transform 0.1s ease, background 0.2s ease, border-color 0.2s; }
.btn-secondary:hover { transform: translateY(-1px); border-color: rgba(167, 139, 250, 0.5); background: linear-gradient(180deg, #131c2c, #0b1220); }

.table-card { border: 1px solid var(--border); border-radius: 14px; overflow: hidden; background: linear-gradient(180deg, #0b1220, #0f172a); }
.table-wrapper { overflow: auto; max-height: 65vh; }
table { width: 100%; border-collapse: separate; border-spacing: 0; }
thead th { position: sticky; top: 0; background: linear-gradient(180deg, #0e1626, #0d1524); z-index: 2; text-align: right; font-weight: 600; font-size: 13px; color: #c7d2fe; border-bottom: 1px solid var(--border); padding: 12px; }
th, td { padding: 12px; border-bottom: 1px solid var(--border); white-space: nowrap; }
tbody tr:hover { background: rgba(167, 139, 250, 0.05); }
tbody tr:nth-child(even) td { background: rgba(255,255,255,0.01); }
.sortable { cursor: pointer; user-select: none; }
.sortable::after { content: ""; display: inline-block; margin-right: 8px; border: 5px solid transparent; transform: translateY(-1px); }
th.sorted-asc::after { border-bottom-color: var(--accent); }
th.sorted-desc::after { border-top-color: var(--accent); }
.table-footer { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; background: linear-gradient(180deg, #0d1524, #0b1220); border-top: 1px solid var(--border); }
.table-info { display: flex; flex-direction: column; gap: 4px; }
.range-info { color: var(--muted); font-size: 12px; }
.search-info { color: var(--accent); font-size: 12px; font-weight: 500; }
.pagination { display: flex; gap: 8px; }
.page-btn { min-width: 34px; padding: 6px 10px; border-radius: 8px; border: 1px solid var(--border); background: #0b1220; color: var(--text); cursor: pointer; transition: background 0.2s ease, transform 0.1s ease, border-color 0.2s ease; }
.page-btn:hover { transform: translateY(-1px); }
.page-btn[disabled] { opacity: 0.5; cursor: default; }
.page-btn.active { background: linear-gradient(180deg, rgba(34, 211, 238, 0.15), rgba(167, 139, 250, 0.15)); border-color: rgba(34, 211, 238, 0.35); }
.empty-state { padding: 40px 24px; text-align: center; color: var(--muted); }
.empty-state-content { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.empty-icon { font-size: 48px; opacity: 0.6; }
.empty-title { font-size: 18px; font-weight: 600; color: var(--text); margin: 0; }
.empty-subtitle { font-size: 14px; color: var(--muted); margin: 0; }
.actions { display: flex; gap: 8px; justify-content: center; }
.btn-action { border: 1px solid var(--border); background: transparent; color: var(--muted); border-radius: 8px; padding: 6px 10px; cursor: pointer; font-size: 12px; transition: all 0.2s ease; text-decoration: none; display: inline-block; }
.btn-action:hover { background: var(--border); color: var(--text); }
.btn-edit:hover { border-color: var(--accent); color: var(--accent); }
.btn-delete:hover { border-color: var(--danger); color: var(--danger); }
.btn-dashboard { background: rgba(34, 211, 238, 0.1); border-color: rgba(34, 211, 238, 0.3); color: var(--accent); }
.btn-dashboard:hover { background: rgba(34, 211, 238, 0.2); color: #67e8f9; }
th:nth-last-child(1), td:nth-last-child(1), th:nth-last-child(2), td:nth-last-child(2) { text-align: center; }
.hidden { display: none !important; }
@media (max-width: 720px) { .controls { grid-template-columns: 1fr 1fr; } .table-wrapper { max-height: 55vh; } }

/* Modal styles, permissions grid, checkboxes, toasts (trimmed for brevity) */
.modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); display: flex; justify-content: center; align-items: center; z-index: 1000; }
.modal-overlay.hidden { display: none; }
.modal { background: var(--card); border-radius: 16px; width: 90%; max-width: 900px; max-height: 90vh; overflow-y: auto; border: 1px solid var(--border); box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25); }
.modal-header { display: flex; justify-content: space-between; align-items: center; padding: 20px 24px; border-bottom: 1px solid var(--border); }
.modal-header h2 { color: var(--text); font-size: 20px; font-weight: 600; margin: 0; }
.modal-header button { background: none; border: none; color: var(--muted); font-size: 24px; cursor: pointer; padding: 0; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; border-radius: 6px; transition: all 0.2s ease; }
.modal-header button:hover { background: rgba(255, 255, 255, 0.1); color: var(--text); }
.modal-body { padding: 24px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.form-group { display: flex; flex-direction: column; gap: 8px; }
.form-group label { color: var(--muted); font-size: 14px; font-weight: 500; }
.form-group input, .form-group select { padding: 12px 16px; border: 1px solid var(--border); border-radius: 8px; background: rgba(255, 255, 255, 0.05); color: var(--text); font-size: 14px; transition: all 0.2s ease; }
.form-group input:focus, .form-group select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(34, 211, 238, 0.1); }
.password-wrapper { display: flex; gap: 8px; align-items: center; }
.permissions-section { margin-top: 24px; border-top: 1px solid var(--border); padding-top: 16px; }
.permissions-title { color: var(--text); font-size: 16px; font-weight: 600; margin-bottom: 16px; }
.permissions-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.permission-row { display: flex; justify-content: space-between; align-items: center; background: #0b1220; padding: 10px 12px; border-radius: 8px; border: 1px solid var(--border); }
.permission-checkboxes { display: flex; gap: 20px; }
.permission-checkboxes input[type="checkbox"] { width: 18px; height: 18px; margin: 0; padding: 0; border-radius: 4px; border: 2px solid #374151; background: #0b1220; appearance: none; cursor: pointer; position: relative; transition: all 0.2s ease; }
.permission-checkboxes input[type="checkbox"]:checked { background: #10b981; border-color: #10b981; }
.permission-checkboxes input[type="checkbox"]:checked::after { content: '✓'; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); color: white; font-size: 12px; font-weight: bold; }
.modal-footer { display: flex; justify-content: flex-end; gap: 12px; padding: 20px 24px; border-top: 1px solid var(--border); background: rgba(255, 255, 255, 0.02); }
.btn-primary { background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: white; border: none; padding: 12px 24px; border-radius: 8px; font-weight: 500; cursor: pointer; transition: all 0.2s ease; }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 8px 25px rgba(34, 211, 238, 0.3); }
.delete-modal { max-width: 500px; }
.delete-warning { text-align: center; padding: 20px 0; }
.warning-icon { font-size: 48px; margin-bottom: 16px; animation: pulse 2s infinite; }
@keyframes pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.1); } }
#deleteMessage { color: var(--text); font-size: 18px; font-weight: 600; }
.delete-note { color: var(--muted); font-size: 14px; }
.btn-danger { background: linear-gradient(135deg, var(--danger), #dc2626); color: white; border: none; padding: 12px 24px; border-radius: 8px; font-weight: 500; cursor: pointer; transition: all 0.2s ease; }
.btn-danger:hover { transform: translateY(-1px); box-shadow: 0 8px 25px rgba(239, 68, 68, 0.3); background: linear-gradient(135deg, #dc2626, var(--danger)); }
@media (max-width: 640px) { .form-row { grid-template-columns: 1fr; } .modal { width: 95%; margin: 20px; } .delete-modal { max-width: 95%; } }

