callix-dialer-widget 2.0.2 → 2.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- .phone-container,.phone-container *,.phone-container *:before,.phone-container *:after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}.phone-container{--bg-color: #f2f2f7;--text-primary: #000;--text-secondary: #8e8e93;--key-bg: #fff;--key-shadow: rgba(0, 0, 0, .08);--call-green: #34c759;--call-red: #ff3b30;--nav-active: #007aff;--call-screen-bg: linear-gradient(180deg, #1c4a5c 0%, #0d2a35 100%)}.phone-container{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:var(--bg-color);display:flex;flex-direction:column;overflow:hidden}.phone-container .screen{flex:1 1 auto;min-height:0;display:none;flex-direction:column;overflow:hidden}.phone-container .screen.active{display:flex}.phone-container .dialer-screen{padding:0}.phone-container .dialer-screen .dialer-header{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;padding:8px 16px}.phone-container .dialer-screen .phone-number-display{flex:0 0 auto;min-height:60px;display:flex;align-items:center;justify-content:center;padding:8px 16px}.phone-container .dialer-screen .keypad{flex:1 1 auto;min-height:0;display:grid;grid-template-columns:repeat(3,80px);gap:14px;justify-content:center;align-content:center;padding:8px 0}.phone-container .dialer-screen .call-actions{flex:0 0 auto;display:flex;align-items:center;justify-content:center;padding:16px 24px;gap:40px}.phone-container .call-history-screen{background:var(--bg-color)}.phone-container .call-history-screen .history-header{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f2f2f7f0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:.5px solid rgba(0,0,0,.1)}.phone-container .header-title{font-size:17px;font-weight:600;color:#000;letter-spacing:-.4px}.phone-container .history-refresh-btn{width:32px;height:32px;border-radius:50%;background:transparent;border:none;color:#007aff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.phone-container .history-refresh-btn:active{transform:scale(.9);opacity:.6}.phone-container .history-refresh-btn:disabled{opacity:.4;cursor:not-allowed}.phone-container .call-history-screen .call-history-list{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;background:#fff}.phone-container .history-empty,.phone-container .history-loading,.phone-container .history-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;height:100%;padding:60px 20px;text-align:center;color:var(--text-secondary);font-size:16px;background:var(--bg-color)}.phone-container .history-empty i,.phone-container .history-loading i,.phone-container .history-error i{font-size:48px;opacity:.4}.phone-container .history-error{color:var(--call-red)}.phone-container .history-error i{opacity:.8}.phone-container .retry-btn{margin-top:8px;padding:12px 24px;background:#007aff;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s ease}.phone-container .retry-btn:active{transform:scale(.97);opacity:.9}.phone-container .history-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-bottom:.5px solid rgba(0,0,0,.08);transition:background .15s ease}.phone-container .history-item:active{background:#0000000a}.phone-container .history-arrow{width:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.phone-container .history-arrow svg{width:14px;height:14px}.phone-container .history-arrow.answered{color:#34c759}.phone-container .history-arrow.missed{color:#ff3b30}.phone-container .history-item-info{flex:1;min-width:0}.phone-container .history-item-number{font-size:17px;font-weight:400;color:#000;letter-spacing:-.4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.phone-container .history-item-number.missed{color:#ff3b30}.phone-container .history-item-meta{display:flex;align-items:center;gap:4px;margin-top:2px}.phone-container .history-item-type{font-size:13px;color:var(--text-secondary);font-weight:400}.phone-container .history-meta-dot{font-size:10px;color:var(--text-secondary)}.phone-container .history-item-datetime{font-size:13px;color:var(--text-secondary)}.phone-container .history-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.phone-container .history-action-btn{width:36px;height:36px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;font-size:16px}.phone-container .history-action-btn:active{transform:scale(.9)}.phone-container .history-action-btn.call-btn{background:#34c7591f;color:#34c759}.phone-container .history-action-btn.call-btn:active{background:#34c75940}.phone-container .history-action-btn.whatsapp-btn{background:#25d3661f;color:#25d366}.phone-container .history-action-btn.whatsapp-btn:active{background:#25d36640}.phone-container .history-item-time{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.phone-container .history-item-date{font-size:12px;color:var(--text-secondary)}.phone-container .history-item-hour{font-size:13px;color:var(--text-secondary);font-weight:500}.phone-container .call-screen{background:linear-gradient(180deg,#1a5a6e,#0f3d4a,#0a2830);color:#fff;flex:1 1 0;min-height:0}.phone-container .call-screen .call-info{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;align-items:center;padding:20px 16px 16px;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.phone-container .call-screen .call-info::-webkit-scrollbar{display:none}.phone-container .call-screen .call-controls{flex:0 0 auto;display:flex;flex-direction:column;gap:20px;padding:16px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.phone-container .incall-keypad-screen{background:linear-gradient(180deg,#1a5a6e,#0f3d4a,#0a2830);color:#fff}.phone-container .incall-keypad-screen .incall-header{flex:0 0 auto;display:flex;justify-content:flex-end;padding:10px 16px}.phone-container .incall-keypad-screen .incall-number-display{flex:0 0 auto;height:40px;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:300;letter-spacing:2px}.phone-container .incall-keypad-screen .keypad{flex:1 1 auto;min-height:0}.phone-container .incall-keypad-screen .incall-actions{flex:0 0 auto;display:flex;justify-content:center;padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.phone-container .bottom-nav{flex:0 0 auto;display:flex;justify-content:space-around;padding:8px 12px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px));background:#f2f2f7f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:.5px solid rgba(0,0,0,.08)}.phone-container .bottom-nav.hidden{display:none}.phone-container .nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-secondary);font-size:10px;cursor:pointer;padding:6px 16px;border-radius:10px;transition:background .2s}.phone-container .nav-item.active{color:var(--nav-active);background:#007aff1a}.phone-container .nav-icon{position:relative;font-size:22px}.phone-container .badge{position:absolute;top:-6px;right:-10px;background:var(--call-red);color:#fff;font-size:11px;font-weight:600;padding:1px 5px;border-radius:10px;min-width:18px;text-align:center}.phone-container .status-container{display:flex;align-items:center}.phone-container .status-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;border:none;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.phone-container .status-badge.available{background:#34c75926;color:#30d158}.phone-container .status-badge.paused{background:#ff9f0a26;color:#ff9f0a}.phone-container .status-badge.error{background:#ff3b3026;color:#ff3b30}.phone-container .status-info{display:flex;align-items:center;gap:0}.phone-container .pause-timer{font-size:13px;font-weight:500;opacity:.9;font-variant-numeric:tabular-nums;margin-left:6px;padding-left:6px;border-left:1px solid rgba(255,159,10,.35)}.phone-container .status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse-dot 2s ease-in-out infinite;flex-shrink:0}.phone-container .status-badge.paused .status-dot,.phone-container .status-badge.error .status-dot{animation:none}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.9)}}.phone-container .status-actions{display:flex;align-items:center;gap:8px}.phone-container .pause-btn,.phone-container .resume-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;border:none;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.phone-container .pause-btn{background:#ff9f0a26;color:#ff9f0a}.phone-container .resume-btn{background:#30d15826;color:#30d158}.phone-container .phone-input{width:100%;max-width:320px;font-size:34px;font-weight:300;letter-spacing:.5px;text-align:center;border:none;background:transparent;color:#000;outline:none;caret-color:#007aff;font-family:inherit}.phone-container .phone-input::placeholder{color:#c7c7cc}.phone-container .key{width:80px;height:80px;border-radius:50%;background:var(--key-bg);box-shadow:0 2px 8px var(--key-shadow),inset 0 -1px 2px #0000000d;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.phone-container .key:active{background:#d1d1d6;transform:scale(.95)}.phone-container .key .number{font-size:32px;font-weight:300;color:var(--text-primary);line-height:1}.phone-container .key .letters{font-size:10px;font-weight:600;color:var(--text-primary);letter-spacing:1.5px;margin-top:2px;text-transform:uppercase}.phone-container .call-button{width:70px;height:70px;border-radius:50%;background:var(--call-green);border:none;color:#fff;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;box-shadow:0 4px 15px #34c75966}.phone-container .call-button:disabled{opacity:.5;cursor:not-allowed}.phone-container .call-button:active:not(:disabled){transform:scale(.95)}.phone-container .delete-button{width:36px;height:36px;background:transparent;border:none;color:#666;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center}.phone-container .empty-space{width:36px}.phone-container .call-status{display:flex;align-items:center;gap:10px;font-size:16px;opacity:.95}.phone-container .operator-badge-small{background:linear-gradient(135deg,#34c759,#30b350);color:#fff;font-size:11px;font-weight:600;padding:3px 6px;border-radius:4px}.phone-container .call-number{font-size:32px;font-weight:300;margin-top:10px;letter-spacing:.5px}.phone-container .call-location{font-size:16px;opacity:.7;margin-top:6px}.phone-container .client-card{margin-top:20px;margin-bottom:20px;width:calc(100% - 32px);max-width:360px;background:#ffffff1f;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;padding:16px;border:1px solid rgba(255,255,255,.1);box-sizing:border-box;flex-shrink:0}.phone-container .client-card-header{display:flex;align-items:center;gap:14px}.phone-container .client-avatar{font-size:44px;color:#ffffffe6;flex-shrink:0;line-height:1}.phone-container .client-main-info{display:flex;flex-direction:column;align-items:flex-start;gap:2px;flex:1;min-width:0}.phone-container .client-name{font-size:17px;font-weight:600;color:#fff;letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.phone-container .client-company{font-size:14px;font-weight:400;color:#ffffffb3;letter-spacing:-.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.phone-container .client-card-divider{height:1px;background:#ffffff26;margin:14px 0}.phone-container .client-info-list{display:flex;flex-direction:column;gap:10px}.phone-container .client-info-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.phone-container .client-info-label{font-size:14px;font-weight:400;color:#fff9;letter-spacing:-.1px;flex-shrink:0}.phone-container .client-info-value{font-size:14px;font-weight:500;color:#fff;letter-spacing:-.1px;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}.phone-container .client-info-value.debt{color:#ff9f0a;font-weight:600}.phone-container .client-capital-section{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 0 4px}.phone-container .client-capital-label{font-size:12px;font-weight:400;color:#fff9;letter-spacing:-.1px;text-transform:uppercase}.phone-container .client-capital-value{font-size:24px;font-weight:600;color:#30d158;font-variant-numeric:tabular-nums;letter-spacing:-.3px}.phone-container .client-card-loading,.phone-container .client-card-error{display:flex;align-items:center;justify-content:center;gap:10px;padding:20px;color:#ffffffb3;font-size:14px}.phone-container .client-card-loading i{font-size:16px;color:#3b82f6}.phone-container .client-card-error{color:#ff6b6b}.phone-container .client-card-error i{font-size:16px}@media (max-width: 340px){.phone-container .client-card{margin-top:16px;padding:12px;border-radius:14px}.phone-container .client-avatar{font-size:36px}.phone-container .client-name{font-size:15px}.phone-container .client-company,.phone-container .client-info-label,.phone-container .client-info-value{font-size:12px}.phone-container .client-capital-label{font-size:11px}.phone-container .client-capital-value{font-size:20px}}.phone-container .control-row{display:flex;justify-content:space-between;align-items:center;padding:0 12px}.phone-container .control-row-center{justify-content:center;gap:40px}.phone-container .control-button{display:flex;flex-direction:column;align-items:center;gap:8px;background:transparent;border:none;color:#fff;cursor:pointer;font-size:11px;min-width:70px}.phone-container .control-icon{width:64px;height:64px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-size:24px;transition:all .2s ease}.phone-container .control-button.active .control-icon{background:#fff;color:#333}.phone-container .control-button.disabled{opacity:.4;cursor:not-allowed}.phone-container .control-button.disabled .control-icon{background:#ffffff1a}.phone-container .whatsapp-btn .control-icon{background:#25d366}.phone-container .end-call-button{width:64px;height:64px;border-radius:50%;background:var(--call-red);border:none;color:#fff;font-size:26px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #ff3b3066}.phone-container .end-call-wrapper{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:70px}.phone-container .end-call-label{color:#fff;font-size:11px}.phone-container .incall-keypad{display:grid;grid-template-columns:repeat(3,70px);gap:12px;justify-content:center;align-content:center;padding:10px 0}.phone-container .incall-key{width:70px;height:70px;background:#ffffff2e;box-shadow:none}.phone-container .incall-key .number,.phone-container .incall-key .letters{color:#fff}.phone-container .incall-key:active{background:#ffffff59}.phone-container .hide-keypad-btn{background:transparent;border:none;color:var(--nav-active);font-size:15px;cursor:pointer}.phone-container .header-title{font-size:17px;font-weight:600;color:#000}.phone-container .input-error{color:var(--call-red);font-size:13px;text-align:center;padding:8px}.phone-container .modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0006;display:none;align-items:flex-end;justify-content:center;z-index:1000;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.phone-container .modal-overlay.active{display:flex}.phone-container .modal-content{background:#fff;border-radius:20px 20px 0 0;width:100%;max-height:70%;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px));animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.phone-container .modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.phone-container .modal-title{font-size:20px;font-weight:600;color:var(--text-primary)}.phone-container .modal-close{width:32px;height:32px;border-radius:50%;background:#00000014;border:none;color:var(--text-secondary);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.phone-container .pause-options{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto;margin-bottom:16px}.phone-container .pause-option{display:flex;align-items:center;gap:14px;padding:14px 16px;background:#f8f8f8;border-radius:14px;cursor:pointer;transition:all .2s ease}.phone-container .pause-option:active{transform:scale(.98)}.phone-container .pause-option-icon{width:40px;height:40px;border-radius:50%;background:#fff;border:2px solid #ff9500;display:flex;align-items:center;justify-content:center;color:#ff9500;font-size:16px}.phone-container .pause-option-info{flex:1}.phone-container .pause-option-name{font-size:16px;font-weight:500;color:var(--text-primary)}.phone-container .pause-option-id{font-size:12px;color:var(--text-secondary);margin-top:2px}.phone-container .modal-cancel-btn{width:100%;padding:16px;background:#f2f2f7;border:none;border-radius:14px;font-size:17px;font-weight:500;color:var(--nav-active);cursor:pointer}.phone-container .qualification-modal{align-items:flex-end;background:#0000004d}.phone-container .qualification-sheet{background:#f2f2f7;border-radius:12px 12px 0 0;width:100%;max-height:85vh;display:flex;flex-direction:column;animation:sheetSlideUp .35s cubic-bezier(.2,.9,.3,1);overflow:hidden}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.phone-container .sheet-handle{width:36px;height:5px;background:#3c3c434d;border-radius:3px;margin:6px auto 0}.phone-container .sheet-header{padding:16px 20px 12px;text-align:center}.phone-container .sheet-title{display:block;font-size:17px;font-weight:600;color:#000}.phone-container .sheet-subtitle{display:block;font-size:13px;color:#8e8e93;margin-top:4px}.phone-container .result-segmented{display:flex;position:relative;background:#7676801f;border-radius:9px;padding:2px;margin:0 16px 16px}.phone-container .segment{flex:1;padding:7px 12px;font-size:13px;font-weight:500;color:#000;background:transparent;border:none;border-radius:7px;cursor:pointer;position:relative;z-index:1}.phone-container .segment.active{color:#000}.phone-container .segment-indicator{position:absolute;top:2px;left:2px;width:calc(50% - 2px);height:calc(100% - 4px);background:#fff;border-radius:7px;box-shadow:0 1px 3px #00000014;transition:transform .2s cubic-bezier(.4,0,.2,1)}.phone-container .segment[data-type=failure].active~.segment-indicator{transform:translate(100%)}.phone-container .qualifications-container{flex:1;overflow:hidden;padding:0 16px}.phone-container .qualification-list{display:flex;flex-direction:column;background:#ffffffd9;border-radius:14px;overflow-y:auto;max-height:300px}.phone-container .qualification-item{display:flex;align-items:center;justify-content:center;padding:18px 20px;background:transparent;border:none;border-bottom:.5px solid rgba(60,60,67,.18);cursor:pointer;font-size:17px;color:#007aff;text-align:center}.phone-container .qualification-item:last-child{border-bottom:none}.phone-container .qualification-item.selected{font-weight:600;background:#007aff14}.phone-container .sheet-footer{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.phone-container .confirm-btn{width:100%;padding:16px;background:#007aff;border:none;border-radius:12px;font-size:17px;font-weight:600;color:#fff;cursor:pointer}.phone-container .confirm-btn:disabled{background:#007aff66;cursor:not-allowed}@media (max-width: 340px){.phone-container .dialer-header{padding:6px 12px}.phone-container .status-badge{padding:5px 10px;font-size:11px}.phone-container .pause-btn span,.phone-container .resume-btn span{display:none}.phone-container .phone-input{font-size:28px}.phone-container .keypad{grid-template-columns:repeat(3,60px);gap:10px}.phone-container .key{width:60px;height:60px}.phone-container .key .number{font-size:26px}.phone-container .key .letters{font-size:8px}.phone-container .call-button{width:60px;height:60px;font-size:24px}.phone-container .call-actions{padding:12px 20px;gap:30px}.phone-container .bottom-nav{padding:6px 8px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.phone-container .nav-item{padding:4px 10px;font-size:9px}}@media (min-width: 341px) and (max-width: 380px){.phone-container .phone-input{font-size:30px}.phone-container .keypad{grid-template-columns:repeat(3,70px);gap:12px}.phone-container .key{width:70px;height:70px}.phone-container .key .number{font-size:28px}}@media (min-width: 600px){.phone-container .keypad{grid-template-columns:repeat(3,85px);gap:18px}.phone-container .key{width:85px;height:85px}.phone-container .key .number{font-size:36px}.phone-container .phone-input{font-size:40px}.phone-container .call-button{width:78px;height:78px;font-size:30px}}@media (min-width: 381px) and (max-width: 430px){.phone-container .phone-input{font-size:36px}.phone-container .keypad{grid-template-columns:repeat(3,75px);gap:14px}.phone-container .key{width:75px;height:75px}.phone-container .key .number{font-size:32px}.phone-container .call-button{width:70px;height:70px}}@media (min-width: 431px) and (max-width: 600px){.phone-container .phone-input{font-size:38px}.phone-container .keypad{grid-template-columns:repeat(3,80px);gap:16px}.phone-container .key{width:80px;height:80px}.phone-container .key .number{font-size:34px}.phone-container .call-button{width:74px;height:74px}}@media (min-width: 601px) and (max-width: 767px){.phone-container{max-width:414px;margin:0 auto}}@media (min-width: 768px){.phone-container{max-width:414px;margin:0 auto}}.phone-container .key{transition:transform .12s cubic-bezier(.25,.46,.45,.94),background-color .12s cubic-bezier(.25,.46,.45,.94);will-change:transform}.phone-container .key:active{transform:scale(.92);background:#d1d1d6}.phone-container .call-button,.phone-container .end-call-button{transition:transform .15s cubic-bezier(.25,.46,.45,.94),box-shadow .15s ease;will-change:transform}.phone-container .call-button:active:not(:disabled),.phone-container .end-call-button:active{transform:scale(.92)}.phone-container .client-card{animation:cardFadeIn .35s cubic-bezier(.25,.46,.45,.94)}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.phone-container .client-card-loading i{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.phone-container .control-button{transition:transform .12s cubic-bezier(.25,.46,.45,.94)}.phone-container .control-button:active{transform:scale(.92)}.phone-container .control-icon{transition:background-color .2s ease,transform .15s cubic-bezier(.25,.46,.45,.94)}.phone-container .control-button:active .control-icon{transform:scale(.95)}.phone-container .status-badge{transition:background-color .25s ease,color .25s ease,transform .12s cubic-bezier(.25,.46,.45,.94)}.phone-container .status-badge:active{transform:scale(.97)}.phone-container .pause-btn:active,.phone-container .resume-btn:active{transform:scale(.95)}.phone-container .modal-content{animation:modalSpring .4s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSpring{0%{transform:translateY(100%) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.phone-container .qualification-item{transition:background-color .15s ease}.phone-container .qualification-item:active{background:#007aff26}.phone-container .confirm-btn{transition:background-color .2s ease,transform .12s cubic-bezier(.25,.46,.45,.94)}.phone-container .confirm-btn:active:not(:disabled){transform:scale(.98)}.phone-container .nav-item{transition:color .2s ease,background-color .2s ease,transform .1s ease}.phone-container .nav-item:active{transform:scale(.95)}.phone-container .pause-option{transition:background-color .15s ease,border-color .15s ease,transform .12s cubic-bezier(.25,.46,.45,.94)}.phone-container .pause-option:active{transform:scale(.97);background:#f0f0f0}@supports (padding: max(0px)){.phone-container .bottom-nav{padding-bottom:max(20px,env(safe-area-inset-bottom,20px))}.phone-container .sheet-footer{padding-bottom:max(16px,calc(16px + env(safe-area-inset-bottom,0px)))}.phone-container .modal-content{padding-bottom:max(20px,calc(20px + env(safe-area-inset-bottom,0px)))}.phone-container .incall-actions{padding-bottom:max(16px,calc(16px + env(safe-area-inset-bottom,0px)))}}@media (prefers-reduced-motion: reduce){.phone-container *,.phone-container *:before,.phone-container *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
1
+ .phone-container,.phone-container *,.phone-container *:before,.phone-container *:after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;text-decoration:inherit}.phone-container a[x-apple-data-detectors],.phone-container [x-apple-data-detectors]{color:inherit!important;text-decoration:none!important;font-size:inherit!important;font-family:inherit!important;font-weight:inherit!important;line-height:inherit!important;pointer-events:none!important}.phone-container{--bg-color: #f2f2f7;--text-primary: #000;--text-secondary: #8e8e93;--key-bg: #fff;--key-shadow: rgba(0, 0, 0, .08);--call-green: #34c759;--call-red: #ff3b30;--nav-active: #007aff;--call-screen-bg: linear-gradient(180deg, #1c4a5c 0%, #0d2a35 100%)}.phone-container{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:var(--bg-color);display:flex;flex-direction:column;overflow:hidden}.phone-container .screen{flex:1 1 auto;min-height:0;display:none;flex-direction:column;overflow:hidden}.phone-container .screen.active{display:flex}.phone-container .dialer-screen{padding:0}.phone-container .dialer-screen .dialer-header{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;padding:8px 16px}.phone-container .dialer-screen .phone-number-display{flex:0 0 auto;min-height:60px;display:flex;align-items:center;justify-content:center;padding:8px 16px}.phone-container .dialer-screen .keypad{flex:1 1 auto;min-height:0;display:grid;grid-template-columns:repeat(3,80px);gap:14px;justify-content:center;align-content:center;padding:8px 0}.phone-container .dialer-screen .call-actions{flex:0 0 auto;display:flex;align-items:center;justify-content:center;padding:16px 24px;gap:40px}.phone-container .call-history-screen{background:var(--bg-color)}.phone-container .call-history-screen .history-header{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f2f2f7f0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:.5px solid rgba(0,0,0,.1)}.phone-container .header-title{font-size:17px;font-weight:600;color:#000;letter-spacing:-.4px}.phone-container .history-refresh-btn{width:32px;height:32px;border-radius:50%;background:transparent;border:none;color:#007aff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.phone-container .history-refresh-btn:active{transform:scale(.9);opacity:.6}.phone-container .history-refresh-btn:disabled{opacity:.4;cursor:not-allowed}.phone-container .call-history-screen .call-history-list{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;background:#fff}.phone-container .history-empty,.phone-container .history-loading,.phone-container .history-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;height:100%;padding:60px 20px;text-align:center;color:var(--text-secondary);font-size:16px;background:var(--bg-color)}.phone-container .history-empty i,.phone-container .history-loading i,.phone-container .history-error i{font-size:48px;opacity:.4}.phone-container .history-error{color:var(--call-red)}.phone-container .history-error i{opacity:.8}.phone-container .retry-btn{margin-top:8px;padding:12px 24px;background:#007aff;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s ease}.phone-container .retry-btn:active{transform:scale(.97);opacity:.9}.phone-container .history-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-bottom:.5px solid rgba(0,0,0,.08);transition:background .15s ease}.phone-container .history-item:active{background:#0000000a}.phone-container .history-arrow{width:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.phone-container .history-arrow svg{width:14px;height:14px}.phone-container .history-arrow.answered{color:#34c759}.phone-container .history-arrow.missed{color:#ff3b30}.phone-container .history-item-info{flex:1;min-width:0}.phone-container .history-item-number{font-size:17px;font-weight:400;color:#000;letter-spacing:-.4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.phone-container .history-item-number.missed{color:#ff3b30}.phone-container .history-item-meta{display:flex;align-items:center;gap:4px;margin-top:2px}.phone-container .history-item-type{font-size:13px;color:var(--text-secondary);font-weight:400}.phone-container .history-meta-dot{font-size:10px;color:var(--text-secondary)}.phone-container .history-item-datetime{font-size:13px;color:var(--text-secondary)}.phone-container .history-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.phone-container .history-action-btn{width:36px;height:36px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;font-size:16px}.phone-container .history-action-btn:active{transform:scale(.9)}.phone-container .history-action-btn.call-btn{background:#34c7591f;color:#34c759}.phone-container .history-action-btn.call-btn:active{background:#34c75940}.phone-container .history-action-btn.whatsapp-btn{background:#25d3661f;color:#25d366}.phone-container .history-action-btn.whatsapp-btn:active{background:#25d36640}.phone-container .history-item-time{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.phone-container .history-item-date{font-size:12px;color:var(--text-secondary)}.phone-container .history-item-hour{font-size:13px;color:var(--text-secondary);font-weight:500}.phone-container .call-screen{background:linear-gradient(180deg,#1a5a6e,#0f3d4a,#0a2830);color:#fff;flex:1 1 0;min-height:0}.phone-container .call-screen .call-info{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;align-items:center;padding:20px 16px 16px;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.phone-container .call-screen .call-info::-webkit-scrollbar{display:none}.phone-container .call-screen .call-controls{flex:0 0 auto;display:flex;flex-direction:column;gap:20px;padding:16px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.phone-container .incall-keypad-screen{background:linear-gradient(180deg,#1a5a6e,#0f3d4a,#0a2830);color:#fff}.phone-container .incall-keypad-screen .incall-header{flex:0 0 auto;display:flex;justify-content:flex-end;padding:10px 16px}.phone-container .incall-keypad-screen .incall-number-display{flex:0 0 auto;height:40px;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:300;letter-spacing:2px}.phone-container .incall-keypad-screen .keypad{flex:1 1 auto;min-height:0}.phone-container .incall-keypad-screen .incall-actions{flex:0 0 auto;display:flex;justify-content:center;padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.phone-container .bottom-nav{flex:0 0 auto;display:flex;justify-content:space-around;padding:8px 12px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px));background:#f2f2f7f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:.5px solid rgba(0,0,0,.08)}.phone-container .bottom-nav.hidden{display:none}.phone-container .nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-secondary);font-size:10px;cursor:pointer;padding:6px 16px;border-radius:10px;transition:background .2s}.phone-container .nav-item.active{color:var(--nav-active);background:#007aff1a}.phone-container .nav-icon{position:relative;font-size:22px}.phone-container .badge{position:absolute;top:-6px;right:-10px;background:var(--call-red);color:#fff;font-size:11px;font-weight:600;padding:1px 5px;border-radius:10px;min-width:18px;text-align:center}.phone-container .status-container{display:flex;align-items:center}.phone-container .status-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;border:none;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.phone-container .status-badge.available{background:#34c75926;color:#30d158}.phone-container .status-badge.paused{background:#ff9f0a26;color:#ff9f0a}.phone-container .status-badge.error{background:#ff3b3026;color:#ff3b30}.phone-container .status-info{display:flex;align-items:center;gap:0}.phone-container .pause-timer{font-size:13px;font-weight:500;opacity:.9;font-variant-numeric:tabular-nums;margin-left:6px;padding-left:6px;border-left:1px solid rgba(255,159,10,.35)}.phone-container .status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse-dot 2s ease-in-out infinite;flex-shrink:0}.phone-container .status-badge.paused .status-dot,.phone-container .status-badge.error .status-dot{animation:none}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.9)}}.phone-container .status-actions{display:flex;align-items:center;gap:8px}.phone-container .pause-btn,.phone-container .resume-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;border:none;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.phone-container .pause-btn{background:#ff9f0a26;color:#ff9f0a}.phone-container .resume-btn{background:#30d15826;color:#30d158}.phone-container .phone-input{width:100%;max-width:320px;font-size:34px;font-weight:300;letter-spacing:.5px;text-align:center;border:none;background:transparent;color:#000;outline:none;caret-color:#007aff;font-family:inherit}.phone-container .phone-input::placeholder{color:#c7c7cc}.phone-container .key{width:80px;height:80px;border-radius:50%;background:var(--key-bg);box-shadow:0 2px 8px var(--key-shadow),inset 0 -1px 2px #0000000d;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;user-select:none;-webkit-touch-callout:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;text-decoration:none!important}.phone-container .key:active{background:#d1d1d6;transform:scale(.95)}.phone-container .key .number{font-size:32px;font-weight:300;color:var(--text-primary);line-height:1;-webkit-touch-callout:none;-webkit-user-select:none;pointer-events:none;text-decoration:none!important;-webkit-text-decoration:none!important}.phone-container .key .letters{font-size:10px;font-weight:600;color:var(--text-primary);letter-spacing:1.5px;margin-top:2px;text-transform:uppercase;-webkit-touch-callout:none;-webkit-user-select:none;pointer-events:none;text-decoration:none!important;-webkit-text-decoration:none!important}.phone-container .call-button{width:70px;height:70px;border-radius:50%;background:var(--call-green);border:none;color:#fff;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;box-shadow:0 4px 15px #34c75966}.phone-container .call-button:disabled{opacity:.5;cursor:not-allowed}.phone-container .call-button:active:not(:disabled){transform:scale(.95)}.phone-container .delete-button{width:36px;height:36px;background:transparent;border:none;color:#666;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center}.phone-container .empty-space{width:36px}.phone-container .call-status{display:flex;align-items:center;gap:10px;font-size:16px;opacity:.95}.phone-container .operator-badge-small{background:linear-gradient(135deg,#34c759,#30b350);color:#fff;font-size:11px;font-weight:600;padding:3px 6px;border-radius:4px}.phone-container .call-number{font-size:32px;font-weight:300;margin-top:10px;letter-spacing:.5px}.phone-container .call-location{font-size:16px;opacity:.7;margin-top:6px}.phone-container .client-card{margin-top:20px;margin-bottom:20px;width:calc(100% - 32px);max-width:360px;background:#ffffff1f;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;padding:16px;border:1px solid rgba(255,255,255,.1);box-sizing:border-box;flex-shrink:0}.phone-container .client-card-header{display:flex;align-items:center;gap:14px}.phone-container .client-avatar{font-size:44px;color:#ffffffe6;flex-shrink:0;line-height:1}.phone-container .client-main-info{display:flex;flex-direction:column;align-items:flex-start;gap:2px;flex:1;min-width:0}.phone-container .client-name{font-size:17px;font-weight:600;color:#fff;letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.phone-container .client-company{font-size:14px;font-weight:400;color:#ffffffb3;letter-spacing:-.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.phone-container .client-card-divider{height:1px;background:#ffffff26;margin:14px 0}.phone-container .client-info-list{display:flex;flex-direction:column;gap:10px}.phone-container .client-info-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.phone-container .client-info-label{font-size:14px;font-weight:400;color:#fff9;letter-spacing:-.1px;flex-shrink:0}.phone-container .client-info-value{font-size:14px;font-weight:500;color:#fff;letter-spacing:-.1px;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}.phone-container .client-info-value.debt{color:#ff9f0a;font-weight:600}.phone-container .client-capital-section{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 0 4px}.phone-container .client-capital-label{font-size:12px;font-weight:400;color:#fff9;letter-spacing:-.1px;text-transform:uppercase}.phone-container .client-capital-value{font-size:24px;font-weight:600;color:#30d158;font-variant-numeric:tabular-nums;letter-spacing:-.3px}.phone-container .client-card-loading,.phone-container .client-card-error{display:flex;align-items:center;justify-content:center;gap:10px;padding:20px;color:#ffffffb3;font-size:14px}.phone-container .client-card-loading i{font-size:16px;color:#3b82f6}.phone-container .client-card-error{color:#ff6b6b}.phone-container .client-card-error i{font-size:16px}@media (max-width: 340px){.phone-container .client-card{margin-top:16px;padding:12px;border-radius:14px}.phone-container .client-avatar{font-size:36px}.phone-container .client-name{font-size:15px}.phone-container .client-company,.phone-container .client-info-label,.phone-container .client-info-value{font-size:12px}.phone-container .client-capital-label{font-size:11px}.phone-container .client-capital-value{font-size:20px}}.phone-container .control-row{display:flex;justify-content:space-between;align-items:center;padding:0 12px}.phone-container .control-row-center{justify-content:center;gap:40px}.phone-container .control-button{display:flex;flex-direction:column;align-items:center;gap:8px;background:transparent;border:none;color:#fff;cursor:pointer;font-size:11px;min-width:70px}.phone-container .control-icon{width:64px;height:64px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-size:24px;transition:all .2s ease}.phone-container .control-button.active .control-icon{background:#fff;color:#333}.phone-container .control-button.disabled{opacity:.4;cursor:not-allowed}.phone-container .control-button.disabled .control-icon{background:#ffffff1a}.phone-container .whatsapp-btn .control-icon{background:#25d366}.phone-container .end-call-button{width:64px;height:64px;border-radius:50%;background:var(--call-red);border:none;color:#fff;font-size:26px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #ff3b3066}.phone-container .end-call-wrapper{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:70px}.phone-container .end-call-label{color:#fff;font-size:11px}.phone-container .incall-keypad{display:grid;grid-template-columns:repeat(3,70px);gap:12px;justify-content:center;align-content:center;padding:10px 0}.phone-container .incall-key{width:70px;height:70px;background:#ffffff2e;box-shadow:none}.phone-container .incall-key .number,.phone-container .incall-key .letters{color:#fff}.phone-container .incall-key:active{background:#ffffff59}.phone-container .hide-keypad-btn{background:transparent;border:none;color:var(--nav-active);font-size:15px;cursor:pointer}.phone-container .header-title{font-size:17px;font-weight:600;color:#000}.phone-container .input-error{color:var(--call-red);font-size:13px;text-align:center;padding:8px}.phone-container .modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0006;display:none;align-items:flex-end;justify-content:center;z-index:1000;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.phone-container .modal-overlay.active{display:flex}.phone-container .modal-content{background:#fff;border-radius:20px 20px 0 0;width:100%;max-height:70%;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px));animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.phone-container .modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.phone-container .modal-title{font-size:20px;font-weight:600;color:var(--text-primary)}.phone-container .modal-close{width:32px;height:32px;border-radius:50%;background:#00000014;border:none;color:var(--text-secondary);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.phone-container .pause-options{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto;margin-bottom:16px}.phone-container .pause-option{display:flex;align-items:center;gap:14px;padding:14px 16px;background:#f8f8f8;border-radius:14px;cursor:pointer;transition:all .2s ease}.phone-container .pause-option:active{transform:scale(.98)}.phone-container .pause-option-icon{width:40px;height:40px;border-radius:50%;background:#fff;border:2px solid #ff9500;display:flex;align-items:center;justify-content:center;color:#ff9500;font-size:16px}.phone-container .pause-option-info{flex:1}.phone-container .pause-option-name{font-size:16px;font-weight:500;color:var(--text-primary)}.phone-container .pause-option-id{font-size:12px;color:var(--text-secondary);margin-top:2px}.phone-container .modal-cancel-btn{width:100%;padding:16px;background:#f2f2f7;border:none;border-radius:14px;font-size:17px;font-weight:500;color:var(--nav-active);cursor:pointer}.phone-container .qualification-modal{align-items:flex-end;background:#0000004d}.phone-container .qualification-sheet{background:#f2f2f7;border-radius:12px 12px 0 0;width:100%;max-height:85vh;display:flex;flex-direction:column;animation:sheetSlideUp .35s cubic-bezier(.2,.9,.3,1);overflow:hidden}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.phone-container .sheet-handle{width:36px;height:5px;background:#3c3c434d;border-radius:3px;margin:6px auto 0}.phone-container .sheet-header{padding:16px 20px 12px;text-align:center}.phone-container .sheet-title{display:block;font-size:17px;font-weight:600;color:#000}.phone-container .sheet-subtitle{display:block;font-size:13px;color:#8e8e93;margin-top:4px}.phone-container .result-segmented{display:flex;position:relative;background:#7676801f;border-radius:9px;padding:2px;margin:0 16px 16px}.phone-container .segment{flex:1;padding:7px 12px;font-size:13px;font-weight:500;color:#000;background:transparent;border:none;border-radius:7px;cursor:pointer;position:relative;z-index:1}.phone-container .segment.active{color:#000}.phone-container .segment-indicator{position:absolute;top:2px;left:2px;width:calc(50% - 2px);height:calc(100% - 4px);background:#fff;border-radius:7px;box-shadow:0 1px 3px #00000014;transition:transform .2s cubic-bezier(.4,0,.2,1)}.phone-container .segment[data-type=failure].active~.segment-indicator{transform:translate(100%)}.phone-container .qualifications-container{flex:1;overflow:hidden;padding:0 16px}.phone-container .qualification-list{display:flex;flex-direction:column;background:#ffffffd9;border-radius:14px;overflow-y:auto;max-height:300px}.phone-container .qualification-item{display:flex;align-items:center;justify-content:center;padding:18px 20px;background:transparent;border:none;border-bottom:.5px solid rgba(60,60,67,.18);cursor:pointer;font-size:17px;color:#007aff;text-align:center}.phone-container .qualification-item:last-child{border-bottom:none}.phone-container .qualification-item.selected{font-weight:600;background:#007aff14}.phone-container .sheet-footer{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.phone-container .confirm-btn{width:100%;padding:16px;background:#007aff;border:none;border-radius:12px;font-size:17px;font-weight:600;color:#fff;cursor:pointer}.phone-container .confirm-btn:disabled{background:#007aff66;cursor:not-allowed}@media (max-width: 340px){.phone-container .dialer-header{padding:6px 12px}.phone-container .status-badge{padding:5px 10px;font-size:11px}.phone-container .pause-btn span,.phone-container .resume-btn span{display:none}.phone-container .phone-input{font-size:28px}.phone-container .keypad{grid-template-columns:repeat(3,60px);gap:10px}.phone-container .key{width:60px;height:60px}.phone-container .key .number{font-size:26px}.phone-container .key .letters{font-size:8px}.phone-container .call-button{width:60px;height:60px;font-size:24px}.phone-container .call-actions{padding:12px 20px;gap:30px}.phone-container .bottom-nav{padding:6px 8px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.phone-container .nav-item{padding:4px 10px;font-size:9px}}@media (min-width: 341px) and (max-width: 380px){.phone-container .phone-input{font-size:30px}.phone-container .keypad{grid-template-columns:repeat(3,70px);gap:12px}.phone-container .key{width:70px;height:70px}.phone-container .key .number{font-size:28px}}@media (min-width: 600px){.phone-container .keypad{grid-template-columns:repeat(3,85px);gap:18px}.phone-container .key{width:85px;height:85px}.phone-container .key .number{font-size:36px}.phone-container .phone-input{font-size:40px}.phone-container .call-button{width:78px;height:78px;font-size:30px}}@media (min-width: 381px) and (max-width: 430px){.phone-container .phone-input{font-size:36px}.phone-container .keypad{grid-template-columns:repeat(3,75px);gap:14px}.phone-container .key{width:75px;height:75px}.phone-container .key .number{font-size:32px}.phone-container .call-button{width:70px;height:70px}}@media (min-width: 431px) and (max-width: 600px){.phone-container .phone-input{font-size:38px}.phone-container .keypad{grid-template-columns:repeat(3,80px);gap:16px}.phone-container .key{width:80px;height:80px}.phone-container .key .number{font-size:34px}.phone-container .call-button{width:74px;height:74px}}@media (min-width: 601px) and (max-width: 767px){.phone-container{max-width:414px;margin:0 auto}}@media (min-width: 768px){.phone-container{max-width:414px;margin:0 auto}}.phone-container .key{transition:transform .12s cubic-bezier(.25,.46,.45,.94),background-color .12s cubic-bezier(.25,.46,.45,.94);will-change:transform}.phone-container .key:active{transform:scale(.92);background:#d1d1d6}.phone-container .call-button,.phone-container .end-call-button{transition:transform .15s cubic-bezier(.25,.46,.45,.94),box-shadow .15s ease;will-change:transform}.phone-container .call-button:active:not(:disabled),.phone-container .end-call-button:active{transform:scale(.92)}.phone-container .client-card{animation:cardFadeIn .35s cubic-bezier(.25,.46,.45,.94)}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.phone-container .client-card-loading i{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.phone-container .control-button{transition:transform .12s cubic-bezier(.25,.46,.45,.94)}.phone-container .control-button:active{transform:scale(.92)}.phone-container .control-icon{transition:background-color .2s ease,transform .15s cubic-bezier(.25,.46,.45,.94)}.phone-container .control-button:active .control-icon{transform:scale(.95)}.phone-container .status-badge{transition:background-color .25s ease,color .25s ease,transform .12s cubic-bezier(.25,.46,.45,.94)}.phone-container .status-badge:active{transform:scale(.97)}.phone-container .pause-btn:active,.phone-container .resume-btn:active{transform:scale(.95)}.phone-container .modal-content{animation:modalSpring .4s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSpring{0%{transform:translateY(100%) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.phone-container .qualification-item{transition:background-color .15s ease}.phone-container .qualification-item:active{background:#007aff26}.phone-container .confirm-btn{transition:background-color .2s ease,transform .12s cubic-bezier(.25,.46,.45,.94)}.phone-container .confirm-btn:active:not(:disabled){transform:scale(.98)}.phone-container .nav-item{transition:color .2s ease,background-color .2s ease,transform .1s ease}.phone-container .nav-item:active{transform:scale(.95)}.phone-container .pause-option{transition:background-color .15s ease,border-color .15s ease,transform .12s cubic-bezier(.25,.46,.45,.94)}.phone-container .pause-option:active{transform:scale(.97);background:#f0f0f0}@supports (padding: max(0px)){.phone-container .bottom-nav{padding-bottom:max(20px,env(safe-area-inset-bottom,20px))}.phone-container .sheet-footer{padding-bottom:max(16px,calc(16px + env(safe-area-inset-bottom,0px)))}.phone-container .modal-content{padding-bottom:max(20px,calc(20px + env(safe-area-inset-bottom,0px)))}.phone-container .incall-actions{padding-bottom:max(16px,calc(16px + env(safe-area-inset-bottom,0px)))}}@media (prefers-reduced-motion: reduce){.phone-container *,.phone-container *:before,.phone-container *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
@@ -56496,8 +56496,28 @@ function AuthenticatedMobileDialer({
56496
56496
  setSpeakerSupported(false);
56497
56497
  return;
56498
56498
  }
56499
- const devices = await navigator.mediaDevices.enumerateDevices();
56500
- const audioOutputs = devices.filter((d) => d.kind === "audiooutput");
56499
+ let hasAudioPermission = false;
56500
+ let devices = await navigator.mediaDevices.enumerateDevices();
56501
+ let audioOutputs = devices.filter((d) => d.kind === "audiooutput");
56502
+ const hasLabels = audioOutputs.some((d) => d.label && d.label.length > 0);
56503
+ if (!hasLabels && audioOutputs.length > 0) {
56504
+ console.log("[MobileDialer] Labels vazios, solicitando permissão de áudio...");
56505
+ try {
56506
+ const stream = await navigator.mediaDevices.getUserMedia({
56507
+ audio: true
56508
+ // Em alguns navegadores, especificar mais detalhes pode ajudar
56509
+ });
56510
+ hasAudioPermission = true;
56511
+ stream.getTracks().forEach((track) => track.stop());
56512
+ devices = await navigator.mediaDevices.enumerateDevices();
56513
+ audioOutputs = devices.filter((d) => d.kind === "audiooutput");
56514
+ console.log("[MobileDialer] Permissão concedida. Dispositivos:", audioOutputs.length, audioOutputs);
56515
+ } catch (permError) {
56516
+ console.log("[MobileDialer] Usuário negou permissão de áudio:", permError);
56517
+ }
56518
+ } else {
56519
+ hasAudioPermission = true;
56520
+ }
56501
56521
  console.log("[MobileDialer] Dispositivos de saída encontrados:", audioOutputs.length, audioOutputs);
56502
56522
  if (audioOutputs.length <= 1) {
56503
56523
  console.log("[MobileDialer] Apenas um dispositivo de saída - viva-voz não disponível");
@@ -56973,10 +56993,21 @@ function AuthenticatedMobileDialer({
56973
56993
  const s = (callDurationSeconds % 60).toString().padStart(2, "0");
56974
56994
  return `${m}:${s}`;
56975
56995
  }, [callDurationSeconds]);
56976
- const renderKey = (value, letters) => /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "key", "data-value": value, onClick: () => handleDigit(value), children: [
56977
- /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "number", children: value }),
56978
- /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "letters", children: letters || " " })
56979
- ] }, value);
56996
+ const renderKey = (value, letters) => /* @__PURE__ */ jsxRuntimeExports.jsxs(
56997
+ "div",
56998
+ {
56999
+ className: "key",
57000
+ "data-value": value,
57001
+ onClick: () => handleDigit(value),
57002
+ role: "button",
57003
+ "aria-label": `Tecla ${value}`,
57004
+ children: [
57005
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "number", "aria-hidden": "true", children: value }),
57006
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "letters", "aria-hidden": "true", children: letters || " " })
57007
+ ]
57008
+ },
57009
+ value
57010
+ );
56980
57011
  return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "phone-container", children: [
56981
57012
  /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: `screen dialer-screen ${activeScreen === "dialer" ? "active" : ""}`, id: "dialerScreen", children: [
56982
57013
  /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "dialer-header", children: [
@@ -58416,6 +58447,17 @@ function setupPageUnloadCleanup() {
58416
58447
  }
58417
58448
  setupWebSocketInterceptor();
58418
58449
  setupPageUnloadCleanup();
58450
+ function setupIOSFormatDetection() {
58451
+ if (typeof document === "undefined") return;
58452
+ const existingMeta = document.querySelector('meta[name="format-detection"]');
58453
+ if (existingMeta) return;
58454
+ const meta = document.createElement("meta");
58455
+ meta.name = "format-detection";
58456
+ meta.content = "telephone=no, date=no, email=no, address=no";
58457
+ document.head.appendChild(meta);
58458
+ console.log("[Callix Dialer] ✅ iOS format-detection meta tag adicionada");
58459
+ }
58460
+ setupIOSFormatDetection();
58419
58461
  const DialerConfigContext = createContext(null);
58420
58462
  function useDialerConfig() {
58421
58463
  const context = useContext(DialerConfigContext);