/* ZorX Bot dashboard — scoped styles.
   Professional, Nightbot-grade dashboard built on the ZorX esports SaaS look
   (dark glass panels, neon #aaff14, Inter + Orbitron). The page now has a
   site-consistent top navbar (.zb-sitenav) plus a two-column sidebar dashboard
   (.zb-layout: .zb-sidebar + content). All selectors stay namespaced under
   .zb-* / #zb-app so nothing leaks into shared pages. */

:root {
    --zb-bg: #070a08;
    --zb-panel: #0d120e;
    --zb-panel-2: #0f1610;
    --zb-border: #1d2a1d;
    --zb-border-2: #26361f;
    --zb-green: #aaff14;
    --zb-green-2: #7dd610;
    --zb-text: #f6fff2;
    --zb-muted: #8aa182;
    --zb-danger: #ff5d5d;
    --zb-amber: #ffc24b;
    --zb-radius: 16px;
    --zb-radius-sm: 10px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    background:
        radial-gradient(1200px 600px at 80% -10%, rgba(170,255,20,0.06), transparent 60%),
        var(--zb-bg);
    color: var(--zb-text);
    -webkit-font-smoothing: antialiased;
    min-height: 100vh;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }

/* ---- site navbar (matches other feature pages) ---- */
.zb-sitenav {
    position: sticky; top: 0; z-index: 30;
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    padding: 14px clamp(16px, 4vw, 40px);
    background: rgba(8, 10, 8, .78);
    border-bottom: 1px solid var(--zb-border);
    backdrop-filter: blur(16px);
}
.zb-sitenav-logo img { height: 36px; width: auto; display: block; }
.zb-sitenav-links { display: flex; align-items: center; gap: 10px; }
.zb-sitenav-link {
    min-height: 40px; display: inline-flex; align-items: center; justify-content: center;
    padding: 0 16px; border: 1px solid var(--zb-border-2); border-radius: 8px;
    color: var(--zb-muted); font-family: 'Orbitron', monospace; font-size: 12px;
    text-transform: uppercase; letter-spacing: .08em; background: rgba(255,255,255,.03);
    transition: all .15s ease;
}
.zb-sitenav-link:hover { color: var(--zb-green); border-color: var(--zb-green-2); }

/* ---- boot / loading ---- */
.zb-boot {
    min-height: 70vh; display: flex; flex-direction: column;
    align-items: center; justify-content: center; gap: 16px; text-align: center;
}
.zb-boot-logo { font-family: 'Orbitron', sans-serif; font-weight: 800; font-size: 30px; letter-spacing: 1px; }
.zb-boot-logo span { color: var(--zb-green); margin-left: 6px; }
.zb-boot p { color: var(--zb-muted); }
.zb-spinner {
    width: 34px; height: 34px; border-radius: 50%;
    border: 3px solid var(--zb-border-2); border-top-color: var(--zb-green);
    animation: zb-spin .8s linear infinite;
}
@keyframes zb-spin { to { transform: rotate(360deg); } }

/* ---- dashboard layout (sidebar + content) ---- */
.zb-shell { max-width: 1240px; margin: 0 auto; padding: 22px clamp(14px, 3vw, 28px) 60px; }

.zb-pagehead {
    display: flex; align-items: center; justify-content: space-between;
    gap: 14px; flex-wrap: wrap; margin-bottom: 16px;
}
.zb-pagehead .zb-title { display: flex; align-items: center; gap: 12px; }
.zb-pagehead .zb-title h1 {
    font-family: 'Orbitron', sans-serif; font-weight: 800; font-size: 22px; margin: 0;
}
.zb-pagehead .zb-title h1 span { color: var(--zb-green); }
.zb-pagehead .tag {
    font-size: 11px; color: var(--zb-muted); border: 1px solid var(--zb-border-2);
    padding: 3px 8px; border-radius: 999px; text-transform: uppercase; letter-spacing: .5px;
}

.zb-layout { display: grid; grid-template-columns: 232px 1fr; gap: 22px; align-items: start; }

/* sidebar */
.zb-sidebar {
    position: sticky; top: 80px;
    background: linear-gradient(180deg, var(--zb-panel), var(--zb-panel-2));
    border: 1px solid var(--zb-border); border-radius: var(--zb-radius);
    padding: 10px; display: flex; flex-direction: column; gap: 3px;
}
.zb-navitem {
    display: flex; align-items: center; gap: 11px; width: 100%;
    background: transparent; border: 1px solid transparent; color: var(--zb-muted);
    padding: 11px 13px; border-radius: var(--zb-radius-sm); cursor: pointer;
    font-weight: 600; font-size: 14px; text-align: left; transition: all .15s ease;
}
.zb-navitem svg { width: 18px; height: 18px; flex: none; opacity: .85; }
.zb-navitem:hover { color: var(--zb-text); background: rgba(255,255,255,.03); }
.zb-navitem.active {
    color: var(--zb-green); background: rgba(170,255,20,.10);
    border-color: rgba(170,255,20,.25);
}
.zb-navitem.active svg { opacity: 1; }
.zb-sidebar-foot {
    margin-top: 6px; padding: 12px 13px 6px; border-top: 1px solid var(--zb-border);
    color: var(--zb-muted); font-size: 11px; line-height: 1.5;
}

