/*!
 * NoxVRP Admin CSS – v2.0
 * Complete admin panel styles: sidebar, cards, tables, badges, forms.
 */

/* ─────────────────────── Layout Shell ─────────────────────── */
.admin-wrap {
    display: flex;
    min-height: 100vh;
    padding-top: 80px; /* below fixed navbar */
}

/* ─────────────────────── Sidebar ─────────────────────── */
.admin-sidebar {
    position: fixed;
    top: 80px;
    left: 0;
    bottom: 0;
    width: 240px;
    background: rgba(10, 10, 22, 0.97);
    border-right: 1px solid rgba(255,255,255,.07);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    z-index: 30;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 1rem 0 2rem;
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,.1) transparent;
    transition: transform .3s cubic-bezier(.4,0,.2,1);
}
.admin-sidebar::-webkit-scrollbar { width: 4px; }
.admin-sidebar::-webkit-scrollbar-track { background: transparent; }
.admin-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border-radius: 4px; }

.admin-content {
    flex: 1;
    margin-left: 240px;
    min-height: calc(100vh - 80px);
    padding: 2rem 1.5rem 4rem;
    max-width: 100%;
    overflow-x: hidden;
}

/* Mobile sidebar */
.admin-sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.6);
    z-index: 29;
    backdrop-filter: blur(2px);
}

@media (max-width: 900px) {
    .admin-sidebar {
        transform: translateX(-100%);
    }
    .admin-sidebar.is-open {
        transform: translateX(0);
        box-shadow: 4px 0 32px rgba(0,0,0,.5);
    }
    .admin-sidebar-overlay.is-open { display: block; }
    .admin-content { margin-left: 0; }
    .admin-mobile-toggle { display: flex !important; }
}

.admin-mobile-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: .6rem;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
    cursor: pointer;
    position: fixed;
    bottom: 1.25rem;
    right: 1.25rem;
    z-index: 31;
    color: #fff;
    font-size: 1.25rem;
}

/* ─────────────────────── Sidebar Brand ─────────────────────── */
.admin-brand {
    display: flex;
    align-items: center;
    gap: .7rem;
    padding: .5rem 1rem 1.25rem;
    border-bottom: 1px solid rgba(255,255,255,.07);
    margin-bottom: .5rem;
}
.admin-brand-icon {
    width: 34px;
    height: 34px;
    background: linear-gradient(135deg, #6366f1, #f43f5e);
    border-radius: .6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .875rem;
    color: #fff;
    flex-shrink: 0;
}
.admin-brand-text {
    font-size: .875rem;
    font-weight: 700;
    color: #f9fafb;
    line-height: 1.2;
}
.admin-brand-sub {
    font-size: .65rem;
    color: rgba(255,255,255,.35);
    letter-spacing: .05em;
    text-transform: uppercase;
}

/* ─────────────────────── Nav Items ─────────────────────── */
.admin-nav-section {
    padding: .75rem 1rem .25rem;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: rgba(255,255,255,.25);
}
.admin-nav-link {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .55rem .75rem .55rem 1rem;
    margin: .1rem .5rem;
    border-radius: .65rem;
    font-size: .8125rem;
    font-weight: 500;
    color: rgba(255,255,255,.55);
    text-decoration: none;
    border: 1px solid transparent;
    transition: all .15s;
    white-space: nowrap;
    overflow: hidden;
}
.admin-nav-link i { font-size: .95rem; flex-shrink: 0; min-width: 18px; }
.admin-nav-link:hover {
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.9);
    border-color: rgba(255,255,255,.08);
}
.admin-nav-link.active {
    background: rgba(99,102,241,.18);
    border-color: rgba(99,102,241,.35);
    color: #a5b4fc;
    font-weight: 600;
}
.admin-nav-link .badge {
    margin-left: auto;
    font-size: .625rem;
    padding: .1rem .4rem;
    border-radius: 9999px;
    background: rgba(99,102,241,.2);
    color: #a5b4fc;
    border: 1px solid rgba(99,102,241,.3);
}

