:root{--bg: #0f0f0f;--surface: #1a1a1a;--surface2: #222222;--accent: #4f8ef7;--male: #3a7bd5;--female: #e8547a;--text: #e8e8e8;--text-dim: #888888;--border: #2a2a2a;--radius: 12px;--transition: .15s ease}*,*:before,*:after{box-sizing:border-box}body{margin:0;font:15px system-ui,-apple-system,sans-serif;color:var(--text);background:var(--bg)}.auth-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:16px}.auth-card{width:100%;max-width:480px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px}.auth-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.auth-card h1{margin:0 0 6px;font-size:22px;font-weight:700}.how-it-works-link{display:inline-flex;align-items:center;gap:5px;background:none;border:1px solid var(--border);border-radius:20px;padding:4px 12px 4px 10px;margin:0 0 18px;font:inherit;font-size:12px;font-weight:500;color:var(--text-dim);cursor:pointer;transition:border-color var(--transition),color var(--transition),background var(--transition);letter-spacing:.01em}.how-it-works-link:before{content:"ℹ";font-size:12px}.how-it-works-link:hover{border-color:var(--accent);color:var(--text);background:#4f8ef712}.auth-card .subtitle{margin:0 0 28px;color:var(--text-dim);font-size:14px}.gender-buttons{display:flex;gap:12px}.gender-btn{flex:1;padding:18px 12px;font-size:16px;font-weight:600;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface2);color:var(--text);cursor:pointer;transition:border-color var(--transition),background var(--transition)}.gender-btn:hover{border-color:var(--accent);background:#1e2a3a}.gender-btn.male:hover{border-color:var(--male)}.gender-btn.female:hover{border-color:var(--female)}.name-picker-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.back-btn{background:none;border:none;color:var(--text-dim);font-size:14px;cursor:pointer;padding:4px 0;transition:color var(--transition);text-decoration:underline;text-underline-offset:3px}.back-btn:hover{color:var(--text)}.name-picker-header h2{margin:0;font-size:18px;font-weight:600}.spinner{display:flex;justify-content:center;padding:32px 0}.spinner:after{content:"";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)}}.name-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.name-btn{padding:10px 8px;font-size:14px;font-weight:500;border:1px solid var(--border);border-radius:8px;background:var(--surface2);color:var(--text);cursor:pointer;transition:border-color var(--transition),background var(--transition);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.name-btn:hover{border-color:var(--accent);background:#1e2a3a}.name-btn.male:hover{border-color:var(--male);background:#1a2744}.name-btn.female:hover{border-color:var(--female);background:#2e1820}.error-msg{margin-top:16px;color:var(--female);font-size:14px}.chat-screen{display:flex;flex-direction:column;height:100vh}.chat-header{height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:var(--surface2);border-bottom:1px solid var(--border);flex-shrink:0;gap:12px}.chat-header-left{display:flex;align-items:center;gap:10px;overflow:hidden}.chat-header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.chat-username{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gender-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:12px;font-weight:600;flex-shrink:0}.gender-badge.male{background:var(--male);color:#fff}.gender-badge.female{background:var(--female);color:#fff}.online-badge{font-size:12px;color:var(--text-dim);padding:2px 8px;border-radius:10px;background:var(--surface);border:1px solid var(--border);flex-shrink:0;display:inline-flex;align-items:center;gap:6px}.online-dot{width:8px;height:8px;border-radius:50%;background:#4caf50;flex-shrink:0;animation:pulse-dot 2s ease-in-out infinite}.ws-status{font-size:12px;color:var(--text-dim);padding:2px 8px;border-radius:10px;background:var(--surface);border:1px solid var(--border);flex-shrink:0;display:inline-flex;align-items:center;gap:6px}.ws-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ws-status-reconnecting .ws-dot{animation:pulse-dot 1s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.25}}.logout-btn{padding:6px 14px;font-size:13px;font-weight:600;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text-dim);cursor:pointer;transition:border-color var(--transition),color var(--transition);white-space:nowrap}.logout-btn:hover{border-color:var(--female);color:var(--female)}.lang-switcher{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;flex-shrink:0}.lang-btn{padding:4px 10px;font-size:12px;font-weight:600;border:none;background:transparent;color:var(--text-dim);cursor:pointer;transition:background var(--transition),color var(--transition);line-height:1.4}.lang-btn+.lang-btn{border-left:1px solid var(--border)}.lang-btn:hover{background:var(--surface2);color:var(--text)}.lang-btn.active{background:var(--accent);color:#fff}.message-list{flex:1;overflow-y:auto;padding:12px 16px;background:#111;display:flex;flex-direction:column;gap:6px}.message-list-empty{color:var(--text-dim);font-size:14px;text-align:center;margin-top:32px}.chat-input-bar{background:var(--surface2);border-top:1px solid var(--border);padding:12px;display:flex;gap:10px;align-items:flex-end;flex-shrink:0}.chat-input-wrap{flex:1;display:flex;flex-direction:column;gap:4px}.input-footer{display:flex;align-items:baseline;justify-content:space-between;min-height:18px}.input-error{margin:0;color:var(--female);font-size:13px}.char-counter{margin-left:auto;font-size:12px;color:var(--text-muted, #888);white-space:nowrap;transition:color .2s}.char-counter--warn{color:#e6a817}.char-counter--max{color:var(--female)}.msg-expand-btn{display:inline;background:none;border:none;padding:0;margin-left:6px;color:var(--accent);font:inherit;font-size:.85em;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.msg-expand-btn:hover{opacity:.75}.chat-textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:10px 12px;resize:none;font:inherit;font-size:15px;line-height:1.5;min-height:42px;max-height:220px;overflow-y:auto;overflow-x:hidden;transition:border-color var(--transition);box-sizing:border-box}.chat-textarea:focus{border-color:var(--accent);outline:none}.chat-textarea:disabled{opacity:.5}.send-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:10px 20px;cursor:pointer;font:inherit;font-weight:600;white-space:nowrap;transition:opacity var(--transition);flex-shrink:0}.send-btn:disabled{opacity:.4;cursor:not-allowed}.message-item{display:flex;flex-direction:column;max-width:70%}.message-item.own{align-self:flex-end;align-items:flex-end}.message-item.other{align-self:flex-start;align-items:flex-start}.message-bubble{padding:8px 12px;border-radius:10px;font-size:14px;line-height:1.5;word-break:break-word;white-space:pre-wrap}.message-item.own .message-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:3px}.message-item.own .message-bubble .msg-expand-btn{color:#fffc}.message-item.own .message-bubble .msg-expand-btn:hover{color:#fff;opacity:1}.message-item.other .message-bubble{background:var(--surface);color:var(--text);border-bottom-left-radius:3px}.message-meta{display:flex;align-items:center;gap:6px;margin-bottom:3px}.name-badge{display:inline-block;padding:1px 7px;border-radius:8px;font-size:11px;font-weight:600;color:#fff}.name-badge.male{background:var(--male)}.name-badge.female{background:var(--female)}.message-time{font-size:11px;color:var(--text-dim)}.toast-container{position:fixed;top:16px;right:16px;z-index:1000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{background:#2a2a2a;border:1px solid var(--border);border-radius:8px;padding:10px 16px;color:var(--text);font-size:14px;max-width:280px;animation:toast-slide-in .2s ease}@keyframes toast-slide-in{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.message-item.admin-msg{align-self:center;max-width:82%;width:100%;align-items:center}.name-badge.admin-badge{background:#b8860b;color:#fff}.message-bubble.admin-bubble{background:#d4a0171f;border:1px solid #d4a017;color:var(--text);text-align:center;width:100%;font-weight:500}.admin-title{color:#d4a017;font-weight:700}.admin-nav-btn{padding:6px 14px;font-size:13px;font-weight:600;border:1px solid #d4a017;border-radius:8px;background:transparent;color:#d4a017;cursor:pointer;transition:background var(--transition),color var(--transition);white-space:nowrap}.admin-nav-btn:hover{background:#d4a017;color:#000}.admin-nav-btn--danger{border-color:var(--female);color:var(--female)}.admin-nav-btn--danger:hover{background:var(--female);color:#fff}.admin-send-label{font-size:12px;color:#d4a017;font-weight:600;white-space:nowrap;align-self:center;flex-shrink:0}.admin-view-item .admin-meta{flex-wrap:wrap;gap:6px}.sender-ip{font-size:11px;color:var(--text-dim);font-family:monospace;display:inline-flex;align-items:center;gap:6px}.ban-btn{padding:1px 7px;font-size:11px;font-weight:700;border:1px solid #f44336;border-radius:6px;background:transparent;color:#f44336;cursor:pointer;transition:background var(--transition),color var(--transition);line-height:1.4}.ban-btn:hover{background:#f44336;color:#fff}.banned-list{flex:1;overflow-y:auto;padding:16px;background:#111;display:flex;flex-direction:column;gap:8px}.banned-entry{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.banned-ip{font-family:monospace;font-size:14px;color:var(--text);font-weight:600;flex:1}.banned-ttl{font-size:12px;color:var(--text-dim);flex-shrink:0}.unban-btn{padding:5px 14px;font-size:13px;font-weight:600;border:1px solid #4caf50;border-radius:8px;background:transparent;color:#4caf50;cursor:pointer;transition:background var(--transition),color var(--transition);white-space:nowrap;flex-shrink:0}.unban-btn:hover{background:#4caf50;color:#fff}.support-row{margin-top:20px;display:flex;justify-content:center}.support-link{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:500;color:var(--text-dim);text-decoration:none;padding:5px 12px;border-radius:20px;border:1px solid transparent;transition:color var(--transition),border-color var(--transition),background var(--transition)}.support-link:hover{color:#e8547a;border-color:#e8547a4d;background:#e8547a0f}.support-heart{font-size:12px;transition:color var(--transition)}.support-link:hover .support-heart{color:#e8547a}.disclaimer-footer{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:4px}.disclaimer-notice{margin:0;font-size:12px;color:var(--text-dim);text-align:center}.disclaimer-link{background:none;border:none;padding:0;color:var(--text-dim);font-size:12px;cursor:pointer;text-decoration:underline;text-underline-offset:2px;transition:color var(--transition);font-family:inherit}.disclaimer-link:hover{color:var(--text)}.disclaimer-link--inline{display:inline}.modal-overlay{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:500;padding:16px;animation:modal-fade-in .15s ease}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-card{width:100%;max-width:520px;max-height:82vh;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;animation:modal-slide-up .15s ease}@keyframes modal-slide-up{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0;flex-shrink:0}.modal-title{margin:0;font-size:18px;font-weight:700}.modal-close-btn{background:none;border:none;color:var(--text-dim);font-size:16px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background var(--transition),color var(--transition);line-height:1;flex-shrink:0}.modal-close-btn:hover{background:var(--surface2);color:var(--text)}.modal-body{padding:16px 24px 24px;overflow-y:auto;font-size:14px;line-height:1.7;color:var(--text)}.modal-intro{margin:0 0 12px;color:var(--text-dim)}.modal-list{margin:0 0 16px;padding-left:22px;display:flex;flex-direction:column;gap:10px}.modal-points-heading{margin:4px 0 10px;font-weight:600;font-size:14px;color:var(--text)}.modal-points{margin:0 0 16px;padding-left:20px;display:flex;flex-direction:column;gap:10px;font-size:14px;line-height:1.65}.modal-footer-note{margin:0;color:var(--text-dim);font-style:italic}@media(max-width:480px){.name-grid{grid-template-columns:repeat(2,1fr)}.chat-username{max-width:120px}.message-item{max-width:88%}}
