/* ── Variables ─────────────────────────────────────────────── */
:root {
    --bg:      #060a12; --bg2: #0c1220; --bg3: #111827;
    --border:  #1e2a3a; --border2: #243044;
    --text:    #e2e8f0; --muted: #64748b; --muted2: #94a3b8;
    --accent:  #22d3ee; --accent2: #a855f7;
    --success: #22c55e; --danger: #ef4444; --warn: #f59e0b;
}
*{box-sizing:border-box;margin:0;padding:0}
[v-cloak]{display:none}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;font-size:14px;min-height:100vh}

/* ── Login ─────────────────────────────────────────────────── */
.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:radial-gradient(circle at 30% 40%,rgba(34,211,238,.06),transparent 60%),var(--bg)}
.login-card{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:48px;text-align:center;max-width:400px;width:90%}
.login-logo{font-size:48px;margin-bottom:16px}
.login-card h1{font-size:22px;font-weight:800;margin-bottom:8px}
.login-card p{color:var(--muted);margin-bottom:28px}
.btn-discord{display:inline-flex;align-items:center;gap:10px;padding:13px 28px;background:#5865f2;color:#fff;border-radius:10px;text-decoration:none;font-weight:700;transition:all .15s}
.btn-discord:hover{background:#4752c4;transform:translateY(-1px)}

/* ── Layout ────────────────────────────────────────────────── */
.app-layout{display:grid;grid-template-columns:320px 1fr;height:100vh;overflow:hidden}

/* ── Sidebar ───────────────────────────────────────────────── */
.sidebar{display:flex;flex-direction:column;background:var(--bg2);border-right:1px solid var(--border);overflow:hidden}
.sidebar-header{display:flex;align-items:center;gap:12px;padding:18px 16px;border-bottom:1px solid var(--border)}
.sidebar-logo{font-size:28px}
.sidebar-title{font-size:15px;font-weight:800;color:var(--text)}
.sidebar-sub{font-size:11px;color:var(--muted)}
.stats-row{display:flex;gap:0;border-bottom:1px solid var(--border)}
.stat-item{flex:1;text-align:center;padding:10px 4px;border-right:1px solid var(--border)}
.stat-item:last-child{border-right:none}
.stat-val{font-size:18px;font-weight:800;font-family:'JetBrains Mono',monospace;color:var(--accent)}
.stat-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.search-box{padding:10px 12px;border-bottom:1px solid var(--border)}
.search-input{width:100%;padding:8px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;outline:none}
.search-input:focus{border-color:var(--accent)}
.filters{display:flex;flex-direction:column;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border)}
.filter-select{width:100%;padding:6px 10px;background:var(--bg3);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:12px;outline:none;cursor:pointer}

/* Char list */
.char-list{flex:1;overflow-y:auto;padding:6px}
.char-list::-webkit-scrollbar{width:4px}
.char-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
.char-item{padding:10px 12px;border-radius:10px;cursor:pointer;margin-bottom:2px;border:1px solid transparent;transition:all .12s}
.char-item:hover{background:var(--bg3)}
.char-item.active{background:linear-gradient(135deg,rgba(34,211,238,.12),rgba(168,85,247,.08));border-color:rgba(34,211,238,.3)}
.char-item.dead{opacity:.6}
.char-item-name{font-weight:700;font-size:14px}
.char-item-meta{display:flex;gap:4px;margin-top:3px;flex-wrap:wrap}
.char-item-player{font-size:11px;color:var(--muted);margin-top:2px}
.badge-faction{padding:1px 7px;background:rgba(34,211,238,.1);color:var(--accent);border-radius:5px;font-size:10px;font-weight:700;text-transform:uppercase}
.badge-grade{padding:1px 7px;background:rgba(168,85,247,.1);color:#c084fc;border-radius:5px;font-size:10px;font-weight:700}
.badge-dead{font-size:12px}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:10px;padding:10px;border-top:1px solid var(--border);font-size:12px;color:var(--muted)}
.page-btn{padding:4px 10px;background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:6px;cursor:pointer}
.page-btn:disabled{opacity:.4;cursor:default}

/* Sidebar footer */
.sidebar-footer{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid var(--border);background:var(--bg)}
.user-avatar{width:32px;height:32px;border-radius:50%;border:2px solid var(--border)}
.user-name{font-size:13px;font-weight:600}
.user-role{font-size:11px;color:var(--warn)}
.logout-btn{margin-left:auto;color:var(--muted);text-decoration:none;font-size:16px}
.logout-btn:hover{color:var(--danger)}

/* Loading / empty */
.loading-state,.empty-state{text-align:center;padding:32px;color:var(--muted);font-size:13px}

/* ── Main ──────────────────────────────────────────────────── */
.main-content{overflow-y:auto;padding:28px 32px}
.empty-main{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--muted);gap:12px}
.empty-icon{font-size:64px;opacity:.3}

