:root{--primary:#7c3aed;--primary-light:#a78bfa;--primary-dark:#5b21b6;--secondary:#ec4899;--secondary-light:#f472b6;--accent:#06b6d4;--bg-primary:#0f0f1a;--bg-secondary:#1a1a2e;--bg-tertiary:#252542;--bg-glass:rgba(26, 26, 46, 0.8);--bg-glass-light:rgba(37, 37, 66, 0.6);--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--color-male:#5850ff;--color-female:#ff00cf;--color-other:#ff8020;--success:#22c55e;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--border-color:rgba(255, 255, 255, 0.1);--border-radius:12px;--border-radius-sm:8px;--border-radius-lg:16px;--shadow-sm:0 2px 8px rgba(0, 0, 0, 0.3);--shadow-md:0 4px 16px rgba(0, 0, 0, 0.4);--shadow-lg:0 8px 32px rgba(0, 0, 0, 0.5);--shadow-glow:0 0 20px rgba(124, 58, 237, 0.3);--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--header-height:60px;--sidebar-width:260px;--user-panel-width:240px;--input-height:56px;--font-size-messages:14px;--transition-fast:150ms ease;--transition-normal:250ms ease;--transition-slow:400ms ease;--z-sidebar:100;--z-header:200;--z-overlay:500;--z-modal:600;--z-toast:700}.theme-light{--bg-primary:#f8fafc;--bg-secondary:#ffffff;--bg-tertiary:#f1f5f9;--bg-glass:rgba(255, 255, 255, 0.9);--bg-glass-light:rgba(241, 245, 249, 0.8);--text-primary:#1e293b;--text-secondary:#475569;--text-muted:#94a3b8;--border-color:rgba(0, 0, 0, 0.1);--shadow-sm:0 2px 8px rgba(0, 0, 0, 0.08);--shadow-md:0 4px 16px rgba(0, 0, 0, 0.12);--shadow-lg:0 8px 32px rgba(0, 0, 0, 0.16);--shadow-glow:0 0 20px rgba(124, 58, 237, 0.2)}.btn-theme-toggle .icon-sun{display:flex}.btn-theme-toggle .icon-moon,.theme-light .btn-theme-toggle .icon-sun{display:none}.theme-light .btn-theme-toggle .icon-moon{display:flex}.login-container{position:relative}.login-container>.btn-theme-toggle{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast);z-index:1}.login-container>.btn-theme-toggle:hover{background:var(--bg-glass)}.login-container>.btn-theme-toggle svg{width:18px;height:18px}*,::after,::before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;font-size:1rem;line-height:1.5;color:var(--text-primary);background:var(--bg-primary);background-image:radial-gradient(ellipse at 20% 0,rgba(124,58,237,.15) 0,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(236,72,153,.15) 0,transparent 50%);min-height:100vh;overflow:hidden}a{color:var(--primary-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary)}button{font-family:inherit;cursor:pointer;border:none;background:0 0}input,select,textarea{font-family:inherit;font-size:1rem}ul{list-style:none}.hidden{display:none!important}.screen{position:fixed;inset:0;display:flex;transition:opacity var(--transition-normal)}.screen.hidden{opacity:0;pointer-events:none}.ban-overlay{position:fixed;inset:0;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;z-index:9999}.ban-overlay.hidden{display:none}.ban-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:40px 32px;max-width:420px;width:90%;text-align:center;box-shadow:var(--shadow-lg)}.ban-modal-logo{width:100px;height:auto;margin-bottom:16px;opacity:.85}.ban-modal-title{color:var(--danger,#e74c3c);font-size:1.4rem;font-weight:700;margin:0 0 24px}.ban-modal-body p{display:flex;align-items:baseline;gap:10px;margin:10px 0;font-size:.95rem;color:var(--text-primary);text-align:left}.ban-label{color:var(--text-secondary);font-weight:600;min-width:64px;flex-shrink:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:.9375rem;font-weight:500;border-radius:var(--border-radius-sm);transition:all var(--transition-fast)}.btn-primary{background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);color:#fff;box-shadow:var(--shadow-sm),var(--shadow-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-glass-light)}.btn-small{padding:var(--spacing-xs) var(--spacing-sm);font-size:.8125rem}.btn-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--border-radius-sm);color:var(--text-secondary);transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-glass-light);color:var(--text-primary)}.btn-icon svg{width:20px;height:20px}.auth-tabs{display:flex;gap:2px;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);padding:3px;margin-bottom:var(--spacing-lg)}.auth-tab{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:0 0;border:none;border-radius:calc(var(--border-radius-sm) - 2px);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.auth-tab.active{background:var(--bg-secondary);color:var(--text-primary);box-shadow:0 1px 3px rgba(0,0,0,.2)}.auth-tab:hover:not(.active){color:var(--text-primary)}.btn-connect,.btn-register{width:100%;padding:var(--spacing-md);font-size:1rem;position:relative;overflow:hidden}.btn-connect.loading .btn-text,.btn-register.loading .btn-text{opacity:0}.btn-connect.loading .btn-loader,.btn-register.loading .btn-loader{opacity:1}.btn-loader{position:absolute;width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;opacity:0;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}#login-screen{display:flex;align-items:center;justify-content:center;padding:var(--spacing-md)}.login-container{width:100%;max-width:400px;padding:var(--spacing-xl);background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.logo{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.logo-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);border-radius:var(--border-radius);font-size:1.5rem;font-weight:700;color:#fff}.logo-text{font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--primary-light) 0,var(--secondary-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{color:var(--text-secondary);font-size:.9375rem}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.form-group label .optional{font-weight:400;color:var(--text-muted)}.form-group input,.form-group select,.form-group textarea{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);transition:all var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(124,58,237,.2)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.input-hint{font-size:.75rem;color:var(--text-muted)}.form-row{display:flex;gap:var(--spacing-md)}.form-group-small{flex:1}.login-footer{margin-top:var(--spacing-lg);text-align:center}.login-footer a{font-size:.875rem;color:var(--text-muted)}.login-footer a:hover{color:var(--primary-light)}#chat-screen{flex-direction:column}.chat-header{display:flex;align-items:center;gap:var(--spacing-md);height:var(--header-height);padding:0 var(--spacing-md);background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);z-index:var(--z-header)}.btn-menu{display:none}.channel-info{flex:1;min-width:0}.channel-name{font-size:1.125rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.channel-topic{font-size:.8125rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4;max-height:1.4em}.channel-topic a{color:var(--primary-light);text-decoration:underline}.channel-topic a:hover{color:var(--primary)}.header-actions{display:flex;align-items:center;gap:var(--spacing-xs)}.btn-report-header svg{width:18px;height:18px}.btn-report-header:hover{background:rgba(239,68,68,.15)}.btn-cam-header svg{width:18px;height:18px}.btn-cam-header:hover{background:rgba(34,197,94,.15);color:#22c55e}.btn-cam-header.cam-active{color:#22c55e;background:rgba(34,197,94,.2)}.btn-cam-header.cam-active:hover{background:rgba(239,68,68,.15);color:#ef4444}.btn-id-header svg{width:18px;height:18px}.btn-id-header:hover{background:rgba(99,102,241,.15);color:var(--primary)}.btn-id-header.hidden{display:none}#btn-premium{color:var(--text-secondary)}#btn-premium svg{width:18px;height:18px}#btn-premium:hover{background:rgba(234,179,8,.15);color:#eab308}#btn-premium.btn-premium-active{color:#eab308}#btn-premium.btn-premium-active:hover{background:rgba(234,179,8,.15)}#btn-premium.hidden{display:none}.modal.modal-premium{max-width:560px;max-height:92vh}.premium-info,.premium-subscribe{display:flex;flex-direction:column;gap:var(--spacing-sm)}.premium-benefits{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;font-size:.8rem;color:var(--text-secondary)}.premium-benefits li::before{content:'★ ';color:#eab308}.premium-info .premium-benefits{grid-template-columns:1fr;gap:6px;font-size:.875rem}@media (max-width:480px){.premium-benefits{grid-template-columns:1fr}}.premium-active-msg{color:var(--text-secondary);font-size:.9rem;text-align:center;padding:var(--spacing-sm) 0}.premium-expiry{font-size:.85rem;text-align:center;padding:8px var(--spacing-md);border-radius:var(--border-radius);margin:0}.premium-expiry--active{background:rgba(34,197,94,.12);color:#4ade80;border:1px solid rgba(34,197,94,.25)}.premium-expiry--expired{background:rgba(234,179,8,.12);color:#fbbf24;border:1px solid rgba(234,179,8,.25)}.premium-gift-banner{background:rgba(124,58,237,.15);border:1px solid rgba(124,58,237,.35);border-radius:var(--border-radius);padding:10px var(--spacing-md);text-align:center;font-size:.9rem;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.premium-gift-banner strong{color:var(--primary)}.btn-gift-premium{background:linear-gradient(135deg,#7c3aed,#ec4899);color:#fff;border:none}.btn-gift-premium:hover{opacity:.9}.premium-payment-wrapper{display:flex;flex-direction:column;gap:0;border-radius:12px;overflow:hidden;border:1px solid var(--border-color);margin-top:var(--spacing-sm)}.premium-payment-wrapper .premium-expiry{border-radius:0;border-left:none;border-right:none;border-top:none;border-bottom:1px solid var(--border-color);font-size:.8rem;padding:10px var(--spacing-md)}.premium-payment-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);text-align:center;padding:8px var(--spacing-md);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);margin:0}.premium-sumup{width:100%;background:#fff;padding:0}.premium-sumup iframe,.premium-sumup>div{width:100%!important;display:block}.premium-secure-notice{font-size:.7rem;color:var(--text-muted);text-align:center;padding:6px var(--spacing-md);margin:0;border-top:1px solid var(--border-color);background:var(--bg-secondary);opacity:.8}.premium-payment-checking,.premium-payment-error,.premium-payment-success{text-align:center;padding:var(--spacing-lg) var(--spacing-md);font-size:.9rem;margin:0;background:var(--bg-secondary)}.premium-payment-checking{color:var(--text-secondary)}.premium-payment-success{color:#4ade80}.premium-payment-error{color:#f87171}.identify-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.identify-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.5;margin:0}.identify-form .form-group{display:flex;flex-direction:column;gap:4px}.identify-form label{font-size:.8rem;color:var(--text-muted);font-weight:500}.identify-form .input-text{padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.9rem;font-family:inherit;transition:border-color .2s}.identify-form .input-text:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,.15)}.identify-form .checkbox-label{flex-direction:row;align-items:center;gap:8px;font-size:.85rem;color:var(--text-secondary);cursor:pointer}.badge{display:flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;background:var(--primary);border-radius:9px;font-size:.6875rem;font-weight:600;color:#fff;position:absolute;top:4px;right:4px}.btn-icon{position:relative}.chat-container{display:flex;flex:1;min-height:0}.sidebar{display:flex;flex-direction:column;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:var(--z-sidebar)}.sidebar-section{padding:var(--spacing-md)}.sidebar-section-join{padding:var(--spacing-sm) var(--spacing-md);flex-shrink:0}.sidebar-section-scroll{flex:1;overflow-y:auto;padding:var(--spacing-sm) var(--spacing-md)}.sidebar-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--spacing-sm);display:flex;align-items:center;justify-content:space-between}.btn-close-all-queries{display:none;cursor:pointer;font-size:1.1rem;line-height:1;color:var(--text-muted);padding:0 4px;border-radius:4px;transition:color .15s,background .15s}.btn-close-all-queries:hover{color:var(--error);background:rgba(239,68,68,.15)}.btn-close-all-queries.visible{display:inline-flex}.channel-list,.query-list{display:flex;flex-direction:column;gap:2px}.channel-item,.query-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.channel-item:hover,.query-item:hover{background:var(--bg-glass-light);color:var(--text-primary)}.channel-item.active,.query-item.active{background:linear-gradient(135deg,rgba(124,58,237,.2) 0,rgba(236,72,153,.2) 100%);color:var(--text-primary)}.channel-item .channel-icon{font-size:1rem;opacity:.7}.channel-item .channel-name,.query-item .channel-name{flex:1;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.channel-item .unread-count,.query-item .unread-count{min-width:20px;height:20px;padding:0 6px;background:var(--primary);border-radius:10px;font-size:.6875rem;font-weight:600;color:#fff;text-align:center;line-height:20px}.channel-item .btn-close-tab,.query-item .btn-close-tab{display:none;width:18px;height:18px;border-radius:50%;color:var(--text-muted);font-size:.75rem;line-height:18px;text-align:center;flex-shrink:0;transition:all var(--transition-fast)}.channel-item:hover .btn-close-tab,.query-item:hover .btn-close-tab{display:flex;align-items:center;justify-content:center}.channel-item .btn-close-tab:hover,.query-item .btn-close-tab:hover{background:rgba(239,68,68,.3);color:var(--error)}.query-item.offline .channel-name{color:#e74c3c}.channel-server-notices{border-bottom:1px solid rgba(255,0,0,.2);margin-bottom:4px;padding-bottom:6px}.channel-server-notices .channel-icon{color:red;font-weight:700}.channel-server-notices .channel-name{color:#f44;font-weight:600}.channel-server-notices.active{background:rgba(255,0,0,.15);border-left-color:red}.channel-server-notices:hover{background:rgba(255,0,0,.1)}.btn-join-channel{width:100%;margin-top:var(--spacing-sm);color:var(--text-muted);border:1px dashed var(--border-color);background:0 0}.btn-join-channel:hover{border-color:var(--primary);color:var(--primary-light)}.sidebar-footer{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-top:1px solid var(--border-color);background:var(--bg-tertiary)}.user-info{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-glass-light);background-size:cover;background-position:center;flex-shrink:0}.user-details{display:flex;flex-direction:column;min-width:0}.user-nick{font-size:.875rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-status{font-size:.75rem;color:var(--success)}.user-status.status-dnd{color:var(--danger,#ef4444)}.btn-user-settings{color:var(--text-muted)}.btn-user-settings:hover{color:var(--text-primary);background:var(--bg-glass-light)}.chat-main{display:flex;flex-direction:column;flex:1;min-width:0}.messages-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-md)}.messages-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.message{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--border-radius-sm);transition:background var(--transition-fast)}.message:hover{background:var(--bg-glass-light)}.message-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-tertiary);background-size:cover;background-position:center;flex-shrink:0}.message-content{flex:1;min-width:0}.message-grouped{padding-top:0;padding-bottom:0;margin-top:-4px}.message-avatar-spacer{width:36px;flex-shrink:0}.message-grouped .message-time-hover{opacity:.6;font-size:.6875rem;color:var(--text-muted);align-self:center;flex-shrink:0;transition:opacity var(--transition-fast)}.message-grouped:hover .message-time-hover{opacity:1}.message-header{display:flex;align-items:baseline;gap:var(--spacing-sm);margin-bottom:2px}.message-nick{font-weight:600;cursor:pointer;transition:color var(--transition-fast)}.message-nick:hover{text-decoration:underline}.message-nick.message-nick-mention{font-weight:400;text-decoration:underline}.message-nick.sex-male{color:var(--color-male)}.message-nick.sex-female{color:var(--color-female)}.message-nick.sex-other{color:var(--color-other)}.message-asl{font-size:.75rem;font-weight:400;color:var(--text-muted);margin-left:4px}.message-nick.nick-owner,.user-item-nick.nick-owner{color:red!important}.message-nick.nick-admin,.user-item-nick.nick-admin{color:#7f0000!important}.message-nick.nick-op,.user-item-nick.nick-op{color:#009300!important}.message-nick.nick-halfop,.user-item-nick.nick-halfop{color:#009393!important}.message-nick.nick-voice,.user-item-nick.nick-voice{color:#04c2fc!important}.user-group-title.group-staff{color:red;opacity:1}.user-group-title.group-animators{color:#04c2fc;opacity:1}.user-group-title.group-premium{color:#f5a623;opacity:1}.user-group-title.group-certified{color:#27ae60;opacity:1}.user-group-title.group-verified{color:#e67e22;opacity:1}.user-group-title.group-registered{color:#3498db;opacity:1}.user-item[data-group=premium] .user-item-nick{color:#f5a623}.message-time{font-size:.75rem;color:var(--text-secondary);opacity:.8}.hide-timestamps .message-time,.hide-timestamps .message-time-hover{display:none!important}.message-text{color:var(--text-primary);font-size:var(--font-size-messages);word-wrap:break-word;overflow-wrap:break-word}.message.message-action{--action-color:transparent;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-sm);animation:.3s ease-out actionSlideIn}.theme-dark .message.message-action{background:color-mix(in srgb,var(--action-color) 12%,transparent);border-left:3px solid color-mix(in srgb,var(--action-color) 40%,transparent)}.theme-light .message.message-action{background:color-mix(in srgb,var(--action-color) 8%,transparent);border-left:3px solid color-mix(in srgb,var(--action-color) 30%,transparent)}.message-action-inner{font-style:italic;color:var(--text-secondary)}.message.message-action .message-nick{font-style:normal;font-weight:600}.message.message-action .message-time-hover{font-style:normal}@keyframes actionSlideIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}.message.message-join,.message.message-kick,.message.message-mode,.message.message-nickchange,.message.message-part,.message.message-quit,.message.message-topic{padding:var(--spacing-xs) var(--spacing-sm)}.message.message-join .message-text,.message.message-kick .message-text,.message.message-mode .message-text,.message.message-nickchange .message-text,.message.message-part .message-text,.message.message-quit .message-text,.message.message-topic .message-text{font-size:.8125rem;color:var(--text-muted)}.message.message-join .message-nick{color:var(--success)}.message.message-part .message-nick,.message.message-quit .message-nick{color:var(--error)}.message.message-nickchange .message-nick{color:var(--info)}.message.message-mode .message-nick{color:var(--warning)}.message.message-topic .message-nick{color:var(--accent)}.message.message-kick .message-nick{color:var(--error)}.message.message-notice{background:rgba(59,130,246,.1);border-left:3px solid var(--info)}.message.message-highlight{background:rgba(124,58,237,.15);border-left:3px solid var(--primary)}.message.message-crosschan{background:var(--bg-glass);border-left:3px solid var(--text-secondary);padding-top:4px;padding-bottom:4px}.crosschan-source{display:inline-block;font-size:.72rem;font-weight:600;padding:1px 7px;border-radius:3px;margin-right:6px;cursor:pointer;transition:filter var(--transition-fast)}.crosschan-source:hover{filter:brightness(1.3)}.crosschan-source-chan{background:rgba(124,58,237,.2);color:var(--primary-light)}.crosschan-source-pm{background:rgba(243,156,18,.2);color:var(--warning,#f39c12)}.typing-indicator{display:flex;align-items:center;gap:6px;padding:2px var(--spacing-md);font-size:.75rem;color:var(--text-muted);min-height:18px}.typing-indicator.hidden{display:none}.typing-dots{display:inline-flex;gap:2px;align-items:center}.typing-dots span{width:4px;height:4px;border-radius:50%;background:var(--text-muted);animation:1.2s infinite typingBounce}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,100%,60%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-2px)}}.typing-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.input-container{display:flex;align-items:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-secondary);border-top:1px solid var(--border-color)}.input-actions{display:flex;gap:2px}.input-wrapper{flex:1;background:var(--bg-tertiary);border-radius:var(--border-radius);border:1px solid var(--border-color);transition:all var(--transition-fast)}.input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(124,58,237,.2)}#message-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:0 0;border:none;color:var(--text-primary);resize:none;max-height:120px}#message-input:focus{outline:0}.btn-send{background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);color:#fff}.btn-send:hover{transform:scale(1.05)}.msg-reply-btn{display:none;position:absolute;top:50%;right:6px;transform:translateY(-50%);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-muted);font-size:.8rem;padding:2px 6px;cursor:pointer;line-height:1;transition:all var(--transition-fast);z-index:1}.msg-reply-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.message{position:relative}.message:hover .msg-reply-btn{display:block}#reply-banner{display:flex;align-items:center;gap:6px;padding:6px 10px;background:rgba(124,58,237,.08);border-bottom:1px solid rgba(124,58,237,.25);border-radius:var(--border-radius) var(--border-radius) 0 0;font-size:.8rem;min-width:0}.reply-banner-icon{color:var(--primary);font-size:.9rem;flex-shrink:0}.reply-banner-nick{color:var(--primary);font-weight:600;flex-shrink:0}.reply-banner-text{color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.reply-banner-cancel{background:0 0;border:none;color:var(--text-muted);cursor:pointer;font-size:.75rem;padding:0 2px;flex-shrink:0;line-height:1;transition:color var(--transition-fast)}.reply-banner-cancel:hover{color:var(--danger)}.msg-quote-block{display:flex;flex-direction:column;background:var(--bg-secondary);border-left:3px solid var(--primary);border-radius:0 var(--border-radius-sm) var(--border-radius-sm) 0;padding:4px 8px;margin-bottom:4px;gap:1px;max-width:100%}.msg-quote-nick{font-size:.75rem;font-weight:700;color:var(--primary)}.msg-quote-text{font-size:.8rem;color:var(--text-muted);display:flex;flex-wrap:wrap;align-items:flex-start;gap:4px;max-width:100%;word-break:break-word}.quote-media-thumb{display:inline-block;position:relative;flex-shrink:0}.quote-media-thumb img{display:block;max-height:80px;max-width:120px;width:auto;height:auto;border-radius:var(--border-radius-sm);object-fit:cover}.quote-yt-thumb{position:relative}.quote-yt-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.9}.quote-media-link{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;color:var(--primary);text-decoration:none;padding:2px 6px;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);border:1px solid var(--border-color)}.quote-media-link:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.voice-player-compact{padding:4px 8px;gap:6px}.voice-player-compact .voice-player-btn{width:22px;height:22px;min-width:22px}.voice-player-compact .voice-player-wave{height:16px}.user-panel{display:flex;flex-direction:column;width:var(--user-panel-width);background:var(--bg-secondary);border-left:1px solid var(--border-color)}.user-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--border-color)}.user-panel-header-left{display:flex;align-items:center;gap:var(--spacing-sm);min-width:0}.user-panel-header h2{font-size:.875rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-panel-header-actions{display:flex;align-items:center;gap:2px}.btn-room-info{width:28px;height:28px;padding:4px;color:var(--text-muted);transition:color .15s}.btn-room-info:hover{color:var(--primary)}.btn-close-panel,.btn-room-info.hidden{display:none}.user-search{padding:var(--spacing-sm) var(--spacing-md)}.user-search-wrapper{position:relative;display:flex;align-items:center}.user-search input{width:100%;padding:var(--spacing-sm);padding-right:28px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.8125rem}.user-search input:focus{outline:0;border-color:var(--primary)}.user-search-clear{position:absolute;right:4px;background:0 0;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:2px 6px;line-height:1;border-radius:50%;transition:color .15s,background .15s}.user-search-clear:hover{color:var(--text-primary);background:var(--bg-tertiary)}.user-search-clear.hidden{display:none}.user-search-chips{display:flex;flex-wrap:nowrap;gap:3px;margin-top:6px;align-items:center}.user-search-chips .chip{padding:2px 6px;font-size:.65rem;font-weight:600;white-space:nowrap;flex-shrink:0;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:.15s;line-height:1.4}.user-search-chips .chip:hover{border-color:var(--primary);color:var(--text-primary);background:var(--bg-tertiary)}.user-search-chips .chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.user-search-chips .chip[data-filter="sex:H"].active{background:#5850ff;border-color:#5850ff}.user-search-chips .chip[data-filter="sex:F"].active{background:#ff00cf;border-color:#ff00cf}.user-search-chips .chip[data-filter="sex:A"].active{background:#ff8020;border-color:#ff8020}.chip-sep{width:1px;height:16px;background:var(--border-color);margin:0 2px}.user-search-count{font-size:.7rem;color:var(--primary);margin-top:4px;font-weight:500}.user-search-count.hidden{display:none}.query-profil-container{flex:1;overflow-y:auto;display:flex;flex-direction:column}.query-profil-container.hidden{display:none}.query-profil-card{width:100%;display:flex;flex-direction:column;flex:1}.query-profil-card .mini-profil-header{height:90px;min-height:90px;background-size:cover;background-position:center}.query-profil-card .mini-profil-avatar{width:72px;height:72px;margin:-36px auto 0;border-radius:50%;background-size:cover;background-position:center;border:3px solid var(--bg-secondary)}.query-profil-card .mini-profil-body{padding:var(--spacing-sm) var(--spacing-md) var(--spacing-md);text-align:center;display:flex;flex-direction:column;gap:var(--spacing-sm)}.query-profil-card .mini-profil-nick{font-size:1rem;font-weight:600}.query-profil-card .mini-profil-asl{font-size:.8125rem;color:var(--text-secondary)}.query-profil-card .mini-profil-away{font-size:.75rem;padding:3px 10px;border-radius:10px;background:rgba(251,191,36,.15);color:#fbbf24;display:inline-block;margin:0 auto}.query-profil-card .mini-profil-bio{font-size:.8125rem;color:var(--text-secondary);line-height:1.4;padding:var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--border-radius-sm)}.query-profil-card .mini-profil-whois{font-size:.75rem;color:var(--text-muted)}.query-profil-card .mini-profil-stats{display:flex;justify-content:center;gap:var(--spacing-lg);padding:var(--spacing-sm) 0}.query-profil-card .mini-profil-actions{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:0 var(--spacing-sm)}.query-profil-card .mini-profil-actions .btn{width:100%}.user-list-container{flex:1;overflow-y:auto;padding:var(--spacing-sm)}.user-list{display:flex;flex-direction:column;gap:2px}.user-group-title{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:var(--spacing-md) var(--spacing-sm) var(--spacing-xs);margin:0;border-top:1px solid rgba(255,255,255,.06);opacity:.7;list-style:none}.user-group-title:first-child{border-top:none;padding-top:var(--spacing-xs)}.user-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast)}.user-item:hover{background:var(--bg-glass-light)}.user-item-avatar{width:28px;height:28px;border-radius:50%;background:var(--bg-tertiary);background-size:cover;background-position:center;flex-shrink:0}.user-item-info{flex:1;min-width:0}.user-item-nick{font-size:.8125rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-item-nick.sex-male{color:var(--color-male)}.user-item-nick.sex-female{color:var(--color-female)}.user-item-nick.sex-other{color:var(--color-other)}.user-item-asl{font-size:.6875rem;color:var(--text-muted)}.user-item.away{opacity:.5}.user-item.away .user-item-nick::after{content:' (absent)';font-weight:400;color:var(--text-muted)}.user-item-mode{font-size:.75rem;font-weight:600}.user-item-mode.owner{color:red}.user-item-mode.admin{color:#7f0000}.user-item-mode.op{color:#009300}.user-item-mode.halfop{color:#009393}.user-item-mode.voice{color:#04c2fc}.overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);z-index:var(--z-overlay);opacity:1;transition:opacity var(--transition-normal)}.overlay.hidden{opacity:0;pointer-events:none}.mini-profil{width:100%;max-width:360px;background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);overflow:visible;transform:scale(.95);transition:transform var(--transition-normal)}.overlay:not(.hidden) .mini-profil{transform:scale(1)}.mini-profil-header{position:relative;height:100px;background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}.mini-profil-avatar{display:block;width:80px;height:80px;margin:-40px auto 0;border-radius:50%;border:4px solid var(--bg-glass);background-color:var(--bg-tertiary);background-size:cover;background-position:center;position:relative;z-index:2}.mini-profil-body{padding:var(--spacing-sm) var(--spacing-lg) var(--spacing-lg);text-align:center;background:var(--bg-glass);border-radius:0 0 var(--border-radius-lg) var(--border-radius-lg)}.mini-profil-nick{font-size:1.25rem;font-weight:700;margin-bottom:var(--spacing-xs)}.mini-profil-asl{font-size:.9375rem;color:var(--text-secondary);margin-bottom:var(--spacing-md)}.mini-profil-stats{display:flex;justify-content:center;gap:var(--spacing-lg);padding:var(--spacing-md) 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);margin-bottom:var(--spacing-md)}.mini-profil-stat{text-align:center}.mini-profil-stat-value{font-size:1.25rem;font-weight:700;color:var(--primary-light)}.mini-profil-stat-label{font-size:.6875rem;color:var(--text-muted);text-transform:uppercase}.mini-profil-actions{display:flex;gap:var(--spacing-sm)}.mini-profil-actions .btn{flex:1}.modal{width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-title{font-size:1.125rem;font-weight:600}.modal-content{padding:var(--spacing-lg);flex:1;overflow-y:auto;overflow-x:hidden}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color)}.wallops-modal{max-width:440px;border:1px solid rgba(255,165,0,.4);box-shadow:0 0 30px rgba(255,140,0,.2),var(--shadow-lg);animation:.25s wallops-appear}@keyframes wallops-appear{from{transform:scale(.92) translateY(-10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.wallops-modal-header{display:flex;align-items:center;gap:10px;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid rgba(255,165,0,.3);background:rgba(255,140,0,.07);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}.wallops-icon{font-size:1.4rem;flex-shrink:0}.wallops-modal-titles{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.wallops-modal-title{font-size:1rem;font-weight:700;color:#ffb347;margin:0}.wallops-modal-from{font-size:.75rem;color:var(--text-muted)}.wallops-close{flex-shrink:0}.wallops-modal-body{padding:var(--spacing-lg);font-size:.95rem;line-height:1.6;color:var(--text-primary);word-break:break-word}.wallops-modal-footer{display:flex;justify-content:flex-end;padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color)}.gift-modal{max-width:420px;border:2px solid rgba(236,72,153,.5);box-shadow:0 0 40px rgba(124,58,237,.3),0 0 20px rgba(236,72,153,.2),var(--shadow-lg);animation:.35s cubic-bezier(.34,1.56,.64,1) gift-appear;text-align:center;overflow:hidden}@keyframes gift-appear{from{transform:scale(.8) translateY(-20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.gift-modal-header{padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-md);background:linear-gradient(135deg,rgba(124,58,237,.25),rgba(236,72,153,.2));border-bottom:1px solid rgba(236,72,153,.3);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}.gift-modal-icon{font-size:3rem;display:block;animation:.8s infinite alternate gift-bounce}@keyframes gift-bounce{from{transform:translateY(0) rotate(-5deg)}to{transform:translateY(-8px) rotate(5deg)}}.gift-modal-title{font-size:1.4rem;font-weight:800;margin:8px 0 0;background:linear-gradient(135deg,#c084fc,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gift-modal-body{padding:var(--spacing-lg)}.gift-emojis{font-size:1.6rem;letter-spacing:6px;margin-bottom:var(--spacing-md);animation:2s infinite gift-shimmer}@keyframes gift-shimmer{0%,100%{opacity:1}50%{opacity:.5}}.gift-modal-gifter{font-size:1.15rem;font-weight:700;color:#c084fc;margin:0 0 var(--spacing-sm)}.gift-modal-desc{font-size:.95rem;color:var(--text-secondary);line-height:1.6;margin:0}.gift-modal-footer{padding:var(--spacing-sm) var(--spacing-lg) var(--spacing-lg)}.btn-gift-thanks{width:100%;font-size:1rem;font-weight:700;padding:12px;background:linear-gradient(135deg,#7c3aed,#ec4899);border:none;border-radius:var(--border-radius-md);color:#fff;cursor:pointer;transition:opacity .2s}.btn-gift-thanks:hover{opacity:.9}.toast-container{position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-sm);z-index:var(--z-toast);pointer-events:none}.toast{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-glass);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);box-shadow:var(--shadow-md);pointer-events:auto;animation:.3s toastIn}.toast.toast-out{animation:.3s forwards toastOut}@keyframes toastIn{from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes toastOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}.toast-icon{width:20px;height:20px;flex-shrink:0}.toast.success .toast-icon{color:var(--success)}.toast.error .toast-icon{color:var(--error)}.toast.warning .toast-icon{color:var(--warning)}.toast.info .toast-icon{color:var(--info)}.circc-welcome-banner{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);width:min(520px,calc(100vw - 32px));background:var(--bg-secondary,#1e2130);border:1px solid var(--border,#2e3347);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.45);z-index:9999;overflow:hidden;opacity:0;transition:opacity .35s,transform .35s;pointer-events:none}.circc-welcome-banner.wb-visible{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:all}.circc-welcome-banner.wb-out{opacity:0;transform:translateX(-50%) translateY(20px);pointer-events:none}.circc-welcome-banner.wb-visitor{border-top:3px solid var(--info,#4f8ef7)}.circc-welcome-banner.wb-member{border-top:3px solid #f5a623}.wb-body{display:flex;align-items:flex-start;gap:14px;padding:18px 20px 14px}.wb-icon{font-size:2rem;line-height:1;flex-shrink:0;margin-top:2px}.wb-content{flex:1;min-width:0}.wb-title{font-size:.95rem;font-weight:700;color:var(--text-primary,#e8eaf0);margin-bottom:5px}.wb-text{font-size:.82rem;color:var(--text-secondary,#9ba3bf);line-height:1.5;margin-bottom:12px}.wb-actions{display:flex;gap:8px;flex-wrap:wrap}.wb-btn{padding:7px 16px;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;border:none;transition:opacity .15s;text-decoration:none;display:inline-block}.wb-btn:hover{opacity:.85}.wb-btn-primary{background:var(--accent,#4f8ef7);color:#fff}.wb-visitor .wb-btn-primary{background:var(--info,#4f8ef7)}.wb-member .wb-btn-primary{background:#f5a623;color:#1a1a2e}.wb-btn-secondary{background:0 0;color:var(--text-secondary,#9ba3bf);border:1px solid var(--border,#2e3347)}.wb-progress{height:3px;background:rgba(255,255,255,.08)}.wb-bar{height:100%;width:100%;background:var(--accent,#4f8ef7);animation:60s linear forwards wbCountdown;transform-origin:left}.wb-visitor .wb-bar{background:var(--info,#4f8ef7)}.wb-member .wb-bar{background:#f5a623}@keyframes wbCountdown{from{width:100%}to{width:0%}}.toast-message{font-size:.875rem;color:var(--text-primary)}.message-media{display:block;margin-top:6px;border-radius:8px;overflow:hidden;max-width:100%}.message-image{display:inline-block;max-width:400px}.message-image img{display:block;max-width:100%;max-height:350px;border-radius:8px;object-fit:contain;cursor:pointer;transition:opacity var(--transition-fast)}.message-image img:hover{opacity:.9}.message-image.error img{display:none}.message-video{max-width:480px;min-width:280px}.message-video video{display:block;width:100%;max-height:400px;border-radius:8px;background:#000}.message-audio{max-width:400px}.message-audio audio{display:block;width:100%}.message-file{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-tertiary);border-radius:8px;color:var(--text-primary);text-decoration:none;transition:background var(--transition-fast)}.message-file:hover{background:var(--bg-glass-light)}.message-file .file-icon{display:flex;align-items:center;color:var(--text-secondary)}.message-file .file-text{font-size:.875rem}.message-uploaded-file{max-width:400px}.uploaded-file-preview{display:block;max-width:100%;max-height:350px;border-radius:8px;object-fit:contain;cursor:pointer}.upload-toast{pointer-events:auto}.upload-toast .toast-content{display:flex;align-items:center;gap:10px;width:100%}.upload-toast-body{flex:1;display:flex;flex-direction:column;gap:4px}.upload-progress{width:100%;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.upload-progress-bar{height:100%;background:var(--primary);border-radius:2px;transition:width .2s}.upload-progress-text{font-size:.75rem;color:var(--text-secondary)}.upload-drop-overlay{position:absolute;inset:0;background:rgba(99,102,241,.15);border:2px dashed var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;z-index:50;backdrop-filter:blur(4px)}.upload-drop-overlay.hidden{display:none}.upload-drop-content{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--primary);font-size:1.1rem;font-weight:500}.upload-drop-content svg{opacity:.8}.message-youtube{max-width:480px}.youtube-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);text-decoration:none;color:var(--text-primary);font-size:.85rem;font-weight:500;margin-bottom:6px;transition:background var(--transition-fast)}.youtube-badge:hover{background:var(--bg-glass-light)}.youtube-logo{flex-shrink:0}.youtube-embed{position:relative;width:100%;padding-bottom:56.25%;border-radius:var(--border-radius-sm);overflow:hidden;background:#000}.youtube-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.compact-chat .message{padding:1px var(--spacing-sm);gap:0}.compact-chat .message-avatar,.compact-chat .message-avatar-spacer{display:none}.compact-chat .message-grouped{margin-top:-2px}.compact-chat .message-header{display:inline}.compact-chat .message-header .message-nick{font-size:.8125rem}.compact-chat .message-header .message-nick::after{content:': '}.compact-chat .message-text{display:inline;font-size:.8125rem}.compact-chat .message-header .message-time{font-size:.625rem;margin-left:4px}.compact-chat .message-header .message-asl{display:none}.compact-chat .message.message-action{padding:2px var(--spacing-sm)}.compact-nicklist .user-item{padding:1px var(--spacing-sm);gap:4px}.compact-nicklist .user-item-avatar{width:18px;height:18px}.compact-nicklist .user-item-nick{font-size:.75rem}.compact-nicklist .user-item-asl{display:none}.compact-nicklist .user-group-title{padding:2px var(--spacing-sm);font-size:.65rem}.game-ttt-board{display:grid;grid-template-columns:repeat(3,44px);gap:3px;padding:var(--spacing-sm);width:fit-content}.game-ttt-cell{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;border-radius:var(--border-radius-sm);background:color-mix(in srgb,var(--text-primary) 10%,var(--bg-primary));border:2px solid color-mix(in srgb,var(--text-primary) 20%,var(--bg-primary));color:var(--text-primary)}.game-ttt-cell.cell-x{color:#5850ff}.game-ttt-cell.cell-o{color:#ff00cf}.game-ttt-cell.cell-empty{color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:background .15s,border-color .15s}.game-ttt-cell.cell-empty:hover{background:color-mix(in srgb,var(--accent-color) 20%,var(--bg-primary));border-color:var(--accent-color);color:var(--text-primary)}.game-ttt-waiting .game-ttt-cell.cell-empty{cursor:default;opacity:.5}.game-ttt-waiting .game-ttt-cell.cell-empty:hover{background:color-mix(in srgb,var(--text-primary) 10%,var(--bg-primary));border-color:color-mix(in srgb,var(--text-primary) 20%,var(--bg-primary));color:var(--text-muted)}.message-html{padding:var(--spacing-xs) 0}.query-games{padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--border-color)}.query-games-title{font-size:.7rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.query-games-buttons{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs)}.query-game-btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:7px 6px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.78rem;font-weight:500;cursor:pointer;transition:.18s;white-space:nowrap}.query-game-btn:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.query-game-icon{font-size:.95rem;line-height:1}.pfc-choice{display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap;padding:var(--spacing-xs) 0}.pfc-label{font-size:.8rem;color:var(--text-muted);margin-right:var(--spacing-xs)}.pfc-btn{padding:6px 14px;background:color-mix(in srgb,var(--text-primary) 10%,var(--bg-primary));border:2px solid color-mix(in srgb,var(--text-primary) 20%,var(--bg-primary));border-radius:var(--radius-md);color:var(--text-primary);font-size:.85rem;font-weight:600;cursor:pointer;transition:.2s}.pfc-btn:hover:not(:disabled){background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.pfc-btn:disabled{opacity:.4;cursor:default}.pfc-btn-selected{background:var(--accent-color)!important;color:#fff!important;border-color:var(--accent-color)!important;opacity:1!important}.query-game-btn-premium{border-color:color-mix(in srgb,gold 40%,var(--border-color))}.query-game-btn-premium:hover{background:color-mix(in srgb,gold 60%,var(--accent-color));border-color:gold}.query-game-btn-full{grid-column:1/-1}.game-pendu{padding:var(--spacing-sm) var(--spacing-xs);max-width:340px}.pendu-body{display:flex;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.pendu-svg{flex-shrink:0;opacity:.9}.pendu-right{display:flex;flex-direction:column;gap:var(--spacing-xs);padding-top:var(--spacing-xs)}.pendu-word{display:flex;flex-wrap:wrap;gap:4px;align-items:flex-end}.pendu-letter{display:inline-flex;align-items:center;justify-content:center;width:26px;height:30px;font-size:.95rem;font-weight:700;border-radius:4px;background:color-mix(in srgb,var(--text-primary) 8%,var(--bg-primary));border:1px solid color-mix(in srgb,var(--text-primary) 22%,var(--bg-primary));color:transparent;text-transform:uppercase;user-select:none}.pendu-letter.found{color:var(--accent-color);border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 12%,var(--bg-primary))}.pendu-errors{font-size:.72rem;color:var(--text-muted);margin-top:4px}.pendu-word-input{padding:var(--spacing-xs) 0;display:flex;flex-direction:column;gap:6px;max-width:320px}.pendu-word-input-label{font-size:.82rem;color:var(--text-secondary)}.pendu-word-input-row{display:flex;gap:6px}.pendu-word-field{flex:1;padding:6px 10px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;outline:0;transition:border-color .15s}.pendu-word-field:focus{border-color:var(--accent-color)}.pendu-word-field.pendu-field-error{border-color:#e74c3c;animation:.3s shake}.pendu-word-submit{padding:6px 14px;background:var(--accent-color);border:none;border-radius:var(--border-radius-sm);color:#fff;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .15s;white-space:nowrap}.pendu-word-submit:hover{opacity:.85}.pendu-word-hint{font-size:.7rem;color:var(--text-muted)}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.pendu-keyboard{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--spacing-xs)}.pendu-key{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;border-radius:var(--border-radius-sm);background:color-mix(in srgb,var(--text-primary) 10%,var(--bg-primary));border:1px solid color-mix(in srgb,var(--text-primary) 20%,var(--bg-primary));color:var(--text-primary);cursor:pointer;transition:background .12s,border-color .12s}.pendu-key:hover:not(:disabled){background:var(--accent-color);border-color:var(--accent-color);color:#fff}.pendu-key:disabled{cursor:default}.pendu-key.correct{background:color-mix(in srgb,#22c55e 30%,var(--bg-primary));border-color:#22c55e;color:#22c55e}.pendu-key.wrong{background:color-mix(in srgb,#e74c3c 15%,var(--bg-primary));border-color:color-mix(in srgb,#e74c3c 40%,var(--bg-primary));color:var(--text-muted);opacity:.5}.game-p4{padding:var(--spacing-xs);width:fit-content}.p4-status-turn{display:block;font-size:.8rem;font-weight:600;color:var(--accent-color);margin-bottom:var(--spacing-xs)}.p4-status-wait{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:var(--spacing-xs)}.p4-col-arrows{display:grid;grid-template-columns:repeat(7,38px);gap:3px;margin-bottom:2px}.p4-col-arrow{width:38px;height:22px;display:flex;align-items:center;justify-content:center;font-size:.7rem;background:0 0;border:none;color:var(--text-muted);cursor:default;border-radius:var(--border-radius-sm);transition:background .12s,color .12s}.p4-col-arrow.active{color:var(--accent-color);cursor:pointer}.p4-col-arrow.active:hover{background:color-mix(in srgb,var(--accent-color) 20%,var(--bg-primary));color:var(--accent-color)}.p4-col-arrow:disabled{cursor:default;opacity:.3}.p4-grid{display:grid;grid-template-columns:repeat(7,38px);grid-template-rows:repeat(6,38px);gap:3px;background:#1a2a6c;padding:5px;border-radius:var(--radius-md)}.p4-cell{width:38px;height:38px;border-radius:50%;background:color-mix(in srgb,#000 40%,#1a2a6c);transition:background .15s}.p4-cell.p4-red{background:radial-gradient(circle at 35% 35%,#ff6b6b,#c0392b);box-shadow:0 0 6px rgba(192,57,43,.6)}.p4-cell.p4-yellow{background:radial-gradient(circle at 35% 35%,#ffd93d,#e67e22);box-shadow:0 0 6px rgba(230,126,34,.5)}.game-bn{padding:var(--spacing-xs) 0;font-size:.8rem}.bn-st-turn{display:block;color:var(--accent-color);font-weight:600;margin-bottom:6px}.bn-st-wait{display:block;color:var(--text-muted);margin-bottom:6px}.bn-wait-msg{color:var(--text-muted);font-size:.78rem;margin-top:6px}.bn-grid-wrap{display:inline-block}.bn-col-labels{display:grid;grid-template-columns:16px repeat(8,20px);gap:2px;padding-left:0;margin-bottom:1px}.bn-col-labels span{text-align:center;font-size:.65rem;color:var(--text-muted);line-height:1}.bn-row{display:grid;grid-template-columns:16px repeat(8,20px);gap:2px;margin-bottom:2px}.bn-rl{font-size:.65rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center}.bn-cell{width:20px;height:20px;border-radius:2px;background:color-mix(in srgb,#1e3a5f 80%,var(--bg-primary));border:1px solid color-mix(in srgb,#2a5a8f 50%,var(--bg-primary));cursor:default}.bn-empty{cursor:pointer}.bn-empty:hover{background:color-mix(in srgb,var(--accent-color) 30%,#1e3a5f);border-color:var(--accent-color)}.bn-s{background:#3b82f6;border-color:#60a5fa}.bn-s-P{background:#1d4ed8}.bn-s-C{background:#2563eb}.bn-s-D{background:#3b82f6}.bn-s-V{background:#60a5fa}.bn-hit-me{background:radial-gradient(circle,#ef4444,#b91c1c);border-color:#ef4444}.bn-miss-me{background:color-mix(in srgb,#94a3b8 20%,#1e3a5f);border-color:#475569}.bn-miss-me::after{content:'·';display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:1rem;color:#64748b;line-height:1}.bn-hit{background:radial-gradient(circle,#f97316,#c2410c);border-color:#f97316}.bn-miss{background:color-mix(in srgb,#94a3b8 15%,#1e3a5f);border-color:#334155}.bn-miss::after{content:'·';display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:1rem;color:#475569;line-height:1}.bn-atk{cursor:crosshair}.bn-atk:hover{background:color-mix(in srgb,#f97316 30%,#1e3a5f);border-color:#f97316}.bn-boards{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.bn-board-title{font-size:.68rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:.04em;margin-bottom:4px}.bn-ships-list{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.bn-ship-item{display:flex;align-items:center;gap:4px;padding:3px 7px;border-radius:var(--border-radius-sm);background:var(--bg-secondary);border:1px solid var(--border-color);font-size:.75rem;cursor:pointer;transition:.15s;user-select:none}.bn-ship-item:hover{border-color:var(--accent-color)}.bn-ship-item.bn-selected{border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 15%,var(--bg-primary));color:var(--accent-color);font-weight:600}.bn-ship-item.bn-placed{opacity:.5;cursor:pointer;text-decoration:line-through}.bn-ship-item.bn-placed:hover{opacity:.9;border-color:#ef4444;text-decoration:none}.bn-sc{display:inline-block;width:8px;height:8px;background:#3b82f6;border-radius:1px;margin-left:1px}.bn-controls{display:flex;gap:6px;margin-top:6px;align-items:center}.bn-rotate-btn{padding:4px 10px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.75rem;cursor:pointer;transition:.15s}.bn-rotate-btn:hover{border-color:var(--accent-color);color:var(--accent-color)}.bn-ready-btn{padding:4px 12px;background:var(--accent-color);border:none;border-radius:var(--border-radius-sm);color:#fff;font-size:.75rem;font-weight:600;cursor:pointer;transition:opacity .15s}.bn-ready-btn:hover:not(:disabled){opacity:.85}.bn-ready-btn:disabled{background:var(--bg-secondary);color:var(--text-muted);cursor:default;border:1px solid var(--border-color)}@media (max-width:768px){.message-youtube{max-width:100%}}.btn-vocal{position:relative}.btn-vocal.recording svg{color:var(--error);animation:1.5s infinite vocal-pulse}@keyframes vocal-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.7}}.voice-recording-timer{position:absolute;top:-22px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.85);color:var(--error);padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:600;white-space:nowrap;pointer-events:none;font-variant-numeric:tabular-nums}.voice-player{display:inline-flex;align-items:center;gap:8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:20px;padding:6px 14px;margin:4px 0;max-width:320px;min-width:200px;user-select:none}.voice-player.playing{border-color:var(--primary);box-shadow:0 0 8px rgba(124,58,237,.2)}.voice-player-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;border-radius:50%;border:none;background:var(--primary);color:#fff;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);padding:0}.voice-player-btn:hover{background:var(--primary-dark);transform:scale(1.08)}.voice-player-btn svg{width:14px;height:14px}.voice-player-wave{flex:1;height:22px;background:rgba(255,255,255,.08);border-radius:11px;position:relative;cursor:pointer;overflow:hidden}.voice-player-progress{height:100%;background:var(--primary);border-radius:11px;width:0%;transition:width .15s linear}.voice-player-time{font-size:.7rem;color:var(--text-secondary);white-space:nowrap;min-width:60px;text-align:right;font-variant-numeric:tabular-nums}@media (max-width:1024px){.user-panel{position:fixed;right:0;top:var(--header-height);bottom:0;transform:translateX(100%);transition:transform var(--transition-normal);z-index:var(--z-sidebar)}.user-panel.open{transform:translateX(0)}.btn-close-panel{display:flex}}@media (max-width:768px){.voice-player{max-width:260px;min-width:180px;padding:5px 10px}.voice-player-time{font-size:.65rem;min-width:50px}:root{--header-height:56px;--sidebar-width:100%}.btn-menu{display:flex}.sidebar{position:fixed;left:0;top:var(--header-height);bottom:0;transform:translateX(-100%);transition:transform var(--transition-normal);width:280px;max-width:80vw}.sidebar.open{transform:translateX(0)}.header-actions .btn-icon:not(#btn-toggle-users):not(#btn-settings):not(#btn-report):not(#btn-identify):not(#btn-cam):not(#btn-premium){display:none}.input-container{flex-wrap:wrap;gap:4px;padding:var(--spacing-sm) var(--spacing-md)}.input-wrapper{order:0;flex:1;min-width:0}.btn-send{order:1;flex-shrink:0}.input-actions{order:2;width:100%;justify-content:space-around;gap:0;border-top:1px solid var(--border-color);padding-top:4px}.message-avatar{width:32px;height:32px}.toast-container{left:var(--spacing-md);right:var(--spacing-md);bottom:calc(var(--input-height) + var(--spacing-md))}.toast{width:100%}}@media (max-width:480px){.login-container{padding:var(--spacing-lg)}.form-row{flex-direction:column;gap:var(--spacing-md)}.modal{max-width:100%;margin:var(--spacing-md)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--bg-tertiary) transparent}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}.loading{animation:1.5s ease-in-out infinite pulse}.autocomplete-dropdown{position:absolute;bottom:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);box-shadow:var(--shadow-md);max-height:200px;overflow-y:auto;z-index:50;margin-bottom:4px}.autocomplete-item{padding:var(--spacing-xs) var(--spacing-md);cursor:pointer;font-size:.875rem;color:var(--text-primary);transition:background var(--transition-fast)}.autocomplete-item.active,.autocomplete-item:hover{background:var(--bg-glass-light)}.autocomplete-item .ac-nick{font-weight:600}.sidebar-radio{padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--border)}.radio-player-controls{display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:6px}.radio-btn{background:0 0;border:none;color:var(--text-secondary);cursor:pointer;padding:5px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast),background var(--transition-fast)}.radio-btn:hover{color:var(--text-primary);background:var(--bg-glass-light)}.radio-btn:disabled{opacity:.3;cursor:default}.radio-btn:disabled:hover{background:0 0;color:var(--text-secondary)}.radio-btn svg{width:18px;height:18px}.radio-btn-play{color:var(--primary-light)}.radio-btn-play:hover{color:var(--primary)}.radio-player-volume{display:flex;align-items:center;gap:6px;padding:0 2px}.radio-volume-slider{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:var(--border);border-radius:2px;outline:0;cursor:pointer}.radio-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--primary-light);cursor:pointer}.radio-volume-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--primary-light);cursor:pointer;border:none}.radio-vol-icon{display:flex;align-items:center;color:var(--text-secondary);flex-shrink:0}.radio-vol-icon svg{width:16px;height:16px}.radio-player-station{text-align:center;font-size:.78rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:2px 4px 0}.radio-player-station.radio-errored{color:var(--danger,#e74c3c)}.radio-station-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border);transition:background var(--transition-fast)}.radio-station-item:last-child{border-bottom:none}.radio-station-item:hover{background:var(--bg-glass-light)}.radio-station-item.radio-station-active{background:var(--bg-glass);border-left:3px solid var(--primary-light)}.radio-station-item.radio-station-empty{opacity:.5}.radio-station-img{width:42px;height:42px;border-radius:6px;object-fit:cover;flex-shrink:0;margin-top:2px}.radio-station-details{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:center;gap:4px}.radio-station-actions{display:flex;gap:2px}.radio-station-name{flex:1;min-width:0;font-weight:600;color:var(--text-primary);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.radio-station-desc{flex-basis:100%;font-size:.78rem;color:var(--text-secondary);margin:0;opacity:.75}.radio-station-link{flex-basis:100%;font-size:.78rem;margin:0}.radio-station-link a{color:var(--primary-light);text-decoration:none}.radio-station-link a:hover{text-decoration:underline}.radio-station-salon{cursor:pointer}.radio-btn-star.starred{background:rgba(243,156,18,.12);border-radius:4px}.radio-modal-empty{text-align:center;color:var(--text-secondary);padding:var(--spacing-lg);font-size:.88rem;opacity:.7}.channel-link{color:var(--primary-light);cursor:pointer;font-weight:500}.channel-link:hover{text-decoration:underline;color:var(--primary)}.user-item-status{font-size:.625rem;color:var(--text-muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-text span[style*=background-color]{-webkit-box-decoration-break:clone;box-decoration-break:clone;border-radius:2px;padding:0 1px}.strip-irc-colors .message-text span[style*=color]{color:var(--text-primary)!important;background-color:transparent!important}.message.message-topic-reminder{background:rgba(6,182,212,.08);border-left:3px solid var(--accent);padding:var(--spacing-sm)}.message.message-topic-reminder .message-text{font-size:.8125rem;color:var(--text-secondary)}.topic-reminder-label{font-weight:600;color:var(--accent)}.channel-topic.topic-hidden{display:none!important}.hide-sex-colors .message-nick.sex-female,.hide-sex-colors .message-nick.sex-male,.hide-sex-colors .message-nick.sex-other{color:var(--text-primary)}.settings-panel{display:flex;flex-direction:column;gap:var(--spacing-lg)}.settings-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--spacing-sm)}.settings-toggle{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:var(--spacing-sm) 0;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.05)}.settings-toggle:last-child{border-bottom:none}.settings-toggle-label{font-size:.9375rem;font-weight:500;color:var(--text-primary);flex:1}.settings-toggle-desc{width:100%;font-size:.75rem;color:var(--text-muted);margin-top:2px;order:3}.settings-toggle input[type=checkbox]{display:none}.settings-toggle-switch{position:relative;width:44px;height:24px;background:var(--bg-tertiary);border-radius:12px;border:1px solid var(--border-color);transition:all var(--transition-fast);flex-shrink:0}.settings-toggle-switch::after{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;background:var(--text-muted);border-radius:50%;transition:all var(--transition-fast)}.settings-toggle input:checked+.settings-toggle-switch{background:var(--primary);border-color:var(--primary)}.settings-toggle input:checked+.settings-toggle-switch::after{left:22px;background:#fff}.user-settings-panel{display:flex;flex-direction:column;gap:var(--spacing-md);max-height:70vh;overflow-y:auto}.settings-field{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.settings-field:last-child{margin-bottom:0}.settings-field-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.settings-field-row{display:flex;gap:var(--spacing-sm);align-items:center}.settings-input{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.8125rem}.settings-input:focus{outline:0;border-color:var(--primary)}.format-toolbar{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.format-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.format-btn:hover{background:var(--bg-glass-light);color:var(--text-primary)}.format-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.color-picker-group{margin-bottom:var(--spacing-sm)}.color-picker-palette{display:grid;grid-template-columns:repeat(8,1fr);gap:3px;margin-top:var(--spacing-xs)}.color-swatch{aspect-ratio:1;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);min-height:28px}.color-swatch:hover{transform:scale(1.15);z-index:1}.color-swatch.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-secondary),0 0 0 4px var(--primary);transform:scale(1.1);z-index:1}.format-preview{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.format-preview-box{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--border-radius-sm);border:1px solid var(--border-color);font-size:.875rem;color:var(--text-primary)}.btn-warning{background:rgba(251,191,36,.15);color:#fbbf24;border:1px solid rgba(251,191,36,.3)}.btn-warning:hover{background:rgba(251,191,36,.25)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.room-info-panel{display:flex;flex-direction:column;max-height:70vh;overflow-y:auto}.room-info-empty,.room-info-loading{padding:var(--spacing-xl);text-align:center;color:var(--text-muted)}.room-info-image{width:100%;height:120px;background-size:cover;background-position:center;background-color:var(--bg-tertiary);border-radius:var(--border-radius-sm) var(--border-radius-sm) 0 0}.room-info-image-default{background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary))}.room-info-body{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.room-info-name{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.room-info-section{display:flex;flex-direction:column;gap:var(--spacing-xs)}.room-info-section-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.room-info-topic{font-size:.8125rem;color:var(--text-secondary);line-height:1.5;word-break:break-word}.room-info-topic em{color:var(--text-muted);font-style:italic}.room-info-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.room-info-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.6875rem;font-weight:600}.room-info-badge.nsfw{background:rgba(239,68,68,.15);color:#ef4444}.room-info-badge.minor{background:rgba(59,130,246,.15);color:#3b82f6}.room-info-badge.major{background:rgba(234,179,8,.15);color:#eab308}.room-info-badge.reput{background:rgba(168,85,247,.15);color:#a855f7}.room-info-badge.age{background:rgba(6,182,212,.15);color:#06b6d4}.room-info-options{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.room-info-option{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.6875rem;background:rgba(255,255,255,.06);color:var(--text-secondary)}.room-info-modes{font-family:monospace;font-size:.8125rem;color:var(--primary);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--border-radius-sm);display:inline-block}.room-info-stats{display:flex;gap:var(--spacing-lg)}.room-info-stat{text-align:center}.room-info-stat-value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.room-info-stat-label{font-size:.6875rem;color:var(--text-muted)}.room-info-cm{font-size:.8125rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.room-info-empty-staff{font-size:.8125rem;color:var(--text-muted);font-style:italic}.room-info-staff-list{display:flex;flex-direction:column;gap:4px}.room-info-staff-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:3px 0;font-size:.8125rem}.room-info-staff-mode{font-weight:700;width:14px;text-align:center}.room-info-staff-nick{color:var(--text-primary);font-weight:500}.room-info-staff-role{color:var(--text-muted);font-size:.6875rem;margin-left:auto}.channel-list-panel{display:flex;flex-direction:column;gap:var(--spacing-md);max-height:60vh}.channel-list-search-wrap{position:sticky;top:0;z-index:1;background:var(--bg-secondary);padding-bottom:var(--spacing-sm)}.channel-list-search{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);color:var(--text-primary);font-size:.875rem;outline:0;transition:border-color var(--transition-fast);box-sizing:border-box}.channel-list-search:focus{border-color:var(--primary)}.channel-list-search::placeholder{color:var(--text-muted)}.channel-list-grid{display:flex;flex-direction:column;gap:2px;overflow-y:auto;max-height:50vh}.channel-card{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-sm);cursor:pointer;transition:background var(--transition-fast)}.channel-card:hover{background:var(--bg-glass-light)}.channel-card.joined{background:rgba(99,102,241,.08);border-left:3px solid var(--primary)}.channel-card.age-restricted{opacity:.45;pointer-events:auto;position:relative}.channel-card.age-restricted::after{content:'🔒';position:absolute;top:50%;right:12px;transform:translateY(-50%);font-size:1.1rem}.channel-card-image{width:40px;height:40px;border-radius:var(--border-radius-sm);background:var(--bg-tertiary);background-size:cover;background-position:center;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1.25rem}.channel-card-image:empty::after{content:'#';font-weight:700;font-size:1rem;color:var(--text-muted)}.channel-card-info{flex:1;min-width:0}.channel-card-name{font-size:.875rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.channel-card-topic{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.channel-card-topic em{font-style:italic;opacity:.6}.channel-card-users{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-secondary);flex-shrink:0;padding:2px 8px;background:var(--bg-tertiary);border-radius:10px}.channel-card-badge{font-size:.625rem;padding:1px 5px;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.channel-card-badge.nsfw{background:rgba(239,68,68,.2);color:#ef4444}.channel-card-badge.minor{background:rgba(251,191,36,.2);color:#fbbf24}.channel-card-badge.game{background:rgba(34,197,94,.2);color:#22c55e}.channel-card-badge.major{background:rgba(99,102,241,.2);color:#818cf8}.channel-card-badge.reput{background:rgba(168,85,247,.2);color:#a855f7}.channel-card-badge.age{background:rgba(6,182,212,.2);color:#06b6d4}.channel-list-section{margin-bottom:var(--spacing-sm)}.channel-list-section-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:var(--spacing-xs) var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.05);margin-bottom:2px}.channel-list-empty,.channel-list-loading{text-align:center;color:var(--text-muted);padding:var(--spacing-xl);font-size:.875rem}.settings-tabs{display:flex;border-bottom:2px solid var(--border-color);margin-bottom:var(--spacing-md);gap:0}.settings-tab{flex:1;padding:10px 12px;background:0 0;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--text-muted);font-size:.8125rem;font-weight:500;cursor:pointer;transition:color .2s,border-color .2s;text-align:center}.settings-tab:hover{color:var(--text-primary)}.settings-tab.active{color:var(--primary-light);border-bottom-color:var(--primary-light)}.settings-tab-content{display:none}.settings-tab-content.active{display:block}.settings-description{font-size:.8125rem;color:var(--text-muted);margin-bottom:var(--spacing-sm);line-height:1.4}.block-option{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;margin-bottom:8px;transition:border-color .2s,background .2s}.block-option:hover{border-color:var(--primary-light);background:rgba(124,58,237,.05)}.block-option input[type=checkbox]{margin-top:2px;width:16px;height:16px;cursor:pointer;accent-color:var(--primary);flex-shrink:0}.block-option-text{display:flex;flex-direction:column;gap:3px;flex:1}.block-option-text strong{font-size:.8125rem;color:var(--text-primary)}.block-option-text small{font-size:.75rem;color:var(--text-muted)}.block-option-small{margin-top:var(--spacing-sm);background:var(--bg-glass-light)}.block-status{margin-top:var(--spacing-sm);padding:8px 12px;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);border-radius:var(--border-radius-sm);color:var(--success);font-size:.8125rem}.block-whitelist-section{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.whitelist-container{max-height:150px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-glass-light);margin-top:var(--spacing-xs)}.whitelist-empty{padding:12px;text-align:center;color:var(--text-muted);font-style:italic;font-size:.8125rem}.whitelist-list{list-style:none;margin:0;padding:0}.whitelist-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.05)}.whitelist-item:last-child{border-bottom:none}.whitelist-nick{font-weight:500;font-size:.8125rem;color:var(--text-primary)}.whitelist-count{margin-top:6px;font-size:.75rem;color:var(--text-muted)}.btn-danger{background:var(--error);color:#fff;border:none;cursor:pointer;padding:2px 8px;border-radius:4px;font-size:.75rem}.btn-danger:hover{background:#dc2626}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#16a34a}.block-quick-add-notif{position:fixed;bottom:20px;right:20px;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:14px 18px;border-radius:var(--border-radius);box-shadow:var(--shadow-lg);z-index:10001;max-width:350px;animation:.3s blockNotifSlideIn}.block-quick-add-notif.confirmed{border-color:rgba(34,197,94,.5);background:rgba(34,197,94,.15)}.block-notif-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.block-notif-title{font-weight:600;font-size:.875rem;color:var(--error)}.block-notif-reason{font-size:.8125rem;color:var(--text-muted);margin-top:2px}.block-notif-close{background:0 0;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:0}.block-notif-actions{display:flex;gap:8px;margin-top:10px}.block-notif-confirmed{display:flex;align-items:center;gap:8px;color:var(--success);font-size:.875rem}@keyframes blockNotifSlideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.mini-profil-mod-actions{display:flex;gap:6px;margin-top:8px;justify-content:center;flex-wrap:wrap}.mini-profil-mod-actions .btn{font-size:.75rem;padding:4px 10px}.help-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center;animation:.2s helpFadeIn}@keyframes helpFadeIn{from{opacity:0}to{opacity:1}}.help-window{background:var(--bg-secondary,#1a1a2e);border:1px solid var(--border,#333);border-radius:12px;width:90%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 8px 32px rgba(0,0,0,.5);animation:.25s helpSlideIn}@keyframes helpSlideIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.help-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border,#333)}.help-header h2{margin:0;font-size:1.1rem;color:var(--text-primary,#fff);font-weight:600}.help-close{background:0 0;border:none;color:var(--text-muted,#888);font-size:1.5rem;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s}.help-close:hover{color:var(--danger,#e74c3c)}.help-body{padding:16px 20px;overflow-y:auto;flex:1}.help-section{margin-bottom:18px}.help-section h3{font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:var(--accent,#00bcd4);margin:0 0 8px;padding-bottom:4px;border-bottom:1px solid rgba(255,255,255,.06)}.help-cmd{display:flex;gap:12px;padding:5px 0;font-size:.85rem;line-height:1.4}.help-syntax{color:var(--warning,#f0ad4e);font-family:monospace;white-space:nowrap;min-width:210px;flex-shrink:0}.help-desc{color:var(--text-secondary,#aaa)}.help-footer-note{margin-top:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,.06);font-size:.78rem;color:var(--text-muted,#666);font-style:italic;text-align:center}@media (max-width:600px){.help-window{width:96%;max-height:90vh;border-radius:8px}.help-cmd{flex-direction:column;gap:2px;padding:6px 0}.help-syntax{min-width:auto}.help-desc{padding-left:12px;font-size:.8rem}}.video-float-win{position:fixed;width:260px;height:220px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column;user-select:none;transition:box-shadow .2s}.video-float-win:hover{box-shadow:var(--shadow-lg),0 0 12px rgba(124,58,237,.2)}.video-float-win.dragging{opacity:.85;box-shadow:var(--shadow-lg),var(--shadow-glow);cursor:grabbing}.video-float-win.resizing{opacity:.9}.video-float-titlebar{display:flex;align-items:center;justify-content:space-between;padding:3px 6px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);cursor:grab;flex-shrink:0;min-height:26px}.video-float-titlebar:active{cursor:grabbing}.video-float-title{font-size:.75rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.video-float-actions{display:flex;gap:3px;flex-shrink:0}.video-float-btn{width:20px;height:20px;padding:0;background:0 0;border:none;border-radius:4px;color:var(--text-secondary);font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.video-float-btn:hover{background:rgba(255,255,255,.1);color:var(--text-primary)}.video-float-close:hover{background:var(--error);color:#fff}.btn-mute-audio{font-size:12px!important}.btn-mute-audio.btn-muted{opacity:.5}.btn-force-stop{font-size:11px!important}.btn-force-stop:hover{background:var(--warning)!important;color:#fff!important}.btn-report-cam{font-size:11px!important;color:var(--error)}.btn-report-cam:hover{background:rgba(239,68,68,.3)!important;color:#fff!important}.video-float-win video{flex:1;width:100%;min-height:0;object-fit:cover;display:block;background:#000}.video-float-label{position:absolute;bottom:0;left:0;right:0;padding:3px 8px;background:linear-gradient(transparent,rgba(0,0,0,.6));color:var(--text-primary);font-size:.7rem;font-weight:500;pointer-events:none}.video-float-resize{position:absolute;bottom:0;right:0;width:14px;height:14px;cursor:nwse-resize;z-index:1}.video-float-resize::after{content:'';position:absolute;bottom:3px;right:3px;width:8px;height:8px;border-right:2px solid var(--text-muted);border-bottom:2px solid var(--text-muted);opacity:.5;transition:opacity .2s}.video-float-win:hover .video-float-resize::after{opacity:1}.video-local-preview{position:fixed;bottom:80px;right:16px;width:180px;border-radius:var(--border-radius-sm);overflow:hidden;background:var(--bg-primary);box-shadow:var(--shadow-lg);z-index:400;border:2px solid var(--primary);cursor:grab;user-select:none;transition:box-shadow .2s}.video-local-preview:hover{box-shadow:var(--shadow-lg),0 0 12px rgba(124,58,237,.3)}.video-local-preview.dragging{opacity:.85;cursor:grabbing;box-shadow:var(--shadow-lg),var(--shadow-glow)}.video-local-preview.hidden{display:none}.video-local-preview video{width:100%;display:block;transform:scaleX(-1)}.video-local-controls{display:flex;justify-content:center;gap:8px;padding:4px;background:var(--bg-tertiary);cursor:default}.video-local-controls .btn-icon{width:28px;height:28px;padding:4px;border-radius:50%;background:var(--bg-glass-light);border:none;color:var(--text-primary);cursor:pointer;transition:background .2s}.video-local-controls .btn-icon:hover{background:var(--primary)}.video-local-controls .btn-icon.btn-muted,.video-local-controls .btn-stop-cam:hover{background:var(--error)}.user-item-cam{display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;margin-left:5px;vertical-align:middle;background:var(--primary);color:#fff;border-radius:3px;padding:1px 4px;font-weight:700;letter-spacing:.02em;animation:2s ease-in-out infinite cam-pulse;line-height:1.4;cursor:pointer;transition:background .15s,transform .1s}.user-item-cam:hover{background:var(--secondary);transform:scale(1.1);animation:none}@keyframes cam-pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(124,58,237,.4)}50%{opacity:.9;box-shadow:0 0 0 4px rgba(124,58,237,0)}}.user-item-birthday{font-size:.85rem;margin-left:4px;vertical-align:middle;animation:2s ease-in-out infinite birthday-bounce}@keyframes birthday-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}.user-item-mood{font-size:.85rem;margin-left:3px;vertical-align:middle;cursor:default}.video-local-viewers{background:var(--bg-secondary);border-top:1px solid var(--border);max-height:120px;overflow-y:auto}.video-local-viewers:not(.has-viewers){display:none}.video-viewers-header{display:flex;align-items:center;padding:4px 8px;background:var(--bg-tertiary)}.video-viewers-count{font-size:.75rem;color:var(--text-muted);font-weight:600}.video-viewers-list{list-style:none;margin:0;padding:0}.video-viewer-item{display:flex;align-items:center;justify-content:space-between;padding:3px 8px;border-bottom:1px solid var(--border);gap:4px}.video-viewer-item:last-child{border-bottom:none}.video-viewer-nick{font-size:.8rem;color:var(--text-primary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.video-viewer-kick{flex-shrink:0;width:18px;height:18px;font-size:.65rem;padding:0;border:none;background:0 0;color:var(--text-muted);cursor:pointer;border-radius:3px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .15s,color .15s}.video-viewer-item:hover .video-viewer-kick{opacity:1}.video-viewer-kick:hover{background:var(--error);color:#fff}.video-pending-win{width:230px;height:auto!important;min-height:0!important;overflow:visible;z-index:320!important}.video-pending-status{display:flex;flex-direction:row;align-items:center;padding:8px 10px;gap:8px}.video-pending-icon{font-size:1.1rem;line-height:1;flex-shrink:0}.video-pending-text{font-size:.78rem;color:var(--text-muted);line-height:1.3;flex:1}.video-pending-spinner{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:.8s linear infinite spin;flex-shrink:0}.video-pending-granted .video-pending-text{color:var(--success)}.video-pending-granted .video-pending-spinner{border-top-color:var(--success)}.video-pending-denied .video-pending-text{color:var(--error)}.cam-request-toast{width:240px;height:auto!important;min-height:0!important;z-index:350!important}.cam-request-body{padding:8px 12px 12px}.cam-request-msg{font-size:.82rem;margin:0 0 10px;line-height:1.4;color:var(--text-primary)}.cam-request-actions{display:flex;gap:8px;justify-content:flex-end}.mini-profil-video-actions{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;padding-top:6px;border-top:1px solid var(--border)}.mini-profil-video-actions .btn{font-size:.75rem;padding:4px 10px}.mini-profil-mood{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.85rem;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.mini-profil-mood .mood-emoji{font-size:1.1em;line-height:1}.mini-profil-mood .mood-text{font-style:italic}.mood-picker{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}.mood-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:6px 10px;cursor:pointer;font-size:1.1em;line-height:1;transition:border-color var(--transition-fast),background var(--transition-fast)}.mood-btn.selected,.mood-btn:hover{border-color:var(--primary);background:rgba(124,58,237,.15)}@media (max-width:768px){.video-float-win{width:200px;height:180px}.video-local-preview{width:120px;bottom:70px;right:8px}}@media (max-width:480px){.video-float-win{width:160px;height:150px}.video-float-titlebar{padding:2px 4px;min-height:22px}.video-float-title{font-size:.65rem}.video-local-preview{width:100px;bottom:60px;right:4px}.video-local-controls .btn-icon{width:24px;height:24px}}.emoji-picker-container{position:absolute;bottom:100%;left:0;margin-bottom:8px;z-index:1000}.emoji-picker{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);width:320px;max-height:350px;overflow-y:auto;padding:var(--spacing-sm)}.emoji-picker-search{width:100%;padding:var(--spacing-xs) var(--spacing-sm);margin-bottom:var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.875rem}.emoji-picker-search::placeholder{color:var(--text-muted)}.emoji-category{margin-bottom:var(--spacing-sm)}.emoji-category-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs);padding:0 var(--spacing-xs)}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px}.emoji-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:0 0;border:none;border-radius:var(--border-radius-sm);cursor:pointer;font-size:1.25rem;transition:background-color .15s}.emoji-btn:hover{background:var(--bg-tertiary)}.emoji-btn:active{transform:scale(.9)}.emoji-btn-custom img{width:24px;height:24px;object-fit:contain}.gif-picker-container{position:absolute;bottom:100%;left:0;margin-bottom:8px;z-index:1000}.gif-picker{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);width:380px;display:flex;flex-direction:column;overflow:hidden}.gif-picker-header{padding:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.gif-picker-search{width:100%;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.875rem}.gif-picker-search::placeholder{color:var(--text-muted)}.gif-picker-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;padding:4px;max-height:320px;overflow-y:auto;overflow-x:hidden}.gif-picker-item{display:block;padding:0;margin:0;background:var(--bg-tertiary);border:none;border-radius:var(--border-radius-sm);cursor:pointer;overflow:hidden;height:120px;transition:transform .15s,box-shadow .15s}.gif-picker-item:hover{transform:scale(1.03);box-shadow:0 0 0 2px var(--primary);z-index:1}.gif-picker-item:active{transform:scale(.97)}.gif-picker-item img{width:100%;height:100%;object-fit:cover;display:block}.gif-picker-footer{padding:4px var(--spacing-sm);border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:flex-end;gap:4px}.gif-powered-text{font-size:.65rem;color:var(--text-muted);opacity:.5}.gif-picker-empty,.gif-picker-loading{grid-column:1/-1;text-align:center;padding:var(--spacing-lg);color:var(--text-muted);font-size:.875rem}.gif-spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:.6s linear infinite gif-spin}@keyframes gif-spin{to{transform:rotate(360deg)}}.btn-gif{position:relative}.btn-gif-label{font-size:.7rem;font-weight:800;letter-spacing:.02em;color:var(--text-secondary);border:1.5px solid var(--text-secondary);border-radius:3px;padding:1px 4px;line-height:1;transition:all var(--transition-fast)}.btn-gif:hover .btn-gif-label{color:var(--primary-light);border-color:var(--primary-light)}.message-gif{position:relative;max-width:350px;border-radius:8px;overflow:hidden}.message-gif img{max-width:100%;max-height:280px;display:block;border-radius:8px}.message-gif.error{display:none}.gif-badge{position:absolute;top:6px;left:6px;background:rgba(0,0,0,.6);color:#fff;font-size:.6rem;font-weight:700;padding:2px 5px;border-radius:3px;letter-spacing:.05em;pointer-events:none}@keyframes wizz-shake{0%,100%{transform:translate(0,0)}10%{transform:translate(-8px,-6px)}20%{transform:translate(6px,8px)}30%{transform:translate(-10px,4px)}40%{transform:translate(8px,-8px)}50%{transform:translate(-6px,6px)}60%{transform:translate(10px,-4px)}70%{transform:translate(-4px,8px)}80%{transform:translate(6px,-6px)}90%{transform:translate(-8px,4px)}}.wizz-shake{animation:.5s ease-in-out wizz-shake}.btn-wizz{color:var(--warning)!important;transition:all var(--transition-fast)}.btn-wizz:hover{color:#fbbf24!important;filter:drop-shadow(0 0 6px rgba(245, 158, 11, .5))}.btn-wizz-cooldown{opacity:.4;pointer-events:none}.emoji{vertical-align:middle}.emoji-custom{width:1.5em;height:1.5em;vertical-align:middle;margin:0 1px}@media (max-width:768px){.emoji-picker-container{left:50%;transform:translateX(-50%)}.emoji-picker{width:280px;max-height:300px}.emoji-grid{grid-template-columns:repeat(7,1fr)}.emoji-btn{width:32px;height:32px;font-size:1.1rem}.gif-picker-container{left:50%;transform:translateX(-50%)}.gif-picker{width:calc(100vw - 24px);max-width:340px}.gif-picker-grid{max-height:260px}.message-gif img{max-height:200px}}.premium-badge{display:inline-block;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;border-radius:8px;background:linear-gradient(135deg,#ffc107,#e0a800);color:#1a1a2e;vertical-align:middle;margin-left:6px}.premium-locked{display:flex;align-items:center;justify-content:center;min-height:200px}.premium-locked-content{text-align:center;padding:2rem;opacity:.8}.premium-locked-icon{font-size:3rem;margin-bottom:1rem}.premium-locked-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.premium-locked-desc{color:var(--text-secondary);font-size:.8125rem;margin-bottom:.75rem}.premium-locked-cta{color:var(--accent);font-size:.8125rem;font-weight:600}.badword-mode-selector{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.badword-mode-option{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem .75rem;border-radius:6px;background:var(--bg-secondary);cursor:pointer;transition:background .15s}.badword-mode-option:hover{background:var(--bg-tertiary)}.badword-mode-option input[type=radio]{margin-top:3px;accent-color:var(--accent)}.badword-mode-label{font-weight:500;font-size:.8125rem;color:var(--text-primary);display:block}.badword-mode-option small{color:var(--text-secondary);font-size:.75rem;display:block;margin-top:2px}.badword-count{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem}.theme-presets-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.theme-preset-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-fast)}.theme-preset-btn:hover{border-color:var(--primary);background:var(--bg-glass-light)}.theme-preset-preview{width:48px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;gap:4px}.theme-preset-dot{width:10px;height:10px;border-radius:50%}.theme-preset-name{font-size:.7rem;color:var(--text-secondary)}.theme-custom-colors{display:grid;grid-template-columns:1fr 1fr;gap:10px}.theme-color-field{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 10px;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);font-size:.8rem;color:var(--text-secondary)}.theme-color-field input[type=color]{width:32px;height:24px;border:none;border-radius:4px;cursor:pointer;background:0 0;padding:0}.settings-range{width:100%;accent-color:var(--primary)}