:root{--bg-primary: #ffffff;--bg-secondary: #f0f2f5;--bg-tertiary: #e4e6eb;--bg-chat: #efeae2;--bg-bubble-incoming: #ffffff;--bg-bubble-outgoing: #effdde;--bg-sidebar: #ffffff;--bg-hover: rgba(0, 0, 0, .04);--bg-active: rgba(0, 0, 0, .08);--bg-input: #ffffff;--bg-overlay: rgba(0, 0, 0, .5);--text-primary: #111827;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--text-inverse: #ffffff;--text-link: #2aabee;--text-danger: #ef4444;--accent: #2aabee;--accent-hover: #229ed9;--accent-light: rgba(42, 171, 238, .1);--color-success: #22c55e;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #3b82f6;--border-primary: #e5e7eb;--border-secondary: #d1d5db;--border-focus: #2aabee;--badge-unread: #2aabee;--badge-awaiting: #f59e0b;--badge-online: #22c55e;--badge-offline: #9ca3af;--color-max: #7c3aed;--color-telegram: #2aabee;--color-whatsapp: #25d366;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-2xl: 24px;--space-3xl: 32px;--font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-xs: 11px;--font-sm: 12px;--font-base: 13px;--font-md: 14px;--font-lg: 15px;--font-xl: 16px;--font-2xl: 18px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--line-height: 1.5;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 50%;--sidebar-width: 220px;--sidebar-collapsed: 48px;--dialogs-width: 340px;--dialogs-width-compact: 280px;--profile-width: 300px;--header-height: 48px;--input-height: 48px;--sidebar-item-height: 34px;--sidebar-item-height-compact: 32px;--sidebar-icon-size: 20px;--sidebar-badge-size: 18px;--duration-fast: .1s;--duration-normal: .2s;--duration-slow: .3s;--easing: cubic-bezier(.4, 0, .2, 1);--bg-date-badge: rgba(0, 0, 0, .15);--text-date-badge: rgba(0, 0, 0, .55);--bg-active-item: #e3f2fd;--text-active-item: var(--accent);--bg-system-msg: rgba(0, 0, 0, .04);--text-system-msg: var(--text-secondary);--bubble-max-width: 65%;--text-bubble-outgoing: #111827;--text-bubble-outgoing-meta: rgba(0, 0, 0, .4);--bg-reply: rgba(0, 0, 0, .04);--bg-reply-hover: rgba(0, 0, 0, .08);--z-base: 0;--z-dropdown: 10;--z-sticky: 20;--z-overlay: 30;--z-modal: 40;--z-toast: 50;--z-tooltip: 60}[data-theme=dark]{--bg-primary: #1f2937;--bg-secondary: #111827;--bg-tertiary: #374151;--bg-chat: #0e0e0e;--bg-bubble-incoming: #2b2b2b;--bg-bubble-outgoing: #005c4b;--bg-sidebar: #1f2937;--bg-hover: rgba(255, 255, 255, .06);--bg-active: rgba(255, 255, 255, .1);--bg-input: #374151;--bg-overlay: rgba(0, 0, 0, .7);--text-primary: #f9fafb;--text-secondary: #9ca3af;--text-tertiary: #6b7280;--text-inverse: #111827;--border-primary: #374151;--border-secondary: #4b5563;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--bg-date-badge: rgba(255, 255, 255, .08);--text-date-badge: rgba(255, 255, 255, .6);--bg-active-item: rgba(42, 171, 238, .15);--text-active-item: #5bc0f0;--bg-system-msg: rgba(255, 255, 255, .06);--text-system-msg: #9ca3af;--text-bubble-outgoing: #f0f0f0;--text-bubble-outgoing-meta: rgba(255, 255, 255, .5);--bg-reply: rgba(255, 255, 255, .06);--bg-reply-hover: rgba(255, 255, 255, .1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}.is-iframe .messenger{height:100%;border-radius:0}body{font-family:var(--font-family);font-size:var(--font-base);line-height:var(--line-height);color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}a{color:var(--text-link);text-decoration:none}a:hover{text-decoration:underline}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea{font-family:inherit;font-size:inherit;color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);transition:border-color var(--duration-fast) var(--easing)}input:focus,textarea:focus{border-color:var(--border-focus);outline:none}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-secondary)}.login-card{width:100%;max-width:360px;padding:var(--space-3xl);background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.login-title{font-size:var(--font-2xl);font-weight:var(--font-weight-semibold);text-align:center;margin-bottom:var(--space-xs)}.login-subtitle{font-size:var(--font-sm);color:var(--text-secondary);text-align:center;margin-bottom:var(--space-2xl)}.login-form{display:flex;flex-direction:column;gap:var(--space-lg)}.login-field{display:flex;flex-direction:column;gap:var(--space-xs)}.login-field label{font-size:var(--font-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary)}.login-field input{padding:var(--space-md) var(--space-lg);font-size:var(--font-md)}.login-button{padding:var(--space-md) var(--space-lg);background:var(--accent);color:var(--text-inverse);font-size:var(--font-md);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:background var(--duration-fast) var(--easing)}.login-button:hover:not(:disabled){background:var(--accent-hover)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-error{padding:var(--space-sm) var(--space-md);background:#ef44441a;color:var(--text-danger);font-size:var(--font-sm);border-radius:var(--radius-sm);text-align:center}.sidebar-header{display:flex;align-items:center;height:48px;padding:0 12px;gap:10px;flex-shrink:0;border-bottom:1px solid var(--border-primary)}.sidebar-logo{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--accent);color:var(--text-inverse);border-radius:var(--radius-md);font-size:var(--font-xs);font-weight:var(--font-weight-semibold);flex-shrink:0}.sidebar-title{font-size:var(--font-md);font-weight:var(--font-weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;opacity:1;transition:opacity var(--duration-fast)}.sidebar--collapsed .sidebar-title{opacity:0;width:0;pointer-events:none}.sidebar-collapse-btn{margin-left:auto;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;flex-shrink:0;transition:background var(--duration-fast)}.sidebar-collapse-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar--collapsed .sidebar-collapse-btn{margin:0 auto}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 0}.sidebar-nav::-webkit-scrollbar{width:0}.sidebar-section__title{font-size:10px;font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);padding:12px 12px 4px;white-space:nowrap;overflow:hidden}.sidebar--collapsed .sidebar-section__title{font-size:0;padding:0;margin:4px 8px;height:1px;background:var(--border-primary)}.sidebar-section{padding:0 4px}.sidebar-item{display:flex;align-items:center;height:var(--sidebar-item-height);padding:0 12px;gap:10px;cursor:pointer;border-radius:0;color:var(--text-secondary);transition:background var(--duration-fast),color var(--duration-fast);position:relative;white-space:nowrap;width:100%}.sidebar-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-item--active{background:var(--bg-hover);color:var(--accent)}.sidebar-item--active:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--accent);border-radius:0 2px 2px 0}.sidebar-item__icon{width:var(--sidebar-icon-size);height:var(--sidebar-icon-size);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;line-height:1}.sidebar-item__stage-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;position:relative}.sidebar-item__dot-indicator{position:absolute;top:-3px;right:-3px;width:6px;height:6px;border-radius:50%;background:var(--color-danger)}.sidebar-item__label{flex:1;font-size:var(--font-sm);overflow:hidden;text-overflow:ellipsis;transition:opacity var(--duration-fast)}.sidebar--collapsed .sidebar-item__label{opacity:0;width:0;pointer-events:none}.sidebar-item__badge{min-width:var(--sidebar-badge-size);height:var(--sidebar-badge-size);padding:0 5px;border-radius:9px;font-size:10px;font-weight:var(--font-weight-semibold);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--bg-tertiary);color:var(--text-secondary);line-height:1}.sidebar-item__badge--highlight{background:var(--accent);color:#fff}.sidebar-item__badge--zero{opacity:.3}.sidebar--collapsed .sidebar-item{height:var(--sidebar-item-height-compact);padding:0;justify-content:center;gap:0}.sidebar--collapsed .sidebar-item__icon{width:100%;height:100%;font-size:18px;position:relative}.sidebar--collapsed .sidebar-item__stage-dot{width:10px;height:10px}.sidebar--collapsed .sidebar-item__badge{position:absolute;top:-2px;right:4px;min-width:14px;height:14px;padding:0 3px;font-size:9px;border-radius:7px}.sidebar--collapsed .sidebar-item__badge--zero,.sidebar-item__tooltip{display:none}.sidebar--collapsed .sidebar-item__tooltip{display:none;position:absolute;left:calc(var(--sidebar-collapsed) + 4px);top:50%;transform:translateY(-50%);background:var(--bg-primary);border:1px solid var(--border-primary);box-shadow:var(--shadow-md);padding:4px 8px;border-radius:var(--radius-sm);font-size:var(--font-xs);color:var(--text-primary);white-space:nowrap;z-index:var(--z-tooltip);pointer-events:none}.sidebar--collapsed .sidebar-item:hover .sidebar-item__tooltip{display:block}.sidebar-user{padding:8px 12px;border-bottom:1px solid var(--border-primary)}.sidebar-user__name{font-size:var(--font-sm);font-weight:var(--font-weight-medium);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user__role{font-size:var(--font-xs);color:var(--text-tertiary);text-transform:capitalize}.sidebar--collapsed .sidebar-user{display:none}.manager-selector{display:flex;flex-wrap:wrap;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm)}.manager-avatar{position:relative;width:28px;height:28px;border-radius:var(--radius-full);background:var(--bg-secondary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:var(--font-weight-semibold);cursor:pointer;border:2px solid transparent;transition:border-color var(--duration-fast) var(--easing)}.manager-avatar:hover{border-color:var(--border-primary)}.manager-avatar--active{border-color:var(--accent)}.manager-avatar__reset{font-size:var(--font-xs);background:var(--bg-hover)}.sidebar--collapsed .manager-selector{flex-direction:column;align-items:center;padding:4px}.sidebar--collapsed .manager-avatar{width:24px;height:24px;font-size:10px}.sidebar-footer{display:flex;align-items:center;padding:8px 12px;gap:4px;border-top:1px solid var(--border-primary);flex-shrink:0}.sidebar-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:background var(--duration-fast),color var(--duration-fast);font-size:16px}.sidebar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar--collapsed .sidebar-footer{flex-direction:column;padding:4px}.sidebar-item--tag .sidebar-item__icon{font-size:14px;color:var(--text-tertiary)}.sidebar-item--tag.sidebar-item--active .sidebar-item__icon{color:var(--accent)}.sidebar-tag-dropdown{position:absolute;left:var(--sidebar-collapsed);top:0;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:180px;max-height:300px;overflow-y:auto;z-index:var(--z-dropdown);padding:4px;animation:fadeIn var(--duration-normal) var(--easing)}.sidebar-tag-dropdown__item{display:flex;align-items:center;padding:6px 8px;gap:8px;border-radius:var(--radius-xs);cursor:pointer;font-size:var(--font-sm);color:var(--text-secondary);background:none;border:none;width:100%;text-align:left}.sidebar-tag-dropdown__item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-tag-dropdown__item--active{color:var(--accent);font-weight:500}.sidebar-tag-dropdown__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sidebar-tag-dropdown__badge{margin-left:auto;font-size:10px;font-weight:600;color:var(--text-tertiary)}.sidebar-placeholder{padding:var(--space-md);color:var(--text-tertiary);font-size:var(--font-sm)}.dialog-search{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-primary)}.dialog-search__input{flex:1;border:none;outline:none;background:var(--bg-secondary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);font-size:var(--font-sm);color:var(--text-primary)}.dialog-search__input::placeholder{color:var(--text-tertiary)}.dialog-search__clear{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-full);color:var(--text-tertiary);cursor:pointer;font-size:var(--font-sm)}.dialog-search__clear:hover{background:var(--bg-hover);color:var(--text-secondary)}.dialog-toolbar{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);border-bottom:1px solid var(--border-primary)}.dialog-toolbar__sort{font-size:var(--font-xs);color:var(--text-secondary);background:none;border:1px solid var(--border-primary);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);cursor:pointer}.dialog-toolbar__sort:hover{background:var(--bg-hover)}.dialog-toolbar__tag-chip{display:flex;align-items:center;gap:4px;font-size:var(--font-xs);padding:2px 8px;border-radius:var(--radius-lg);background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;font-weight:500}.dialog-toolbar__tag-chip:hover{opacity:.85}.dialog-list{flex:1;overflow-y:auto}.dialog-list__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--text-tertiary);font-size:var(--font-sm);text-align:center;gap:var(--space-sm)}.dialog-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);height:72px;cursor:pointer;transition:background var(--duration-fast) var(--easing);position:relative}.dialog-card:hover,.dialog-card--active{background:var(--bg-hover)}.dialog-card--unread .dialog-card__name{font-weight:var(--font-weight-semibold);color:var(--text-primary)}.dialog-card--awaiting{border-left:3px solid var(--badge-awaiting)}.dialog-card__avatar{position:relative;width:40px;height:40px;border-radius:var(--radius-full);background:var(--accent);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-size:var(--font-md);font-weight:var(--font-weight-semibold);flex-shrink:0}.dialog-card__avatar-img{width:40px;height:40px;object-fit:cover;border-radius:var(--radius-full)}.dialog-card__channel-badge{position:absolute;bottom:-2px;right:-2px;width:16px;height:16px;border-radius:var(--radius-full);border:2px solid var(--bg-primary);display:flex;align-items:center;justify-content:center;line-height:0;background:transparent}.dialog-card__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.dialog-card__row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-xs)}.dialog-card__name{font-size:var(--font-md);font-weight:var(--font-weight-normal);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.dialog-card__time{font-size:var(--font-xs);color:var(--text-tertiary);white-space:nowrap;flex-shrink:0}.dialog-card__preview{font-size:var(--font-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dialog-card__meta{display:flex;align-items:center;gap:var(--space-xs)}.dialog-card__badge{display:flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-xs);border-radius:var(--radius-full);background:var(--badge-unread);color:var(--text-inverse);font-size:var(--font-xs);font-weight:var(--font-weight-semibold);flex-shrink:0}.dialog-card__awaiting{width:8px;height:8px;border-radius:var(--radius-full);background:var(--badge-awaiting);animation:pulse 1.5s infinite;flex-shrink:0}.dialog-card__pin{color:var(--text-tertiary);font-size:var(--font-xs);flex-shrink:0}.dialog-card__tags{display:flex;gap:3px;overflow:hidden;margin-top:1px}.dialog-card__tag{font-size:10px;padding:1px 6px;border-radius:8px;border:1px solid transparent;white-space:nowrap;cursor:pointer;transition:opacity var(--duration-fast);font-weight:500}.dialog-card__tag:hover{opacity:.8}.dialog-card__tag--active{outline:1.5px solid currentColor;outline-offset:.5px}.dialog-card__tag--more{background:var(--bg-secondary);color:var(--text-tertiary);cursor:default;border:none}.context-menu{position:fixed;z-index:var(--z-dropdown);min-width:180px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-xs) 0;animation:fadeIn var(--duration-fast) var(--easing)}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu__item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:var(--font-sm);color:var(--text-primary);cursor:pointer;transition:background var(--duration-fast) var(--easing)}.context-menu__item:hover{background:var(--bg-hover)}.context-menu__item--danger{color:var(--color-danger)}.context-menu__separator{height:1px;background:var(--border-primary);margin:var(--space-xs) 0}.context-menu__submenu{position:relative}.context-menu__submenu-content{position:absolute;left:100%;top:0;min-width:160px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-xs) 0}.dialog-skeleton{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);height:72px}.dialog-skeleton__avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--bg-secondary);animation:skeleton-pulse 1.5s infinite}.dialog-skeleton__lines{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.dialog-skeleton__line{height:12px;border-radius:var(--radius-sm);background:var(--bg-secondary);animation:skeleton-pulse 1.5s infinite}.dialog-skeleton__line--short{width:60%}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.new-dialog-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-full);border:none;background:var(--accent);color:#fff;font-size:var(--font-lg);font-weight:600;cursor:pointer;transition:background var(--duration-fast);flex-shrink:0}.new-dialog-btn:hover{background:var(--accent-hover)}.phone-input-wrapper{position:relative}.phone-input{font-family:monospace;font-size:var(--font-md);letter-spacing:.5px}.phone-input--valid{border-color:var(--color-success)}.phone-input__check{position:absolute;right:var(--space-sm);top:50%;transform:translateY(-50%);color:var(--color-success);font-size:var(--font-md)}.new-dialog__messenger{display:flex;gap:var(--space-sm)}.new-dialog__messenger-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:600;background:var(--bg-secondary);color:var(--text-tertiary)}.new-dialog__messenger-badge--active{background:var(--color-max, #7c3aed);color:#fff}.stage-dropdown{position:relative}.stage-dropdown__trigger{border:none;border-radius:var(--radius-md);padding:var(--space-xs) var(--space-sm);font-size:var(--font-xs);font-weight:500;cursor:pointer;white-space:nowrap;transition:filter var(--duration-fast)}.stage-dropdown__trigger:hover{filter:brightness(.95)}.stage-dropdown__menu{position:absolute;top:100%;right:0;margin-top:var(--space-xs);min-width:160px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:0 4px 12px #0000001f;z-index:var(--z-dropdown);overflow:hidden;animation:stage-dropdown-slide var(--duration-fast) ease-out}@keyframes stage-dropdown-slide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.stage-dropdown__item{padding:var(--space-sm) var(--space-md);font-size:var(--font-sm);cursor:pointer;transition:background var(--duration-fast)}.stage-dropdown__item:hover{background:var(--bg-hover)}.stage-dropdown__item--active{font-weight:600;background:var(--bg-active-item);color:var(--text-active-item)}.collapsible-text__toggle{display:inline-block;background:none;border:none;color:var(--accent);font-size:var(--font-xs);cursor:pointer;padding:var(--space-xs) 0;margin-top:var(--space-xs)}.collapsible-text__toggle:hover{text-decoration:underline}.linkified-url{color:var(--accent);text-decoration:none;word-break:break-all}.linkified-url:hover{text-decoration:underline}.template-panel{position:absolute;bottom:100%;left:var(--space-md);right:var(--space-md);max-width:400px;max-height:400px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:0 -4px 16px #0000001f;display:flex;flex-direction:column;z-index:var(--z-dropdown);overflow:hidden;animation:template-panel-slide-up var(--duration-normal) ease-out}@keyframes template-panel-slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.template-panel__header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-primary);flex-shrink:0}.template-panel__search{flex:1;border:none;outline:none;background:transparent;font-size:var(--font-sm);color:var(--text-primary);padding:var(--space-xs) 0}.template-panel__search::placeholder{color:var(--text-tertiary)}.template-panel__close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);font-size:var(--font-md);line-height:1;border-radius:var(--radius-sm)}.template-panel__close:hover{color:var(--text-primary);background:var(--bg-hover)}.template-panel__body{flex:1;overflow-y:auto;padding:var(--space-xs) 0}.template-panel__empty{padding:var(--space-xl);text-align:center;color:var(--text-tertiary);font-size:var(--font-sm)}.template-category{border-bottom:1px solid var(--border-secondary)}.template-category:last-child{border-bottom:none}.template-category__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--duration-fast)}.template-category__header:hover{background:var(--bg-hover)}.template-category__name{font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.template-category__count{font-size:var(--font-xs);color:var(--text-tertiary);margin-left:var(--space-xs)}.template-category__chevron{font-size:var(--font-xs);color:var(--text-tertiary);transition:transform var(--duration-fast)}.template-category__chevron--open{transform:rotate(90deg)}.template-category__items{padding:0 var(--space-sm) var(--space-xs)}.template-category--favorites{border-bottom:1px solid var(--border-primary);padding-bottom:4px;margin-bottom:4px}.template-category--favorites .template-category__header{color:#f5a623;font-weight:600}.template-item{display:flex;flex-direction:column;gap:2px;padding:var(--space-sm) var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast)}.template-item:hover{background:var(--bg-hover)}.template-item__top{display:flex;align-items:center;gap:var(--space-xs)}.template-item__favorite{width:16px;height:16px;color:var(--text-tertiary);cursor:pointer;flex-shrink:0;opacity:0;transition:opacity var(--duration-fast),color var(--duration-fast);font-size:14px;line-height:16px;text-align:center}.template-item:hover .template-item__favorite,.template-item__favorite--active{opacity:1}.template-item__favorite--active,.template-item__favorite:hover{color:#f5a623}.template-item__title{font-size:var(--font-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.template-item__shortcut{font-size:var(--font-xs);color:var(--accent);font-family:monospace;flex-shrink:0;margin-left:auto}.template-item__preview{font-size:var(--font-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-item__resolved-preview{font-size:var(--font-xs);color:var(--accent);padding:4px 8px;margin-top:4px;background:#2aabee0f;border-radius:var(--radius-xs);border-left:2px solid var(--accent);display:none;white-space:pre-wrap;max-height:60px;overflow:hidden}.template-item:hover .template-item__resolved-preview{display:block}.template-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:0;font-size:18px;line-height:1;border-radius:var(--radius-full);flex-shrink:0;transition:color var(--duration-fast),background var(--duration-fast)}.template-btn:hover,.template-btn--active{color:var(--accent);background:var(--bg-hover)}.shortcut-autocomplete{position:absolute;bottom:100%;left:var(--space-md);min-width:240px;max-width:360px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:0 -2px 8px #0000001a;z-index:var(--z-dropdown);overflow:hidden;animation:template-panel-slide-up var(--duration-fast) ease-out}.shortcut-autocomplete__item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);cursor:pointer;transition:background var(--duration-fast)}.shortcut-autocomplete__item:hover,.shortcut-autocomplete__item--active{background:var(--bg-hover)}.shortcut-autocomplete__shortcut{font-size:var(--font-xs);color:var(--accent);font-family:monospace;flex-shrink:0;min-width:48px}.shortcut-autocomplete__title{font-size:var(--font-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-input__toolbar{display:flex;align-items:center;gap:var(--space-xs);padding:0 var(--space-sm)}.template-manager{padding:24px 32px;max-width:960px;margin:0 auto;height:100%;overflow-y:auto}.template-manager__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.template-manager__title{font-size:var(--font-xl);font-weight:600;color:var(--text-primary);margin:4px 0 0}.template-manager__breadcrumb{font-size:var(--font-sm);color:var(--text-tertiary)}.template-manager__breadcrumb a{color:var(--accent);text-decoration:none}.template-manager__breadcrumb a:hover{text-decoration:underline}.template-manager__toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px}.template-manager__search{flex:1;max-width:320px;height:36px;padding:0 12px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-sm)}.template-manager__search:focus{outline:none;border-color:var(--accent)}.template-manager__filter-select{height:36px;padding:0 12px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-sm);cursor:pointer}.template-table{width:100%;border-collapse:collapse;margin-bottom:32px}.template-table th{text-align:left;padding:8px 12px;font-size:var(--font-xs);font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-primary)}.template-table td{padding:10px 12px;font-size:var(--font-sm);color:var(--text-primary);border-bottom:1px solid var(--border-secondary);vertical-align:middle}.template-table tr:hover td{background:var(--bg-hover)}.template-table tbody tr{cursor:pointer}.template-table__drag-handle{width:16px;color:var(--text-tertiary);cursor:grab;opacity:0;transition:opacity var(--duration-fast)}.template-table tr:hover .template-table__drag-handle{opacity:1}.template-table__shortcut{font-family:monospace;font-size:var(--font-xs);color:var(--accent);background:#2aabee14;padding:2px 6px;border-radius:var(--radius-xs)}.template-table__status{width:8px;height:8px;border-radius:50%;display:inline-block}.template-table__status--active{background:var(--color-success)}.template-table__status--inactive{background:var(--text-tertiary);opacity:.5}.template-table__usage{font-variant-numeric:tabular-nums;color:var(--text-secondary)}.template-table__actions{display:flex;gap:4px;opacity:0;transition:opacity var(--duration-fast)}.template-table tr:hover .template-table__actions{opacity:1}.template-table__action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xs);color:var(--text-tertiary);cursor:pointer;background:none;border:none;font-size:14px}.template-table__action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.template-table__action-btn--danger:hover{background:#ef44441a;color:var(--color-danger)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.template-editor-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn var(--duration-normal) ease}.template-editor{width:560px;max-height:90vh;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;overflow:hidden;animation:slideUp var(--duration-normal) ease}.template-editor__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-primary)}.template-editor__title{font-size:var(--font-lg);font-weight:600;color:var(--text-primary)}.template-editor__close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xs);color:var(--text-tertiary);cursor:pointer;background:none;border:none;font-size:16px}.template-editor__close:hover{background:var(--bg-hover);color:var(--text-primary)}.template-editor__body{padding:20px;overflow-y:auto;flex:1}.template-editor__field{margin-bottom:16px}.template-editor__label{display:block;font-size:var(--font-xs);font-weight:500;color:var(--text-secondary);margin-bottom:6px}.template-editor__label--required:after{content:" *";color:var(--color-danger)}.template-editor__input{width:100%;height:36px;padding:0 12px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-sm);transition:border-color var(--duration-fast);box-sizing:border-box}.template-editor__input:focus{outline:none;border-color:var(--accent)}.template-editor__input--error{border-color:var(--color-danger)}.template-editor__error{font-size:var(--font-xs);color:var(--color-danger);margin-top:4px}.template-editor__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.template-editor__textarea{width:100%;min-height:120px;max-height:200px;padding:10px 12px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-family:inherit;font-size:var(--font-sm);line-height:1.5;resize:vertical;transition:border-color var(--duration-fast);box-sizing:border-box}.template-editor__textarea:focus{outline:none;border-color:var(--accent)}.template-editor__variables{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.template-editor__variable-tag{font-family:monospace;font-size:var(--font-xs);color:var(--accent);background:#2aabee14;padding:2px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast)}.template-editor__variable-tag:hover{background:#2aabee29}.template-editor__preview{margin-top:12px;padding:10px 12px;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px dashed var(--border-primary)}.template-editor__preview-label{font-size:var(--font-xs);color:var(--text-tertiary);margin-bottom:6px}.template-editor__preview-text{font-size:var(--font-sm);color:var(--text-primary);white-space:pre-wrap;line-height:1.5}.template-editor__checkbox{display:flex;align-items:center;gap:8px;margin-top:16px;cursor:pointer}.template-editor__checkbox-input{width:16px;height:16px;accent-color:var(--accent)}.template-editor__checkbox-label{font-size:var(--font-sm);color:var(--text-primary)}.template-editor__footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--border-primary)}.template-editor__btn{height:36px;padding:0 20px;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:background var(--duration-fast);border:none}.template-editor__btn--cancel{background:transparent;color:var(--text-secondary);border:1px solid var(--border-primary)}.template-editor__btn--cancel:hover{background:var(--bg-hover)}.template-editor__btn--save{background:var(--accent);color:#fff}.template-editor__btn--save:hover{background:var(--accent-hover)}.template-editor__btn--save:disabled{opacity:.5;cursor:not-allowed}.category-manager{margin-top:32px}.category-manager__title{font-size:var(--font-lg);font-weight:600;color:var(--text-primary);margin-bottom:12px}.category-manager__list{display:flex;flex-direction:column;gap:2px}.category-manager__item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-md);transition:background var(--duration-fast)}.category-manager__item:hover{background:var(--bg-hover)}.category-manager__drag{color:var(--text-tertiary);cursor:grab;opacity:0;transition:opacity var(--duration-fast)}.category-manager__item:hover .category-manager__drag{opacity:1}.category-manager__name{flex:1;font-size:var(--font-sm);color:var(--text-primary)}.category-manager__count{font-size:var(--font-xs);color:var(--text-tertiary);margin-right:8px}.category-manager__btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xs);color:var(--text-tertiary);cursor:pointer;opacity:0;transition:opacity var(--duration-fast);background:none;border:none;font-size:14px}.category-manager__item:hover .category-manager__btn{opacity:1}.category-manager__btn:hover{background:var(--bg-hover);color:var(--text-primary)}.category-manager__btn--delete:hover{background:#ef44441a;color:var(--color-danger)}.category-manager__edit-input{flex:1;height:28px;padding:0 8px;border:1px solid var(--accent);border-radius:var(--radius-xs);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-sm)}.category-manager__add{display:flex;align-items:center;gap:6px;padding:8px 12px;color:var(--accent);font-size:var(--font-sm);cursor:pointer;border-radius:var(--radius-md)}.category-manager__add:hover{background:#2aabee0f}.template-item__badge{font-size:10px;font-weight:600;padding:1px 5px;border-radius:var(--radius-xs);flex-shrink:0;line-height:1.4}.template-item__badge--personal{background:#8b5cf61a;color:#8b5cf6}.template-item__badge--role{background:#3b82f61a;color:#3b82f6}.template-item__badge--attach{background:#6b72801a;color:var(--text-secondary)}.template-table__visibility{font-size:var(--font-xs);padding:2px 8px;border-radius:var(--radius-xs)}.template-table__visibility--all{background:#22c55e1a;color:#16a34a}.template-table__visibility--role{background:#3b82f61a;color:#3b82f6}.template-table__visibility--personal{background:#8b5cf61a;color:#8b5cf6}.template-editor__radio-group{display:flex;gap:16px;margin-top:4px}.template-editor__radio{display:flex;align-items:center;gap:6px;font-size:var(--font-sm);color:var(--text-primary);cursor:pointer}.template-editor__radio input[type=radio]{accent-color:var(--accent)}.template-editor__role-checkboxes{display:flex;gap:16px;margin-top:8px;padding:8px 12px;background:var(--bg-secondary);border-radius:var(--radius-md)}.template-editor__attachments{margin-top:12px}.template-editor__upload-area{border:2px dashed var(--border-primary);border-radius:var(--radius-md);padding:16px;text-align:center;cursor:pointer;transition:border-color var(--duration-fast),background var(--duration-fast)}.template-editor__upload-area:hover{border-color:var(--accent);background:#2aabee0a}.template-editor__upload-hint{font-size:var(--font-xs);color:var(--text-tertiary);margin-top:4px}.template-editor__file-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.template-editor__file-item{display:flex;align-items:center;gap:6px;padding:4px 8px;background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:var(--font-xs);color:var(--text-secondary)}.template-editor__file-remove{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:0;font-size:14px;line-height:1}.template-editor__file-remove:hover{color:var(--color-danger)}.typing-indicator{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);color:var(--text-tertiary);font-size:var(--font-xs);min-height:24px}.typing-indicator__dots{display:flex;gap:3px;align-items:center}.typing-indicator__dot{width:6px;height:6px;border-radius:50%;background:var(--text-tertiary);animation:typing-bounce 1.4s ease-in-out infinite}.typing-indicator__dot:nth-child(2){animation-delay:.2s}.typing-indicator__dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.typing-indicator__text{font-style:italic}.presence-dot{display:inline-block;border-radius:50%;flex-shrink:0;border:1.5px solid var(--bg-primary)}.presence-dot--online{background:#25d366}.presence-dot--offline{background:var(--text-tertiary)}.client-profile{position:absolute;top:0;right:0;bottom:0;width:var(--profile-width);background:var(--bg-primary);border-left:1px solid var(--border-primary);display:flex;flex-direction:column;overflow:hidden;z-index:var(--z-dropdown);transform:translate(100%);transition:transform var(--duration-slow) var(--easing)}.client-profile--open{transform:translate(0)}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg);height:var(--header-height);border-bottom:1px solid var(--border-primary);flex-shrink:0}.profile-header__title{font-size:var(--font-lg);font-weight:var(--font-weight-medium)}.profile-header__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);font-size:var(--font-xl);color:var(--text-secondary);cursor:pointer}.profile-header__close:hover{background:var(--bg-hover);color:var(--text-primary)}.profile-body{flex:1;overflow-y:auto;padding:var(--space-lg)}.profile-avatar{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding-bottom:var(--space-lg)}.profile-avatar__circle{width:80px;height:80px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--text-inverse);font-size:24px;font-weight:var(--font-weight-semibold)}.profile-avatar__circle--img{object-fit:cover}.profile-avatar__name{font-size:var(--font-xl);font-weight:var(--font-weight-semibold);text-align:center}.profile-info{display:flex;flex-direction:column;gap:var(--space-sm);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-primary)}.profile-info__row{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-sm)}.profile-info__icon{width:16px;text-align:center;flex-shrink:0;color:var(--text-tertiary)}.profile-info__value{color:var(--text-primary);word-break:break-all}.profile-info__value--copyable{cursor:pointer}.profile-info__value--copyable:hover{color:var(--accent)}.profile-info__label{color:var(--text-tertiary);font-size:var(--font-xs)}.profile-section{padding:var(--space-md) 0;border-bottom:1px solid var(--border-primary)}.profile-section:last-child{border-bottom:none}.profile-section__header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:var(--space-xs) 0;-webkit-user-select:none;user-select:none}.profile-section__title{font-size:var(--font-sm);font-weight:var(--font-weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.profile-section__chevron{font-size:var(--font-xs);color:var(--text-tertiary);transition:transform var(--duration-fast) var(--easing)}.profile-section__chevron--collapsed{transform:rotate(-90deg)}.profile-section__content{padding-top:var(--space-sm)}.profile-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.profile-tag{display:inline-flex;align-items:center;gap:4px;padding:2px var(--space-sm);border-radius:var(--radius-xl);background:var(--accent-light);color:var(--accent);font-size:var(--font-xs);font-weight:var(--font-weight-medium)}.profile-tag__remove{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:var(--radius-full);font-size:10px;cursor:pointer;color:var(--accent);opacity:.6}.profile-tag__remove:hover{opacity:1;background:#0000001a}.profile-tag--add{background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;border:1px dashed var(--border-secondary)}.profile-tag--add:hover{border-color:var(--accent);color:var(--accent)}.profile-tag-input{width:80px;border:none;background:transparent;font-size:var(--font-xs);color:var(--text-primary);outline:none;padding:2px var(--space-xs)}.profile-notes__textarea{width:100%;min-height:80px;max-height:160px;resize:vertical;border:1px solid var(--border-primary);border-radius:var(--radius-sm);padding:var(--space-sm);font-family:var(--font-family);font-size:var(--font-sm);line-height:var(--line-height);color:var(--text-primary);background:var(--bg-input);outline:none;transition:border-color var(--duration-fast) var(--easing)}.profile-notes__textarea:focus{border-color:var(--border-focus)}.profile-notes__textarea::placeholder{color:var(--text-tertiary)}.profile-notes__status{font-size:var(--font-xs);color:var(--text-tertiary);margin-top:var(--space-xs)}.profile-notes__status--saving{color:var(--color-warning)}.profile-notes__status--saved{color:var(--color-success)}.profile-channel{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0;font-size:var(--font-sm)}.profile-channel__badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;line-height:0;flex-shrink:0}.profile-channel__info{display:flex;flex-direction:column;gap:1px;min-width:0}.profile-channel__id{font-size:var(--font-xs);color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-channel__donor{font-size:var(--font-xs);color:var(--text-tertiary)}.profile-channel__status{width:6px;height:6px;border-radius:var(--radius-full);flex-shrink:0}.profile-channel__status--active{background:var(--badge-online)}.profile-channel__status--inactive{background:var(--badge-offline)}.profile-crm-link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-link);font-size:var(--font-sm);text-decoration:none;transition:background var(--duration-fast) var(--easing)}.profile-crm-link:hover{background:var(--bg-tertiary)}.profile-empty{color:var(--text-tertiary);font-size:var(--font-sm);font-style:italic}.deals-section{padding:0 var(--space-md)}.deals-section__header{font-size:var(--font-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.deals-section__list{display:flex;flex-direction:column;gap:var(--space-xs)}.deals-section__empty,.deals-section__error{font-size:var(--font-xs);color:var(--text-tertiary);padding:var(--space-sm) 0}.deals-section__error{color:var(--color-danger)}.deals-section__show-more{display:block;width:100%;background:none;border:none;color:var(--accent);font-size:var(--font-xs);cursor:pointer;padding:var(--space-sm) 0;text-align:center}.deals-section__show-more:hover{text-decoration:underline}.deal-card{padding:var(--space-sm);border-radius:var(--radius-sm);background:var(--bg-secondary);border-left:3px solid transparent}.deal-card--won{border-left-color:var(--color-success)}.deal-card--lost{border-left-color:var(--color-danger)}.deal-card__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-xs)}.deal-card__title{font-size:var(--font-xs);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.deal-card__stage{font-size:10px;padding:1px var(--space-xs);border-radius:var(--radius-xs);white-space:nowrap;font-weight:500}.deal-card__amount{font-size:var(--font-xs);color:var(--text-secondary);margin-top:2px}.deals-section__skeleton{display:flex;flex-direction:column;gap:var(--space-xs)}.deals-skeleton-card{height:44px;border-radius:var(--radius-sm);background:var(--bg-secondary);animation:deals-pulse 1.2s ease-in-out infinite}@keyframes deals-pulse{0%,to{opacity:.4}50%{opacity:.8}}.chat-header{display:flex;align-items:center;gap:var(--space-md);padding:0 var(--space-lg);height:var(--header-height);background:var(--bg-primary);border-bottom:1px solid var(--border-primary);flex-shrink:0}.chat-header__back{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;flex-shrink:0;margin-right:4px;font-size:var(--font-xl)}.chat-header__back:hover{background:var(--bg-hover);color:var(--text-primary)}.chat-header__avatar{width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--text-inverse);font-size:var(--font-sm);font-weight:var(--font-weight-semibold);flex-shrink:0}.chat-header__avatar-img{width:40px;height:40px;object-fit:cover;border-radius:var(--radius-full)}.chat-header__info{flex:1;min-width:0}.chat-header__name{font-size:var(--font-lg);font-weight:var(--font-weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header__meta{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-xs);color:var(--text-secondary)}.chat-header__channel-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;line-height:0}.chat-header__stage{padding:2px var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:var(--font-weight-medium);background:var(--bg-tertiary);color:var(--text-secondary)}.message-list{flex:1;overflow-y:auto;padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs)}.message-list__loader{display:flex;justify-content:center;padding:var(--space-md);color:var(--text-tertiary);font-size:var(--font-sm)}.message-list__empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:var(--font-md)}.date-divider{display:flex;align-items:center;justify-content:center;padding:var(--space-md) 0}.date-divider__label{padding:var(--space-xs) var(--space-md);border-radius:10px;background:var(--bg-date-badge);color:var(--text-date-badge);font-size:var(--font-xs);font-weight:var(--font-weight-medium);-webkit-user-select:none;user-select:none}.system-message{display:flex;justify-content:center;padding:var(--space-xs) 0}.system-message__text{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-lg);background:var(--bg-system-msg);color:var(--text-system-msg);font-size:var(--font-xs);font-style:italic;max-width:80%;text-align:center}.message-row{display:flex}.message-row--incoming{justify-content:flex-start}.message-row--outgoing{justify-content:flex-end}.message-bubble{display:flex;flex-direction:column;max-width:var(--bubble-max-width);min-width:80px;width:fit-content;animation:fadeIn var(--duration-normal) var(--easing)}.message-bubble--incoming .message-bubble__body{background:var(--bg-bubble-incoming);border-radius:var(--radius-xs) var(--radius-lg) var(--radius-lg) var(--radius-lg)}.message-bubble--outgoing .message-bubble__body{background:var(--bg-bubble-outgoing);border-radius:var(--radius-lg) var(--radius-xs) var(--radius-lg) var(--radius-lg)}.message-bubble--grouped{margin-top:-3px}.message-bubble--grouped .message-bubble__sender{display:none}.message-bubble--incoming.message-bubble--grouped .message-bubble__body,.message-bubble--outgoing.message-bubble--grouped .message-bubble__body{border-radius:var(--radius-lg)}.message-bubble--incoming.message-bubble--group-last .message-bubble__body{border-radius:var(--radius-lg) var(--radius-lg) var(--radius-lg) var(--radius-xs)}.message-bubble--outgoing.message-bubble--group-last .message-bubble__body{border-radius:var(--radius-lg) var(--radius-lg) var(--radius-xs) var(--radius-lg)}.message-bubble__body{padding:var(--space-sm) var(--space-md);position:relative;word-break:break-word;box-shadow:0 1px 1px #0000000a}.message-bubble__sender{font-size:var(--font-xs);font-weight:var(--font-weight-semibold);color:var(--accent);margin-bottom:2px}.message-bubble--outgoing .message-bubble__sender{display:none}.message-bubble__text{font-size:var(--font-base);line-height:var(--line-height);white-space:pre-wrap;word-break:break-word;color:var(--text-primary)}.message-bubble--outgoing .message-bubble__text{color:var(--text-bubble-outgoing)}.message-bubble__footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-xs);margin-top:2px}.message-bubble__time{font-size:10px;color:var(--text-tertiary);line-height:1}.message-bubble--outgoing .message-bubble__time{color:var(--text-bubble-outgoing-meta)}.message-bubble__status{font-size:var(--font-xs);display:inline-flex;align-items:center;line-height:1}.message-bubble__status--pending,.message-bubble__status--sent,.message-bubble__status--delivered{color:var(--text-tertiary)}.message-bubble__status--read{color:var(--accent)}.message-bubble__status--failed{color:var(--color-danger);cursor:pointer}.message-bubble__reply{padding:var(--space-xs) var(--space-sm);margin-bottom:var(--space-xs);border-left:3px solid var(--accent);border-radius:var(--radius-xs);background:var(--bg-reply);cursor:pointer}.message-bubble__reply:hover{background:var(--bg-reply-hover)}.message-bubble__reply-sender{font-size:var(--font-xs);font-weight:var(--font-weight-semibold);color:var(--accent)}.message-bubble__reply-text{font-size:var(--font-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px}.message-bubble__attachments{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-xs)}.message-bubble__attachment-image{max-width:260px;max-height:200px;border-radius:var(--radius-sm);object-fit:cover;cursor:pointer;transition:opacity var(--duration-fast)}.message-bubble__attachment-image:hover{opacity:.9}.message-bubble__lightbox{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;background:#000000d9;cursor:zoom-out}.message-bubble__lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-md)}.message-bubble__attachment-file{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:var(--bg-hover);border-radius:var(--radius-sm);text-decoration:none;color:inherit;transition:background var(--duration-fast)}.message-bubble__attachment-file:hover{background:var(--bg-secondary)}.message-bubble__attachment-file-icon{font-size:20px;flex-shrink:0}.message-bubble__attachment-file-info{display:flex;flex-direction:column;min-width:0}.message-bubble__attachment-file-name{font-size:var(--font-sm);font-weight:var(--font-weight-medium);color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.message-bubble__attachment-file-size{font-size:var(--font-xs);color:var(--text-tertiary)}.video-player{position:relative;max-width:320px;border-radius:10px;overflow:hidden;background:#000;line-height:0}.video-player__element{display:block;width:100%;max-height:360px;border-radius:10px}.video-player__fullscreen{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;background:#00000080;color:#fff;border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.video-player:hover .video-player__fullscreen{opacity:1}.video-player__preview{position:relative;max-width:320px;border-radius:10px;overflow:hidden;cursor:pointer}.video-player__thumb{display:block;width:100%;max-height:360px;object-fit:cover}.video-player__thumb-placeholder{width:240px;height:160px;background:var(--bg-tertiary)}.video-player__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.video-player__play-btn{width:48px;height:48px;border-radius:50%;background:#0000008c;position:relative}.video-player__play-btn:after{content:"";position:absolute;left:19px;top:13px;border-style:solid;border-width:11px 0 11px 18px;border-color:transparent transparent transparent #fff}.video-player__preview:hover .video-player__play-btn{background:#000000b3;transform:scale(1.05);transition:all .15s}.video-player__retry{width:48px;height:48px;border-radius:50%;background:#dc3232b3;color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px}.video-player__spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.video-player__duration{position:absolute;bottom:6px;right:6px;background:#000000a6;color:#fff;font-size:11px;padding:2px 6px;border-radius:4px;font-variant-numeric:tabular-nums}.message-bubble__attachment-audio{display:flex;align-items:center;gap:var(--space-sm);min-width:180px}.message-bubble__audio-player{width:100%;max-width:240px;height:32px}.message-bubble__attachment-audio-bar{display:flex;align-items:center;gap:var(--space-xs)}.message-bubble__attachment-audio-icon{font-size:18px}.message-bubble__attachment-audio-label{font-size:var(--font-sm);color:var(--text-secondary)}.message-bubble__attachment-audio-duration{font-size:var(--font-xs);color:var(--text-tertiary);margin-left:auto}.message-bubble__attachment-sticker{display:block;width:128px;height:128px;object-fit:contain}.message-bubble__attachment-sticker-fallback{font-size:var(--font-sm);color:var(--text-secondary)}.message-bubble__attachment-contact{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:var(--bg-secondary);border-radius:8px;min-width:160px}.message-bubble__attachment-contact-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.message-bubble__attachment-contact-avatar-placeholder{width:36px;height:36px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.message-bubble__attachment-contact-name{font-size:var(--font-sm);font-weight:500;color:var(--text-primary)}.message-input-wrapper{background:var(--bg-primary);border-top:1px solid var(--border-primary);flex-shrink:0}.message-input__reply-preview{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.message-input__reply-bar{width:3px;height:32px;background:var(--accent);border-radius:2px;flex-shrink:0}.message-input__reply-content{flex:1;min-width:0}.message-input__reply-name{font-size:var(--font-xs);font-weight:var(--font-weight-semibold);color:var(--accent)}.message-input__reply-text{font-size:var(--font-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-input__reply-close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-full);color:var(--text-tertiary);font-size:var(--font-lg);cursor:pointer;flex-shrink:0}.message-input__reply-close:hover{background:var(--bg-hover);color:var(--text-primary)}.message-input{display:flex;align-items:flex-end;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);min-height:var(--input-height)}.message-input__textarea{flex:1;resize:none;border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-sm) var(--space-md);font-family:var(--font-family);font-size:var(--font-md);line-height:var(--line-height);color:var(--text-primary);background:var(--bg-input);min-height:38px;max-height:150px;overflow-y:auto;outline:none;transition:border-color var(--duration-fast) var(--easing)}.message-input__textarea:focus{border-color:var(--border-focus)}.message-input__textarea::placeholder{color:var(--text-tertiary)}.message-input__send{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-full);background:var(--accent);color:var(--text-inverse);font-size:var(--font-xl);cursor:pointer;flex-shrink:0;transition:background var(--duration-fast) var(--easing)}.message-input__send:hover{background:var(--accent-hover)}.message-input__send:disabled{opacity:.4;cursor:default}[data-theme=dark] .message-input__send:disabled{opacity:.3}.message-input__attach-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-full);color:var(--text-tertiary);cursor:pointer;flex-shrink:0;transition:color var(--duration-fast),background var(--duration-fast);background:none;border:none;padding:0}.message-input__attach-btn:hover{color:var(--accent);background:var(--bg-hover)}.message-input__attach-icon{width:20px;height:20px;transform:rotate(-45deg)}.message-input__file-input{display:none}.message-input__attachments{display:flex;flex-wrap:wrap;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);border-bottom:1px solid var(--border-primary)}.message-input__attachment-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:var(--font-xs);color:var(--text-secondary);max-width:200px}.message-input__attachment-icon{font-size:14px;flex-shrink:0}.message-input__attachment-thumb{width:32px;height:32px;border-radius:var(--radius-xs);object-fit:cover;flex-shrink:0}.message-input__attachment-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message-input__attachment-size{color:var(--text-tertiary);flex-shrink:0}.message-input__attachment-remove{width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text-tertiary);cursor:pointer;flex-shrink:0;font-size:10px;background:none;border:none;padding:0}.message-input__attachment-remove:hover{background:var(--color-danger);color:#fff}.message-input__toast{position:absolute;top:-40px;left:50%;transform:translate(-50%);padding:var(--space-sm) var(--space-lg);background:var(--color-danger);color:#fff;border-radius:var(--radius-md);font-size:var(--font-sm);white-space:nowrap;z-index:var(--z-toast);animation:fadeIn var(--duration-normal) var(--easing)}.message-bubble--highlight .message-bubble__body{animation:highlightPulse 1.5s ease-out}@keyframes highlightPulse{0%{box-shadow:0 0 0 3px var(--accent);background-color:#2aabee26}to{box-shadow:0 0 0 0 transparent}}.media-gallery{position:fixed;inset:0;z-index:var(--z-modal);background:#000000eb;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:zoom-out}.media-gallery__toolbar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:12px 20px;z-index:1}.media-gallery__close{width:40px;height:40px;border-radius:50%;background:#ffffff26;color:#fff;border:none;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}.media-gallery__close:hover{background:#ffffff40}.media-gallery__counter{color:#fff;font-size:14px;background:#00000080;padding:4px 12px;border-radius:12px}.media-gallery__download{padding:6px 16px;border-radius:8px;background:#ffffff26;color:#fff;border:none;cursor:pointer;font-size:13px}.media-gallery__download:hover{background:#ffffff40}.media-gallery__content{display:flex;align-items:center;justify-content:center;gap:16px;max-width:95vw;max-height:85vh;cursor:default}.media-gallery__image{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:4px;transition:opacity .2s ease}.media-gallery__video-loading{color:#fff9;font-size:15px;padding:60px;display:flex;flex-direction:column;align-items:center;gap:16px}.media-gallery__video{max-width:90vw;max-height:85vh;border-radius:4px;outline:none}.media-gallery__nav{width:48px;height:48px;border-radius:50%;background:#ffffff26;color:#fff;border:none;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.media-gallery__nav:hover{background:#ffffff40}.message-bubble__photo-grid{display:grid!important;grid-template-columns:1fr 1fr;gap:2px;border-radius:8px;overflow:hidden}.message-bubble__photo-grid .message-bubble__attachment-image{width:100%;max-width:none;height:130px;border-radius:0}.file-view{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-hover);border-radius:8px;min-width:200px}.file-view__icon{font-size:24px;flex-shrink:0}.file-view__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.file-view__name{font-size:13px;font-weight:500;color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-view__size{font-size:11px;color:var(--text-tertiary)}.file-view__actions{display:flex;gap:4px;flex-shrink:0}.file-view__btn{padding:4px 10px;border-radius:6px;border:1px solid var(--border-primary);background:transparent;color:var(--accent);font-size:12px;cursor:pointer}.file-view__btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.file-view__btn:disabled{opacity:.5;cursor:wait}.document-preview{position:fixed;inset:0;z-index:var(--z-modal);background:#000000d9;display:flex;flex-direction:column}.document-preview__toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--bg-secondary);flex-shrink:0}.document-preview__filename{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-preview__actions{display:flex;gap:8px}.document-preview__download{padding:6px 14px;border-radius:6px;background:var(--accent);color:#fff;border:none;cursor:pointer;font-size:13px}.document-preview__close{width:32px;height:32px;border-radius:50%;background:var(--bg-hover);color:var(--text-primary);border:none;cursor:pointer;font-size:16px}.document-preview__content{flex:1;display:flex;align-items:center;justify-content:center;overflow:auto}.document-preview__pdf{width:100%;height:100%;border:none}.document-preview__image{max-width:90vw;max-height:85vh;object-fit:contain}.document-preview__video{max-width:90vw;max-height:85vh}.document-preview__audio-wrap{text-align:center;color:#fff}.document-preview__unsupported{text-align:center;color:#ffffffb3;padding:40px}.document-preview__unsupported button{margin-top:16px;padding:8px 20px;border-radius:8px;background:var(--accent);color:#fff;border:none;cursor:pointer;font-size:14px}.message-bubble--sticker .message-bubble__body{background:transparent!important;box-shadow:none!important;padding:4px!important}.sticker-view{width:128px;height:128px}.sticker-view img,.sticker-view svg{width:100%;height:100%;object-fit:contain}.sticker-view__fallback{font-size:var(--font-sm);color:var(--text-secondary)}.audio-player{display:flex;align-items:center;gap:8px;min-width:200px;height:44px;padding:0 4px}.audio-player__toggle{width:32px;height:32px;border-radius:50%;border:none;background:var(--accent);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.audio-player__toggle:hover{opacity:.85}.audio-player__progress{flex:1;height:4px;background:#0000001a;border-radius:2px;cursor:pointer;position:relative}.audio-player--outgoing .audio-player__progress{background:#ffffff4d}.audio-player__progress-filled{height:100%;background:var(--accent);border-radius:2px;position:relative;transition:width .1s linear}.audio-player--outgoing .audio-player__progress-filled{background:#fff}.audio-player__progress-filled:after{content:"";position:absolute;right:-5px;top:-3px;width:10px;height:10px;border-radius:50%;background:var(--accent)}.audio-player--outgoing .audio-player__progress-filled:after{background:#fff}.audio-player__time{font-size:11px;opacity:.7;flex-shrink:0;min-width:65px;text-align:right}.audio-player--unavailable{opacity:.5}.audio-player__icon{font-size:18px}.audio-player__label{font-size:var(--font-sm);color:var(--text-secondary)}.contact-view{display:flex;align-items:center;gap:12px;padding:10px 14px;min-width:200px}.contact-view__avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0}.contact-view__avatar img{width:100%;height:100%;object-fit:cover}.contact-view__avatar span{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#fff;font-weight:600;font-size:16px;border-radius:50%}.contact-view__info{display:flex;flex-direction:column;gap:4px;min-width:0}.contact-view__name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-view__action{align-self:flex-start;padding:4px 12px;border:1px solid var(--accent);border-radius:12px;background:transparent;color:var(--accent);font-size:12px;cursor:pointer}.contact-view__action:hover:not(:disabled){background:var(--accent);color:#fff}.contact-view__action:disabled{opacity:.5;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.admin-panel{display:flex;flex-direction:column;height:100%;background:var(--bg-primary)}.admin-header{display:flex;align-items:center;gap:var(--space-lg);padding:0 var(--space-xl);height:var(--header-height);border-bottom:1px solid var(--border-primary);flex-shrink:0}.admin-header__back{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-sm);color:var(--text-secondary);cursor:pointer}.admin-header__back:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-header__title{font-size:var(--font-xl);font-weight:var(--font-weight-semibold)}.admin-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-primary);padding:0 var(--space-xl);flex-shrink:0}.admin-tab{padding:var(--space-md) var(--space-lg);font-size:var(--font-md);font-weight:var(--font-weight-medium);color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:color var(--duration-fast) var(--easing),border-color var(--duration-fast) var(--easing)}.admin-tab:hover{color:var(--text-primary)}.admin-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.admin-content{flex:1;overflow-y:auto;padding:var(--space-xl)}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.admin-toolbar__title{font-size:var(--font-lg);font-weight:var(--font-weight-semibold)}.admin-table{width:100%;border-collapse:collapse;font-size:var(--font-sm)}.admin-table th{text-align:left;padding:var(--space-sm) var(--space-md);font-size:var(--font-xs);font-weight:var(--font-weight-semibold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-primary)}.admin-table td{padding:var(--space-md);border-bottom:1px solid var(--border-primary);color:var(--text-primary);vertical-align:middle}.admin-table tr:hover td{background:var(--bg-hover)}.admin-table__username{color:var(--text-secondary);font-size:var(--font-xs)}.admin-table__actions{display:flex;gap:var(--space-xs)}.admin-badge{display:inline-flex;align-items:center;padding:2px var(--space-sm);border-radius:var(--radius-xl);font-size:var(--font-xs);font-weight:var(--font-weight-medium)}.admin-badge--admin{background:#8b5cf61a;color:#8b5cf6}.admin-badge--senior{background:#3b82f61a;color:#3b82f6}.admin-badge--manager{background:#22c55e1a;color:#22c55e}.admin-badge--active{background:#22c55e1a;color:var(--color-success)}.admin-badge--inactive{background:#9ca3af1a;color:var(--text-tertiary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background var(--duration-fast) var(--easing),opacity var(--duration-fast) var(--easing);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--accent);color:var(--text-inverse)}.btn--primary:hover:not(:disabled){background:var(--accent-hover)}.btn--secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn--secondary:hover:not(:disabled){background:var(--bg-active)}.btn--danger{background:#ef44441a;color:var(--color-danger)}.btn--danger:hover:not(:disabled){background:#ef444433}.btn--ghost{background:transparent;color:var(--text-secondary);padding:var(--space-xs) var(--space-sm)}.btn--ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn--sm{padding:var(--space-xs) var(--space-sm);font-size:var(--font-xs)}.modal-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:modalFadeIn var(--duration-normal) var(--easing)}.modal-card{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:modalSlideIn var(--duration-normal) var(--easing)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border-primary)}.modal-header__title{font-size:var(--font-lg);font-weight:var(--font-weight-semibold)}.modal-header__close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-full);font-size:var(--font-md);color:var(--text-secondary);cursor:pointer}.modal-header__close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:var(--space-xl)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--border-primary)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.form-group{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-lg)}.form-group:last-child{margin-bottom:0}.form-label{font-size:var(--font-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary)}.form-input,.form-select{padding:var(--space-sm) var(--space-md);border:1px solid var(--border-primary);border-radius:var(--radius-sm);font-size:var(--font-md);font-family:var(--font-family);color:var(--text-primary);background:var(--bg-input);outline:none;transition:border-color var(--duration-fast) var(--easing)}.form-input:focus,.form-select:focus{border-color:var(--border-focus)}.form-input::placeholder{color:var(--text-tertiary)}.form-error{font-size:var(--font-xs);color:var(--color-danger)}.form-hint{font-size:var(--font-xs);color:var(--text-tertiary)}.admin-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-3xl);color:var(--text-tertiary);font-size:var(--font-md);text-align:center}.admin-placeholder__icon{font-size:48px;opacity:.3}.confirm-inline{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-xs)}.confirm-inline__text{color:var(--color-danger)}.donor-management{display:flex;flex-direction:column;gap:16px}.pool-health-card{background:var(--surface-secondary, #f8f9fa);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;padding:16px}.pool-health-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.pool-health-card__title{font-weight:600;font-size:14px}.pool-health-card__refresh{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-secondary, #666);padding:4px;border-radius:4px}.pool-health-card__refresh:hover{background:var(--hover-bg, #e8e8e8)}.pool-health-card__stats{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:12px}.pool-stat{font-size:13px;padding:2px 8px;border-radius:10px;font-weight:500}.pool-stat--active{background:#e6f4ea;color:#1e7e34}.pool-stat--paused{background:#fff3cd;color:#856404}.pool-stat--blocked{background:#f8d7da;color:#721c24}.pool-stat--warming{background:#d1ecf1;color:#0c5460}.pool-health-card__load{display:flex;flex-direction:column;gap:4px}.pool-load__label{font-size:13px;color:var(--text-secondary, #666)}.pool-load__bar{height:8px;background:var(--border-color, #e0e0e0);border-radius:4px;overflow:hidden}.pool-load__fill{height:100%;border-radius:4px;transition:width .3s ease}.pool-load--normal{background:#28a745}.pool-load--warning{background:#ffc107}.pool-load--critical{background:#dc3545}.pool-health-card__warning{margin-top:8px;padding:8px 12px;background:#f8d7da;color:#721c24;border-radius:4px;font-size:13px;font-weight:500}.donor-table-wrapper{overflow-x:auto}.donor-table{width:100%;border-collapse:collapse;font-size:13px}.donor-table th{text-align:left;padding:8px 10px;border-bottom:2px solid var(--border-color, #e0e0e0);font-weight:600;font-size:12px;color:var(--text-secondary, #666);white-space:nowrap;-webkit-user-select:none;user-select:none}.donor-th--sortable{cursor:pointer}.donor-th--sortable:hover{color:var(--text-primary, #333)}.donor-th__arrow{font-size:11px}.donor-table td{padding:8px 10px;border-bottom:1px solid var(--border-color, #e0e0e0);vertical-align:middle}.donor-row:hover{background:var(--hover-bg, #f5f5f5)}.donor-row__phone{font-family:monospace;font-size:13px;white-space:nowrap}.donor-row__num{text-align:center}.donor-row__usage{display:flex;flex-direction:column;gap:3px}.donor-row__date{white-space:nowrap;color:var(--text-secondary, #666);font-size:12px}.donor-row__actions{white-space:nowrap}.donor-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:12px;font-weight:500}.donor-badge--active{background:#e6f4ea;color:#1e7e34}.donor-badge--paused{background:#fff3cd;color:#856404}.donor-badge--blocked{background:#f8d7da;color:#721c24}.donor-badge--warming{background:#d1ecf1;color:#0c5460}.donor-load__bar{height:4px;background:var(--border-color, #e0e0e0);border-radius:2px;overflow:hidden;min-width:60px}.donor-load__fill{height:100%;border-radius:2px;transition:width .3s ease}.donor-load--normal{background:#28a745}.donor-load--warning{background:#ffc107}.donor-load--critical{background:#dc3545}.btn--sm{padding:3px 10px;font-size:12px;border-radius:4px}.btn--warning{background:#ffc107;color:#333;border:none;cursor:pointer}.btn--warning:hover{background:#e0a800}.btn--success{background:#28a745;color:#fff;border:none;cursor:pointer}.btn--success:hover{background:#218838}.donor-table__empty{text-align:center;padding:40px;color:var(--text-secondary, #666);font-size:14px}.donor-loading{padding:20px}.donor-error{display:flex;align-items:center;gap:12px;padding:20px;color:#721c24}.messenger{display:grid;grid-template-columns:var(--sidebar-width) var(--dialogs-width) 1fr;grid-template-rows:1fr;height:100%;overflow:hidden;container-type:inline-size;container-name:messenger}.messenger--collapsed{grid-template-columns:var(--sidebar-collapsed) var(--dialogs-width) 1fr}.messenger__sidebar{display:flex;flex-direction:column;background:var(--bg-sidebar);border-right:1px solid var(--border-primary);overflow:hidden;transition:width var(--duration-normal) var(--easing)}.messenger__dialogs{display:flex;flex-direction:column;background:var(--bg-primary);border-right:1px solid var(--border-primary);overflow:hidden}.messenger__chat{display:flex;flex-direction:column;background:var(--bg-chat);overflow:hidden;min-width:0;position:relative}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);height:var(--header-height);border-bottom:1px solid var(--border-primary);font-weight:var(--font-weight-medium)}.panel-placeholder{display:flex;align-items:flex-start;justify-content:center;padding:var(--space-2xl);color:var(--text-tertiary);font-size:var(--font-sm)}.panel-placeholder--center{align-items:center;flex:1;font-size:var(--font-md)}.ws-indicator{width:8px;height:8px;border-radius:var(--radius-full)}.ws-indicator--online{background:var(--badge-online)}.ws-indicator--reconnecting{background:var(--badge-awaiting);animation:pulse 1.5s infinite}.ws-indicator--offline{background:var(--badge-offline)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.messenger[data-breakpoint=lg]{grid-template-columns:var(--sidebar-collapsed) var(--dialogs-width-compact) 1fr}.messenger[data-breakpoint=md]{grid-template-columns:var(--dialogs-width-compact) 1fr}.messenger[data-breakpoint=md] .messenger__sidebar{display:none}.messenger[data-breakpoint=sm]{grid-template-columns:1fr}.messenger[data-breakpoint=sm] .messenger__sidebar,.messenger[data-breakpoint=sm] .messenger__dialogs{display:none}.messenger[data-breakpoint=sm].messenger--show-dialogs .messenger__dialogs{display:flex}.messenger[data-breakpoint=sm].messenger--show-dialogs .messenger__chat{display:none}.messenger[data-breakpoint=xs]{grid-template-columns:1fr}.messenger[data-breakpoint=xs] .messenger__sidebar,.messenger[data-breakpoint=xs] .messenger__dialogs{display:none}.messenger[data-breakpoint=xs].messenger--show-dialogs .messenger__dialogs{display:flex}.messenger[data-breakpoint=xs].messenger--show-dialogs .messenger__chat{display:none}.messenger[data-breakpoint=xs] .panel-header{height:40px;padding:0 var(--space-sm)}.messenger[data-breakpoint=sm] .client-profile--open,.messenger[data-breakpoint=xs] .client-profile--open{width:100%;left:0}@container messenger (max-width: 1199px){.messenger__sidebar{width:var(--sidebar-collapsed)}}@container messenger (max-width: 999px){.messenger__sidebar{display:none}}.shortcut-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal, 100)}.shortcut-help{background:var(--surface-primary, #fff);border-radius:12px;padding:20px 24px;min-width:340px;max-width:420px;box-shadow:0 8px 32px #0003}.shortcut-help__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.shortcut-help__title{font-size:16px;font-weight:600}.shortcut-help__close{background:none;border:none;font-size:16px;cursor:pointer;color:var(--text-secondary, #666);padding:4px}.shortcut-section{margin-bottom:14px}.shortcut-section__title{font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-secondary, #666);margin-bottom:8px;letter-spacing:.5px}.shortcut-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.shortcut-kbd{display:inline-block;padding:2px 6px;background:var(--surface-secondary, #f0f0f0);border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:12px;font-family:monospace;min-width:24px;text-align:center}.shortcut-desc{font-size:13px;color:var(--text-primary, #333)}.shortcut-help__footer{margin-top:12px;padding-top:10px;border-top:1px solid var(--border-color, #e0e0e0);font-size:12px;color:var(--text-secondary, #888);text-align:center}.conn-banner{position:fixed;top:0;left:0;right:0;z-index:var(--z-sticky, 20);padding:6px 16px;text-align:center;font-size:13px;font-weight:500;animation:conn-slide-down .2s ease-out}@keyframes conn-slide-down{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.conn-banner--warning{background:#fff3cd;color:#856404;border-bottom:1px solid #ffc107}.conn-banner--danger{background:#f8d7da;color:#721c24;border-bottom:1px solid #dc3545}.conn-banner--success{background:#d4edda;color:#155724;border-bottom:1px solid #28a745}