/* Detail header */
.char-detail{}
.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.detail-name{font-size:26px;font-weight:900;display:flex;align-items:center;gap:10px}
.dead-badge{font-size:14px;background:rgba(239,68,68,.15);color:#ef4444;padding:3px 10px;border-radius:6px;font-weight:700}
.detail-meta{font-size:13px;color:var(--muted);margin-top:4px}
.steamid{font-family:'JetBrains Mono',monospace;font-size:11px}
.refresh-indicator{font-size:12px;display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:8px}
.online-dot{width:8px;height:8px;border-radius:50%;background:var(--success);display:inline-block}
.offline-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);display:inline-block}

/* Tabs */
.tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:-1px}
.tab{padding:8px 18px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.tab:hover{color:var(--text)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}

/* Fields grid */
.fields-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px;margin-bottom:24px}
.field-edit{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;transition:border-color .15s}
.field-edit:hover{border-color:var(--border2)}
.field-locked{opacity:.6}
.field-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:7px;display:flex;align-items:center;gap:4px}
.superadmin-tag{color:var(--warn);font-size:11px}
.field-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.field-value{font-size:14px;font-weight:600;color:var(--text)}
.edit-btn{padding:4px 8px;background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:6px;cursor:pointer;font-size:12px;transition:all .15s}
.edit-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.edit-btn:disabled{cursor:not-allowed;opacity:.5}
.field-edit-form{display:flex;flex-direction:column;gap:8px}
.edit-input{padding:8px 10px;background:var(--bg);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-size:13px;outline:none;width:100%}
.edit-input:focus{border-color:var(--accent)}
.edit-reason{padding:7px 10px;background:var(--bg);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-size:12px;outline:none;width:100%}
.edit-reason:focus{border-color:var(--warn)}
.edit-actions{display:flex;gap:8px}
.save-btn{flex:1;padding:8px;background:var(--accent);color:#000;border:none;border-radius:8px;font-weight:700;font-size:13px;cursor:pointer}
.save-btn:hover:not(:disabled){background:var(--accent2);color:#fff}
.cancel-btn{padding:8px 14px;background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:8px;cursor:pointer}

/* Readonly section */
.readonly-section{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px}
.readonly-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:12px}
.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border)}
.info-row:last-child{border-bottom:none}
.info-lbl{font-size:12px;color:var(--muted)}
.info-val{font-size:13px;font-weight:600}
.info-val.accent{color:var(--accent);font-family:'JetBrains Mono',monospace}

/* History table */
.history-table{width:100%;border-collapse:collapse;font-size:12px}
.history-table th{text-align:left;padding:8px 12px;border-bottom:1px solid var(--border);color:var(--muted);font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.history-table td{padding:10px 12px;border-bottom:1px solid var(--border)}
.history-table tr:hover td{background:var(--bg2)}
.field-badge{padding:2px 8px;background:rgba(34,211,238,.1);color:var(--accent);border-radius:5px;font-family:'JetBrains Mono',monospace;font-size:11px}
.old-val{color:var(--danger);font-family:'JetBrains Mono',monospace}
.new-val{color:var(--success);font-family:'JetBrains Mono',monospace}
.mono{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted)}