.zb-content { min-width: 0; }

/* ---- worker notice banner ---- */
.zb-worker-banner {
    display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
    background: linear-gradient(90deg, rgba(255,194,75,0.10), rgba(255,194,75,0.03));
    border: 1px solid rgba(255,194,75,0.28);
    border-radius: var(--zb-radius-sm); padding: 12px 16px; margin-bottom: 18px;
    color: #f3e4c2; font-size: 14px;
}
.zb-worker-banner .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--zb-amber); box-shadow: 0 0 10px var(--zb-amber); flex: none; }
.zb-worker-banner code { background: rgba(0,0,0,.35); border: 1px solid rgba(255,255,255,.12); border-radius: 5px; padding: 1px 6px; font-size: 12.5px; word-break: break-all; }
.zb-worker-banner.ok {
    background: linear-gradient(90deg, rgba(170,255,20,0.10), rgba(170,255,20,0.03));
    border-color: rgba(170,255,20,0.30);
    color: #e7f6cf;
}
.zb-worker-banner.ok .dot { background: var(--zb-green); box-shadow: 0 0 10px var(--zb-green); }

/* ---- panels / cards ---- */
.zb-panel {
    background: linear-gradient(180deg, var(--zb-panel), var(--zb-panel-2));
    border: 1px solid var(--zb-border); border-radius: var(--zb-radius);
    padding: 20px; margin-bottom: 18px;
}
.zb-panel h2 {
    font-size: 17px; margin: 0 0 4px; display: flex; align-items: center; gap: 9px;
}
.zb-panel h2 svg { width: 18px; height: 18px; color: var(--zb-green); flex: none; }
.zb-panel h3 { font-size: 14px; margin: 18px 0 10px; color: var(--zb-text); }
.zb-panel .sub { color: var(--zb-muted); font-size: 13px; margin: 0 0 16px; line-height: 1.5; }

.zb-grid { display: grid; gap: 14px; }
.zb-grid.cards { grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); margin-bottom: 18px; }

.zb-stat {
    position: relative; overflow: hidden;
    background: var(--zb-panel); border: 1px solid var(--zb-border);
    border-radius: var(--zb-radius-sm); padding: 16px;
}
.zb-stat .stat-icon {
    position: absolute; top: 14px; right: 14px; width: 18px; height: 18px;
    color: var(--zb-border-2); opacity: .9;
}
.zb-stat .label { color: var(--zb-muted); font-size: 12px; text-transform: uppercase; letter-spacing: .5px; }
.zb-stat .value { font-family: 'Orbitron', sans-serif; font-weight: 700; font-size: 24px; margin-top: 6px; word-break: break-word; }
.zb-stat .value.green { color: var(--zb-green); }

/* connected-channel card */
.zb-channel-card {
    display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
    background: var(--zb-bg); border: 1px solid var(--zb-border); border-radius: var(--zb-radius-sm);
    padding: 14px;
}
.zb-channel-card img { width: 52px; height: 52px; border-radius: 50%; border: 2px solid var(--zb-border-2); object-fit: cover; }
.zb-channel-card .meta { flex: 1; min-width: 160px; }
.zb-channel-card .meta .title { font-weight: 700; font-size: 16px; }
.zb-channel-card .meta .cid { color: var(--zb-muted); font-size: 12px; word-break: break-all; }

.zb-status-pill {
    display: inline-flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 700;
    padding: 5px 11px; border-radius: 999px; border: 1px solid var(--zb-border-2);
}
.zb-status-pill .dot { width: 8px; height: 8px; border-radius: 50%; }
.zb-status-pill.connected { color: var(--zb-green); border-color: rgba(170,255,20,.4); }
.zb-status-pill.connected .dot { background: var(--zb-green); box-shadow: 0 0 8px var(--zb-green); }
.zb-status-pill.disconnected { color: var(--zb-muted); }
.zb-status-pill.disconnected .dot { background: var(--zb-muted); }
.zb-status-pill.error { color: var(--zb-danger); border-color: rgba(255,93,93,.4); }
.zb-status-pill.error .dot { background: var(--zb-danger); }

