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.
@@ -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}}