﻿/* ═══════════════════════════════════════════════════════════════
   GORILLA CEE — Panel Admin CSS  v3 (Full Redesign)
   ═══════════════════════════════════════════════════════════════ */

:root {
  --bg:            #010d01;
  --bg2:           #031403;
  --sidebar-bg:    #021002;
  --panel:         #072007;
  --panel-hov:     #0a2a0a;
  --panel-2:       #0d2a0d;
  --border:        #113311;
  --border-hov:    #1a4a1a;

  --text:   #ecfdf5;
  --text-2: #86efac;
  --text-3: #3d6450;

  --accent:        #15803d;
  --accent-soft:   rgba(21,128,61,.16);
  --accent-border: rgba(74,222,128,.35);
  --accent-2:      #4ade80;
  --accent-glow:   rgba(74,222,128,.4);

  --green:   #22c55e;
  --g-soft:  rgba(34,197,94,.12);
  --g-brd:   rgba(34,197,94,.3);
  --yellow:  #f59e0b;
  --y-soft:  rgba(245,158,11,.12);
  --red:     #ef4444;
  --r-soft:  rgba(239,68,68,.12);
  --r-brd:   rgba(239,68,68,.28);
  --blue:    #3b82f6;
  --b-soft:  rgba(59,130,246,.12);
  --b-brd:   rgba(59,130,246,.28);
  --indigo:  #6366f1;
  --i-soft:  rgba(99,102,241,.12);
  --orange:  #f97316;
  --o-soft:  rgba(249,115,22,.12);
  --discord: #5865f2;
  --d-soft:  rgba(88,101,242,.12);

  --sidebar-w: 252px;
  --topbar-h:  60px;
  --radius:    8px;
  --radius-lg: 12px;
  --font:   'Inter', system-ui, sans-serif;
  --mono:   'JetBrains Mono', monospace;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 14px; -webkit-font-smoothing: antialiased; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  overflow-x: hidden;
}
button, input, textarea, select { font: inherit; }
button { border: 0; cursor: pointer; background: transparent; color: inherit; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4 { font-weight: 700; }

::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-hov); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-3); }

