.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.login-box{background:white;padding:40px;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-box h1{text-align:center;color:#333;margin-bottom:10px}.subtitle{text-align:center;color:#666;margin-bottom:30px}.form-group input{width:100%;padding:12px;font-size:16px}.login-btn{width:100%;padding:12px;font-size:16px;font-weight:700}.error-message{color:#ff4d4f;text-align:center;margin-bottom:15px;font-size:14px}.sms-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:1000}.sms-dialog{background:white;border-radius:8px;width:90%;max-width:500px;box-shadow:0 4px 20px #0000004d}.sms-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e8e8e8}.sms-dialog-header h2{margin:0;font-size:20px}.close-btn{background:none;border:none;font-size:28px;cursor:pointer;color:#999;padding:0;width:30px;height:30px;line-height:1}.close-btn:hover{color:#333}.sms-dialog-body{padding:20px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:700;color:#333}.recipient-info{display:flex;gap:10px;align-items:center;padding:10px;background:#f5f5f5;border-radius:4px}.recipient-info strong{color:#333}.recipient-info span{color:#666}.form-group select,.form-group textarea{width:100%;padding:10px;border:1px solid #d9d9d9;border-radius:4px;font-size:14px}.form-group textarea{resize:vertical;font-family:inherit}.char-count{float:right;font-weight:400;color:#666;font-size:12px}.message-type-info{display:flex;align-items:center;gap:10px;padding:10px;background:#f0f0f0;border-radius:4px}.type-badge{padding:4px 12px;background:#1890ff;color:#fff;border-radius:12px;font-size:12px;font-weight:700}.type-desc{font-size:12px;color:#666}.sms-dialog-footer{display:flex;justify-content:flex-end;gap:10px;padding:20px;border-top:1px solid #e8e8e8}.btn-cancel,.btn-send{padding:10px 24px;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s}.btn-cancel{background:#f5f5f5;color:#333}.btn-cancel:hover{background:#e8e8e8}.btn-send{background:#52c41a;color:#fff}.btn-send:hover{background:#389e0d}.automation-settings{padding:20px;max-width:1200px;margin:0 auto}.automation-settings h2{margin-bottom:20px;color:#262626}.automation-tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:2px solid #e8e8e8}.automation-tabs button{padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:15px;color:#666;transition:all .2s}.automation-tabs button:hover{color:#1890ff;background:#f5f5f5}.automation-tabs button.active{color:#1890ff;border-bottom-color:#1890ff;font-weight:700}.tab-content{animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.description{color:#666;font-size:14px;margin-bottom:20px;padding:12px;background:#f5f5f5;border-radius:4px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-bottom:15px}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#262626}.form-group input[type=text],.form-group input[type=tel],.form-group input[type=number],.form-group input[type=datetime-local],.form-group select,.form-group textarea{width:100%;padding:10px;border:1px solid #d9d9d9;border-radius:4px;font-size:14px;transition:all .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f5f5f5;cursor:not-allowed}.form-group small{display:block;margin-top:5px;color:#999;font-size:12px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-group{display:flex;flex-direction:column;gap:10px;padding:10px;background:#fafafa;border-radius:4px}.btn-primary{padding:10px 24px;background:#1890ff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s}.btn-primary:hover{background:#40a9ff;transform:translateY(-1px);box-shadow:0 2px 8px #1890ff4d}.schedule-table{width:100%;border-collapse:collapse;background:white}.schedule-table th,.schedule-table td{padding:12px;text-align:left;border-bottom:1px solid #f0f0f0}.schedule-table th{background:#fafafa;font-weight:700;color:#262626}.schedule-table tbody tr:hover{background:#f5f5f5}.no-data{text-align:center;color:#999;padding:40px!important}.task-type{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:700;display:inline-block}.task-type.call{background:#e6f7ff;color:#1890ff}.task-type.sms{background:#f6ffed;color:#52c41a}.status-badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:700;display:inline-block}.status-badge.pending{background:#fff7e6;color:#faad14}.status-badge.processing{background:#e6f7ff;color:#1890ff}.status-badge.completed{background:#f6ffed;color:#52c41a}.status-badge.failed{background:#fff1f0;color:#ff4d4f}.status-badge.cancelled{background:#f5f5f5;color:#8c8c8c}.btn-cancel{padding:6px 12px;background:#ff4d4f;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;transition:all .3s}.btn-cancel:hover{background:#ff7875}.btn-cancel.small{padding:4px 10px;font-size:11px}.agent-dashboard{min-height:100vh;background:#f5f5f5}.notice-container{position:fixed;top:16px;right:16px;z-index:2000;display:flex;flex-direction:column;gap:10px;max-width:420px}.notice-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:8px;color:#fff;box-shadow:0 4px 10px #00000026}.notice-item.info{background:#1890ff}.notice-item.success{background:#52c41a}.notice-item.warning{background:#faad14;color:#262626}.notice-item.error{background:#ff4d4f}.notice-close{border:none;background:transparent;color:inherit;font-size:18px;line-height:1;cursor:pointer;padding:0}.dashboard-header{background:white;padding:20px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center}.socket-debug-panel{margin:12px auto 0;max-width:1400px;background:#fffbe6;border:1px solid #ffe58f;border-radius:6px;padding:10px 12px;display:flex;align-items:center;gap:10px}.socket-debug-actions{display:flex;gap:8px}.user-info{display:flex;align-items:center;gap:15px}.automation-btn{padding:8px 16px;background:#52c41a;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .3s}.automation-btn:hover{background:#73d13d}.logout-btn{padding:8px 16px;background:#ff4d4f;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .3s}.logout-btn:hover{background:#ff7875}.status-indicator{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:700}.status-indicator.connected{background:#52c41a;color:#fff}.status-indicator.disconnected{background:#ff4d4f;color:#fff}.dashboard-content{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:20px;max-width:1400px;margin:0 auto}.task-list{max-height:600px;overflow-y:auto}.task-item{display:flex;justify-content:space-between;align-items:center;padding:15px;border:1px solid #e8e8e8;border-radius:4px;margin-bottom:10px}.task-info strong{display:block;margin-bottom:5px}.task-info span{color:#666;font-size:14px}.call-control{text-align:center}.call-status{margin:20px 0;font-size:18px}.status-idle{color:#666}.status-dialing{color:#1890ff}.status-active{color:#52c41a}.status-ended{color:#999}.current-call-info{background:#f0f0f0;padding:15px;border-radius:4px;margin:15px 0}.customer-info .info-row{display:flex;padding:10px 0;border-bottom:1px solid #f0f0f0}.customer-info .info-row label{font-weight:700;width:100px}.manual-call{display:flex;gap:10px;margin-top:15px}.manual-call input{flex:1;padding:10px;border:1px solid #d9d9d9;border-radius:4px;font-size:14px}.file-upload{display:flex;align-items:center;gap:15px;margin:15px 0}.upload-btn{padding:10px 20px;background:#1890ff;color:#fff;border-radius:4px;cursor:pointer;transition:background .3s}.upload-btn:hover{background:#40a9ff}.file-info{color:#666;font-size:14px}.auto-dial-control{display:flex;align-items:center;gap:15px;margin:15px 0;padding:15px;background:#f0f0f0;border-radius:4px}.dial-progress{font-weight:700;color:#1890ff}.phone-list{max-height:400px;overflow-y:auto;margin-top:15px}.phone-item{display:flex;justify-content:space-between;align-items:center;padding:12px;border:1px solid #e8e8e8;border-radius:4px;margin-bottom:8px;transition:all .3s}.phone-item.current{background:#e6f7ff;border-color:#1890ff}.phone-item.completed{background:#f6ffed;border-color:#52c41a;opacity:.7}.phone-info{flex:1}.phone-info strong{display:block;margin-bottom:4px;color:#262626}.phone-info span{color:#666;font-size:14px}button.small{padding:6px 12px;font-size:13px}.phone-actions{display:flex;gap:8px}.sms-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.sms-header h2{display:flex;align-items:center;gap:8px;margin:0}.unread-badge{background:#ff4d4f;color:#fff;padding:2px 8px;border-radius:10px;font-size:12px;font-weight:700;animation:bounce 1s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.total-count{color:#999;font-size:14px;font-weight:400}.sms-actions{display:flex;gap:8px}.empty-message{text-align:center;padding:40px 20px;color:#999}.empty-message p{margin:0;font-size:14px}.received-messages,.sent-messages{max-height:500px;overflow-y:auto;margin-top:15px}.message-item{padding:15px;border:1px solid #e8e8e8;border-radius:4px;margin-bottom:10px;background:#fff;transition:all .3s;cursor:pointer}.message-item.unread{background:#e6f7ff;border-color:#1890ff;border-left:4px solid #1890ff}.message-item.sent{cursor:default}.message-item.sent.success{border-left:4px solid #52c41a}.message-item.sent.failed{border-left:4px solid #ff4d4f;background:#fff1f0}.message-item:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #f0f0f0}.message-sender{display:flex;align-items:center;gap:8px}.message-header strong{color:#1890ff;font-size:15px}.new-badge{background:#ff4d4f;color:#fff;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:700}.status-badge{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700}.status-badge.success{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}.status-badge.failed{background:#fff1f0;color:#ff4d4f;border:1px solid #ffccc7}.message-time{color:#999;font-size:12px}.message-content{color:#262626;font-size:14px;line-height:1.6;word-break:break-word;margin-bottom:12px;padding:10px;background:#fafafa;border-radius:4px}.message-actions{display:flex;gap:8px;justify-content:flex-end}button.secondary{background:#8c8c8c;color:#fff}button.secondary:hover{background:#595959}.call-history{max-height:500px;overflow-y:auto;margin-top:15px}.call-record{padding:15px;border:1px solid #e8e8e8;border-radius:4px;margin-bottom:10px;background:#fff;transition:all .3s}.call-record.outgoing{border-left:4px solid #1890ff}.call-record.incoming{border-left:4px solid #52c41a}.call-record:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}.call-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #f0f0f0}.call-info{display:flex;align-items:center;gap:8px}.call-type-badge{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700}.call-type-badge.outgoing{background:#e6f7ff;color:#1890ff;border:1px solid #91d5ff}.call-type-badge.incoming{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}.call-header strong{color:#262626;font-size:15px}.call-time{color:#999;font-size:12px}.call-details{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:8px;background:#fafafa;border-radius:4px}.customer-name{color:#595959;font-size:14px}.call-duration{color:#8c8c8c;font-size:13px;font-weight:500}.call-actions{display:flex;gap:8px;justify-content:flex-end}.incoming-call-alert{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;animation:pulse 2s infinite}.incoming-call-alert h2{color:#fff;margin-bottom:15px}@keyframes pulse{0%,to{box-shadow:0 0 #667eeab3}50%{box-shadow:0 0 0 20px #667eea00}}.incoming-call-info{text-align:center}.caller-number{font-size:24px;font-weight:700;margin:15px 0;letter-spacing:2px}.call-time{font-size:14px;opacity:.9;margin-bottom:15px}.dismiss-btn{padding:10px 30px;background:white;color:#667eea;border:none;border-radius:4px;cursor:pointer;font-weight:700;transition:all .3s}.dismiss-btn:hover{background:#f0f0f0;transform:scale(1.05)}.license-management{padding:18px 20px 24px;max-width:1440px;min-width:1280px;margin:0 auto}.license-management h1{margin:0 0 14px;font-size:32px;font-weight:700;color:#243447;letter-spacing:-.3px}.license-management .info-banner{background:#e6f7ff;border:1px solid #91d5ff;border-radius:8px;padding:12px 16px;margin-bottom:14px;color:#0050b3;font-size:14px;line-height:1.5}.license-management .info-banner strong{margin-right:8px}.license-management .management-layout{display:grid;grid-template-columns:320px 1fr;gap:16px;margin-top:14px;min-width:1240px}.license-management .user-list-panel{background:white;border-radius:10px;border:1px solid #e7edf5;padding:16px;box-shadow:0 2px 10px #1228460d}.license-management .user-list-panel h2{margin:0 0 10px;font-size:22px;font-weight:700;color:#2a3a4d}.license-management .user-list{margin-top:10px;max-height:70vh;overflow-y:auto}.license-management .user-item{padding:12px;border:1px solid #e7edf5;border-radius:8px;margin-bottom:8px;cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.license-management .user-item:hover{background:#f7fbff;border-color:#bfdcff}.license-management .user-item.selected{border-color:#1890ff;background:#eef6ff;box-shadow:0 0 0 2px #1890ff1a}.license-management .user-name{font-weight:600;margin-bottom:6px;color:#293a4d}.license-management .user-status{display:flex;gap:10px;align-items:center;font-size:12px}.license-management .badge{padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}.license-management .badge.active{background:#d4edda;color:#155724}.license-management .badge.inactive{background:#f8d7da;color:#721c24}.license-management .badge.approval-approved{background:#d4edda;color:#155724}.license-management .badge.approval-pending{background:#fff3cd;color:#856404}.license-management .badge.approval-rejected{background:#f8d7da;color:#721c24}.license-management .days-remaining{color:#5f6f85;font-weight:500}.license-management .detail-panel{display:flex;flex-direction:column;gap:14px}.license-management .card{background:#fff;border:1px solid #e7edf5;border-radius:10px;box-shadow:0 2px 10px #1228460d;padding:16px;overflow-x:auto}.license-management .card h2{margin:0 0 12px;font-size:22px;font-weight:700;color:#2a3a4d}.license-management .license-settings .form-group,.license-management .credentials-settings .form-group{margin-bottom:15px}.license-management .license-settings label,.license-management .credentials-settings label{display:block;margin-bottom:6px;font-weight:600;color:#42566d}.license-management .license-settings input,.license-management .license-settings select,.license-management .credentials-settings input{width:100%;min-height:36px;padding:0 12px;border:1px solid #cdd9e8;border-radius:8px;background:#fff;font-size:14px;line-height:1;color:#243447;box-sizing:border-box}.license-management .license-settings input:focus,.license-management .license-settings select:focus,.license-management .credentials-settings input:focus{outline:none;border-color:#40a9ff;box-shadow:0 0 0 3px #1890ff1f}.license-management .device-list table{width:100%;min-width:980px;border-collapse:collapse;margin-top:10px}.license-management .device-list th,.license-management .device-list td{padding:10px 12px;text-align:left;border-bottom:1px solid #eef2f6;line-height:1.4}.license-management .device-list th{background:#f8fafd;color:#42566d;font-weight:600;font-size:13px}.license-management .device-list .imei{font-family:monospace;font-size:12px}.license-management .no-devices{text-align:center;color:#8292a8;padding:40px}.license-management .form-group small{display:block;margin-top:4px;color:#7a8ba1;font-size:12px}.license-management button{min-height:36px;padding:0 16px;border:none;border-radius:8px;font-size:13px;font-weight:600;line-height:1;cursor:pointer;transition:background .2s ease,box-shadow .2s ease}.license-management button.small{min-height:28px;padding:0 10px;font-size:12px;line-height:1}.license-management .credentials-settings{background:white}.license-management button.primary{background:#1890ff;color:#fff}.license-management button.primary:hover{background:#40a9ff}.license-management button.success{background:#52c41a;color:#fff}.license-management button.success:hover{background:#73d13d}.license-management button.secondary{background:#f2f5f9;color:#38495d;border:1px solid #ccd7e4}.license-management button.secondary:hover{background:#e5edf6}.license-management button.warning{background:#faad14;color:#fff}.license-management button.warning:hover{background:#ffc53d}.license-management .credentials-settings input:disabled{background:#f4f7fb;color:#6f8096;cursor:not-allowed}.unified-device-management{padding:18px 20px 24px;max-width:1500px;min-width:1280px;margin:0 auto}.unified-device-management h1{margin:0 0 14px;color:#243447;font-size:32px;font-weight:700;letter-spacing:-.3px}.unified-device-management .info-banner{background:#e6f7ff;border:1px solid #91d5ff;border-radius:8px;padding:12px 16px;margin-bottom:14px;color:#0050b3;font-size:14px}.unified-device-management .management-layout{display:grid;grid-template-columns:320px 1fr;gap:16px;min-width:1240px}.unified-device-management .user-list-panel{background:white;border-radius:10px;border:1px solid #e7edf5;padding:16px;box-shadow:0 2px 10px #1228460d;height:fit-content;max-height:80vh;overflow-y:auto}.unified-device-management .user-list-panel h2{margin:0 0 10px;font-size:22px;font-weight:700;color:#2a3a4d}.unified-device-management .user-category{margin-bottom:25px}.unified-device-management .category-title{font-size:14px;font-weight:700;color:#4a5d74;margin-bottom:10px;padding:9px 12px;background:#f4f8fd;border-radius:8px;border-left:4px solid #1890ff}.unified-device-management .user-list{margin-top:10px}.unified-device-management .user-item{padding:12px;border:1px solid #e7edf5;border-radius:8px;margin-bottom:8px;cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.unified-device-management .user-item:hover{background:#f7fbff;border-color:#1890ff}.unified-device-management .user-item.selected{border-color:#1890ff;background:#eef6ff;box-shadow:0 0 0 2px #1890ff1a}.unified-device-management .user-name{font-weight:600;margin-bottom:4px;font-size:15px;color:#293a4d}.unified-device-management .user-username{font-size:11px;color:#7d8ea5;margin-bottom:6px}.unified-device-management .user-type-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:600;margin-bottom:6px}.unified-device-management .user-type-badge.pc-web{background:#e6f7ff;color:#0050b3;border:1px solid #91d5ff}.unified-device-management .user-type-badge.sip-phone{background:#f6ffed;color:#389e0d;border:1px solid #b7eb8f}.unified-device-management .user-status{margin-top:6px}.unified-device-management .detail-panel{display:flex;flex-direction:column;gap:14px}.unified-device-management .card{background:white;border-radius:10px;border:1px solid #e7edf5;padding:16px;box-shadow:0 2px 10px #1228460d;overflow-x:auto}.unified-device-management .card h2{margin:0 0 12px;color:#2a3a4d;font-size:22px;font-weight:700}.unified-device-management .connection-status{background:#eef5ff;border-color:#cfe3ff;color:#2a3a4d}.unified-device-management .connection-status h2{color:#2a3a4d}.unified-device-management .status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-top:15px}.unified-device-management .status-item{background:#fff;border:1px solid #dce9f9;padding:12px;border-radius:8px}.unified-device-management .status-label{font-size:13px;margin-bottom:6px;color:#5f6f85}.unified-device-management .status-indicator{font-size:15px;font-weight:600}.unified-device-management .status-indicator.online{color:#52c41a}.unified-device-management .status-indicator.offline{color:#ff4d4f}.unified-device-management .device-section table{width:100%;min-width:1600px;border-collapse:collapse;margin-top:10px}.unified-device-management .device-section th,.unified-device-management .device-section td{padding:10px 12px;text-align:left;border-bottom:1px solid #eef2f6;line-height:1.4}.unified-device-management .device-section th{background:#f8fafd;color:#42566d;font-weight:600;font-size:13px}.unified-device-management .device-section tr:hover{background:#f7fbff}.unified-device-management .imei{font-family:monospace;font-size:12px}.unified-device-management .meta-grid-cell{display:flex;flex-direction:column;gap:4px;min-width:210px;font-size:12px}.unified-device-management .meta-grid-cell strong{color:#42566d}.unified-device-management .no-devices{text-align:center;color:#7d8ea5;padding:40px}.unified-device-management .badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600}.unified-device-management .badge.active{background:#d4edda;color:#155724}.unified-device-management .badge.inactive{background:#f8d7da;color:#721c24}.unified-device-management .badge.approval-approved{background:#d4edda;color:#155724}.unified-device-management .badge.approval-pending{background:#fff3cd;color:#856404}.unified-device-management .badge.approval-rejected{background:#f8d7da;color:#721c24}.unified-device-management button{min-height:36px;padding:0 16px;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;line-height:1;transition:background .2s ease,box-shadow .2s ease}.unified-device-management button.small{min-height:28px;padding:0 10px;font-size:12px;line-height:1}.unified-device-management button.primary{background:#2196f3;color:#fff}.unified-device-management button.success{background:#4caf50;color:#fff}.unified-device-management button.danger{background:#f44336;color:#fff}.unified-device-management button.warning{background:#faad14;color:#fff}.unified-device-management button:hover{opacity:.95}.unified-device-management button:active{opacity:1}.unified-device-management .usage-info{background:#f8fbff}.unified-device-management .usage-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin-top:15px}.unified-device-management .usage-item{background:white;padding:14px;border-radius:8px;border:1px solid #e5edf6}.unified-device-management .usage-item h3{font-size:15px;margin-bottom:8px;color:#1890ff}.unified-device-management .usage-item p{font-size:13px;color:#55667b;line-height:1.55;margin-bottom:8px}.unified-device-management .usage-note{font-size:12px;color:#7d8ea5;font-style:italic}.unified-device-management code{font-family:Courier New,monospace;background:#f3f7fc;padding:2px 6px;border-radius:4px;color:#3e4f65}.sip-monitoring{padding:18px 20px 24px;max-width:1500px;min-width:1280px;margin:0 auto}.sip-monitoring .monitoring-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px;flex-wrap:wrap}.sip-monitoring .monitoring-header h2{margin:0;color:#243447;font-size:32px;font-weight:700;letter-spacing:-.2px}.sip-monitoring .header-controls{display:flex;gap:12px;align-items:center}.sip-monitoring .auto-refresh-toggle{display:flex;align-items:center;gap:10px;min-height:36px;cursor:pointer;-webkit-user-select:none;user-select:none}.sip-monitoring .auto-refresh-toggle input[type=checkbox]{width:16px;height:16px;margin:0;cursor:pointer}.sip-monitoring .auto-refresh-toggle span{font-size:13px;color:#5f6f85;font-weight:500;line-height:1}.sip-monitoring .btn-refresh{min-height:36px;padding:0 16px;background:#1890ff;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;line-height:1;transition:background .2s ease}.sip-monitoring .btn-refresh:hover{background:#40a9ff}.sip-monitoring .sip-stats-grid{display:grid;grid-template-columns:repeat(4,minmax(170px,1fr));gap:12px;margin-bottom:14px;min-width:1240px}.sip-monitoring .sip-stat-card{background:white;padding:12px 14px;border-radius:10px;border:1px solid #e7edf5;box-shadow:0 2px 10px #1228460d;display:flex;align-items:center;gap:10px;transition:border-color .2s ease,box-shadow .2s ease}.sip-monitoring .sip-stat-card:hover{border-color:#cde3ff}.sip-monitoring .sip-stat-card.online{border-left:4px solid #52c41a}.sip-monitoring .sip-stat-card.offline{border-left:4px solid #ff4d4f}.sip-monitoring .sip-stat-card.active{border-left:4px solid #faad14}.sip-monitoring .stat-icon{font-size:28px}.sip-monitoring .stat-info{flex:1}.sip-monitoring .stat-label{font-size:13px;color:#607086;margin-bottom:4px;font-weight:500}.sip-monitoring .stat-value{font-size:34px;font-weight:700;color:#1f2e3d;line-height:1.1}.sip-monitoring .card{background:#fff;border:1px solid #e7edf5;border-radius:10px;box-shadow:0 2px 10px #1228460d;padding:14px;margin-bottom:12px;overflow-x:auto}.sip-monitoring .card h3{margin:0 0 10px;color:#2a3a4d;font-size:22px;font-weight:700}.sip-monitoring .sip-table{width:100%;min-width:1080px;border-collapse:collapse;background:white}.sip-monitoring .sip-table th,.sip-monitoring .sip-table td{padding:10px 12px;text-align:left;border-bottom:1px solid #eef2f6;line-height:1.4}.sip-monitoring .sip-peer-table th:nth-child(1),.sip-monitoring .sip-peer-table td:nth-child(1),.sip-monitoring .sip-peer-table th:nth-child(5),.sip-monitoring .sip-peer-table td:nth-child(5),.sip-monitoring .sip-peer-table th:nth-child(6),.sip-monitoring .sip-peer-table td:nth-child(6){text-align:right}.sip-monitoring .sip-table th{background:#f8fafd;font-weight:600;color:#42566d;font-size:13px;white-space:nowrap}.sip-monitoring .sip-table tbody tr{transition:background .2s}.sip-monitoring .sip-table tbody tr:hover{background:#f7fbff}.sip-monitoring .sip-table tbody tr.online-row{background:#f6ffed}.sip-monitoring .sip-table tbody tr.online-row:hover{background:#d9f7be}.sip-monitoring .sip-table tbody tr.offline-row{background:#fff1f0}.sip-monitoring .sip-table tbody tr.offline-row:hover{background:#ffccc7}.sip-monitoring .sip-table tbody tr.active-call-row{background:#fffbe6;animation:pulse-call 3s infinite}@keyframes pulse-call{0%,to{background:#fffbe6}50%{background:#fff7cc}}.sip-monitoring .no-data{text-align:center;color:#7d8ea5;padding:40px!important}.sip-monitoring .latency{color:#52c41a;font-weight:600}.sip-monitoring .status-badge{padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600;display:inline-block}.sip-monitoring .status-badge.online{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}.sip-monitoring .status-badge.offline{background:#fff1f0;color:#ff4d4f;border:1px solid #ffccc7}.sip-monitoring .status-badge.calling{background:#fffbe6;color:#faad14;border:1px solid #ffe58f}.sip-monitoring code{font-family:Courier New,monospace;background:#f3f7fc;padding:2px 6px;border-radius:4px;font-size:12px;color:#3e4f65}.manager-dashboard{min-height:100vh;min-width:1280px;background:#f6f8fb}.manager-dashboard .dashboard-header{position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(90deg,#1890ff 0%,#40a9ff 100%);color:#fff;padding:20px 28px;box-shadow:0 6px 18px #1890ff24;border-bottom:none}.manager-dashboard .dashboard-header h1{font-size:32px;font-weight:700;letter-spacing:-.3px;margin:0;color:#fff}.manager-dashboard .dashboard-header .user-info{font-size:15px;color:#fff;background:rgba(255,255,255,.2);padding:8px 16px;border-radius:18px;font-weight:500}.manager-dashboard .manager-nav{display:flex;flex-wrap:nowrap;gap:8px;background:white;border-bottom:1px solid #e6ecf3;padding:10px 20px}.manager-dashboard .manager-nav button{min-height:40px;padding:0 16px;background:transparent;border:1px solid transparent;border-bottom:2px solid transparent;border-radius:8px 8px 0 0;cursor:pointer;font-size:15px;font-weight:500;line-height:1;color:#5f6f85;transition:all .2s}.manager-dashboard .manager-nav button:hover{color:#1890ff;background:#f5f9ff}.manager-dashboard .manager-nav button.active{color:#1890ff;border-bottom-color:#1890ff;border-left-color:#d9e8ff;border-right-color:#d9e8ff;border-top-color:#d9e8ff;font-weight:600;background:#f7fbff}.manager-dashboard .dashboard-content{display:block;padding:18px 20px 26px;max-width:1440px;min-width:1240px;margin:0 auto}.manager-dashboard .stats-grid{display:grid;grid-template-columns:repeat(4,minmax(170px,1fr));gap:14px;margin-bottom:14px;align-items:start}.manager-dashboard .stat-card{background:white;padding:12px 14px;border-radius:10px;border:1px solid #e9eef5;box-shadow:0 2px 10px #0f233c0d;text-align:center;height:auto}.manager-dashboard .stat-card h3{color:#607086;font-size:17px;font-weight:600;margin:0 0 6px}.manager-dashboard .stat-value{font-size:40px;font-weight:700;color:#1890ff;line-height:1.08}.manager-dashboard .card{background:#fff;border:1px solid #e9eef5;border-radius:10px;box-shadow:0 2px 10px #0f233c0a;padding:16px;overflow-x:auto}.manager-dashboard .card h2{margin:0 0 14px;font-size:22px;font-weight:700;color:#243447;letter-spacing:-.2px}.manager-dashboard .agent-table{width:100%;min-width:1120px;border-collapse:collapse;background:white}.manager-dashboard .agent-table th,.manager-dashboard .agent-table td{padding:10px 12px;text-align:left;border-bottom:1px solid #eef2f6;line-height:1.4}.manager-dashboard .agent-table th{background:#f8fafd;color:#435265;font-size:13px;font-weight:600;white-space:nowrap}.manager-dashboard .agent-table td{vertical-align:middle;color:#2f3f52}.manager-dashboard .agent-table th:nth-child(1),.manager-dashboard .agent-table td:nth-child(1){text-align:right}.manager-dashboard .agent-table tbody tr{transition:background .2s}.manager-dashboard .agent-table tbody tr:hover{background:#f6fbff}.manager-dashboard .status-badge{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}.manager-dashboard .status-badge.online{background:#d4edda;color:#155724}.manager-dashboard .status-badge.busy{background:#fff3cd;color:#856404}.manager-dashboard .status-badge.offline{background:#f8d7da;color:#721c24}.manager-dashboard .status-badge.active{background:#d4edda;color:#155724}.manager-dashboard .status-badge.inactive{background:#f8d7da;color:#721c24}.manager-dashboard .agent-credentials-notice{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:10px 12px;margin-bottom:12px;color:#856404;font-size:13px;font-weight:500}.manager-dashboard .password-field{font-family:Courier New,monospace;background:#f5f5f5;padding:4px 8px;border-radius:4px;color:#d32f2f;font-weight:700;font-size:13px}.manager-dashboard .password-edit{display:flex;gap:5px}.manager-dashboard .password-input{min-height:36px;padding:0 10px;border:1px solid #9ec7ff;border-radius:4px;font-size:13px;line-height:1;font-family:Courier New,monospace;width:150px}.manager-dashboard .password-input:focus{outline:none;border-color:#40a9ff;box-shadow:0 0 0 3px #1890ff24}.manager-dashboard .action-buttons{display:flex;gap:5px}.manager-dashboard .btn-edit,.manager-dashboard .btn-save,.manager-dashboard .btn-cancel{min-height:36px;padding:0 16px;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;line-height:1;transition:background .2s ease,box-shadow .2s ease}.manager-dashboard .btn-edit{background:#1890ff;color:#fff}.manager-dashboard .btn-edit:hover{background:#40a9ff}.manager-dashboard .btn-save{background:#52c41a;color:#fff}.manager-dashboard .btn-save:hover{background:#73d13d}.manager-dashboard .btn-cancel{background:#ff4d4f;color:#fff}.manager-dashboard .btn-cancel:hover{background:#ff7875}.manager-dashboard button.small{min-height:28px;padding:0 10px;font-size:12px;line-height:1}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5}.container{max-width:1400px;margin:0 auto;padding:20px}button{cursor:pointer;border:none;padding:10px 20px;border-radius:4px;font-size:14px;transition:all .2s}button:hover{opacity:.9}button.primary{background:#1890ff;color:#fff}button.success{background:#52c41a;color:#fff}button.danger{background:#ff4d4f;color:#fff}input,textarea{padding:8px 12px;border:1px solid #d9d9d9;border-radius:4px;font-size:14px}input:focus,textarea:focus{outline:none;border-color:#1890ff}.card{background:white;border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000001a}
