*, *::before, *::after { box-sizing: border-box; }
.overlay-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.85); display: flex; align-items: center; justify-content: center; z-index: 9999; backdrop-filter: blur(8px); }
.modal-box { background: var(--panel-main); border: 2px solid var(--primary); padding: 30px; border-radius: 12px; width: 320px; box-shadow: 0 0 30px rgba(88,101,242,0.3); animation: modalIn 0.3s cubic-bezier(0.18, 0.89, 0.32, 1.28); }
@keyframes modalIn { from { transform: scale(0.8); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.modal-box h2 { color: var(--primary); font-size: 20px; margin-bottom: 15px; text-align: center; letter-spacing: 2px; }
.modal-actions { display: flex; gap: 10px; }
.btn-confirm, .btn-cancel { flex: 1; padding: 12px; border: none; border-radius: 6px; font-family: 'Outfit', sans-serif; font-weight: 700; cursor: pointer; transition: 0.2s; font-size: 12px; }
.btn-confirm { background: var(--success); color: white; }
.btn-confirm:hover { background: #2ecc71; transform: translateY(-2px); }
.btn-cancel { background: rgba(255,255,255,0.1); color: var(--text-muted); }
.btn-cancel:hover { background: rgba(255,255,255,0.2); }
:root {
    --bg-color: #36393f;
    --panel-bg: #2f3136;
    --panel-dark: #202225;
    --primary: #5865F2;
    --primary-hover: #4752C4;
    --accent: #ed4245;
    --success: #3ba55d;
    --text-main: #dcddde;
    --text-muted: #72767d;
    --glass-border: #202225;
}
body { margin:0; overflow:hidden; background:var(--bg-color); font-family:'Inter',sans-serif; color:var(--text-main); display:flex; justify-content:center; align-items:center; width:100vw; height:100vh; }
canvas { display:block; width:100%; height:100%; }
.hidden { display:none !important; }

/* SCROLLBAR */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--panel-dark); border-radius:3px; }
::-webkit-scrollbar-thumb { background:#555; border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--primary); }

/* GAME CONTAINER */
#game-container { width:100vw; height:100vh; position:fixed; top:0; left:0; background:var(--bg-color); z-index:10; }

/* LOADER */
#loading-overlay { position:fixed; top:0; left:0; width:100vw; height:100vh; background:rgba(32,34,37,0.8); backdrop-filter:blur(12px); z-index:99999; display:flex; flex-direction:column; align-items:center; justify-content:center; transition:opacity 0.5s,visibility 0.5s; }
#loading-overlay.hidden { opacity:0; visibility:hidden; pointer-events:none; }
#loading-overlay h2 { color:#fff; margin-top:30px; letter-spacing:2px; text-shadow:0 0 10px rgba(255,255,255,0.5); font-family:'Orbitron',sans-serif; }
#loading-overlay p { color:#aaa; margin-top:10px; }
.loader { width:150px; height:150px; border-radius:50%; position:relative; box-shadow:0 0 30px 4px rgba(0,0,0,0.5) inset,0 5px 12px rgba(0,0,0,0.15); overflow:hidden; }
.loader:before,.loader:after { content:""; position:absolute; width:100%; height:100%; border-radius:45%; top:-40%; background-color:#2e2e2e; animation:wave 5s linear infinite; }
.loader:before { border-radius:30%; background:rgba(122,122,122,0.4); }
@keyframes wave { 0%{transform:rotate(0)} 100%{transform:rotate(360deg)} }
@keyframes fadeInBtn { 0%{opacity:0;visibility:hidden} 100%{opacity:1;visibility:visible} }
#manual-enter-btn { margin-top:20px; background:var(--primary); color:white; border:none; padding:12px 24px; border-radius:8px; cursor:pointer; font-family:'Orbitron',sans-serif; font-weight:bold; opacity:0; visibility:hidden; animation:fadeInBtn 0.5s ease forwards; animation-delay:5s; transition:0.2s; }
#manual-enter-btn:hover { background:var(--primary-hover); transform:scale(1.05); }

/* ════════ AUTH SCREEN ════════ */
#auth-screen { position:fixed; top:0; left:0; width:100vw; height:100vh; background:linear-gradient(135deg,#1a1c20 0%,#2f3136 50%,#1a1c20 100%); display:flex; align-items:center; justify-content:center; z-index:500; }
.auth-box { background:rgba(47,49,54,0.95); border:1px solid rgba(88,101,242,0.3); border-radius:16px; padding:40px; width:380px; box-shadow:0 20px 60px rgba(0,0,0,0.6),0 0 40px rgba(88,101,242,0.1); backdrop-filter:blur(20px); }
.auth-box h1 { font-family:'Orbitron',sans-serif; font-size:24px; text-align:center; margin:0 0 6px; color:var(--primary); letter-spacing:3px; }
.auth-slogan { text-align:center; color:var(--text-muted); font-size:13px; font-style:italic; margin-bottom:28px; letter-spacing:1px; }
.auth-tabs { display:flex; margin-bottom:20px; border-bottom:2px solid var(--panel-dark); }
.auth-tab { flex:1; padding:10px; background:none; border:none; color:var(--text-muted); font-family:'Orbitron',sans-serif; font-size:11px; cursor:pointer; letter-spacing:1px; transition:0.2s; border-bottom:2px solid transparent; margin-bottom:-2px; }
.auth-tab.active { color:var(--primary); border-bottom-color:var(--primary); }
.auth-tab:hover { color:var(--text-main); }
.auth-field { width:100%; box-sizing:border-box; background:var(--panel-dark); border:1px solid var(--glass-border); color:var(--text-main); padding:12px 14px; border-radius:8px; font-family:'Inter',sans-serif; font-size:14px; outline:none; margin-bottom:12px; transition:border-color 0.2s; }
.auth-field:focus { border-color:var(--primary); }
.auth-btn { width:100%; padding:13px; background:var(--primary); color:white; border:none; border-radius:8px; font-family:'Orbitron',sans-serif; font-size:13px; font-weight:bold; cursor:pointer; letter-spacing:1px; transition:0.2s; margin-top:4px; }
.auth-btn:hover { background:var(--primary-hover); transform:translateY(-1px); }
.auth-btn:disabled { opacity:0.6; cursor:not-allowed; }
.auth-divider { display:flex; align-items:center; gap:12px; margin:18px 0; color:var(--text-muted); font-size:11px; }
.auth-divider::before,.auth-divider::after { content:''; flex:1; height:1px; background:var(--glass-border); }
.auth-guest-btn { width:100%; padding:12px; background:transparent; color:var(--text-muted); border:1px dashed var(--glass-border); border-radius:8px; font-family:'Orbitron',sans-serif; font-size:11px; cursor:pointer; letter-spacing:1px; transition:0.2s; }
.auth-guest-btn:hover { border-color:var(--text-muted); color:var(--text-main); background:rgba(255,255,255,0.03); }
#auth-error { color:var(--accent); font-size:12px; text-align:center; min-height:18px; margin-top:8px; font-weight:bold; }

/* ════════ LOBBY ════════ */
#lobby { position:fixed; top:0; left:0; width:100vw; height:100vh; background:rgba(32,34,37,0.92); display:flex; align-items:center; justify-content:center; z-index:100; backdrop-filter:blur(8px); overflow:hidden; }

/* 16:9 inner wrapper — fixed design size, JS zoom scales it */
.lobby-wrapper { width:1600px; height:900px; margin:auto; display:flex; flex-direction:column; transform-origin:center center; }

/* TOP BAR */
.top-bar { display:flex; align-items:center; justify-content:space-between; padding:0 28px; height:68px; background:var(--panel-bg); border-bottom:1px solid var(--glass-border); flex-shrink:0; }
.top-bar-left { display:flex; align-items:center; gap:20px; }
.top-bar-logo { font-family:'Orbitron',sans-serif; font-size:20px; font-weight:700; color:var(--text-main); letter-spacing:3px; }
.top-bar-logo span { color:var(--primary); }
.top-bar-right { display:flex; align-items:center; gap:18px; }
.profile-pill { display:flex; align-items:center; gap:12px; background:var(--panel-dark); padding:8px 18px; border-radius:24px; border:1px solid var(--glass-border); }
.profile-name { font-size:15px; font-weight:600; }
.profile-level { font-size:13px; color:#f1c40f; font-weight:700; font-family:'Orbitron',sans-serif; }
.xp-bar-mini { width:100px; height:5px; background:var(--panel-dark); border-radius:3px; overflow:hidden; }
.xp-bar-mini-fill { height:100%; background:var(--primary); border-radius:3px; transition:width 0.4s; }
.xp-text-mini { font-size:10px; color:var(--text-muted); }
.online-count { font-size:13px; color:var(--text-muted); font-weight:600; }
.top-btn { background:none; border:1px solid var(--glass-border); color:var(--text-muted); padding:8px 12px; border-radius:6px; cursor:pointer; font-size:14px; transition:0.2s; }
.top-btn:hover { border-color:var(--primary); color:var(--text-main); }

/* LOBBY GRID */
.lobby-content { display:grid; grid-template-columns:1fr 2fr 1.2fr; gap:16px; padding:16px 20px; flex:1; overflow:hidden; min-height:0; }

/* PANELS */
.panel { background:var(--panel-bg); border:1px solid var(--glass-border); border-radius:12px; padding:20px; display:flex; flex-direction:column; overflow:hidden; box-shadow:0 4px 12px rgba(0,0,0,0.15); }
.panel-title { font-family:'Orbitron',sans-serif; font-size:13px; color:var(--text-main); margin:0 0 16px; padding-bottom:10px; border-bottom:1px solid var(--glass-border); letter-spacing:1px; }

/* LEFT PANEL */
.controls-list { list-style:none; padding:0; margin:0; }
.controls-list li { display:flex; justify-content:space-between; align-items:center; padding:7px 0; border-bottom:1px solid rgba(255,255,255,0.03); font-size:12px; color:var(--text-muted); }
.key { background:var(--panel-dark); padding:3px 7px; border-radius:4px; font-family:monospace; color:var(--text-main); border:1px solid var(--glass-border); font-size:10px; }
.pro-tip { background:rgba(88,101,242,0.08); border:1px solid rgba(88,101,242,0.15); border-radius:8px; padding:10px; margin-top:12px; font-size:11px; color:var(--text-muted); line-height:1.5; }
.pro-tip strong { color:var(--primary); }

/* CENTER PANEL */
.center-panel { border:2px solid var(--primary); box-shadow:0 0 20px rgba(88,101,242,0.15); }
.quick-play-btn { width:100%; padding:16px; background:linear-gradient(135deg,var(--primary),#7c6af5); color:white; border:none; border-radius:10px; font-family:'Orbitron',sans-serif; font-size:15px; font-weight:700; cursor:pointer; letter-spacing:2px; transition:0.2s; margin-bottom:10px; box-shadow:0 4px 15px rgba(88,101,242,0.3); }
.quick-play-btn:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(88,101,242,0.4); }
.create-room-btn { width:100%; padding:12px; background:var(--panel-dark); color:var(--text-main); border:1px solid var(--glass-border); border-radius:8px; font-family:'Orbitron',sans-serif; font-size:11px; font-weight:600; cursor:pointer; letter-spacing:1px; transition:0.2s; margin-bottom:16px; }
.create-room-btn:hover { border-color:var(--primary); color:var(--primary); }
#room-list { display:flex; flex-direction:column; gap:10px; overflow-y:auto; flex:1; padding-right:4px; }
.room-card { background:var(--panel-dark); border:1px solid var(--glass-border); padding:12px 14px; border-radius:8px; transition:0.2s; cursor:pointer; }
.room-card:hover { border-color:var(--primary); transform:translateX(2px); }
.room-card-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.room-card h3 { margin:0; font-size:13px; color:var(--text-main); font-family:'Orbitron',sans-serif; }
.room-card-badge { font-size:9px; padding:2px 6px; border-radius:4px; font-weight:700; letter-spacing:0.5px; }
.badge-ffa { background:rgba(88,101,242,0.2); color:#7c8af5; }
.badge-coop { background:rgba(46,204,113,0.2); color:#2ecc71; }
.player-tag { display:inline-block; padding:2px 7px; border-radius:3px; margin:2px; font-size:10px; font-weight:600; background:rgba(255,255,255,0.05); border:1px solid currentColor; }
.room-join-btn { width:100%; margin-top:8px; background:var(--success); color:white; border:none; padding:7px; border-radius:6px; cursor:pointer; font-family:'Inter',sans-serif; font-size:11px; font-weight:600; transition:0.2s; }
.room-join-btn:hover { background:#328f50; }
.room-join-btn:disabled { background:var(--panel-bg); color:var(--text-muted); cursor:not-allowed; }

/* RIGHT PANEL (ARMORY) */
.armory-preview { width:100%; flex:1; min-height:120px; background:var(--panel-dark); border-radius:8px; border:1px solid var(--glass-border); display:flex; justify-content:center; align-items:center; margin-bottom:12px; overflow:hidden; position:relative; }
#previewCanvas { width:100%; height:100%; }
.armory-tabs { display:flex; gap:4px; margin-bottom:12px; }
.armory-tab { flex:1; padding:8px 4px; background:var(--panel-dark); border:1px solid var(--glass-border); border-radius:6px; color:var(--text-muted); font-size:10px; font-weight:700; font-family:'Orbitron',sans-serif; cursor:pointer; text-align:center; transition:0.2s; letter-spacing:0.5px; }
.armory-tab:hover { border-color:var(--primary); color:var(--text-main); }
.armory-tab.active { background:var(--primary); border-color:var(--primary); color:#fff; }
.armory-content { flex:1; overflow-y:auto; }

/* ══ COLOR PICKER ══ */
.cp-wrap { display:flex; flex-direction:column; gap:10px; }
.cp-gradient-wrap { position:relative; width:100%; border-radius:8px; overflow:hidden; cursor:crosshair; }
.cp-gradient-wrap canvas { width:100%; height:160px; display:block; border-radius:8px; }
.cp-cursor { position:absolute; width:16px; height:16px; border:2px solid #fff; border-radius:50%; pointer-events:none; transform:translate(-50%,-50%); box-shadow:0 0 3px rgba(0,0,0,0.5),inset 0 0 2px rgba(0,0,0,0.3); top:10px; left:10px; z-index:2; }
.cp-hue-wrap { position:relative; width:100%; height:20px; }
.cp-hue-wrap canvas { width:100%; height:14px; display:block; border-radius:7px; cursor:pointer; margin-top:3px; }
.cp-hue-thumb { position:absolute; width:18px; height:18px; border:3px solid #fff; border-radius:50%; pointer-events:none; box-shadow:0 0 4px rgba(0,0,0,0.4); top:1px; left:50%; transform:translateX(-50%); z-index:2; }
.cp-result-row { display:flex; align-items:center; gap:10px; }
.cp-preview { width:36px; height:36px; border-radius:50%; border:2px solid var(--glass-border); flex-shrink:0; box-shadow:0 2px 8px rgba(0,0,0,0.3); }
.cp-hex-box { flex:1; background:var(--panel-dark); border-radius:20px; padding:2px; }
.cp-hex-input { width:100%; background:transparent; border:none; color:var(--text-main); font-family:monospace; font-size:14px; font-weight:600; padding:8px 14px; outline:none; letter-spacing:1px; }
.cp-save-btn { padding:8px 16px; background:var(--success); color:#fff; border:none; border-radius:20px; font-family:'Orbitron',sans-serif; font-size:10px; font-weight:bold; cursor:pointer; transition:0.2s; letter-spacing:1px; flex-shrink:0; }
.cp-save-btn:hover { background:#328f50; transform:scale(1.05); }
.cp-presets { display:flex; flex-wrap:wrap; gap:6px; justify-content:center; }
.cp-sw { width:28px; height:28px; border-radius:50%; cursor:pointer; border:2px solid transparent; transition:0.15s; box-shadow:0 2px 4px rgba(0,0,0,0.2); }
.cp-sw:hover { transform:scale(1.15); border-color:rgba(255,255,255,0.3); }
.cp-sw.active { border-color:#fff; transform:scale(1.15); }
.color-section { display:flex; flex-direction:column; gap:10px; align-items:center; }
.color-picker { display:flex; gap:8px; flex-wrap:wrap; justify-content:center; }
.color-swatch { width:28px; height:28px; border-radius:50%; cursor:pointer; border:3px solid transparent; transition:0.2s; box-shadow:0 2px 6px rgba(0,0,0,0.2); }
.color-swatch:hover { transform:scale(1.15); }
.color-swatch.active { border-color:var(--text-main); transform:scale(1.15); }
.hex-input-row { display:flex; align-items:center; gap:8px; width:100%; }
.hex-preview { width:28px; height:28px; border-radius:50%; border:2px solid var(--glass-border); flex-shrink:0; }
.hex-input { flex:1; background:var(--panel-dark); border:1px solid var(--glass-border); color:var(--text-main); padding:6px 10px; border-radius:6px; font-family:monospace; font-size:12px; outline:none; transition:0.2s; }
.hex-input:focus { border-color:var(--primary); }
.item-list { display:flex; flex-direction:column; gap:4px; }
.item-row { display: flex; align-items: center; gap: 4px; border-radius: 6px; overflow: hidden; border: 1px solid var(--glass-border); background: var(--panel-dark); transition: 0.2s; }
.item-row.active { border-color: var(--primary); background: var(--primary); }
.item-row.active .item-btn { color: #fff; }
.item-row.locked .item-btn { opacity: 0.7; }
.item-btn { flex: 1; background: transparent; border: none; color: var(--text-muted); padding: 7px 10px; cursor: pointer; font-family: 'Inter', sans-serif; font-size: 10px; font-weight: 600; text-align: left; transition: 0.2s; }
.buy-btn { background: rgba(0,0,0,0.2); border: none; border-left: 1px solid var(--glass-border); padding: 7px 10px; cursor: pointer; transition: 0.2s; display: flex; align-items: center; justify-content: center; }
.buy-btn:hover { background: var(--success); }
.item-name { flex: 1; text-align: left; }
.item-price { font-size: 9px; display: flex; align-items: center; gap: 4px; color: #f1c40f; font-weight: bold; white-space: nowrap; }
.cart-icon { font-style: normal; font-size: 11px; }
.item-emoji { font-size:14px; }
.item-lock { font-size:9px; color:var(--text-muted); margin-left:auto; }
.perk-desc { font-size:9px; color:var(--text-muted); margin-left:auto; font-weight:normal; font-family:'Inter',sans-serif; }
.active .perk-desc { color:rgba(255,255,255,0.8); }
.perk-grid { display:grid; grid-template-columns:1fr 1fr; gap:6px; }
.perk-slot { background:var(--panel-dark); border:1px dashed var(--glass-border); border-radius:8px; height:60px; display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:10px; font-family:'Orbitron',sans-serif; }
.guest-overlay { position:absolute; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.7); display:flex; align-items:center; justify-content:center; border-radius:8px; z-index:5; }
.guest-overlay span { color:var(--accent); font-size:11px; font-weight:700; text-align:center; line-height:1.5; }

/* MATCH HISTORY (Horizontal Cards) */
#matchSummaries { display:flex; gap:10px; overflow-x:auto; padding-bottom:5px; flex-shrink:0; height:85px; margin-top:8px; }
#matchSummaries::-webkit-scrollbar { height:3px; }
#matchSummaries::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.1); border-radius:3px; }
.summary-card { flex-shrink:0; width:160px; background:rgba(255,255,255,0.025); border:1px solid var(--glass-border); border-radius:8px; padding:8px 12px; height:auto; display:flex; flex-direction:column; justify-content:center; transition:0.2s; }
.summary-card:hover { background:rgba(255,255,255,0.05); border-color:rgba(88,101,242,0.3); }
.summary-result { font-family:'Orbitron',sans-serif; font-size:9px; font-weight:700; letter-spacing:1px; margin-bottom:4px; color:var(--gold); }
.summary-result.win { color:var(--success); }
.summary-result.loss { color:var(--accent); }
.summary-stats { display:flex; justify-content:space-between; align-items:center; margin:4px 0; }
.summary-val { font-size:13px; font-weight:700; color:var(--text-main); }
.summary-time { font-size:11px; color:var(--text-muted); }
.summary-xp { font-size:10px; color:var(--primary); font-weight:600; }

/* CREATE ROOM MODAL + PASSWORD MODAL */
.overlay-modal { position:fixed; top:0; left:0; width:100vw; height:100vh; background:rgba(0,0,0,0.75); z-index:20000; display:flex; justify-content:center; align-items:center; backdrop-filter:blur(6px); }
#createRoomModal { position:fixed; top:0; left:0; width:100vw; height:100vh; background:rgba(0,0,0,0.7); z-index:999; display:flex; justify-content:center; align-items:center; backdrop-filter:blur(4px); }
#passwordModal { position:fixed; top:0; left:0; width:100vw; height:100vh; background:rgba(0,0,0,0.7); z-index:999; display:flex; justify-content:center; align-items:center; backdrop-filter:blur(4px); }
.modal-box { background:var(--panel-bg); border:1px solid var(--primary); border-radius:12px; padding:28px; width:340px; box-shadow:0 15px 40px rgba(0,0,0,0.5); }
.modal-box h2 { font-family:'Orbitron',sans-serif; font-size:16px; color:var(--primary); margin:0 0 20px; text-align:center; letter-spacing:1px; }
.modal-field { width:100%; box-sizing:border-box; background:var(--panel-dark); border:1px solid var(--glass-border); color:var(--text-main); padding:11px 12px; border-radius:6px; font-size:13px; outline:none; margin-bottom:10px; transition:0.2s; }
.modal-field:focus { border-color:var(--primary); }
.mode-selector { display:flex; gap:8px; margin-bottom:14px; }
.mode-btn { flex:1; padding:10px; border-radius:6px; background:var(--panel-dark); border:2px solid var(--glass-border); color:var(--text-muted); font-family:'Orbitron',sans-serif; font-size:11px; font-weight:bold; cursor:pointer; transition:0.2s; text-align:center; }
.mode-btn:hover { border-color:var(--primary); color:var(--text-main); }
.mode-btn.active { background:var(--primary); border-color:var(--primary); color:#fff; }
.mode-btn.coop-active { background:#2ecc71; border-color:#27ae60; color:#fff; }
.modal-actions { display:flex; gap:8px; margin-top:6px; }
.modal-actions button { flex:1; padding:11px; border-radius:6px; font-family:'Orbitron',sans-serif; font-size:11px; font-weight:bold; cursor:pointer; transition:0.2s; letter-spacing:0.5px; }
.btn-confirm { background:var(--primary); color:#fff; border:none; }
.btn-confirm:hover { background:var(--primary-hover); }
.btn-cancel { background:var(--panel-dark); color:var(--text-muted); border:1px solid var(--glass-border); }
.btn-cancel:hover { border-color:var(--accent); color:var(--accent); }
#pw-error { color:var(--accent); font-size:11px; text-align:center; min-height:16px; margin-top:6px; font-weight:bold; }

/* ROOM ERROR */
@keyframes errorIn { 0%{transform:translateY(-5px);opacity:0} 20%{transform:translateX(3px)} 40%{transform:translateX(-3px)} 60%{transform:translateX(3px)} 100%{transform:translateY(0);opacity:1} }
.error-anim { animation:errorIn 0.3s ease-out forwards; transition:opacity 0.8s; }
.error-fade { opacity:0 !important; }

/* SOLO COOP MODAL */
#soloCoopModal { position:fixed; top:0; left:0; width:100vw; height:100vh; background:rgba(0,0,0,0.8); z-index:999; display:flex; justify-content:center; align-items:center; }

/* IN-GAME UI */
#volume-control { position:absolute; top:20px; left:20px; display:flex; flex-direction:column; gap:8px; background:rgba(32,34,37,0.9); backdrop-filter:blur(10px); padding:15px; border-radius:12px; border:1px solid var(--glass-border); z-index:200; width:260px; box-shadow:0 8px 32px rgba(0,0,0,0.3); }
#volume-control .vol-row { display:flex; align-items:center; justify-content:space-between; gap:12px; width:100%; }
#volume-control input { flex:1; height:4px; border-radius:2px; cursor:pointer; accent-color:var(--primary); }
.vol-label { font-size:9px; font-weight:800; color:var(--text-muted); font-family:'Orbitron',sans-serif; width:65px; text-transform: uppercase; }
.vol-pct { font-size:10px; color:var(--text-main); width:40px; text-align:right; font-weight:bold; font-family:'Orbitron',sans-serif; }
#leave-btn { width:100%; margin-top:8px; background:rgba(237,66,69,0.1); border:1px solid rgba(237,66,69,0.3); color:#ed4245; font-family:'Orbitron',sans-serif; font-size:10px; font-weight:800; padding:10px; border-radius:8px; cursor:pointer; transition:0.2s; display:none; letter-spacing:1px; text-align:center; }
#leave-btn:hover { background:#ed4245; color:#fff; border-color:#ed4245; transform:translateY(-1px); box-shadow:0 4px 12px rgba(237,66,69,0.3); }
#announcement { position:absolute; top:30%; left:50%; transform:translate(-50%,-50%); font-family:'Orbitron',sans-serif; font-size:56px; color:var(--primary); text-shadow:2px 2px 0px var(--panel-dark); pointer-events:none; z-index:50; }
#chat-container { position:absolute; bottom:30px; left:30px; width:400px; display:flex; flex-direction:column; justify-content:flex-end; pointer-events:none; z-index:100; }
#chat-messages { display:flex; flex-direction:column; gap:6px; margin-bottom:12px; max-height:250px; overflow-y:hidden; mask-image:linear-gradient(to top,black 80%,transparent 100%); -webkit-mask-image:linear-gradient(to top,black 80%,transparent 100%); }
#chat-container.chat-active #chat-messages { pointer-events:auto; overflow-y:auto; background:rgba(32,34,37,0.85); padding:10px; border-radius:8px; border:1px solid var(--primary); }
.chat-msg { background:rgba(47,49,54,0.9); padding:8px 12px; border-radius:6px; width:fit-content; font-size:14px; color:var(--text-main); font-weight:500; animation:slideIn 0.2s ease-out; border-left:3px solid var(--primary); box-shadow:0 4px 6px rgba(0,0,0,0.1); transition:opacity 0.5s; }
.chat-msg.faded { opacity:0; pointer-events:none; }
#chat-container.chat-active .chat-msg.faded { opacity:1; pointer-events:auto; }
@keyframes slideIn { from{transform:translateX(-20px);opacity:0} to{transform:translateX(0);opacity:1} }
#chat-input-wrapper { display:none; pointer-events:auto; }
#chatInput { width:100%; background:var(--panel-dark); border:1px solid var(--primary); color:var(--text-main); padding:12px; border-radius:6px; font-size:14px; outline:none; margin:0; }
#emote-menu { display:none; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); background:rgba(47,49,54,0.95); border:1px solid var(--primary); border-radius:12px; padding:20px; z-index:150; box-shadow:0 10px 30px rgba(0,0,0,0.3); text-align:center; }
#emote-menu h3 { margin:0 0 15px; font-size:14px; color:var(--text-main); }
.emote-buttons { display:flex; gap:10px; }
.emote-btn { background:var(--panel-dark); border:1px solid var(--glass-border); color:var(--text-main); padding:10px 15px; border-radius:6px; cursor:pointer; font-size:14px; transition:0.2s; }
.emote-btn:hover { background:var(--primary); border-color:var(--primary); }

/* Dil toggle butonları */
.lang-btn.active { color: var(--primary) !important; border-color: var(--primary) !important; }
.lang-btn:hover { color: var(--text-main) !important; }