/* AMBIENT ORBS */
.admin-orbs { position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.admin-orb { position: absolute; border-radius: 50%; filter: blur(90px); animation: orbFloat 20s ease-in-out infinite; will-change: transform; }
.admin-orb-1 { width: 500px; height: 500px; background: radial-gradient(circle, rgba(21,128,61,.22) 0%, transparent 70%); top: -140px; left: calc(var(--sidebar-w) + 60px); animation-duration: 22s; }
.admin-orb-2 { width: 420px; height: 420px; background: radial-gradient(circle, rgba(74,222,128,.12) 0%, transparent 70%); top: 38%; right: 0; animation-duration: 28s; animation-delay: -9s; }
.admin-orb-3 { width: 360px; height: 360px; background: radial-gradient(circle, rgba(34,197,94,.10) 0%, transparent 70%); bottom: -60px; left: calc(var(--sidebar-w) + 20%); animation-duration: 24s; animation-delay: -15s; }
.admin-orb-4 { width: 280px; height: 280px; background: radial-gradient(circle, rgba(21,128,61,.12) 0%, transparent 70%); top: 62%; left: calc(var(--sidebar-w) + 5%); animation-duration: 19s; animation-delay: -6s; }
@keyframes orbFloat { 0%, 100% { transform: translate(0, 0) scale(1); } 25% { transform: translate(22px, -16px) scale(1.04); } 50% { transform: translate(-12px, 20px) scale(0.97); } 75% { transform: translate(16px, 8px) scale(1.02); } }

/* SIDEBAR */
.sidebar { position: fixed; inset: 0 auto 0 0; width: var(--sidebar-w); background: var(--sidebar-bg); border-right: 1px solid var(--border); display: flex; flex-direction: column; z-index: 100; overflow-y: auto; }
.brand { height: var(--topbar-h); min-height: var(--topbar-h); padding: 0 14px; display: flex; align-items: center; gap: 10px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.brand-icon { width: 32px; height: 32px; border-radius: 7px; flex-shrink: 0; background: linear-gradient(135deg, var(--accent), var(--accent-2)); display: grid; place-items: center; overflow: hidden; font-weight: 800; font-size: .95rem; color: #fff; }
.brand-icon img { width: 100%; height: 100%; object-fit: contain; display: block; }
.brand-text strong { display: block; font-size: .88rem; font-weight: 700; }
.brand-text span { font-size: .64rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .12em; }
.sidebar-close { margin-left: auto; width: 26px; height: 26px; border-radius: 5px; color: var(--text-3); font-size: 1.1rem; display: grid; place-items: center; }
.sidebar-close:hover { background: rgba(255,255,255,.06); color: var(--text-2); }
.nav { flex: 1; padding: 10px 8px; display: flex; flex-direction: column; overflow-y: auto; }
.nav-group { display: flex; flex-direction: column; gap: 1px; margin-bottom: 18px; }
.nav-label { padding: 0 8px 6px; font-size: .62rem; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--text-3); }
.nav-item { display: flex; align-items: center; gap: 9px; min-height: 34px; padding: 0 9px; border-radius: 6px; color: var(--text-2); font-size: .82rem; font-weight: 500; transition: background .12s, color .12s; position: relative; white-space: nowrap; }
.nav-item:hover { background: rgba(255,255,255,.04); color: var(--text); }
.nav-item.active { background: var(--accent-soft); color: var(--text); border: 1px solid var(--accent-border); }
.nav-item.active::before { content: ''; position: absolute; left: 0; top: 20%; bottom: 20%; width: 3px; border-radius: 0 2px 2px 0; background: var(--accent); }
.nav-icon { width: 15px; height: 15px; flex-shrink: 0; }
.sidebar-footer { padding: 10px 8px; border-top: 1px solid var(--border); display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.user-info { flex: 1; min-width: 0; display: flex; align-items: center; gap: 9px; }
.user-avatar { width: 30px; height: 30px; border-radius: 7px; flex-shrink: 0; background: linear-gradient(135deg, var(--accent), var(--accent-2)); display: grid; place-items: center; font-weight: 800; font-size: .84rem; }
.user-meta strong { display: block; font-size: .82rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.user-meta span { font-size: .65rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .07em; }
.logout-btn { width: 30px; height: 30px; border-radius: 6px; display: grid; place-items: center; color: var(--text-3); transition: background .12s, color .12s; flex-shrink: 0; }
.logout-btn:hover { background: var(--r-soft); color: var(--red); }
.logout-btn svg { width: 14px; height: 14px; }
.sidebar-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.6); backdrop-filter: blur(4px); z-index: 99; }
.sidebar-backdrop.hidden { display: none !important; }

/* MAIN / TOPBAR */
.main { margin-left: var(--sidebar-w); min-height: 100vh; padding-top: var(--topbar-h); display: block; position: relative; z-index: 1; }
.topbar { position: fixed; top: 0; left: var(--sidebar-w); right: 0; z-index: 50; height: var(--topbar-h); padding: 0 20px; background: rgba(1,13,1,.94); backdrop-filter: blur(16px); border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 12px; }
.menu-btn { width: 32px; height: 32px; border-radius: 7px; display: grid; place-items: center; color: var(--text-2); }
.menu-btn svg { width: 17px; height: 17px; }
.topbar-title { flex: 1; min-width: 0; }
.breadcrumb { font-size: .64rem; text-transform: uppercase; letter-spacing: .14em; color: var(--text-3); display: block; }
.topbar-title h1 { font-size: .92rem; font-weight: 700; margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.topbar-right { display: flex; align-items: center; gap: 8px; margin-left: auto; flex-shrink: 0; }
.sync-indicator { display: flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; border: 1px solid var(--border); background: var(--panel); font-size: .71rem; color: var(--text-3); }
.sync-dot { width: 6px; height: 6px; border-radius: 999px; background: var(--text-3); flex-shrink: 0; transition: background .3s; }
.sync-dot.ok { background: var(--green); box-shadow: 0 0 6px var(--green); }
.sync-dot.err { background: var(--red); }
.icon-btn { width: 32px; height: 32px; border-radius: 7px; border: 1px solid var(--border); background: var(--panel); display: grid; place-items: center; color: var(--text-2); transition: background .12s, color .12s; }
.icon-btn svg { width: 15px; height: 15px; }
.icon-btn:hover { color: var(--text); background: var(--panel-hov); border-color: var(--border-hov); }
.topbar-link { display: flex; align-items: center; gap: 5px; font-size: .78rem; color: var(--text-2); padding: 5px 10px; border-radius: 7px; border: 1px solid var(--border); background: var(--panel); transition: background .12s, color .12s; }
.topbar-link:hover { color: var(--text); background: var(--panel-hov); border-color: var(--border-hov); }
.topbar-link svg { width: 11px; height: 11px; }

/* VIEWS */
.view { padding: 20px 22px; }
.view.hidden { display: none !important; }
.view-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.view-header h2 { font-size: 1.35rem; display: flex; align-items: center; gap: 9px; }
.view-header-right { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.live-badge { font-size: .6rem; font-weight: 800; letter-spacing: .1em; padding: 2px 7px; border-radius: 999px; background: var(--r-soft); border: 1px solid var(--r-brd); color: var(--red); }
.mt-14 { margin-top: 14px; }
.mt-20 { margin-top: 20px; }

/* KPI CARDS */
.kpi-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 10px; margin-bottom: 14px; }
.kpi-4 { grid-template-columns: repeat(4,1fr); }
.kpi-3 { grid-template-columns: repeat(3,1fr); }
.kpi-2 { grid-template-columns: repeat(2,1fr); }
.kpi-card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 14px 16px; display: flex; align-items: flex-start; gap: 12px; transition: border-color .15s, transform .15s; position: relative; overflow: hidden; }
.kpi-card::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,255,255,.02) 0%, transparent 60%); pointer-events: none; }
.kpi-card:hover { border-color: var(--border-hov); transform: translateY(-1px); }
.kpi-icon { width: 38px; height: 38px; border-radius: 9px; display: grid; place-items: center; flex-shrink: 0; }
.kpi-icon svg { width: 17px; height: 17px; }
.kpi-purple { background: var(--accent-soft); color: var(--accent); }
.kpi-blue { background: var(--b-soft); color: var(--blue); }
.kpi-green { background: var(--g-soft); color: var(--green); }
.kpi-orange { background: var(--o-soft); color: var(--orange); }
.kpi-indigo { background: var(--i-soft); color: var(--indigo); }
.kpi-discord { background: var(--d-soft); color: var(--discord); }
.kpi-red { background: var(--r-soft); color: var(--red); }
.kpi-cyan { background: rgba(34,211,238,.12); color: var(--accent-2); }
.kpi-body { flex: 1; min-width: 0; }
.kpi-body span { font-size: .69rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .08em; display: block; }
.kpi-body strong { font-size: 1.4rem; font-weight: 800; font-family: var(--mono); letter-spacing: -.02em; display: block; margin-top: 3px; line-height: 1; }
.kpi-sub { font-size: .67rem; color: var(--text-3); margin-top: 5px; line-height: 1.4; }

/* CHART PANELS */
.chart-panel { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; }
.panel-head { padding: 12px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: 10px; min-height: 50px; }
.panel-head h3 { font-size: .87rem; font-weight: 600; }
.panel-sub { font-size: .69rem; color: var(--text-3); margin-top: 2px; }
.panel-head-right { display: flex; align-items: center; gap: 8px; }
.chart-wrap { padding: 14px; position: relative; }
.chart-h240 { height: 240px; }
.chart-h200 { height: 200px; }
.chart-wrap canvas { width: 100% !important; height: 100% !important; display: block; }

