.chat-shell{width:100%;--chat-bg:#efeae2;--chat-bg-dark:#0b141a;--chat-me:#d9fdd3;--chat-me-dark:#005c4b;--chat-them:#ffffff;--chat-them-dark:#202c33;--chat-tick:#53bdeb}.chat-shell__inner{width:100%;max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:.75rem;padding:.5rem .5rem 1rem;box-sizing:border-box}.chat-shell__header{display:flex;flex-direction:column;gap:.6rem;padding:0 .25rem}.chat-shell__title{margin:0;font-size:var(--fs-heading);font-weight:700;color:var(--text);letter-spacing:-.01em}.chat-shell__subtitle{display:none;margin:.2rem 0 0;color:var(--muted);font-size:.9rem}.chat-shell__nav{display:flex;gap:.3rem;padding:.25rem;background:var(--surface-alt);border-radius:999px;border:1px solid var(--border);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;width:100%;box-sizing:border-box}.chat-shell__nav::-webkit-scrollbar{display:none}.chat-shell__link{flex-shrink:0;white-space:nowrap;padding:.4rem .85rem;border-radius:999px;text-decoration:none;color:var(--muted);background:transparent;font-weight:500;font-size:.82rem;transition:background .15s ease,color .15s ease}.chat-shell__link:hover{color:var(--text)}.chat-shell__link--active,.chat-shell__link--primary{background:var(--color-primary);color:white}.chat-shell__link--primary:hover{background:var(--color-primary-hover);color:white}.chat-input{width:100%;padding:.55rem .9rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text);font-size:.95rem;font-family:inherit;box-sizing:border-box;transition:border-color .15s ease,box-shadow .15s ease}.chat-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 22%,transparent)}.chat-input--textarea{border-radius:.75rem;resize:vertical;min-height:80px}.chat-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.5rem 1rem;min-height:2.4rem;border-radius:999px;border:1px solid transparent;background:var(--surface-alt);color:var(--text);font-weight:600;font-size:.85rem;font-family:inherit;cursor:pointer;text-decoration:none;white-space:nowrap;transition:background .15s ease,transform .08s ease}.chat-btn:disabled{opacity:.6;cursor:not-allowed}.chat-btn--primary{background:var(--color-primary);color:white}.chat-btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.chat-btn--ghost{background:transparent;border-color:var(--border)}.chat-btn--ghost:hover:not(:disabled){background:var(--surface-alt)}.chat-btn--danger{background:#c0392b;color:white}.chat-btn--danger:hover:not(:disabled){background:#a53125}.chat-btn--icon{width:2.4rem;height:2.4rem;min-height:2.4rem;padding:0;border-radius:50%;background:transparent;color:var(--muted);font-size:1.05rem}.chat-btn--icon:hover:not(:disabled){background:var(--surface-alt);color:var(--text)}.chat-state{padding:1.5rem 1rem;text-align:center;color:var(--muted);background:var(--card-bg);border:1px solid var(--card-border);border-radius:.75rem}.chat-state--error{color:#c0392b;border-color:#f5b7b1;background:color-mix(in srgb,#f5b7b1 22%,var(--card-bg))}.chat-empty{padding:2rem 1rem;text-align:center;background:var(--card-bg);border:1px dashed var(--card-border);border-radius:.75rem;display:flex;flex-direction:column;align-items:center;gap:.6rem}.chat-empty h3{margin:0;color:var(--text);font-size:1.05rem}.chat-empty p{margin:0;color:var(--muted);max-width:420px}.chat-section{display:flex;flex-direction:column;gap:.6rem}.chat-section__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:0 .5rem}.chat-section__head h2{margin:0;font-size:.85rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.chat-section__link{font-size:.8rem;color:var(--color-primary);text-decoration:none;font-weight:600}.chat-section__link:hover{text-decoration:underline}.chat-list-panel{background:var(--card-bg);border:1px solid var(--card-border);border-radius:.75rem;overflow:hidden;display:flex;flex-direction:column}.chat-list-panel__search{padding:.6rem;border-bottom:1px solid var(--card-border);background:var(--surface-alt);display:flex;flex-wrap:wrap;gap:.5rem}.chat-list-panel__search>*{flex:1 1 100%;min-width:0}.chat-list{display:flex;flex-direction:column}.chat-list__section-label{padding:.55rem .9rem .3rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);background:var(--surface)}.chat-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.7rem;padding:.7rem .8rem;border-bottom:1px solid color-mix(in srgb,var(--border) 50%,transparent);background:var(--card-bg);text-decoration:none;color:inherit;cursor:pointer;transition:background .12s ease}.chat-row:hover{background:var(--surface-alt)}.chat-row:last-child{border-bottom:none}.chat-row__avatar{grid-column:1;width:2.6rem;height:2.6rem;border-radius:50%;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:white;font-size:.85rem;background:linear-gradient(135deg,var(--color-primary),color-mix(in srgb,var(--color-primary) 55%,#111));flex-shrink:0}.chat-row__avatar img{width:100%;height:100%;object-fit:cover}.chat-row__body{grid-column:2;min-width:0;display:flex;flex-direction:column;gap:.15rem}.chat-row__head{display:flex;align-items:baseline;justify-content:space-between;gap:.4rem}.chat-row__name{margin:0;font-size:.95rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.chat-row__time{font-size:.68rem;color:var(--muted);flex-shrink:0}.chat-row__preview{display:flex;align-items:center;min-width:0}.chat-row__snippet{font-size:.82rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1 1}.chat-row__action{grid-column:3;display:inline-flex;align-items:center;gap:.35rem;flex-shrink:0;justify-self:end}.chat-row__action .chat-btn{padding:.4rem .95rem;min-height:2.1rem;font-size:.82rem}.chat-row__badge{background:var(--color-primary);color:white;font-size:.7rem;font-weight:700;padding:.15rem .55rem;border-radius:999px;text-align:center}.chat-row__badge--muted{background:var(--surface);color:var(--muted);border:1px solid var(--border);font-weight:600}.chat-row__tag{display:inline-flex;align-items:center;gap:.2rem;font-size:.7rem;padding:.15rem .45rem;border-radius:999px;background:color-mix(in srgb,var(--color-primary) 15%,transparent);color:var(--color-primary);font-weight:600}.chat-row__tag--private{background:color-mix(in srgb,#e67e22 20%,transparent);color:#b35100}.chat-form{gap:.9rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:.75rem;padding:1rem;max-width:680px;width:100%;box-sizing:border-box}.chat-form,.chat-form__row{display:flex;flex-direction:column}.chat-form__row{gap:.35rem}.chat-form__row label{font-size:.82rem;font-weight:600;color:var(--text)}.chat-form__row .chat-input:not(.chat-input--textarea){border-radius:.55rem}.chat-form__grid{display:grid;grid-template-columns:1fr;gap:.9rem}.chat-form__actions{display:flex;justify-content:flex-end;gap:.5rem}.chat-form__error{margin:0;color:#c0392b;font-size:.88rem}.chat-room-main{padding:0!important}.chat-room-page{height:calc(100vh - var(--subject-sticky-offset));height:calc(100dvh - var(--subject-sticky-offset));max-height:calc(100vh - var(--subject-sticky-offset));max-height:calc(100dvh - var(--subject-sticky-offset));overflow:hidden!important;padding:0!important}.chat-room,.chat-room-page{display:flex;flex-direction:column}.chat-room{background:var(--card-bg);flex:1 1;min-height:0;width:100%;max-width:1100px;margin:0 auto;border:none;border-radius:0;overflow:hidden}.chat-room__header{display:flex;align-items:center;gap:.5rem;padding:.5rem .6rem;border-bottom:1px solid var(--card-border);background:var(--surface-alt)}.chat-room__back{width:2.1rem;height:2.1rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;color:var(--text);font-size:1.1rem;flex-shrink:0}.chat-room__back:hover{background:color-mix(in srgb,var(--color-primary) 12%,transparent)}.chat-room__identity{display:flex;align-items:center;gap:.55rem;flex:1 1;min-width:0;cursor:pointer}.chat-room__avatar,.chat-room__avatar-img{width:2.2rem;height:2.2rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:white;background:linear-gradient(135deg,var(--color-primary),color-mix(in srgb,var(--color-primary) 55%,#111));object-fit:cover;flex-shrink:0;font-size:.78rem}.chat-room__title-block{min-width:0;display:flex;flex-direction:column}.chat-room__title{margin:0;font-size:.92rem;font-weight:600;color:var(--text)}.chat-room__subtitle,.chat-room__title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-room__subtitle{background:none;border:none;padding:0;margin:.05rem 0 0;cursor:pointer;font-size:.7rem;color:var(--muted);text-align:left;display:block;max-width:100%}.chat-room__subtitle:hover{color:var(--color-primary)}.chat-room__actions{display:flex;gap:.3rem;align-items:center;flex-shrink:0}.chat-room__actions .chat-btn{padding:.4rem .7rem;min-height:2.1rem;font-size:.78rem}.chat-room__members{padding:.7rem .9rem;border-bottom:1px solid var(--card-border);background:var(--surface)}.chat-room__members h4{margin:0 0 .3rem;font-size:.88rem;color:var(--text)}.chat-room__members p{margin:0;color:var(--muted);font-size:.82rem}.chat-room__members-count{margin-top:.25rem!important;font-size:.7rem!important;text-transform:uppercase;letter-spacing:.04em}.chat-room__messages{flex:1 1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:.75rem .5rem;display:flex;flex-direction:column;gap:.3rem;background-color:var(--chat-bg);background-image:radial-gradient(circle at 20% 20%,rgba(0,0,0,.03) 1px,transparent 1.5px),radial-gradient(circle at 80% 70%,rgba(0,0,0,.025) 1px,transparent 1.5px),radial-gradient(circle at 50% 50%,rgba(0,0,0,.02) 1px,transparent 1.5px);background-size:42px 42px,78px 78px,120px 120px}[data-theme=dark] .chat-room__messages{background-color:var(--chat-bg-dark);background-image:radial-gradient(circle at 20% 20%,rgba(255,255,255,.03) 1px,transparent 1.5px),radial-gradient(circle at 80% 70%,rgba(255,255,255,.025) 1px,transparent 1.5px),radial-gradient(circle at 50% 50%,rgba(255,255,255,.02) 1px,transparent 1.5px)}.chat-room__messages::-webkit-scrollbar{width:6px}.chat-room__messages::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--muted) 40%,transparent);border-radius:6px}.chat-room__empty{margin:auto;color:var(--muted);padding:.9rem 1.1rem;background:color-mix(in srgb,var(--surface) 85%,transparent);border-radius:999px;font-size:.85rem}.chat-room__day{display:flex;flex-direction:column;gap:.15rem}.chat-room__day-marker{align-self:center;font-size:.7rem;color:var(--text);background:color-mix(in srgb,var(--surface) 90%,transparent);padding:.22rem .65rem;border-radius:999px;margin:.4rem 0;box-shadow:0 1px 2px rgba(0,0,0,.08);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.chat-msg{display:flex;align-items:flex-end;gap:.35rem;max-width:88%;align-self:flex-start;position:relative;margin-top:.15rem;cursor:pointer}.chat-msg--mine{flex-direction:row-reverse;align-self:flex-end}.chat-msg+.chat-msg{margin-top:.12rem}.chat-msg__avatar{width:1.7rem;height:1.7rem;border-radius:50%;background:var(--color-primary);color:white;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;overflow:hidden;flex-shrink:0;align-self:flex-end;margin-bottom:.1rem}.chat-msg__avatar img{width:100%;height:100%;object-fit:cover}.chat-msg__bubble{background:var(--chat-them);padding:.45rem .7rem .35rem;border-radius:.6rem;color:#111b21;font-size:.92rem;word-break:break-word;min-width:0;max-width:100%;position:relative;box-shadow:0 1px 1px rgba(0,0,0,.08);line-height:1.35}.chat-msg__bubble:before{content:"";position:absolute;bottom:0;left:-7px;width:10px;height:13px;background:var(--chat-them);clip-path:polygon(100% 0,100% 100%,0 100%)}.chat-msg--mine .chat-msg__bubble{background:var(--chat-me);color:#111b21}.chat-msg--mine .chat-msg__bubble:before{left:auto;right:-7px;background:var(--chat-me);clip-path:polygon(0 0,0 100%,100% 100%)}[data-theme=dark] .chat-msg__bubble{background:var(--chat-them-dark);color:#e9edef}[data-theme=dark] .chat-msg__bubble:before{background:var(--chat-them-dark)}[data-theme=dark] .chat-msg--mine .chat-msg__bubble{background:var(--chat-me-dark);color:#e9edef}[data-theme=dark] .chat-msg--mine .chat-msg__bubble:before{background:var(--chat-me-dark)}.chat-msg.chat-msg--tailless .chat-msg__bubble:before{display:none}.chat-msg.chat-msg--tailless{margin-left:2.05rem}.chat-msg.chat-msg--tailless.chat-msg--mine{margin-left:0}.chat-msg.chat-msg--tailless .chat-msg__avatar{visibility:hidden}.chat-msg__sender{font-weight:600;font-size:.74rem;color:var(--color-primary);margin-bottom:.15rem}.chat-msg--mine .chat-msg__sender{display:none}.chat-msg__reply{display:flex;flex-direction:column;padding:.3rem .5rem;margin-bottom:.35rem;border-left:4px solid var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,transparent);border-radius:.3rem;font-size:.78rem}.chat-msg__reply-sender{font-weight:600;color:var(--color-primary)}.chat-msg__reply-text{color:#4b5b63;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}[data-theme=dark] .chat-msg__reply-text{color:#aebac1}.chat-msg__text{white-space:pre-wrap;word-break:break-word}.chat-msg__text--deleted{color:#667781;font-style:italic}.chat-msg__image{display:block;margin:-.15rem -.35rem .3rem;border-radius:.45rem;overflow:hidden}.chat-msg__image img{max-width:220px;max-height:240px;width:100%;border-radius:.45rem;display:block}.chat-msg__file{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .6rem;background:color-mix(in srgb,var(--color-primary) 8%,transparent);border:1px solid color-mix(in srgb,var(--color-primary) 18%,transparent);border-radius:.4rem;text-decoration:none;color:inherit;font-size:.85rem;margin-bottom:.3rem}.chat-msg__meta{display:flex;justify-content:flex-end;align-items:center;gap:.25rem;margin-top:.2rem;font-size:.66rem;color:#667781;white-space:nowrap}[data-theme=dark] .chat-msg__meta{color:#8696a0}.chat-msg--mine .chat-msg__meta:after{content:"✓✓";color:var(--chat-tick);font-size:.72rem;margin-left:.1rem;letter-spacing:-2px}.chat-msg__reactions{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.35rem}.chat-msg__reaction{display:inline-flex;align-items:center;gap:.2rem;padding:.1rem .45rem;font-size:.8rem;border-radius:999px;background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;line-height:1.4}.chat-msg__reaction--mine{background:color-mix(in srgb,var(--color-primary) 18%,var(--surface));border-color:color-mix(in srgb,var(--color-primary) 50%,var(--border))}.chat-msg__reaction-count{font-size:.7rem;font-weight:600;color:var(--muted)}.chat-msg__reaction--mine .chat-msg__reaction-count{color:var(--color-primary)}.chat-msg__react-wrap{position:relative;display:inline-flex}.chat-msg__react-picker{position:absolute;bottom:calc(100% + .35rem);left:50%;transform:translateX(-50%);display:flex;gap:.15rem;padding:.3rem .4rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:999px;box-shadow:0 6px 24px rgba(0,0,0,.15);z-index:20}.chat-msg--mine .chat-msg__react-picker{left:auto;right:50%;transform:translateX(50%)}.chat-msg__react-picker-item{width:2.1rem;height:2.1rem;border-radius:50%;background:transparent;border:none;cursor:pointer;font-size:1.15rem;line-height:1;padding:0;transition:transform .1s ease,background .1s ease}.chat-msg__react-picker-item:hover{background:var(--surface-alt);transform:scale(1.2)}.chat-msg__tools{display:none;flex-direction:row;gap:.25rem;position:absolute;bottom:calc(100% + .3rem);right:0;z-index:5;background:var(--card-bg);border:1px solid var(--card-border);border-radius:999px;padding:.25rem .4rem;box-shadow:0 6px 20px rgba(0,0,0,.18)}.chat-msg--mine .chat-msg__tools{right:auto;left:0}.chat-msg.chat-msg--active .chat-msg__tools{display:flex}.chat-msg.chat-msg--active .chat-msg__bubble{box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 45%,transparent)}.chat-msg__tool{width:2rem;height:2rem;border-radius:50%;border:none;background:var(--surface);color:var(--muted);cursor:pointer;font-size:.9rem;line-height:1;padding:0;display:inline-flex;align-items:center;justify-content:center}.chat-msg__tool:hover{background:var(--surface-alt);color:var(--text)}.chat-msg__tool--danger:hover{background:color-mix(in srgb,#c0392b 20%,var(--surface));color:#c0392b}.chat-msg__edit{display:flex;flex-direction:column;gap:.4rem}.chat-msg__edit-actions{display:flex;gap:.35rem;justify-content:flex-end}.chat-room__input{border-top:1px solid var(--card-border);padding:.5rem .6rem calc(.6rem + env(safe-area-inset-bottom));background:var(--surface-alt);display:flex;flex-direction:column;gap:.4rem}.chat-room__reply-preview{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.45rem .7rem;background:var(--surface);border-radius:.5rem;font-size:.85rem;border-left:4px solid var(--color-primary)}.chat-room__reply-preview button{background:none;border:none;cursor:pointer;color:var(--muted);font-size:1.15rem;line-height:1;padding:0 .25rem}.chat-room__input-row{display:flex;align-items:flex-end;gap:.35rem}.chat-room__input-row .chat-input{flex:1 1;min-width:0;border-radius:1.3rem;padding:.6rem 1rem;background:var(--surface);border-color:var(--border);font-size:16px}.chat-room__send{width:2.6rem;height:2.6rem;border-radius:50%;padding:0;font-size:1.05rem;background:var(--color-primary);color:white;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.chat-room__send:hover:not(:disabled){background:var(--color-primary-hover)}.chat-room__send:disabled{opacity:.55;cursor:not-allowed}.chat-room__join-prompt{padding:1rem;display:flex;flex-direction:column;gap:.5rem;align-items:center;justify-content:center;background:var(--surface-alt);border-top:1px solid var(--card-border)}.chat-room__join-prompt p{margin:0;color:var(--muted)}.chat-room__error{padding:.5rem .9rem;color:#c0392b;background:color-mix(in srgb,#f5b7b1 30%,transparent);font-size:.85rem;border-top:1px solid #f5b7b1}@media (min-width:640px){.chat-shell__inner{padding:1rem .75rem 1.5rem;gap:1rem}.chat-shell__header{flex-direction:row;align-items:flex-end;justify-content:space-between}.chat-shell__header>div:first-child{min-width:0;flex:1 1 220px}.chat-shell__title{font-size:1.5rem}.chat-shell__subtitle{display:block}.chat-shell__nav{width:auto}.chat-list-panel__search{flex-wrap:nowrap}.chat-list-panel__search>.chat-input{flex:1 1 220px}.chat-list-panel__search>select.chat-input{flex:0 0 180px}.chat-row{grid-template-columns:auto minmax(0,1fr) auto;gap:.85rem;padding:.85rem 1rem}.chat-row__avatar{width:3rem;height:3rem;font-size:1rem}.chat-row__name{font-size:1rem}.chat-row__snippet{font-size:.85rem}.chat-room__messages{padding:1rem .85rem}.chat-msg{max-width:78%}.chat-msg__bubble{border-radius:.65rem}.chat-form{padding:1.2rem}.chat-form__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:960px){.chat-room{border:1px solid var(--card-border);border-radius:1rem;box-shadow:0 10px 40px color-mix(in srgb,var(--color-primary) 8%,transparent)}.chat-room__header{padding:.6rem .9rem}.chat-room__avatar,.chat-room__avatar-img{width:2.4rem;height:2.4rem;font-size:.85rem}.chat-room__title{font-size:1rem}.chat-room__subtitle{font-size:.78rem}.chat-msg{max-width:70%}.chat-msg:focus-within .chat-msg__tools,.chat-msg:hover .chat-msg__tools{display:flex;flex-direction:column;position:static;background:transparent;border:none;padding:0;box-shadow:none;align-self:center}.chat-msg.chat-msg--active .chat-msg__tools{flex-direction:column;position:static;background:transparent;border:none;padding:0;box-shadow:none;align-self:center}.chat-msg{cursor:default}}@media (hover:none) and (pointer:coarse){.chat-msg:hover .chat-msg__tools{display:none}.chat-msg.chat-msg--active .chat-msg__tools{display:flex;flex-direction:row;position:absolute;background:var(--card-bg);border:1px solid var(--card-border);padding:.25rem .4rem;box-shadow:0 6px 20px rgba(0,0,0,.18);align-self:auto}}