/* ─────────────────────── Page Header ─────────────────────── */
.admin-page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1.75rem;
}
.admin-page-title {
    font-size: 1.625rem;
    font-weight: 800;
    color: #f9fafb;
    font-family: 'Orbitron', sans-serif;
    line-height: 1.1;
}
.admin-page-sub {
    font-size: .8125rem;
    color: rgba(255,255,255,.4);
    margin-top: .25rem;
}

/* ─────────────────────── Cards ─────────────────────── */
.admin-card {
    background: rgba(255,255,255,.035);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 1.125rem;
    overflow: hidden;
}
.admin-card-hd {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid rgba(255,255,255,.07);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
}
.admin-card-hd-title {
    font-size: .9375rem;
    font-weight: 700;
    color: #f9fafb;
}
.admin-card-bd { padding: 1.25rem; }

/* ─────────────────────── Grid helpers ─────────────────────── */
.admin-grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.25rem; }
.admin-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.admin-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.25rem; }
@media(max-width:900px){
    .admin-grid-2,.admin-grid-3,.admin-grid-4 { grid-template-columns:1fr; }
}
@media(min-width:640px) and (max-width:900px){
    .admin-grid-2 { grid-template-columns:repeat(2,1fr); }
    .admin-grid-4 { grid-template-columns:repeat(2,1fr); }
}

/* ─────────────────────── KPI stat boxes ─────────────────────── */
.admin-kpi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:1rem; margin-bottom:1.5rem; }
.admin-kpi {
    padding: 1.25rem 1.25rem 1rem;
    background: rgba(255,255,255,.035);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    gap: .5rem;
}
.admin-kpi-icon { font-size: 1.5rem; opacity: .6; }
.admin-kpi-value { font-size: 2rem; font-weight: 800; color: #f9fafb; line-height: 1; }
.admin-kpi-label { font-size: .75rem; color: rgba(255,255,255,.4); font-weight: 500; }

/* ─────────────────────── Table ─────────────────────── */
.admin-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.admin-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .8125rem;
}
.admin-table th {
    text-align: left;
    padding: .6rem .875rem;
    font-size: .6875rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: rgba(255,255,255,.35);
    border-bottom: 1px solid rgba(255,255,255,.07);
    white-space: nowrap;
}
.admin-table td {
    padding: .75rem .875rem;
    border-bottom: 1px solid rgba(255,255,255,.05);
    color: rgba(255,255,255,.82);
    vertical-align: middle;
}
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: rgba(255,255,255,.025); }
.admin-table .td-muted { color: rgba(255,255,255,.35); font-size: .75rem; }