/* GRID LAYOUTS */
.row-2-1 { display: grid; grid-template-columns: 1.55fr 1fr; gap: 12px; margin-bottom: 12px; }
.row-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.row-equal { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.tall { display: flex; flex-direction: column; min-height: 420px; }
.tall .feed { flex: 1; overflow-y: auto; max-height: 380px; }

/* LISTS */
.rank-list { padding: 4px 0; }
.meter-list { padding: 6px; }
.feed { padding: 6px; }
.rank-row { display: flex; align-items: center; gap: 10px; padding: 8px 16px; transition: background .12s; cursor: default; }
.rank-row:hover { background: rgba(255,255,255,.03); }
.rank-num { width: 18px; font-size: .75rem; font-weight: 700; color: var(--text-3); text-align: center; flex-shrink: 0; }
.page-icon-badge { font-size: .9rem; line-height: 1; flex-shrink: 0; }
.rank-info { flex: 1; min-width: 0; }
.rank-info strong { display: block; font-size: .8rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rank-info small { font-size: .68rem; color: var(--text-3); }
.rank-bar-track { height: 6px; background: rgba(255,255,255,.05); border-radius: 999px; margin-top: 5px; overflow: hidden; }
.rank-bar-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--accent), var(--accent-2)); transition: width .5s cubic-bezier(.4,0,.2,1); }
.rank-count { font-family: var(--mono); font-size: .8rem; font-weight: 700; color: var(--accent-2); flex-shrink: 0; }
.feed-row { padding: 8px 9px; border-radius: 6px; display: flex; align-items: flex-start; gap: 9px; transition: background .1s; }
.feed-row:hover { background: rgba(255,255,255,.03); }
.feed-dot { width: 6px; height: 6px; border-radius: 999px; background: var(--accent-2); flex-shrink: 0; margin-top: 5px; }
.feed-main { flex: 1; min-width: 0; }
.feed-main strong { display: block; font-size: .81rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.feed-main small { font-size: .68rem; color: var(--text-3); margin-top: 2px; display: block; }
.feed-time { font-family: var(--mono); font-size: .67rem; color: var(--text-3); flex-shrink: 0; white-space: nowrap; }
.meter-row { padding: 7px 9px; display: flex; flex-direction: column; gap: 5px; }
.meter-top { display: flex; justify-content: space-between; align-items: center; }
.meter-top strong { font-size: .81rem; }
.meter-top-right { display: flex; align-items: center; gap: 8px; }
.meter-top span { font-family: var(--mono); font-size: .73rem; color: var(--text-3); }
.meter-pct { font-family: var(--mono); font-size: .72rem; font-weight: 700; color: var(--accent-2); min-width: 34px; text-align: right; }
.meter-track { height: 10px; border-radius: 999px; background: rgba(255,255,255,.05); overflow: hidden; }
.meter-fill { height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--accent), var(--accent-2)); transition: width .5s cubic-bezier(.4,0,.2,1); }

/* BADGES */
.badge { display: inline-flex; align-items: center; padding: 2px 8px; border-radius: 999px; font-size: .69rem; font-weight: 600; letter-spacing: .02em; white-space: nowrap; }
.badge-purple { background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent-border); }
.badge-green { background: var(--g-soft); color: var(--green); border: 1px solid var(--g-brd); }
.badge-red { background: var(--r-soft); color: var(--red); border: 1px solid var(--r-brd); }
.badge-orange { background: var(--o-soft); color: var(--orange); border: 1px solid rgba(249,115,22,.3); }
.badge-blue { background: var(--b-soft); color: var(--blue); border: 1px solid var(--b-brd); }
.badge-gray { background: rgba(255,255,255,.05); color: var(--text-3); border: 1px solid var(--border); }
.badge-indigo { background: var(--i-soft); color: var(--indigo); border: 1px solid rgba(99,102,241,.3); }
.badge-cyan { background: rgba(34,211,238,.1); color: var(--accent-2); border: 1px solid rgba(34,211,238,.3); }
.status-badge { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; border-radius: 999px; font-size: .73rem; font-weight: 600; border: 1px solid var(--border); color: var(--text-3); }
.status-badge.open { background: var(--g-soft); color: var(--green); border-color: var(--g-brd); }
.status-badge.closed { background: var(--r-soft); color: var(--red); border-color: var(--r-brd); }
.chip-label { font-family: var(--mono); font-size: .71rem; color: var(--text-3); padding: 2px 7px; border-radius: 4px; background: rgba(255,255,255,.04); border: 1px solid var(--border); white-space: nowrap; }
.chip-btn { font-size: .71rem; color: var(--text-3); padding: 4px 10px; border-radius: 5px; background: rgba(255,255,255,.04); border: 1px solid var(--border); transition: all .12s; }
.chip-btn:hover, .chip-btn.active { color: var(--accent-2); border-color: rgba(34,211,238,.3); background: rgba(34,211,238,.07); }

/* BUTTONS */
.btn-primary { display: inline-flex; align-items: center; justify-content: center; gap: 6px; min-height: 34px; padding: 0 15px; border-radius: var(--radius); font-size: .82rem; font-weight: 700; color: #fff; background: var(--accent); border: 1px solid transparent; transition: opacity .15s, transform .1s; white-space: nowrap; }
.btn-primary:hover { opacity: .88; transform: translateY(-1px); }
.btn-primary:active { transform: none; }
.btn-primary:disabled { opacity: .45; cursor: not-allowed; transform: none; }
.btn-secondary { display: inline-flex; align-items: center; gap: 6px; min-height: 34px; padding: 0 13px; border-radius: var(--radius); font-size: .82rem; font-weight: 600; color: var(--text-2); border: 1px solid var(--border); background: var(--panel); transition: background .12s, border .12s, color .12s; white-space: nowrap; }
.btn-secondary:hover { background: var(--panel-hov); border-color: var(--border-hov); color: var(--text); }
.btn-ghost { display: inline-flex; align-items: center; gap: 6px; min-height: 34px; padding: 0 13px; border-radius: var(--radius); font-size: .82rem; color: var(--text-3); border: 1px solid var(--border); transition: background .12s, color .12s; }
.btn-ghost:hover { background: rgba(255,255,255,.04); color: var(--text-2); }
.btn-danger { display: inline-flex; align-items: center; gap: 6px; min-height: 34px; padding: 0 13px; border-radius: var(--radius); font-size: .82rem; font-weight: 600; color: var(--red); background: var(--r-soft); border: 1px solid var(--r-brd); transition: background .12s; white-space: nowrap; }
.btn-danger:hover { background: rgba(239,68,68,.2); }
.btn-danger:disabled { opacity: .4; cursor: not-allowed; }
.btn-danger-outline { display: inline-flex; align-items: center; gap: 6px; min-height: 34px; padding: 0 13px; border-radius: var(--radius); font-size: .82rem; font-weight: 600; color: var(--red); background: transparent; border: 1px solid var(--r-brd); transition: background .12s; }
.btn-danger-outline:hover { background: var(--r-soft); }
.btn-danger-outline:disabled { opacity: .4; cursor: not-allowed; }
.btn-success { display: inline-flex; align-items: center; gap: 6px; min-height: 34px; padding: 0 13px; border-radius: var(--radius); font-size: .82rem; font-weight: 600; color: var(--green); background: var(--g-soft); border: 1px solid var(--g-brd); transition: background .12s; }
.btn-success:hover { background: rgba(34,197,94,.2); }
.tiny-btn { min-height: 26px; padding: 0 9px; border-radius: 5px; font-size: .71rem; color: var(--text-3); background: rgba(255,255,255,.04); border: 1px solid var(--border); transition: background .1s, color .1s; }
.tiny-btn:hover { color: var(--text); background: rgba(255,255,255,.08); }

/* FORMS */
.form-body { padding: 14px; display: flex; flex-direction: column; gap: 12px; }
.field-label { display: flex; flex-direction: column; gap: 5px; font-size: .7rem; font-weight: 700; color: var(--text-3); text-transform: uppercase; letter-spacing: .08em; }
.form-input { width: 100%; min-height: 36px; padding: 7px 11px; border-radius: var(--radius); border: 1px solid var(--border); background: var(--bg2); color: var(--text); font-size: .83rem; outline: none; transition: border-color .12s, box-shadow .12s; }
.form-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(124,58,237,.1); }
.form-input:disabled { opacity: .5; cursor: not-allowed; }
.form-input.compact { width: auto; min-height: 32px; padding: 4px 8px; font-size: .77rem; }
textarea.form-input { min-height: 80px; resize: vertical; line-height: 1.55; }
select.form-input { cursor: pointer; }

