.app-shell{min-height:100vh;background:#fff;color:#000}.force-username{min-height:calc(100vh - 72px);display:grid;place-items:center;padding:24px}.force-username__card{width:min(560px,100%);border:1px solid #e5e7eb;border-radius:16px;padding:20px;background:#fff}.force-username__card h2{margin:0 0 10px;font-size:22px}.force-username__card p{margin:0 0 14px;color:#4b5563}.force-username__form{display:flex;gap:8px}.force-username__form--column{flex-direction:column;gap:10px}.force-username__form--column .button{align-self:flex-end}.force-username__error{margin-top:10px;color:#b91c1c;font-size:13px}.topbar{height:72px;border-bottom:1px solid #e5e7eb;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:12px}.topbar__actions{display:flex;align-items:center;gap:10px}.topbar__username{display:flex;align-items:center;gap:8px}.topbar__username .input{width:180px}.modal-backdrop{position:fixed;inset:0;background:#00000059;display:grid;place-items:center;z-index:1000;padding:16px}.username-modal{width:min(520px,100%);border-radius:16px;border:1px solid #e5e7eb;background:#fff;padding:18px;display:flex;flex-direction:column;gap:10px}.username-modal h3{margin:0;font-size:20px}.username-modal__actions{display:flex;justify-content:flex-end;gap:8px}.brand{display:flex;align-items:center;gap:10px}.brand__logo{width:36px;height:36px;border-radius:999px;background:#000;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.brand__name{font-size:20px;font-weight:600}.layout{height:calc(100vh - 72px);display:grid;grid-template-columns:340px minmax(0,1fr)}.sidebar{border-right:1px solid #e5e7eb;padding:16px;display:flex;flex-direction:column;gap:10px;min-height:0}.section-title{margin:4px 2px 0;color:#9ca3af;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.friend-add{display:flex;gap:8px}.friends{display:flex;flex-direction:column;gap:2px;overflow-y:auto;min-height:0}.friend{display:flex;align-items:center;gap:10px;text-align:left;background:transparent;border:none;border-radius:14px;padding:8px;color:#000}.friend:hover,.friend--active{background:#f5f5f5}.friend__avatar{width:44px;height:44px;border-radius:999px;background:#f3f4f6;color:#6b7280;font-size:16px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.friend__content{flex:1;min-width:0}.friend__row{display:flex;align-items:center;gap:8px;justify-content:space-between}.friend__name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend__badge{min-width:20px;height:20px;border-radius:999px;background:#000;color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;padding:0 6px}.friend__meta{margin-top:2px;color:#6b7280;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat{min-width:0;min-height:0;display:flex;flex-direction:column;height:100%;overflow:hidden}.chat__header{min-height:68px;border-bottom:1px solid #e5e7eb;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:12px}.chat__title-wrap{display:flex;align-items:center;gap:10px;min-width:0}.chat__avatar{width:36px;height:36px;border-radius:999px;background:#f3f4f6;color:#6b7280;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.chat__title{margin:0;font-size:18px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.call{margin:10px 24px 0;border-radius:14px;border:1px solid #e5e7eb;background:#fff;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.call--active{background:#f8fafc}.call__actions{display:flex;gap:8px}.messages{padding:14px 24px;overflow-y:auto;border-top:1px solid #e5e7eb;flex:1 1 auto;min-height:0}.message-row{display:flex;justify-content:flex-start;margin-bottom:8px}.message-row--me{justify-content:flex-end}.message{max-width:min(540px,75%);padding:10px 14px;border-radius:16px 16px 16px 6px;background:#f3f4f6}.message--me{border-radius:16px 16px 6px;background:#000}.message__text{font-size:14px;line-height:1.35;color:#000;word-break:break-word}.message--me .message__text{color:#fff}.message__time{margin-top:4px;font-size:11px;color:#6b7280}.message__time--me{color:#d1d5db}.composer{display:flex;gap:8px;padding:10px 24px 14px;border-top:1px solid #e5e7eb}.input{width:100%;height:42px;border:none;border-radius:999px;background:#f5f5f5;color:#000;padding:0 14px;font-size:14px}.input::placeholder{color:#9ca3af}.input:focus{outline:2px solid #000;outline-offset:1px}.button{border:none;border-radius:999px;height:42px;padding:0 16px;font-size:14px;font-weight:600;cursor:pointer;background:#000;color:#fff}.button:disabled{opacity:.6;cursor:default}.button--primary{background:#000;color:#fff}.button--danger{background:#dc2626;color:#fff}.button--soft{background:#f3f4f6;color:#000}.button--ghost{background:#fff;color:#000;border:1px solid #e5e7eb}.button--icon{width:42px;padding:0;font-size:18px}@media(max-width:980px){.layout{grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr)}.sidebar{border-right:none;border-bottom:1px solid #e5e7eb;max-height:46vh}.chat{min-height:54vh}.messages{padding:12px 14px}.chat__header,.composer,.call{margin-left:0;margin-right:0;padding-left:14px;padding-right:14px}}:root{font-family:PT Sans,Segoe UI,Helvetica Neue,Arial,sans-serif;line-height:1.4;font-weight:400;color:#000;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#fff}#root{min-height:100vh}
