.admin-page {
    max-width: 1100px;
    margin: 0 auto;
    padding: 40px 28px;
}

.admin-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 32px;
    flex-wrap: wrap;
    gap: 16px;
}

.admin-title {
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: -0.5px;
    color: #f0f0f5;
}

.admin-subtitle {
    font-size: 1.1rem;
    font-weight: 600;
    color: #f0f0f5;
    margin-bottom: 20px;
}

.admin-header-actions {
    display: flex;
    gap: 12px;
    align-items: center;
}

.admin-karta {
    background: #111116;
    border: 1px solid #1c1c26;
    border-radius: 14px;
    padding: 28px 32px;
    margin-bottom: 28px;
}

.btn-primary-sm {
    display: inline-flex;
    align-items: center;
    padding: 8px 18px;
    background: #e8b000;
    color: #0b0b0f;
    border-radius: 8px;
    font-size: 0.85rem;
    font-weight: 700;
    border: none;
    cursor: pointer;
    transition: opacity 0.15s;
}

.btn-primary-sm:hover { opacity: 0.85; }

.btn-ghost-sm {
    display: inline-flex;
    align-items: center;
    padding: 8px 18px;
    border: 1px solid #2e2e42;
    color: #8b8b9e;
    border-radius: 8px;
    font-size: 0.85rem;
    font-weight: 500;
    background: transparent;
    cursor: pointer;
    text-decoration: none;
    transition: border-color 0.15s, color 0.15s;
}

.btn-ghost-sm:hover { border-color: #3a2e00; color: #f0f0f5; }

.form-grid {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    align-items: flex-end;
    margin-bottom: 16px;
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 200px;
}

.form-group label {
    font-size: 0.8rem;
    color: #8b8b9e;
    font-weight: 500;
}

.form-check { justify-content: flex-end; }

.form-input, .form-input-sm {
    background: #0b0b0f;
    border: 1px solid #1c1c26;
    color: #f0f0f5;
    border-radius: 8px;
    padding: 9px 14px;
    font-size: 0.875rem;
    outline: none;
    transition: border-color 0.15s;
}

.form-input-sm { padding: 6px 10px; font-size: 0.8rem; width: 140px; }
.form-input:focus, .form-input-sm:focus { border-color: #e8b000; }

.form-actions { display: flex; gap: 10px; }

.users-table-wrapper {
    overflow-x: auto;
    border-radius: 14px;
    border: 1px solid #1c1c26;
}

.users-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.users-table th {
    background: #111116;
    color: #8b8b9e;
    font-weight: 600;
    padding: 14px 16px;
    text-align: left;
    border-bottom: 1px solid #1c1c26;
}

.users-table td {
    padding: 14px 16px;
    color: #f0f0f5;
    border-bottom: 1px solid #1c1c26;
    vertical-align: middle;
}

.users-table tr:last-child td { border-bottom: none; }
.users-table tr:hover td { background: rgba(255,255,255,0.02); }

.row-blocked td { opacity: 0.5; }
.row-haslo td { background: #0f0f14; }

.badge-admin {
    font-size: 0.72rem;
    font-weight: 600;
    font-family: 'Cascadia Code', 'Fira Code', monospace;
    padding: 3px 10px;
    background: rgba(232,176,0,0.10);
    color: #e8b000;
    border-radius: 100px;
    border: 1px solid rgba(232,176,0,0.18);
}

.badge-user {
    font-size: 0.72rem;
    font-weight: 600;
    font-family: 'Cascadia Code', 'Fira Code', monospace;
    padding: 3px 10px;
    background: rgba(255,255,255,0.05);
    color: #8b8b9e;
    border-radius: 100px;
    border: 1px solid #1c1c26;
}

.badge-active {
    font-size: 0.72rem;
    font-weight: 600;
    font-family: 'Cascadia Code', 'Fira Code', monospace;
    padding: 3px 10px;
    background: rgba(34,197,94,0.10);
    color: #22c55e;
    border-radius: 100px;
    border: 1px solid rgba(34,197,94,0.18);
}

.badge-blocked {
    font-size: 0.72rem;
    font-weight: 600;
    font-family: 'Cascadia Code', 'Fira Code', monospace;
    padding: 3px 10px;
    background: rgba(239,68,68,0.10);
    color: #ef4444;
    border-radius: 100px;
    border: 1px solid rgba(239,68,68,0.18);
}

.actions-cell {
    display: flex;
    gap: 6px;
    align-items: center;
}

.btn-edit, .btn-save, .btn-cancel, .btn-delete, .btn-pw {
    padding: 5px 12px;
    border-radius: 6px;
    font-size: 0.78rem;
    font-weight: 600;
    border: none;
    cursor: pointer;
    transition: opacity 0.15s;
}

.btn-edit { background: rgba(232,176,0,0.15); color: #e8b000; }
.btn-save { background: rgba(34,197,94,0.15); color: #22c55e; }
.btn-cancel { background: rgba(255,255,255,0.05); color: #8b8b9e; }
.btn-delete { background: rgba(239,68,68,0.15); color: #ef4444; }
.btn-delete:disabled { opacity: 0.3; cursor: not-allowed; }
.btn-pw { background: rgba(99,102,241,0.15); color: #818cf8; }

.btn-edit:hover, .btn-save:hover, .btn-cancel:hover, .btn-delete:not(:disabled):hover, .btn-pw:hover { opacity: 0.75; }

.haslo-form { display: flex; gap: 10px; align-items: center; }

.alert-success {
    background: rgba(34,197,94,0.10);
    border: 1px solid rgba(34,197,94,0.25);
    color: #22c55e;
    border-radius: 10px;
    padding: 12px 16px;
    margin-bottom: 20px;
    font-size: 0.875rem;
}

.alert-error {
    background: rgba(239,68,68,0.10);
    border: 1px solid rgba(239,68,68,0.25);
    color: #ef4444;
    border-radius: 10px;
    padding: 12px 16px;
    margin-bottom: 20px;
    font-size: 0.875rem;
}

.ladowanie {
    color: #8b8b9e;
    font-size: 0.9rem;
    padding: 32px;
    text-align: center;
}

.check-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.875rem;
    color: #f0f0f5;
    cursor: pointer;
}