/* SEGMENTED */
.segmented { display: inline-flex; padding: 3px; gap: 2px; border-radius: 7px; background: var(--bg2); border: 1px solid var(--border); }
.segmented button { min-height: 27px; padding: 0 12px; border-radius: 5px; font-size: .77rem; color: var(--text-3); transition: background .1s, color .1s; }
.segmented button.active { background: var(--panel-hov); color: var(--text); }
.log-tabs { margin-bottom: 12px; }

/* TABLES */
.table-wrap { overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; min-width: 560px; }
.data-table th { padding: 9px 14px; text-align: left; font-size: .66rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--text-3); border-bottom: 1px solid var(--border); white-space: nowrap; background: rgba(255,255,255,.01); }
.data-table td { padding: 10px 14px; border-bottom: 1px solid rgba(28,34,53,.6); font-size: .81rem; color: var(--text-2); vertical-align: middle; }
.data-table tr:last-child td { border-bottom: 0; }
.data-table tr:hover td { background: rgba(255,255,255,.015); }
.mono { font-family: var(--mono); font-size: .75rem !important; }
.truncate { max-width: 220px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* TOGGLE SWITCH */
.toggle-switch { position: relative; width: 44px; height: 24px; border-radius: 999px; background: var(--border); border: 1px solid var(--border-hov); transition: background .2s; flex-shrink: 0; }
.toggle-switch[aria-checked="true"] { background: var(--accent); border-color: var(--accent); }
.toggle-thumb { position: absolute; width: 16px; height: 16px; border-radius: 999px; background: white; top: 3px; left: 3px; pointer-events: none; transition: left .2s; }
.toggle-switch[aria-checked="true"] .toggle-thumb { left: calc(100% - 19px); }

/* TOAST */
.toast-container { position: fixed; right: 16px; bottom: 16px; z-index: 600; display: flex; flex-direction: column; gap: 7px; pointer-events: none; }
.toast { max-width: 340px; padding: 11px 14px; border-radius: var(--radius); background: #051405; border: 1px solid var(--border-hov); box-shadow: 0 12px 40px rgba(0,0,0,.5); font-size: .82rem; pointer-events: auto; animation: toast-in .18s ease; display: flex; align-items: center; gap: 8px; }
.toast::before { content: 'i'; font-size: .85rem; flex-shrink: 0; font-style: italic; font-weight: 700; color: var(--accent-2); }
.toast.success { border-color: var(--g-brd); }
.toast.success::before { content: '+'; color: var(--green); font-style: normal; }
.toast.error { border-color: var(--r-brd); }
.toast.error::before { content: '!'; color: var(--red); font-style: normal; font-weight: 700; }
@keyframes toast-in { from { opacity:0; transform: translateY(8px) scale(.96); } to { opacity:1; transform: none; } }

/* MODAL */
.modal-overlay { position: fixed; inset: 0; z-index: 400; display: grid; place-items: center; padding: 16px; background: rgba(0,0,0,.72); backdrop-filter: blur(8px); }
.modal-overlay.hidden { display: none !important; }
.modal { position: relative; width: min(460px,100%); background: #041204; border: 1px solid var(--border-hov); border-radius: var(--radius-lg); padding: 22px; box-shadow: 0 24px 80px rgba(0,0,0,.6); }
.modal h3 { font-size: 1rem; margin-bottom: 8px; }
.modal p { color: var(--text-3); font-size: .83rem; line-height: 1.6; margin-bottom: 12px; }
.modal-close { position: absolute; right: 12px; top: 11px; width: 26px; height: 26px; border-radius: 5px; font-size: 1.05rem; color: var(--text-3); display: grid; place-items: center; }
.modal-close:hover { background: rgba(255,255,255,.06); color: var(--text); }
.modal-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 14px; }
#modalExtra { margin-bottom: 4px; }
#modalExtra .form-input { margin-top: 6px; }

/* SPINNER */
.spinner { width: 18px; height: 18px; border-radius: 50%; border: 2px solid rgba(255,255,255,.08); border-top-color: var(--accent); animation: spin .75s linear infinite; flex-shrink: 0; }
@keyframes spin { to { transform: rotate(360deg); } }

/* MISC */
.empty-state { padding: 24px; text-align: center; color: var(--text-3); font-size: .82rem; line-height: 1.6; }
.hidden { display: none !important; }

/* LIVE INDICATORS */
.live-pulse { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--green); flex-shrink: 0; box-shadow: 0 0 0 0 rgba(34,197,94,.5); animation: livepulse 2s infinite; }
@keyframes livepulse { 0% { box-shadow: 0 0 0 0 rgba(34,197,94,.5); } 70% { box-shadow: 0 0 0 7px rgba(34,197,94,0); } 100% { box-shadow: 0 0 0 0 rgba(34,197,94,0); } }
.live-pulse-label { display: flex; align-items: center; gap: 7px; font-size: .79rem; color: var(--text-3); }
.nav-live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--green); margin-left: auto; opacity: 0; transition: opacity .3s; flex-shrink: 0; box-shadow: 0 0 5px var(--green); }

