:root{--font-size-xs:.5rem;--font-size-sm:1rem;--font-size-md:1.5rem;--font-size-lg:3rem;--color-primary:#6a11cb;--color-secondary:#2575fc;--color-text:#3b3333;--color-text-light:#636e72d5;--color-white:#fff;--color-shadow:rgba(250,8,8,.5);--color-background:#f8f9fa;--color-hover:#e9ecef;--color-border:#dee2e6;--color-border-light:#e9ecef;--color-primary-light:#e6d9fa;--gradient-primary:linear-gradient(140deg,#a99fe2 40%,#2575fc 50%);--gradient-button:linear-gradient(140deg,#a99fe2 20%,#2575fc 50%);--background-container:hsla(0,0%,100%,.788);--spacing-xs:10px;--spacing-sm:15px;--spacing-md:25px;--spacing-lg:40px;--spacing-xl:50px;--radius-sm:10px;--radius-md:15px;--radius-lg:40px;--shadow-main:10px 25px 50px var(--color-shadow);--shadow-card:0 2px 8px rgba(0,0,0,.1)}*{box-sizing:border-box;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-style:normal;line-height:normal;margin:0;padding:0}body{align-items:center;background:var(--gradient-primary);justify-content:center;min-height:100vh}.container,body{display:-webkit-box;display:-ms-flexbox;display:flex}.container{background:var(--background-container);border-radius:var(--radius-lg);box-shadow:var(--shadow-main);flex-direction:column;padding:50px 40px;width:min(500px,90vw)}.header{margin-bottom:var(--spacing-lg);text-align:center;width:100%}.header h1{font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs)}.header p{color:var(--color-text-light);font-size:var(--font-size-md)}.main{height:100%;margin-bottom:var(--spacing-lg);width:100%}.footer{color:var(--color-text);font-size:var(--font-size-sm);text-align:center;width:100%}.footer a{color:var(--color-secondary);text-decoration:none}.footer a:hover{text-decoration:underline}.footer p{line-height:1.4;margin:0 auto;max-width:400px}#app{align-items:center;display:-webkit-box;display:-ms-flexbox;display:flex;justify-content:center;min-height:100vh;width:100%}.error-message{color:#ff4757!important;font-size:12px!important;margin-top:4px!important}.field-error{animation:fadeIn .3s ease;color:#ff4757;font-size:12px;margin-top:4px}.global-error{background-color:#ff47571a;color:#ff4757}.global-error,.success-message{animation:fadeIn .3s ease;border-radius:8px;margin-bottom:16px;padding:12px;text-align:center}.success-message{background-color:#2ecc711a;color:#2ecc71}.form-input.has-error{background-color:#ff47570d;border-color:#ff4757!important}.form-input.is-valid{background-color:#2ecc710d;border-color:#2ecc71!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.form-input--readonly{background-color:#f8f9fa;cursor:not-allowed}@media(max-width:768px){.field-error,.global-error,.success-message{font-size:11px;padding:10px}}.messenger-page{height:100vh;margin:0;overflow:hidden;padding:0;position:relative;width:100vw;z-index:1}.wrapper{background:var(--color-background);display:-webkit-box;display:-ms-flexbox;display:flex;height:100%;width:100%}.left-column{background:var(--color-white);border-right:1px solid var(--color-border-light);flex-shrink:0;height:100vh;width:320px}.left-column,.left-column-main{display:-webkit-box;display:-ms-flexbox;display:flex;flex-direction:column}.left-column-main{height:100%;overflow:hidden}.left-column-main-header{background:var(--color-white);border-bottom:1px solid var(--color-border-light);flex-shrink:0;height:120px;padding:16px}.left-header{align-items:center;background:var(--background-container);display:-webkit-box;display:-ms-flexbox;display:flex;gap:12px;padding:var(--spacing-sm)}.chat-list-wrapper{flex:1;height:calc(100vh - 120px);overflow-y:auto}.right-column{background:var(--color-background);flex:1;flex-direction:column;height:100vh;min-width:0;overflow:hidden}.chat-header,.right-column{display:-webkit-box;display:-ms-flexbox;display:flex}.chat-header{align-items:center;background:var(--color-white);border-bottom:1px solid var(--color-border-light);box-sizing:border-box;flex-shrink:0;height:80px;justify-content:space-between;padding:16px 24px}.chat-info{align-items:center;display:-webkit-box;display:-ms-flexbox;display:flex;gap:12px}.chat-avatar{border-radius:50%;flex-shrink:0;height:44px;overflow:hidden;width:44px}.chat-avatar-img{height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.chat-avatar-placeholder{align-items:center;background:var(--gradient-primary);border-radius:50%;color:#fff;display:-webkit-box;display:-ms-flexbox;display:flex;flex-shrink:0;font-size:16px;font-weight:600;height:44px;justify-content:center;width:44px}.chat-title{color:var(--color-text);font-size:18px;font-weight:600;line-height:1.2;margin:0}.chat-online-status{color:var(--color-text-light);font-size:12px;margin-top:2px}.messages-container{background:var(--color-background);flex:1 1 auto;height:calc(100vh - 200px);min-height:0;overflow-y:auto;padding:24px}.messages-container,.messages-wrapper{display:-webkit-box;display:-ms-flexbox;display:flex;flex-direction:column}.messages-wrapper{justify-content:flex-end;margin-top:auto}.message-input-container{background:var(--color-white);border-top:1px solid var(--color-border-light);box-sizing:border-box;flex-shrink:0;padding:16px 24px;width:100%}.message-input,.message-input__form{width:100%}.message-input__wrapper{align-items:center;background:var(--color-background);border-radius:24px;display:-webkit-box;display:-ms-flexbox;display:flex;gap:12px;padding:4px 4px 4px 16px}.message-input__field{background:transparent;border:none;flex:1;font-size:14px;outline:none;padding:12px 0}.message-input__button{align-items:center;background:var(--color-primary);border:none;border-radius:50%;color:#fff;cursor:pointer;display:-webkit-box;display:-ms-flexbox;display:flex;height:40px;justify-content:center;transition:background-color .2s;width:40px}.message-input__button:hover{background:var(--color-primary-dark)}.message-input__icon{height:20px;width:20px}.message{margin-bottom:8px;max-width:70%}.message--mine{align-self:flex-end}.message--theirs{align-self:flex-start}.message__content{display:-webkit-box;display:-ms-flexbox;display:flex;flex-direction:column}.message__bubble{background:var(--color-white);border-radius:18px;box-shadow:0 1px 2px #0000001a;padding:10px 14px;position:relative;word-wrap:break-word}.message--mine .message__bubble{background:var(--color-primary);color:#fff}.message__meta{align-items:center;color:var(--color-text-light);display:-webkit-box;display:-ms-flexbox;display:flex;font-size:11px;gap:4px;margin-top:4px}.message--mine .message__meta{color:#ffffffb3}.message__time{white-space:nowrap}.message__sender{color:var(--color-text);font-size:12px;font-weight:600;margin-bottom:2px}.message__avatar{background:var(--gradient-primary);border-radius:50%;color:#fff;font-size:12px;font-weight:600;height:28px;margin-right:8px;width:28px}.message__avatar,.messages-empty{align-items:center;display:-webkit-box;display:-ms-flexbox;display:flex;justify-content:center}.messages-empty{color:var(--color-text-light);height:100%;text-align:center}.profile-button{align-items:center;background:var(--gradient-primary);border-radius:50%;color:#fff;display:-webkit-box;display:-ms-flexbox;display:flex;font-weight:600;height:40px;justify-content:center;overflow:hidden;text-decoration:none;transition:transform .2s ease;width:40px}.profile-avatar{display:block;height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.profile-button:hover{transform:scale(1.05)}@media(max-width:768px){.left-column{width:100%}.right-column{display:none}.right-column--active{display:-webkit-box;display:-ms-flexbox;display:flex;inset:0;position:fixed;z-index:100}}form{margin:0 auto;max-width:600px}form label{font-size:var(--font-size-md);font-weight:600}form input{border:2px solid #98a8af;border-radius:var(--radius-sm);font-size:var(--font-size-sm);padding:var(--spacing-sm);width:100%}.avatar-section{margin-bottom:24px}.avatar-container,.avatar-section{display:-webkit-box;display:-ms-flexbox;display:flex;justify-content:center}.avatar-container{align-items:center;background:var(--gradient-primary);border-radius:50%;height:120px;overflow:hidden;position:relative;width:120px}.avatar-img{display:block;height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;color:#fff;display:-webkit-box;display:-ms-flexbox;display:flex;font-size:var(--font-size-md);font-weight:600;height:100%;justify-content:center;width:100%}.profile-info{margin-bottom:var(--spacing-md);text-align:center}.profile-name{font-size:var(--font-size-md);font-weight:600;margin-bottom:var(--spacing-xs)}.profile-display-name{color:var(--color-text-light);font-size:var(--font-size-sm)}.password-section{border-top:1px solid var(--color-border-light);margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.section-title{color:var(--color-text);font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--spacing-md)}.profile-actions{display:-webkit-box;display:-ms-flexbox;display:flex;gap:12px;justify-content:center;margin-top:var(--spacing-md)}.form-input--readonly{background-color:var(--color-background);cursor:default}.form-input--readonly:focus{border-color:var(--color-border);outline:none}.button{border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:var(--font-size-md);font-weight:600;min-width:150px;padding:var(--spacing-sm);text-decoration:none;transition:all .2s ease}.button:hover{box-shadow:0 4px 12px #6a11cb4d;transform:translateY(-2px)}.button.button--primary{background:var(--gradient-button);color:#fff}.button.button--primary:hover{background:var(--color-primary)}.button.button--secondary{background:#fff;border:2px solid var(--color-primary);color:var(--color-primary)}.button.button--secondary:hover{background:var(--color-hover)}.button.button--authorization{background:var(--gradient-button);color:#fff}.button.button--home,.button.button--registration{background:#fff;border:2px solid #6a11cb}.avatar-upload-btn{background:#0009;bottom:0;color:#fff;cursor:pointer;font-size:12px;left:0;padding:8px;position:absolute;right:0;text-align:center;transition:background .3s}.avatar-upload-btn:hover{background:#000c}.form-buttons{display:-webkit-box;display:-ms-flexbox;display:flex;gap:15px;justify-content:center;margin-top:30px}.chat-item{align-items:center;background:var(--color-background);border-bottom:1px solid var(--color-border-light);cursor:pointer;display:-webkit-box;display:-ms-flexbox;display:flex;padding:12px 16px;transition:background-color .2s ease}.chat-item:hover{background-color:var(--color-hover)}.chat-item--active{background-color:var(--color-primary-light);border-left:3px solid var(--color-primary)}.chat-item__avatar{border-radius:50%;flex-shrink:0;height:48px;overflow:hidden;position:relative;width:48px}.chat-item__avatar-img{height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.chat-item__avatar-placeholder{align-items:center;background:var(--gradient-primary);border-radius:50%;color:#fff;display:-webkit-box;display:-ms-flexbox;display:flex;font-size:18px;font-weight:600;height:100%;justify-content:center;width:100%}.chat-item__content{flex:1;min-width:0}.chat-item__header{align-items:center;display:-webkit-box;display:-ms-flexbox;display:flex;justify-content:space-between;margin-bottom:4px}.chat-item__name{color:var(--color-text);font-size:16px;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-item__time{color:var(--color-text-light);font-size:12px;white-space:nowrap}.chat-item__footer{align-items:center;display:-webkit-box;display:-ms-flexbox;display:flex;justify-content:space-between}.chat-item__last-message{color:var(--color-text-light);flex:1;font-size:14px;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-item__badge{align-items:center;background-color:var(--color-primary);border-radius:10px;color:#fff;display:-webkit-box;display:-ms-flexbox;display:flex;font-size:12px;font-weight:600;height:20px;justify-content:center;margin-left:8px;min-width:20px;padding:0 6px}.message{display:-webkit-box;display:-ms-flexbox;display:flex;margin-bottom:16px;max-width:80%}.message--mine{flex-direction:row-reverse;margin-left:auto}.message--theirs{margin-right:auto}.message__avatar{flex-shrink:0;margin-right:8px}.message__avatar-img{border-radius:50%;height:32px;-o-object-fit:cover;object-fit:cover;width:32px}.message__avatar-placeholder{align-items:center;background:var(--gradient-primary);border-radius:50%;color:#fff;font-size:14px;font-weight:600;height:32px;justify-content:center;width:32px}.message__avatar-placeholder,.message__content{display:-webkit-box;display:-ms-flexbox;display:flex}.message__content{flex-direction:column}.message__sender{color:var(--color-text-light);font-size:12px;margin-bottom:4px;margin-left:8px}.message__bubble{background:var(--color-background);border-radius:18px;box-shadow:0 1px 2px #0000001a;padding:10px 16px;position:relative}.message--mine .message__bubble{background:var(--color-primary-light);border-bottom-right-radius:4px}.message--theirs .message__bubble{background:#fff;border-bottom-left-radius:4px}.message__text{color:var(--color-text);font-size:14px;line-height:1.4;margin-bottom:4px;word-break:break-word}.message__meta{align-items:center;display:-webkit-box;display:-ms-flexbox;display:flex;gap:4px;justify-content:flex-end}.message__time{color:var(--color-text-light);font-size:11px;opacity:.8}.message__status{font-size:12px}.message__status,.message__status--sent{color:var(--color-text-light)}.message__status--read{color:var(--color-primary)}.message-input{background:var(--color-background);border-top:1px solid var(--color-border-light);padding:16px}.message-input__form{width:100%}.message-input__wrapper{align-items:center;display:-webkit-box;display:-ms-flexbox;display:flex;gap:12px}.message-input__field{background:#fff;border:2px solid var(--color-border);border-radius:24px;flex:1;font-size:14px;outline:none;padding:12px 16px;transition:border-color .2s ease}.message-input__field:focus{border-color:var(--color-primary)}.message-input__button{align-items:center;background:var(--gradient-primary);border:none;border-radius:50%;color:#fff;cursor:pointer;display:-webkit-box;display:-ms-flexbox;display:flex;flex-shrink:0;height:44px;justify-content:center;transition:transform .2s ease,box-shadow .2s ease;width:44px}.message-input__button:hover{box-shadow:0 4px 12px #6a11cb4d;transform:translateY(-2px)}.message-input__icon{stroke:#fff}.search-input{flex:1;position:relative}.search-input__icon{color:var(--color-text-light);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input__field{background:var(--color-background);border:1px solid var(--color-border);border-radius:20px;font-size:14px;outline:none;padding:10px 12px 10px 40px;transition:border-color .2s ease;width:100%}.search-input__field:focus{border-color:var(--color-primary)}.search-input__field::-moz-placeholder{color:var(--color-text-light)}.search-input__field::placeholder{color:var(--color-text-light)}.dropdown-menu{display:inline-block;position:relative}.dropdown-menu__button{align-items:center;background:none;border:none;border-radius:50%;color:var(--color-text-light);cursor:pointer;display:-webkit-box;display:-ms-flexbox;display:flex;font-size:20px;height:32px;justify-content:center;padding:4px 8px;transition:background-color .2s;width:32px}.dropdown-menu__button:hover{background-color:var(--color-hover);color:var(--color-primary)}.dropdown-menu__list{background:var(--color-white);border:1px solid var(--color-border-light);border-radius:8px;box-shadow:0 4px 12px #00000026;display:none;margin-top:8px;max-width:300px;min-width:200px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.dropdown-menu__list--left,.left-column .dropdown-menu__list{left:0;right:auto}.dropdown-menu__list--right{left:auto;right:0}.dropdown-menu__list.visible{display:block}.dropdown-menu__item{background:none;border:none;color:var(--color-text);cursor:pointer;display:block;font-size:14px;padding:10px 16px;text-align:left;width:100%}.dropdown-menu__item:hover{background-color:var(--color-background)}.dropdown-menu__item:first-child{border-radius:8px 8px 0 0}.dropdown-menu__item:last-child{border-radius:0 0 8px 8px}.modal{display:none;inset:0;position:fixed;z-index:9999}.modal--open{display:block!important}.modal__overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;inset:0;position:absolute}.modal__content{animation:modalFadeIn .3s ease;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000004d;left:50%;max-height:90vh;max-width:450px;overflow-y:auto;position:relative;top:50%;transform:translate(-50%,-50%);width:90%}@keyframes modalFadeIn{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.modal__header{align-items:center;background:#fff;border-bottom:1px solid var(--color-border-light);border-radius:16px 16px 0 0;display:-webkit-box;display:-ms-flexbox;display:flex;justify-content:space-between;padding:20px 24px}.modal__title{color:var(--color-text);font-size:20px;font-weight:600;margin:0}.modal__close{align-items:center;background:none;border:none;border-radius:50%;color:var(--color-text-light);cursor:pointer;display:-webkit-box;display:-ms-flexbox;display:flex;font-size:28px;height:36px;justify-content:center;padding:0;transition:all .2s;width:36px}.modal__close:hover{background-color:var(--color-hover);color:var(--color-text);transform:scale(1.1)}.modal__body{background:#fff;border-radius:0 0 16px 16px;max-height:60vh;overflow-y:auto;padding:24px}.create-chat-form{display:-webkit-box;display:-ms-flexbox;display:flex;flex-direction:column;gap:20px}.create-chat-form .form-group{margin-bottom:0}.create-chat-form .form-hint{color:var(--color-text-light);display:block;font-size:12px;margin-top:4px}.create-chat-form .form-actions{display:-webkit-box;display:-ms-flexbox;display:flex;gap:12px;margin-top:20px}.create-chat-form .form-actions button{flex:1}.form-input{border:2px solid var(--color-border);border-radius:8px;font-size:14px;padding:12px 16px;transition:border-color .2s;width:100%}.form-input:focus{border-color:var(--color-primary);outline:none}.form-label{color:var(--color-text);display:block;font-weight:500;margin-bottom:8px}.add-user-form{display:-webkit-box;display:-ms-flexbox;display:flex;flex-direction:column;gap:20px}.chat-users,.search-results{border:1px solid var(--color-border-light);border-radius:8px;max-height:200px;overflow-y:auto;padding:12px}.chat-users__title,.search-results__title{color:var(--color-text-light);font-size:14px;margin:0 0 8px}.chat-users__list,.search-results__list{list-style:none;margin:0;padding:0}.chat-users__item,.search-results__item{align-items:center;border-bottom:1px solid var(--color-border-light);display:-webkit-box;display:-ms-flexbox;display:flex;gap:8px;padding:8px}.chat-users__item:last-child,.search-results__item:last-child{border-bottom:none}.chat-users__name,.search-results__name{flex:1;font-weight:500}.chat-users__login,.search-results__login{color:var(--color-text-light);font-size:12px}.chat-users__remove,.search-results__add{border:none;border-radius:4px;cursor:pointer;font-size:12px;padding:4px 8px}.search-results__add{background:var(--color-primary);color:#fff}.chat-users__remove{background:#ff4757;color:#fff}.chat-users__badge{color:var(--color-text-light);font-size:12px;font-style:italic}.chat-users-empty{border:1px dashed var(--color-border-light);border-radius:8px;padding:20px;text-align:center}.chat-users-empty,.form-hint{color:var(--color-text-light)}.form-hint{font-size:12px;margin-top:4px}
