@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
:root {
  --bg-primary: #101012;
  --bg-secondary: #0a0a0c;
  --bg-card: #141416;
  --bg-hover: #1a1a1e;
  --bg-active: #1c1a1a;
  --bg-message: #161618;
  --bg-message-own: #1a1618;
  --bg-input: #161618;
  --text-primary: #dcdcdc;
  --text-secondary: #7a7a82;
  --text-muted: #484850;
  --accent: #b04040;
  --accent-hover: #c45050;
  --accent-glow: rgba(176, 64, 64, 0.07);
  --green: #5a9a5a;
  --red: #b04040;
  --orange: #c8884a;
  --border: #1e1e22;
  --border-accent: rgba(176, 64, 64, 0.12);
  --scrollbar: #282830;
  --badge: #904040;
  --shadow: rgba(0,0,0,0.5);
  --radius: 12px;
}
html,body{height:100%;height:100dvh;font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-secondary);color:var(--text-primary);overflow:hidden;overflow-x:hidden;-webkit-font-smoothing:antialiased;max-width:100%}

/* ===================== AUTH / LANDING ===================== */
.auth-screen{display:flex;height:100vh;height:100dvh;background:#050505;overflow-y:auto;overflow-x:hidden}
.landing-container{width:100%;min-height:100vh;display:flex;flex-direction:column}

.landing-hero{position:relative;padding:72px 20px 48px;text-align:center}
.landing-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%, rgba(176,64,64,.06) 0%, transparent 70%);pointer-events:none}
.landing-hero-content{position:relative;z-index:1}
.landing-logo{margin-bottom:20px}
.landing-logo-icon{margin:0 auto 12px;width:80px;height:80px;border-radius:20px;background:rgba(176,64,64,.06);border:1px solid rgba(176,64,64,.12);display:flex;align-items:center;justify-content:center}
.logo-text{font-size:36px;font-weight:800;letter-spacing:8px;color:var(--accent);text-transform:uppercase;font-family:'Inter',sans-serif}
.logo-sub{font-size:11px;letter-spacing:3px;color:var(--text-muted);text-transform:uppercase;margin-top:4px}
.landing-tagline{color:var(--text-secondary);font-size:15px;max-width:500px;margin:0 auto;line-height:1.6}

.landing-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;padding:0 20px;max-width:900px;margin:0 auto 48px}
.stat-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:14px;padding:16px 8px;text-align:center;transition:all .2s}
.stat-card:hover{border-color:var(--border-accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.stat-icon{margin:0 auto 8px;width:36px;height:36px;border-radius:10px;background:rgba(176,64,64,.06);display:flex;align-items:center;justify-content:center}
.stat-icon svg{width:18px;height:18px;color:var(--accent)}
.stat-value{font-size:22px;font-weight:800;color:var(--text-primary);line-height:1}
.stat-label{font-size:10px;color:var(--text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:0.5px}

.landing-auth-section{display:flex;justify-content:center;padding:0 20px 40px}
.auth-box{background:var(--bg-primary);padding:36px 32px;border-radius:16px;width:420px;max-width:100%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.6);border:1px solid var(--border)}
.auth-box h1{font-size:22px;font-weight:700;margin-bottom:6px}
.auth-box .subtitle{color:var(--text-secondary);font-size:13px;margin-bottom:28px}
.form-group{margin-bottom:16px;text-align:left}
.form-group label{display:block;color:var(--text-secondary);font-size:12px;margin-bottom:6px;font-weight:500;text-transform:uppercase;letter-spacing:0.5px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent)}
.form-group input::placeholder{color:var(--text-muted)}
.btn{width:100%;padding:14px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;margin-top:8px;letter-spacing:0.5px}
.btn:hover{background:var(--accent-hover);box-shadow:0 4px 20px rgba(176,64,64,.2)}.btn:disabled{opacity:.4;cursor:not-allowed}
.btn.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-primary)}.btn.btn-secondary:hover{border-color:var(--accent);color:var(--accent);background:rgba(176,64,64,.04)}
.btn.btn-danger{background:var(--red)}
.auth-toggle{margin-top:24px;font-size:13px;color:var(--text-secondary)}
.auth-toggle a{color:var(--accent);cursor:pointer;text-decoration:none;font-weight:600}
.auth-toggle a:hover{text-decoration:underline}
.auth-error{background:rgba(176,64,64,.07);color:var(--red);padding:12px;border-radius:8px;font-size:13px;margin-bottom:16px;display:none;border:1px solid rgba(176,64,64,.15)}

/* ===================== LANDING SECTIONS ===================== */
.landing-section{max-width:800px;margin:0 auto;padding:0 20px 40px;width:100%}
.landing-section-title{font-size:20px;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:10px;color:var(--text-primary)}

