.chat-channel-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.chat-presence{align-items:center;gap:.4rem;display:flex}.chat-presence__dots{align-items:center;display:flex}.chat-presence__dot{border:2px solid var(--color-surface);border-radius:42% 58% 65% 35%/38% 62%;width:1.6rem;height:1.6rem;margin-left:-.3rem;animation:8s ease-in-out infinite commBlobMorph,4s ease-in-out infinite commBlobGlow;box-shadow:inset 1px 1px 2px #ffffff26,inset -1px -1px 2px #0003}.chat-presence__dot:nth-child(2){animation-delay:-2s}.chat-presence__dot:nth-child(3){animation-delay:-4s}.chat-presence__dot:nth-child(4){animation-delay:-6s}.chat-presence__dot:first-child{margin-left:0}.chat-presence__count{font-family:var(--font-headline);letter-spacing:.15em;text-transform:uppercase;color:var(--color-dark);opacity:.82;font-size:.45rem}.chat-channel-toggle{background:var(--color-bg);box-shadow:inset 2px 2px 4px var(--neu-inset-dark),inset -2px -2px 4px var(--neu-inset-light);border-radius:.4rem;align-items:center;gap:0;width:fit-content;padding:3px;display:flex}.chat-channel-toggle__btn{font-family:var(--font-headline);letter-spacing:.15em;text-transform:uppercase;cursor:pointer;color:var(--color-dark);opacity:.82;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:.3rem;padding:.35rem 1rem;font-size:.55rem;transition:all .25s}.chat-channel-toggle__btn--active{background:var(--color-bg);opacity:1;color:var(--color-plum);box-shadow:2px 2px 4px var(--neu-dark),-2px -2px 4px var(--neu-light)}.chat-channel-toggle__btn:not(.chat-channel-toggle__btn--active):hover{opacity:.65}.project-access-panel{flex-direction:column;gap:1.25rem;display:flex}.project-access-panel__list{flex-direction:column;gap:0;display:flex}.project-access-panel__entry{opacity:.85;border-bottom:none;align-items:center;gap:.75rem;padding:.75rem .25rem;display:flex;position:relative}.project-access-panel__entry+.project-access-panel__entry:before{content:"";opacity:.35;pointer-events:none;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='10'%3E%3Cpath d='M0 5 C8 2 16 8 24 5 C32 2 40 8 48 5 C56 2 64 8 72 5 L80 5' stroke='%23874a6e' stroke-width='0.6' fill='none'/%3E%3Cpath d='M0 3 C10 7 20 1 30 5 C40 9 50 1 60 5 C70 9 80 3 80 4' stroke='%23874a6e' stroke-width='0.45' fill='none'/%3E%3Cpath d='M0 7 C10 3 20 9 30 5 C40 1 50 9 60 5 C70 1 80 7 80 6' stroke='%23874a6e' stroke-width='0.45' fill='none'/%3E%3C/svg%3E") 50% repeat-x;height:10px;position:absolute;top:0;left:5%;right:5%;-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 12% 88%,#0000 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 12% 88%,#0000 100%)}.project-access-panel__entry:last-child{border-bottom:none}.project-access-panel__avatar{width:2.1rem;height:2.1rem;box-shadow:inset 1px 1px 3px #ffffff26,inset -1px -1px 3px #0003,0 0 3px color-mix(in srgb,var(--color-plum)8%,transparent);border-radius:42% 58% 65% 35%/38% 62%;flex-shrink:0;animation:8s ease-in-out infinite commBlobMorph,4s ease-in-out infinite commBlobGlow}@keyframes commBlobMorph{0%{border-radius:42% 58% 65% 35%/38% 62%;transform:rotate(0)scale(.98)}25%{border-radius:55% 45% 40% 60%/50% 38% 62% 50%;transform:rotate(15deg)scale(1.02)}50%{border-radius:38% 62% 55% 45%/60% 45% 55% 40%;transform:rotate(-10deg)scale(.97)}75%{border-radius:60% 40% 45% 55%/40% 55% 45% 60%;transform:rotate(8deg)scale(1.01)}to{border-radius:42% 58% 65% 35%/38% 62%;transform:rotate(0)scale(.98)}}@keyframes commBlobGlow{0%,to{box-shadow:inset 1px 1px 3px #ffffff26,inset -1px -1px 3px #0003,0 0 3px color-mix(in srgb,var(--color-plum)8%,transparent);opacity:.85}50%{box-shadow:inset 1px 1px 3px #fff3,inset -1px -1px 3px #00000040,0 0 6px color-mix(in srgb,var(--color-plum)20%,transparent);opacity:1}}.project-access-panel__entry:nth-child(2) .project-access-panel__avatar{animation-delay:-2.5s}.project-access-panel__entry:nth-child(3) .project-access-panel__avatar{animation-delay:-5s}.project-access-panel__entry:nth-child(4) .project-access-panel__avatar{animation-delay:-7s}[data-theme=dark] .project-access-panel__avatar{box-shadow:inset 1px 1px 3px #ffffff0f,inset -1px -1px 3px #00000059,0 0 3px color-mix(in srgb,var(--color-plum)8%,transparent)}.project-access-panel__identity{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.project-access-panel__name{font-family:var(--font-headline);letter-spacing:.04em;text-transform:none;color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;font-weight:400;overflow:hidden}.project-access-panel__email{font-family:var(--font-body);letter-spacing:.02em;text-transform:none;color:var(--color-dark);opacity:.82;text-overflow:ellipsis;white-space:nowrap;font-size:.6rem;overflow:hidden}.project-access-panel__role-label{font-family:var(--font-headline);letter-spacing:.2em;text-transform:uppercase;color:var(--color-dark);opacity:.82;flex-shrink:0;margin-left:auto;font-size:.55rem}.project-access-panel__role-label--interactive{cursor:pointer;transition:opacity .2s,color .2s}.project-access-panel__role-label--interactive:hover{opacity:.9;color:var(--color-plum)}.project-access-panel__revoke{cursor:pointer;color:var(--color-coral);opacity:0;background:0 0;border:none;flex-shrink:0;padding:0 .2rem;font-size:.9rem;line-height:1;transition:opacity .2s}.project-access-panel__entry:hover .project-access-panel__revoke{opacity:.45}.project-access-panel__revoke:hover{opacity:1}.project-access-panel__input-row{gap:.5rem;padding-top:.25rem;display:flex}.project-access-panel__input{font-family:var(--font-body);text-transform:none;letter-spacing:.02em;background:var(--color-surface);color:var(--color-text);box-shadow:inset 2px 2px 4px var(--neu-inset-dark),inset -2px -2px 4px var(--neu-inset-light);border:none;border-radius:.4rem;outline:none;flex:1;padding:.55rem .75rem;font-size:.7rem;transition:box-shadow .3s}.project-access-panel__input:focus{box-shadow:inset 2px 2px 4px var(--neu-inset-dark),inset -2px -2px 4px var(--neu-inset-light),0 0 0 2px var(--color-plum)}.project-access-panel__input::placeholder{color:var(--color-dark);opacity:.78;text-transform:none;letter-spacing:.04em;font-size:.65rem}.project-access-panel__add{font-family:var(--font-headline);letter-spacing:.2em;text-transform:uppercase;background:var(--color-bg);color:var(--color-plum);cursor:pointer;box-shadow:2px 2px 4px var(--neu-dark),-2px -2px 4px var(--neu-light);-webkit-tap-highlight-color:transparent;border:none;border-radius:.4rem;flex-shrink:0;padding:.55rem 1.1rem;font-size:.55rem;transition:box-shadow .25s,opacity .2s}.project-access-panel__add:hover{box-shadow:inset 2px 2px 4px var(--neu-inset-dark),inset -2px -2px 4px transparent}@media (max-width:768px){.project-access-panel__avatar{width:1.8rem;height:1.8rem}.project-access-panel__name{font-size:.7rem}.project-access-panel__email{font-size:.55rem}.project-access-panel__role-label{font-size:.5rem}}@media (max-width:480px){.project-access-panel__entry{gap:.5rem;padding:.6rem .15rem}.project-access-panel__avatar{width:1.6rem;height:1.6rem}.project-access-panel__name{font-size:.65rem}.project-access-panel__input{padding:.5rem .6rem;font-size:.65rem}.project-access-panel__add{padding:.5rem .8rem;font-size:.5rem}}.project-chat{flex-direction:column;flex:1;min-width:0;max-width:100%;min-height:300px;max-height:500px;display:flex;overflow:hidden}.project-chat__header{border-bottom:1px solid var(--color-border);align-items:center;gap:.5rem;margin-bottom:.5rem;padding-bottom:.15rem;display:flex}.project-chat__label{font-family:var(--font-headline);letter-spacing:.25em;text-transform:uppercase;color:var(--color-dark);opacity:.85;font-size:.6rem;font-weight:400}.project-chat__status{background:var(--color-dark);opacity:.15;border-radius:50%;width:6px;height:6px;transition:background .3s,opacity .3s}.project-chat__status--on{background:var(--color-green);opacity:.8}.project-chat__messages{scrollbar-width:thin;scrollbar-color:var(--color-scrollbar)transparent;flex-direction:column;flex:1;gap:.4rem;padding:.5rem 0;display:flex;overflow-y:auto}.project-chat__loading{text-align:center;font-family:var(--font-body);letter-spacing:.1em;text-transform:uppercase;color:var(--color-dark);opacity:.78;padding:.5rem;font-size:.5rem}.project-chat__bubble{background:var(--color-surface);max-width:80%;box-shadow:inset 2px 2px 4px var(--neu-inset-dark),inset -2px -2px 4px var(--neu-inset-light);border-radius:.75rem .75rem .75rem .25rem;flex-direction:column;align-self:flex-start;gap:.15rem;padding:.6rem .85rem;display:flex}.project-chat__bubble--colored{background:var(--bubble-color);box-shadow:3px 3px 6px var(--neu-dark),-3px -3px 6px var(--neu-light)}.project-chat__bubble--colored .project-chat__content{color:var(--color-light)}.project-chat__bubble--colored .project-chat__time{color:var(--color-light);opacity:.5}.project-chat__bubble--colored .project-chat__sender{color:var(--color-light);opacity:.65}.project-chat__bubble--own{border-radius:.75rem .75rem .25rem;align-self:flex-end}.project-chat__bubble--colored:not(.project-chat__bubble--own){border-radius:.75rem .75rem .75rem .25rem}[data-theme=dark] .project-chat__bubble{box-shadow:inset 2px 2px 5px #00000059,inset -2px -2px 5px #ffffff0a}[data-theme=dark] .project-chat__bubble--own{box-shadow:3px 3px 8px #0006,-3px -3px 8px #ffffff0a}.project-chat__sender{font-family:var(--font-body);letter-spacing:.08em;text-transform:uppercase;color:var(--color-plum);opacity:.9;font-size:.45rem}.project-chat__content{font-family:var(--font-body);letter-spacing:.02em;text-transform:none;color:var(--color-text);word-break:break-word;white-space:pre-wrap;font-size:.7rem;line-height:1.5}.project-chat__time{font-family:var(--font-body);letter-spacing:.08em;text-transform:uppercase;color:var(--color-dark);opacity:.78;align-self:flex-end;font-size:.4rem}.project-chat__new-indicator{background:var(--color-plum);color:var(--color-light);cursor:pointer;font-family:var(--font-body);letter-spacing:.1em;text-transform:uppercase;-webkit-tap-highlight-color:transparent;border:none;border-radius:.75rem;align-self:center;margin:.25rem 0;padding:.25rem .75rem;font-size:.45rem;transition:opacity .2s}.project-chat__new-indicator:hover{opacity:.85}.project-chat__input-area{align-items:flex-end;gap:.4rem;max-width:100%;margin-top:.5rem;padding:2px;display:flex}.project-chat__file-input{display:none}.project-chat__upload{font-family:var(--font-headline);background:var(--color-bg);color:var(--color-plum);cursor:pointer;width:36px;height:36px;box-shadow:2px 2px 4px var(--neu-dark),-2px -2px 4px var(--neu-light);-webkit-tap-highlight-color:transparent;border:none;border-radius:.4rem;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:1rem;font-weight:400;line-height:1;transition:box-shadow .2s,opacity .2s,color .2s,transform .12s;display:flex}.project-chat__upload:hover:not(:disabled){color:var(--color-plum);box-shadow:1px 1px 3px var(--neu-dark),-1px -1px 3px var(--neu-light)}.project-chat__upload:active:not(:disabled){color:var(--color-plum);box-shadow:inset 3px 3px 5px var(--neu-inset-dark),inset -3px -3px 5px transparent;transform:scale(.94)}.project-chat__upload:disabled{opacity:.3;cursor:default}.project-chat__pending{flex-wrap:wrap;gap:.35rem;padding:.4rem .15rem .1rem;display:flex}.project-chat__pending-thumb{width:56px;height:56px;box-shadow:inset 2px 2px 4px var(--neu-inset-dark),inset -2px -2px 4px var(--neu-inset-light);background:var(--color-surface);border-radius:.4rem;position:relative;overflow:hidden}.project-chat__pending-thumb img{object-fit:cover;width:100%;height:100%;display:block}.project-chat__pending-remove{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#0000008c;border:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;padding:0;font-size:.75rem;line-height:1;transition:background .2s;display:flex;position:absolute;top:2px;right:2px}.project-chat__pending-remove:hover{background:var(--color-coral)}.project-chat__upload-error{font-family:var(--font-body);letter-spacing:.05em;text-transform:none;color:var(--color-coral);background:color-mix(in srgb,var(--color-coral)8%,transparent);border-radius:.35rem;justify-content:space-between;align-items:center;gap:.5rem;margin:.3rem 0 0;padding:.35rem .6rem;font-size:.55rem;display:flex}.project-chat__upload-error button{color:var(--color-coral);cursor:pointer;opacity:.7;background:0 0;border:none;padding:0 .2rem;font-size:.9rem;line-height:1;transition:opacity .2s}.project-chat__upload-error button:hover{opacity:1}.project-chat__images{border-radius:.5rem;gap:3px;max-width:260px;margin-bottom:.15rem;display:grid;overflow:hidden}.project-chat__images--count-1{grid-template-columns:1fr}.project-chat__images--count-2,.project-chat__images--count-3{grid-template-columns:1fr 1fr}.project-chat__images--count-3 .project-chat__image-link:first-child{grid-column:1/-1}.project-chat__images--count-4{grid-template-columns:1fr 1fr}.project-chat__image-link{background:var(--color-bg);aspect-ratio:1;display:block;position:relative;overflow:hidden}.project-chat__images--count-1 .project-chat__image-link{aspect-ratio:auto;max-height:280px}.project-chat__image{object-fit:cover;width:100%;height:100%;transition:opacity .2s;display:block}.project-chat__images--count-1 .project-chat__image{object-fit:contain;max-height:280px}.project-chat__image-link:hover .project-chat__image{opacity:.88}.project-chat__bubble--image-only{box-shadow:none;background:0 0;padding:.35rem}.project-chat__bubble--image-only.project-chat__bubble--colored{box-shadow:none;background:0 0}.project-chat__bubble--image-only .project-chat__time{padding:0 .35rem}@media (max-width:480px){.project-chat__upload{width:32px;height:32px;font-size:.9rem}.project-chat__pending-thumb{width:44px;height:44px}.project-chat__images{max-width:200px}}.project-chat__input{font-family:var(--font-body);text-transform:none;letter-spacing:.02em;background:var(--color-surface);color:var(--color-text);box-shadow:inset 2px 2px 4px var(--neu-inset-dark),inset -2px -2px 4px var(--neu-inset-light);resize:none;border:none;border-radius:.4rem;outline:none;flex:1;min-height:36px;max-height:80px;padding:.55rem .75rem;font-size:.7rem;transition:box-shadow .25s}.project-chat__input:hover:not(:focus){box-shadow:inset 3px 3px 5px var(--neu-inset-dark),inset -3px -3px 5px var(--neu-inset-light)}.project-chat__input:focus{box-shadow:inset 2px 2px 4px var(--neu-inset-dark),inset -2px -2px 4px var(--neu-inset-light),0 0 0 2px var(--color-plum)}.project-chat__input::placeholder{color:var(--color-dark);opacity:.78;text-transform:uppercase;letter-spacing:.05em;font-size:.55rem;transition:opacity .2s}.project-chat__input:focus::placeholder{opacity:.5}.project-chat__send{font-family:var(--font-headline);letter-spacing:.15em;text-transform:uppercase;background:var(--color-bg);color:var(--color-dark);cursor:pointer;box-shadow:2px 2px 4px var(--neu-dark),-2px -2px 4px var(--neu-light);-webkit-tap-highlight-color:transparent;border:none;border-radius:.4rem;flex-shrink:0;align-self:flex-end;padding:.5rem 1rem;font-size:.55rem;transition:box-shadow .2s,opacity .2s,color .2s,transform .12s}.project-chat__send:hover:not(:disabled){color:var(--color-plum);box-shadow:1px 1px 3px var(--neu-dark),-1px -1px 3px var(--neu-light)}.project-chat__send:active:not(:disabled){color:var(--color-plum);box-shadow:inset 3px 3px 5px var(--neu-inset-dark),inset -3px -3px 5px transparent;transform:scale(.97)}.project-chat__send:disabled{opacity:.25;cursor:default;box-shadow:2px 2px 4px var(--neu-dark),-2px -2px 4px var(--neu-light)}@media (max-width:768px){.project-chat{min-height:250px;max-height:400px}.project-chat__content{font-size:.65rem}.project-chat__input{padding:.45rem .55rem;font-size:.65rem}.project-chat__send{padding:.45rem .75rem;font-size:.5rem}}@media (max-width:480px){.project-chat{min-height:200px;max-height:350px}.project-chat__label{font-size:.5rem}.project-chat__sender{font-size:.4rem}.project-chat__content{font-size:.6rem}.project-chat__time{font-size:.35rem}.project-chat__input{padding:.35rem .45rem;font-size:.6rem}.project-chat__send{padding:.35rem .6rem;font-size:.45rem}}.project-access-panel__controls{flex-shrink:0;align-items:center;gap:.75rem;margin-left:auto;display:flex}.chat-channel-toggle--sm{padding:2px}.chat-channel-toggle--sm .chat-channel-toggle__btn{letter-spacing:.1em;padding:.25rem .6rem;font-size:.45rem}
