@import "https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=Noto+Sans+SC:wght@400;500;700&family=Noto+Serif+SC:wght@500;600;700&display=swap";:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}body{font-family:IBM Plex Sans,Noto Sans SC,PingFang SC,Microsoft YaHei,sans-serif}button,input,textarea{font:inherit}:root{--brand:#07c160;--brand-strong:#06ad56;--brand-soft:#e8f9f0;--teal:#22a6a1;--danger:#de6b63;--text-primary:#1c1c1c;--text-secondary:#555;--text-muted:#999;--bg-page:#ededed;--bg-panel:#fff;--bg-panel-soft:#f7f7f7;--bg-border:#00000017;--bg-border-strong:#00000026;--shadow-sm:none;--shadow-md:none;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--transition:.18s ease;--font-display:"IBM Plex Sans", "Noto Sans SC", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;min-height:100%}body{color:var(--text-primary);background:#ededed;overflow:hidden}.bg-animation{display:none}.app-container{width:100vw;min-width:0;height:100dvh;min-height:0;box-shadow:none;background:#ededed;border:none;border-radius:0;grid-template-columns:336px minmax(0,1fr);margin:0;display:grid;overflow:hidden}.sidebar{background:#f7f7f7;border-right:1px solid #e0e0e0;flex-direction:column;min-width:0;height:100%;min-height:0;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--bg-border);flex-direction:column;flex-shrink:0;gap:10px;padding:14px 14px 12px;display:flex}.sidebar-header-top{justify-content:space-between;align-items:center;gap:10px;display:flex}.sidebar-header-main{align-items:center;gap:10px;min-width:0;display:flex}.sidebar-header-copy{min-width:0}.sidebar-header-icon{width:34px;height:34px;font-family:var(--font-display);letter-spacing:.04em;color:#fff;background:#07c160;border-radius:10px;flex-shrink:0;place-items:center;font-size:14px;font-weight:700;display:grid}.sidebar-header h2{font-size:15px;font-family:var(--font-display);letter-spacing:.02em;white-space:nowrap;font-weight:700;line-height:1.2}.sidebar-header-robot-name{color:var(--text-muted);letter-spacing:0;font-size:13px;font-weight:500}.sidebar-header p{color:var(--text-muted);white-space:nowrap;margin-top:2px;font-size:11px}.sidebar-header-action{color:#07c160;cursor:pointer;height:30px;transition:border-color var(--transition), background var(--transition);white-space:nowrap;background:#fff;border:1px solid #d0d0d0;border-radius:999px;flex-shrink:0;padding:0 12px;font-size:11px;font-weight:700}.sidebar-header-action:hover{background:#f0faf5;border-color:#07c160}.sidebar-stats{grid-template-columns:1fr 1fr;gap:6px;width:100%;display:grid}.sidebar-stat-item{background:#eee;border:1px solid #ddd;border-radius:8px;flex-direction:column;gap:1px;padding:6px 10px;display:flex}.sidebar-stat-label{color:var(--text-muted);font-size:10px;font-weight:500}.sidebar-stat-value{color:#07c160;font-size:16px;font-weight:700;line-height:1.2}.sidebar-stat-sub{color:var(--text-muted);font-size:10px}.user-list{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:8px;height:0;min-height:0;padding:10px 10px 18px;display:flex;overflow-y:auto}.user-list>*{flex-shrink:0}.view-toggle{background:#ebebeb;border-radius:999px;align-items:center;gap:2px;width:100%;padding:3px;display:flex}.view-toggle-btn{color:#888;cursor:pointer;height:26px;transition:background var(--transition), color var(--transition);white-space:nowrap;background:0 0;border:none;border-radius:999px;flex:1;justify-content:center;align-items:center;gap:5px;padding:0 10px;font-size:11px;font-weight:600;display:inline-flex}.view-toggle-btn:hover{color:#555}.view-toggle-btn.active{color:#07c160;background:#fff;box-shadow:0 1px 4px #0000001a}.view-toggle-btn.active.hosting{color:#f97316}.view-toggle-dot{background:#07c160;border-radius:999px;flex-shrink:0;width:6px;height:6px}.view-toggle-dot.hosting{background:#f97316}.view-toggle-count{color:#c2500a;background:#f9731626;border-radius:999px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:9px;font-weight:700;display:inline-flex}.view-toggle-btn:not(.hosting) .view-toggle-count{color:#06ad56;background:#07c16026}.status-section-empty{color:var(--text-muted);text-align:center;padding:24px 14px;font-size:12px}.owner-group{background:#fff;border:1px solid #e5e5e5;border-radius:14px;transition:border-color .2s,box-shadow .2s;overflow:hidden}.owner-group.expanded{border-color:#b8dfc8;box-shadow:0 2px 10px #07c16017}.owner-group-header{cursor:pointer;width:100%;color:var(--text-primary);text-align:left;transition:background var(--transition);-webkit-user-select:none;user-select:none;background:0 0;border:none;align-items:center;gap:10px;padding:11px 14px;display:flex}.owner-group-header:hover{background:#f5f5f5}.owner-group.expanded .owner-group-header{background:#f0fdf6;border-bottom:1px solid #daf0e4}.owner-group.expanded .owner-group-header:hover{background:#eafaf2}.owner-group-avatar{color:#fff;letter-spacing:0;background:linear-gradient(135deg,#f04444 0%,#d63030 100%);border-radius:9px;flex-shrink:0;place-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:grid}.owner-group-name{color:var(--text-primary);letter-spacing:.01em;white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;font-weight:700;overflow:hidden}.owner-group-count{color:#888;transition:background var(--transition), color var(--transition);background:#0000000f;border-radius:999px;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:600}.owner-group.expanded .owner-group-count{color:#06ad56;background:#07c1601f}.owner-group-stats{color:#bbb;white-space:nowrap;transition:color var(--transition);flex-shrink:0;font-size:10px}.owner-group.expanded .owner-group-stats{color:#7ec49a}.owner-streak-badge{white-space:nowrap;cursor:default;border-radius:999px;flex-shrink:0;align-items:center;gap:3px;padding:1px 7px 1px 5px;font-size:11px;font-weight:700;transition:all .2s;display:inline-flex}.owner-streak-badge.lit{color:var(--streak-color);background:color-mix(in srgb, var(--streak-color) 12%, transparent);border:1px solid color-mix(in srgb, var(--streak-color) 30%, transparent);box-shadow:0 0 8px var(--streak-glow)}.owner-streak-badge.dim{color:#aab8cc;filter:grayscale();opacity:.55;background:#aab8cc1a;border:1px solid #aab8cc33}.owner-group-arrow{color:#ccc;flex-shrink:0;font-size:8px;transition:transform .22s,color .2s;transform:rotate(0)}.owner-group-arrow.expanded{color:#07c160;transform:rotate(90deg)}.owner-group-body{background:#fafafa;flex-direction:column;gap:5px;padding:8px 8px 10px;display:flex}.owner-group-body .user-item+.user-item{margin-top:0}.user-item{cursor:pointer;transition:background var(--transition), border-color var(--transition), box-shadow var(--transition);touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;content-visibility:auto;contain-intrinsic-size:88px;background:#fff;border:1px solid #0000;border-radius:10px;align-items:stretch;gap:12px;padding:12px;display:flex;position:relative;box-shadow:0 1px 3px #0000000d}.user-item-trigger{text-align:left;min-width:0;color:inherit;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex:1;align-items:flex-start;gap:12px;padding:0;display:flex}.user-item+.user-item{margin-top:0}.user-item:hover{background:#f0fdf6;border-color:#c4e4d0;box-shadow:0 2px 6px #07c16014}.user-item.active{box-shadow:none;background:#d9f0e4;border-color:#a6d4b8}.user-avatar{color:#fff;width:44px;height:44px;box-shadow:none;background:#07c160;border-radius:999px;flex-shrink:0;place-items:center;font-size:15px;font-weight:700;display:grid}.user-avatar-wrap{flex-shrink:0;position:relative}.user-unread-badge{color:#fff;pointer-events:none;box-sizing:border-box;background:#ef4444;border:2px solid #fff;border-radius:999px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.user-info{flex:1;min-width:0}.user-line{justify-content:space-between;align-items:center;gap:10px;display:flex}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:700;overflow:hidden}.user-time{color:var(--text-muted);flex-shrink:0;font-size:11px}.user-wxid{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-family:monospace;font-size:10px;overflow:hidden}.user-status{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:6px;font-size:12px;line-height:1.55;display:-webkit-box;overflow:hidden}.user-owner-row{align-items:center;gap:8px;margin-top:7px;display:flex}.user-owner-badge,.chat-owner-badge{min-height:24px;color:var(--brand-strong);letter-spacing:.01em;background:#e8f3ffeb;border:1px solid #6f95d32e;border-radius:999px;align-items:center;padding:0 10px;font-size:11px;font-weight:700;display:inline-flex}.chat-owner-badge{margin-top:8px}.user-msg-count{color:var(--text-muted);margin-left:auto;font-size:10px}.user-side-actions{flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.user-quick-action,.delete-user-btn{width:28px;height:28px;color:var(--text-muted);cursor:pointer;opacity:0;transition:opacity var(--transition), background var(--transition), color var(--transition);box-shadow:none;background:#ffffffe0;border:none;border-radius:999px;font-size:17px}.user-quick-action{opacity:0;font-size:14px}.user-item:hover .delete-user-btn,.user-item.active .delete-user-btn,.user-item:hover .user-quick-action,.user-item.active .user-quick-action{opacity:1}.user-quick-action:hover{color:#07c160;background:#f0faf5}.delete-user-btn:hover{color:var(--danger);background:#fff1ef}.delete-user-btn:disabled{cursor:not-allowed}.delete-user-btn.loading{opacity:1;color:var(--danger);background:#fff1ef;font-weight:700}.chat-area{background:#ededed;flex-direction:column;min-width:0;height:100%;min-height:0;display:flex;overflow:hidden}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;height:100%;min-height:0;padding:24px;display:flex}.empty-state-icon{color:#07c160;width:104px;height:104px;box-shadow:none;background:#f0faf5;border:1px solid #c5e8d5;border-radius:28px;place-items:center;font-size:26px;font-weight:700;display:grid}.empty-state h3{font-size:32px;font-family:var(--font-display);letter-spacing:.03em;font-weight:600;line-height:1.15}.empty-state p{max-width:540px;color:var(--text-secondary);line-height:1.75}.empty-state-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.chat-header{background:#f7f7f7;border-bottom:1px solid #e0e0e0;flex-shrink:0;grid-template-columns:minmax(220px,1fr) auto minmax(220px,1fr);align-items:center;gap:18px;padding:18px 24px 16px;display:grid}.chat-header-left{align-items:center;gap:14px;min-width:0;display:flex}.chat-header-center{justify-content:center;display:flex}.mobile-menu-btn{border:1px solid var(--bg-border-strong);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:#ffffffeb;border-radius:12px;place-items:center;display:none}.chat-header-avatar{color:#fff;width:46px;height:46px;box-shadow:none;background:#07c160;border-radius:8px;place-items:center;font-size:15px;font-weight:700;display:grid}.chat-header-info h3{font-size:24px;font-family:var(--font-display);white-space:nowrap;text-overflow:ellipsis;font-weight:600;line-height:1.15;overflow:hidden}.chat-header-info p{color:var(--text-muted);margin-top:6px;font-size:12px}.chat-header-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.quality-summary-card{min-width:330px;box-shadow:none;background:#fff;border:1px solid #e0e0e0;border-radius:12px;align-items:center;gap:14px;padding:10px 14px;display:flex}.quality-summary-chart{border-radius:999px;flex-shrink:0;place-items:center;width:68px;height:68px;display:grid}.quality-summary-chart-hole{background:#fcfefffa;border-radius:999px;flex-direction:column;justify-content:center;align-items:center;width:46px;height:46px;display:flex;box-shadow:inset 0 1px #fffc}.quality-summary-total{color:var(--text-primary);font-size:16px;font-weight:700;line-height:1}.quality-summary-total-label{color:var(--text-muted);margin-top:4px;font-size:10px;font-weight:700;line-height:1}.quality-summary-meta{flex-direction:column;gap:8px;min-width:0;display:flex}.quality-summary-title{color:var(--text-secondary);font-size:13px;font-weight:700}.quality-summary-legend{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.quality-legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:11px;font-weight:700;display:inline-flex}.quality-legend-dot{border-radius:999px;width:8px;height:8px;display:inline-block}.quality-legend-item.success .quality-legend-dot{background:#2ca36d}.quality-legend-item.failed .quality-legend-dot{background:#d26a5a}.quality-legend-item.pending .quality-legend-dot{background:#d8deea}.quality-summary-comment{border-left:1px solid #7082a224;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-width:64px;padding-left:14px;display:flex}.quality-summary-comment-value{color:#07c160;font-size:22px;font-weight:700;line-height:1}.quality-summary-comment-label{color:var(--text-muted);font-size:11px;font-weight:700}.icon-btn{height:40px;color:var(--text-secondary);cursor:pointer;box-shadow:none;transition:border-color var(--transition), background var(--transition), color var(--transition);background:#fff;border:1px solid #d5d5d5;border-radius:999px;padding:0 14px;font-size:12px;font-weight:700}.icon-btn:hover{color:var(--text-primary);box-shadow:none;background:#f5f5f5;border-color:#bbb;transform:none}.icon-btn.active{color:#07c160;background:#f0faf5;border-color:#b2dfc5}.icon-btn.icon-btn-strong{color:#fff;box-shadow:none;background:#07c160;border-color:#07c160}.icon-btn.icon-btn-strong:hover,.icon-btn.icon-btn-strong.active{color:#fff;background:#06ad56;border-color:#06ad56}.icon-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.messages-container{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;overflow-anchor:none;will-change:scroll-position;background:#ededed;flex-direction:column;flex:1;gap:18px;min-height:0;padding:28px clamp(18px,3vw,40px);display:flex;overflow-y:scroll}.loading-hint{color:var(--text-secondary);font-size:13px}.message{contain:layout;max-width:min(76ch,88%);display:flex}.message.assistant{align-self:flex-start}.message.user{align-self:flex-end}.message-wrapper{align-items:flex-start;gap:10px;display:flex}.message.user .message-wrapper{flex-direction:row-reverse}.message-main{min-width:0}.message-avatar{color:#fff;white-space:nowrap;border-radius:12px;flex-shrink:0;place-items:center;width:34px;min-width:34px;max-width:34px;height:34px;min-height:34px;max-height:34px;font-size:11px;font-weight:700;line-height:1;display:grid;overflow:hidden;box-shadow:0 4px 10px #1e283e14}.message.assistant .message-avatar{box-shadow:none;background:#07c160;border-radius:4px}.message.user .message-avatar{box-shadow:none;background:#5fbe4b;border-radius:4px}.message-content{white-space:pre-wrap;word-break:break-word;cursor:pointer;transition:border-color var(--transition), background var(--transition);border:1px solid #0000;border-radius:18px;padding:14px 16px;font-size:14px;line-height:1.72}.message.assistant .message-content{color:var(--text-primary);box-shadow:none;background:#fff;border-color:#d9d9d9;border-radius:4px 14px 14px}.message.user .message-content{color:#1a1a1a;box-shadow:none;background:#95ec69;border-radius:14px 4px 14px 14px}.message-content.error{color:#9d2f2f;background:#fff4f3;border-color:#c35b523d}.message.selection-mode{max-width:min(80ch,94%)}.message.selection-mode .message-main{align-items:flex-start;gap:10px;display:flex}.message-select-btn{color:#0000;cursor:pointer;width:24px;height:24px;transition:border-color var(--transition), background var(--transition), color var(--transition);background:#ffffffd6;border:1px solid #7082a247;border-radius:999px;flex-shrink:0;margin-top:3px;font-size:12px;font-weight:700;line-height:1}.message-select-btn:hover{border-color:#07c16080}.message-select-btn.selected{color:#fff;background:#07c160;border-color:#0000}.message.selected .message-content{border-color:#07c16080;box-shadow:0 0 0 2px #07c16026}.message.has-comment-thread .message-content{border-color:#07c16059;box-shadow:0 0 0 2px #07c1601a}.message.assistant.review-good .message-content,.message.assistant .message-content.review-good{box-shadow:none;background:#f4fbf0;border-color:#07c16066}.message.assistant.review-bad .message-content,.message.assistant .message-content.review-bad{box-shadow:none;background:#fff6f5;border-color:#c35b5252}.retry-btn{color:#b63a3a;cursor:pointer;background:#ffffffe6;border:1px solid #c35b5242;border-radius:999px;height:28px;margin-top:10px;padding:0 12px;font-size:12px;font-weight:700}.message-meta{color:var(--text-muted);margin-top:4px;font-size:11px}.message.user .message-meta{text-align:right}.message-extra{justify-content:space-between;align-items:center;gap:10px;margin-top:10px;display:flex}.message.user .message-extra{justify-content:flex-end}.assistant-message-actions{align-items:center;gap:8px;display:flex}.assistant-review-actions{box-shadow:none;background:#fff;border:1px solid #e0e0e0;border-radius:999px;align-items:center;gap:4px;padding:3px;display:inline-flex}.assistant-review-btn{color:#7483a0;cursor:pointer;min-width:24px;height:28px;transition:background var(--transition), color var(--transition), box-shadow var(--transition);background:0 0;border:none;border-radius:999px;align-items:center;gap:4px;padding:0 10px;font-size:12px;font-weight:700;line-height:1;display:inline-flex}.assistant-review-btn:hover{color:#07c160;background:#e8f9f0}.assistant-review-btn.good.active{color:#1f7a37;background:#e7f7eb;box-shadow:inset 0 0 0 1px #9bd2a8}.assistant-review-btn.bad.active{color:#a63c34;background:#fdeeed;box-shadow:inset 0 0 0 1px #efb1ac}.assistant-review-icon{font-size:12px;line-height:1}.assistant-review-text{white-space:nowrap;font-size:11px;font-weight:700;line-height:1}.message-review-badge{letter-spacing:.15px;border-radius:999px;align-items:center;gap:4px;min-height:24px;margin-top:8px;padding:0 10px;font-size:12px;font-weight:700;display:inline-flex}.message-review-badge.review-good{color:#196f37;background:linear-gradient(#e9f8ef 0%,#dcf2e6 100%);border:1px solid #9fd5b0;box-shadow:0 8px 14px #37905e1f}.message-review-badge.review-bad{color:#9d3631;background:linear-gradient(#fff1f0 0%,#ffe5e4 100%);border:1px solid #efb0ac;box-shadow:0 8px 14px #b4433d1a}.message-comment-btn{height:28px;color:var(--text-secondary);cursor:pointer;transition:border-color var(--transition), color var(--transition), background var(--transition);box-shadow:none;background:#ffffffe6;border:1px solid #97b1d838;border-radius:999px;padding:0 10px;font-size:12px;font-weight:700}.message-comment-btn:hover{color:var(--text-primary);border-color:#486db23d}.message-comment-btn.has-comment{color:#fff;box-shadow:none;background:#07c160;border-color:#07c1604d}.message-comment-btn.has-comment:before{content:"";vertical-align:middle;background:#fff;border-radius:999px;width:6px;height:6px;margin-right:6px;display:inline-block}.message-comment-panel{border-radius:var(--radius-md);box-shadow:none;background:#f7f7f7;border:1px solid #e0e0e0;margin-top:10px;padding:12px}.message-comment-title{color:#555;letter-spacing:.25px;margin-bottom:8px;font-size:12px;font-weight:700}.message-comment-input{width:100%;min-height:84px;color:var(--text-primary);resize:vertical;background:#ffffffeb;border:1px solid #718ab647;border-radius:14px;outline:none;padding:10px 12px;line-height:1.55}.message-comment-input:focus{border-color:#07c16080;box-shadow:0 0 0 3px #07c1601f}.message-comment-content{color:var(--text-primary);white-space:pre-wrap;word-break:break-word;background:#ffffffd6;border:1px solid #718ab633;border-radius:14px;padding:10px 12px;font-size:13px;line-height:1.65}.message-comment-time{color:#999;margin-top:6px;font-size:11px;font-weight:500}.message-comment-actions{justify-content:flex-end;align-items:center;gap:8px;margin-top:10px;display:flex}.typing-indicator{box-shadow:none;background:#fff;border:1px solid #e0e0e0;border-radius:16px;gap:4px;padding:10px 12px;display:flex}.typing-indicator-wrap{align-items:center;gap:10px;display:flex}.cancel-waiting-btn{color:#c0392b;cursor:pointer;white-space:nowrap;background:#fff0f0e6;border:1px solid #dc505066;border-radius:12px;padding:4px 10px;font-size:11px;transition:background .15s,border-color .15s}.cancel-waiting-btn:hover{background:#ffdcdcf2;border-color:#dc5050b3}.typing-indicator span{background:#07c160;border-radius:999px;width:7px;height:7px;animation:1.15s ease-in-out infinite pulse}.typing-indicator span:nth-child(2){animation-delay:.12s}.typing-indicator span:nth-child(3){animation-delay:.24s}@keyframes pulse{0%,80%,to{opacity:.45;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.input-area{background:#f7f7f7;border-top:1px solid #e0e0e0;flex-shrink:0;padding:16px clamp(16px,2vw,24px) 18px}.selection-toolbar{border-radius:var(--radius-md);max-width:1040px;box-shadow:none;background:#ffffffdb;border:1px solid #97b1d833;justify-content:space-between;align-items:center;gap:10px;margin:0 auto 12px;padding:12px 14px;display:flex}.selection-count{color:var(--text-secondary);font-size:13px;font-weight:700}.selection-actions{align-items:center;gap:8px;display:flex}.input-wrapper{align-items:flex-end;gap:10px;max-width:1040px;margin:0 auto;display:flex}.message-input{min-height:52px;max-height:176px;color:var(--text-primary);resize:none;background:#fff;border:1px solid #d5d5d5;border-radius:8px;outline:none;flex:1;padding:12px 14px;line-height:1.6;box-shadow:inset 0 1px #ffffffb3}.message-input::placeholder{color:var(--text-muted)}.message-input:focus{border-color:#07c160;outline:none;box-shadow:0 0 0 3px #07c1601f}.message-input:disabled{color:var(--text-muted);cursor:not-allowed;background:#f4f6fae6}.send-btn{color:#fff;cursor:pointer;min-width:94px;height:52px;box-shadow:none;background:#07c160;border:none;border-radius:8px;font-weight:700}.send-btn:hover:not(:disabled){filter:none;background:#06ad56}.send-btn:disabled{opacity:.58;cursor:not-allowed;box-shadow:none}.modal-overlay{z-index:1000;background:#4166a438;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.modal{width:min(620px,100%);max-height:86vh;box-shadow:var(--shadow-md);background:#fafdfff5;border:1px solid #97b1d833;border-radius:26px;flex-direction:column;display:flex;overflow:hidden}.modal.large{width:min(860px,100%)}.modal-header{border-bottom:1px solid var(--bg-border);justify-content:space-between;align-items:center;height:66px;padding:0 20px;display:flex}.modal-header h3{font-size:20px;font-family:var(--font-display);font-weight:600}.modal-close{width:34px;height:34px;color:var(--text-secondary);cursor:pointer;background:#fffffff5;border:1px solid #7082a233;border-radius:12px;font-size:20px}.modal-close:hover{color:var(--text-primary);background:#fff}.modal-body{flex:1;min-height:0;padding:20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--bg-border);justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.form-group+.form-group{margin-top:14px}.form-label{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:700;display:block}.form-input{background:#ffffffeb;border:1px solid #97b1d83d;border-radius:14px;outline:none;width:100%;height:44px;padding:0 12px}.form-input:focus{border-color:#07c16080;box-shadow:0 0 0 3px #07c1601a}.form-hint{color:var(--text-muted);margin-top:6px;font-size:12px}.btn-primary,.btn-secondary,.btn-danger{cursor:pointer;border-radius:999px;height:40px;padding:0 14px;font-weight:700}.btn-primary{color:#fff;background:#07c160;border:1px solid #07c160}.btn-secondary{color:var(--text-secondary);background:#fff;border:1px solid #d5d5d5}.btn-danger{color:#fff;background:linear-gradient(145deg,#d2685f,#bf4f45);border:1px solid #0000}.btn-primary:disabled,.btn-secondary:disabled,.btn-danger:disabled{opacity:.6;cursor:not-allowed}.data-section{background:#ffffffd6;border:1px solid #97b1d833;border-radius:18px;padding:14px}.data-section+.data-section{margin-top:12px}.data-section-title{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:700}.data-section-content{color:var(--text-primary);white-space:pre-wrap;line-height:1.62}.json-block{color:#333;background:#f7f7f7;border:1px solid #e0e0e0;border-radius:8px;margin:0;padding:14px;font-family:Cascadia Mono,Consolas,monospace;font-size:12px;line-height:1.6;overflow-x:auto;box-shadow:inset 0 1px #ffffffb3}.muted-text{color:var(--text-muted);font-size:13px}.sidebar-overlay{pointer-events:none;display:none}.login-screen{background:var(--bg-page);flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100dvh;display:flex}.login-card{border-radius:var(--radius-lg);border:1px solid var(--bg-border);background:var(--bg-panel);flex-direction:column;width:min(340px,92vw);display:flex;overflow:hidden}.login-card-header{border-bottom:1px solid var(--bg-border);background:var(--bg-panel-soft);flex-direction:column;align-items:center;gap:12px;padding:28px 28px 24px;display:flex}.login-logo{border-radius:var(--radius-md);background:var(--brand);color:#fff;width:48px;height:48px;font-size:13px;font-weight:700;font-family:var(--font-display);letter-spacing:.03em;text-align:center;place-items:center;line-height:1.2;display:grid}.login-title{text-align:center;font-size:16px;font-weight:700;font-family:var(--font-display);color:var(--text-primary);letter-spacing:.02em;margin:0}.login-subtitle{color:var(--text-muted);margin:-6px 0 0;font-size:12px}.login-card-body{flex-direction:column;gap:14px;padding:24px 28px 28px;display:flex}.login-field{flex-direction:column;gap:5px;display:flex}.login-label{color:var(--text-secondary);font-size:12px;font-weight:600}.login-input{border-radius:var(--radius-sm);border:1px solid var(--bg-border-strong);background:var(--bg-panel-soft);height:42px;color:var(--text-primary);transition:border-color var(--transition);outline:none;padding:0 12px;font-size:14px}.login-input::placeholder{color:var(--text-muted)}.login-input:focus{border-color:var(--brand);background:#fff}.login-error{border-radius:var(--radius-sm);color:#c0392b;background:#fff1f0;border:1px solid #ffd0cc;padding:9px 12px;font-size:12px;font-weight:500}.login-btn{border-radius:var(--radius-sm);background:var(--brand);color:#fff;height:42px;font-size:14px;font-weight:700;font-family:var(--font-display);cursor:pointer;transition:background var(--transition);border:none;margin-top:2px}.login-btn:hover:not(:disabled){background:var(--brand-strong)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.sidebar-icon-btn{color:#888;cursor:pointer;width:28px;height:28px;transition:background var(--transition), color var(--transition), border-color var(--transition);background:#fff;border:1px solid #d5d5d5;border-radius:8px;flex-shrink:0;place-items:center;font-size:14px;display:grid}.sidebar-icon-btn:hover{color:#555;background:#f5f5f5;border-color:#bbb}.sidebar-icon-btn.spinning{pointer-events:none;animation:.7s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar-icon-btn.logout:hover{color:var(--danger);background:#fff1ef;border-color:#f5b8b3}.sidebar-footer{border-top:1px solid var(--bg-border);background:var(--bg-panel-soft);flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;display:flex}.sidebar-footer-account{align-items:center;gap:7px;min-width:0;display:flex}.sidebar-footer-avatar{background:var(--brand);color:#fff;border-radius:8px;flex-shrink:0;place-items:center;width:26px;height:26px;font-size:11px;font-weight:700;display:grid}.sidebar-footer-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.sidebar-footer-wxid{color:var(--text-muted);margin-top:1px;font-family:monospace;font-size:10px}.sidebar-footer-role{color:var(--text-muted);margin-top:1px;font-size:10px}.sidebar-logout-btn{border:1px solid var(--bg-border-strong);height:26px;color:var(--text-secondary);cursor:pointer;transition:background var(--transition), color var(--transition), border-color var(--transition);background:0 0;border-radius:999px;flex-shrink:0;padding:0 10px;font-size:11px;font-weight:600}.sidebar-logout-btn:hover{color:var(--danger);background:#fff1ef;border-color:#f5b8b3}@media (width<=980px){.app-container{border:none;border-radius:0;grid-template-columns:1fr;width:100vw;height:100dvh;min-height:100dvh;margin:0}.sidebar{z-index:1200;pointer-events:auto;isolation:isolate;background:#f7f7f7;border-right:1px solid #e0e0e0;width:min(90vw,356px);transition:transform .22s;position:fixed;top:0;bottom:0;left:0;overflow:hidden;transform:translate(-102%);box-shadow:2px 0 12px #0000001f}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:1100;background:#141d2d2e;position:fixed;inset:0 0 0 min(90vw,356px)}.sidebar-overlay.active{pointer-events:auto;display:block}.mobile-menu-btn{display:inline-grid}.sidebar-header{background:#f8f2e9f5;gap:8px;padding:12px 14px 10px}.sidebar-header-main{width:100%}.sidebar-header h2{font-size:12px}.sidebar-header p{margin-top:2px}.sidebar-header-action{height:28px}.chat-header{grid-template:"left actions""center center"/1fr auto;align-items:start;gap:6px 10px;padding:10px 12px 8px;display:grid}.user-list{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y;pointer-events:auto;flex:auto;height:auto;padding:12px 12px 24px;overflow:hidden auto}.user-item{pointer-events:auto;background:#fffffff0;border-color:#7082a21f;padding:12px;box-shadow:0 10px 18px #1f2b420f}.user-item.active{background:#cce9b5}.user-item-trigger{pointer-events:auto}.user-name{font-size:11px}.user-status{font-size:9px}.user-side-actions{gap:6px}.chat-owner-badge{margin-top:6px}.chat-header-left{grid-area:left;align-items:center;gap:10px;width:100%;min-width:0;overflow:hidden}.chat-header-actions{grid-area:actions;grid-template-columns:repeat(2,minmax(70px,auto));align-self:start;gap:5px;width:auto;display:grid}.chat-header-center{grid-area:center;justify-content:flex-start;width:100%}.quality-summary-card{border-radius:12px;gap:8px;width:100%;min-width:0;padding:8px 12px}.quality-summary-chart,.quality-summary-chart-hole,.quality-summary-total,.quality-summary-total-label{display:none}.quality-summary-meta{flex-flow:wrap;flex:1;align-items:center;gap:6px;min-width:0}.quality-summary-title{white-space:nowrap;font-size:9px}.quality-summary-legend{flex-flow:wrap;gap:4px 10px;display:flex}.quality-legend-item{white-space:nowrap;font-size:9px}.quality-summary-comment{min-width:44px;padding-left:8px}.quality-summary-comment-value{font-size:13px}.quality-summary-comment-label{font-size:8px}.icon-btn{justify-content:center;width:100%;min-width:0;height:36px;padding:0 8px;font-size:9px}.messages-container{padding:12px 10px}.message{max-width:96%}.message-extra{flex-wrap:wrap;gap:6px}.assistant-message-actions{flex-wrap:wrap;justify-content:flex-end;gap:6px}.assistant-review-actions{gap:3px;padding:2px}.assistant-review-btn{gap:3px;height:26px;padding:0 8px}.assistant-review-text{font-size:8px}.message-comment-panel{padding:10px}.message-comment-actions{flex-wrap:wrap;gap:6px}.input-area{padding:10px 10px calc(10px + env(safe-area-inset-bottom));background:#f7f7f7;position:sticky;bottom:0}.input-wrapper{gap:8px;max-width:100%}.selection-toolbar{flex-direction:column;align-items:flex-start;margin-bottom:8px;padding:10px 12px}.selection-actions{gap:6px;width:100%}.selection-actions .btn-secondary,.selection-actions .btn-danger{flex:1}.message-select-btn{width:24px;height:24px}.message-input{min-height:44px;max-height:132px}.send-btn{min-width:76px;height:44px;box-shadow:none}.empty-state-actions{flex-direction:column;width:100%;max-width:280px}.empty-state-actions .btn-primary,.empty-state-actions .btn-secondary{width:100%}.chat-header-info p{display:none}.chat-header-info h3{text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:12px;overflow:hidden}.chat-header-avatar{border-radius:11px;width:34px;height:34px;font-size:10px}.message-content{padding:10px 12px;font-size:10px;line-height:1.6}.modal-overlay{padding:12px}.message-meta{font-size:9px}.owner-group-name{font-size:10px}.owner-group-count{font-size:9px}.owner-group-stats{font-size:8px}.owner-streak-badge,.user-time,.user-owner-badge,.chat-owner-badge{font-size:9px}.user-msg-count{font-size:8px}}
