@import url("https://fonts.googleapis.com/css2?family=Inter+Tight:ital,wght@0,100..900;1,100..900&display=swap");*{margin:0;padding:0;box-sizing:border-box}.ant-badge,.ant-btn,.ant-dropdown,.ant-input,.ant-message,.ant-modal,.ant-notification,.ant-picker,.ant-popover,.ant-select,.ant-table,.ant-tabs,.ant-tag,.ant-tooltip,a,body,button,div,h1,h2,h3,h4,h5,h6,input,label,li,p,select,span,td,textarea,th{font-family:Inter Tight,sans-serif}:root{--radius:4px;--radius-sm:2px;--radius-lg:6px;--primary:#10b981;--primary-light:#34d399;--primary-dark:#059669;--bg:#f8fafc;--card:#ffffff;--border:#e2e8f0;--text:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8}body{font-family:Inter Tight,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased}.app-container,body{background:var(--bg)}.app-container{height:100vh;display:flex;flex-direction:column}.app-header{height:60px;background:var(--card);border-bottom:1px solid var(--border);justify-content:space-between;padding:0 20px}.app-header,.header-left{display:flex;align-items:center}.header-left{gap:12px}.header-logo-img{width:34px;height:34px;border-radius:.25vw;border:.1vw solid #e2e8f0;display:block}.header-brand{font-size:18px;font-weight:600;color:var(--text);letter-spacing:-.025em}.header-team-badge{padding:4px 10px;background:var(--primary);color:white;font-size:11px;font-weight:600;border-radius:.25vw;text-transform:uppercase;letter-spacing:.5px}.header-right{gap:12px}.header-btn,.header-right{display:flex;align-items:center}.header-btn{justify-content:center;gap:6px;padding:8px 16px;min-height:36px;background:#f5f5f5;border:none;border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--text);cursor:pointer;transition:all .15s ease;white-space:nowrap}.header-btn:hover{background:#e5e5e5}.header-btn:active{background:#d4d4d4}.header-back-btn{padding:8px 12px;margin-right:8px}.header-badge{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;min-height:36px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-size:13px;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:#f59e0b}.status-dot.connected{background:#10b981}.main-layout{flex:1;gap:12px;padding:12px}.main-layout,.panel{display:flex;overflow:hidden}.panel{background:var(--card);border-radius:var(--radius-lg);border:1px solid var(--border);flex-direction:column}.left-panel{width:340px;flex-shrink:0}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.panel-title{font-size:14px;font-weight:600;color:var(--text)}.panel-count{font-size:12px;color:var(--text-muted);font-weight:500}.fetch-progress{display:flex;align-items:center;gap:8px;padding:6px 16px;border-bottom:1px solid var(--border)}.fetch-progress-bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.fetch-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-light),var(--primary));border-radius:3px;transition:width .2s ease}.fetch-progress-text{font-size:11px;color:var(--text-secondary);font-weight:500;white-space:nowrap}.dialing-list-section{padding:0 16px;flex:1;overflow:auto}.dialing-list-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg);border-radius:var(--radius);margin-bottom:10px}.dialing-list-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--primary)}.dialing-list-empty{text-align:center;padding:24px 16px;color:var(--text-muted);font-size:12px}.borrower-card{padding:10px 12px;background:var(--bg);border-radius:var(--radius);margin-bottom:8px;border:1px solid transparent;transition:all .15s ease}.borrower-card:hover{border-color:var(--border)}.borrower-card.active{background:#ecfdf5;border-color:var(--primary)}.borrower-card.priority{background:linear-gradient(90deg,#fef3c7 0,var(--bg) 50%);border-left:3px solid #f59e0b}.borrower-card.priority.active{background:linear-gradient(90deg,#ecfdf5 0,#fef3c7 50%,var(--bg) 100%);border-left:3px solid var(--primary)}.engagement-badge{display:inline-flex;align-items:center;justify-content:center;font-size:14px;margin-left:6px;cursor:help}.engagement-badge.instantly-email{color:#3b82f6}.engagement-badge.\32 chat-whatsapp,.engagement-badge.peach-whatsapp{color:#10b981}.engagement-team{font-size:10px;font-weight:600;background:rgba(0,0,0,.1);padding:1px 4px;border-radius:3px;margin-left:4px;color:#374151}.borrower-card{position:relative}.email-indicator{position:absolute;bottom:6px;right:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:16px;color:#3b82f6}.email-team-code{font-size:9px;font-weight:600;color:#3b82f6;background:#eff6ff;padding:1px 4px;border-radius:3px;white-space:nowrap}.whatsapp-indicator{position:absolute;bottom:6px;right:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:#25D366}.whatsapp-indicator.ai{color:#25D366}.whatsapp-indicator.human{color:#128C7E}.whatsapp-team-code{font-size:9px;font-weight:600;color:#25D366;background:#dcfce7;padding:1px 4px;border-radius:3px;white-space:nowrap}.whatsapp-indicator.human .whatsapp-team-code{color:#128C7E;background:#d1fae5}.human-icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.human-icon-wrapper .whatsapp-mini{position:absolute;bottom:-2px;right:-4px;background:white;border-radius:50%;padding:1px}.borrower-row{justify-content:space-between;margin-bottom:6px}.borrower-info,.borrower-row{display:flex;align-items:flex-start}.borrower-info{gap:8px;flex:1}.borrower-number{width:22px;height:22px;background:var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text-secondary);font-weight:500;flex-shrink:0;margin-top:2px}.borrower-details{flex:1;min-width:0}.borrower-phone-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.borrower-phone{font-size:13px;font-family:monospace;color:var(--text);font-weight:500}.borrower-name{font-size:11px;color:var(--text-secondary);margin-top:2px}.borrower-tag{display:inline-block;padding:1px 6px;border-radius:var(--radius-sm);font-size:9px;font-weight:600;text-transform:uppercase}.borrower-tag.not-in-db{background:#fef2f2;color:#dc2626}.borrower-tag.loading{background:#f3f4f6;color:var(--text-muted)}.borrower-stats{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.stat-item{display:flex;flex-direction:column;gap:2px;min-width:60px}.stat-item .stat-label{font-size:9px;color:var(--text-muted);text-transform:uppercase}.stat-item .stat-value{font-size:12px;font-weight:600}.stat-item .stat-value.green{color:#10b981}.stat-item .stat-value.red{color:#dc2626}.borrower-status{font-size:9px;font-weight:600;padding:2px 6px;border-radius:var(--radius-sm);background:var(--border);color:var(--text-secondary);text-transform:uppercase}.borrower-status.pending{background:#f1f5f9;color:#94a3b8}.borrower-status.dialing{background:#dcfce7;color:#059669;animation:pulse-dialing 1.5s ease-in-out infinite}@keyframes pulse-dialing{0%,to{opacity:1}50%{opacity:.6}}.borrower-status.dialed{background:#dbeafe;color:#2563eb}.borrower-status.paused{background:#fef3c7;color:#d97706}.borrower-status.not-dialed{background:#fef2f2;color:#dc2626}.borrower-status.callback{background:#f3e8ff;color:#9333ea;animation:pulse-dialing 1.5s ease-in-out infinite}.borrower-status.blocked-alternate,.borrower-status.master-pause{background:#fef2f2;color:#dc2626}.borrower-status.busy{background:#fff7ed;color:#ea580c}.borrower-status.no-answer{background:#fefce8;color:#ca8a04}.borrower-status.out-of-coverage,.borrower-status.rejected,.borrower-status.unreachable{background:#fef2f2;color:#dc2626}.borrower-status.invalid-number{background:#fdf4ff;color:#a21caf}.borrower-status.switched-off{background:#faf5ff;color:#059669}.borrower-status.congestion{background:#fff7ed;color:#ea580c}.clear-list-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#f5f5f5;border:none;border-radius:var(--radius-sm);font-size:11px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.clear-list-btn:hover{background:#fee2e2;color:#dc2626}.clear-list-btn:active{background:#fecaca}.paste-section{padding:12px;border-top:1px solid var(--border);background:var(--bg)}.paste-textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px;resize:none;margin-bottom:8px;font-family:monospace;background:var(--card)}.paste-textarea:focus{outline:none;border-color:var(--primary)}.paste-actions{display:flex;gap:8px}.paste-add-btn{display:flex;align-items:center;gap:4px;padding:10px 16px;background:#f5f5f5;border:none;border-radius:var(--radius);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:all .12s ease}.paste-add-btn:hover{background:#e5e5e5}.paste-add-btn:active{background:#d4d4d4}.paste-add-btn.priority-btn{background:#171717;color:white}.paste-add-btn.priority-btn:hover{background:#262626}.paste-add-btn.priority-btn:active{background:#0a0a0a}.start-button{width:100%;padding:12px;background:linear-gradient(135deg,var(--primary-light) 0,var(--primary) 100%);border:none;border-radius:var(--radius);color:#fff;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s ease}.start-button:hover{opacity:.9}.start-button:disabled{background:var(--border);cursor:not-allowed}.center-panel{flex:1;padding:16px;overflow:auto}.status-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.status-title{font-size:14px;font-weight:600;color:var(--text)}.status-badge{padding:4px 12px;background:#dcfce7;color:#059669;border-radius:var(--radius);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.status-badge.callback{background:#f3e8ff;color:#9333ea;animation:pulse-dialing 1.5s ease-in-out infinite}.customer-card{background:linear-gradient(135deg,#3a3a3a,#252525);border-radius:var(--radius);padding:16px;margin-bottom:16px}.customer-name{text-align:center;margin-bottom:16px}.customer-name h3{color:#fff;font-size:15px;font-weight:600;margin-bottom:2px}.customer-name span{color:#9ca3af;font-size:12px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.stat-card{background:rgba(255,255,255,.08);border-radius:var(--radius);padding:10px 8px;text-align:center;min-height:56px;display:flex;flex-direction:column;justify-content:center}.stat-label{font-size:9px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;white-space:nowrap}.stat-value{font-size:16px;font-weight:700;color:var(--primary)}.stat-value.white{color:#fff}.stat-value.red{color:#ef4444}.stat-value.loan-id{font-size:11px;word-break:break-all}.borrower-stats .loan-id-item{flex-basis:100%;margin-top:4px}.borrower-stats .loan-id-item .stat-value{font-size:10px;word-break:break-all}.section-card{background:var(--bg);border-radius:var(--radius);padding:14px;margin-bottom:12px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title{font-size:12px;font-weight:600;color:var(--text)}.section-title.green{color:var(--primary)}.section-shortcut{font-size:10px;color:var(--text-muted)}.quick-actions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;background:#f5f5f5;border:none;border-radius:var(--radius);cursor:pointer;transition:all .15s ease;position:relative}.quick-action-btn:hover{background:#e5e5e5}.quick-action-btn:active{background:#d4d4d4}.quick-action-btn:disabled{opacity:.4;cursor:not-allowed}.quick-action-icon{font-size:20px;color:var(--text-secondary)}.quick-action-label{font-size:11px;font-weight:500;color:var(--text)}.quick-action-key{position:absolute;top:6px;right:6px;width:16px;height:16px;background:var(--bg);border-radius:var(--radius-sm);font-size:9px;font-weight:600;color:var(--text-muted);display:flex;align-items:center;justify-content:center}.disposition-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.disposition-grid.four-cols{grid-template-columns:repeat(4,1fr)}.disposition-grid.seven-cols{grid-template-columns:repeat(7,1fr)}.disposition-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 6px;background:#f5f5f5;border:none;border-radius:var(--radius);cursor:pointer;transition:all .15s ease;position:relative}.disposition-btn:hover{filter:brightness(.95)}.disposition-btn:active{filter:brightness(.9)}.disposition-btn:disabled{opacity:.4;cursor:not-allowed}.disposition-btn.ptp{background:#d1fae5}.disposition-btn.ptp:hover{background:#a7f3d0}.disposition-btn.ptp .disposition-icon{color:#10b981}.disposition-btn.agent-ptp{background:#fef3c7}.disposition-btn.agent-ptp:hover{background:#fde68a}.disposition-btn.agent-ptp .disposition-icon{color:#d97706}.disposition-btn.broken-ptp{background:#fef2f2}.disposition-btn.broken-ptp:hover{background:#fee2e2}.disposition-btn.broken-ptp .disposition-icon{color:#ef4444}.disposition-btn.rtp{background:#fff7ed}.disposition-btn.rtp:hover{background:#ffedd5}.disposition-btn.rtp .disposition-icon{color:#ea580c}.disposition-btn.callback{background:#eff6ff}.disposition-btn.callback:hover{background:#dbeafe}.disposition-btn.callback .disposition-icon{color:#3b82f6}.disposition-btn.payment-link{background:#f0fdf4}.disposition-btn.payment-link:hover{background:#dcfce7}.disposition-btn.payment-link .disposition-icon{color:#059669}.disposition-btn.already-paid{background:#ecfdf5}.disposition-btn.already-paid:hover{background:#d1fae5}.disposition-btn.already-paid .disposition-icon{color:var(--primary)}.disposition-btn.no-commitment{background:#f5f5f4}.disposition-btn.no-commitment:hover{background:#e7e5e4}.disposition-btn.no-commitment .disposition-icon{color:#78716c}.disposition-btn.no-response{background:#fafaf9}.disposition-btn.no-response:hover{background:#f5f5f4}.disposition-btn.no-response .disposition-icon{color:#a8a29e}.disposition-btn.nrpc{background:#fef2f2}.disposition-btn.nrpc:hover{background:#fee2e2}.disposition-btn.nrpc .disposition-icon{color:#dc2626}.disposition-number{position:absolute;top:-5px;right:-5px;width:16px;height:16px;background:#475569;color:#fff;border-radius:50%;font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center}.disposition-icon{font-size:18px}.disposition-label{font-size:9px;font-weight:600;color:var(--text);text-align:center;line-height:1.2}.auto-resume{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg);border-radius:var(--radius);margin-bottom:16px}.auto-resume-label{font-size:12px;color:var(--text)}.control-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.control-btn{padding:12px 16px;border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s ease;border:none}.control-btn:disabled{opacity:.4;cursor:not-allowed}.control-btn.resume{background:linear-gradient(135deg,var(--primary-light) 0,var(--primary) 100%);color:#fff}.control-btn.pause{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.control-btn.stop{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.right-panel{width:320px;flex-shrink:0}.whatsapp-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.whatsapp-title{gap:10px}.whatsapp-icon,.whatsapp-title{display:flex;align-items:center}.whatsapp-icon{width:32px;height:32px;background:#25d366;border-radius:var(--radius);justify-content:center;font-size:16px}.whatsapp-icon,.whatsapp-icon .anticon,.whatsapp-icon svg{color:#fff!important}.whatsapp-title span{font-size:14px;font-weight:600;color:var(--text)}.whatsapp-status{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--primary)}.whatsapp-tabs{display:flex;border-bottom:1px solid var(--border)}.whatsapp-tab{flex:1;padding:10px;text-align:center;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;background:none;border:none;border-bottom:2px solid transparent;display:flex;align-items:center;justify-content:center;gap:5px}.whatsapp-tab:hover{color:var(--primary)}.whatsapp-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.whatsapp-content{padding:14px 16px;flex:1;overflow:auto}.reply-to{font-size:11px;color:var(--text-secondary);margin-bottom:10px}.message-input-row{display:flex;gap:8px;margin-bottom:12px}.message-input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px;font-family:inherit;background:var(--card)}.message-input:focus{outline:none;border-color:var(--primary)}.send-btn{width:40px;height:40px;background:linear-gradient(135deg,var(--primary-light) 0,var(--primary) 100%);border:none;border-radius:var(--radius);color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.send-btn:hover{opacity:.9}.send-btn:disabled{background:var(--border);cursor:not-allowed}.quick-replies{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.quick-reply-btn{padding:6px 12px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);font-size:11px;color:var(--text);cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .15s ease}.quick-reply-btn:hover{border-color:var(--primary);background:#f0fdf4}.recent-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.recent-title{font-size:11px;font-weight:600;color:var(--text-secondary)}.load-recent{font-size:10px;color:var(--primary);cursor:pointer;background:none;border:none;font-weight:500}.message-item{padding:10px 12px;background:var(--bg);border-radius:var(--radius);margin-bottom:8px;border-left:3px solid var(--primary)}.message-item-header{display:flex;justify-content:space-between;margin-bottom:4px}.message-phone{font-size:11px;font-weight:600;color:var(--text)}.message-time{font-size:9px;color:var(--text-muted)}.message-text{font-size:12px;color:var(--text);margin-bottom:6px}.message-actions{display:flex;gap:6px}.message-action{padding:3px 8px;font-size:9px;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;border:none}.message-action.reply{background:#374151;color:#fff}.message-action.link{background:#ef4444;color:#fff}.device-modal .ant-modal-content{border-radius:var(--radius-lg)!important;padding:0!important;overflow:hidden}.device-modal .ant-modal-body{padding:0!important}.adb-modal{padding:0}.adb-header{justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.adb-header,.adb-title{display:flex;align-items:center}.adb-title{gap:8px;font-size:15px;font-weight:600;color:var(--text)}.adb-title .anticon{font-size:16px;color:var(--text-secondary)}.adb-header-actions,.adb-linked-banner{display:flex;align-items:center;gap:8px}.adb-linked-banner{padding:10px 20px;background:#ecfdf5;border-bottom:1px solid #a7f3d0;font-size:13px;color:#047857}.adb-linked-banner strong{font-weight:600}.port-badge{display:inline-block;padding:2px 8px;margin-left:8px;background:#dbeafe;color:#1d4ed8;border-radius:var(--radius-sm);font-size:11px;font-weight:500}.adb-table-wrapper{padding:0;max-height:360px;overflow:auto}.adb-table{width:100%;border-collapse:collapse;font-size:13px}.adb-table th{text-align:left;padding:10px 16px;background:var(--bg);font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.3px}.adb-table td,.adb-table th{border-bottom:1px solid var(--border)}.adb-table td{padding:12px 16px;color:var(--text);vertical-align:middle}.adb-table tbody tr:hover{background:var(--bg)}.adb-table tbody tr.linked-row{background:#f0fdf4}.adb-table tbody tr.linked-row:hover{background:#ecfdf5}.adb-empty{text-align:center;padding:40px 16px!important;color:var(--text-muted);font-size:13px}.device-cell{display:flex;align-items:center;gap:10px}.device-cell-icon{font-size:18px;color:var(--text-muted)}.device-name{font-weight:500;color:var(--text);font-size:13px}.device-id{font-family:monospace;font-size:11px;color:var(--text-muted)}.phone-cell{font-family:monospace;font-size:13px;color:var(--text-secondary)}.port-cell{font-family:monospace;font-size:12px;color:#1d4ed8;font-weight:500}.linked-cell{font-size:12px;color:var(--text-secondary)}.in-use-badge{background:#fef3c7;color:#92400e}.adb-status,.in-use-badge{display:inline-block;padding:3px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:500}.adb-status.connected,.adb-status.idle{background:#dcfce7;color:#059669}.adb-status.disconnected{background:#fef2f2;color:#dc2626}.adb-actions{display:flex;align-items:center;gap:8px}.linked-badge{color:var(--primary)}.adb-btn,.linked-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500}.adb-btn{padding:6px 12px;border-radius:var(--radius);cursor:pointer;transition:all .12s ease;border:none}.adb-btn.outline{background:var(--card);border:1px solid var(--border);color:var(--text)}.adb-btn.outline:hover{border-color:var(--text-secondary)}.adb-btn.primary{background:var(--primary);color:#fff}.adb-btn.primary:hover{background:var(--primary-dark)}.adb-btn.primary-sm{background:var(--primary);color:#fff;padding:5px 10px;font-size:11px}.adb-btn.primary-sm:hover{background:var(--primary-dark)}.adb-btn.text-danger{background:none;color:var(--text-muted);padding:5px 8px}.adb-btn.text-danger:hover{color:#dc2626}.adb-btn:disabled{opacity:.5;cursor:not-allowed}.add-device-modal .ant-modal-content{border-radius:var(--radius-lg)!important;padding:0!important}.add-device-modal .ant-modal-body{padding:0!important}.add-device-content{padding:32px 24px;text-align:center}.add-device-icon{width:64px;height:64px;margin:0 auto 20px;background:var(--bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--text-secondary)}.add-device-icon.checking{background:#eff6ff;color:#3b82f6}.add-device-icon.success{background:#ecfdf5;color:var(--primary)}.add-device-icon.error{background:#fef2f2;color:#dc2626}.add-device-content h3{font-size:18px;font-weight:600;color:var(--text);margin:0 0 8px}.add-device-content p{font-size:13px;color:var(--text-secondary);margin:0 0 20px;line-height:1.5}.add-device-steps{text-align:left;background:var(--bg);border-radius:var(--radius);padding:16px 20px;margin-bottom:24px}.add-device-steps .step{font-size:13px;color:var(--text);padding:6px 0}.add-device-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 24px;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;transition:all .12s ease;border:none;min-width:160px}.add-device-btn.primary{background:var(--primary);color:#fff}.add-device-btn.primary:hover{background:var(--primary-dark)}.add-device-btn.outline{background:var(--card);border:1px solid var(--border);color:var(--text)}.add-device-btn.outline:hover{border-color:var(--text-secondary)}.found-device-info{background:var(--bg);border-radius:var(--radius);padding:16px 20px;margin-bottom:16px;text-align:left}.found-device-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px}.found-device-row span{color:var(--text-secondary)}.found-device-row strong{color:var(--text);font-weight:500}.assigned-port-info{display:inline-block;padding:8px 16px;margin-bottom:12px;background:#dbeafe;color:#1d4ed8;border-radius:var(--radius);font-size:14px;font-weight:500}.assigned-port-info strong{font-weight:600}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.ant-switch-checked{background:var(--primary)!important}.ant-checkbox-checked .ant-checkbox-inner{background-color:var(--primary)!important;border-color:var(--primary)!important}.ant-modal-content{border-radius:.25vw!important;box-shadow:none!important;border:1px solid #e5e5e5!important}.ant-modal-header{border-radius:.25vw .25vw 0 0!important}.ant-modal-footer{border-radius:0 0 .25vw .25vw!important}.ant-modal-mask{background:rgba(0,0,0,.4)!important}.ant-btn{border-radius:.2vw!important;font-family:Inter Tight,sans-serif!important}.ant-btn-primary{background:#171717!important;border-color:#171717!important;color:#ffffff!important}.ant-btn-primary:hover{background:#262626!important;border-color:#262626!important;color:#ffffff!important}.ant-input{border-radius:.2vw!important;font-family:Inter Tight,sans-serif!important;border-color:#e5e5e5!important}.ant-input-focused,.ant-input:focus{border-color:#0a0a0a!important}.ant-input-affix-wrapper{border-radius:.2vw!important;border-color:#e5e5e5!important}.ant-input-affix-wrapper-focused,.ant-input-affix-wrapper:focus{border-color:#0a0a0a!important}.ant-table{font-family:Inter Tight,sans-serif!important}.ant-table,.ant-table-container{border-radius:.2vw!important}.ant-tag{border-radius:.1vw!important;font-family:Inter Tight,sans-serif!important}.ant-select-selector{border-radius:.2vw!important;border-color:#e5e5e5!important}.ant-select-focused .ant-select-selector{border-color:#0a0a0a!important}.ant-input-prefix{display:flex;align-items:center;margin-right:12px!important}.ant-input-prefix .anticon{justify-content:center}.ant-input-password .ant-input-prefix,.ant-input-prefix .anticon{display:flex;align-items:center}.ant-input-affix-wrapper .ant-input-prefix{margin-inline-end:12px!important}.ant-input-affix-wrapper-focused,.ant-input-affix-wrapper:focus,.ant-input-focused,.ant-input:focus{box-shadow:none!important;border-color:var(--primary)!important}.ant-btn:focus,.ant-select-focused .ant-select-selector,.ant-select:focus{box-shadow:none!important}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.login-card{background:var(--card);border-radius:.25vw;border:1px solid var(--border);padding:40px;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:64px;height:64px;border-radius:.25vw;background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:#fff;font-size:28px}.login-header h1{font-size:24px;font-weight:600;color:var(--text);margin-bottom:4px}.login-header span{font-size:13px;color:var(--primary);font-weight:500}.login-form{display:flex;flex-direction:column;gap:16px}.login-input{width:100%;height:44px;padding:0 16px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;color:var(--text);background:var(--bg);transition:border-color .2s}.login-input:focus{outline:none;border-color:var(--primary)}.login-input::-moz-placeholder{color:var(--text-muted)}.login-input::placeholder{color:var(--text-muted)}.login-error{color:#dc2626;font-size:13px;text-align:center;padding:8px;background:#fef2f2;border-radius:var(--radius)}.login-btn{height:44px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:15px;font-weight:500;cursor:pointer;transition:background .2s}.login-btn:hover{background:var(--primary-dark)}.header-btn.logout{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.header-btn.logout:hover{border-color:#dc2626;color:#dc2626}.ant-message-notice-content{animation:sonar-pulse .4s ease-out;box-shadow:none;border-radius:.25vw;padding:10px 16px}@keyframes sonar-pulse{0%{transform:scale(.95);opacity:0}50%{transform:scale(1.02)}to{transform:scale(1);opacity:1}}.ant-message-success .ant-message-notice-content{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86efac}.ant-message-info .ant-message-notice-content{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #93c5fd}.ant-message-warning .ant-message-notice-content{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d}.ant-message-error .ant-message-notice-content{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fca5a5}.ant-popover .ant-input{color:#1e293b!important}.ant-popover .ant-input::-moz-placeholder{color:#94a3b8!important}.ant-popover .ant-input::placeholder{color:#94a3b8!important}.ant-popover .ant-input-focused,.ant-popover .ant-input:focus{border-color:#10b981!important;box-shadow:none!important}.ant-popover .ant-input:hover{border-color:#94a3b8!important}.dial-countdown-toast{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;align-items:center;gap:10px;background:#fff;color:#1e293b;padding:10px 16px;border-radius:.25vw;font-size:13px;border:1px solid #e2e8f0}.dial-toast-icon{color:#10b981;font-size:14px}.dial-toast-text{font-weight:500;color:#334155}.dial-toast-bar{width:60px;height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden}.dial-toast-progress{height:100%;background:#10b981;border-radius:2px;transition:width .1s linear}