.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.feature-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:14px;padding:20px;transition:all .2s;text-align:center;display:flex;flex-direction:column;align-items:center}
.feature-card:hover{border-color:var(--border-accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.feature-icon{width:40px;height:40px;border-radius:12px;background:rgba(176,64,64,.06);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.feature-icon svg{width:20px;height:20px;color:var(--accent)}
.feature-card h3{font-size:14px;font-weight:700;margin-bottom:6px;color:var(--text-primary)}
.feature-card p{font-size:12px;color:var(--text-secondary);line-height:1.5}

.rules-list{display:flex;flex-direction:column;gap:10px}
.rule-item{display:flex;gap:14px;background:var(--bg-primary);border:1px solid var(--border);border-radius:14px;padding:16px;transition:all .15s}
.rule-item:hover{border-color:var(--border-accent)}
.rule-num{width:32px;height:32px;border-radius:10px;background:var(--accent);color:#fff;font-size:14px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rule-content h4{font-size:14px;font-weight:700;margin-bottom:4px;color:var(--text-primary)}
.rule-content p{font-size:12px;color:var(--text-secondary);line-height:1.5}

.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{background:var(--bg-primary);border:1px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;transition:all .15s}
.faq-item:hover{border-color:var(--border-accent)}
.faq-question{display:flex;align-items:center;gap:10px;padding:14px 16px;font-size:14px;font-weight:600;color:var(--text-primary);user-select:none}
.faq-arrow{width:16px;height:16px;color:var(--accent);transition:transform .2s;flex-shrink:0}
.faq-item.open .faq-arrow{transform:rotate(90deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;font-size:13px;color:var(--text-secondary);line-height:1.6;padding:0 16px 0 42px}
.faq-item.open .faq-answer{max-height:300px;padding:0 16px 14px 42px}

.disclaimer-box{display:flex;gap:16px;background:rgba(176,64,64,.03);border:1px solid rgba(176,64,64,.1);border-radius:14px;padding:20px}
.disclaimer-icon{width:48px;height:48px;border-radius:14px;background:rgba(176,64,64,.06);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent)}
.disclaimer-content h3{font-size:15px;font-weight:700;color:var(--accent);margin-bottom:6px}
.disclaimer-content p{font-size:12px;color:var(--text-secondary);line-height:1.6}

.landing-footer{background:var(--bg-primary);border-top:1px solid var(--border);margin-top:auto;padding:24px 20px}
.landing-footer-inner{max-width:800px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}
.landing-footer-links{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}
.landing-footer-links a{color:var(--text-secondary);text-decoration:none;font-size:12px;display:flex;align-items:center;gap:4px;transition:color .15s}
.landing-footer-links a:hover{color:var(--accent)}
.landing-footer-copy{font-size:11px;color:var(--text-muted)}

@media(max-width:768px){
  .landing-stats{grid-template-columns:repeat(3,1fr)}
  .features-grid{grid-template-columns:1fr}
  .disclaimer-box{flex-direction:column;text-align:center}
  .disclaimer-icon{margin:0 auto}
}
@media(max-width:480px){
  .landing-stats{grid-template-columns:repeat(2,1fr)}
  .landing-hero{padding:40px 16px 20px}
  .logo-text{font-size:28px;letter-spacing:5px}
  .stat-value{font-size:18px}
}

/* ===================== LAYOUT ===================== */
.chat-app{display:none;height:100vh;height:100dvh;width:100%;max-width:100vw;position:relative;overflow-x:hidden;overflow-y:hidden}
.chat-layout{display:flex;height:100%;min-height:0}

/* ===================== SIDEBAR ===================== */
.sidebar{width:380px;min-width:280px;max-width:400px;background:var(--bg-primary);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;height:100%}
.sidebar-header{display:flex;align-items:center;padding:10px 12px;gap:8px;min-height:56px;border-bottom:1px solid var(--border)}
.sidebar-header .menu-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px;cursor:pointer;background:none;border:none;color:var(--text-secondary);transition:all .15s}
.sidebar-header .menu-btn:hover{background:var(--bg-hover);color:var(--text-primary)}
.sidebar-header .menu-btn svg{width:20px;height:20px}
.sidebar-search{flex:1;position:relative}
.sidebar-search input{width:100%;padding:10px 14px 10px 38px;background:var(--bg-input);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:13px;font-family:inherit;outline:none;transition:border-color .2s}
.sidebar-search input:focus{border-color:var(--accent)}
.sidebar-search input::placeholder{color:var(--text-muted)}
.sidebar-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);width:16px;height:16px}
.room-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 0;min-height:0;-webkit-overflow-scrolling:touch}

