*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--app-height: 100dvh;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}@supports not (height: 100dvh){:root{--app-height: 100vh}}html,body{margin:0!important;padding:0!important;width:100%;height:100%;max-width:100%;overflow:hidden;overscroll-behavior:none;background-color:#000;color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;-webkit-text-size-adjust:100%}body{position:fixed;inset:0}#root{position:fixed;top:0;left:0;width:100%;height:var(--app-height);max-height:var(--app-height);display:flex;flex-direction:column;overflow:hidden;background-color:#f4f7f6;touch-action:manipulation;transform:translateZ(0)}.tg-contacts-list,.chat-body{touch-action:pan-y!important;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}h1,h2,h3{color:#2c3e50}.main-container{height:100%;display:flex;flex-direction:column;overflow:hidden}.header{padding-top:calc(env(safe-area-inset-top,0px) + 10px);padding-bottom:10px;background-color:#2c3e50;width:100%}.container{max-width:500px;margin:15vh auto;background:#fff;padding:30px;border-radius:15px;box-shadow:0 4px 15px #0000001a;text-align:center}.screen{display:none}.active-screen{display:block}button{display:block;width:100%;padding:15px;margin:10px 0;font-size:18px;border:none;border-radius:8px;cursor:pointer;transition:.3s}.btn-login{background-color:#3498db;color:#fff}.btn-login:hover{background-color:#2980b9}.btn-call{background-color:#2ecc71;color:#fff}.btn-call:hover{background-color:#27ae60}.btn-hangup{background-color:#e74c3c;color:#fff;margin-top:30px}.btn-hangup:hover{background-color:#c0392b}#status-text{margin:20px 0;font-weight:700;color:#7f8c8d}.status-error{color:#e74c3c!important;font-weight:700!important;font-size:1.1em;transition:all .3s ease}.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;z-index:1000;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-content{background:#fff;padding:30px;border-radius:15px;text-align:center;box-shadow:0 10px 25px #0003;max-width:300px;width:90%}.modal-content h3{margin-top:0;color:#2c3e50}.modal-buttons{display:flex;gap:15px;margin-top:25px}.modal-buttons button{margin:0}.tg-layout{display:flex;width:100%;height:100%;overflow:hidden;background-color:#f4f7f6}.tg-sidebar{width:320px;background:#fff;border-right:1px solid #ddd;display:flex;flex-direction:column;height:100%}.tg-sidebar-header{padding:15px 20px;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;align-items:center;background-color:#fdfdfd}.tg-btn-logout{background:#e74c3c;color:#fff;border:none;padding:6px 10px;border-radius:6px;cursor:pointer;font-size:14px;width:auto;margin:0}.tg-contacts-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.tg-contact-item{display:flex;align-items:center;padding:12px 20px;cursor:pointer;transition:background .2s;border-bottom:1px solid #f0f0f0}.tg-contact-item:hover{background:#f4f7f6}.tg-contact-item.active{background:#3498db;color:#fff}.tg-avatar{width:45px;height:45px;background:#bdc3c7;color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:20px;font-weight:700;margin-right:15px;flex-shrink:0}.tg-contact-item.active .tg-avatar{background:#fff;color:#3498db}.tg-contact-info{display:flex;flex-direction:column;flex:1;overflow:hidden}.tg-contact-name{font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tg-main-content{flex:1;display:flex;flex-direction:column;background:#fff;text-align:center;min-width:0;min-height:0}.tg-empty-chat{flex:1;display:flex;justify-content:center;align-items:center}.tg-empty-badge{background:#00000080;color:#fff;padding:5px 15px;border-radius:20px;font-size:16px;font-weight:700}.chat-container{display:flex;flex-direction:column;height:100%;width:100%;min-width:0;min-height:0}.chat-header{display:flex;align-items:center;padding:10px 20px;background:#fff;border-bottom:1px solid #ddd;min-height:65px;position:relative;z-index:2}.chat-header-info{flex:1;display:flex;flex-direction:column;text-align:left;margin:0 15px;overflow:hidden}.chat-header-name{margin:0;font-size:18px;color:#2c3e50;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header-status{font-size:13px;color:#7f8c8d;margin-top:2px}.btn-icon{width:45px!important;height:45px!important;border-radius:50%!important;padding:0!important;margin:0!important;display:flex;justify-content:center;align-items:center;font-size:20px;flex-shrink:0;cursor:pointer}.btn-call-small{background-color:#2ecc71;color:#fff}.btn-call-small:hover{background-color:#27ae60}.btn-hangup-small{background-color:#e74c3c;color:#fff}.btn-hangup-small:hover{background-color:#c0392b}.btn-back{background-color:transparent;color:#3498db;font-size:24px;border:none}.btn-back:hover{background-color:#f0f0f0}.chat-body{flex:1;padding:20px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;background-image:url(https://www.transparenttextures.com/patterns/cubes.png);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;position:relative;z-index:1}.chat-empty-state{margin:auto;background:#fffc;padding:8px 16px;border-radius:15px;font-size:14px}.messages-list{display:flex;flex-direction:column;gap:10px;margin-top:auto}.msg-bubble{max-width:85%;padding:10px 14px;border-radius:16px;position:relative;box-shadow:0 1px 2px #0000001a;display:flex;flex-direction:column;word-break:break-word;overflow-wrap:break-word}.msg-mine{align-self:flex-end;background-color:#ccefff;border-bottom-right-radius:4px}.msg-theirs{align-self:flex-start;background-color:#e4e4e4;border-bottom-left-radius:4px}.msg-system{background-color:#ccefff;font-size:14px;color:#717171;font-weight:500;text-align:center;align-self:center!important;border-radius:16px!important}.missed-call{background-color:#fce4ec;font-size:14px;color:#c2185b;font-weight:500;text-align:center;align-self:center!important;border-radius:16px!important}.unanswered-call{background-color:#e4e4e4;font-size:14px;color:#717171;font-weight:500;text-align:center;align-self:center!important;border-radius:16px!important}.msg-content{font-size:16px;line-height:1.4;color:#2c3e50;text-align:left;white-space:pre-wrap}.msg-time{font-size:11px;color:#7f8c8d;align-self:flex-end;margin-top:4px;display:flex;align-items:center}.msg-ticks{color:#3498db;margin-left:4px;font-weight:700}.date-separator{font-size:12px;color:#7f8c8d;margin:10px 0;padding:0 10px;text-align:center}.date-separator-wrapper{display:flex;align-items:center;gap:12px;margin:16px 0}.date-separator-line{flex:1;height:1px;background-color:#e0e0e0}.date-separator-bubble{background-color:#f0f0f0;padding:4px 8px;border-radius:12px;display:inline-block;font-size:12px;color:#7f8c8d;font-weight:500;white-space:nowrap}.chat-footer{display:flex;padding:15px 20px;background:#fdfdfd;border-top:1px solid #ddd;align-items:center;gap:15px;position:relative;z-index:2}.chat-input{flex:1;padding:12px 15px;background-color:#e3e3e3;color:#000;border:1px solid #ccc;border-radius:25px;font-size:16px;outline:none;transition:border .3s;-webkit-appearance:none}.chat-input:focus{border-color:#3498db}.chat-actions{display:flex;align-items:center;gap:10px}.char-counter{font-size:12px;color:#7f8c8d}.limit-reached{color:#e74c3c;font-weight:700}.btn-send{width:45px;height:45px;border-radius:50%;background-color:#3498db;color:#fff;border:none;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer;margin:0;padding:0;transition:background .3s;flex-shrink:0}.btn-send:disabled{background-color:#bdc3c7;cursor:not-allowed}.btn-send:hover:not(:disabled){background-color:#2980b9}.active-call-overlay{position:fixed;top:0;left:0;width:100vw;height:100dvh;pointer-events:all;background-color:#0009;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;justify-content:center;align-items:center;z-index:9999}.active-call-window{pointer-events:all;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:30px 40px;border-radius:20px;box-shadow:0 15px 35px #0003;text-align:center;border:1px solid #e0e0e0;animation:popIn .3s cubic-bezier(.175,.885,.32,1.275);width:90%;max-width:320px}.call-avatar-pulse{font-size:60px;margin-bottom:10px;animation:pulse 1.5s infinite}@keyframes popIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.loading-spinner{text-align:center;color:#95a5a6;font-size:12px;padding:10px}.unread-badge{background-color:#3498db;color:#fff;font-size:12px;font-weight:700;padding:2px 8px;border-radius:12px;margin-left:auto;box-shadow:0 2px 4px #3498db4d;animation:popIn .3s cubic-bezier(.175,.885,.32,1.275)}@media(max-width:768px){#root{width:100vw}.tg-sidebar-header{padding-top:calc(var(--safe-top) + 10px);position:relative;z-index:2}.chat-header{padding-top:calc(var(--safe-top) + 10px)}.chat-footer{padding-bottom:calc(var(--safe-bottom) + 15px)}.hide-on-mobile{display:none!important}.tg-sidebar{width:100%;border-right:none}}