/* ---- buttons ---- */
.zb-btn {
    display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
    border-radius: var(--zb-radius-sm); padding: 10px 16px; font-weight: 700; font-size: 14px;
    border: 1px solid var(--zb-border-2); background: var(--zb-panel); color: var(--zb-text);
    transition: all .15s ease;
}
.zb-btn svg { width: 16px; height: 16px; }
.zb-btn:hover { border-color: var(--zb-green-2); }
.zb-btn.primary { background: var(--zb-green); color: var(--zb-bg); border-color: var(--zb-green); }
.zb-btn.primary:hover { background: var(--zb-green-2); }
.zb-btn.danger { color: var(--zb-danger); border-color: rgba(255,93,93,.35); }
.zb-btn.danger:hover { background: rgba(255,93,93,.10); }
.zb-btn.small { padding: 6px 11px; font-size: 13px; }
.zb-btn:disabled { opacity: .5; cursor: not-allowed; }

/* ---- forms ---- */
.zb-field { margin-bottom: 14px; }
.zb-field label { display: block; font-size: 13px; color: var(--zb-muted); margin-bottom: 6px; font-weight: 600; }
.zb-field .hint { font-size: 12px; color: var(--zb-muted); margin-top: 5px; line-height: 1.5; }
.zb-input, .zb-select, .zb-textarea {
    width: 100%; background: var(--zb-bg); color: var(--zb-text);
    border: 1px solid var(--zb-border-2); border-radius: var(--zb-radius-sm);
    padding: 10px 12px; font-size: 14px; font-family: inherit;
}
.zb-input:focus, .zb-select:focus, .zb-textarea:focus { outline: none; border-color: var(--zb-green); }
.zb-textarea { resize: vertical; min-height: 78px; }
.zb-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.zb-form-row.three { grid-template-columns: 1fr 1fr 1fr; }

/* toggle switch */
.zb-switch { display: inline-flex; align-items: center; gap: 9px; cursor: pointer; user-select: none; }
.zb-switch input { display: none; }
.zb-switch .track { width: 42px; height: 24px; border-radius: 999px; background: var(--zb-border-2); position: relative; transition: background .15s ease; flex: none; }
.zb-switch .track::after { content: ''; position: absolute; top: 3px; left: 3px; width: 18px; height: 18px; border-radius: 50%; background: var(--zb-muted); transition: all .15s ease; }
.zb-switch input:checked + .track { background: rgba(170,255,20,.3); }
.zb-switch input:checked + .track::after { left: 21px; background: var(--zb-green); }
.zb-switch .switch-label { font-size: 14px; }

/* a rule presented as a card (moderation) */
.zb-rule-card {
    background: var(--zb-bg); border: 1px solid var(--zb-border);
    border-radius: var(--zb-radius-sm); padding: 14px; margin-bottom: 12px;
}
.zb-rule-card .rule-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.zb-rule-card .rule-name { font-weight: 700; font-size: 14px; }
.zb-rule-card .rule-desc { color: var(--zb-muted); font-size: 12px; margin-top: 3px; }
.zb-rule-card .rule-body { margin-top: 12px; }

/* variables / code hint list */
.zb-varlist {
    display: flex; flex-wrap: wrap; gap: 7px; margin-top: 8px;
}
.zb-varlist code {
    background: var(--zb-bg); border: 1px solid var(--zb-border-2); border-radius: 6px;
    padding: 3px 8px; font-size: 12px; color: var(--zb-green); font-family: ui-monospace, Menlo, monospace;
}

/* ---- tables / lists ---- */
.zb-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.zb-table th { text-align: left; color: var(--zb-muted); font-size: 12px; text-transform: uppercase; letter-spacing: .4px; padding: 10px 12px; border-bottom: 1px solid var(--zb-border); }
.zb-table td { padding: 11px 12px; border-bottom: 1px solid var(--zb-border); vertical-align: middle; }
.zb-table tbody tr { transition: background .12s ease; }
.zb-table tbody tr:hover { background: rgba(255,255,255,.02); }
.zb-table tr:last-child td { border-bottom: none; }
.zb-table .row-actions { display: flex; gap: 7px; justify-content: flex-end; }
.zb-cmd-name { font-family: 'Orbitron', sans-serif; color: var(--zb-green); font-weight: 700; }
.zb-table-wrap { overflow-x: auto; }