/* ===================== ROOM ITEM ===================== */
.room-item{display:flex;align-items:center;padding:10px 12px;cursor:pointer;transition:background .12s;gap:12px;margin:1px 6px;border-radius:10px}
.room-item:hover{background:var(--bg-hover)}
.room-item.active{background:var(--bg-active);border:1px solid var(--border-accent)}
.room-item:not(.active){border:1px solid transparent}
.room-icon{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;overflow:hidden}
.room-info{flex:1;min-width:0;overflow:hidden}
.room-info-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.room-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.room-time{font-size:11px;color:var(--text-muted);flex-shrink:0}
.room-item.active .room-time{color:var(--accent)}.room-item.has-unread .room-time{color:var(--accent)}
.room-info-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:3px;gap:8px}
.room-last-msg{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.room-last-msg .msg-author{color:var(--text-primary);font-weight:500}
.room-badge{background:var(--badge);color:rgba(255,255,255,.9);font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px;flex-shrink:0}

/* ===================== CHAT MAIN ===================== */
.chat-main{flex:1;display:flex;flex-direction:column;background:var(--bg-secondary);position:relative;overflow-x:hidden;min-width:0;min-height:0;height:100%}
.chat-placeholder{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;color:var(--text-muted);gap:16px}
.chat-placeholder .ph-icon{font-size:80px;opacity:.15;filter:grayscale(1)}
.chat-placeholder p{font-size:15px;letter-spacing:0.5px}

/* ===================== HEADER ===================== */
.chat-header{display:flex;align-items:center;padding:10px 16px;background:var(--bg-primary);border-bottom:1px solid var(--border);min-height:56px;gap:12px}
.room-icon-header{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:600;color:#fff;flex-shrink:0;overflow:hidden}
.chat-header-info{flex:1;min-width:0}
.chat-header-name{font-size:15px;font-weight:700}
.chat-header-sub{font-size:12px;color:var(--text-secondary)}
.chat-header-actions{display:flex;gap:4px}
.chat-header-actions button{width:38px;height:38px;border-radius:10px;border:none;background:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.chat-header-actions button:hover{background:var(--bg-hover);color:var(--text-primary)}
.chat-header-actions button svg{width:18px;height:18px}

/* ===================== SEARCH BAR ===================== */
.chat-search-bar{display:none;align-items:center;padding:8px 12px;background:var(--bg-primary);border-bottom:1px solid var(--border);gap:8px}
.chat-search-bar.visible{display:flex}
.chat-search-bar input{flex:1;padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:13px;font-family:inherit;outline:none}
.chat-search-bar input:focus{border-color:var(--accent)}
.chat-search-bar button{width:32px;height:32px;border-radius:8px;border:none;background:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center}
.chat-search-bar button svg{width:16px;height:16px}
.chat-search-bar button:hover{background:var(--bg-hover);color:var(--text-primary)}

/* ===================== MESSAGES ===================== */
.messages-area{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 0;display:flex;flex-direction:column;position:relative;min-height:0;-webkit-overflow-scrolling:touch}
.messages-area .messages-spacer{flex:1 1 auto}
.messages-container{max-width:720px;width:100%;margin:0 auto;padding:0 16px;overflow-x:hidden;flex-shrink:0}
.message{display:flex;gap:8px;margin-bottom:3px;align-items:flex-end;animation:msgIn .15s ease;padding:2px 0;border-radius:10px;transition:background .3s;max-width:100%;min-width:0;overflow:hidden}
.message.highlight{background:var(--accent-glow)}.message.search-match{background:rgba(255,200,0,.08)}
@keyframes msgIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.msg-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0;cursor:pointer;transition:transform .1s;overflow:hidden;letter-spacing:-.5px}
.msg-avatar:hover{transform:scale(1.08)}.msg-avatar.hidden{visibility:hidden}
.msg-bubble{max-width:min(480px,75vw);padding:8px 12px;border-radius:14px 14px 14px 4px;background:var(--bg-message);position:relative;word-wrap:break-word;word-break:break-word;overflow-wrap:break-word;overflow:hidden;min-width:80px;border:1px solid var(--border)}
.msg-bubble.own{background:var(--bg-message-own);border-radius:14px 14px 4px 14px;margin-left:auto;border-color:var(--border-accent)}
.msg-bubble.gif-bubble{width:fit-content;max-width:min(260px,65vw);padding:4px 4px 2px;min-width:0;background:transparent;border:none}
.msg-bubble.gif-bubble .msg-meta{padding:0 4px}
.msg-bubble.gif-bubble.own{background:transparent;border:none}
.msg-bubble.media-bubble{padding:4px 4px 2px;min-width:0;overflow:hidden}
.msg-bubble.media-bubble .msg-media{margin:0;border-radius:8px}
.msg-bubble.media-bubble .msg-media img,.msg-bubble.media-bubble .msg-media video{border-radius:8px}
.msg-bubble.media-bubble .msg-meta{padding:2px 6px 0}
.msg-bubble.media-bubble .msg-author{padding:2px 6px}
.msg-bubble.system{background:transparent;text-align:center;color:var(--text-muted);font-size:12px;max-width:100%;margin:8px auto;padding:4px;border:none}
.msg-author{font-size:13px;font-weight:600;margin-bottom:2px;cursor:pointer;display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.msg-author .role-badge{font-size:9px;padding:2px 6px;border-radius:4px;margin-left:6px;font-weight:700;vertical-align:middle;text-transform:uppercase;letter-spacing:0.3px}
.role-badge.admin{background:var(--red);color:#fff}.role-badge.assistant{background:#65aadd;color:#fff}.role-badge.moderator{background:var(--orange);color:#fff}
.custom-tag{font-size:11px;font-weight:600;margin-left:auto;color:#ffcc00;opacity:.85}
.msg-text{font-size:14px;line-height:1.5;white-space:pre-wrap;word-break:break-word;overflow-wrap:break-word}
.msg-text a{color:var(--accent);text-decoration:none}.msg-text a:hover{text-decoration:underline}
.msg-reply{background:var(--accent-glow);border-left:3px solid var(--accent);border-radius:4px;padding:4px 8px;margin-bottom:4px;font-size:12px;cursor:pointer;transition:background .15s}
.msg-reply:hover{background:rgba(176,64,64,.1)}
.msg-reply .reply-author{font-weight:600;color:var(--accent);font-size:11px}
.msg-reply .reply-text{color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.msg-meta{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:2px}
.msg-time{font-size:11px;color:var(--text-muted)}.msg-bubble.own .msg-time{color:rgba(255,255,255,.4)}
.msg-checks{display:inline-flex;align-items:center;margin-left:2px;color:rgba(255,255,255,.35);flex-shrink:0}
.msg-checks.read{color:#5ab8a0}
.msg-edited{font-size:11px;color:var(--text-muted);font-style:italic}

/* ===================== MEDIA ===================== */
.msg-media{margin:4px 0;border-radius:10px;overflow:hidden;max-width:min(320px,100%);cursor:pointer}
.msg-media img{width:100%;display:block;border-radius:10px;max-width:100%}
.msg-media.gif{max-width:min(250px,100%);width:fit-content}
.msg-media.gif img{width:auto;max-width:100%;max-height:250px;object-fit:contain}
.msg-media video{width:100%;display:block;border-radius:10px;max-width:100%}
.video-wrap{position:relative;cursor:pointer}
.video-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);border-radius:10px;transition:opacity .2s}
.video-wrap:hover .video-play-overlay{background:rgba(0,0,0,.45)}
.video-play-btn{width:56px;height:56px;border-radius:50%;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);border:2px solid rgba(255,255,255,.2);transition:transform .15s}
.video-wrap:hover .video-play-btn{transform:scale(1.08)}
.msg-audio{display:flex;align-items:center;gap:8px;padding:4px 0;max-width:100%;overflow:hidden}
.msg-audio audio{height:32px;flex:1;min-width:0;filter:invert(1) hue-rotate(180deg) brightness(0.7)}
.audio-dur{font-size:12px;color:var(--text-muted)}
.msg-file{display:flex;align-items:center;gap:10px;padding:8px;background:var(--accent-glow);border-radius:10px;cursor:pointer;transition:background .15s;border:1px solid var(--border-accent)}
.msg-file:hover{background:rgba(176,64,64,.1)}
.file-name{font-size:13px;font-weight:500;color:var(--accent)}.file-size{font-size:11px;color:var(--text-muted)}

/* ===================== CONTEXT MENUS ===================== */
.msg-context-menu,.user-context-menu{position:fixed;background:var(--bg-primary);border-radius:12px;padding:6px 0;min-width:180px;max-width:calc(100vw - 16px);box-shadow:0 8px 30px var(--shadow);z-index:1000;display:none;border:1px solid var(--border)}
.user-context-menu{display:block;z-index:1001}
.ctx-reactions{display:flex;padding:6px 10px;gap:2px;border-bottom:1px solid var(--border);justify-content:center}
.ctx-reactions .ctx-emoji{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:18px;border-radius:8px;cursor:pointer;transition:all .12s}
.ctx-reactions .ctx-emoji:hover{background:var(--bg-hover);transform:scale(1.2)}
.msg-context-menu .ctx-item,.user-context-menu .ctx-item{padding:10px 16px;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:10px;color:var(--text-primary);transition:background .1s}
.msg-context-menu .ctx-item:hover,.user-context-menu .ctx-item:hover{background:var(--bg-hover)}
.msg-context-menu .ctx-item.danger,.user-context-menu .ctx-item.danger{color:var(--red)}
.user-context-menu .ctx-header{padding:8px 16px 6px;font-size:12px;font-weight:700;color:var(--accent);border-bottom:1px solid var(--border);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.5px}

/* ===================== INPUT ===================== */
.chat-input-area{padding:10px 12px 12px;background:var(--bg-primary);border-top:1px solid var(--border)}
.reply-preview{display:none;align-items:center;padding:8px 12px;background:var(--bg-input);border-radius:10px 10px 0 0;border-left:3px solid var(--accent);margin-bottom:-2px;gap:8px}
.reply-preview.visible{display:flex}
.reply-preview-content{flex:1;min-width:0}
.reply-preview-author{font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:0.3px}
.reply-preview-text{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.reply-preview-close{width:28px;height:28px;border-radius:8px;border:none;background:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center}
.reply-preview-close:hover{background:var(--bg-hover)}
.chat-input-row{display:flex;align-items:flex-end;gap:6px}
.chat-input-row textarea{flex:1;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:14px;color:var(--text-primary);font-size:14px;font-family:inherit;outline:none;resize:none;max-height:200px;min-height:42px;line-height:1.4;transition:border-color .2s}
.chat-input-row textarea:focus{border-color:var(--border)}
.chat-input-row textarea::placeholder{color:var(--text-muted)}
.input-action-btn{width:42px;height:42px;border-radius:12px;border:none;background:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.input-action-btn:hover{color:var(--accent);background:var(--bg-hover)}
.input-action-btn svg{width:20px;height:20px}
.input-action-btn.recording{color:var(--red);animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.voice-recording-indicator{display:none;align-items:center;gap:6px;padding:0 8px;height:42px;border-radius:12px;background:rgba(229,57,53,.1);flex-shrink:0}
.voice-recording-indicator.active{display:flex}
.voice-rec-dot{width:8px;height:8px;border-radius:50%;background:var(--red);animation:pulse 1s infinite}
.voice-rec-timer{font-size:13px;font-weight:600;color:var(--red);font-variant-numeric:tabular-nums;min-width:40px}
.send-btn{width:42px;height:42px;border-radius:12px;background:var(--accent);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.send-btn:hover{background:var(--accent-hover);box-shadow:0 4px 16px rgba(176,64,64,.2);transform:scale(1.05)}
.typing-indicator{font-size:12px;color:var(--accent);padding:2px 16px;height:18px;overflow:hidden}

/* ===================== SIDEBAR MENU ===================== */
.sidebar-menu{position:fixed;top:0;left:0;width:300px;height:100vh;background:var(--bg-primary);z-index:2000;transform:translateX(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;border-right:1px solid var(--border)}
.sidebar-menu.open{transform:translateX(0)}
.sidebar-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1999;display:none}
.sidebar-menu-overlay.open{display:block}
.sidebar-menu-header{padding:24px 20px;background:linear-gradient(135deg, var(--bg-active), var(--bg-primary));border-bottom:1px solid var(--border-accent)}
.sidebar-menu-avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;margin-bottom:12px;overflow:hidden}
.sidebar-menu-name{font-size:16px;font-weight:700}
.sidebar-menu-email{font-size:12px;color:var(--text-muted);margin-top:2px}
.sidebar-menu-items{flex:1;padding:8px 0}
.sidebar-menu-item{display:flex;align-items:center;padding:12px 20px;gap:16px;cursor:pointer;font-size:14px;color:var(--text-primary);transition:all .12s}
.sidebar-menu-item:hover{background:var(--bg-hover);color:var(--accent)}
.sidebar-menu-item .icon{width:28px;display:flex;justify-content:center;color:var(--text-muted)}
.sidebar-menu-item:hover .icon{color:var(--accent)}
.sidebar-menu-item .icon svg{width:18px;height:18px}
.sidebar-menu-item.danger{color:var(--red)}.sidebar-menu-item.danger .icon{color:var(--red)}

/* ===================== ROOM INFO PANEL ===================== */
.room-info-panel{position:fixed;top:0;right:0;width:380px;max-width:100vw;height:100vh;background:var(--bg-primary);z-index:2000;transform:translateX(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 40px rgba(0,0,0,.5);border-left:1px solid var(--border)}
.room-info-panel.open{transform:translateX(0)}
.room-info-panel-header{display:flex;align-items:center;padding:12px 16px;gap:12px;border-bottom:1px solid var(--border);min-height:56px;justify-content:space-between}
.room-info-panel-header button{width:36px;height:36px;border-radius:10px;border:none;background:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center}
.room-info-panel-header button svg{width:18px;height:18px}
.room-info-panel-header button:hover{background:var(--bg-hover);color:var(--text-primary)}
.room-info-panel-header span{font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:1px}
.room-info-content{flex:1;overflow-y:auto;padding:8px}

.info-stats-grid{display:flex;flex-direction:column;gap:1px;padding:0 8px;margin:8px 0;background:var(--bg-card);border-radius:12px;overflow:hidden;border:1px solid var(--border)}
.info-stat{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .12s;font-size:13px;color:var(--text-primary)}
.info-stat:hover{background:var(--bg-hover)}
.info-stat svg{width:18px;height:18px;color:var(--accent)}
.info-stat+.info-stat{border-top:1px solid var(--border)}

.media-gal-month{font-size:13px;font-weight:600;color:var(--text-secondary);padding:12px 16px 6px}
.media-gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;padding:0 2px}
.media-gal-grid.cols3{grid-template-columns:repeat(3,1fr)}
.media-gal-item{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer;background:var(--bg-input)}
.media-gal-item img,.media-gal-item video{width:100%;height:100%;object-fit:cover;display:block}
.media-gal-item .vid-dur{position:absolute;bottom:4px;left:6px;font-size:11px;color:#fff;background:rgba(0,0,0,.6);padding:1px 5px;border-radius:4px;display:flex;align-items:center;gap:3px}
.media-gal-voice{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}
.media-gal-voice:hover{background:var(--bg-hover)}
.media-gal-voice audio{position:absolute;opacity:0;pointer-events:none}
.media-gal-voice .v-play{width:40px;height:40px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}
.media-gal-voice.playing .v-play{background:var(--green)}
.media-gal-voice .v-play svg{color:#fff}
.media-gal-voice .v-info{flex:1;min-width:0}
.media-gal-voice .v-name{font-size:14px;font-weight:500;color:var(--text-primary)}
.media-gal-voice .v-meta{font-size:12px;color:var(--text-muted)}
.media-gal-link{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s;align-items:flex-start}
.media-gal-link:hover{background:var(--bg-hover)}
.media-gal-link .l-icon{width:40px;height:40px;border-radius:10px;background:var(--bg-input);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;font-weight:700;color:var(--accent)}
.media-gal-link .l-body{flex:1;min-width:0;overflow:hidden}
.media-gal-link .l-title{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.media-gal-link .l-url{font-size:12px;color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.media-gal-link .l-date{font-size:11px;color:var(--text-muted);margin-top:2px}

.member-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px;transition:background .12s;cursor:pointer}
.member-item:hover{background:var(--bg-hover)}
.member-av{flex-shrink:0}

/* ===================== MEDIA GALLERY ===================== */
.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.media-thumb{aspect-ratio:1;overflow:hidden;border-radius:6px;cursor:pointer;border:1px solid var(--border)}
.media-thumb img,.media-thumb video{width:100%;height:100%;object-fit:cover}

/* ===================== PROFILE MODAL ===================== */
.profile-modal{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:3000;display:none;align-items:center;justify-content:center}
.profile-modal.open{display:flex}
.profile-modal-content{background:var(--bg-primary);border-radius:16px;padding:24px;width:420px;max-width:95vw;max-height:90vh;max-height:90dvh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.5);border:1px solid var(--border);-webkit-overflow-scrolling:touch}
.profile-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.profile-modal-header h2{font-size:20px;font-weight:700}
.profile-modal-header button{width:36px;height:36px;border-radius:10px;border:none;background:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center}
.profile-modal-header button:hover{background:var(--bg-hover);color:var(--text-primary)}
.profile-avatar-big{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:#fff;margin:0 auto;overflow:hidden}
.avatar-upload-btn{position:absolute;bottom:-4px;right:calc(50% - 54px);width:32px;height:32px;border-radius:10px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid var(--bg-primary)}
.avatar-upload-btn:hover{background:var(--accent-hover)}

/* ===================== PINNED ===================== */
.pinned-bar{display:none;align-items:center;padding:8px 16px;background:var(--bg-primary);border-bottom:1px solid var(--border);gap:10px;cursor:pointer}
.pinned-bar.visible{display:flex}
.pin-content{flex:1;min-width:0}.pin-label{font-size:11px;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:0.5px}
.pin-text{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ===================== SCROLL BOTTOM BTN ===================== */
.scroll-bottom-btn{position:absolute;bottom:12px;right:16px;width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.3);z-index:20;transition:opacity .2s}
.scroll-bottom-btn:hover{background:var(--bg-hover)}
.scroll-bottom-btn.visible{display:flex}
.scroll-bottom-badge{position:absolute;top:-6px;right:-4px;min-width:20px;height:20px;border-radius:10px;background:var(--red);color:#fff;font-size:11px;font-weight:700;display:none;align-items:center;justify-content:center;padding:0 5px;line-height:1}
.scroll-bottom-badge.has-count{display:flex}
/* ===================== UNREAD SEPARATOR ===================== */
.unread-separator{display:flex;align-items:center;gap:10px;padding:8px 0;margin:4px 0}
.unread-separator::before,.unread-separator::after{content:'';flex:1;height:1px;background:var(--red);opacity:.35}
.unread-separator span{color:var(--red);font-size:11px;font-weight:600;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}
/* ===================== DATE SEPARATOR ===================== */
.date-separator{text-align:center;padding:12px 0}
.date-separator span{background:rgba(176,64,64,.04);color:var(--text-secondary);padding:5px 14px;border-radius:8px;font-size:12px;font-weight:500;border:1px solid rgba(176,64,64,.06)}

/* ===================== SCROLLBAR ===================== */
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#444}

/* ===================== TOAST ===================== */
.toast-container{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:5000;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:var(--bg-primary);color:var(--text-primary);padding:12px 24px;border-radius:12px;font-size:13px;box-shadow:0 8px 30px var(--shadow);animation:toastIn .2s ease;transition:opacity .3s;border:1px solid var(--border)}
.toast.error{border-left:4px solid var(--red)}.toast.success{border-left:4px solid var(--green)}.toast.info{border-left:4px solid var(--accent)}
@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ===================== DM SECTION ===================== */
.dm-section{padding:2px 6px;cursor:pointer;border-bottom:1px solid var(--border);margin-bottom:2px}
.dm-section-inner{display:flex;align-items:center;width:100%;padding:10px 12px;gap:12px;border-radius:10px;border:1px solid transparent;transition:background .12s}
.dm-section:hover .dm-section-inner{background:var(--bg-hover)}
.dm-section.active .dm-section-inner{background:var(--bg-active);border-color:var(--border-accent)}

/* ===================== USER PROFILE ===================== */
.profile-actions{display:flex;justify-content:center;gap:24px;padding:16px 0;border-bottom:1px solid var(--border);margin:0 16px}
.profile-action-btn{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;color:var(--accent);transition:all .15s;font-size:12px;font-weight:500}
.profile-action-btn:hover{color:var(--accent-hover);transform:translateY(-1px)}
.profile-action-btn svg{width:22px;height:22px}
.profile-bio-section{padding:12px 16px;border-bottom:1px solid var(--border)}
.profile-bio-label{font-size:11px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:4px}
.profile-bio-text{font-size:14px;color:var(--text-primary);line-height:1.5}
.profile-info-section{padding:12px 16px;border-bottom:1px solid var(--border)}
.profile-info-item{display:flex;flex-direction:column;gap:2px;padding:6px 0}
.profile-info-item span:first-child{font-size:11px}
.profile-info-item span:last-child{font-size:14px;color:var(--text-primary)}
.profile-block-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;margin:16px;border-radius:12px;background:rgba(176,64,64,.05);color:var(--red);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;border:1px solid rgba(176,64,64,.1)}
.profile-block-btn:hover{background:rgba(176,64,64,.1)}
.profile-block-btn.unblock{color:var(--green);background:rgba(90,154,90,.05);border-color:rgba(90,154,90,.1)}
.profile-block-btn.unblock:hover{background:rgba(90,154,90,.1)}
.mention{color:var(--accent);font-weight:600;background:rgba(176,64,64,.08);padding:1px 4px;border-radius:4px;cursor:pointer}
.mention:hover{text-decoration:underline}

/* ===================== REACTIONS ===================== */
.msg-reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.reaction-chip{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:12px;font-size:13px;cursor:pointer;background:var(--bg-hover);border:1px solid var(--border);transition:all .15s;user-select:none;line-height:1.4}
.reaction-chip:hover{border-color:var(--accent);background:rgba(176,64,64,.06)}
.reaction-chip.mine{border-color:var(--accent);background:rgba(176,64,64,.08)}
.reaction-chip .r-count{font-size:11px;font-weight:600;color:var(--text-secondary)}
.reaction-chip.mine .r-count{color:var(--accent)}

.reaction-tooltip{position:fixed;background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;padding:8px 12px;font-size:12px;color:var(--text-secondary);box-shadow:0 4px 20px var(--shadow);z-index:2000;pointer-events:none;max-width:200px}

/* ===================== RANK BADGE ===================== */
.rank-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:700;padding:1px 6px;border-radius:4px;margin-left:5px;vertical-align:middle;letter-spacing:0.3px;text-transform:uppercase}
.rank-1{background:rgba(120,120,120,.15);color:#888}
.rank-2{background:rgba(120,120,120,.2);color:#999}
.rank-3{background:rgba(90,154,90,.15);color:#6a6}
.rank-4{background:rgba(90,154,90,.2);color:#7b7}
.rank-5{background:rgba(100,140,200,.2);color:#79b}
.rank-6{background:rgba(130,100,200,.2);color:#97c}
.rank-7{background:rgba(200,140,60,.2);color:#ca6}
.rank-8{background:rgba(220,120,50,.2);color:#d84}
.rank-9{background:rgba(200,60,60,.2);color:#c55}
.rank-10{background:linear-gradient(135deg,rgba(255,200,50,.2),rgba(255,100,50,.2));color:#fa0}

.rep-bar{width:100%;height:4px;background:var(--border);border-radius:2px;margin-top:6px;overflow:hidden}
.rep-bar-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .3s}

/* ===================== ONLINE DOT ===================== */
.avatar-wrap{position:relative;flex-shrink:0}
.online-dot{position:absolute;bottom:1px;right:1px;width:12px;height:12px;border-radius:50%;background:#4caf50;border:2px solid var(--bg-primary);z-index:1}

/* ===================== USER SEARCH ===================== */
.user-search-results{border-bottom:1px solid var(--border);padding-bottom:4px}
.search-section-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;padding:8px 16px 4px}

/* ===================== GIF PANEL ===================== */
.gif-panel{display:none;background:var(--bg-primary);border-top:1px solid var(--border);max-height:340px;flex-direction:column;overflow:hidden}
.gif-panel.open{display:flex}
.gif-panel-header{display:flex;align-items:center;padding:8px 8px 4px;gap:6px}
.gif-panel-header input{flex:1;padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:13px;font-family:inherit;outline:none}
.gif-panel-header input:focus{border-color:var(--accent)}
.gif-panel-header input::placeholder{color:var(--text-muted)}
.gif-panel-close{width:32px;height:32px;border-radius:8px;border:none;background:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center}
.gif-panel-close:hover{background:var(--bg-hover);color:var(--text-primary)}
.gif-tabs{display:flex;gap:2px;padding:0 8px 4px;overflow-x:auto}
.gif-tab{padding:5px 12px;border:none;background:none;color:var(--text-muted);font-size:12px;font-family:inherit;cursor:pointer;border-radius:6px;white-space:nowrap;transition:all .15s}
.gif-tab:hover{color:var(--text-primary);background:var(--bg-hover)}
.gif-tab.active{color:var(--text-primary);background:var(--bg-active);font-weight:600}
.gif-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:4px;padding:4px 8px 8px;overflow-y:auto;flex:1}
.gif-grid .gif-item{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;aspect-ratio:1;border:1px solid var(--border);transition:all .15s}
.gif-grid .gif-item:hover{border-color:var(--accent);transform:scale(1.03)}
.gif-grid .gif-item img{width:100%;height:100%;object-fit:cover;display:block}
.gif-grid .gif-item .gif-save-btn{position:absolute;top:4px;right:4px;width:26px;height:26px;border-radius:6px;background:rgba(0,0,0,.6);border:none;color:#fff;cursor:pointer;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);transition:background .15s}
.gif-grid .gif-item:hover .gif-save-btn{display:flex}
.gif-grid .gif-item .gif-save-btn:hover{background:var(--accent)}
.gif-grid .gif-item .gif-save-btn.saved{display:flex;color:var(--accent)}
.gif-grid .gif-empty{grid-column:1/-1;text-align:center;padding:30px;color:var(--text-muted);font-size:13px}

/* ===================== GAMES ===================== */
.games-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:12px 0 0}
.game-card.mil{background:#1e1e1e;border:1px solid #333;border-radius:12px;padding:20px 10px;text-align:center;cursor:pointer;transition:all .15s}
.game-card.mil:hover{background:#2a2a2a;border-color:#555;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.3)}
.game-card-icon{margin-bottom:8px;position:relative;z-index:1;display:flex;align-items:center;justify-content:center}
.game-card-name{font-size:14px;font-weight:800;color:#c8e6c9;letter-spacing:0.5px;text-transform:uppercase;position:relative;z-index:1}
.game-card-sub{font-size:10px;font-weight:600;color:#6b8e5a;margin-top:2px;position:relative;z-index:1}
#tetris-canvas{max-width:200px;aspect-ratio:1/2;width:100%;height:auto;background:#1a2418;border-radius:6px;border:1px solid #3a4a30}
#flappy-canvas{max-width:320px;aspect-ratio:4/5;width:100%;height:auto;background:#3a4a3a;border-radius:6px;border:1px solid #3a4a30}
#tanks-canvas{max-width:312px;width:100%;height:auto;aspect-ratio:1;background:#0a0a0a;border-radius:6px;border:1px solid #3a4a30}
.tanks-controls{display:none;padding:8px 16px 4px;align-items:center;justify-content:center;gap:16px}
.tanks-controls.visible{display:flex}
.tanks-dpad{display:grid;grid-template-columns:repeat(3,48px);grid-template-rows:repeat(3,42px);gap:3px;justify-content:center}
.tanks-fire-btn{width:64px;height:64px;border-radius:50%;border:2px solid #5a7d48;background:#2a3a24;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none;transition:all .1s}
.tanks-fire-btn:active{background:#4a6b3a;transform:scale(.9)}


/* ===================== SNAKE GAME (MILITARY) ===================== */
.snake-modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.92);z-index:1200;align-items:center;justify-content:center;padding:10px}
.snake-modal.open{display:flex}
.snake-modal-content{background:#1a1a1a;border:1px solid #333;border-radius:16px;max-width:380px;width:100%;max-height:95vh;overflow-y:auto;display:flex;flex-direction:column}
.snake-header{padding:12px 16px 8px;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}
.snake-header-left{display:flex;align-items:center;gap:8px}
.snake-header-left .snake-icon{font-size:18px}
.snake-header-title{font-size:15px;font-weight:800;letter-spacing:1.5px;color:#8bb87a;text-transform:uppercase}
.snake-close{background:none;border:none;color:#6b8e5a;cursor:pointer;padding:4px}
.snake-close:hover{color:#c8e6c9}
.snake-stats{display:flex;justify-content:center;gap:24px;padding:0 16px 10px;border-bottom:1px solid #2a3a24;position:relative;z-index:1}
.snake-stat{display:flex;flex-direction:column;align-items:center;gap:1px}
.snake-stat-label{font-size:9px;color:#6b8e5a;text-transform:uppercase;letter-spacing:0.5px;font-weight:700}
.snake-stat-value{font-size:20px;font-weight:800;color:#c8e6c9}
.snake-canvas-wrap{position:relative;display:flex;justify-content:center;padding:12px 16px 8px;z-index:1}
#snake-canvas{background:#1a2e1a;border-radius:6px;border:1px solid #3a4a30;width:100%;max-width:320px;aspect-ratio:1;height:auto}
.snake-overlay{position:absolute;top:12px;left:16px;right:16px;bottom:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(15,25,15,.94);border-radius:6px;gap:10px;padding:16px;z-index:2}
.snake-overlay.hidden{display:none}
.snake-overlay-title{font-size:22px;font-weight:800;color:#c8e6c9;letter-spacing:2px}
.snake-overlay-sub{font-size:12px;color:#7a9a6a;text-align:center}
.snake-levels{display:flex;flex-direction:column;gap:5px;width:100%;max-width:200px}
.snake-level-btn{padding:9px 12px;border:1px solid #3a4a30;border-radius:8px;background:#1e2e1c;color:#a0c090;font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}
.snake-level-btn:hover,.snake-level-btn:active{background:#4a6b3a;border-color:#5a7d48;color:#e0edd8}
.snake-level-btn.mil-btn{text-transform:uppercase;letter-spacing:0.5px;font-weight:700}
.snake-controls{display:none;grid-template-columns:repeat(3,56px);grid-template-rows:repeat(3,48px);justify-content:center;gap:4px;padding:8px 16px 4px;position:relative;z-index:1}
.snake-controls.visible{display:grid}
.snake-ctrl-btn{border:1px solid #3a4a30;border-radius:10px;background:#1e2e1c;color:#8bb87a;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none}
.snake-ctrl-btn:active{background:#4a6b3a;color:#e0edd8;transform:scale(.9)}
.snake-lb-toggle{text-align:center;padding:10px;font-size:12px;font-weight:600;color:#6b8e5a;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;border-top:1px solid #2a3a24;transition:color .15s;position:relative;z-index:1}
.snake-lb-toggle:hover{color:#8bb87a}
.snake-lb{padding:0 16px 12px;max-height:200px;overflow-y:auto;position:relative;z-index:1}
.snake-lb-item{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid #243020}
.snake-lb-item:last-child{border:none}
.snake-lb-pos{width:22px;text-align:center;font-weight:800;font-size:13px;color:#d4a017}
.snake-lb-name{flex:1;font-weight:600;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#a0c090}
.snake-lb-score{font-weight:800;color:#8bb87a;font-size:13px}
.snake-lb-tabs{display:flex;gap:3px;padding:0 0 8px;overflow-x:auto;flex-wrap:nowrap}
.snake-lb-tab{padding:5px 10px;border:1px solid #3a4a30;border-radius:6px;background:#1e2e1c;color:#6b8e5a;font-family:inherit;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}
.snake-lb-tab.active{background:#4a6b3a;border-color:#5a7d48;color:#e0edd8}
.snake-lb-tab:hover:not(.active){background:#2a3a24;color:#a0c090}
@media(max-width:380px){.snake-controls.visible{grid-template-columns:repeat(3,50px);grid-template-rows:repeat(3,42px)}.snake-modal-content{border-radius:10px}}

/* ===================== CONTEST ===================== */
.contest-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:linear-gradient(135deg,rgba(233,30,99,.08),rgba(255,160,0,.08));border-top:1px solid var(--border);gap:10px;flex-wrap:wrap}
.contest-bar-info{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.contest-bar-info .contest-active-dot{width:8px;height:8px;border-radius:50%;background:#4caf50;animation:pulse 1.5s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.contest-bar-actions{display:flex;gap:8px;flex-shrink:0}
.contest-btn{padding:8px 16px;border:none;border-radius:8px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s}
.contest-btn.primary{background:var(--accent);color:#fff}
.contest-btn.primary:hover{filter:brightness(1.15)}
.contest-btn.gold{background:linear-gradient(135deg,#ffa000,#e91e63);color:#fff}
.contest-btn.gold:hover{filter:brightness(1.15)}
.contest-btn.outline{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}
.contest-btn.outline:hover{background:var(--bg-hover);color:var(--text-primary)}
.contest-modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:1100;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}
.contest-modal.open{display:flex}
.contest-modal-content{background:var(--bg-primary);border:1px solid var(--border);border-radius:16px;padding:24px;max-width:440px;width:100%;max-height:80vh;overflow-y:auto}
.contest-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.contest-modal-header h3{display:flex;align-items:center;gap:8px;font-size:18px;color:var(--text-primary);margin:0}
.contest-modal-header button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}
.contest-modal-header button:hover{color:var(--text-primary)}
.msg-contest{border-radius:14px;overflow:hidden;margin:4px 0}
.msg-contest.start{background:linear-gradient(135deg,rgba(233,30,99,.12),rgba(255,160,0,.12));border:1px solid rgba(233,30,99,.25);padding:16px}
.msg-contest.end{background:linear-gradient(135deg,rgba(255,160,0,.12),rgba(76,175,80,.12));border:1px solid rgba(255,160,0,.25);padding:16px}
.msg-contest .contest-title{font-size:16px;font-weight:800;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.msg-contest .contest-conditions{font-size:14px;line-height:1.5;white-space:pre-wrap;color:var(--text-primary)}
.msg-contest .contest-winner{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:14px;font-weight:600}
.msg-contest .contest-winner .place{min-width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff}
.msg-contest .contest-winner .place.p1{background:linear-gradient(135deg,#ffd700,#ffa000)}
.msg-contest .contest-winner .place.p2{background:linear-gradient(135deg,#c0c0c0,#90a4ae)}
.msg-contest .contest-winner .place.p3{background:linear-gradient(135deg,#cd7f32,#a1887f)}
.msg-contest .contest-winner .place.other{background:var(--bg-active)}
.contest-input-hint{text-align:center;padding:16px;color:var(--text-muted);font-size:13px;border-top:1px solid var(--border);background:linear-gradient(135deg,rgba(233,30,99,.04),rgba(255,160,0,.04))}

/* ===================== RESPONSIVE ===================== */
@media(max-width:768px){
  .sidebar{width:100%;max-width:100%;height:100vh;height:100dvh}
  .chat-main{display:none}
  .chat-layout.room-open .sidebar{display:none}
  .chat-layout.room-open .chat-main{display:flex;height:100vh;height:100dvh}
  .chat-header .back-btn{display:flex!important}
  .room-info-panel{width:100vw}
  .chat-layout{height:100vh;height:100dvh}
}
.back-btn{display:none;width:40px;height:40px;border-radius:10px;border:none;background:none;color:var(--text-secondary);cursor:pointer;align-items:center;justify-content:center}
.back-btn:hover{background:var(--bg-hover);color:var(--text-primary)}
.back-btn svg{width:20px;height:20px}
.loading{display:flex;align-items:center;justify-content:center;padding:20px}
.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===================== POPUP NOTIFICATIONS ===================== */
#popup-notifications{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-width:360px;width:calc(100vw - 40px);pointer-events:none}
.popup-notification{background:var(--bg-primary);border:1px solid var(--border-accent);border-radius:14px;padding:12px 14px;box-shadow:0 8px 30px rgba(0,0,0,.5);cursor:pointer;pointer-events:auto;animation:popIn .3s ease;transition:opacity .4s,transform .4s}
.popup-notification.hiding{opacity:0;transform:translateX(60px)}
.popup-notification:hover{border-color:var(--accent);background:var(--bg-hover)}
@keyframes popIn{from{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
.popup-notif-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.popup-notif-icon{width:32px;height:32px;border-radius:10px;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.popup-notif-info{flex:1;min-width:0}
.popup-notif-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.popup-notif-from{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.popup-notif-close{width:28px;height:28px;border-radius:8px;border:none;background:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.popup-notif-close:hover{background:var(--bg-active);color:var(--text-primary)}
.popup-notif-text{font-size:13px;color:var(--text-secondary);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:768px){#popup-notifications{bottom:70px;right:10px;left:10px;max-width:none;width:auto}}
@media(max-width:480px){.profile-modal-content{padding:16px;max-height:100%;border-radius:0;width:100%;max-width:100vw;margin:0}.profile-modal{padding:0;align-items:stretch}}

/* ===================== LIGHTBOX ===================== */
.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:3000;display:none;align-items:center;justify-content:center;flex-direction:column}
.lightbox-overlay.open{display:flex}
.lightbox-overlay img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:8px;user-select:none}
.lightbox-toolbar{position:absolute;top:0;right:0;display:flex;gap:8px;padding:16px;z-index:1}
.lightbox-btn{width:44px;height:44px;border-radius:12px;border:none;background:rgba(255,255,255,.12);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);transition:background .15s}
.lightbox-btn:hover{background:rgba(255,255,255,.25)}

/* ===================== FORWARD MODAL ===================== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:2500;display:flex;align-items:center;justify-content:center;padding:20px}
.forward-modal{background:var(--bg-primary);border-radius:16px;width:100%;max-width:380px;max-height:70vh;display:flex;flex-direction:column;border:1px solid var(--border);overflow:hidden}
.forward-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border)}
.forward-modal-header h3{margin:0;font-size:16px}
.forward-modal-list{overflow-y:auto;flex:1;padding:4px 0}
.forward-room-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .12s}
.forward-room-item:hover{background:var(--bg-hover)}
.forward-room-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.forward-room-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ===================== REPORT MODAL ===================== */
.report-modal{background:var(--bg-primary);border-radius:16px;width:100%;max-width:400px;border:1px solid var(--border);overflow:hidden}
.report-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.report-modal-header h3{margin:0;font-size:16px}
.report-modal-body{padding:16px 20px}
.report-reason{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;cursor:pointer;font-size:14px;transition:background .12s;margin-bottom:4px}
.report-reason:hover{background:var(--bg-hover)}
.report-reason input[type="radio"]{accent-color:var(--accent);width:16px;height:16px;flex-shrink:0}
.report-modal-actions{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border)}
