*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#eef2f5;--bg-header:#fff;--bg-bubble:#fff;--bg-bubble-own:#dcf8c6;--bg-reply-bar:#f0f4ff;--bg-input:#fff;--bg-input-wrap:#f0f2f5;--text:#1a1a1a;--text-muted:#8a8a8e;--text-secondary:#667085;--accent:#2d74da;--accent-light:#ebf2ff;--accent-hover:#2563c3;--danger:#ff3b30;--border:#e4e8ee;--shadow-bubble:0 1px 2px #0000001a;--shadow-header:0 1px 4px #00000012;--radius:18px;--radius-sm:10px;--radius-xs:6px;--name-colors:#2d74da, #e05c2a, #27ae60, #8e44ad, #c0392b, #16a085}html,body{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,Arial,sans-serif;font-size:15px;line-height:1.45;overflow-x:hidden}#root{height:100%}.app{background:var(--bg);flex-direction:column;max-width:640px;height:100dvh;margin:0 auto;display:flex}.app__header{background:var(--bg-header);box-shadow:var(--shadow-header);z-index:20;border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:12px 16px;display:flex;position:sticky;top:0}.app__header-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.app__header-icon{background:var(--accent-light);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;display:flex}.app__header-info{flex-direction:column;min-width:0;display:flex}.app__title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:16px;font-weight:700;overflow:hidden}.app__subtitle{color:var(--text-muted);font-size:12px;font-weight:400}.app__header-actions{align-items:center;gap:6px;display:flex}.app__icon-btn{cursor:pointer;width:36px;height:36px;color:var(--text-muted);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s;display:flex}.app__icon-btn:hover{background:var(--bg-input-wrap);color:var(--accent)}.app__main{flex-direction:column;flex:1;padding:12px 8px 8px;display:flex;overflow-y:auto}.app__footer{background:var(--bg-input);border-top:1px solid var(--border);padding:8px 8px 12px}.comment-list{flex-direction:column;gap:2px;display:flex}.comment{align-items:flex-end;gap:8px;padding:3px 8px;display:flex}.comment--reply{padding:2px 0 0}.comment__avatar-wrap{flex-shrink:0;align-self:flex-end;margin-bottom:2px}.comment__bubble{background:var(--bg-bubble);border-radius:var(--radius) var(--radius) var(--radius) 4px;min-width:0;box-shadow:var(--shadow-bubble);flex:1;max-width:calc(100% - 48px);padding:8px 12px 6px;position:relative}.comment__bubble--own{background:var(--bg-bubble-own);border-radius:var(--radius) var(--radius) 4px var(--radius)}.comment__header{align-items:baseline;gap:6px;margin-bottom:3px;display:flex}.comment__name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.comment__time{color:var(--text-muted);flex-shrink:0;margin-left:auto;font-size:11px}.comment__text{word-break:break-word;white-space:pre-wrap;color:var(--text);font-size:15px;line-height:1.45}.comment__image{border-radius:var(--radius-sm);cursor:pointer;object-fit:cover;width:100%;max-width:100%;max-height:280px;margin-top:6px;display:block}.comment__quote{border-left:3px solid var(--accent);border-radius:0 var(--radius-xs) var(--radius-xs) 0;color:var(--text-secondary);background:#2d74da14;margin-bottom:6px;padding:4px 8px;font-size:13px}.comment__quote-author{color:var(--accent);margin-bottom:1px;font-size:12px;font-weight:700}.comment__quote-text{text-overflow:ellipsis;white-space:nowrap;max-width:220px;overflow:hidden}.comment__actions{flex-wrap:wrap;align-items:center;gap:4px;margin-top:5px;display:flex}.comment__btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);background:0 0;border:none;padding:3px 6px;font-size:12px;font-weight:500;transition:background .12s,color .12s}.comment__btn:hover{background:var(--accent-light);color:var(--accent)}.comment__btn--danger:hover{color:var(--danger);background:#ff3b301a}.comment__actions-sep{background:var(--border);width:1px;height:12px}.reactions{flex-wrap:wrap;align-items:center;gap:4px;margin-top:5px;display:flex}.reaction{background:var(--bg-input-wrap);cursor:pointer;-webkit-user-select:none;user-select:none;border:1.5px solid #0000;border-radius:30px;align-items:center;gap:3px;padding:3px 8px;font-size:14px;line-height:1;transition:border-color .12s,background .12s;display:flex}.reaction:hover,.reaction--active{border-color:var(--accent);background:var(--accent-light)}.reaction__count{color:var(--accent);min-width:10px;font-size:12px;font-weight:600}.reaction__add{border:1.5px dashed var(--border);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:30px;padding:3px 7px;font-size:14px;transition:border-color .12s,color .12s}.reaction__add:hover{border-color:var(--accent);color:var(--accent)}.reaction-picker{background:var(--bg-header);border:1px solid var(--border);border-radius:30px;gap:4px;margin-top:4px;padding:4px 8px;display:flex;box-shadow:0 4px 16px #0000001f}.reaction-picker__emoji{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px;font-size:20px;line-height:1;transition:transform .1s}.reaction-picker__emoji:hover{transform:scale(1.3)}.comment__replies{flex-direction:column;gap:2px;margin-top:4px;margin-left:16px;display:flex}.comment__replies .comment__bubble{border-left:3px solid var(--border);border-radius:var(--radius-xs) var(--radius) var(--radius) var(--radius-xs);background:#f7f8fa}.name-color-0{color:#2d74da}.name-color-1{color:#e05c2a}.name-color-2{color:#27ae60}.name-color-3{color:#8e44ad}.name-color-4{color:#c0392b}.name-color-5{color:#16a085}.name-color-6{color:#d4ac0d}.name-color-7{color:#1a5276}.comment-form{flex-direction:column;gap:0;display:flex}.comment-form__reply-banner{background:var(--bg-reply-bar);border-left:3px solid var(--accent);border-radius:0 var(--radius-xs) var(--radius-xs) 0;color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:6px;margin-left:2px;padding:6px 10px;font-size:13px;display:flex}.comment-form__reply-preview{flex:1;min-width:0}.comment-form__reply-author{color:var(--accent);font-size:12px;font-weight:700}.comment-form__reply-text{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.comment-form__cancel{cursor:pointer;color:var(--text-muted);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:2px;font-size:16px;line-height:1;display:flex}.comment-form__cancel:hover{color:var(--danger)}.comment-form__row{align-items:flex-end;gap:8px;display:flex}.comment-form__input-wrap{background:var(--bg-input-wrap);border:1.5px solid #0000;border-radius:22px;flex:1;min-width:0;padding:8px 12px;transition:border-color .15s}.comment-form__input-wrap:focus-within{border-color:var(--accent);background:#fff}.comment-form__textarea{width:100%;color:var(--text);resize:none;background:0 0;border:none;outline:none;max-height:120px;font-family:inherit;font-size:15px;line-height:1.4;display:block;overflow-y:auto}.comment-form__textarea::placeholder{color:var(--text-muted)}.comment-form__preview{margin-bottom:6px;display:inline-block;position:relative}.comment-form__preview img{border-radius:var(--radius-sm);object-fit:cover;max-width:120px;max-height:80px;display:block}.comment-form__remove-img{color:#fff;cursor:pointer;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;display:flex;position:absolute;top:-5px;right:-5px}.comment-form__attach{cursor:pointer;color:var(--text-muted);background:0 0;border:none;flex-shrink:0;margin-bottom:2px;padding:0 2px;font-size:20px;line-height:1;transition:color .12s}.comment-form__attach:hover{color:var(--accent)}.comment-form__send{background:var(--accent);cursor:pointer;color:#fff;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s,transform .1s;display:flex}.comment-form__send:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.05)}.comment-form__send:disabled{background:var(--border);cursor:not-allowed}.comment-form__send svg{width:18px;height:18px}.empty{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty__icon{opacity:.6;font-size:52px}.empty__title{color:var(--text);font-size:17px;font-weight:700}.empty__text{color:var(--text-muted);text-align:center;max-width:240px;font-size:14px;line-height:1.5}.date-divider{align-items:center;gap:10px;padding:8px 0;display:flex}.date-divider__line{background:var(--border);flex:1;height:1px}.date-divider__label{color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:2px 8px;font-size:12px;font-weight:500}.loader{flex:1;justify-content:center;align-items:center;padding:50px;display:flex}.loader__spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:30px;height:30px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-msg{color:var(--danger);text-align:center;padding:20px;font-size:14px}.error-screen{height:100dvh;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:20px;display:flex}