.zb-tag {
    display: inline-block; font-size: 12px; padding: 3px 9px; border-radius: 999px;
    border: 1px solid var(--zb-border-2); color: var(--zb-muted); white-space: nowrap;
}
.zb-tag.on { color: var(--zb-green); border-color: rgba(170,255,20,.4); }
.zb-tag.action-deleted, .zb-tag.action-banned { color: var(--zb-danger); border-color: rgba(255,93,93,.35); }
.zb-tag.action-timeout, .zb-tag.action-warned { color: var(--zb-amber); border-color: rgba(255,194,75,.35); }
.zb-tag.level-mod { color: var(--zb-amber); border-color: rgba(255,194,75,.35); }
.zb-tag.level-owner { color: var(--zb-danger); border-color: rgba(255,93,93,.35); }

.zb-empty {
    text-align: center; color: var(--zb-muted); padding: 40px 16px; font-size: 14px;
    border: 1px dashed var(--zb-border-2); border-radius: var(--zb-radius-sm);
}
.zb-empty .zb-empty-icon { width: 40px; height: 40px; margin: 0 auto 12px; color: var(--zb-border-2); }
.zb-empty .zb-empty-icon svg { width: 40px; height: 40px; display: block; margin: 0 auto; }
.zb-empty .zb-btn { margin-top: 14px; }

/* banned words / list chips */
.zb-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.zb-chip { display: inline-flex; align-items: center; gap: 6px; background: var(--zb-panel); border: 1px solid var(--zb-border-2); border-radius: 999px; padding: 5px 10px; font-size: 13px; }
.zb-chip button { background: none; border: none; color: var(--zb-danger); cursor: pointer; font-size: 15px; line-height: 1; padding: 0; }

/* worker token reveal */
.zb-token-box { background: var(--zb-bg); border: 1px dashed var(--zb-green-2); border-radius: var(--zb-radius-sm); padding: 14px; margin-top: 12px; }
.zb-token-box code { display: block; font-family: ui-monospace, Menlo, monospace; color: var(--zb-green); word-break: break-all; font-size: 13px; margin: 8px 0; }
.zb-token-box .warn { color: var(--zb-amber); font-size: 12px; }

/* numbered guide (make bot a moderator) */
.zb-guide { counter-reset: zb-step; margin: 6px 0 0; padding: 0; list-style: none; }
.zb-guide li {
    position: relative; padding: 0 0 14px 38px; color: var(--zb-text); font-size: 14px; line-height: 1.5;
}
.zb-guide li::before {
    counter-increment: zb-step; content: counter(zb-step);
    position: absolute; left: 0; top: -1px; width: 26px; height: 26px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(170,255,20,.12); border: 1px solid rgba(170,255,20,.3);
    color: var(--zb-green); border-radius: 50%; font-weight: 700; font-size: 13px;
}
.zb-guide li:last-child { padding-bottom: 0; }
.zb-guide code { background: var(--zb-bg); border: 1px solid var(--zb-border-2); border-radius: 5px; padding: 1px 6px; color: var(--zb-green); font-size: 13px; }

/* toast */
.zb-toast {
    position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%) translateY(20px);
    background: var(--zb-panel); border: 1px solid var(--zb-border-2);
    color: var(--zb-text); padding: 12px 18px; border-radius: var(--zb-radius-sm);
    font-size: 14px; box-shadow: 0 12px 40px rgba(0,0,0,.5); opacity: 0; pointer-events: none;
    transition: all .25s ease; z-index: 9999; max-width: 90vw;
}
.zb-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.zb-toast.error { border-color: rgba(255,93,93,.5); color: #ffd7d7; }
.zb-toast.success { border-color: rgba(170,255,20,.5); }

/* modal */
.zb-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.65); display: none; align-items: center; justify-content: center; z-index: 9998; padding: 18px; }
.zb-modal-overlay.show { display: flex; }
.zb-modal { background: var(--zb-panel); border: 1px solid var(--zb-border-2); border-radius: var(--zb-radius); padding: 22px; width: 100%; max-width: 540px; max-height: 90vh; overflow-y: auto; }
.zb-modal h3 { margin: 0 0 16px; font-size: 18px; }
.zb-modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 18px; }

.zb-section-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }

/* ---- responsive ---- */
@media (max-width: 880px) {
    .zb-layout { grid-template-columns: 1fr; gap: 14px; }
    .zb-sidebar {
        position: static; flex-direction: row; overflow-x: auto; gap: 6px; padding: 8px;
    }
    .zb-navitem { flex: 0 0 auto; white-space: nowrap; }
    .zb-navitem span.label { display: inline; }
    .zb-sidebar-foot { display: none; }
}
@media (max-width: 640px) {
    .zb-form-row, .zb-form-row.three { grid-template-columns: 1fr; }
    .zb-stat .value { font-size: 21px; }
    .zb-navitem span.label { display: none; }
    .zb-navitem { padding: 11px; }
    .zb-sitenav-link { font-size: 11px; padding: 0 11px; }
}
