/*
 * Copyright 2026 Kroonen AI, Inc.
 * https://kroonen.ai
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
*{box-sizing:border-box;margin:0;padding:0}:root{--bg-base:#000;--bg-surface:#0a0a0af2;--bg-elevated:#0a0a0a;--bg-hover:#141414;--bg-active:#1a1a1a;--text-primary:#fafafa;--text-secondary:#a1a1aa;--text-muted:#71717a;--border-default:#ffffff14;--border-subtle:#ffffff0d;--accent:#8b5cf6;--accent-hover:#7c3aed;--accent-contrast:#fff;--accent-contrast-muted:#ffffffbd;--primary:#8b5cf6;--primary-hover:#7c3aed;--success:#22c55e;--success-muted:#22c55e26;--warning:#d97706;--warning-muted:#f59e0b26;--danger:#ef4444;--danger-muted:#ef444426;--accent-muted:#8b5cf626;--mobile-tabs-height:79px;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 24px #0009}[data-theme=light]{--bg-base:#fff;--bg-surface:#fffffff2;--bg-elevated:#fafafa;--bg-hover:#f4f4f5;--bg-active:#e4e4e7;--text-primary:#0a0a0a;--text-secondary:#525252;--text-muted:#a1a1aa;--border-default:#00000014;--border-subtle:#0000000d;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001f}body{background:var(--bg-base);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:background-color .15s,color .15s;overflow:hidden}.app{max-width:1400px;height:100vh;margin:0 auto;display:flex}.sidebar{background:var(--bg-elevated);border-right:1px solid var(--border-default);flex-direction:column;width:380px;min-width:380px;transition:background-color .15s,border-color .15s;display:flex}.sidebar-header{border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;padding:20px;display:flex}.sidebar-header-left{flex-direction:column;display:flex}.sidebar-header-right{align-items:center;gap:8px;display:flex}.sidebar-header h1{letter-spacing:-.02em;color:var(--text-primary);font-family:Inter,system-ui,sans-serif;font-size:1.125rem;font-weight:600}.my-number{color:var(--text-secondary);margin-top:4px;font-size:.75rem}.line-select,.modal-select,.compose-line-select,.dial-line-select{border:1px solid var(--border-default);background:var(--bg-base);color:var(--text-primary);font-family:inherit;transition:border-color .15s,background-color .15s}.line-select{border-radius:6px;max-width:160px;margin-top:6px;padding:4px 8px;font-size:.75rem}.line-select:focus,.modal-select:focus,.compose-line-select:focus,.dial-line-select:focus{border-color:var(--accent);outline:none}.theme-toggle{border:1px solid var(--border-default);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.theme-toggle:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-default)}.theme-toggle svg{width:18px;height:18px}.theme-toggle .sun-icon{display:none}.theme-toggle .moon-icon,[data-theme=light] .theme-toggle .sun-icon{display:block}[data-theme=light] .theme-toggle .moon-icon{display:none}.tabs{border-bottom:none;flex-direction:column;gap:2px;padding:8px;display:flex}.tab{color:var(--text-secondary);cursor:pointer;white-space:nowrap;text-align:left;letter-spacing:-.01em;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;padding:8px 12px;font-size:.8125rem;font-weight:400;transition:background .1s;display:flex;position:relative}.tab-icon{opacity:.7;flex-shrink:0;width:18px;height:18px}.tab-label{flex:1}.tab.active{color:var(--text-primary);background:var(--bg-active);font-weight:500}.tab.active .tab-icon{opacity:1;color:var(--accent)}.tab:hover:not(.active){background:var(--bg-hover)}.mobile-tabs{display:none}@media (width<=768px){.sidebar .tabs{display:none}.mobile-tabs{z-index:200;display:block;position:fixed;bottom:0;left:0;right:0}.mobile-tabs .tabs{border-bottom:none;border-top:1px solid var(--border-default);background:var(--bg-elevated);flex-direction:row;justify-content:space-around;gap:0;padding:0}.mobile-tabs .tab{text-align:center;border-radius:0;flex-direction:column;flex:1;justify-content:center;gap:4px;padding:10px 4px 8px}.mobile-tabs .tab-icon{width:24px;height:24px}.mobile-tabs .tab-label{font-size:.625rem;font-weight:400}.mobile-tabs .voicemail-badge{border-radius:999px;min-width:18px;height:18px;margin-left:0;padding:0 5px}.mobile-tabs .tab.active{background:0 0}.mobile-tabs .tab.active:before{display:none}.mobile-tabs .tab:hover:not(.active){background:0 0}}.conversations-list{flex:1;overflow-y:auto}.conversation-item{border-bottom:1px solid var(--border-subtle);cursor:pointer;padding:16px 20px;transition:background .15s}.conversation-item:hover{background:var(--bg-hover)}.conversation-item.active{background:var(--bg-active);border-left:3px solid var(--accent)}.conversation-header{justify-content:space-between;margin-bottom:4px;display:flex}.conversation-name{font-weight:500}.conversation-time{color:var(--text-muted);font-size:.75rem}.conversation-preview{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;overflow:hidden}.main{background:var(--bg-base);flex-direction:column;flex:1;transition:background-color .15s;display:flex}.chat-header{border-bottom:1px solid var(--border-default);background:var(--bg-elevated);justify-content:space-between;align-items:center;padding:16px 24px;transition:background-color .15s,border-color .15s;display:flex}.chat-header-left{align-items:center;display:flex}.chat-contact{font-size:1.125rem;font-weight:500}.chat-actions{gap:8px;display:flex}.icon-btn{background:var(--bg-hover);border:1px solid var(--border-default);width:40px;height:40px;color:var(--text-primary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1.25rem;transition:all .15s;display:flex}.icon-btn:hover{background:var(--accent);border-color:var(--accent)}.icon-btn.call{background:var(--success);border-color:var(--success)}.icon-btn.hangup,.icon-btn.danger:hover{background:var(--danger);border-color:var(--danger)}.delete-confirm-banner{background:var(--danger-muted);border-bottom:1px solid var(--danger);color:var(--text-primary);justify-content:space-between;align-items:center;padding:12px 24px;font-size:.875rem;display:flex}.delete-confirm-actions{gap:8px;display:flex}.btn-cancel,.btn-delete{cursor:pointer;border:none;border-radius:6px;padding:6px 16px;font-size:.8125rem;font-weight:500;transition:all .15s}.btn-cancel{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-default)}.btn-cancel:hover{background:var(--bg-active)}.btn-delete{background:var(--danger);color:#fff}.btn-delete:hover{opacity:.9}.messages{flex-direction:column;flex:1;gap:12px;padding:24px;display:flex;overflow-y:auto}.message{border-radius:16px;max-width:70%;padding:12px 16px;font-size:.9375rem;line-height:1.4}.message.inbound{background:var(--bg-elevated);border:1px solid var(--border-default);border-bottom-left-radius:4px;align-self:flex-start}.message.outbound{background:var(--accent);color:var(--accent-contrast);border-bottom-right-radius:4px;align-self:flex-end}.message-time{color:var(--text-muted);margin-top:4px;font-size:.7rem}.message-line{align-items:center;gap:5px;margin-right:8px;display:inline-flex}.line-color-dot{background:var(--line-color,var(--accent));border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block;box-shadow:inset 0 0 0 1px #ffffff47}.message.outbound .message-time{color:var(--accent-contrast-muted)}.compose{border-top:1px solid var(--border-default);background:var(--bg-elevated);gap:12px;padding:16px 24px;transition:background-color .15s,border-color .15s;display:flex}.compose input{border:1px solid var(--border-default);background:var(--bg-base);min-width:0;color:var(--text-primary);border-radius:24px;flex:1;padding:12px 16px;font-size:.9375rem;transition:all .15s}.compose input:focus{border-color:var(--accent);outline:none}.compose-line-select{border-radius:20px;flex-shrink:0;width:142px;padding:9px 10px;font-size:.8125rem}.compose button{background:var(--accent);color:var(--accent-contrast);cursor:pointer;border:none;border-radius:24px;padding:12px 24px;font-weight:500;transition:all .15s}.compose button:hover{background:var(--accent-hover)}.compose-wrapper{flex:1;align-items:center;gap:8px;min-width:0;display:flex;position:relative}.emoji-btn{background:var(--bg-hover);border:1px solid var(--border-default);width:40px;height:40px;color:var(--text-primary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.25rem;transition:all .15s;display:flex}.emoji-btn:hover{background:var(--bg-active)}.emoji-picker{background:var(--bg-elevated);border:1px solid var(--border-default);z-index:50;width:min(420px,100vw - 48px);height:min(410px,58vh);box-shadow:var(--shadow-lg);backdrop-filter:blur(18px);border-radius:22px;padding:12px;transition:background-color .15s,border-color .15s;display:none;position:absolute;bottom:calc(100% + 10px);left:0;overflow:hidden}.emoji-picker.active{flex-direction:column;display:flex}.emoji-toolbar{align-items:center;gap:8px;margin-bottom:10px;display:flex}.emoji-search-wrap{flex:1;min-width:0;position:relative}.emoji-search-icon{width:16px;height:16px;color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.emoji-picker .emoji-close-btn{background:var(--bg-hover);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-weight:400;display:flex}.emoji-picker .emoji-close-btn:hover{background:var(--bg-active);color:var(--text-primary)}.emoji-picker .emoji-close-btn svg{width:18px;height:18px}.emoji-picker-header{border-bottom:1px solid var(--border-subtle);scrollbar-width:none;gap:6px;margin:0 -2px 10px;padding:0 2px 10px;display:flex;overflow-x:auto}.emoji-picker-header::-webkit-scrollbar{display:none}.emoji-grid::-webkit-scrollbar{display:none}.emoji-picker .emoji-category-btn{width:40px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:18px;flex-shrink:0;padding:0;font-size:1.15rem;font-weight:400;transition:all .15s}.emoji-picker .emoji-category-btn.active{background:var(--accent);color:var(--accent-contrast)}.emoji-picker .emoji-category-btn:hover:not(.active){background:var(--bg-hover)}.emoji-section-title{color:var(--text-secondary);letter-spacing:.02em;text-transform:uppercase;margin:0 2px 8px;font-size:.75rem;font-weight:600}.emoji-grid{overscroll-behavior:contain;scrollbar-width:none;grid-template-columns:repeat(auto-fill,minmax(42px,1fr));gap:6px;padding:2px 0 4px;display:grid;overflow-y:auto}.emoji-picker .emoji-item{cursor:pointer;width:42px;height:42px;color:var(--text-primary);background:0 0;border:none;border-radius:12px;justify-content:center;justify-self:center;align-items:center;padding:0;font-size:1.4rem;font-weight:400;transition:background .15s,transform .12s;display:flex}.emoji-picker .emoji-item:hover{background:var(--bg-hover)}.emoji-picker .emoji-item:active{transform:scale(.92)}.emoji-picker .emoji-search{border:1px solid var(--border-default);background:var(--bg-base);width:100%;color:var(--text-primary);border-radius:18px;padding:10px 14px 10px 38px;font-size:.875rem;transition:all .15s}.emoji-picker .emoji-search::placeholder{color:var(--text-muted)}.emoji-picker .emoji-search:focus{border-color:var(--accent);outline:none}[data-theme=light] .emoji-picker{box-shadow:0 -12px 36px #00000024}.emoji-empty{color:var(--text-muted);text-align:center;grid-column:1/-1;padding:32px 0;font-size:.875rem}.modal-overlay{backdrop-filter:blur(4px);z-index:100;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal,.modal-content{background:var(--bg-elevated);border:1px solid var(--border-default);width:90%;max-width:400px;box-shadow:var(--shadow-lg);border-radius:16px;padding:24px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{margin:0;font-size:1.25rem}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-close svg{width:20px;height:20px}.modal-body{margin-bottom:20px}.modal-footer{justify-content:flex-end;gap:12px;display:flex}.modal-btn{cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-weight:500;transition:all .15s}.modal-btn.secondary{background:var(--bg-hover);border:1px solid var(--border-default);color:var(--text-primary)}.modal-btn.secondary:hover{background:var(--bg-active)}.modal-btn.primary{background:var(--accent);color:#fff}.modal-btn.primary:hover:not(:disabled){background:var(--accent-hover)}.modal-btn:disabled{opacity:.5;cursor:not-allowed}.modal h2{margin-bottom:16px}.modal input{border:1px solid var(--border-default);background:var(--bg-base);width:100%;color:var(--text-primary);border-radius:8px;margin-bottom:12px;padding:12px;transition:all .15s}.modal input:focus{border-color:var(--accent);outline:none}.modal-select{border-radius:8px;width:100%;margin-bottom:12px;padding:12px}.modal-actions{justify-content:flex-end;gap:12px;display:flex}.modal-actions button{cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-weight:500;transition:all .15s}.modal-actions .cancel{background:var(--bg-hover);border:1px solid var(--border-default);color:var(--text-primary)}.modal-actions .cancel:hover{background:var(--bg-active)}.modal-actions .confirm{background:var(--accent);color:#fff}.modal-actions .confirm:hover{background:var(--accent-hover)}.empty-state{color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.empty-state-icon{opacity:.5;margin-bottom:16px;font-size:4rem}.empty-state h2{color:var(--text-primary);margin-bottom:6px;font-size:1.1rem;font-weight:600}.empty-state p{text-align:center;max-width:320px;line-height:1.5}.ai-summary-btn{letter-spacing:0;border-radius:12px;width:44px;font-size:.75rem;font-weight:700}.ai-summary-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.ai-summary-panel{border:1px solid var(--border-default);background:var(--bg-elevated);box-shadow:var(--shadow-sm);border-radius:8px;margin:12px 24px 0;padding:14px}.ai-summary-header,.ai-draft-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.ai-summary-eyebrow{color:var(--text-muted);text-transform:uppercase;letter-spacing:0;margin-bottom:2px;font-size:.7rem;display:block}.ai-summary-header h2{font-size:.95rem;font-weight:600}.ai-summary-provider{background:var(--accent-muted);color:var(--accent);border-radius:999px;padding:4px 8px;font-size:.7rem;font-weight:600}.ai-summary-loading,.ai-summary-error,.ai-summary-text{color:var(--text-secondary);margin-top:12px;font-size:.875rem;line-height:1.5}.ai-summary-error{color:var(--danger)}.ai-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px;display:grid}.ai-summary-grid>div,.ai-draft-box{border:1px solid var(--border-subtle);background:var(--bg-base);border-radius:8px;padding:10px}.ai-summary-grid span,.ai-draft-header span{color:var(--text-muted);text-transform:uppercase;letter-spacing:0;margin-bottom:4px;font-size:.72rem;font-weight:600;display:block}.ai-summary-grid p,.ai-draft-box p{color:var(--text-primary);font-size:.84rem;line-height:1.45}.ai-draft-box{margin-top:10px}.ai-copy-btn{border:1px solid var(--border-default);background:var(--bg-hover);color:var(--text-primary);cursor:pointer;border-radius:6px;padding:5px 8px;font-size:.75rem}.ai-copy-btn:hover{background:var(--bg-active)}.dialpad{flex-direction:column;align-items:center;gap:16px;padding:24px;display:none}.dialpad.active{display:flex}.dial-display{text-align:center;width:100%;max-width:280px;min-height:48px;font-size:2rem;font-weight:300}.dial-display-input{text-align:center;width:100%;max-width:280px;min-height:48px;color:var(--text-primary);background:0 0;border:none;outline:none;font-family:inherit;font-size:2rem;font-weight:300}.dial-display-input::placeholder{color:var(--text-muted);font-size:1.25rem}.dial-line-select{border-radius:8px;width:220px;padding:10px 12px;font-size:.875rem}.dial-grid{grid-template-columns:repeat(3,80px);gap:12px;display:grid}.dial-btn{background:var(--bg-elevated);border:1px solid var(--border-default);width:80px;height:80px;color:var(--text-primary);cursor:pointer;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;font-size:1.5rem;transition:all .15s;display:flex}.dial-btn:hover{background:var(--bg-hover)}.dial-btn small{color:var(--text-muted);letter-spacing:2px;font-size:.6rem}.dial-btn.call-btn{background:var(--success);border-color:var(--success)}.dial-btn.call-btn:hover{background:#16a34a}.loading{color:var(--text-secondary);justify-content:center;align-items:center;padding:20px;display:flex}.call-filters{border-bottom:1px solid var(--border-default);gap:8px;padding:12px 16px;display:flex}.filter-btn{background:var(--bg-hover);border:1px solid var(--border-default);color:var(--text-secondary);cursor:pointer;border-radius:16px;padding:6px 12px;font-size:.75rem;transition:all .15s}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.filter-btn:hover:not(.active){background:var(--bg-active);color:var(--text-primary)}.call-search{background:var(--bg-base);border:1px solid var(--border-default);color:var(--text-primary);border-radius:16px;flex:1;padding:6px 12px;font-size:.75rem;transition:all .15s}.call-search:focus{border-color:var(--accent);outline:none}.call-item{border-bottom:1px solid var(--border-subtle);cursor:pointer;align-items:center;gap:12px;padding:14px 16px;transition:background .15s;display:flex}.call-item:hover{background:var(--bg-hover)}.call-item.active{background:var(--bg-active);border-left:3px solid var(--accent)}.call-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;display:flex}.call-icon.inbound{background:var(--success-muted)}.call-icon.outbound{background:var(--accent-muted)}.call-icon.missed{background:var(--danger-muted)}.call-info{flex:1;min-width:0}.call-contact{white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.call-meta{color:var(--text-secondary);flex-wrap:wrap;gap:8px;min-width:0;margin-top:2px;font-size:.75rem;display:flex}.call-status{align-items:center;gap:4px;display:inline-flex}.call-status.completed{color:var(--success)}.call-status.missed,.call-status.no-answer,.call-status.busy,.call-status.failed,.call-status.blocked{color:var(--danger)}.call-duration{color:var(--text-secondary)}.call-line{color:var(--text-muted);align-items:center;gap:5px;display:inline-flex}.call-time{color:var(--text-muted);white-space:nowrap;font-size:.75rem}.call-detail{flex-direction:column;height:100%;display:flex;overflow-y:auto}.call-detail-header{text-align:center;border-bottom:1px solid var(--border-default);padding:32px 0}.call-detail-icon{border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 16px;font-size:2.5rem;display:flex}.call-detail-icon.inbound{background:var(--success-muted)}.call-detail-icon.outbound{background:var(--accent-muted)}.call-detail-icon.missed{background:var(--danger-muted)}.call-detail-contact{margin-bottom:4px;font-size:1.5rem;font-weight:600}.call-detail-number{color:var(--text-secondary);font-size:.9rem}.call-detail-info{flex:1;padding:24px}.call-detail-row{border-bottom:1px solid var(--border-subtle);justify-content:space-between;padding:12px 0;display:flex}.call-detail-label{color:var(--text-secondary)}.call-detail-value{font-weight:500}.line-detail-value{align-items:center;gap:6px;display:inline-flex}.call-detail-actions{gap:12px;padding:16px 24px 24px;display:flex}.call-action-btn{cursor:pointer;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px;font-weight:500;transition:all .15s;display:flex}.call-action-btn.primary{background:var(--success);color:#fff}.call-action-btn.secondary{background:var(--bg-hover);border:1px solid var(--border-default);color:var(--text-primary)}.call-action-btn:hover{opacity:.9}.settings-container{height:100%;padding:20px;overflow-y:auto}.settings-section{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:12px;margin-bottom:16px;padding:20px}.settings-section h3{align-items:center;gap:8px;margin-bottom:16px;font-size:1rem;font-weight:600;display:flex}.settings-section-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.settings-section-header h3{margin-bottom:0}.settings-alert{border:1px solid var(--danger);background:var(--danger-muted);color:var(--text-primary);border-radius:8px;margin-bottom:14px;padding:12px 14px;font-size:.875rem}.settings-row{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:12px 0;display:flex}.settings-row:last-child{border-bottom:none}.settings-label{flex-direction:column;gap:2px;display:flex}.settings-label span{font-size:.875rem;font-weight:500}.settings-label small{color:var(--text-muted);font-size:.75rem}.toggle-switch{width:48px;height:26px;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:var(--bg-active);border-radius:26px;transition:all .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--text-primary);border-radius:50%;width:20px;height:20px;transition:all .2s;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.toggle-slider{background:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.settings-input{border:1px solid var(--border-default);background:var(--bg-base);width:100%;color:var(--text-primary);border-radius:8px;margin-top:8px;padding:10px 12px;font-size:.875rem;transition:all .15s}.settings-input:focus{border-color:var(--accent);outline:none}.settings-textarea{border:1px solid var(--border-default);background:var(--bg-base);width:100%;color:var(--text-primary);resize:vertical;border-radius:8px;min-height:60px;margin-top:8px;padding:10px 12px;font-family:inherit;font-size:.875rem;transition:all .15s}.settings-textarea:focus{border-color:var(--accent);outline:none}.settings-select{border:1px solid var(--border-default);background:var(--bg-base);color:var(--text-primary);cursor:pointer;border-radius:8px;padding:10px 12px;font-size:.875rem;transition:all .15s}.settings-select:focus{border-color:var(--accent);outline:none}.settings-btn{cursor:pointer;border:none;border-radius:8px;padding:10px 16px;font-size:.875rem;font-weight:500;transition:all .15s}.settings-btn.compact{padding:7px 12px;font-size:.75rem}.settings-btn.primary{background:var(--accent);color:#fff}.settings-btn.primary:hover{background:var(--accent-hover)}.settings-btn.secondary{background:var(--bg-hover);border:1px solid var(--border-default);color:var(--text-primary)}.settings-btn.secondary:hover{background:var(--bg-active)}.settings-btn.danger{background:var(--danger);color:#fff}.settings-btn.danger:hover{background:#dc2626}.settings-muted{color:var(--text-muted);font-size:.875rem}.appearance-segmented{background:var(--bg-base);border:1px solid var(--border-default);border-radius:10px;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;padding:4px;display:grid}.appearance-segmented button{color:var(--text-secondary);font:inherit;cursor:pointer;background:0 0;border:0;border-radius:7px;padding:10px 12px;font-size:.875rem;font-weight:500;transition:background .15s,color .15s}.appearance-segmented button:hover{color:var(--text-primary)}.appearance-segmented button.active{background:var(--accent);color:var(--accent-contrast)}.accent-grid{grid-template-columns:repeat(auto-fit,minmax(112px,1fr));gap:8px;display:grid}.accent-swatch{border:1px solid var(--border-default);background:var(--bg-base);min-height:42px;color:var(--text-secondary);font:inherit;cursor:pointer;border-radius:10px;align-items:center;gap:8px;padding:9px 10px;font-size:.8125rem;font-weight:500;transition:border-color .15s,background .15s,color .15s;display:flex}.accent-swatch span{background:var(--swatch-color);border-radius:50%;flex-shrink:0;width:18px;height:18px;box-shadow:inset 0 0 0 1px #ffffff40}.accent-swatch:hover,.accent-swatch.active{border-color:var(--swatch-color);background:var(--accent-muted);color:var(--text-primary)}.custom-color-row{border:1px solid var(--border-default);background:var(--bg-base);color:var(--text-secondary);border-radius:10px;justify-content:space-between;align-items:center;gap:12px;margin-top:14px;padding:12px;font-size:.875rem;font-weight:500;display:flex}.custom-color-row input,.line-color-picker input[type=color]{border:1px solid var(--border-default);cursor:pointer;background:0 0;border-radius:8px;width:42px;height:34px;padding:0}.appearance-preview{border:1px solid var(--border-default);background:var(--bg-base);border-radius:12px;margin-top:14px;padding:14px}.appearance-preview-header{color:var(--text-secondary);justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;font-size:.8125rem;font-weight:500;display:flex}.appearance-preview-header button{background:var(--accent);color:var(--accent-contrast);font:inherit;border:0;border-radius:8px;padding:7px 12px;font-size:.8125rem;font-weight:600}.appearance-preview-bubble{background:var(--accent);width:fit-content;max-width:100%;color:var(--accent-contrast);border-radius:16px 16px 4px;margin-left:auto;padding:11px 14px;font-size:.875rem}.line-identity-list{gap:12px;display:grid}.line-identity-card{border:1px solid var(--border-default);background:var(--bg-base);border-radius:12px;padding:14px}.line-identity-heading{align-items:center;gap:10px;margin-bottom:12px;display:flex}.line-identity-heading>div{min-width:0}.line-identity-heading span:not(.line-color-dot){color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.9375rem;font-weight:600;display:block;overflow:hidden}.line-identity-heading small{color:var(--text-muted);margin-top:2px;font-size:.75rem;display:block}.line-color-picker{flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px;display:flex}.line-color-swatch{border:1px solid var(--border-default);background:var(--line-color);cursor:pointer;border-radius:50%;width:34px;height:34px;transition:transform .15s,box-shadow .15s,border-color .15s}.line-color-swatch:hover{transform:translateY(-1px)}.line-color-swatch.active{border-color:var(--text-primary);box-shadow:0 0 0 3px var(--bg-base), 0 0 0 5px var(--line-color)}.audio-file-item{background:var(--bg-base);border:1px solid var(--border-default);border-radius:8px;justify-content:space-between;align-items:center;margin-top:8px;padding:10px 12px;display:flex}.audio-file-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.audio-file-name{white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;overflow:hidden}.audio-file-actions{flex-shrink:0;gap:8px;display:flex}.audio-file-btn{background:var(--bg-hover);width:32px;height:32px;color:var(--text-primary);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.audio-file-btn:hover{background:var(--bg-active)}.audio-file-btn.danger:hover{background:var(--danger-muted);color:var(--danger)}.menu-option-item{background:var(--bg-base);border:1px solid var(--border-default);border-radius:8px;align-items:center;gap:12px;margin-top:8px;padding:12px;display:flex}.menu-option-digit{background:var(--accent-muted);width:36px;height:36px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:flex}.menu-option-config{flex-wrap:wrap;flex:1;align-items:center;gap:8px;display:flex}.menu-option-select{border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-primary);cursor:pointer;border-radius:6px;padding:8px 10px;font-size:.8rem}.menu-option-input{border:1px solid var(--border-default);background:var(--bg-elevated);min-width:120px;color:var(--text-primary);border-radius:6px;flex:1;padding:8px 10px;font-size:.8rem}.menu-option-remove{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.menu-option-remove:hover{background:var(--danger-muted);color:var(--danger)}.add-option-btn{border:1px dashed var(--border-default);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;gap:6px;margin-top:12px;padding:12px;font-size:.875rem;transition:all .15s;display:flex}.add-option-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-muted)}.upload-area{border:2px dashed var(--border-default);text-align:center;cursor:pointer;border-radius:8px;margin-top:12px;padding:24px;transition:all .15s}.upload-area:hover,.upload-area.dragover{border-color:var(--accent);background:var(--accent-muted)}.upload-area-icon{margin-bottom:8px;font-size:2rem}.upload-area-text{color:var(--text-secondary);font-size:.875rem}.upload-area-hint{color:var(--text-muted);margin-top:4px;font-size:.75rem}.save-bar{background:var(--bg-elevated);border-top:1px solid var(--border-default);justify-content:flex-end;gap:12px;padding:16px 20px;display:flex;position:sticky;bottom:0;left:0;right:0}.voicemail-item{border-bottom:1px solid var(--border-subtle);cursor:pointer;align-items:center;gap:14px;padding:16px 20px;transition:all .15s;display:flex}.voicemail-item:hover{background:var(--bg-hover)}.voicemail-item.active{background:var(--bg-active);border-left:3px solid var(--accent)}.voicemail-item.unread{background:linear-gradient(135deg, var(--accent-muted) 0%, transparent 100%)}.voicemail-icon{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.voicemail-icon svg{width:22px;height:22px}.voicemail-info{flex:1;min-width:0}.voicemail-contact{white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:.9375rem;font-weight:500;overflow:hidden}.voicemail-item.unread .voicemail-contact{color:var(--text-primary);font-weight:600}.voicemail-meta{color:var(--text-secondary);align-items:center;gap:8px;font-size:.8rem;display:flex}.voicemail-duration{color:var(--text-muted);align-items:center;gap:4px;display:flex}.voicemail-duration svg{opacity:.7;width:12px;height:12px}.voicemail-time{color:var(--text-muted);white-space:nowrap;flex-direction:column;align-items:flex-end;gap:4px;font-size:.75rem;display:flex}.voicemail-badge{background:var(--accent);color:var(--accent-contrast);border-radius:10px;justify-content:center;align-items:center;margin-left:4px;padding:2px 6px;font-size:.65rem;font-weight:600;line-height:1;display:inline-flex}.voicemail-new-dot{background:var(--accent);border-radius:50%;width:8px;height:8px}.voicemail-detail{flex-direction:column;height:100%;padding:0;display:flex;overflow-y:auto}.voicemail-detail-header{text-align:center;background:linear-gradient(180deg, var(--bg-elevated) 0%, var(--bg-base) 100%);border-bottom:1px solid var(--border-default);padding:40px 24px}.voicemail-detail-icon{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:88px;height:88px;margin:0 auto 20px;display:flex;box-shadow:0 8px 32px #8b5cf64d}.voicemail-detail-icon svg{width:40px;height:40px}.voicemail-detail-contact{letter-spacing:-.02em;margin-bottom:6px;font-size:1.5rem;font-weight:600}.voicemail-detail-number{color:var(--text-secondary);font-size:.9rem}.voicemail-player{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:16px;flex-direction:column;align-items:center;gap:20px;margin:24px;padding:32px 24px;display:flex}.voicemail-player-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.75rem;font-weight:500}.audio-visualizer{background:var(--bg-base);border:1px solid var(--border-subtle);border-radius:8px;width:100%;max-width:100%;height:60px}.audio-controls{align-items:center;gap:12px;width:100%;padding:8px 0;display:flex}.audio-play-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;transition:background-color .15s,transform .1s;display:flex}.audio-play-btn:hover{background:var(--primary-hover)}.audio-play-btn:active{transform:scale(.95)}.audio-play-btn svg{width:24px;height:24px}.audio-progress{appearance:none;background:var(--bg-hover);cursor:pointer;border-radius:3px;flex:1;height:6px}.audio-progress::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary);cursor:pointer;border:2px solid #fff;border-radius:50%;width:16px;height:16px;box-shadow:0 1px 3px #0003}.audio-progress::-moz-range-thumb{background:var(--primary);cursor:pointer;border:2px solid #fff;border-radius:50%;width:16px;height:16px;box-shadow:0 1px 3px #0003}.audio-progress::-webkit-slider-runnable-track{border-radius:3px;height:6px}.audio-progress::-moz-range-track{background:var(--bg-hover);border-radius:3px;height:6px}.voicemail-player-info{color:var(--text-secondary);align-items:center;gap:16px;font-size:.875rem;display:flex}.voicemail-player-stat{align-items:center;gap:6px;display:flex}.voicemail-player-stat svg{opacity:.7;width:16px;height:16px}.voicemail-detail-info{padding:0 24px 24px}.voicemail-detail-section{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:12px;overflow:hidden}.voicemail-detail-row{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.voicemail-detail-row:last-child{border-bottom:none}.voicemail-detail-label{color:var(--text-secondary);font-size:.875rem}.voicemail-detail-value{font-size:.875rem;font-weight:500}.voicemail-detail-actions{gap:12px;padding:0 24px 24px;display:flex}.voicemail-action-btn{cursor:pointer;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px 16px;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.voicemail-action-btn svg{width:18px;height:18px}.voicemail-action-btn.primary{background:var(--success);color:#fff}.voicemail-action-btn.primary:hover{background:#16a34a;transform:translateY(-1px)}.voicemail-action-btn.secondary{background:var(--bg-hover);border:1px solid var(--border-default);color:var(--text-primary)}.voicemail-action-btn.secondary:hover{background:var(--bg-active)}.voicemail-action-btn.danger{background:var(--danger-muted);color:var(--danger)}.voicemail-action-btn.danger:hover{background:var(--danger);color:#fff}.mobile-menu-btn{background:var(--bg-hover);border:1px solid var(--border-default);width:40px;height:40px;color:var(--text-primary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:all .15s;display:none}.mobile-menu-btn:hover{background:var(--bg-active)}.mobile-menu-btn svg{width:20px;height:20px}.mobile-back-btn{width:36px;height:36px;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;margin-right:8px;transition:all .15s;display:none}.mobile-back-btn:hover{background:var(--bg-hover)}.mobile-back-btn svg{width:20px;height:20px}@media (width<=1024px){.app{max-width:100%}.sidebar{width:320px;min-width:320px}.dial-grid{grid-template-columns:repeat(3,70px);gap:10px}.dial-btn{width:70px;height:70px;font-size:1.3rem}.settings-container{padding:16px}}@media (width<=768px){.app{flex-direction:column;position:relative}.sidebar{z-index:100;width:100%;min-width:100%;height:100vh;transition:transform .3s;position:fixed;top:0;left:0;transform:translate(0)}.sidebar.hidden{transform:translate(-100%)}.main{width:100%;height:auto;top:0;left:0;bottom:var(--mobile-tabs-height);position:fixed}.mobile-menu-btn,.mobile-back-btn{display:flex}.sidebar-header{padding:16px}.sidebar-header h1{font-size:1rem}.conversations-list,.calls-list,.voicemail-list,.contacts-list,.settings-container{padding-bottom:70px}.chat-header{padding:12px 16px}.chat-contact{font-size:1rem}.icon-btn{width:36px;height:36px;font-size:1rem}.messages{padding:16px}.ai-summary-panel{margin:10px 12px 0;padding:12px}.ai-summary-grid{grid-template-columns:1fr}.message{max-width:85%;padding:10px 14px;font-size:.875rem}.compose{flex-wrap:nowrap;gap:8px;padding:12px 16px}.compose input{padding:10px 14px;font-size:.875rem}.compose-line-select{width:118px;padding:8px;font-size:.75rem}.compose button{padding:10px 18px;font-size:.875rem}.emoji-btn{width:36px;height:36px;font-size:1rem}.emoji-picker{left:0;right:0;bottom:calc(var(--mobile-tabs-height) + 63px);z-index:190;border-bottom:none;border-left:none;border-right:none;border-radius:24px 24px 0 0;width:100%;height:min(48vh,390px);max-height:none;padding:12px 14px 10px;position:fixed}.emoji-grid{grid-template-columns:repeat(auto-fill,minmax(38px,1fr));gap:7px 4px}.emoji-picker .emoji-item{border-radius:11px;width:40px;height:40px;font-size:1.35rem}.emoji-picker-header{margin-bottom:8px;padding-bottom:8px}.emoji-picker .emoji-category-btn{width:38px;height:34px}.dialpad{gap:12px;padding:20px 16px}.dial-display{min-height:40px;font-size:1.75rem}.dial-grid{grid-template-columns:repeat(3,72px);gap:10px}.dial-btn{width:72px;height:72px;font-size:1.4rem}.dial-btn small{font-size:.5rem}.call-filters{flex-wrap:nowrap;gap:6px;padding:10px 12px;overflow-x:auto}.filter-btn{flex-shrink:0;padding:6px 10px;font-size:.7rem}.call-search{min-width:100px;font-size:.7rem}.call-item{gap:10px;padding:12px 14px}.call-icon{width:36px;height:36px;font-size:1rem}.call-contact{font-size:.9rem}.call-meta{font-size:.7rem}.call-detail{padding:16px}.call-detail-header{padding:24px 0}.call-detail-icon{width:64px;height:64px;font-size:2rem}.call-detail-contact{font-size:1.25rem}.call-detail-actions{flex-direction:column;gap:8px}.call-action-btn{padding:12px}.voicemail-item{gap:12px;padding:14px 16px}.voicemail-icon{width:40px;height:40px}.voicemail-icon svg{width:18px;height:18px}.voicemail-contact{font-size:.875rem}.voicemail-meta{font-size:.75rem}.voicemail-detail-header{padding:28px 16px}.voicemail-detail-icon{width:72px;height:72px}.voicemail-detail-icon svg{width:32px;height:32px}.voicemail-detail-contact{font-size:1.25rem}.voicemail-player{border-radius:12px;margin:16px;padding:24px 16px}.voicemail-player-info{flex-wrap:wrap;justify-content:center;gap:12px}.voicemail-detail-info{padding:0 16px 16px}.voicemail-detail-row{padding:12px 14px}.voicemail-detail-actions{flex-direction:column;gap:8px;padding:0 16px 16px}.voicemail-action-btn{padding:12px 14px}.settings-container{padding:12px}.settings-section{margin-bottom:12px;padding:16px}.settings-section h3{margin-bottom:12px;font-size:.9rem}.settings-section-header h3{margin-bottom:0}.accent-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.accent-swatch{min-height:40px;font-size:.75rem}.line-identity-card{padding:12px}.settings-row{flex-direction:column;align-items:flex-start;gap:8px;padding:10px 0}.settings-label span{font-size:.8rem}.settings-label small{font-size:.7rem}.settings-input,.settings-textarea{font-size:.8rem}.settings-select{width:100%;font-size:.8rem}.menu-option-item{flex-wrap:wrap;gap:10px;padding:10px}.menu-option-digit{width:32px;height:32px;font-size:.875rem}.menu-option-config{flex:none;width:100%}.menu-option-select,.menu-option-input{padding:6px 8px;font-size:.75rem}.audio-file-item{flex-wrap:wrap;gap:8px;padding:8px 10px}.audio-file-info{width:100%}.audio-file-name{font-size:.8rem}.upload-area{padding:20px 16px}.upload-area-icon{font-size:1.5rem}.upload-area-text{font-size:.8rem}.save-bar{flex-direction:column;gap:8px;padding:12px 16px}.save-bar .settings-btn{width:100%}.conversation-item{padding:14px 16px}.conversation-name{font-size:.9rem}.conversation-preview{font-size:.8rem}.conversation-time{font-size:.7rem}.empty-state-icon{font-size:3rem}.empty-state p{font-size:.875rem}.modal{width:95%;padding:20px}.modal h2{font-size:1.125rem}.modal input{padding:10px;font-size:.875rem}.modal-actions{flex-direction:column-reverse;gap:8px}.modal-actions button{width:100%;padding:12px}}@media (width<=380px){.sidebar-header h1{font-size:.9rem}.my-number{font-size:.7rem}.line-select{max-width:130px;font-size:.7rem}.tab{padding:10px 8px;font-size:.75rem}.dial-grid{grid-template-columns:repeat(3,64px);gap:8px}.dial-btn{width:64px;height:64px;font-size:1.25rem}.voicemail-detail-contact,.call-detail-contact{font-size:1.1rem}}@media (width<=768px) and (orientation:landscape){.dialpad{flex-flow:wrap;justify-content:center;gap:16px;padding:16px}.dial-display{width:100%;min-height:36px;font-size:1.5rem}.dial-grid{grid-template-columns:repeat(4,60px);gap:8px}.dial-btn{width:60px;height:60px;font-size:1.2rem}.voicemail-detail-header{padding:20px 16px}.voicemail-detail-icon{width:56px;height:56px}.voicemail-player{margin:12px;padding:16px}.call-detail-header{padding:16px 0}.call-detail-icon{width:48px;height:48px;font-size:1.5rem}}@media (width>=1400px){.app{max-width:1600px}.sidebar{width:360px}.messages{padding:32px}.settings-container{padding:24px}}@media (hover:none) and (pointer:coarse){.icon-btn,.dial-btn,.filter-btn,.settings-btn,.emoji-btn,.call-action-btn,.voicemail-action-btn{min-width:44px;min-height:44px}.tab{min-height:44px}.conversation-item,.call-item,.voicemail-item{min-height:64px}}@supports (padding-top:env(safe-area-inset-top)){.sidebar-header{padding-top:calc(16px + env(safe-area-inset-top))}@media (width<=768px){.main{bottom:calc(var(--mobile-tabs-height) + env(safe-area-inset-bottom))}.mobile-tabs .tabs{padding-bottom:env(safe-area-inset-bottom)}.emoji-picker{bottom:calc(var(--mobile-tabs-height) + 63px + env(safe-area-inset-bottom))}}.compose{padding-bottom:calc(12px + env(safe-area-inset-bottom))}.save-bar{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.voicemail-detail-actions,.call-detail-actions{padding-bottom:calc(24px + env(safe-area-inset-bottom))}}.call-overlay{z-index:1000;background:#000000fa;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.call-overlay-content{text-align:center;padding:40px}.call-overlay-status{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;font-size:1rem}.call-overlay-timer{color:var(--success);font-variant-numeric:tabular-nums;letter-spacing:.05em;margin-bottom:8px;font-size:3rem;font-weight:300}.call-overlay-number{color:var(--text-primary);margin-bottom:60px;font-size:1.5rem;font-weight:500}.call-overlay-actions{justify-content:center;gap:48px;display:flex}.call-overlay-btn{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:12px;padding:8px;transition:transform .15s;display:flex}.call-overlay-btn:hover{transform:scale(1.08)}.call-overlay-btn:active{transform:scale(.95)}.call-btn-icon{border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;display:flex}.call-btn-icon.answer-icon{background:var(--success);color:#fff}.call-btn-icon.reject-icon,.call-btn-icon.hangup-icon{background:var(--danger);color:#fff}.call-btn-icon:not(.answer-icon):not(.reject-icon):not(.hangup-icon):not(.keypad-active){color:var(--text-primary);background:#ffffff26}.call-btn-icon svg{width:32px;height:32px}.call-btn-label{color:var(--text-secondary);font-size:.875rem}.call-keypad{grid-template-columns:repeat(3,64px);gap:12px;margin-bottom:40px;display:grid}.call-keypad-btn{width:64px;height:64px;color:var(--text-primary);cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;transition:all .15s;display:flex}.call-keypad-btn:hover{background:#fff3}.call-keypad-btn:active{background:#ffffff4d;transform:scale(.95)}.call-keypad-digit{font-size:1.5rem;font-weight:400}.call-keypad-letters{color:var(--text-muted);letter-spacing:2px;margin-top:2px;font-size:.5rem}.call-btn-icon.keypad-active{background:var(--accent);color:#fff}.search-container{border-bottom:1px solid var(--border-default);gap:8px;padding:12px 16px;display:flex}.search-input{border:1px solid var(--border-default);background:var(--bg-base);color:var(--text-primary);border-radius:10px;flex:1;padding:10px 14px;font-size:.875rem;transition:all .15s}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--accent);outline:none}.contact-item{border-bottom:1px solid var(--border-subtle);cursor:pointer;align-items:center;gap:12px;padding:12px 16px;transition:background .15s;display:flex}.contact-item:hover{background:var(--bg-hover)}.contact-item.selected{background:var(--bg-active);border-left:3px solid var(--accent)}.contact-item.blocked .contact-avatar{background:var(--danger-muted);color:var(--danger)}.contact-avatar{background:var(--accent-muted);width:40px;height:40px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:600;display:flex}.contact-info{flex:1;min-width:0}.contact-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9375rem;font-weight:500;overflow:hidden}.contact-name-row{align-items:center;gap:8px;min-width:0;display:flex}.contact-name-row .contact-name{min-width:0}.contact-list-badge{background:var(--danger-muted);color:var(--danger);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:2px 6px;font-size:.65rem;font-weight:600;line-height:1;display:inline-flex}.contact-phone{color:var(--text-secondary);margin-top:2px;font-size:.8125rem}.contact-group-header{color:var(--text-muted);background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle);text-transform:uppercase;letter-spacing:.05em;padding:8px 16px;font-size:.75rem;font-weight:600}.new-contact-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:background-color .15s,transform .15s;display:flex}.new-contact-btn:hover{background:var(--accent-hover)}.new-contact-btn:active{transform:scale(.95)}.contact-detail{height:100%;padding:32px;overflow-y:auto}.contact-detail-header{flex-direction:column;align-items:center;margin-bottom:32px;display:flex}.contact-detail-avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;margin-bottom:16px;font-size:2.5rem;font-weight:600;display:flex}.contact-detail-avatar.blocked{background:var(--danger-muted);color:var(--danger)}.contact-detail-name{color:var(--text-primary);margin-bottom:4px;font-size:1.5rem;font-weight:600}.contact-blocked-badge{background:var(--danger-muted);color:var(--danger);border-radius:999px;align-items:center;gap:6px;margin-bottom:8px;padding:5px 9px;font-size:.75rem;font-weight:600;line-height:1;display:inline-flex}.contact-blocked-badge svg{width:14px;height:14px}.contact-edit-link{color:var(--accent);cursor:pointer;background:0 0;border:none;margin-bottom:8px;padding:4px 8px;font-size:.875rem}.contact-edit-link:hover{text-decoration:underline}.contact-detail-phone{color:var(--text-secondary);font-size:1rem}.contact-edit-form{flex-direction:column;align-items:center;gap:12px;width:100%;max-width:280px;margin-bottom:8px;display:flex}.contact-edit-input{border:1px solid var(--border-default);background:var(--bg-elevated);width:100%;color:var(--text-primary);text-align:center;border-radius:8px;padding:10px 14px;font-size:1rem}.contact-edit-input:focus{border-color:var(--accent);outline:none}.contact-edit-actions{gap:8px;display:flex}.contact-edit-btn{cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:background-color .15s}.contact-edit-btn.cancel{background:var(--bg-hover);color:var(--text-primary)}.contact-edit-btn.cancel:hover{background:var(--bg-active)}.contact-edit-btn.save{background:var(--accent);color:#fff}.contact-edit-btn.save:hover:not(:disabled){background:var(--accent-hover)}.contact-edit-btn.save:disabled{opacity:.5;cursor:not-allowed}.contact-detail-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:32px;display:flex}.contact-action-btn{cursor:pointer;border:none;border-radius:16px;flex-direction:column;align-items:center;gap:6px;min-width:100px;padding:16px 24px;font-size:.875rem;font-weight:500;transition:background-color .15s,transform .15s;display:flex}.contact-action-btn svg{width:24px;height:24px}.contact-action-btn.primary{background:var(--success-muted);color:var(--success)}.contact-action-btn.primary:hover:not(:disabled){background:var(--success);color:#fff}.contact-action-btn.secondary{background:var(--accent-muted);color:var(--accent)}.contact-action-btn.secondary:hover:not(:disabled){background:var(--accent);color:var(--accent-contrast)}.contact-action-btn.warning{background:var(--warning-muted);color:var(--warning)}.contact-action-btn.warning:hover:not(:disabled){background:var(--warning);color:#fff}.contact-action-btn.danger{background:var(--danger-muted);color:var(--danger)}.contact-action-btn.danger:hover:not(:disabled){background:var(--danger);color:#fff}.contact-action-btn:disabled{opacity:.5;cursor:not-allowed}.contact-detail-info{max-width:400px;margin:0 auto}.contact-detail-section{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:16px;padding:16px}.contact-detail-row{justify-content:space-between;align-items:center;padding:12px 0;display:flex}.contact-detail-row:not(:last-child){border-bottom:1px solid var(--border-subtle)}.contact-detail-label{color:var(--text-secondary);font-size:.875rem}.contact-detail-value{color:var(--text-primary);font-weight:500}.contact-detail-value.blocked{color:var(--danger)}.modal-error{background:var(--danger-muted);color:var(--danger);border-radius:8px;margin-bottom:16px;padding:12px;font-size:.875rem}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:.875rem;display:block}.form-input{border:1px solid var(--border-default);background:var(--bg-elevated);width:100%;color:var(--text-primary);border-radius:8px;padding:12px 14px;font-size:1rem}.form-input:focus{border-color:var(--accent);outline:none}.settings-menu-item{cursor:pointer;border-radius:10px;grid-template-columns:48px minmax(0,1fr) 20px;align-items:center;gap:14px;min-height:76px;margin:-4px -8px;padding:12px 14px;transition:background .15s;display:grid}.settings-menu-item:hover{background:var(--bg-hover)}.settings-menu-icon{background:var(--accent-muted);width:48px;height:48px;color:var(--accent);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.settings-menu-icon svg{width:24px;height:24px;display:block;overflow:visible}.settings-menu-content{flex:1;align-self:center;min-width:0}.settings-menu-title{color:var(--text-primary);margin-bottom:2px;font-size:.9375rem;font-weight:500;display:block}.settings-menu-desc{color:var(--text-secondary);font-size:.8125rem;line-height:1.25;display:block}.settings-menu-arrow{color:var(--text-muted);flex-shrink:0}.back-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:24px;padding:0;font-size:.9375rem;font-weight:500;transition:opacity .15s;display:flex}.back-btn:hover{opacity:.8}.about-header{text-align:center;margin-bottom:24px;padding:32px 0}.about-logo{background:var(--accent);color:#fff;border-radius:20px;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 16px;display:flex}.about-title{color:var(--text-primary);margin:0 0 4px;font-size:1.5rem;font-weight:600}.about-version{color:var(--text-secondary);margin:0;font-size:.875rem}.about-description{color:var(--text-secondary);margin:0;font-size:.9375rem;line-height:1.6}.license-text{font-size:.8125rem;line-height:1.6}.license-header{color:var(--text-primary);margin:0 0 8px;font-weight:600}.license-copyright{color:var(--text-primary);margin:0 0 16px}.license-body{color:var(--text-secondary);margin:0 0 12px}.license-text a{color:var(--accent);text-decoration:none}.license-text a:hover{text-decoration:underline}.license-disclaimer{text-transform:uppercase;font-size:.75rem}.credits-list{flex-direction:column;gap:12px;display:flex}.credit-item{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:12px 0;display:flex}.credit-item:last-child{border-bottom:none}.credit-name{color:var(--text-primary);font-weight:500}.credit-desc{color:var(--text-secondary);font-size:.8125rem}.notification-container{z-index:9999;pointer-events:none;flex-direction:column;gap:12px;max-width:400px;display:flex;position:fixed;top:16px;right:16px}.notification-bubble{background:var(--bg-elevated);border:1px solid var(--border-default);box-shadow:var(--shadow-lg), 0 0 40px #0000004d;pointer-events:auto;backdrop-filter:blur(12px);border-radius:16px;align-items:flex-start;gap:12px;min-width:280px;padding:14px 16px;animation:.3s cubic-bezier(.34,1.56,.64,1) notificationSlideIn;display:flex}@keyframes notificationSlideIn{0%{opacity:0;transform:translate(100%)scale(.8)}to{opacity:1;transform:translate(0)scale(1)}}.notification-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.notification-icon svg{width:20px;height:20px}.notification-info .notification-icon{background:var(--accent-muted);color:var(--accent)}.notification-success .notification-icon{background:var(--success-muted);color:var(--success)}.notification-warning .notification-icon{color:#fbbf24;background:#fbbf2426}.notification-error .notification-icon{background:var(--danger-muted);color:var(--danger)}.notification-call .notification-icon{background:linear-gradient(135deg, var(--success) 0%, #16a34a 100%);color:#fff;animation:1.5s ease-in-out infinite notificationPulse}.notification-message .notification-icon{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%);color:#fff}.notification-voicemail .notification-icon{color:#fff;background:linear-gradient(135deg,#f97316 0%,#ea580c 100%)}@keyframes notificationPulse{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 8px #22c55e00}}.notification-call{background:linear-gradient(135deg, #22c55e1a 0%, var(--bg-elevated) 100%);border-color:var(--success)}.notification-content{flex:1;min-width:0}.notification-title{color:var(--text-primary);margin-bottom:2px;font-size:.9375rem;font-weight:600}.notification-message{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;overflow:hidden}.notification-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.notification-action-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:8px 16px;font-size:.8125rem;font-weight:600;transition:all .15s}.notification-action-btn:hover{background:var(--accent-hover);transform:scale(1.02)}.notification-call .notification-action-btn{background:var(--success)}.notification-call .notification-action-btn:hover{background:#16a34a}.notification-dismiss{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.notification-dismiss:hover{background:var(--bg-hover);color:var(--text-primary)}.notification-dismiss svg{width:16px;height:16px}@media (width<=768px){.notification-container{top:auto;bottom:calc(var(--mobile-tabs-height) + env(safe-area-inset-bottom,0px) + 12px);max-width:none;max-height:calc(100dvh - var(--mobile-tabs-height) - env(safe-area-inset-bottom,0px) - 28px);overscroll-behavior:contain;scrollbar-width:none;left:12px;right:12px;overflow-y:auto}.notification-container::-webkit-scrollbar{display:none}.notification-bubble{border-radius:18px;gap:10px;width:100%;min-width:auto;padding:12px;animation:.3s cubic-bezier(.34,1.56,.64,1) notificationSlideUp}.notification-icon{border-radius:11px;width:36px;height:36px}.notification-message{white-space:normal;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box}.notification-actions{gap:4px}.notification-action-btn{padding:7px 10px}@keyframes notificationSlideUp{0%{opacity:0;transform:translateY(100%)scale(.8)}to{opacity:1;transform:translateY(0)scale(1)}}}.notification-bell-wrapper,.notification-bell{position:relative}.notification-badge{background:var(--danger);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.6875rem;font-weight:600;animation:.3s cubic-bezier(.34,1.56,.64,1) badgePop;display:flex;position:absolute;top:-4px;right:-4px}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.notification-panel-overlay{z-index:999;background:#0000004d;position:fixed;inset:0}.notification-panel{background:var(--bg-elevated);border:1px solid var(--border-default);width:360px;max-width:calc(100vw - 32px);max-height:calc(100vh - 100px);box-shadow:var(--shadow-lg);z-index:1000;border-radius:16px;flex-direction:column;animation:.2s ease-out panelSlideIn;display:flex;position:fixed;top:70px;left:16px;overflow:hidden}@keyframes panelSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-panel-header{border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;gap:12px;padding:16px;display:flex}.notification-panel-header h3{color:var(--text-primary);margin:0;font-size:1rem;font-weight:600}.notification-panel-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.mark-all-read-btn{border:1px solid var(--border-default);color:var(--accent);cursor:pointer;background:0 0;border-radius:8px;padding:6px 12px;font-size:.75rem;font-weight:500;transition:all .15s}.mark-all-read-btn:hover{background:var(--accent-muted);border-color:var(--accent)}.notification-panel-close{border:1px solid var(--border-default);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.notification-panel-close:hover{background:var(--bg-hover);color:var(--text-primary)}.notification-panel-close svg{width:16px;height:16px}.notification-panel-list{flex:1;overflow-y:auto}.notification-panel-empty{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.notification-panel-empty p{margin-top:12px;font-size:.875rem}.notification-panel-item{cursor:pointer;align-items:flex-start;gap:12px;padding:14px 16px;transition:background .15s;display:flex;position:relative}.notification-panel-item.read{opacity:.74}.notification-panel-item:hover{background:var(--bg-hover)}.notification-panel-item.unread{background:var(--accent-muted)}.notification-panel-item.unread:hover{background:#3b82f626}.notification-panel-icon{color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.notification-icon-message{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%)}.notification-icon-call{background:linear-gradient(135deg, var(--success) 0%, #16a34a 100%)}.notification-icon-voicemail{background:linear-gradient(135deg,#f97316 0%,#ea580c 100%)}.notification-panel-content{flex:1;min-width:0}.notification-panel-title{color:var(--text-primary);margin-bottom:2px;font-size:.875rem;font-weight:600}.notification-panel-message{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:.8125rem;overflow:hidden}.notification-panel-time{color:var(--text-muted);font-size:.75rem}.notification-unread-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}@media (width<=768px){.notification-panel{top:auto;bottom:calc(var(--mobile-tabs-height) + env(safe-area-inset-bottom,0px));width:auto;max-width:none;max-height:min(74vh, calc(100dvh - var(--mobile-tabs-height) - env(safe-area-inset-bottom,0px) - 24px));border-radius:20px 20px 0 0;margin-top:0;position:fixed;left:8px;right:8px;box-shadow:0 -16px 48px #00000059}.notification-panel-overlay{background:#00000080}.notification-panel-header{padding:14px 14px 12px}.notification-panel-header h3{font-size:1rem}.mark-all-read-btn{white-space:nowrap;padding:7px 10px}.notification-panel-list{padding-bottom:env(safe-area-inset-bottom,0px)}.notification-panel-item{gap:10px;padding:14px}.notification-panel-message{white-space:normal;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box}}
