.login-root{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f0f4f8;position:relative;overflow:hidden}.login-grid-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(37,99,235,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.04) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}.login-glow{display:none}.login-left{width:460px;flex-shrink:0;display:flex;flex-direction:column;justify-content:center;padding:3rem 3.5rem;position:relative;z-index:1;background:#1e3a8a;border-radius:20px 0 0 20px;min-height:580px}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:3rem}.login-logo{width:38px;height:38px;background:#ffffff26;border-radius:10px;display:flex;align-items:center;justify-content:center}.login-logo-inner{width:16px;height:16px;background:#fff;border-radius:4px;transform:rotate(45deg) scale(.85)}.login-brand-name{font-family:var(--font-display);font-weight:800;font-size:22px;color:#fff;letter-spacing:.1em}.login-brand-tag{font-size:11px;color:#ffffff80;letter-spacing:.18em;text-transform:uppercase;margin-top:1px}.login-headline{font-family:var(--font-display);font-weight:700;font-size:1.9rem;color:#fff;line-height:1.2;margin-bottom:1rem}.login-headline-accent{color:#93c5fd}.login-sub{font-size:14px;color:#fff9;line-height:1.7;max-width:340px;margin-bottom:2.5rem}.login-features{list-style:none;display:flex;flex-direction:column;gap:12px}.login-features li{display:flex;align-items:center;gap:10px;font-size:13px;color:#ffffff8c}.feat-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.login-divider{display:none}.login-right{width:400px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;z-index:1;background:#fff;border-radius:0 20px 20px 0;min-height:580px;box-shadow:var(--shadow-md)}.login-card{width:100%}.login-card-header{margin-bottom:1.75rem}.login-card-title{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--text-primary);margin-bottom:4px}.login-card-sub{font-size:13px;color:var(--text-muted)}.login-tabs{display:flex;background:var(--bg-base);border-radius:var(--radius-sm);padding:3px;gap:3px;margin-bottom:1.5rem;border:1px solid var(--border)}.login-tab{flex:1;padding:8px 10px;border:none;background:transparent;border-radius:4px;font-size:12px;color:var(--text-muted);cursor:pointer;transition:all .15s;font-weight:500}.login-tab.active{background:#fff;color:#2563eb;box-shadow:0 1px 3px #0000001a}.adm-notice{display:flex;align-items:center;gap:8px;background:#f5f3ff;border:1px solid #DDD6FE;border-radius:var(--radius-sm);padding:8px 12px;font-size:12px;color:#7c3aed;margin-bottom:1.25rem}.adm-dot{width:6px;height:6px;border-radius:50%;background:#7c3aed;flex-shrink:0}.login-field{margin-bottom:1rem}.login-label{display:block;font-size:12px;color:var(--text-secondary);font-weight:500;margin-bottom:6px}.login-input-wrap{position:relative}.login-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);display:flex;align-items:center;padding:0;transition:color .15s}.login-eye:hover{color:var(--text-secondary)}.login-forgot{text-align:right;margin-bottom:1.25rem;margin-top:-4px}.login-forgot a{font-size:12px;color:#2563eb;transition:color .15s}.login-forgot a:hover{color:#1d4ed8}.login-error{background:#fef2f2;border:1px solid #FECACA;border-radius:var(--radius-sm);padding:8px 12px;font-size:12px;color:#dc2626;margin-bottom:1rem}.login-submit{width:100%;padding:11px;background:#2563eb;border:none;border-radius:var(--radius-md);color:#fff;font-size:14px;font-weight:500;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 1px 2px #2563eb4d}.login-submit:hover:not(:disabled){background:#1d4ed8}.login-submit:disabled{opacity:.6;cursor:not-allowed}.spin{animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-hint{margin-top:1rem;padding:8px 12px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:11px;color:var(--text-muted);text-align:center}.login-hint strong{color:var(--text-secondary)}.login-footer{margin-top:1.25rem;text-align:center;font-size:11px;color:var(--text-muted)}.sidebar{width:220px;flex-shrink:0;height:100vh;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:1.1rem 1rem;border-bottom:1px solid var(--border)}.sidebar-logo{width:32px;height:32px;background:#2563eb;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-logo-inner{width:12px;height:12px;background:#fff;border-radius:3px;transform:rotate(45deg) scale(.85)}.sidebar-brand-name{font-family:var(--font-display);font-weight:800;font-size:16px;color:var(--text-primary);letter-spacing:.06em;line-height:1}.sidebar-brand-tag{font-size:10px;color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;margin-top:2px}.sidebar-nav{flex:1;padding:.875rem .75rem;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-md);font-size:13px;color:var(--text-secondary);transition:all .15s;position:relative}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-link.active{background:#eff6ff;color:#2563eb;font-weight:500}.sidebar-badge{margin-left:auto;font-size:10px!important;padding:2px 7px!important}.sidebar-footer{border-top:1px solid var(--border);padding:.75rem;display:flex;align-items:center;gap:8px}.sidebar-user{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.sidebar-avatar{width:30px;height:30px;border-radius:50%;background:#eff6ff;border:1px solid #BFDBFE;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#2563eb;flex-shrink:0}.sidebar-user-info{min-width:0}.sidebar-user-name{font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logout{width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.sidebar-logout:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.adm-root{display:flex;min-height:100vh}.adm-main{flex:1;overflow-y:auto;background:var(--bg-base)}.page-header{padding:1.75rem 2rem 0;margin-bottom:1.5rem}.page-title{font-family:var(--font-display);font-weight:700;font-size:1.3rem;color:var(--text-primary);margin-bottom:3px}.page-sub{font-size:13px;color:var(--text-muted)}.page-body{padding:0 2rem 2rem}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:1.75rem}.stat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-card)}.stat-label{font-size:11px;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;font-weight:500}.stat-value{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:4px}.stat-detail{font-size:12px;color:var(--text-muted)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem}.section-title{font-weight:600;font-size:14px;color:var(--text-primary)}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;padding:10px 16px;border-bottom:1px solid var(--border);background:#f8fafc}.data-table th:first-child{border-radius:var(--radius-sm) 0 0 0}.data-table th:last-child{border-radius:0 var(--radius-sm) 0 0}.data-table td{padding:12px 16px;font-size:13px;color:var(--text-secondary);border-bottom:1px solid #F1F5F9}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#f8fafc}.td-name{color:var(--text-primary)!important;font-weight:500}.table-action{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 10px;font-size:12px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.table-action:hover{border-color:#bfdbfe;color:#2563eb;background:#eff6ff}.table-action.danger:hover{border-color:#fecaca;color:#dc2626;background:#fef2f2}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.company-root{display:flex;min-height:100vh}.company-main-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-base)}.company-topbar{height:50px;border-bottom:1px solid var(--border);background:#fff;display:flex;align-items:center;gap:10px;padding:0 1.5rem;flex-shrink:0}.company-topbar-name{font-weight:600;font-size:14px;color:var(--text-primary)}.company-main{flex:1;overflow-y:auto}.contacts-root{display:flex;height:calc(100vh - 50px)}.contacts-list{width:300px;flex-shrink:0;border-right:1px solid var(--border);background:#fff;display:flex;flex-direction:column;overflow:hidden}.contacts-list-header{padding:1rem;border-bottom:1px solid var(--border)}.contacts-list-title{font-weight:600;font-size:14px;color:var(--text-primary);margin-bottom:10px}.contacts-search{width:100%;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 12px;color:var(--text-primary);font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s}.contacts-search:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb14}.contacts-search::placeholder{color:var(--text-muted)}.contacts-list-body{flex:1;overflow-y:auto}.contact-item{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-bottom:1px solid #F8FAFC;cursor:pointer;transition:background .12s}.contact-item:hover{background:var(--bg-hover)}.contact-item.selected{background:#eff6ff;border-right:2px solid #2563EB}.contact-avatar{width:36px;height:36px;border-radius:50%;background:#f1f5f9;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.contact-info{flex:1;min-width:0}.contact-name{font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:2px}.contact-preview{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.contact-time{font-size:11px;color:var(--text-muted)}.contact-unread{width:18px;height:18px;border-radius:50%;background:#2563eb;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}.chat-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#f8fafc}.chat-header{padding:13px 20px;border-bottom:1px solid var(--border);background:#fff;display:flex;align-items:center;gap:12px}.chat-body{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:10px}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);gap:8px}.msg-row{display:flex;gap:8px;align-items:flex-end}.msg-row.ai{justify-content:flex-start}.msg-row.client{justify-content:flex-end}.msg-bubble{max-width:70%;padding:9px 13px;border-radius:14px;font-size:13px;line-height:1.5}.msg-row.ai .msg-bubble{background:#fff;border:1px solid var(--border);color:var(--text-primary);border-bottom-left-radius:4px;box-shadow:var(--shadow-card)}.msg-row.client .msg-bubble{background:#2563eb;color:#fff;border-bottom-right-radius:4px}.msg-bubble.type-scheduled{border-color:#a7f3d0;background:#ecfdf5;color:#065f46}.msg-bubble.type-help{border-color:#fde68a;background:#fffbeb;color:#92400e}.msg-time{font-size:10px;color:var(--text-muted);margin-top:4px;padding:0 2px}.msg-label{font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px;padding:0 2px;color:var(--text-muted)}.history-root,.alerts-root{padding:1.75rem 2rem}.alert-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:10px;display:flex;gap:14px;align-items:flex-start;box-shadow:var(--shadow-card)}.alert-card.unresolved{border-left:3px solid #D97706}.alert-card.resolved{opacity:.5}.alert-icon{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.alert-body{flex:1;min-width:0}.alert-title{font-weight:500;font-size:14px;color:var(--text-primary);margin-bottom:4px}.alert-msg{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:8px}.alert-footer{display:flex;align-items:center;gap:10px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #F0F4F8;--bg-surface: #FFFFFF;--bg-card: #FFFFFF;--bg-hover: #F1F5F9;--border: #E2E8F0;--border-focus: #2563EB;--accent-cyan: #2563EB;--accent-violet: #7C3AED;--accent-green: #059669;--accent-amber: #D97706;--accent-red: #DC2626;--text-primary: #0F172A;--text-secondary:#475569;--text-muted: #94A3B8;--font-display: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-card: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08)}html,body,#root{height:100%;background:var(--bg-base);color:var(--text-primary);font-family:var(--font-body);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font-body)}input,textarea,select{font-family:var(--font-body)}.nx-btn-primary{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;background:#2563eb;border:none;border-radius:var(--radius-md);color:#fff;font-size:13px;font-weight:500;transition:all .15s;box-shadow:0 1px 2px #2563eb33}.nx-btn-primary:hover{background:#1d4ed8}.nx-btn-primary:active{transform:scale(.98)}.nx-btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;transition:all .15s}.nx-btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary);border-color:#cbd5e1}.nx-input{width:100%;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:9px 13px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s}.nx-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #2563eb1a}.nx-input::placeholder{color:var(--text-muted)}.nx-select{width:100%;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:9px 13px;color:var(--text-primary);font-size:14px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:border-color .15s}.nx-select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #2563eb1a}.nx-select option{background:#fff;color:var(--text-primary)}.nx-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.nx-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:500;letter-spacing:.02em}.nx-badge-cyan{background:#eff6ff;color:#2563eb;border:1px solid #BFDBFE}.nx-badge-green{background:#ecfdf5;color:#059669;border:1px solid #A7F3D0}.nx-badge-amber{background:#fffbeb;color:#d97706;border:1px solid #FDE68A}.nx-badge-red{background:#fef2f2;color:#dc2626;border:1px solid #FECACA}.nx-badge-violet{background:#f5f3ff;color:#7c3aed;border:1px solid #DDD6FE}.nx-badge-gray{background:#f8fafc;color:var(--text-secondary);border:1px solid var(--border)}.page-enter{animation:fadeSlide .25s ease both}@keyframes fadeSlide{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.dot-pulse{width:7px;height:7px;border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}