/* LIVE BAR */
.live-bar { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 10px 16px; margin-bottom: 14px; background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius-lg); border-left: 3px solid var(--green); }
.live-bar-left { display: flex; align-items: center; gap: 8px; font-size: .83rem; }
.live-bar-count { font-family: var(--mono); font-weight: 800; font-size: 1.1rem; color: var(--green); }
.live-bar-pages { flex: 1; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.lp-chip { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: 999px; background: var(--panel-hov); border: 1px solid var(--border); font-size: .71rem; color: var(--text-2); }
.lp-chip small { color: var(--accent-2); font-weight: 700; }

/* BOT CONTROL */
.bot-card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 18px 22px; display: flex; align-items: center; gap: 20px; flex-wrap: wrap; margin-bottom: 14px; }
.bot-card-left { display: flex; align-items: center; gap: 14px; }
.bot-dot { width: 12px; height: 12px; border-radius: 999px; background: var(--text-3); flex-shrink: 0; transition: background .3s, box-shadow .3s; }
.bot-dot.online { background: var(--green); box-shadow: 0 0 12px var(--green); animation: livepulse 2.5s infinite; }
.bot-dot.offline { background: var(--red); }
.bot-card-left strong { font-size: .96rem; display: block; font-weight: 700; }
.bot-card-left p { font-size: .77rem; color: var(--text-3); margin-top: 3px; }
.bot-stats { display: flex; gap: 12px; margin-left: auto; flex-wrap: wrap; }
.bot-stat { display: flex; flex-direction: column; align-items: center; gap: 3px; padding: 8px 12px; border-radius: 8px; background: var(--bg2); border: 1px solid var(--border); min-width: 68px; }
.bot-stat span { font-size: .63rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .08em; }
.bot-stat strong { font-family: var(--mono); font-size: .88rem; font-weight: 700; }
.bot-kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 14px; }
.maint-body { padding: 16px; }
.maint-toggle-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.maint-toggle-row strong { display: block; font-size: .88rem; }
.maint-toggle-row p { font-size: .77rem; color: var(--text-3); margin-top: 3px; }
.maint-form { margin-top: 14px; display: flex; flex-direction: column; gap: 10px; }
.maint-actions { display: flex; gap: 7px; }
.presence-info { padding: 10px 16px; display: flex; flex-direction: column; gap: 1px; }
.presence-row { display: flex; justify-content: space-between; align-items: center; padding: 9px 0; border-bottom: 1px solid rgba(28,34,53,.6); }
.presence-row:last-child { border-bottom: 0; }
.presence-row span { font-size: .74rem; color: var(--text-3); }
.presence-row strong { font-size: .82rem; font-weight: 600; }
.announce-form { padding: 14px; display: flex; flex-direction: column; gap: 12px; }
.autorefresh-chip { display: flex; align-items: center; gap: 7px; padding: 5px 12px; border-radius: 999px; border: 1px solid var(--border); background: var(--panel); font-size: .77rem; color: var(--text-3); cursor: pointer; transition: all .15s; }
.autorefresh-chip.on { border-color: var(--g-brd); background: var(--g-soft); color: var(--green); }
.autorefresh-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--text-3); flex-shrink: 0; }
.autorefresh-chip.on .autorefresh-dot { background: var(--green); box-shadow: 0 0 5px var(--green); animation: livepulse 2s infinite; }

/* Member lookup */
.member-lookup-card { display: flex; align-items: flex-start; gap: 14px; padding: 14px; background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; margin-top: 8px; flex-wrap: wrap; }
.member-lookup-avatar { width: 52px; height: 52px; border-radius: 12px; flex-shrink: 0; overflow: hidden; background: var(--accent-soft); display: grid; place-items: center; }
.member-lookup-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.member-lookup-avatar span { font-weight: 800; font-size: 1.2rem; color: var(--accent); }
.member-lookup-info { flex: 1; min-width: 0; }
.member-lookup-name { font-size: .9rem; font-weight: 700; margin-bottom: 4px; }
.member-lookup-meta { font-size: .75rem; color: var(--text-3); margin-bottom: 4px; }
.member-lookup-stats { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }
.member-lookup-stat { display: flex; flex-direction: column; gap: 2px; }
.member-lookup-stat span { font-size: .63rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .06em; }
.member-lookup-stat strong { font-family: var(--mono); font-size: .8rem; font-weight: 700; }