/* Toasts */
.toasts{position:fixed;bottom:24px;right:24px;z-index:100;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{padding:11px 18px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;font-size:13px;font-weight:600;min-width:260px;pointer-events:auto;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.toast-success{border-left:3px solid var(--success)}
.toast-error{border-left:3px solid var(--danger)}
.toast-enter-from{transform:translateX(40px);opacity:0}
.toast-leave-to{transform:translateX(20px);opacity:0}
.toast-enter-active,.toast-leave-active{transition:all .25s}

/* ─── VIEW TOGGLE (Personnages / Tickets) ──────────────────────────────── */
.view-toggle{display:flex;gap:6px;padding:0 16px 12px;border-bottom:1px solid var(--border);margin-bottom:12px}
.view-btn{flex:1;background:var(--bg2);border:1px solid var(--border);color:var(--muted);padding:9px 10px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px;position:relative}
.view-btn:hover:not(.active){color:var(--text);background:var(--bg3)}
.view-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.view-btn.disabled,.view-btn:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.5)}
.view-btn.disabled:hover,.view-btn:disabled:hover{background:var(--bg2);color:var(--muted)}
.view-soon{font-size:9px;text-transform:uppercase;letter-spacing:.5px;background:rgba(255,255,255,.08);padding:1px 6px;border-radius:6px;margin-left:4px;font-weight:600}
.view-badge{background:#ef4444;color:#fff;border-radius:10px;padding:1px 7px;font-size:10px;font-weight:700;min-width:20px;text-align:center}
.view-btn.active .view-badge{background:rgba(0,0,0,.3)}

/* ─── TICKETS sidebar ──────────────────────────────────────────────────── */
.tickets-status{display:flex;align-items:center;gap:8px;padding:8px 16px;color:var(--muted);font-size:12px}
.status-dot{width:8px;height:8px;border-radius:50%;background:#10b981;display:inline-block;box-shadow:0 0 6px #10b981;animation:pulse-dot 2s infinite}
.status-dot.dead{background:#ef4444;box-shadow:0 0 6px #ef4444}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.4}}
.sound-btn{margin-left:auto;background:transparent;border:1px solid var(--border);color:var(--text);padding:3px 8px;border-radius:5px;cursor:pointer;font-size:14px}
.sound-btn:hover{background:var(--bg3)}

.ticket-filters{display:flex;flex-wrap:wrap;gap:4px;padding:0 16px 8px}
.tf-btn{background:var(--bg2);border:1px solid var(--border);color:var(--muted);padding:4px 9px;border-radius:6px;cursor:pointer;font-size:11px;font-weight:600;display:flex;align-items:center;gap:5px}
.tf-btn:hover:not(.active){background:var(--bg3);color:var(--text)}
.tf-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.tf-count{background:var(--bg3);color:var(--muted);padding:0 6px;border-radius:8px;font-size:10px;font-weight:700}
.tf-btn.active .tf-count{background:rgba(0,0,0,.3);color:#fff}

.ticket-list{flex:1;overflow-y:auto;padding:0 16px 16px;display:flex;flex-direction:column;gap:8px}
.ticket-card{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:11px;cursor:pointer;transition:all .12s;border-left:3px solid #6b7280}
.ticket-card:hover{background:var(--bg3);border-color:var(--accent)}
.ticket-card.active{background:var(--bg3);border-color:var(--accent);box-shadow:0 0 0 2px rgba(34,211,238,.18)}
.ticket-card.prio-3{border-left-color:#fbbf24}
.ticket-card.prio-4{border-left-color:#ef4444}
.ticket-card.st-open{box-shadow:inset 0 0 0 1px rgba(239,68,68,.2)}
.ticket-card-head{display:flex;align-items:center;gap:6px;margin-bottom:4px;font-size:11px}
.t-id{font-family:'JetBrains Mono',monospace;color:var(--muted);font-weight:700}
.t-prio{padding:1px 7px;border-radius:8px;background:rgba(99,102,241,.15);color:#a5b4fc;font-size:10px;font-weight:700;text-transform:uppercase}
.t-time{margin-left:auto;color:var(--muted);font-size:11px}
.t-player{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px}
.t-msg{font-size:12px;color:var(--muted);line-height:1.35;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.t-staff{margin-top:6px;font-size:11px;color:#10b981}

/* ─── TICKET DETAIL (main) ─────────────────────────────────────────────── */
.ticket-detail{padding:24px;display:flex;flex-direction:column;gap:18px}
.td-head{padding-bottom:18px;border-bottom:1px solid var(--border)}
.td-title{font-size:22px;font-weight:700;letter-spacing:-.02em;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.td-status{padding:3px 11px;border-radius:11px;font-size:11px;font-weight:700;text-transform:uppercase}
.td-status.st-open{background:rgba(239,68,68,.18);color:#f87171}
.td-status.st-claimed,.td-status.st-in_progress{background:rgba(251,191,36,.18);color:#fbbf24}
.td-status.st-closed{background:rgba(107,114,128,.18);color:#9ca3af}
.td-prio{padding:3px 11px;border-radius:11px;font-size:11px;font-weight:700;text-transform:uppercase}
.td-prio.prio-1{background:rgba(107,114,128,.18);color:#9ca3af}
.td-prio.prio-2{background:rgba(6,182,212,.18);color:#06b6d4}
.td-prio.prio-3{background:rgba(251,191,36,.18);color:#fbbf24}
.td-prio.prio-4{background:rgba(239,68,68,.22);color:#f87171}
.td-sub{color:var(--muted);font-size:13px;margin-top:6px}

.td-section{display:flex;flex-direction:column;gap:6px}
.td-section-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700}
.td-player-rp{color:#06b6d4;font-size:15px;font-weight:600}
.td-player-name{font-size:18px;font-weight:700}
.td-player-sid{font-family:'JetBrains Mono',monospace;color:var(--muted);font-size:11px}
.td-msg{background:var(--bg2);border-left:3px solid var(--accent);padding:14px 16px;border-radius:6px;font-size:14px;line-height:1.5;white-space:pre-wrap;word-break:break-word}
.td-assigned{color:#10b981;font-size:14px;font-weight:600}

.td-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.td-actions button{padding:10px 16px;border-radius:8px;border:1px solid transparent;cursor:pointer;font-size:13px;font-weight:600;transition:all .15s}
.td-actions button:hover{transform:translateY(-1px)}
.btn-claim{background:var(--accent);color:#fff}
.btn-claim:hover{filter:brightness(1.1)}
.btn-close{background:#ef4444;color:#fff}
.btn-close:hover{background:#dc2626}
.btn-goto{background:rgba(6,182,212,.18);color:#06b6d4;border-color:rgba(6,182,212,.4)}
.btn-bring{background:rgba(139,92,246,.18);color:#a78bfa;border-color:rgba(139,92,246,.4)}
.btn-zone{background:rgba(16,185,129,.18);color:#10b981;border-color:rgba(16,185,129,.4)}
.btn-return{background:rgba(249,115,22,.18);color:#fb923c;border-color:rgba(249,115,22,.4)}
