@import"https://fonts.googleapis.com/css2?family=Inter:wght@200;300;400;500;600&display=swap";:root{font-family:Inter,system-ui,-apple-system,sans-serif;color:#152035;background:#f4f7fb}*{box-sizing:border-box}body{margin:0;background:linear-gradient(180deg,#f8fbff,#eef3fb);overflow:hidden}html,body,#root{height:100%;overscroll-behavior:none}.screen{min-height:100dvh;height:100dvh;overflow-y:auto;padding:16px}.card{background:#fff;border:1px solid #d9e4f2;border-radius:16px;padding:16px;box-shadow:0 10px 40px #13397a14}.form{display:grid;gap:10px}.auth-tabs{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}.forgot-password-row{display:flex;justify-content:flex-end;margin-top:-4px;margin-bottom:4px}.forgot-password-link{font-size:13px;color:#1b5cff;text-decoration:none;background:none;border:none;padding:0;cursor:pointer}.forgot-password-link:hover{text-decoration:underline}.forgot-password-back{margin:0;font-size:14px}.forgot-password-back--phone{margin-top:clamp(1.35rem,4vw + .5rem,3rem);padding-top:clamp(.4rem,1.5vw,1rem)}@media (min-width: 640px){.forgot-password-back--phone{margin-top:clamp(1.75rem,2.8vw + .75rem,2.85rem);padding-top:clamp(.5rem,1vw,1.1rem)}}.forgot-password-back a{color:#58719a;text-decoration:none}.forgot-password-back a:hover{text-decoration:underline}.forgot-code-form{grid-template-columns:1fr}.forgot-code-form button{width:100%;justify-self:stretch;min-height:44px;box-sizing:border-box}.forgot-password-back--code{margin-top:clamp(1.5rem,4.5vw + .6rem,3.35rem);padding-top:clamp(.45rem,1.6vw,1.05rem)}@media (min-width: 640px){.forgot-password-back--code{margin-top:clamp(2rem,2.8vw + 1rem,3.1rem);padding-top:clamp(.55rem,1vw,1.15rem)}}input,button{border-radius:12px;border:1px solid #d4deea;padding:10px 12px;font-size:14px}button{background:#1b5cff;color:#fff;border:none;transition:transform .16s ease,box-shadow .2s ease,background-color .2s ease,border-color .2s ease,color .2s ease,opacity .2s ease;will-change:transform}button:hover{transform:translateY(-1px)}button:active{transform:translateY(0) scale(.98)}button:disabled{opacity:.65;cursor:not-allowed;transform:none}.ghost{background:#eef3fb;color:#1d345a;border:1px solid #d4deea}.ghost:hover{background:#e7effb;border-color:#bfd0e6}.logout-btn{width:auto;min-width:96px;height:42px;border-radius:10px;padding:8px 16px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.active-tab{background:#1b5cff;color:#fff}.inline-actions{display:grid;grid-template-columns:1fr auto;gap:8px}.admin-sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.admin-sidebar-header h2{margin:0}.active-chat-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}.active-chat-title-stack{display:flex;flex-direction:column;gap:2px;min-width:0}.active-chat-header h2{margin:0}.active-chat-ids{margin:0;font-size:13px;line-height:1.35;word-break:break-word}.edit-profile-btn{min-width:170px;height:40px;border-radius:10px;padding:8px 14px;white-space:nowrap}.search-bar-wrap{margin-bottom:12px}.search-input{width:100%;border-radius:12px;border:1px solid #d4deea;background:#f6f9ff;padding:10px 12px;font-size:14px;color:#1d345a}.meta{color:#6a7d97}.error{color:#c62828}.topbar{margin-bottom:12px}.screen.chat-screen{display:flex;flex-direction:column;overflow:hidden}.chat-screen>.topbar,.chat-screen>.error,.chat-screen>footer{flex-shrink:0}.chat-screen .messages{flex:1 1 auto;min-height:0;max-height:none;margin-bottom:12px;overflow-y:auto;-webkit-overflow-scrolling:touch}.messages{display:flex;flex-direction:column;gap:10px;margin-bottom:12px;max-height:56vh;overflow-y:auto;padding-right:10px;scrollbar-gutter:stable}.bubble{max-width:82%;padding:10px 12px;border-radius:14px;display:grid;gap:6px;font-weight:400;font-variation-settings:"wght" 400}.mine{align-self:flex-end;background:#dbe9ff}.theirs{align-self:flex-start;background:#fff;border:1px solid #e1e8f3}.composer-shell{position:sticky;bottom:0;background:#f6f9ff;border:1px solid #dbe4f1;border-radius:16px;padding:8px;display:grid;grid-template-columns:auto auto 1fr auto;gap:8px;align-items:flex-end}.hidden-file-input{display:none}.icon-action{background:#ecf2fb;color:#314663;border:1px solid #d5deeb;border-radius:12px;padding:8px;width:46px;height:42px;display:inline-flex;align-items:center;justify-content:center}.icon-action:hover{box-shadow:0 6px 14px #2040721f}.icon-svg{width:19px;height:19px}.composer-input{border-radius:12px;border:1px solid #d4deea;padding:10px 12px;font-size:16px;background:#fff;font-family:inherit;min-height:42px;max-height:min(30vh,200px);resize:none;overflow-y:auto;line-height:1.35;box-sizing:border-box}textarea.composer-input{display:block;width:100%}.send-btn{background:#1b5cff;color:#fff;border-radius:12px;padding:10px 16px;border:none;display:inline-flex;align-items:center;gap:8px;justify-content:center}.send-btn:hover{background:#1653e6;box-shadow:0 10px 18px #1b5cff40}.send-btn:disabled,.icon-action:disabled,.composer-input:disabled{opacity:.72;cursor:not-allowed}.send-label{white-space:nowrap}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.bubble-time{font-size:11px;color:#7f8ca1;justify-self:end}.bubble .message-link{color:#1450d8;text-decoration:underline;text-underline-offset:2px;word-break:break-all}.bubble.mine .message-link{color:#0d3eb0}.attachment-wrap{display:grid;gap:6px}.attachment-image{width:min(260px,100%);border-radius:10px;border:1px solid #d6e1f0;display:block}.attachment-image-link{display:inline-block}.attachment-image-button{border:none;background:transparent;padding:0;margin:0;cursor:zoom-in}.media-bubble{background:transparent;border:none;padding:0;max-width:min(300px,82%)}.media-bubble .attachment-wrap{gap:0}.media-bubble .attachment-image{border:none;border-radius:16px}.media-bubble .bubble-time{background:#13254285;color:#fff;border-radius:999px;padding:0 8px;min-height:18px;font-size:10px;display:inline-flex;align-items:center;justify-content:center;line-height:1;margin-top:-34px;margin-right:8px;z-index:1}.image-viewer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#060d18bf;z-index:1100;display:flex;align-items:center;justify-content:center;padding:16px}.image-viewer-card{max-width:min(1000px,96vw);max-height:92vh}.image-viewer-image{display:block;max-width:100%;max-height:92vh;border-radius:14px}.file-attachment{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;background:transparent;border:none;border-radius:0;padding:0}.file-icon-wrap{width:40px;height:40px;border-radius:999px;background:#fff;border:1px solid #e5edf8;display:inline-flex;align-items:center;justify-content:center;color:#111}.file-icon-svg{width:18px;height:18px}.file-meta{display:grid;gap:2px;min-width:0}.file-name{font-weight:500;color:#22395e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.file-open{font-size:12px;color:#58719a}.admin-layout{display:grid;gap:12px;align-items:stretch}.active-chat-panel{display:flex;flex-direction:column;min-height:0;height:100%}.active-chat-panel .messages{flex:1 1 auto;min-height:0;max-height:none;margin-bottom:12px;display:block;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-gutter:stable;padding-right:10px}.messages-stack{min-height:100%;display:flex;flex-direction:column;justify-content:flex-end;gap:10px}.active-chat-panel .composer-shell{margin-top:auto}.list-item{padding:10px;border-bottom:1px solid #edf2f9}.list-item-btn{width:100%;text-align:left;display:grid;gap:2px;padding:10px;border-radius:10px;margin-bottom:8px;border:1px solid #e3eaf5;background:#fff;color:#152035;cursor:pointer;transition:border-color .2s ease,background-color .2s ease,transform .14s ease,box-shadow .2s ease}.list-item-btn:hover{border-color:#b9cae5;background:#f7faff;transform:translateY(-1px);box-shadow:0 8px 16px #20407214}.list-item-btn.selected{border-color:#1b5cff;background:#ebf2ff}@media (prefers-reduced-motion: reduce){button,.list-item-btn{transition:none}}.profile-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#09132473;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.profile-modal-card{width:min(520px,100%);background:#fff;border:1px solid #d9e4f2;border-radius:16px;padding:16px;box-shadow:0 20px 50px #10234333}.profile-modal-card h3{margin:0 0 8px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}@media (min-width: 960px){.screen{max-width:1180px;margin:0 auto;padding:24px}.admin-layout{grid-template-columns:340px 1fr;height:calc(100vh - 48px)}.admin-layout>.card{height:100%;overflow:hidden}}@media (max-width: 640px){.chat-screen{--mobile-composer-height: 68px;--mobile-composer-extra-bottom: 1vh}.admin-layout{display:flex;flex-direction:column;gap:6px}.admin-layout>.card{position:relative;z-index:1;overflow:visible}.active-chat-panel{margin-top:0;min-height:58dvh}.active-chat-panel .meta{margin:0 0 6px}.active-chat-panel .messages{margin-top:0;padding-top:0}.chat-screen{min-height:100dvh;display:flex;flex-direction:column;padding-bottom:calc(var(--mobile-composer-height) + var(--mobile-composer-extra-bottom) + env(safe-area-inset-bottom,0px))}.chat-screen .messages{flex:1;min-height:0;max-height:none;margin-bottom:8px}.mobile-bottom-composer{position:fixed;left:10px;right:10px;bottom:calc(var(--mobile-composer-extra-bottom) + env(safe-area-inset-bottom,0px));min-height:var(--mobile-composer-height);height:auto;max-height:42vh;padding-bottom:0;z-index:20;box-shadow:0 8px 24px #142c541f}.composer-shell{grid-template-columns:auto auto 1fr auto;padding:6px;border-radius:16px;min-height:var(--mobile-composer-height);align-items:flex-end}.send-btn{width:42px;height:42px;padding:7px;border-radius:12px}.icon-action{width:42px;height:42px;padding:7px}.composer-input{height:auto;min-height:42px;max-height:min(28vh,180px);line-height:1.25;padding:8px 12px;font-size:16px}.send-label{display:none}}
