/* ══════════════════════════════════════════════════════════════
   FragHub — Index (Main) Page
   Requires base.css (shared theme, CRT, keyframes, animations)
   ═══════════════════════════════════════════════════════════════ */

/* Override base.css body defaults for fixed-height layout */
    body { height: 100vh; overflow: hidden; }

    .header { position: relative; padding: 16px 40px; border-bottom: 2px solid var(--border); background: linear-gradient(180deg, rgba(17,21,32,0.98), var(--bg-dark)); z-index: 10; display: flex; align-items: center; gap: 12px; backdrop-filter: blur(12px); flex-shrink: 0; opacity: 0; }
    .header::after { content: ''; position: absolute; bottom: -2px; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent 0%, var(--accent) 20%, var(--accent-2) 50%, var(--accent) 80%, transparent 100%); opacity: 0.4; }
    .header h1 { font-family: 'Orbitron', sans-serif; font-size: 22px; font-weight: 900; color: var(--accent); letter-spacing: 8px; text-shadow: 0 0 10px var(--accent), 0 0 20px var(--accent-glow-strong); transition: text-shadow 0.3s; }
    .header h1:hover { text-shadow: 0 0 15px var(--accent), 0 0 30px var(--accent-glow-strong), 0 0 45px var(--accent-glow); animation: glitch 0.3s; }
    .header-subtitle { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-dim); letter-spacing: 3px; text-transform: uppercase; margin-top: 2px; }
    .header-subtitle::after { content: '█'; animation: blink 1s step-end infinite; color: var(--accent-dim); margin-left: 3px; font-size: 9px; }
    .header-right { display: flex; align-items: center; gap: 12px; margin-left: auto; }
    .status-badge { font-family: 'JetBrains Mono', monospace; font-size: 11px; padding: 6px 14px; border: 1px solid var(--border); border-radius: 0; letter-spacing: 1px; text-transform: uppercase; }
    .status-badge.online { border-color: var(--success); color: var(--success); }
    .status-badge.cs2-ok { border-color: var(--accent); color: var(--accent); }
    .status-badge.cs2-missing { border-color: var(--danger); color: var(--danger); }
    .status-badge.admin-badge { border-color: var(--admin); color: var(--admin); }
    .status-badge.owner-badge { border-color: var(--owner); color: var(--owner); }
    .user-identity { display: flex; align-items: center; gap: 10px; padding: 6px 14px; border: 1px solid var(--border); border-radius: 0; background: rgba(17,21,32,0.4); }
    .user-identity img { width: 30px; height: 30px; border-radius: 0; border: 1px solid var(--border); transition: border-color 0.2s, box-shadow 0.2s; }
    .user-identity:hover img { border-color: var(--accent); box-shadow: 0 0 8px var(--accent-glow); }
    .user-identity .name { font-weight: 600; font-size: 14px; color: var(--text-bright); }
    .logout-link { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); text-decoration: none; letter-spacing: 1px; cursor: pointer; }
    .logout-link:hover { color: var(--danger); }
    .inbox-btn { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); text-decoration: none; letter-spacing: 1px; cursor: pointer; position: relative; padding: 6px 12px; border: 1px solid var(--border); border-radius: 0; background: rgba(17,21,32,0.6); backdrop-filter: blur(6px); transition: all 0.2s; }
    .inbox-btn:hover { color: var(--accent); border-color: var(--accent); box-shadow: 0 0 8px var(--accent-glow), inset 0 0 8px var(--accent-glow); }
    .inbox-badge { position: absolute; top: -6px; right: -6px; min-width: 16px; height: 16px; border-radius: 8px; background: var(--danger); color: #fff; font-size: 9px; line-height: 16px; text-align: center; padding: 0 4px; display: none; }
    .inbox-badge.visible { display: block; }

    .connected-indicator { display: flex; align-items: center; gap: 8px; padding: 6px 14px; border: 1px solid var(--border); background: rgba(17,21,32,0.4); backdrop-filter: blur(6px); }
    .connected-dot { width: 6px; height: 6px; background: var(--success); box-shadow: 0 0 6px var(--success), 0 0 12px rgba(74,224,94,0.3); animation: pulse 2s ease-in-out infinite; flex-shrink: 0; }
    .connected-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-dim); letter-spacing: 1px; text-transform: uppercase; }
    .connected-count { font-family: 'Orbitron', sans-serif; font-size: 14px; font-weight: 700; color: var(--accent); text-shadow: 0 0 8px var(--accent-glow); min-width: 16px; text-align: center; }

    #main-ui { display: flex; flex-direction: column; height: 100vh; }
    .container { position: relative; z-index: 5; width: 100%; max-width: 1600px; margin: 0 auto; padding: 20px 20px; display: grid; grid-template-columns: 340px 1fr; grid-template-rows: 1fr; gap: 20px; flex: 1; min-height: 0; opacity: 0; overflow: hidden; }
    .col-chat { display: flex; flex-direction: column; min-height: 0; }
    .col-chat .panel { flex: 1; display: flex; flex-direction: column; min-height: 0; }
    .col-right { display: flex; flex-direction: column; gap: 20px; min-height: 0; overflow: hidden auto; }
    .col-right-top { display: flex; flex-direction: column; gap: 20px; flex-shrink: 0; }
    .col-right-bottom { display: flex; gap: 20px; flex-shrink: 0; }
    .col-right-bottom > .panel { flex: 1; }

    .panel { background: rgba(17,21,32,0.85); border: 1px solid var(--border); border-radius: 0; overflow: hidden; position: relative; backdrop-filter: blur(10px); }
    .panel::before { content: ''; position: absolute; top: 0; left: 0; width: 12px; height: 12px; border-top: 2px solid var(--accent-dim); border-left: 2px solid var(--accent-dim); opacity: 0; transition: opacity 0.3s; pointer-events: none; z-index: 1; }
    .panel::after { content: ''; position: absolute; bottom: 0; right: 0; width: 12px; height: 12px; border-bottom: 2px solid var(--accent-dim); border-right: 2px solid var(--accent-dim); opacity: 0; transition: opacity 0.3s; pointer-events: none; z-index: 1; }
    .panel:hover::before, .panel:hover::after { opacity: 0.6; }
    .panel-header { font-family: 'Orbitron', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 4px; text-transform: uppercase; color: var(--text-dim); padding: 14px 20px; border-bottom: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; position: relative; background: linear-gradient(90deg, rgba(247,165,28,0.04) 0%, transparent 60%); flex-shrink: 0; }
    .panel-header::after { content: ''; position: absolute; bottom: -1px; left: 0; width: 60px; height: 1px; background: linear-gradient(90deg, var(--accent-dim), transparent); }
    .panel-header .count { color: var(--accent); font-size: 12px; font-family: 'JetBrains Mono', monospace; padding: 2px 8px; border: 1px solid rgba(247,165,28,0.2); background: rgba(247,165,28,0.05); }
    .panel-body { padding: 20px; }

    /* Login — visibility controlled by inline <style> in <head> for instant first-paint. These are backup rules. */
    html.logged-in #login-screen { display: none !important; }
    html.logged-in #main-ui { display: flex; }
    html:not(.logged-in) #login-screen { display: flex !important; }
    html:not(.logged-in) #main-ui { display: none !important; }
    #login-screen { position: fixed; inset: 0; background: var(--bg-dark); display: none; align-items: center; justify-content: center; z-index: 100; flex-direction: column; }
    #login-screen h2 { font-family: 'Orbitron', sans-serif; font-size: 56px; font-weight: 900; color: var(--accent); letter-spacing: 10px; margin-bottom: 8px; text-shadow: 0 0 20px var(--accent), 0 0 40px var(--accent-glow-strong), 0 0 60px var(--accent-glow); animation: pulseGlowText 3s ease-in-out infinite; }
    #login-screen p { color: var(--text-dim); font-size: 13px; font-family: 'JetBrains Mono', monospace; margin-bottom: 40px; letter-spacing: 3px; text-transform: uppercase; }
    #login-screen p::after { content: '█'; animation: blink 1s step-end infinite; color: var(--accent); margin-left: 4px; }
    .steam-login-btn { display: flex; align-items: center; gap: 12px; background: var(--steam); border: 1px solid #2a475e; border-radius: 0; padding: 18px 36px; color: #c7d5e0; font-family: 'Orbitron', sans-serif; font-weight: 700; font-size: 16px; letter-spacing: 2px; cursor: pointer; text-decoration: none; transition: all 0.3s; position: relative; overflow: hidden; }
    .steam-login-btn::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.05), transparent); transition: left 0.5s; }
    .steam-login-btn:hover::before { left: 100%; }
    .steam-login-btn:hover { background: var(--steam-hover); border-color: #66c0f4; color: #fff; box-shadow: 0 4px 20px rgba(102,192,244,0.2); transform: translateY(-2px); }
    .steam-login-btn svg { width: 28px; height: 28px; fill: #c7d5e0; }
    .steam-login-btn:hover svg { fill: #fff; }
    .login-footer { position: absolute; bottom: 20px; left: 0; right: 0; }
    .main-footer { flex-shrink: 0; }

    #ban-screen { position: fixed; inset: 0; background: var(--bg-dark); display: none; align-items: center; justify-content: center; z-index: 100; flex-direction: column; }
    #ban-screen h2 { font-family: 'Orbitron', sans-serif; font-weight: 900; font-size: 36px; color: var(--danger); letter-spacing: 6px; margin-bottom: 16px; text-shadow: 0 0 15px rgba(224,74,74,0.5); }
    #ban-screen .ban-reason { color: var(--text-dim); font-size: 16px; margin-bottom: 8px; }
    #ban-screen .ban-info { color: var(--text-dim); font-size: 13px; font-family: 'JetBrains Mono', monospace; }

    .btn { font-family: 'Orbitron', sans-serif; font-weight: 700; font-size: 13px; letter-spacing: 2px; text-transform: uppercase; padding: 12px 24px; border: 1px solid; border-radius: 0; cursor: pointer; transition: all 0.2s; outline: none; position: relative; overflow: hidden; }
    .btn::before { content: ''; position: absolute; inset: 0; opacity: 0; transition: opacity 0.2s; }
    .btn:hover::before { opacity: 1; }
    .btn:active { transform: scale(0.98); }
    .btn-primary { background: transparent; border-color: var(--accent); color: var(--accent); }
    .btn-primary::before { background: var(--accent-glow); }
    .btn-primary:hover { box-shadow: 0 0 12px var(--accent-glow), 0 0 4px var(--accent-glow); text-shadow: 0 0 8px var(--accent-glow-strong); }
    .btn-primary:disabled { border-color: #b8791a; color: #b8791a; cursor: not-allowed; opacity: 0.5; box-shadow: none; text-shadow: none; }
    .btn-primary:disabled::before { display: none; }
    .btn-danger { background: transparent; border-color: var(--danger); color: var(--danger); }
    .btn-danger::before { background: rgba(224,74,74,0.1); }
    .btn-danger:hover { box-shadow: 0 0 12px rgba(224,74,74,0.2); text-shadow: 0 0 8px rgba(224,74,74,0.3); }
    .btn-secondary { background: transparent; border-color: var(--border); color: var(--text-dim); }
    .btn-secondary::before { background: rgba(107,122,152,0.08); }
    .btn-secondary:hover { border-color: var(--text-dim); color: var(--text); }
    .btn-store { background: rgba(247,165,28,0.04); border-color: var(--accent); color: var(--accent); animation: storePulse 2.5s ease-in-out infinite; text-shadow: 0 0 6px rgba(247,165,28,0.3); }
    .btn-store::before { background: var(--accent-glow); }
    .btn-store:hover { box-shadow: inset 0 0 30px rgba(247,165,28,0.2), 0 0 30px rgba(247,165,28,0.4), 0 0 60px rgba(247,165,28,0.15), 0 0 8px rgba(247,165,28,0.3); text-shadow: 0 0 12px rgba(247,165,28,0.5); border-color: var(--accent-bright); animation: none; }
    @keyframes storePulse { 0%,100% { box-shadow: inset 0 0 15px rgba(247,165,28,0.06), 0 0 8px rgba(247,165,28,0.1), 0 0 2px rgba(247,165,28,0.05); text-shadow: 0 0 4px rgba(247,165,28,0.2); } 50% { box-shadow: inset 0 0 35px rgba(247,165,28,0.18), 0 0 25px rgba(247,165,28,0.25), 0 0 50px rgba(247,165,28,0.1), 0 0 6px rgba(247,165,28,0.2); text-shadow: 0 0 10px rgba(247,165,28,0.5); } }
    .btn-loadout { background: transparent; border-color: rgba(0,212,255,0.35); color: var(--accent-2); }
    .btn-loadout::before { background: var(--accent-2-glow); }
    .btn-loadout:hover { border-color: var(--accent-2); box-shadow: 0 0 12px var(--accent-2-glow), 0 0 4px var(--accent-2-glow); text-shadow: 0 0 8px rgba(0,212,255,0.3); }
    .btn-sm { padding: 4px 10px; font-size: 9px; letter-spacing: 1px; }

    .matchmaking-area { text-align: center; padding: 60px 20px; position: relative; }
    .matchmaking-area::before { content: ''; position: absolute; top: 50%; left: 50%; width: 200px; height: 200px; transform: translate(-50%, -50%); background: radial-gradient(circle, var(--accent-glow) 0%, transparent 70%); opacity: 0.3; pointer-events: none; }
    .matchmaking-area .btn { font-size: 18px; padding: 18px 60px; position: relative; z-index: 1; }
    .queue-status { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--queue); margin-top: 16px; letter-spacing: 1px; }
    .searching-indicator { display: inline-flex; align-items: center; gap: 10px; }
    .pulse-ring { width: 12px; height: 12px; border-radius: 50%; background: var(--queue); position: relative; box-shadow: 0 0 6px var(--queue); }
    .pulse-ring::before { content: ''; position: absolute; inset: -6px; border-radius: 50%; border: 2px solid var(--queue); animation: pulse 1.5s ease-out infinite; }
    .pulse-ring::after { content: ''; position: absolute; inset: -10px; border-radius: 50%; border: 1px solid var(--queue); animation: pulse 1.5s ease-out 0.4s infinite; opacity: 0.5; }
    @keyframes pulse { 0% { transform: scale(0.8); opacity: 1; } 100% { transform: scale(2); opacity: 0; } }

    .dots-anim::after { content: '...'; display: inline-block; width: 0; overflow: hidden; vertical-align: bottom; animation: dotsWidth 1.5s steps(4, end) infinite; }
    @keyframes dotsWidth { 0% { width: 0; } 100% { width: 3ch; } }

    .empty-msg { color: var(--text-dim); font-size: 14px; text-align: center; padding: 30px; letter-spacing: 1px; }

    /* Match panel */
    #match-panel { display: none; border-color: var(--accent); box-shadow: 0 0 30px var(--accent-glow), 0 0 60px var(--accent-glow); }
    #match-panel.visible { display: block; animation: scaleIn 0.4s cubic-bezier(0.34,1.56,0.64,1) both; }
    .match-info { text-align: center; padding: 30px 20px; }
    .match-vs { font-family: 'Orbitron', sans-serif; font-size: 18px; font-weight: 700; color: var(--text-bright); margin-bottom: 20px; letter-spacing: 2px; display: flex; align-items: center; justify-content: center; gap: 20px; }
    .match-vs img { width: 44px; height: 44px; border-radius: 0; border: 2px solid var(--accent); box-shadow: 0 0 10px var(--accent-glow); }
    .match-vs .vs { color: var(--accent); font-size: 18px; font-family: 'Orbitron', sans-serif; font-weight: 900; animation: pulseGlowText 2s ease-in-out infinite; }
    .connect-box { background: rgba(10,12,16,0.7); border: 1px solid rgba(247,165,28,0.5); border-radius: 0; padding: 20px; margin: 20px 0; position: relative; animation: connectGlow 3s ease-in-out infinite; }
    .connect-box::after { content: '\2588'; position: absolute; bottom: 12px; right: 16px; color: var(--accent); font-size: 10px; animation: blink 1s step-end infinite; }
    .connect-label { font-family: 'Orbitron', sans-serif; font-size: 10px; font-weight: 600; color: var(--text); letter-spacing: 3px; text-transform: uppercase; margin-bottom: 10px; }
    .connect-command { font-family: 'JetBrains Mono', monospace; font-size: 20px; color: var(--accent-bright); cursor: pointer; user-select: all; word-break: break-all; text-shadow: 0 0 10px var(--accent-glow-strong), 0 0 20px var(--accent-glow); }
    .connect-command:hover { color: #ffcb60; text-shadow: 0 0 12px var(--accent-glow-strong), 0 0 24px var(--accent-glow-strong); }
    .copy-hint { font-size: 12px; color: var(--text-dim); margin-top: 8px; }
    @keyframes connectGlow { 0%,100% { border-color: rgba(247,165,28,0.35); box-shadow: 0 0 8px rgba(247,165,28,0.05), inset 0 0 12px rgba(247,165,28,0.03); } 50% { border-color: rgba(247,165,28,0.7); box-shadow: 0 0 16px rgba(247,165,28,0.12), inset 0 0 20px rgba(247,165,28,0.06); } }
    .match-status-msg { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--text-dim); letter-spacing: 1px; margin-top: 16px; }
    .match-status-msg.ready { color: var(--success); }
    .match-status-msg.error { color: var(--danger); }

    #result-panel { display: none; }
    #result-panel.visible { display: block; animation: scaleIn 0.4s cubic-bezier(0.34,1.56,0.64,1) both; }
    .result-card { text-align: center; padding: 30px 20px; }
    .result-title { font-family: 'Orbitron', sans-serif; font-size: 12px; font-weight: 700; color: var(--text-dim); letter-spacing: 4px; text-transform: uppercase; margin-bottom: 24px; }
    .result-scoreboard { display: flex; justify-content: center; align-items: center; gap: 30px; margin-bottom: 24px; }
    .result-player { text-align: center; }
    .result-player img { width: 48px; height: 48px; border-radius: 0; margin-bottom: 8px; border: 2px solid var(--border); }
    .result-player .name { font-size: 18px; font-weight: 700; color: var(--text-bright); margin-bottom: 4px; }
    .result-player .team-tag { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 2px; color: var(--text-dim); }
    .result-player.winner .name { color: var(--success); }
    .result-player.winner img { border-color: var(--success); box-shadow: 0 0 10px rgba(74,224,94,0.3); }
    .result-player.loser .name { color: var(--danger); }
    .result-player.loser img { border-color: var(--danger); box-shadow: 0 0 10px rgba(224,74,74,0.2); }
    .result-score { font-family: 'Orbitron', sans-serif; font-size: 48px; font-weight: 900; color: var(--text-bright); letter-spacing: 4px; }
    .result-score .sep { color: var(--text-dim); margin: 0 6px; }
    .result-meta { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-dim); }
    .result-rating-changes { margin-top: 16px; display: flex; flex-direction: column; gap: 8px; }
    .result-rating-row { display: flex; align-items: center; justify-content: center; gap: 12px; font-family: 'JetBrains Mono', monospace; font-size: 13px; }
    .result-rating-name { color: var(--text); min-width: 80px; text-align: right; }
    .fh-rank-change { font-family: 'JetBrains Mono', monospace; font-weight: 700; min-width: 40px; text-align: center; }
    .fh-rank-change.positive { color: var(--success); text-shadow: 0 0 8px rgba(74,224,94,0.3); }
    .fh-rank-change.negative { color: var(--danger); text-shadow: 0 0 8px rgba(224,74,74,0.3); }
    .result-rating-val { color: var(--text-bright); font-weight: 700; min-width: 40px; }
    .result-rating-progress { width: 120px; height: 4px; background: var(--bg-dark); border-radius: 2px; overflow: hidden; }
    .result-rating-progress-bar { height: 100%; border-radius: 2px; }
    .result-actions { margin-top: 24px; }


    /* ─── Mode Selector ─── */
    .mode-selector { display: flex; gap: 8px; margin-bottom: 16px; justify-content: center; }
    .mode-btn { font-family: 'Orbitron', sans-serif; font-size: 12px; font-weight: 700; letter-spacing: 2px; padding: 10px 24px; border: 1px solid var(--border); background: transparent; color: var(--text-dim); cursor: pointer; transition: all 0.2s; text-transform: uppercase; }
    .mode-btn:hover { border-color: var(--accent-dim); color: var(--text); background: rgba(247,165,28,0.05); }
    .mode-btn.active { border-color: var(--accent); color: var(--accent); background: rgba(247,165,28,0.1); box-shadow: 0 0 10px var(--accent-glow), inset 0 0 10px var(--accent-glow); }
    .mode-btn.disabled { opacity: 0.3; pointer-events: none; filter: grayscale(1); }
    .queue-options { display: flex; gap: 12px; align-items: center; justify-content: center; }
    .queue-type-choice { display: none; flex-direction: column; gap: 10px; align-items: center; width: 100%; margin-top: 8px; animation: scaleIn 0.2s ease both; }
    .queue-type-choice.visible { display: flex; }
    .queue-type-choice .queue-type-label { font-family: 'Orbitron', sans-serif; font-size: 10px; letter-spacing: 2px; color: var(--text-dim); text-transform: uppercase; margin-bottom: 2px; }
    .queue-type-btns { display: flex; gap: 10px; justify-content: center; width: 100%; }
    .queue-type-btns .btn { flex: 1; max-width: 180px; font-size: 11px; padding: 10px 16px; }
    .queue-type-btns .btn .btn-sub { display: block; font-size: 9px; color: var(--text-dim); font-weight: 400; margin-top: 2px; letter-spacing: 0; text-transform: none; }

    /* ─── Map Vote Panel ─── */
    #map-vote-panel { display: none; border-color: var(--accent-2); box-shadow: 0 0 30px var(--accent-2-glow), 0 0 60px var(--accent-2-glow); }
    #map-vote-panel.visible { display: block; animation: scaleIn 0.4s cubic-bezier(0.34,1.56,0.64,1) both; }
    .map-vote-header { text-align: center; margin-bottom: 20px; }
    .map-vote-header h3 { font-family: 'Orbitron', sans-serif; font-size: 14px; font-weight: 700; color: var(--accent-2); letter-spacing: 4px; text-transform: uppercase; margin-bottom: 8px; }
    .map-vote-teams { display: flex; justify-content: space-between; margin-bottom: 16px; font-family: 'JetBrains Mono', monospace; font-size: 11px; }
    .map-vote-team { padding: 8px 12px; border: 1px solid var(--border); }
    .map-vote-team.your-turn { border-color: var(--accent-2); color: var(--accent-2); box-shadow: 0 0 8px var(--accent-2-glow); }
    .map-vote-team.opponent-turn { color: var(--text-dim); }
    .map-vote-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; margin-bottom: 20px; }
    .map-card { position: relative; border: 1px solid var(--border); background: var(--bg-elevated); cursor: pointer; overflow: hidden; transition: all 0.2s; }
    .map-card:hover { border-color: var(--accent-2); box-shadow: 0 0 10px var(--accent-2-glow); }
    .map-card.banned { opacity: 0.3; pointer-events: none; }
    .map-card.banned::after { content: 'BANNED'; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(10,12,16,0.7); font-family: 'Orbitron', sans-serif; font-size: 12px; font-weight: 700; color: var(--danger); letter-spacing: 3px; }
    .map-card.selected { border-color: var(--success); box-shadow: 0 0 15px rgba(74,224,94,0.3); }
    .map-card.selected::after { content: 'SELECTED'; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(74,224,94,0.15); font-family: 'Orbitron', sans-serif; font-size: 12px; font-weight: 700; color: var(--success); letter-spacing: 3px; }
    .map-card-img { width: 100%; height: 90px; object-fit: cover; display: block; border-bottom: 1px solid var(--border); }
    .map-card-name { padding: 8px 10px; font-family: 'JetBrains Mono', monospace; font-size: 11px; font-weight: 600; color: var(--text); letter-spacing: 1px; text-align: center; }
    .vote-timer { text-align: center; font-family: 'Orbitron', sans-serif; font-size: 24px; font-weight: 700; color: var(--accent-2); margin-bottom: 8px; }
    .vote-status { text-align: center; font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-dim); letter-spacing: 1px; }

    /* ─── Team Match Panel (multi-player) ─── */
    .match-teams { display: flex; align-items: flex-start; justify-content: center; gap: 30px; margin-bottom: 24px; }
    .match-team { display: flex; flex-direction: column; gap: 8px; min-width: 140px; }
    .match-team-label { font-family: 'Orbitron', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--text-dim); text-align: center; margin-bottom: 4px; }
    .match-team-player { display: flex; align-items: center; gap: 8px; padding: 6px 10px; border: 1px solid var(--border); background: rgba(17,21,32,0.4); }
    .match-team-player img { width: 28px; height: 28px; border: 1px solid var(--border); }
    .match-team-player .name { font-size: 12px; font-weight: 600; color: var(--text); }
    .match-team-player.captain .name::after { content: ' ★'; color: var(--accent); font-size: 10px; }
    .match-map { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--text-dim); text-align: center; margin-bottom: 12px; }
    .match-map strong { color: var(--accent); }

    /* ─── Team Result Panel ─── */
    .result-teams { display: flex; gap: 30px; justify-content: center; margin-bottom: 24px; }
    .result-team { min-width: 200px; }
    .result-team-header { font-family: 'Orbitron', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 12px; text-align: center; }
    .result-team-header.winner { color: var(--success); }
    .result-team-header.loser { color: var(--danger); }
    .result-team-player { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border: 1px solid var(--border); margin-bottom: 4px; font-family: 'JetBrains Mono', monospace; font-size: 11px; }
    .result-team-player img { width: 24px; height: 24px; border: 1px solid var(--border); }
    .result-team-player .name { flex: 1; color: var(--text); font-weight: 600; }
    .result-team-player .stats { color: var(--text-dim); font-size: 10px; }
    .result-team-player .rating-change { font-weight: 700; min-width: 40px; text-align: right; }
    .result-team-player .rating-change.positive { color: var(--success); }
    .result-team-player .rating-change.negative { color: var(--danger); }

    /* ─── Team Invite Alert ─── */
    .team-invite-alert { position: fixed; top: 80px; right: 20px; z-index: 1000; background: rgba(17,21,32,0.95); border: 2px solid var(--accent-2); box-shadow: 0 0 30px var(--accent-2-glow), 0 0 60px var(--accent-2-glow); padding: 20px; min-width: 300px; max-width: 400px; backdrop-filter: blur(12px); animation: slideInRight 0.4s cubic-bezier(0.34,1.56,0.64,1) both; }
    .team-invite-alert .invite-title { font-family: 'Orbitron', sans-serif; font-size: 11px; font-weight: 700; color: var(--accent-2); letter-spacing: 3px; text-transform: uppercase; margin-bottom: 8px; }
    .team-invite-alert .invite-msg { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--text); margin-bottom: 16px; line-height: 1.5; }
    .team-invite-alert .invite-timer { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); margin-bottom: 12px; }
    .team-invite-alert .invite-actions { display: flex; gap: 10px; }

    /* Team Gathering */
    .team-gathering { text-align: center; padding: 8px 0; }
    .team-gathering-title { font-family: 'Orbitron', sans-serif; font-size: 11px; font-weight: 700; color: var(--accent-2); letter-spacing: 3px; text-transform: uppercase; margin-bottom: 16px; }
    .team-gathering-list { display: flex; flex-direction: column; gap: 6px; max-width: 280px; margin: 0 auto; }
    .team-member-row { display: flex; align-items: center; justify-content: space-between; padding: 8px 12px; border: 1px solid var(--border); background: rgba(255,255,255,0.02); }
    .team-member-name { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-bright); font-weight: 600; }
    .team-member-status { font-family: 'Orbitron', sans-serif; font-size: 9px; font-weight: 700; letter-spacing: 2px; padding: 2px 8px; }
    .team-member-status.accepted { color: var(--success); border: 1px solid rgba(74,224,94,0.3); background: rgba(74,224,94,0.08); }
    .team-member-status.pending { color: var(--accent-2); border: 1px solid rgba(0,212,255,0.3); background: rgba(0,212,255,0.08); animation: pulse 2s ease-in-out infinite; }
    .team-member-status.declined { color: var(--danger); border: 1px solid rgba(224,74,74,0.3); background: rgba(224,74,74,0.08); }

    /* Chat */
    .chat-body { padding: 0 !important; display: flex; flex-direction: column; flex: 1; min-height: 0; overflow: hidden; }
    .chat-messages { flex: 1; min-height: 0; overflow-y: auto; padding: 12px 16px; display: flex; flex-direction: column; gap: 4px; }
    .chat-input-bar { flex-shrink: 0; }
    .chat-msg { display: flex; gap: 8px; align-items: flex-start; }
    .chat-msg img { width: 20px; height: 20px; border-radius: 0; margin-top: 3px; flex-shrink: 0; }
    .chat-msg-body { min-width: 0; }
    .chat-msg-hdr { display: flex; align-items: baseline; gap: 6px; }
    .chat-msg-name { font-weight: 600; font-size: 13px; color: var(--text-bright); cursor: pointer; font-family: 'Orbitron', sans-serif; font-size: 11px; transition: text-shadow 0.2s; }
    .chat-msg-name:hover { text-decoration: underline; text-shadow: 0 0 8px var(--accent-glow-strong); }
    .chat-msg-time { font-family: 'JetBrains Mono', monospace; font-size: 9px; color: var(--text-dim); }
    .chat-msg-text { font-size: 14px; color: var(--text); word-break: break-word; margin-top: 1px; }
    .chat-input-bar { display: flex; gap: 8px; padding: 10px 16px; border-top: 1px solid var(--border); background: rgba(10,12,16,0.6); backdrop-filter: blur(6px); }
    .chat-input-bar input { flex: 1; padding: 8px 12px; background: var(--bg-panel); border: 1px solid var(--border); border-radius: 0; color: var(--text); font-family: 'JetBrains Mono', monospace; font-size: 13px; outline: none; transition: border-color 0.2s, box-shadow 0.2s; }
    .chat-input-bar input:focus { border-color: var(--accent); box-shadow: 0 0 8px var(--accent-glow); }
    .chat-input-bar input::placeholder { color: var(--text-dim); }
    .chat-input-bar button { padding: 8px 16px; background: transparent; border: 1px solid var(--accent); border-radius: 0; color: var(--accent); font-family: 'Orbitron', sans-serif; font-weight: 700; font-size: 10px; letter-spacing: 1px; cursor: pointer; text-transform: uppercase; transition: all 0.2s; }
    .chat-input-bar button:hover { background: var(--accent-glow); }
    .chat-no-user { padding: 12px; text-align: center; color: var(--text-dim); font-size: 12px; border-top: 1px solid var(--border); }
    .chat-notice { padding: 8px 12px; background: rgba(224,74,74,0.1); border: 1px solid rgba(224,74,74,0.3); border-radius: 0; color: var(--danger); font-size: 12px; margin: 6px 8px; animation: fadeNotice 6s forwards; }
    @keyframes fadeNotice { 0%,80% { opacity: 1; } 100% { opacity: 0; } }
    .chat-mute-banner { padding: 8px 12px; background: rgba(224,74,74,0.12); border: 1px solid rgba(224,74,74,0.3); border-radius: 0; color: var(--danger); font-size: 12px; margin: 6px 8px; text-align: center; }

    /* Player Card Drawer (for all users) */
    .pc-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.4); backdrop-filter: blur(4px); z-index: 190; display: none; }
    .pc-overlay.open { display: block; }
    .pc-drawer { position: fixed; top: 0; right: -480px; width: 480px; height: 100vh; background: rgba(17,21,32,0.95); backdrop-filter: blur(12px); border-left: 1px solid var(--border); z-index: 191; transition: right 0.3s cubic-bezier(0.25,0.46,0.45,0.94); overflow-y: auto; box-shadow: -10px 0 40px rgba(0,0,0,0.5); }
    .pc-drawer.open { right: 0; }
    .pc-hdr { padding: 16px 20px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; position: sticky; top: 0; background: rgba(17,21,32,0.95); backdrop-filter: blur(12px); z-index: 1; }
    .pc-hdr span { font-family: 'Orbitron', sans-serif; font-size: 11px; font-weight: 700; color: var(--text-dim); letter-spacing: 3px; text-transform: uppercase; }
    .pc-close { background: none; border: none; color: var(--text-dim); font-size: 24px; cursor: pointer; padding: 4px 8px; }
    .pc-close:hover { color: var(--text); }

    /* Inbox overlay */
    .inbox-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); backdrop-filter: blur(6px); z-index: 180; display: none; align-items: center; justify-content: center; }
    .inbox-overlay.visible { display: flex; }
    .inbox-panel { background: rgba(17,21,32,0.95); border: 1px solid var(--border); border-radius: 0; width: 600px; max-width: 95vw; height: 500px; max-height: 80vh; display: flex; flex-direction: column; position: relative; animation: scaleIn 0.3s cubic-bezier(0.34,1.56,0.64,1) both; }
    .inbox-panel::before { content: ''; position: absolute; top: 0; left: 0; width: 14px; height: 14px; border-top: 2px solid var(--accent-dim); border-left: 2px solid var(--accent-dim); pointer-events: none; z-index: 1; }
    .inbox-panel::after { content: ''; position: absolute; bottom: 0; right: 0; width: 14px; height: 14px; border-bottom: 2px solid var(--accent-dim); border-right: 2px solid var(--accent-dim); pointer-events: none; z-index: 1; }
    .inbox-header { padding: 14px 20px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
    .inbox-header h3 { font-family: 'Orbitron', sans-serif; font-size: 12px; font-weight: 700; letter-spacing: 3px; color: var(--text-dim); text-transform: uppercase; }
    .inbox-back { background: none; border: none; color: var(--text-dim); font-size: 13px; cursor: pointer; font-family: 'JetBrains Mono', monospace; letter-spacing: 1px; }
    .inbox-back:hover { color: var(--accent); }
    .inbox-body { flex: 1; overflow-y: auto; }
    .conv-item { display: flex; gap: 12px; align-items: center; padding: 12px 20px; border-bottom: 1px solid rgba(30,39,64,0.3); cursor: pointer; transition: background 0.15s; }
    .conv-item:hover { background: var(--bg-panel-hover); }
    .conv-item img { width: 36px; height: 36px; border-radius: 0; border: 1px solid var(--border); }
    .conv-item .ci-info { flex: 1; min-width: 0; }
    .conv-item .ci-name { font-weight: 600; font-size: 14px; color: var(--text-bright); }
    .conv-item .ci-preview { font-size: 12px; color: var(--text-dim); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px; }
    .conv-item .ci-time { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-dim); }
    .conv-unread { min-width: 18px; height: 18px; border-radius: 9px; background: var(--accent); color: var(--bg-dark); font-size: 10px; font-weight: 700; line-height: 18px; text-align: center; padding: 0 4px; }
    .msg-list { padding: 16px; display: flex; flex-direction: column; gap: 8px; }
    .dm-msg { display: flex; gap: 8px; align-items: flex-start; }
    .dm-msg.mine { flex-direction: row-reverse; }
    .dm-msg img { width: 24px; height: 24px; border-radius: 0; flex-shrink: 0; }
    .dm-bubble { max-width: 70%; padding: 8px 12px; border-radius: 0; background: var(--bg-dark); border: 1px solid var(--border); }
    .dm-msg.mine .dm-bubble { background: rgba(247,165,28,0.08); border-color: rgba(247,165,28,0.3); }
    .dm-bubble .dm-name { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-dim); margin-bottom: 2px; }
    .dm-bubble .dm-text { font-size: 13px; color: var(--text); word-break: break-word; }
    .dm-bubble .dm-time { font-family: 'JetBrains Mono', monospace; font-size: 9px; color: var(--text-dim); margin-top: 4px; }
    .dm-bubble.fraghub-msg { border-color: rgba(247,165,28,0.4); background: rgba(247,165,28,0.06); }
    .inbox-compose { display: flex; gap: 8px; padding: 12px 20px; border-top: 1px solid var(--border); }
    .inbox-compose input { flex: 1; padding: 8px 12px; background: var(--bg-dark); border: 1px solid var(--border); border-radius: 0; color: var(--text); font-family: 'JetBrains Mono', monospace; font-size: 13px; outline: none; }
    .inbox-compose input:focus { border-color: var(--accent); }
    .inbox-compose button { padding: 8px 16px; background: transparent; border: 1px solid var(--accent); border-radius: 0; color: var(--accent); font-family: 'Orbitron', sans-serif; font-weight: 700; font-size: 10px; cursor: pointer; letter-spacing: 1px; transition: all 0.2s; }
    .inbox-compose button:hover { background: var(--accent-glow); }
    .inbox-compose select { padding: 8px; background: var(--bg-dark); border: 1px solid var(--border); border-radius: 0; color: var(--text); font-size: 12px; cursor: pointer; font-family: 'JetBrains Mono', monospace; }
    .inbox-compose select option { background: var(--bg-dark); }
    .fraghub-avatar { width: 36px; height: 36px; border-radius: 0; border: 1px solid var(--accent); background: var(--bg-dark); display: flex; align-items: center; justify-content: center; font-family: 'Orbitron', sans-serif; font-size: 12px; color: var(--accent); font-weight: 700; flex-shrink: 0; }

    .spinner { display: inline-block; width: 16px; height: 16px; border: 2px solid var(--border); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.6s linear infinite; }
    @keyframes spin { to { transform: rotate(360deg); } }

    /* Chat context menu */
    .chat-ctx { position: fixed; z-index: 250; background: rgba(17,21,32,0.95); backdrop-filter: blur(10px); border: 1px solid var(--border); border-radius: 0; min-width: 180px; box-shadow: 0 8px 30px rgba(0,0,0,0.5); display: none; overflow: hidden; }
    .chat-ctx.visible { display: block; }
    .chat-ctx-item { display: flex; align-items: center; gap: 8px; padding: 10px 16px; font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 500; color: var(--text); cursor: pointer; transition: background 0.12s; letter-spacing: 0.5px; border: none; background: none; width: 100%; text-align: left; }
    .chat-ctx-item:hover { background: var(--bg-panel-hover); }
    .chat-ctx-item.ctx-delete { color: var(--text); }
    .chat-ctx-item.ctx-warn { color: #e0a64a; }
    .chat-ctx-item.ctx-mute { color: var(--queue); }
    .chat-ctx-item.ctx-kick { color: var(--accent); }
    .chat-ctx-item.ctx-ban { color: var(--danger); }
    .chat-ctx-sep { height: 1px; background: var(--border); margin: 2px 0; }
    .chat-msg-text.deleted-msg { color: var(--text-dim); font-style: italic; }

    /* Warning overlay */
    #warning-screen { position: fixed; inset: 0; background: rgba(0,0,0,0.85); z-index: 300; display: none; align-items: center; justify-content: center; }
    #warning-screen.visible { display: flex; }
    .warning-box { background: rgba(17,21,32,0.95); backdrop-filter: blur(12px); border: 2px solid #e0a64a; border-radius: 0; padding: 40px; max-width: 480px; width: 90%; text-align: center; animation: scaleIn 0.3s cubic-bezier(0.34,1.56,0.64,1) both; }
    .warning-box h2 { font-family: 'Orbitron', sans-serif; font-weight: 900; font-size: 24px; color: #e0a64a; letter-spacing: 6px; margin-bottom: 20px; text-shadow: 0 0 12px rgba(224,166,74,0.4); }
    .warning-box .warning-reason { color: var(--text); font-size: 15px; margin-bottom: 8px; line-height: 1.5; }
    .warning-box .warning-meta { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); margin-bottom: 24px; }
    .warning-box button { padding: 14px 32px; background: transparent; border: 1px solid #e0a64a; border-radius: 0; color: #e0a64a; font-family: 'Orbitron', sans-serif; font-weight: 700; font-size: 13px; letter-spacing: 2px; text-transform: uppercase; cursor: pointer; transition: all 0.2s; }
    .warning-box button:hover { background: rgba(224,166,74,0.1); box-shadow: 0 0 12px rgba(224,166,74,0.15); }

    ::-webkit-scrollbar { width: 6px; }
    ::-webkit-scrollbar-track { background: var(--bg-dark); }
    ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, var(--accent-dim), var(--accent)); border-radius: 0; }
    ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, var(--accent), var(--accent-bright)); box-shadow: 0 0 6px var(--accent-glow); }
    * { scrollbar-color: var(--accent-dim) var(--bg-dark); scrollbar-width: thin; }

    /* Friends & Teams tabs */
    .friends-tabs { display: flex; border-bottom: 1px solid var(--border); }
    .friends-tab { flex: 1; padding: 10px 16px; background: none; border: none; border-bottom: 2px solid transparent; color: var(--text-dim); font-family: 'Orbitron', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; cursor: pointer; transition: all 0.15s; }
    .friends-tab:hover { color: var(--text); background: var(--bg-panel-hover); }
    .friends-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
    .friends-tab .tab-badge { display: none; min-width: 16px; height: 16px; border-radius: 8px; background: var(--danger); color: #fff; font-size: 9px; line-height: 16px; text-align: center; padding: 0 4px; margin-left: 6px; font-family: 'JetBrains Mono', monospace; }
    .friends-tab .tab-badge.visible { display: inline-block; }
    .friends-search { padding: 12px 16px; border-bottom: 1px solid var(--border); }
    .friends-search input { width: 100%; padding: 8px 12px; background: var(--bg-dark); border: 1px solid var(--border); border-radius: 0; color: var(--text); font-family: 'JetBrains Mono', monospace; font-size: 13px; outline: none; }
    .friends-search input:focus { border-color: var(--accent); }
    .friends-search input::placeholder { color: var(--text-dim); }
    .friend-item { display: flex; gap: 12px; align-items: center; padding: 10px 16px; border-bottom: 1px solid rgba(30,39,64,0.3); cursor: pointer; transition: background 0.15s; }
    .friend-item:hover { background: var(--bg-panel-hover); }
    .friend-item img { width: 36px; height: 36px; border-radius: 0; border: 1px solid var(--border); }
    .friend-item .fi-info { flex: 1; min-width: 0; }
    .friend-item .fi-name { font-weight: 600; font-size: 14px; color: var(--text-bright); }
    .friend-item .fi-status { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 1px; text-transform: uppercase; }
    .friend-item .fi-status.online { color: var(--success); }
    .friend-item .fi-status.offline { color: var(--text-dim); }
    .friend-item .fi-actions { display: flex; gap: 6px; }
    .team-item { display: flex; gap: 12px; align-items: center; padding: 12px 16px; border-bottom: 1px solid rgba(30,39,64,0.3); cursor: pointer; transition: background 0.15s; }
    .team-item:hover { background: var(--bg-panel-hover); }
    .team-item .ti-icon { width: 36px; height: 36px; border-radius: 0; border: 1px solid var(--accent); background: var(--bg-dark); display: flex; align-items: center; justify-content: center; font-family: 'Orbitron', sans-serif; font-size: 12px; color: var(--accent); font-weight: 700; flex-shrink: 0; }
    .team-item .ti-info { flex: 1; }
    .team-item .ti-name { font-weight: 600; font-size: 14px; color: var(--text-bright); }
    .team-item .ti-meta { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-dim); letter-spacing: 1px; }
    .pending-section { padding: 12px 16px; background: rgba(247,165,28,0.04); border-bottom: 1px solid rgba(247,165,28,0.15); }
    .pending-section h5 { font-family: 'Orbitron', sans-serif; font-size: 9px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
    .team-member-item { display: flex; gap: 10px; align-items: center; padding: 8px 16px; border-bottom: 1px solid rgba(30,39,64,0.3); }
    .team-member-item img { width: 28px; height: 28px; border-radius: 0; border: 1px solid var(--border); }
    .team-member-item .tm-name { flex: 1; font-size: 14px; font-weight: 500; color: var(--text); cursor: pointer; }
    .team-member-item .tm-name:hover { text-decoration: underline; }
    .team-member-item .tm-leader { font-family: 'JetBrains Mono', monospace; font-size: 9px; font-weight: 600; letter-spacing: 1px; color: var(--accent); border: 1px solid rgba(247,165,28,0.3); border-radius: 0; padding: 2px 6px; }
    .team-queue-item { display: flex; align-items: center; justify-content: space-between; padding: 12px; border: 1px solid var(--border); margin-bottom: 8px; cursor: pointer; transition: all 0.2s; }
    .team-queue-item:hover { border-color: var(--accent-2); }

    /* Bottom floating buttons */
    .bottom-bubbles { position: fixed; bottom: 24px; right: 24px; z-index: 170; display: flex; gap: 10px; align-items: flex-end; }
    .bottom-bubble { position: relative; padding: 10px 18px; background: rgba(17,21,32,0.95); font-family: 'Orbitron', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; cursor: pointer; backdrop-filter: blur(8px); transition: all 0.2s; text-decoration: none; }
    .bottom-bubble::before { content: ''; position: absolute; top: 0; left: 0; width: 8px; height: 8px; pointer-events: none; }
    .bottom-bubble::after { content: ''; position: absolute; bottom: 0; right: 0; width: 8px; height: 8px; pointer-events: none; }
    .admin-bubble { border: 1px solid #dc5050; color: #dc5050; box-shadow: 0 0 12px rgba(220,80,80,0.15), 0 4px 20px rgba(0,0,0,0.4); }
    .admin-bubble::before { border-top: 2px solid #dc5050; border-left: 2px solid #dc5050; }
    .admin-bubble::after { border-bottom: 2px solid #dc5050; border-right: 2px solid #dc5050; }
    .admin-bubble:hover { box-shadow: 0 0 20px rgba(220,80,80,0.2), 0 0 40px rgba(220,80,80,0.1), 0 4px 20px rgba(0,0,0,0.4); text-shadow: 0 0 8px rgba(220,80,80,0.4); text-decoration: none; }
    .test-bubble { border: 1px solid var(--admin); color: var(--admin); box-shadow: 0 0 12px var(--admin-glow), 0 4px 20px rgba(0,0,0,0.4); }
    .test-bubble::before { border-top: 2px solid var(--admin); border-left: 2px solid var(--admin); }
    .test-bubble::after { border-bottom: 2px solid var(--admin); border-right: 2px solid var(--admin); }
    .test-bubble:hover { box-shadow: 0 0 20px var(--admin-glow), 0 0 40px var(--admin-glow), 0 4px 20px rgba(0,0,0,0.4); text-shadow: 0 0 8px var(--admin-glow); }
    .test-popup { position: absolute; bottom: calc(100% + 10px); left: 50%; translate: -50% 0; display: none; flex-direction: column; gap: 4px; background: rgba(17,21,32,0.97); border: 1px solid rgba(168,85,247,0.4); padding: 6px; backdrop-filter: blur(8px); box-shadow: 0 -4px 20px rgba(0,0,0,0.5), 0 0 15px var(--admin-glow); animation: scaleIn 0.2s cubic-bezier(0.34,1.56,0.64,1) both; }
    .test-popup.visible { display: flex; }
    .test-popup-btn { background: transparent; border: 1px solid rgba(168,85,247,0.3); color: var(--admin); font-family: 'Orbitron', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; padding: 8px 20px; cursor: pointer; transition: all 0.15s; white-space: nowrap; }
    .test-popup-btn:hover { background: rgba(168,85,247,0.1); border-color: var(--admin); text-shadow: 0 0 8px var(--admin-glow); box-shadow: 0 0 10px var(--admin-glow); }

    /* Feedback */
    .feedback-bubble { border: 1px solid var(--accent-2); color: var(--accent-2); box-shadow: 0 0 12px var(--accent-2-glow), 0 4px 20px rgba(0,0,0,0.4); }
    .feedback-bubble::before { border-top: 2px solid var(--accent-2); border-left: 2px solid var(--accent-2); }
    .feedback-bubble::after { border-bottom: 2px solid var(--accent-2); border-right: 2px solid var(--accent-2); }
    .feedback-bubble:hover { box-shadow: 0 0 20px var(--accent-2-glow), 0 0 40px var(--accent-2-glow), 0 4px 20px rgba(0,0,0,0.4); text-shadow: 0 0 8px var(--accent-2-glow); }
    .feedback-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); backdrop-filter: blur(6px); z-index: 175; display: none; align-items: center; justify-content: center; }
    .feedback-overlay.visible { display: flex; }
    .feedback-modal { background: rgba(17,21,32,0.95); border: 1px solid var(--border); width: 440px; max-width: 95vw; position: relative; animation: scaleIn 0.3s cubic-bezier(0.34,1.56,0.64,1) both; }
    .feedback-modal::before { content: ''; position: absolute; top: 0; left: 0; width: 14px; height: 14px; border-top: 2px solid var(--accent-2); border-left: 2px solid var(--accent-2); pointer-events: none; z-index: 1; }
    .feedback-modal::after { content: ''; position: absolute; bottom: 0; right: 0; width: 14px; height: 14px; border-bottom: 2px solid var(--accent-2); border-right: 2px solid var(--accent-2); pointer-events: none; z-index: 1; }
    .feedback-modal-header { padding: 16px 20px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; background: linear-gradient(90deg, rgba(0,212,255,0.04) 0%, transparent 60%); }
    .feedback-modal-header h3 { font-family: 'Orbitron', sans-serif; font-size: 12px; font-weight: 700; letter-spacing: 3px; color: var(--accent-2); text-transform: uppercase; }
    .feedback-modal-close { background: none; border: none; color: var(--text-dim); font-size: 20px; cursor: pointer; padding: 2px 6px; }
    .feedback-modal-close:hover { color: var(--text); }
    .feedback-modal-body { padding: 20px; }
    .feedback-modal-body .form-group { margin-bottom: 14px; }
    .feedback-modal-body .form-label { display: block; font-family: 'Orbitron', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--text-dim); margin-bottom: 6px; }
    .feedback-modal-body select, .feedback-modal-body textarea { width: 100%; padding: 8px 12px; background: var(--bg-dark); border: 1px solid var(--border); color: var(--text); font-family: 'JetBrains Mono', monospace; font-size: 13px; outline: none; transition: border-color 0.15s, box-shadow 0.15s; }
    .feedback-modal-body select:focus, .feedback-modal-body textarea:focus { border-color: var(--accent-2); box-shadow: 0 0 8px var(--accent-2-glow); }
    .feedback-modal-body select option { background: var(--bg-dark); }
    .feedback-modal-body textarea { resize: vertical; min-height: 100px; }
    .feedback-modal-footer { display: flex; justify-content: flex-end; gap: 10px; padding: 16px 20px; border-top: 1px solid var(--border); }
    .feedback-warn-overlay { position: fixed; inset: 0; z-index: 180; display: none; align-items: center; justify-content: center; background: rgba(0,0,0,0.5); backdrop-filter: blur(6px); }
    .feedback-warn-overlay.visible { display: flex; }
    .feedback-warn-box { background: var(--bg-panel); border: 1px solid var(--accent); width: 380px; max-width: 90vw; position: relative; animation: scaleIn 0.25s cubic-bezier(0.34,1.56,0.64,1) both; box-shadow: 0 0 20px rgba(247,165,28,0.15), 0 8px 32px rgba(0,0,0,0.6); }
    .feedback-warn-box::before { content: ''; position: absolute; top: 0; left: 0; width: 12px; height: 12px; border-top: 2px solid var(--accent); border-left: 2px solid var(--accent); pointer-events: none; z-index: 1; }
    .feedback-warn-box::after { content: ''; position: absolute; bottom: 0; right: 0; width: 12px; height: 12px; border-bottom: 2px solid var(--accent); border-right: 2px solid var(--accent); pointer-events: none; z-index: 1; }
    .feedback-warn-header { padding: 14px 20px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; background: linear-gradient(90deg, rgba(247,165,28,0.06) 0%, transparent 60%); }
    .feedback-warn-header h3 { font-family: 'Orbitron', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 3px; color: var(--accent); text-transform: uppercase; }
    .feedback-warn-body { padding: 20px; }
    .feedback-warn-body p { font-size: 13px; line-height: 1.6; color: var(--text); margin-bottom: 16px; }
    .feedback-warn-body label { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text-dim); cursor: pointer; }
    .feedback-warn-body input[type="checkbox"] { accent-color: var(--accent); width: 16px; height: 16px; cursor: pointer; }
    .feedback-warn-footer { display: flex; justify-content: flex-end; gap: 10px; padding: 14px 20px; border-top: 1px solid var(--border); }

    /* ─── CSP: Inline-style replacements ─── */
    .login-video { width: 650px; height: 560px; }
    .py-40 { padding: 40px 0; }
    .server-info-header { border-color: rgba(0,212,255,0.3); background: linear-gradient(90deg, rgba(0,212,255,0.04) 0%, transparent 60%); }
    .server-info-tag { color: var(--accent-2); border-color: rgba(0,212,255,0.2); background: rgba(0,212,255,0.05); }
    .server-info-list { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--text-dim); line-height: 2; }
    .nav-btn { width: 100%; margin-bottom: 6px; }
    .nav-btn-lg { width: 100%; margin-bottom: 12px; }
    .nav-link-btn { width: 100%; display: block; text-align: center; text-decoration: none; }

    /* index-page.js CSP inline-style removals */
    .load-error-sub { color: #6b7a98; font-size: 14px; margin-top: 12px; }
    .spinner-wrap-lg { padding: 40px; text-align: center; }
    .spinner-wrap { padding: 30px; text-align: center; }
    .spinner-wrap-sm { padding: 10px; text-align: center; }
    .spinner-wrap-xs { padding: 8px; text-align: center; }
    .section-hdr-dim { padding: 8px 16px; font-size: 12px; color: var(--text-dim); text-transform: uppercase; letter-spacing: 1px; }
    .avatar-round-32 { width: 32px; height: 32px; border-radius: 50%; }
    .avatar-round-28 { width: 28px; height: 28px; border-radius: 50%; }
    .status-dot-online { color: var(--success); }
    .status-dot-offline { color: var(--text-dim); }
    .empty-pad-30 { padding: 30px 0; }
    .search-no-results { padding: 10px 16px; color: var(--text-dim); font-size: 13px; }
    .search-no-results-sm { padding: 8px; color: var(--text-dim); font-size: 13px; }
    .search-failed { padding: 10px 16px; color: var(--danger); font-size: 13px; }
    .search-failed-sm { padding: 8px; color: var(--danger); font-size: 13px; }
    .label-you { color: var(--text-dim); font-size: 12px; }
    .label-friends { color: var(--success); font-size: 12px; }
    .label-pending { color: var(--text-dim); font-size: 12px; }
    .fi-status-dim { color: var(--text-dim); }
    .create-team-row { display: flex; gap: 8px; align-items: center; }
    .create-team-input { flex: 1; padding: 8px 12px; background: var(--surface); border: 1px solid var(--border); color: var(--text); border-radius: 4px; font-size: 13px; }
    .create-team-error { font-size: 12px; color: var(--danger); padding-top: 4px; min-height: 16px; }
    .team-detail-actions { padding: 12px 16px; display: flex; gap: 8px; flex-wrap: wrap; }
    .team-create-area { padding: 12px 16px; }
    .team-invite-wrap { padding: 8px 16px; }
    .team-invite-input { width: 100%; padding: 8px 12px; background: var(--surface); border: 1px solid var(--border); color: var(--text); border-radius: 4px; font-size: 13px; }
    .role-tag-fh { font-family: 'JetBrains Mono', monospace; font-size: 9px; font-weight: 600; color: var(--accent); border: 1px solid rgba(247,165,28,0.3); border-radius: 0; padding: 1px 5px; margin-left: 4px; }
    .conv-time-col { text-align: right; }
    .fraghub-avatar-sm { width: 24px; height: 24px; font-size: 10px; }
    .team-select-title { font-family: 'Orbitron', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--accent-2); margin-bottom: 16px; }
    .tq-team-name { font-weight: 700; color: var(--text-bright); }
    .tq-team-meta { color: var(--text-dim); font-size: 11px; margin-left: 8px; }
    .tq-select-arrow { font-size: 10px; color: var(--accent-2); letter-spacing: 2px; }
    .match-vs-divider { font-family: 'Orbitron', sans-serif; font-size: 18px; font-weight: 900; color: var(--accent); align-self: center; animation: pulseGlowText 2s ease-in-out infinite; }
    .match-vs-live { font-size: 16px; }
    .result-timeout-sub { color: var(--text-dim); margin-bottom: 20px; }
    .result-map { margin-bottom: 16px; }
    .result-score-block { text-align: center; margin-bottom: 20px; }
    .result-meta-block { margin-bottom: 20px; }

    @media (max-width: 1200px) {
      .container { grid-template-columns: 300px 1fr; max-width: 1400px; }
    }
    @media (max-width: 900px) {
      body { height: auto; overflow: auto; }
      #main-ui { height: auto; }
      .container { grid-template-columns: 1fr; grid-template-rows: auto; flex: none; padding: 20px 16px; }
      .col-right { overflow-y: visible; }
      .chat-body { height: 350px; flex: none; }
      .col-chat .panel { flex: none; }
      .connected-label { display: none; }
      .bottom-bubbles { bottom: 16px; right: 16px; gap: 8px; }
      .bottom-bubble { padding: 8px 14px; font-size: 10px; }
    }
    @media (max-width: 768px) {
      .container { padding: 16px; }
      .header { padding: 12px 16px; flex-wrap: wrap; gap: 10px; }
      .header h1 { font-size: 18px; letter-spacing: 4px; }
      .header-subtitle { display: none; }
      .header-right { gap: 8px; }
      .matchmaking-area { padding: 40px 16px; }
      .pc-drawer { width: 100%; right: -100%; }
      .chat-body { height: 300px; flex: none; }
      .col-chat .panel { flex: none; }
      .connected-indicator { padding: 4px 10px; }
      .connected-count { font-size: 12px; }
    }
