:root{--bg: #F5F0E8;--bg-warm: #EDE5D8;--surface: #FFFFFF;--border: #D9CFC0;--border-light: #E8DFD2;--text: #1A1612;--muted: #6B5E4F;--accent: #C17F3E;--accent-hover: #a96a2f;--accent-light: rgba(193,127,62,.1);--radius: 16px;--radius-sm: 6px;--success: #4A9E52;--success-dim: rgba(74, 158, 82, .1);--error: #C94040;--error-dim: rgba(201, 64, 64, .1)}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden;overscroll-behavior:none;position:fixed;width:100%;touch-action:none}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app-layout{display:flex;position:fixed;left:0;top:var(--vvtop, 0px);width:100%;height:var(--vvh, 100dvh);overflow:hidden}.sidebar{position:relative;width:360px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border-light);display:flex;flex-direction:column;overflow:hidden}.main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden;background:var(--bg)}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);gap:8px}.empty-icon{font-size:48px;opacity:.3}.back-btn{display:none;width:36px;height:36px;border:none;background:none;cursor:pointer;font-size:20px;color:var(--accent);flex-shrink:0}@media(max-width:768px){.sidebar{width:100%;position:absolute;top:0;right:0;bottom:0;left:0;z-index:10}.app-layout.thread-open .sidebar{display:none}.app-layout:not(.thread-open) .main{display:none}.back-btn{display:flex;align-items:center;justify-content:center}}.club-avatar{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-weight:600;font-size:16px;color:var(--surface);background:var(--accent);transition:border-radius .2s,transform .1s;position:relative;overflow:hidden}.club-avatar:hover{border-radius:10px;transform:scale(1.05)}.club-avatar.active{border-radius:8px}.club-avatar.active:before{content:"";position:absolute;left:-10px;top:50%;transform:translateY(-50%);width:4px;height:20px;background:var(--accent);border-radius:0 4px 4px 0}.club-avatar img{width:100%;height:100%;object-fit:cover}.club-avatar .unread-badge{position:absolute;bottom:-2px;right:-2px;min-width:16px;height:16px;border-radius:8px;background:var(--error);color:#fff;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg-warm)}.sidebar-header-bar{height:56px;padding:0 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-light);flex-shrink:0}.sidebar-header-title{font-size:17px;font-weight:700;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-header-badge{font-size:11px;font-weight:600;color:var(--accent);background:var(--accent-light);padding:2px 8px;border-radius:9999px;flex-shrink:0}.sidebar-back-btn{width:36px;height:36px;border-radius:50%;border:none;background:none;color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.sidebar-back-btn:hover{background:var(--accent-light)}.thread-search{padding:6px 12px;position:relative;flex-shrink:0}.thread-search-input{width:100%;padding:8px 32px 8px 12px;border:1px solid var(--border-light);border-radius:8px;font-size:16px;font-family:inherit;background:var(--bg);outline:none}.thread-search-input:focus{border-color:var(--accent)}.thread-search-clear{position:absolute;right:18px;top:50%;transform:translateY(-50%);border:none;background:none;font-size:18px;color:var(--muted);cursor:pointer}.sidebar-scroll{flex:1;overflow-y:auto;padding:4px 0;touch-action:pan-y;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.sidebar-slide-in{animation:slideInFromRight .2s ease}@keyframes slideInFromRight{0%{transform:translate(30px);opacity:.5}to{transform:translate(0);opacity:1}}.club-list-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .15s}.club-list-item:hover{background:var(--accent-light)}.club-list-avatar{width:48px;height:48px;border-radius:50%;background:var(--bg-warm);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:var(--muted);flex-shrink:0;overflow:hidden;text-transform:uppercase}.club-list-avatar img{width:100%;height:100%;object-fit:cover}.club-list-info{flex:1;min-width:0}.club-list-name{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.club-list-meta{font-size:12px;color:var(--muted);margin-top:2px}.sidebar-tabs{display:flex;border-bottom:1px solid var(--border-light);flex-shrink:0}.sidebar-tab{flex:1;padding:10px 0;text-align:center;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border:none;border-bottom:2px solid transparent;background:none;font-family:inherit;transition:color .15s}.sidebar-tab:hover{color:var(--text)}.sidebar-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.thread-list{padding:4px 8px}.thread-item{display:flex;flex-direction:column;padding:10px 12px;border-radius:10px;cursor:pointer;gap:4px;transition:background .15s}.thread-item:hover{background:var(--surface)}.thread-item.active{background:var(--accent-light)}.thread-item-header{display:flex;align-items:center;justify-content:space-between}.thread-item-title{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thread-item-title .pin-icon{margin-right:4px;color:var(--muted);font-size:12px}.thread-item-time{font-size:11px;color:var(--muted);flex-shrink:0}.thread-item-preview{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-list{padding:4px 8px}.member-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px}.member-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-warm);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:var(--muted);position:relative;flex-shrink:0}.member-avatar .online-dot{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;border:2px solid var(--surface)}.member-avatar .online-dot.online{background:var(--success)}.member-avatar .online-dot.offline{background:var(--border)}.member-info{flex:1;min-width:0}.member-name{font-size:14px;font-weight:500}.member-role{font-size:11px;padding:1px 6px;border-radius:4px;font-weight:500}.member-role.teacher{background:var(--accent-light);color:var(--accent)}.member-role.admin{background:var(--error-dim);color:var(--error)}.member-role.student{background:var(--bg-warm);color:var(--muted)}.search-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:12px 12px 4px}.search-message-item{border-left:3px solid var(--accent);padding-left:9px!important;gap:3px}.search-message-thread{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-message-snippet{font-size:13px;color:var(--text);line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.search-message-snippet mark,.thread-item-title mark{background:var(--accent-light);color:var(--accent);font-weight:600;border-radius:2px;padding:0 1px}.search-message-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}.search-message-author{font-weight:500}.thread-unread-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}.notification-bell{position:relative;width:36px;height:36px;border-radius:50%;border:none;background:none;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.notification-bell:hover{background:var(--bg-warm);color:var(--text)}.notification-bell-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;border-radius:8px;background:var(--error);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px}.notification-dropdown{position:absolute;top:100%;right:0;margin-top:4px;z-index:1000;background:var(--surface);border:1px solid var(--border-light);border-radius:12px;box-shadow:0 8px 24px #0000001f;padding:8px 0;min-width:260px;max-height:320px;overflow-y:auto;animation:menuFadeIn .12s ease}.notification-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;transition:background .1s}.notification-item:hover{background:var(--bg-warm)}.notification-item-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}.notification-item-text{flex:1;font-size:13px;color:var(--text);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-empty{padding:20px 16px;text-align:center;font-size:13px;color:var(--muted)}.member-item-wrapper{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;position:relative}.member-actions-btn{width:28px;height:28px;border-radius:50%;border:none;background:none;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;transition:background .15s;opacity:0}.member-item-wrapper:hover .member-actions-btn{opacity:1}.member-actions-btn:hover{background:var(--bg-warm)}.member-actions-dropdown{position:absolute;right:0;top:100%;z-index:1000;background:var(--surface);border:1px solid var(--border-light);border-radius:10px;box-shadow:0 4px 16px #0000001f;padding:4px 0;min-width:160px;animation:menuFadeIn .12s ease}.member-actions-dropdown button{display:block;width:100%;padding:8px 16px;text-align:left;border:none;background:none;font-size:13px;font-family:inherit;color:var(--text);cursor:pointer}.member-actions-dropdown button:hover{background:var(--bg-warm)}.member-actions-dropdown button.danger{color:var(--error)}.member-actions-dropdown button.danger:hover{background:var(--error-dim)}.msg-check{display:inline-flex;align-items:center;margin-left:4px;vertical-align:middle}.msg-check svg{width:14px;height:14px}.msg-row.outgoing .msg-check{color:#c17f3e80}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--text);color:var(--surface);padding:8px 20px;border-radius:9999px;font-size:13px;font-weight:500;z-index:2000;animation:toastIn .2s ease,toastOut .2s ease 1.8s forwards}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0}}.create-thread-bar{padding:8px 12px;border-bottom:1px solid var(--border-light);flex-shrink:0}.create-thread-toggle{width:100%;padding:8px 12px;border:1px dashed var(--border);border-radius:10px;background:none;color:var(--accent);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s}.create-thread-toggle:hover{background:var(--accent-light)}.create-thread-form{display:flex;gap:6px;align-items:center}.create-thread-form input{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;outline:none;background:var(--surface);color:var(--text)}.create-thread-form input:focus{border-color:var(--accent)}.create-thread-btn{padding:8px 14px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap}.create-thread-btn:hover{background:var(--accent-hover)}.create-thread-cancel{width:28px;height:28px;border:none;border-radius:50%;background:var(--bg-warm);color:var(--muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}@keyframes fbSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes fbSlideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}.fb-btn{width:32px;height:32px;border-radius:50%;background:none;border:none;cursor:pointer;font-size:20px;line-height:1;filter:saturate(.85);transition:filter .2s,transform .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fb-btn:hover{filter:saturate(1.2) brightness(1.1);transform:scale(1.15)}.fb-form{position:fixed;top:54px;right:12px;width:300px;padding:18px;background:var(--surface);border:1px solid var(--border-light);border-radius:14px;box-shadow:0 8px 32px #00000026;z-index:200}.fb-form.open{animation:fbSlide .15s ease}.fb-close{position:absolute;top:8px;right:10px;background:none;border:none;font-size:18px;cursor:pointer;color:var(--muted);padding:8px;line-height:1}.fb-close:hover{opacity:.7}.fb-form h4{font-size:15px;font-weight:600;margin-bottom:10px}.fb-form textarea{width:100%;resize:none;border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:14px;font-family:inherit;outline:none;background:var(--bg);color:var(--text);box-sizing:border-box}.fb-form textarea:focus{border-color:var(--accent)}.fb-hint{font-size:12px;color:var(--muted);margin:6px 0 12px;line-height:1.4}.fb-submit{width:100%;padding:10px;border:none;border-radius:100px;background:var(--accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}.fb-submit:hover{background:var(--accent-hover)}.fb-submit:disabled{opacity:.6;cursor:not-allowed}.fb-error{font-size:13px;color:var(--error);margin-top:8px}.fb-success{text-align:center;padding:16px 0}.fb-success .check{width:40px;height:40px;border-radius:50%;background:var(--success);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;margin:0 auto 10px}.fb-success p{font-size:15px;font-weight:500}.chat-header{height:56px;padding:0 16px;border-bottom:1px solid var(--border-light);background:var(--surface);display:flex;align-items:center;gap:10px;flex-shrink:0}.chat-header-title{font-size:16px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-menu-wrapper{position:relative;flex-shrink:0}.chat-menu-btn{width:36px;height:36px;border-radius:50%;border:none;background:none;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.chat-menu-btn:hover{background:var(--bg-warm);color:var(--text)}.chat-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999}.chat-menu-dropdown{position:absolute;top:100%;right:0;margin-top:4px;z-index:1000;background:var(--surface);border:1px solid var(--border-light);border-radius:12px;box-shadow:0 8px 24px #0000001f;padding:6px 0;min-width:200px;animation:menuFadeIn .12s ease}@keyframes menuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.chat-menu-dropdown button{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;border:none;background:none;font-size:14px;font-family:inherit;color:var(--text);cursor:pointer;transition:background .1s}.chat-menu-dropdown button:hover{background:var(--bg-warm)}.chat-menu-dropdown button svg{color:var(--muted);flex-shrink:0}.chat-menu-divider{height:1px;background:var(--border-light);margin:4px 0}.chat-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0000004d;animation:fadeIn .15s ease}.chat-panel{position:absolute;top:0;right:0;width:340px;height:100%;background:var(--surface);box-shadow:-4px 0 24px #0000001a;display:flex;flex-direction:column;animation:panelSlideIn .2s ease}@keyframes panelSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.chat-panel-header{height:56px;padding:0 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-light);font-size:17px;font-weight:700;flex-shrink:0}.club-info-panel{padding:32px 24px;display:flex;flex-direction:column;align-items:center;text-align:center}.club-info-avatar{width:80px;height:80px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;margin-bottom:16px}.club-info-name{font-size:20px;font-weight:700;margin:0}.club-info-level{font-size:13px;color:var(--accent);font-weight:600;margin-top:4px}.club-info-desc{font-size:14px;color:var(--muted);margin-top:12px;line-height:1.5}.club-info-stats{display:flex;gap:32px;margin-top:24px}.club-info-stat{display:flex;flex-direction:column;align-items:center}.club-info-stat-value{font-size:24px;font-weight:700;color:var(--accent)}.club-info-stat-label{font-size:12px;color:var(--muted);margin-top:2px}.message-list-wrapper{flex:1;position:relative;overflow:hidden;display:flex;flex-direction:column}.message-list{flex:1;overflow-x:hidden;overflow-y:auto;padding:16px 20px 0;display:flex;flex-direction:column;gap:4px;touch-action:pan-y;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.scroll-to-bottom{position:absolute;right:16px;bottom:12px;width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #00000026;z-index:10;transition:opacity .15s}.scroll-to-bottom:hover{background:var(--bg-warm);color:var(--text)}.msg-row{max-width:min(520px,100%);display:flex;flex-direction:column;min-width:0}.msg-row.incoming{align-self:flex-start}.msg-row.msg-group-middle,.msg-row.msg-group-last{margin-top:-2px}.msg-row.incoming.msg-group-first .msg-bubble,.msg-row.incoming.msg-group-first .msg-standalone-content{border-bottom-left-radius:4px}.msg-row.incoming.msg-group-middle .msg-bubble,.msg-row.incoming.msg-group-middle .msg-standalone-content{border-top-left-radius:4px;border-bottom-left-radius:4px}.msg-row.incoming.msg-group-last .msg-bubble,.msg-row.incoming.msg-group-last .msg-standalone-content{border-top-left-radius:4px}.msg-row.outgoing.msg-group-first .msg-bubble,.msg-row.outgoing.msg-group-first .msg-standalone-content{border-bottom-right-radius:4px}.msg-row.outgoing.msg-group-middle .msg-bubble,.msg-row.outgoing.msg-group-middle .msg-standalone-content{border-top-right-radius:4px;border-bottom-right-radius:4px}.msg-row.outgoing.msg-group-last .msg-bubble,.msg-row.outgoing.msg-group-last .msg-standalone-content{border-top-right-radius:4px}.msg-sender-line{display:flex;align-items:center;gap:6px;margin-bottom:2px;padding:0 2px}.msg-sender-name{font-size:13px;font-weight:600;color:var(--accent)}.msg-sender-role{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:1px 6px;border-radius:4px}.msg-sender-role.teacher{color:var(--accent);background:var(--accent-light)}.msg-sender-role.admin{color:var(--error);background:var(--error-dim)}.msg-bubble{padding:8px 12px;border-radius:var(--radius);font-size:14px;line-height:1.55;position:relative;word-wrap:break-word}.msg-row.incoming .msg-bubble{background:var(--surface);border:1px solid var(--border-light);border-bottom-left-radius:4px}.msg-row.outgoing .msg-bubble{background:var(--accent-light);border:1px solid rgba(193,127,62,.15);border-bottom-right-radius:4px}.msg-time-inline{float:right;font-size:11px;color:var(--muted);margin-left:8px;margin-top:4px;line-height:1}.msg-row.outgoing .msg-time-inline{color:#c17f3e99}.msg-time-standalone{display:block;font-size:11px;color:var(--muted);text-align:right;margin-top:2px;padding-right:2px}.msg-standalone-content{position:relative}.msg-reply-bar{font-size:12px;color:var(--muted);border-left:2px solid var(--accent);padding-left:8px;margin-bottom:4px;display:flex;flex-direction:column;gap:1px;overflow:hidden;min-width:0;max-width:100%}.msg-reply-name{font-weight:600;color:var(--accent);font-size:11px}.msg-reply-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-row{position:relative}.msg-swipe-icon{position:absolute;top:50%;transform:translateY(-50%) scale(0);width:28px;height:28px;border-radius:50%;background:var(--accent-light);display:flex;align-items:center;justify-content:center;opacity:0;transition:transform .15s ease,opacity .15s ease;pointer-events:none;z-index:1}.msg-row.swiping .msg-swipe-icon{transition:none}.msg-swipe-icon.visible{opacity:1;transform:translateY(-50%) scale(1)}.msg-swipe-icon svg{width:16px;height:16px;color:var(--accent)}.msg-context-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999}.msg-context-menu{position:fixed;z-index:1000;background:var(--surface);border:1px solid var(--border-light);border-radius:8px;box-shadow:0 4px 16px #0000001f;padding:4px 0;min-width:140px;-webkit-user-select:none;user-select:none}.msg-context-menu button{display:block;width:100%;padding:8px 16px;text-align:left;border:none;background:none;font-size:13px;font-family:inherit;color:var(--text);cursor:pointer}.msg-context-menu button:hover{background:var(--bg-warm)}.msg-context-divider{height:1px;background:var(--border-light);margin:4px 0}.reply-preview{display:flex;align-items:center;gap:8px;padding:6px 20px;background:var(--surface);border-top:1px solid var(--border-light);border-left:3px solid var(--accent);margin:0 12px;border-radius:4px}.reply-preview-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.reply-preview-name{font-size:12px;font-weight:600;color:var(--accent)}.reply-preview-text{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-preview-close{width:24px;height:24px;border-radius:50%;border:none;background:var(--bg-warm);color:var(--muted);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.reply-preview-close:hover{background:var(--border)}.msg-highlight{position:relative}.msg-highlight:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:inherit;background:#c17f3e26;pointer-events:none;animation:highlightPulse 5s ease forwards;z-index:0}@keyframes highlightPulse{0%{opacity:1}20%{opacity:.4}40%{opacity:.8}70%{opacity:.3}to{opacity:0}}.msg-system{align-self:center;color:var(--muted);font-size:12px;text-align:center;max-width:80%;padding:4px 12px;background:var(--bg-warm);border-radius:9999px}.msg-system:has(.ai-feedback-msg),.msg-system:has(.feedback-offer-msg){border-radius:var(--radius);max-width:90%;padding:0;background:none}.ai-feedback-msg{background:var(--bg-warm);border-radius:var(--radius);padding:12px 16px;max-width:100%;border-left:3px solid #7c3aed}.ai-feedback-header{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:#7c3aed;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.ai-feedback-icon{width:14px;height:14px;color:#7c3aed}.ai-feedback-body{font-size:14px;line-height:1.5;color:var(--text);white-space:pre-wrap}.ai-feedback-followup{margin-top:12px;padding-top:10px;border-top:1px solid var(--border-light);font-size:14px;line-height:1.5;color:var(--text-secondary);font-style:italic;white-space:pre-wrap}.feedback-offer-msg{display:flex;align-items:center;gap:10px;padding:6px 16px}.feedback-offer-label{font-size:13px;color:var(--muted)}.feedback-offer-buttons{display:flex;gap:6px}.feedback-offer-btn{font-size:12px;padding:3px 12px;border-radius:9999px;border:1px solid #7c3aed;color:#7c3aed;background:transparent;cursor:pointer;transition:background .15s,color .15s}.feedback-offer-btn:hover{background:#7c3aed;color:#fff}.feedback-offer-thinking{font-size:13px;color:var(--muted);font-style:italic}.input-bar{padding:12px 20px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--border-light);background:var(--surface);display:flex;align-items:flex-end;gap:8px;position:relative;flex-shrink:0}.input-bar textarea{flex:1;border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;font-size:16px;font-family:inherit;resize:none;min-height:40px;max-height:120px;outline:none;background:var(--bg);color:var(--text)}.input-bar textarea:focus{border-color:var(--accent)}.input-bar>button{width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px}.input-bar .send-btn{background:var(--accent);color:#fff}.input-bar .send-btn:hover{background:var(--accent-hover)}.input-bar .attach-btn,.input-bar .voice-btn{background:var(--bg);color:var(--muted);border:1px solid var(--border)}.input-bar .attach-btn:hover,.input-bar .voice-btn:hover{background:var(--bg-warm)}.recording-bar{justify-content:center;gap:12px}.recording-indicator{display:flex;align-items:center;gap:8px;flex:1}.recording-dot{width:10px;height:10px;border-radius:50%;background:var(--error);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.recording-time{font-size:14px;font-weight:500;font-variant-numeric:tabular-nums;color:var(--text)}.cancel-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--error-dim);color:var(--error);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cancel-btn:hover{background:var(--error);color:#fff}.video-recording-bar{justify-content:center;gap:12px;align-items:center}.video-note-preview{width:200px;height:200px;border-radius:50%;overflow:hidden;border:3px solid var(--accent);flex-shrink:0;position:relative;background:var(--text)}.video-note-preview video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.video-note-preview-spinner{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;width:calc(100% + 6px);height:calc(100% + 6px);pointer-events:none;z-index:2}.video-note-preview-spinner svg{width:100%;height:100%}.video-note-preview-spinner .vidnote-spinner-arc{transform-origin:center;animation:vidnote-spin 1.2s linear infinite}.video-note-preview.has-stream .video-note-preview-spinner{display:none}.video-recording-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:20}.video-recording-controls{display:flex;align-items:center;gap:16px}.video-recording-controls .cancel-btn,.video-recording-controls .send-btn{width:48px;height:48px;border-radius:50%;border:none;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.video-recording-controls .cancel-btn{background:#fff3;color:#fff}.video-recording-controls .send-btn{background:var(--accent);color:#fff}.video-recording-controls .recording-indicator,.video-recording-controls .recording-time{color:#fff}.vidnote-recording{display:flex;flex-direction:column;align-items:center;gap:8px}.vidnote-recording video{width:240px;height:240px;border-radius:50%;object-fit:cover;border:3px solid var(--accent)}.typing-indicator{padding:4px 20px;font-size:12px;color:var(--muted);min-height:20px}.vidnote{width:200px;height:200px;border-radius:50%;overflow:hidden;position:relative;cursor:pointer;background:linear-gradient(135deg,var(--bg-warm),var(--border));display:flex;align-items:center;justify-content:center;transition:width .3s,height .3s;flex-shrink:0}.vidnote video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;border-radius:50%}.vidnote-expanded{width:320px;height:320px}.vidnote-play-btn{position:absolute;width:48px;height:48px;border-radius:50%;background:#c17f3ed9;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;z-index:2;pointer-events:none}.vidnote-playing .vidnote-play-btn{display:none}.vidnote-placeholder{font-size:32px;color:var(--muted)}.vidnote-dur{position:absolute;bottom:8px;font-size:11px;color:var(--muted);background:#ffffffb3;padding:1px 6px;border-radius:4px;z-index:2;pointer-events:none}.vidnote-ring{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;width:calc(100% + 8px);height:calc(100% + 8px);pointer-events:none;z-index:3;transform:rotate(-90deg)}.vidnote-ring-bg{fill:none;stroke:var(--border);stroke-width:3}.vidnote-ring-hit{fill:none;stroke:transparent;stroke-width:20;pointer-events:none}.vidnote-ring.seekable .vidnote-ring-hit{pointer-events:stroke;cursor:pointer}.vidnote-ring-progress{fill:none;stroke:var(--accent);stroke-width:3;stroke-linecap:round}.vidnote-playing .vidnote-ring-progress{stroke:var(--success)}.vidnote-ring-thumb{fill:var(--accent);opacity:0;transition:opacity .15s;pointer-events:none}.vidnote-playing .vidnote-ring-thumb{fill:var(--success)}.vidnote-ring.seekable .vidnote-ring-thumb{opacity:1}.vidnote-wrapper{position:relative;display:inline-block}.vidnote-speed-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.msg-row.incoming .vidnote-speed-row{flex-direction:row}.msg-row.outgoing .vidnote-speed-row{flex-direction:row-reverse}@media(max-width:768px){.vidnote-speed-row .voice-transcript{flex-basis:100%;max-width:100%;padding-left:0;padding-right:0}}.speed-btn{font-size:10px;font-weight:700;font-family:inherit;font-variant-numeric:tabular-nums;min-width:30px;height:20px;padding:0 4px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--muted);cursor:pointer;flex-shrink:0;transition:all .15s;display:inline-flex;align-items:center;justify-content:center}.speed-btn:hover{border-color:var(--accent);color:var(--accent)}.speed-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.vidnote-uploading{pointer-events:none;opacity:.8}.vidnote-upload-thumb{width:100%;height:100%;object-fit:cover;position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;transform:scaleX(-1)}.vidnote-upload-spinner{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;width:calc(100% + 8px);height:calc(100% + 8px);z-index:3;pointer-events:none}.vidnote-upload-spinner svg{width:100%;height:100%}.vidnote-spinner-arc{transform-origin:center;animation:vidnote-spin 1.2s linear infinite}@keyframes vidnote-spin{to{transform:rotate(360deg)}}.vidnote-volume{position:absolute;bottom:-20px;width:80px;opacity:0;transition:opacity .2s;z-index:3}.vidnote:hover .vidnote-volume{opacity:1}.photo-gallery{display:flex;flex-direction:column;gap:2px;border-radius:var(--radius-sm);overflow:hidden}.photo-gallery-row{display:flex;flex-shrink:0}.photo-gallery-item{overflow:hidden;cursor:pointer;line-height:0;flex-shrink:0}.photo-gallery-item img{width:100%;height:100%;object-fit:cover;display:block}.photo-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000d9;display:flex;align-items:center;justify-content:center;cursor:default;animation:fadeIn .15s ease}.photo-lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;object-fit:contain}.lightbox-counter{position:absolute;top:16px;left:50%;transform:translate(-50%);color:#fff;font-size:14px;background:#00000080;padding:4px 12px;border-radius:12px}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#00000080;color:#fff;border:none;font-size:32px;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.lightbox-prev{left:12px}.lightbox-next{right:12px}.lightbox-nav.disabled{opacity:.25;pointer-events:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.voice-msg{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--surface);border:1px solid var(--border-light);border-radius:20px;transition:border-color .2s}.voice-msg-playing{border-color:var(--accent)}.msg-row.outgoing .voice-msg{background:var(--accent-light);border-color:#c17f3e40}.msg-row.outgoing{align-self:flex-end}.voice-play-btn{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .15s}.voice-play-btn:hover{transform:scale(1.08)}.voice-msg-playing .voice-play-btn{background:var(--accent-hover)}.voice-wave{flex:1;height:32px;touch-action:none;display:flex;align-items:center;gap:2px;cursor:pointer;padding:2px 0}.voice-bar{width:3px;border-radius:2px;background:var(--border);transition:background .15s;flex-shrink:0}.voice-bar-played{background:var(--accent)}.msg-row.outgoing .voice-bar{background:#c17f3e40}.msg-row.outgoing .voice-bar-played{background:var(--accent)}.voice-dur{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:32px;text-align:right}.voice-msg-wrapper{min-width:240px;max-width:400px}.voice-transcript{font-size:13px;line-height:1.45;color:var(--muted);padding:6px 14px 2px;white-space:pre-wrap;word-break:break-word}.audio-msg{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md);min-width:240px;max-width:320px}.audio-msg-playing{border-color:var(--accent)}.msg-row.outgoing .audio-msg{background:var(--accent-light);border-color:#c17f3e40}.audio-play-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--accent);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.audio-play-btn:hover{background:var(--accent-hover)}.audio-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.audio-title{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.audio-progress-bar{height:4px;background:var(--border-light);border-radius:2px;cursor:pointer;position:relative;padding:10px 0;background-clip:content-box;touch-action:none}.audio-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .1s linear}.audio-dur{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:32px;text-align:right}.photo-message img{max-width:100%;border-radius:var(--radius-sm);display:block}.photo-message .caption,.video-message .caption{margin-top:6px;padding:8px 12px;font-size:14px;line-height:1.4;white-space:pre-wrap;word-break:break-word;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius)}.video-message video{max-width:100%;border-radius:var(--radius-sm)}.quiz-message{display:flex;flex-direction:column;gap:6px}.quiz-message .quiz-question{font-weight:600;margin-bottom:4px}.quiz-option{padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;font-size:13px}.quiz-option.correct{background:var(--success-dim);border-color:var(--success)}.quiz-option.wrong{background:var(--error-dim);border-color:var(--error)}.word-card{display:flex;flex-direction:column;gap:4px;padding:4px 0}.word-card .word{font-size:18px;font-weight:700}.word-card .ipa{font-size:14px;color:var(--muted)}.word-card .translation{font-size:14px;color:var(--accent)}.assignment-block{border:1px solid var(--accent);border-radius:var(--radius-sm);padding:12px;background:var(--accent-light)}.assignment-block .assignment-title{font-weight:600;margin-bottom:4px}.assignment-block .assignment-desc{font-size:13px;color:var(--muted)}.word-list-table{width:100%;border-collapse:collapse;font-size:13px}.word-list-table th,.word-list-table td{padding:6px 8px;border-bottom:1px solid var(--border-light);text-align:left}.word-list-table th{font-weight:600;color:var(--muted);font-size:11px;text-transform:uppercase}.invite-page{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg)}.invite-card{background:var(--surface);border-radius:var(--radius);padding:40px;text-align:center;max-width:400px;width:100%;box-shadow:0 2px 12px #0000000f}.invite-card h2{font-size:20px;margin-bottom:8px}.invite-card p{color:var(--muted);margin-bottom:24px}.invite-card .join-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:12px 32px;font-size:15px;font-weight:600;cursor:pointer}.invite-card .join-btn:hover{background:var(--accent-hover)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:var(--muted);gap:8px;padding:40px;text-align:center}.empty-state .empty-icon{font-size:48px;opacity:.3}.paywall{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;max-width:480px;margin:0 auto;padding:48px 24px;flex:1}.paywall-icon{font-size:56px;opacity:.4;margin-bottom:16px}.paywall-title{font-size:22px;font-weight:700;color:var(--text);margin:0 0 8px}.paywall-subtitle{font-size:14px;color:var(--muted);margin:0 0 28px;line-height:1.5}.paywall-plans{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%}.plan-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:8px}.plan-card-label{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}.plan-card-price{font-size:28px;font-weight:700;color:var(--accent)}.plan-card-period{font-size:14px;font-weight:400;color:var(--muted)}.plan-card-btn{width:100%;padding:10px 16px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s;margin-top:4px}.plan-card-btn:hover{background:var(--accent-hover)}.plan-card-btn:disabled{opacity:.6;cursor:not-allowed}.subscription-status{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:16px}.subscription-plan{font-size:16px;color:var(--text);margin:0}.subscription-expires{font-size:14px;color:var(--muted);margin:0}.cancel-sub-btn{background:var(--error);margin-top:12px;max-width:200px}.cancel-sub-btn:hover{background:var(--error);opacity:.85}.msg-context-menu button.danger{color:var(--error)}.msg-context-menu button.danger:hover{background:var(--error-dim)}.command-suggestions{position:absolute;bottom:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border-light);border-radius:12px;box-shadow:0 -4px 20px #0000001a;padding:6px 0;z-index:10;max-height:240px;overflow-y:auto}.command-suggestion{display:flex;align-items:center;gap:12px;width:100%;padding:8px 16px;border:none;background:none;font-family:inherit;cursor:pointer;text-align:left;transition:background .1s;white-space:nowrap}.command-suggestion:hover{background:var(--accent-light)}.cmd-link{color:var(--accent);cursor:pointer;font-weight:500}.cmd-link:hover{text-decoration:underline}.command-suggestion-cmd{font-size:14px;font-weight:600;color:var(--accent);flex-shrink:0;min-width:90px}.command-suggestion-desc{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis}.profile-btn{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;cursor:pointer;border:none;flex-shrink:0;transition:opacity .15s}.profile-btn:hover{opacity:.85}.profile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.profile-overlay.open{display:block}.profile-panel{display:none;position:absolute;top:52px;right:12px;width:320px;background:var(--surface);border:1px solid var(--border-light);border-radius:14px;box-shadow:0 8px 32px #0000001f;z-index:100;overflow:hidden;animation:profileIn .15s ease}.profile-panel.open{display:block}@keyframes profileIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.profile-panel-header{display:flex;align-items:center;gap:14px;padding:20px 20px 16px}.profile-panel-avatar{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:20px;flex-shrink:0}.profile-panel-name{font-size:15px;font-weight:600}.profile-panel-email{font-size:12px;color:var(--muted);margin-top:2px}.profile-panel-section{padding:0 20px 16px}.profile-panel-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:8px}.profile-panel-sub{display:flex;justify-content:space-between;align-items:center}.profile-panel-plan{font-size:14px;font-weight:600}.profile-panel-expires{font-size:12px;color:var(--muted);margin-top:2px}.profile-panel-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:9999px}.profile-panel-badge.active{color:var(--success);background:var(--success-dim)}.profile-panel-badge.expired{color:var(--error);background:var(--error-dim)}.profile-panel-divider{height:1px;background:var(--border-light);margin:0 20px}.profile-panel-logout{display:block;width:calc(100% - 40px);margin:16px 20px;padding:10px;border-radius:10px;border:1px solid var(--border);background:none;color:var(--muted);font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s;text-align:center}.profile-panel-logout:hover{border-color:var(--error);color:var(--error)}
