@layer app{@scope (.palace-app-chat){.ct-shell{display:contents}.playout{min-height:calc(100dvh - var(--wordmark-h, 44px) - var(--nav-h));max-height:calc(100dvh - var(--wordmark-h, 44px) - var(--nav-h));overflow:hidden}.playout-detail-pane{display:flex;flex-direction:column;overflow:hidden}@media(width<=699px){.ct-shell:not(.ct-in-chat) .playout-detail-pane{display:none}.ct-shell.ct-in-chat .playout-list-pane{display:none}.ct-shell.ct-in-chat .playout-detail-pane{flex:1;display:flex;flex-direction:column;overflow:hidden}}.ct-section-label{font-size:var(--text-2xs);letter-spacing:.1em;text-transform:uppercase;color:var(--gold-muted);margin-bottom:.75rem;margin-top:.5rem}.ct-group-card{display:flex;align-items:center;gap:.875rem;padding:.875rem;margin-bottom:.5rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:border-color .2s,transform .15s}.ct-group-card:hover{border-color:color-mix(in srgb,var(--gold) 40%,transparent);transform:translateY(-1px)}.ct-group-icon{width:var(--space-5);height:var(--space-5);border-radius:50%;background:var(--gold);color:var(--text);display:flex;align-items:center;justify-content:center;font-family:var(--font);font-size:var(--text-xl);font-weight:400;flex-shrink:0}.ct-group-info{flex:1;min-width:0}.ct-group-name{font-size:var(--text-base);font-weight:500;color:var(--text);margin-bottom:.15rem}.ct-group-desc{font-size:var(--text-xs);color:var(--text-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ct-group-count{font-size:var(--text-xs);color:var(--text-faint);flex-shrink:0}.ct-chat{display:none}.ct-chat.active{display:flex;flex-direction:column;flex:1;min-height:0}.ct-chat-hd{display:flex;align-items:center;gap:.75rem;padding:.875rem var(--space-2);background:var(--card);border-bottom:1px solid var(--border);flex-shrink:0;padding-top:calc(.875rem + env(safe-area-inset-top))}.ct-chat-back{display:flex;align-items:center;justify-content:center;width:var(--space-4);height:var(--space-4);border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);color:var(--text-mid);cursor:pointer;transition:color .2s;flex-shrink:0}.ct-chat-back:hover{color:var(--text)}.ct-chat-name{flex:1;font-family:var(--font);font-size:var(--text-lg);font-weight:400;letter-spacing:.06em;color:var(--text)}.ct-call-btn{width:var(--space-4);height:var(--space-4);border-radius:50%;background:var(--surface);border:1px solid var(--border);color:var(--text-mid);font-size:var(--text-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s;flex-shrink:0}.ct-call-btn:hover{color:var(--gold);background:var(--card)}.ct-incoming{display:none;align-items:center;gap:.75rem;padding:.75rem var(--space-2);background:var(--gold-faint);border-bottom:1px solid var(--border);flex-shrink:0}.ct-incoming.active{display:flex}.ct-incoming-text{flex:1;font-size:var(--text-base);color:var(--text)}.ct-callbar{display:none;align-items:center;gap:.75rem;padding:.6rem var(--space-2);background:var(--success-dark);flex-shrink:0}.ct-callbar.active{display:flex}.ct-callbar-text{flex:1;font-size:var(--text-sm);color:var(--bg);font-weight:500}.ct-callbar-pulse{width:var(--space-1);height:var(--space-1);border-radius:50%;background:var(--bg);animation:ct-pulse 1.5s infinite}@keyframes ct-pulse{0%,to{opacity:1}50%{opacity:.3}}.ct-mute-btn,.ct-leave-btn{padding:.3rem .65rem;border-radius:var(--radius-md);font-size:var(--text-xs);cursor:pointer;font-family:var(--font);border:none}.ct-mute-btn{background:color-mix(in srgb,var(--bg) 20%,transparent);color:var(--bg)}.ct-mute-btn.muted{background:color-mix(in srgb,var(--bg) 35%,transparent);color:var(--bg)}.ct-leave-btn{background:var(--error-dark);color:var(--bg)}.ct-messages{flex:1;overflow-y:auto;padding:var(--space-2);display:flex;flex-direction:column;gap:.5rem;-webkit-overflow-scrolling:touch}.ct-msg{max-width:80%;display:flex;flex-direction:column}.ct-msg.ct-mine{align-self:flex-end;align-items:flex-end}.ct-msg.ct-other{align-self:flex-start;align-items:flex-start}.ct-msg-sender{font-size:var(--text-2xs);color:var(--text-faint);margin-bottom:.15rem;letter-spacing:.03em;padding:0 .5rem}.ct-bubble{padding:.6rem .9rem;border-radius:var(--radius-lg);font-size:var(--text-base);line-height:1.45;overflow-wrap:break-word}.ct-mine .ct-bubble{background:var(--gold);color:var(--text);border-bottom-right-radius:var(--space-0h)}.ct-other .ct-bubble{background:var(--card);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:var(--space-0h)}.ct-msg-time{font-size:var(--text-3xs);color:var(--text-faint);margin-top:.15rem;padding:0 .5rem}.ct-chat-input{border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.ct-bubble-img{max-height:var(--col-200, 200px);border-radius:var(--radius-sm);display:block;margin-bottom:.3rem}.ct-deleted-msg{font-style:italic;color:var(--text-faint);background:var(--surface);border:1px dashed var(--border)}.ct-edited-label{font-size:var(--text-3xs);color:var(--text-faint);font-style:italic;padding:0 .5rem}.ct-msg-meta{display:flex;align-items:center;gap:.35rem;padding:0 .5rem}.ct-msg-meta .ct-msg-time{margin-top:0;padding:0}.ct-read-status{font-size:var(--text-3xs);color:var(--text-faint)}.ct-read-status.ct-read{color:var(--gold)}.ct-msg-highlight{animation:ct-highlight-flash 1.5s ease}@keyframes ct-highlight-flash{0%{background:color-mix(in srgb,var(--gold),transparent 70%)}to{background:transparent}}.ct-reply-quote{font-size:var(--text-xs);background:color-mix(in srgb,var(--text),transparent 94%);border-left:2px solid var(--gold);border-radius:var(--radius-xs);padding:.3rem .6rem;margin-bottom:.25rem;cursor:pointer;max-width:100%;overflow:hidden}.ct-reply-quote-name{font-weight:500;color:var(--gold);font-size:var(--text-2xs);margin-bottom:.1rem}.ct-reply-quote-text{color:var(--text-mid);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ct-reply-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem var(--space-2);background:var(--surface);border-top:1px solid var(--border);flex-shrink:0}.ct-reply-bar-accent{width:3px;align-self:stretch;background:var(--gold);border-radius:2px;flex-shrink:0}.ct-reply-bar-content{flex:1;min-width:0;overflow:hidden}.ct-reply-bar-name{font-size:var(--text-2xs);font-weight:500;color:var(--gold)}.ct-reply-bar-text{font-size:var(--text-xs);color:var(--text-mid);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ct-reply-bar-close{background:none;border:none;color:var(--text-faint);font-size:var(--text-sm);cursor:pointer;padding:.2rem;flex-shrink:0;font-family:var(--font)}.ct-reply-bar-close:hover{color:var(--text)}.ct-edit-bar{border-top:1px solid var(--border);background:var(--surface);flex-shrink:0;padding:.5rem var(--space-2)}.ct-edit-bar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.35rem}.ct-edit-bar-label{font-size:var(--text-2xs);color:var(--gold);font-weight:500;letter-spacing:.04em}.ct-edit-bar-cancel{background:none;border:none;color:var(--text-faint);font-size:var(--text-xs);cursor:pointer;padding:0;font-family:var(--font)}.ct-edit-bar-cancel:hover{color:var(--text)}.ct-edit-bar-row{display:flex;gap:.5rem;align-items:flex-end}.ct-edit-input{flex:1;resize:none;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-family:var(--font);font-size:var(--text-base);padding:.5rem .75rem;outline:none;line-height:1.4;min-height:2.2rem;max-height:8rem}.ct-edit-input:focus{border-color:var(--gold)}.ct-typing-indicator{display:flex;align-items:center;gap:.4rem;padding:.25rem 0}.ct-typing-dots{display:flex;align-items:center;gap:3px}.ct-typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--text-faint);animation:ct-typing-bounce 1.2s ease-in-out infinite}.ct-typing-dots span:nth-child(2){animation-delay:.15s}.ct-typing-dots span:nth-child(3){animation-delay:.3s}@keyframes ct-typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.ct-typing-name{font-size:var(--text-2xs);color:var(--text-faint);font-style:italic}.ct-reaction-badges{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.2rem;padding:0 .25rem}.ct-reaction-badge{display:inline-flex;align-items:center;gap:.2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.15rem .45rem;font-size:var(--text-sm);cursor:pointer;transition:border-color .15s}.ct-reaction-badge:hover{border-color:color-mix(in srgb,var(--gold) 50%,transparent)}.ct-reaction-badge.ct-reacted{border-color:var(--gold);background:color-mix(in srgb,var(--gold),transparent 92%)}.ct-reaction-count{font-size:var(--text-2xs);color:var(--text-mid)}.ct-reaction-picker{display:flex;justify-content:center;gap:.25rem;padding:.6rem .75rem;border-bottom:1px solid var(--border)}.ct-reaction-pick-btn{background:none;border:none;font-size:var(--text-xl);cursor:pointer;padding:.3rem;border-radius:var(--radius-sm);transition:background .15s}.ct-reaction-pick-btn:hover{background:color-mix(in srgb,var(--text),transparent 92%)}.ct-link-preview{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;text-decoration:none;margin-top:.25rem;max-width:100%}.ct-link-preview:hover{border-color:color-mix(in srgb,var(--gold) 50%,transparent)}.ct-link-preview-img{width:100%;max-height:120px;object-fit:cover;display:block}.ct-link-preview-body{padding:.45rem .65rem}.ct-link-preview-title{font-size:var(--text-sm);font-weight:500;color:var(--text);margin-bottom:.15rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ct-link-preview-desc{font-size:var(--text-xs);color:var(--text-faint);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.ct-menu-backdrop{position:fixed;inset:0;background:color-mix(in srgb,var(--text),transparent 60%);z-index:1000}.ct-menu-panel{position:absolute;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 32px color-mix(in srgb,var(--text),transparent 70%);min-width:12rem;overflow:hidden;z-index:1001}.ct-menu-items{display:flex;flex-direction:column}.ct-menu-item{background:none;border:none;text-align:left;padding:.65rem 1rem;font-family:var(--font);font-size:var(--text-sm);color:var(--text);cursor:pointer;transition:background .15s}.ct-menu-item:hover{background:color-mix(in srgb,var(--text),transparent 95%)}.ct-menu-item-danger{color:var(--error)}.ct-menu-item-danger:hover{background:color-mix(in srgb,var(--error),transparent 92%)}}}