/* ─────────────────────── Badges ─────────────────────── */
.badge {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    padding: .2rem .55rem;
    border-radius: 9999px;
    font-size: .6875rem;
    font-weight: 600;
    white-space: nowrap;
}
.badge-admin   { background:rgba(16,185,129,.12); color:#6ee7b7; border:1px solid rgba(16,185,129,.25); }
.badge-mod     { background:rgba(99,102,241,.12);  color:#a5b4fc; border:1px solid rgba(99,102,241,.25); }
.badge-user    { background:rgba(255,255,255,.06); color:#9ca3af; border:1px solid rgba(255,255,255,.10); }
.badge-banned  { background:rgba(239,68,68,.12);   color:#fca5a5; border:1px solid rgba(239,68,68,.25); }
.badge-online  { background:rgba(16,185,129,.12);  color:#6ee7b7; border:1px solid rgba(16,185,129,.25); }
.badge-offline { background:rgba(107,114,128,.12); color:#9ca3af; border:1px solid rgba(107,114,128,.20); }
.badge-ok      { background:rgba(16,185,129,.12);  color:#6ee7b7; border:1px solid rgba(16,185,129,.25); }
.badge-warn    { background:rgba(245,158,11,.12);  color:#fcd34d; border:1px solid rgba(245,158,11,.25); }
.badge-error   { background:rgba(239,68,68,.12);   color:#fca5a5; border:1px solid rgba(239,68,68,.25); }

/* ─────────────────────── Forms ─────────────────────── */
.admin-form-grid { display:grid; gap:.875rem; }
.admin-form-row { display:grid; grid-template-columns:1fr 1fr; gap:.875rem; }
@media(max-width:600px){ .admin-form-row { grid-template-columns:1fr; } }
.admin-label { display:block; font-size:.75rem; font-weight:600; color:rgba(255,255,255,.5); margin-bottom:.35rem; letter-spacing:.03em; }
.admin-input,
.admin-select,
.admin-textarea {
    width: 100%;
    background: rgba(0,0,0,.3);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: .7rem;
    padding: .65rem 1rem;
    color: #fff;
    font-size: .875rem;
    outline: none;
    transition: border-color .15s, box-shadow .15s;
    font-family: inherit;
}
.admin-input:focus,
.admin-select:focus,
.admin-textarea:focus {
    border-color: rgba(99,102,241,.5);
    box-shadow: 0 0 0 3px rgba(99,102,241,.12);
}
.admin-input::placeholder,
.admin-textarea::placeholder { color:rgba(255,255,255,.25); }
.admin-select option { background:#11111b; }
.admin-textarea { resize: vertical; min-height: 80px; }
.admin-hint { font-size:.7rem; color:rgba(255,255,255,.3); margin-top:.3rem; }

/* ─────────────────────── Buttons ─────────────────────── */
.btn-admin-primary {
    display:inline-flex;
    align-items:center;
    gap:.5rem;
    padding:.6rem 1.1rem;
    border-radius:.7rem;
    background: linear-gradient(135deg,#6366f1,#4f46e5);
    border: 1px solid rgba(99,102,241,.4);
    color:#fff;
    font-size:.8125rem;
    font-weight:600;
    cursor:pointer;
    text-decoration:none;
    transition:.15s;
    white-space: nowrap;
}
.btn-admin-primary:hover { filter:brightness(1.12); }
.btn-admin-secondary {
    display:inline-flex;
    align-items:center;
    gap:.5rem;
    padding:.6rem 1.1rem;
    border-radius:.7rem;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.12);
    color:rgba(255,255,255,.8);
    font-size:.8125rem;
    font-weight:600;
    cursor:pointer;
    text-decoration:none;
    transition:.15s;
    white-space: nowrap;
}
.btn-admin-secondary:hover { background:rgba(255,255,255,.1); color:#fff; }
.btn-admin-danger {
    display:inline-flex;
    align-items:center;
    gap:.5rem;
    padding:.6rem 1.1rem;
    border-radius:.7rem;
    background:rgba(239,68,68,.1);
    border:1px solid rgba(239,68,68,.25);
    color:#fca5a5;
    font-size:.8125rem;
    font-weight:600;
    cursor:pointer;
    text-decoration:none;
    transition:.15s;
    white-space: nowrap;
}
.btn-admin-danger:hover { background:rgba(239,68,68,.2); }

/* ─────────────────────── Alerts ─────────────────────── */
.admin-alert { padding:.875rem 1rem; border-radius:.875rem; font-size:.8125rem; display:flex; align-items:flex-start; gap:.6rem; }
.admin-alert-ok   { background:rgba(16,185,129,.08);  border:1px solid rgba(16,185,129,.2);  color:#a7f3d0; }
.admin-alert-err  { background:rgba(239,68,68,.08);   border:1px solid rgba(239,68,68,.2);   color:#fca5a5; }
.admin-alert-warn { background:rgba(245,158,11,.08);  border:1px solid rgba(245,158,11,.2);  color:#fcd34d; }
.admin-alert-info { background:rgba(99,102,241,.08);  border:1px solid rgba(99,102,241,.2);  color:#c7d2fe; }

/* ─────────────────────── Quick action row ─────────────────────── */
.admin-actions { display:flex; flex-wrap:wrap; gap:.6rem; }

/* ─────────────────────── Config rows ─────────────────────── */
.admin-config-row {
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:.75rem 0;
    border-bottom:1px solid rgba(255,255,255,.06);
    gap:.75rem;
    flex-wrap:wrap;
}
.admin-config-row:last-child { border-bottom:none; }
.admin-config-key { font-size:.75rem; font-weight:600; color:rgba(255,255,255,.4); font-family:monospace; }
.admin-config-value { font-size:.8125rem; color:rgba(255,255,255,.75); word-break:break-all; }
