callix-dialer-widget 2.0.0 → 2.0.1
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.
- package/dist-widget/README.md +251 -0
- package/dist-widget/dist-widget/callix-dialer.css +1 -0
- package/dist-widget/dist-widget/callix-dialer.es.js +58911 -0
- package/dist-widget/dist-widget/callix-dialer.es.js.map +1 -0
- package/dist-widget/dist-widget/callix-dialer.umd.js +27 -0
- package/dist-widget/dist-widget/callix-dialer.umd.js.map +1 -0
- package/dist-widget/dist-widget/test-cdn-widget.html +335 -0
- package/dist-widget/dist-widget/test-single-widget.html +324 -0
- package/dist-widget/package.json +61 -0
- package/package.json +61 -61
- /package/{README.md → WIDGET-README.md} +0 -0
|
@@ -0,0 +1,251 @@
|
|
|
1
|
+
# 📞 Callix Dialer Widget
|
|
2
|
+
|
|
3
|
+
Widget de discador telefônico para integração via CDN em qualquer site.
|
|
4
|
+
|
|
5
|
+
## 🚀 Quick Start (Uso Simples)
|
|
6
|
+
|
|
7
|
+
Adicione 2 linhas no seu HTML:
|
|
8
|
+
|
|
9
|
+
```html
|
|
10
|
+
<!-- 1. CSS do widget -->
|
|
11
|
+
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@callixbrasil/dialer-widget@1/dist-widget/callix-dialer.css">
|
|
12
|
+
|
|
13
|
+
<!-- 2. Container onde o widget vai aparecer -->
|
|
14
|
+
<div id="callix-dialer"></div>
|
|
15
|
+
|
|
16
|
+
<!-- 3. Script do widget -->
|
|
17
|
+
<script src="https://cdn.jsdelivr.net/npm/@callixbrasil/dialer-widget@1/dist-widget/callix-dialer.umd.js"></script>
|
|
18
|
+
|
|
19
|
+
<!-- 4. Inicialização -->
|
|
20
|
+
<script>
|
|
21
|
+
CallixDialer.init({
|
|
22
|
+
container: '#callix-dialer',
|
|
23
|
+
domain: 'villelabrasil.callix.com.br'
|
|
24
|
+
});
|
|
25
|
+
</script>
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
## 📦 Instalação
|
|
29
|
+
|
|
30
|
+
### Via CDN (Recomendado)
|
|
31
|
+
|
|
32
|
+
```html
|
|
33
|
+
<script src="https://cdn.jsdelivr.net/npm/@callixbrasil/dialer-widget@1.0.0/dist-widget/callix-dialer.umd.js"></script>
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
### Via NPM
|
|
37
|
+
|
|
38
|
+
```bash
|
|
39
|
+
npm install @callixbrasil/dialer-widget
|
|
40
|
+
# ou
|
|
41
|
+
pnpm add @callixbrasil/dialer-widget
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
```javascript
|
|
45
|
+
import { CallixDialerWidget } from '@callixbrasil/dialer-widget';
|
|
46
|
+
|
|
47
|
+
const widget = new CallixDialerWidget({
|
|
48
|
+
container: '#callix-dialer',
|
|
49
|
+
domain: 'villelabrasil.callix.com.br'
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
widget.init();
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
## ⚙️ Configuração
|
|
56
|
+
|
|
57
|
+
```javascript
|
|
58
|
+
CallixDialer.init({
|
|
59
|
+
// Container (obrigatório)
|
|
60
|
+
container: '#callix-dialer', // Seletor CSS ou HTMLElement
|
|
61
|
+
|
|
62
|
+
// Domínio Callix (obrigatório)
|
|
63
|
+
domain: 'villelabrasil.callix.com.br',
|
|
64
|
+
|
|
65
|
+
// URL da API (opcional, detecta automaticamente)
|
|
66
|
+
apiUrl: 'https://villelabrasil.callix.com.br',
|
|
67
|
+
|
|
68
|
+
// Tema (opcional)
|
|
69
|
+
theme: 'light', // 'light' ou 'dark'
|
|
70
|
+
|
|
71
|
+
// Posição (opcional)
|
|
72
|
+
position: 'bottom-right', // 'bottom-right' ou 'bottom-left'
|
|
73
|
+
|
|
74
|
+
// Callbacks (opcional)
|
|
75
|
+
onReady: function() {
|
|
76
|
+
console.log('Widget pronto!');
|
|
77
|
+
},
|
|
78
|
+
|
|
79
|
+
onError: function(error) {
|
|
80
|
+
console.error('Erro:', error);
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
```
|
|
84
|
+
|
|
85
|
+
## 🎨 Exemplos de Uso
|
|
86
|
+
|
|
87
|
+
### HTML Puro
|
|
88
|
+
|
|
89
|
+
```html
|
|
90
|
+
<!DOCTYPE html>
|
|
91
|
+
<html>
|
|
92
|
+
<head>
|
|
93
|
+
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@callixbrasil/dialer-widget@1/dist-widget/callix-dialer.css">
|
|
94
|
+
</head>
|
|
95
|
+
<body>
|
|
96
|
+
<h1>Meu Site</h1>
|
|
97
|
+
<div id="dialer"></div>
|
|
98
|
+
|
|
99
|
+
<script src="https://cdn.jsdelivr.net/npm/@callixbrasil/dialer-widget@1/dist-widget/callix-dialer.umd.js"></script>
|
|
100
|
+
<script>
|
|
101
|
+
CallixDialer.init({
|
|
102
|
+
container: '#dialer',
|
|
103
|
+
domain: 'villelabrasil.callix.com.br'
|
|
104
|
+
});
|
|
105
|
+
</script>
|
|
106
|
+
</body>
|
|
107
|
+
</html>
|
|
108
|
+
```
|
|
109
|
+
|
|
110
|
+
### WordPress
|
|
111
|
+
|
|
112
|
+
```php
|
|
113
|
+
<?php
|
|
114
|
+
// functions.php ou plugin
|
|
115
|
+
|
|
116
|
+
function add_callix_dialer() {
|
|
117
|
+
// Adicionar CSS
|
|
118
|
+
wp_enqueue_style(
|
|
119
|
+
'callix-dialer',
|
|
120
|
+
'https://cdn.jsdelivr.net/npm/@callixbrasil/dialer-widget@1/dist-widget/callix-dialer.css'
|
|
121
|
+
);
|
|
122
|
+
|
|
123
|
+
// Adicionar JS
|
|
124
|
+
wp_enqueue_script(
|
|
125
|
+
'callix-dialer',
|
|
126
|
+
'https://cdn.jsdelivr.net/npm/@callixbrasil/dialer-widget@1/dist-widget/callix-dialer.umd.js',
|
|
127
|
+
array(),
|
|
128
|
+
'1.0.0',
|
|
129
|
+
true
|
|
130
|
+
);
|
|
131
|
+
|
|
132
|
+
// Inicializar
|
|
133
|
+
wp_add_inline_script('callix-dialer', '
|
|
134
|
+
CallixDialer.init({
|
|
135
|
+
container: "#callix-dialer-container",
|
|
136
|
+
domain: "' . get_option('callix_domain') . '"
|
|
137
|
+
});
|
|
138
|
+
');
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
add_action('wp_enqueue_scripts', 'add_callix_dialer');
|
|
142
|
+
|
|
143
|
+
// Adicionar container no footer
|
|
144
|
+
function add_callix_dialer_container() {
|
|
145
|
+
echo '<div id="callix-dialer-container"></div>';
|
|
146
|
+
}
|
|
147
|
+
add_action('wp_footer', 'add_callix_dialer_container');
|
|
148
|
+
```
|
|
149
|
+
|
|
150
|
+
### React/Next.js
|
|
151
|
+
|
|
152
|
+
```tsx
|
|
153
|
+
import { useEffect, useRef } from 'react';
|
|
154
|
+
|
|
155
|
+
export function CallixDialerWidget() {
|
|
156
|
+
const containerRef = useRef<HTMLDivElement>(null);
|
|
157
|
+
const widgetRef = useRef<any>(null);
|
|
158
|
+
|
|
159
|
+
useEffect(() => {
|
|
160
|
+
// Carregar script dinamicamente
|
|
161
|
+
const script = document.createElement('script');
|
|
162
|
+
script.src = 'https://cdn.jsdelivr.net/npm/@callixbrasil/dialer-widget@1/dist-widget/callix-dialer.umd.js';
|
|
163
|
+
script.async = true;
|
|
164
|
+
|
|
165
|
+
script.onload = () => {
|
|
166
|
+
if (containerRef.current && (window as any).CallixDialer) {
|
|
167
|
+
widgetRef.current = (window as any).CallixDialer.init({
|
|
168
|
+
container: containerRef.current,
|
|
169
|
+
domain: 'villelabrasil.callix.com.br'
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
};
|
|
173
|
+
|
|
174
|
+
document.body.appendChild(script);
|
|
175
|
+
|
|
176
|
+
return () => {
|
|
177
|
+
if (widgetRef.current) {
|
|
178
|
+
widgetRef.current.destroy();
|
|
179
|
+
}
|
|
180
|
+
document.body.removeChild(script);
|
|
181
|
+
};
|
|
182
|
+
}, []);
|
|
183
|
+
|
|
184
|
+
return <div ref={containerRef} />;
|
|
185
|
+
}
|
|
186
|
+
```
|
|
187
|
+
|
|
188
|
+
## 🔧 API
|
|
189
|
+
|
|
190
|
+
### `CallixDialer.init(options)`
|
|
191
|
+
|
|
192
|
+
Inicializa o widget e retorna uma instância.
|
|
193
|
+
|
|
194
|
+
**Retorno:** `CallixDialerWidget`
|
|
195
|
+
|
|
196
|
+
### `widget.destroy()`
|
|
197
|
+
|
|
198
|
+
Remove o widget do DOM e limpa recursos.
|
|
199
|
+
|
|
200
|
+
```javascript
|
|
201
|
+
const widget = CallixDialer.init({ container: '#dialer' });
|
|
202
|
+
// ... usar widget
|
|
203
|
+
widget.destroy(); // Remover quando não precisar mais
|
|
204
|
+
```
|
|
205
|
+
|
|
206
|
+
## 🌐 CDN Disponíveis
|
|
207
|
+
|
|
208
|
+
- **jsDelivr** (Recomendado): `https://cdn.jsdelivr.net/npm/@callixbrasil/dialer-widget@1`
|
|
209
|
+
- **unpkg**: `https://unpkg.com/@callixbrasil/dialer-widget@1`
|
|
210
|
+
|
|
211
|
+
## 📝 Versionamento
|
|
212
|
+
|
|
213
|
+
Suportamos [Semantic Versioning](https://semver.org/):
|
|
214
|
+
|
|
215
|
+
- `@1` - Última versão v1.x.x (recomendado)
|
|
216
|
+
- `@1.0` - Última versão v1.0.x
|
|
217
|
+
- `@1.0.0` - Versão exata (fixar versão)
|
|
218
|
+
|
|
219
|
+
## 🐛 Troubleshooting
|
|
220
|
+
|
|
221
|
+
### Widget não aparece
|
|
222
|
+
|
|
223
|
+
1. Verifique o console do navegador
|
|
224
|
+
2. Confirme que o container existe no DOM
|
|
225
|
+
3. Verifique se o CSS foi carregado
|
|
226
|
+
|
|
227
|
+
```javascript
|
|
228
|
+
// Debug
|
|
229
|
+
console.log('CallixDialer disponível?', typeof CallixDialer);
|
|
230
|
+
console.log('Container existe?', document.querySelector('#callix-dialer'));
|
|
231
|
+
```
|
|
232
|
+
|
|
233
|
+
### Conflitos de CSS
|
|
234
|
+
|
|
235
|
+
Se houver conflitos, use um container isolado:
|
|
236
|
+
|
|
237
|
+
```html
|
|
238
|
+
<div style="all: initial;">
|
|
239
|
+
<div id="callix-dialer"></div>
|
|
240
|
+
</div>
|
|
241
|
+
```
|
|
242
|
+
|
|
243
|
+
## 📄 Licença
|
|
244
|
+
|
|
245
|
+
MIT
|
|
246
|
+
|
|
247
|
+
## 🤝 Suporte
|
|
248
|
+
|
|
249
|
+
- 📧 Email: suporte@callixbrasil.com.br
|
|
250
|
+
- 📚 Docs: https://docs.callixbrasil.com.br
|
|
251
|
+
- 🐛 Issues: https://github.com/callixbrasil/dialer-widget/issues
|
|
@@ -0,0 +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}}
|