/* TICKET DETAIL MODAL */
.tc-overlay { position: fixed; inset: 0; z-index: 200; background: rgba(0,0,0,.75); backdrop-filter: blur(6px); display: flex; align-items: stretch; justify-content: flex-end; }
.tc-overlay.hidden { display: none !important; }
.tc-panel { width: min(780px, 100vw); height: 100vh; background: var(--bg2); border-left: 1px solid var(--border); display: flex; flex-direction: column; overflow: hidden; box-shadow: -24px 0 70px rgba(0,0,0,.5); animation: tcSlideIn .22s ease; }
@keyframes tcSlideIn { from { transform: translateX(100%); } to { transform: translateX(0); } }
.tc-header { padding: 14px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: 10px; background: var(--panel); flex-shrink: 0; flex-wrap: wrap; }
.tc-header-left { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.tc-close { width: 32px; height: 32px; border-radius: 7px; flex-shrink: 0; display: grid; place-items: center; color: var(--text-3); transition: background .12s, color .12s; }
.tc-close:hover { background: var(--r-soft); color: var(--red); }
.tc-close svg { width: 14px; height: 14px; }
.tc-title h3 { font-size: .94rem; font-weight: 700; }
.tc-title span { font-size: .72rem; color: var(--text-3); display: block; margin-top: 1px; }
.tc-header-actions { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.tc-refresh-btn { width: 30px; height: 30px; border-radius: 7px; border: 1px solid var(--border); display: grid; place-items: center; color: var(--text-3); transition: background .12s, color .12s; }
.tc-refresh-btn:hover { color: var(--text); background: var(--panel-hov); }
.tc-refresh-btn svg { width: 13px; height: 13px; }
.tc-info-bar { display: flex; gap: 0; padding: 0; border-bottom: 1px solid var(--border); background: var(--panel); flex-shrink: 0; overflow-x: auto; }
.tc-info-item { padding: 8px 14px; border-right: 1px solid var(--border); flex-shrink: 0; }
.tc-info-item:last-child { border-right: 0; }
.tc-info-item span { font-size: .64rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .07em; display: block; }
.tc-info-item strong { font-size: .79rem; display: block; margin-top: 2px; }
.tc-messages { flex: 1; overflow-y: auto; padding: 14px 12px; display: flex; flex-direction: column; gap: 3px; scroll-behavior: smooth; }
.tc-loading { display: flex; align-items: center; gap: 10px; justify-content: center; padding: 40px; color: var(--text-3); font-size: .85rem; }
.tc-error { padding: 12px; color: var(--red); font-size: .83rem; }
.tc-msg { display: flex; align-items: flex-start; gap: 9px; padding: 4px; border-radius: 8px; transition: background .1s; }
.tc-msg:hover { background: rgba(255,255,255,.025); }
.tc-avatar { width: 30px; height: 30px; border-radius: 7px; flex-shrink: 0; margin-top: 2px; display: grid; place-items: center; font-size: .75rem; font-weight: 800; background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent-border); }
.tc-msg-bot .tc-avatar { background: var(--d-soft); color: var(--discord); border-color: rgba(88,101,242,.3); }
.tc-msg-panel .tc-avatar { background: var(--g-soft); color: var(--green); border-color: var(--g-brd); }
.tc-bubble { flex: 1; min-width: 0; }
.tc-bubble-meta { display: flex; align-items: baseline; gap: 8px; margin-bottom: 3px; }
.tc-bubble-meta strong { font-size: .8rem; font-weight: 700; }
.tc-bubble-meta span { font-size: .68rem; color: var(--text-3); }
.tc-bubble-content { font-size: .83rem; line-height: 1.6; color: var(--text-2); word-break: break-word; }
.tc-attachment { max-width: 260px; max-height: 180px; border-radius: 6px; margin-top: 6px; display: block; border: 1px solid var(--border); cursor: pointer; }
.tc-file-link { display: inline-flex; align-items: center; gap: 4px; font-size: .79rem; color: var(--accent-2); text-decoration: underline; margin-top: 4px; }
.tc-input-area { padding: 10px 12px; border-top: 1px solid var(--border); background: var(--panel); flex-shrink: 0; transition: opacity .2s; }
.tc-input-row { display: flex; align-items: center; gap: 8px; }
.tc-attach-btn { width: 34px; height: 34px; border-radius: 8px; border: 1px solid var(--border); display: grid; place-items: center; color: var(--text-3); cursor: pointer; flex-shrink: 0; transition: background .12s, color .12s; }
.tc-attach-btn:hover { background: var(--accent-soft); color: var(--accent); border-color: var(--accent-border); }
.tc-attach-btn svg { width: 15px; height: 15px; }
.tc-msg-input { flex: 1; height: 36px; border-radius: 8px; background: var(--bg); border: 1px solid var(--border); color: var(--text); font-size: .84rem; padding: 0 12px; outline: none; transition: border-color .15s; }
.tc-msg-input:focus { border-color: var(--accent-border); }
.tc-msg-input::placeholder { color: var(--text-3); }
.tc-send-btn { width: 36px; height: 36px; border-radius: 8px; flex-shrink: 0; background: var(--accent); color: #fff; display: grid; place-items: center; transition: background .12s, transform .1s; }
.tc-send-btn:hover { background: #166534; }
.tc-send-btn:active { transform: scale(.94); }
.tc-send-btn:disabled { opacity: .4; cursor: not-allowed; transform: none; }
.tc-send-btn svg { width: 15px; height: 15px; }
.tc-attachments-preview { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 7px; }
.tc-attach-chip { display: flex; align-items: center; gap: 5px; padding: 2px 8px; border-radius: 999px; background: var(--accent-soft); border: 1px solid var(--accent-border); font-size: .71rem; color: var(--text); }
.tc-remove-attach { display: inline-flex; align-items: center; justify-content: center; width: 14px; height: 14px; border-radius: 50%; background: var(--accent-border); color: #fff; font-size: .65rem; cursor: pointer; }
.tc-closed-note { padding: 10px 14px; background: var(--r-soft); border-top: 1px solid var(--r-brd); font-size: .8rem; color: var(--red); text-align: center; flex-shrink: 0; }

/* STAFF */
.staff-main-tabs { margin-bottom: 0; }
.staff-tab-pane { display: block; }
.staff-tab-pane.hidden { display: none !important; }
.staff-cards-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 10px; padding: 14px; }
.staff-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; padding: 14px; display: flex; align-items: center; gap: 12px; transition: border-color .15s; flex-wrap: wrap; }
.staff-card:hover { border-color: var(--border-hov); }
.staff-card-inactive { opacity: .65; }
.staff-card-avatar { width: 40px; height: 40px; border-radius: 10px; flex-shrink: 0; background: linear-gradient(135deg, var(--accent), var(--accent-2)); display: grid; place-items: center; font-weight: 800; font-size: .95rem; color: #fff; }
.staff-card-body { flex: 1; min-width: 0; }
.staff-card-name { font-size: .85rem; font-weight: 700; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: 4px; }
.staff-card-meta { font-size: .69rem; color: var(--text-3); }
.staff-card-actions { display: flex; gap: 5px; flex-wrap: wrap; align-items: center; margin-left: auto; }
.staff-list { padding: 6px; }
.staff-item { display: flex; align-items: center; gap: 9px; padding: 8px 9px; border-radius: 7px; transition: background .1s; }
.staff-item:hover { background: rgba(255,255,255,.03); }
.staff-avatar { width: 34px; height: 34px; border-radius: 8px; flex-shrink: 0; background: linear-gradient(135deg, var(--accent), var(--accent-2)); display: grid; place-items: center; font-weight: 800; font-size: .87rem; }
.staff-info { flex: 1; min-width: 0; }
.staff-info strong { display: block; font-size: .81rem; }
.staff-info small { font-size: .69rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .06em; }
.staff-actions { display: flex; gap: 4px; flex-wrap: wrap; }
.status-dot { width: 7px; height: 7px; border-radius: 999px; background: var(--text-3); }
.status-dot.active { background: var(--green); box-shadow: 0 0 7px var(--green); }

/* PERMISSIONS GRID */
.perm-grid { display: grid; grid-template-columns: 1fr 110px 110px; gap: 0; padding: 14px; }
.perm-cell { display: flex; align-items: center; padding: 10px 14px; border-bottom: 1px solid var(--border); }
.perm-cell:nth-last-child(-n+3) { border-bottom: 0; }
.perm-header { font-size: .66rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--text-3); background: rgba(255,255,255,.01); padding: 8px 14px; }
.perm-view-name { font-size: .82rem; font-weight: 600; }
.perm-view-desc { font-size: .7rem; color: var(--text-3); margin-top: 1px; }
.perm-cell:not(.perm-header):not(.perm-view) { justify-content: center; }
.perm-toggle { position: relative; width: 44px; height: 24px; border-radius: 999px; background: var(--border); border: 1px solid var(--border-hov); transition: background .2s; }
.perm-toggle.on { background: var(--accent); border-color: var(--accent); }
.perm-toggle-thumb { position: absolute; width: 16px; height: 16px; border-radius: 999px; background: white; top: 3px; left: 3px; pointer-events: none; transition: left .2s; }
.perm-toggle.on .perm-toggle-thumb { left: calc(100% - 19px); }

/* CONFIG ROWS */
.config-rows { padding: 8px 16px; display: flex; flex-direction: column; gap: 0; }
.config-row { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid var(--border); gap: 12px; }
.config-row:last-child { border-bottom: 0; }
.config-row-info { flex: 1; min-width: 0; }
.config-row-info strong { display: block; font-size: .83rem; font-weight: 600; }
.config-row-info span { font-size: .74rem; color: var(--text-3); margin-top: 2px; display: block; }

/* SCENEPED DETAIL PANEL */
.sp-overlay { position: fixed; inset: 0; z-index: 200; background: rgba(0,0,0,.75); backdrop-filter: blur(7px); display: flex; align-items: stretch; justify-content: flex-end; }
.sp-overlay.hidden { display: none !important; }
.sp-panel { width: min(820px, 100vw); height: 100vh; background: var(--bg2); border-left: 1px solid var(--border); display: flex; flex-direction: column; overflow: hidden; box-shadow: -24px 0 70px rgba(0,0,0,.5); animation: tcSlideIn .22s ease; }
.sp-header { padding: 14px 18px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: 10px; background: var(--panel); flex-shrink: 0; flex-wrap: wrap; }
.sp-header-left { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.sp-close { width: 32px; height: 32px; border-radius: 7px; flex-shrink: 0; display: grid; place-items: center; color: var(--text-3); transition: background .12s, color .12s; }
.sp-close:hover { background: var(--r-soft); color: var(--red); }
.sp-close svg { width: 14px; height: 14px; }
.sp-title h3 { font-size: .95rem; font-weight: 700; }
.sp-title small { font-size: .71rem; color: var(--text-3); display: block; margin-top: 1px; }
.sp-header-actions { display: flex; align-items: center; gap: 7px; }
.sp-body { flex: 1; overflow-y: auto; padding: 18px 20px; display: flex; flex-direction: column; gap: 14px; }
.sp-actions { padding: 12px 18px; border-top: 1px solid var(--border); background: var(--panel); flex-shrink: 0; display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.sp-actions-note { flex: 1; min-width: 200px; }
.sp-actions-btns { display: flex; gap: 8px; flex-shrink: 0; }
.sp-member-card { background: var(--panel); border: 1px solid var(--border); border-radius: 10px; padding: 16px 18px; display: flex; align-items: flex-start; gap: 16px; flex-wrap: wrap; }
.sp-avatar { width: 64px; height: 64px; border-radius: 14px; overflow: hidden; flex-shrink: 0; background: var(--accent-soft); display: grid; place-items: center; font-weight: 800; font-size: 1.5rem; color: var(--accent); border: 2px solid var(--accent-border); }
.sp-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sp-member-info { flex: 1; min-width: 0; }
.sp-member-name { font-size: 1rem; font-weight: 700; }
.sp-member-sub { font-size: .74rem; color: var(--text-3); margin-top: 2px; }
.sp-member-stats { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 10px; }
.sp-stat { display: flex; flex-direction: column; gap: 2px; }
.sp-stat span { font-size: .63rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .08em; }
.sp-stat strong { font-family: var(--mono); font-size: .85rem; font-weight: 700; }
.sp-roles-row { display: flex; gap: 5px; flex-wrap: wrap; margin-top: 8px; }
.sp-role-chip { font-size: .68rem; padding: 2px 8px; border-radius: 4px; background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent-border); }
.sp-section-title { font-size: .71rem; font-weight: 700; text-transform: uppercase; letter-spacing: .11em; color: var(--text-3); margin-bottom: 6px; }
.sp-answers { display: flex; flex-direction: column; gap: 8px; }
.sp-answer { background: var(--panel); border: 1px solid var(--border); border-radius: 8px; padding: 12px 14px; }
.sp-answer-label { font-size: .67rem; font-weight: 700; text-transform: uppercase; letter-spacing: .09em; color: var(--text-3); margin-bottom: 5px; }
.sp-answer-value { font-size: .85rem; color: var(--text); line-height: 1.6; word-break: break-word; }

/* VISITORS */
.visitor-feed { padding: 8px 4px; max-height: 420px; overflow-y: auto; }
.visitor-item { display: flex; align-items: flex-start; gap: 10px; padding: 9px 12px; border-radius: 8px; transition: background .12s; }
.visitor-item:hover { background: rgba(255,255,255,.03); }
.visitor-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 4px; background: var(--green); box-shadow: 0 0 6px var(--green); animation: livepulse 2.5s infinite; }
.visitor-info strong { font-size: .82rem; display: block; }
.visitor-info small { font-size: .71rem; color: var(--text-3); margin-top: 2px; display: block; }

/* LOGS */
.log-filter-bar { display: flex; align-items: center; gap: 8px; padding: 10px 16px; border-bottom: 1px solid var(--border); flex-wrap: wrap; }
.log-search-input { flex: 1; min-width: 180px; height: 32px; border-radius: 6px; background: var(--bg2); border: 1px solid var(--border); color: var(--text); font-size: .81rem; padding: 0 10px; outline: none; transition: border .12s; }
.log-search-input:focus { border-color: var(--accent-border); }
.sped-status-wrap { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

/* Log level filter buttons */
.log-level-filters { display: flex; gap: 6px; flex-wrap: wrap; margin: 4px 0; }
.log-filter-btn { padding: 4px 12px; border-radius: 6px; border: 1px solid var(--border); background: transparent; color: var(--text-2); font-size: .78rem; cursor: pointer; transition: background .12s, color .12s, border-color .12s; }
.log-filter-btn:hover { background: var(--accent-soft); color: var(--accent); border-color: var(--accent-border); }
.log-filter-btn.active { background: var(--accent-soft); color: var(--accent); border-color: var(--accent-border); font-weight: 600; }

/* Ticket staff performance bar */
.perf-bar-track { width: 100%; height: 6px; background: var(--bg2); border-radius: 3px; }
.perf-bar-fill  { height: 6px; background: var(--accent); border-radius: 3px; transition: width .4s; }

/* Staff activity feed */
.staff-action-feed { max-height: 280px; overflow-y: auto; }
.feed-item { display: flex; align-items: baseline; gap: 8px; padding: 7px 10px; border-radius: 6px; font-size: .8rem; transition: background .12s; }
.feed-item:hover { background: rgba(255,255,255,.03); }
.feed-actor  { font-weight: 600; color: var(--text); flex-shrink: 0; }
.feed-action { color: var(--text-2); flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.feed-time   { color: var(--text-3); font-size: .72rem; flex-shrink: 0; }

/* Boost info rows */
.config-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; border-bottom: 1px solid var(--border); gap: 10px; }
.config-row:last-child { border-bottom: none; }
.config-row-info { display: flex; flex-direction: column; gap: 2px; }
.config-row-info strong { font-size: .84rem; }
.config-row-info span   { font-size: .75rem; color: var(--text-3); }

/* Discord status breakdown container */
#discordStatusBreakdown { padding: 8px 4px; }

/* LOCK OVERLAY */
.lock-overlay { position: fixed; inset: 0; z-index: 350; display: grid; place-items: center; padding: 20px; background: rgba(8,11,20,.9); backdrop-filter: blur(10px); }
.lock-overlay.hidden { display: none !important; }
.lock-panel { text-align: center; max-width: 340px; background: var(--panel); border: 1px solid var(--border-hov); border-radius: var(--radius-lg); padding: 32px 28px; box-shadow: 0 24px 80px rgba(0,0,0,.6); }
.lock-icon-wrap { margin-bottom: 18px; }
.lock-icon { width: 64px; height: 74px; color: var(--text-3); }
.lock-shackle { animation: shackleSwing 0.6s ease-out forwards; }
@keyframes shackleSwing { 0% { transform: translateY(-10px) rotateX(30deg); opacity: 0; } 100% { transform: translateY(0) rotateX(0); opacity: 1; } }
.lock-title { font-size: 1.2rem; margin-bottom: 8px; }
.lock-desc { color: var(--text-3); font-size: .85rem; line-height: 1.6; margin-bottom: 14px; }
.lock-role-badge { display: inline-flex; padding: 4px 12px; border-radius: 999px; background: var(--r-soft); border: 1px solid var(--r-brd); color: var(--red); font-size: .77rem; font-weight: 600; margin-bottom: 18px; }
.lock-back-btn { width: 100%; justify-content: center; }

/* AUTH */
.auth-page { min-height: 100vh; display: grid; place-items: center; padding: 20px; }
.auth-card { width: min(420px,100%); padding: 30px 28px; border-radius: var(--radius-lg); background: var(--panel); border: 1px solid var(--border); box-shadow: 0 24px 80px rgba(0,0,0,.5); }
.auth-logo { text-align: center; margin-bottom: 22px; font-weight: 800; font-size: 1.05rem; }
.auth-logo span { color: var(--accent-2); }
.auth-title { margin: 0; text-align: center; font-size: 1.75rem; }
.auth-sub { margin: 7px 0 24px; color: var(--text-3); text-align: center; line-height: 1.6; font-size: .85rem; }
.auth-form { display: flex; flex-direction: column; gap: 13px; }
.form-label { color: var(--text-3); font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; display: flex; flex-direction: column; gap: 5px; }
.input-wrap { position: relative; }
.input-wrap .form-input { padding-right: 44px; }
.toggle-pw { position: absolute; right: 6px; top: 50%; transform: translateY(-50%); width: 32px; height: 32px; border-radius: 7px; color: var(--text-3); display: grid; place-items: center; }
.toggle-pw:hover { background: rgba(255,255,255,.05); color: var(--text-2); }
.form-error { padding: 9px 12px; border-radius: var(--radius); color: #ffd7dd; background: var(--r-soft); border: 1px solid rgba(239,68,68,.25); font-size: .82rem; }
.btn-auth { width: 100%; min-height: 42px; border-radius: var(--radius); font-weight: 800; color: #fff; background: linear-gradient(135deg, #15803d, #4ade80); font-size: .9rem; }
.btn-auth:disabled { opacity: .65; cursor: wait; }
.auth-footer { margin: 16px 0 0; color: var(--text-3); text-align: center; font-size: .76rem; }
.form-hint { color: var(--text-3); font-size: .74rem; font-weight: 600; }

/* RESPONSIVE */
.mobile-only { display: none !important; }
@media (max-width: 1400px) { .kpi-grid { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 1280px) { .kpi-grid { grid-template-columns: repeat(3,1fr); } .bot-kpi-grid { grid-template-columns: repeat(2,1fr); } .row-3 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 1100px) { .row-2-1 { grid-template-columns: 1fr; } .row-3 { grid-template-columns: 1fr; } .bot-stats { gap: 10px; } .bot-stat { min-width: 60px; } }
@media (max-width: 900px) { .sidebar { transform: translateX(-100%); transition: transform .22s ease; } .sidebar.open { transform: none; } .main { margin-left: 0; } .topbar { left: 0; } .mobile-only { display: flex !important; } .row-equal { grid-template-columns: 1fr; } .kpi-4 { grid-template-columns: repeat(2,1fr); } .bot-kpi-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .view { padding: 12px; } .kpi-grid, .kpi-4, .bot-kpi-grid { grid-template-columns: repeat(2,1fr); } .topbar-link { display: none; } .topbar { padding: 0 12px; } .bot-stats { gap: 8px; } .bot-stat { min-width: 52px; padding: 6px 8px; } .staff-cards-grid { grid-template-columns: 1fr; } .tc-panel { width: 100vw; } .sp-panel { width: 100vw; } .sync-indicator { display: none; } }
