@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--sidebar-bg:#171717;--sidebar-width:220px;--sidebar-hover:#ffffff0f;--sidebar-active-bg:#f4b93f1f;--sidebar-active-border:#f4b93f;--sidebar-text:#ffffff8c;--sidebar-text-active:#fff;--surface:#fff;--bg:#f9f9f9;--border:#e8e8e8;--border-dark:#d0d0d0;--text:#171717;--text-muted:#505a63;--text-success:#2d7a4f;--accent:#f4b93f;--accent-hover:#e0a828;--accent-text:#171717;--danger:#dc2626;--danger-hover:#b91c1c;--warn:#f4b93f;--radius:8px;--radius-sm:6px;--shadow:0 1px 3px #00000012, 0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000014, 0 2px 4px -1px #0000000d;--shadow-lg:0 10px 40px #0003;--font:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Menlo", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}.layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);border-right:1px solid #ffffff0d;flex-direction:column;flex-shrink:0;display:flex}.sidebar-brand{border-bottom:1px solid #ffffff0f;justify-content:center;align-items:center;padding:20px 20px 18px;display:flex}.sidebar-logo{object-fit:contain;width:140px;height:auto}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--sidebar-text);border-left:2px solid #0000;align-items:center;gap:10px;padding:9px 12px;font-size:13.5px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-item:hover{background:var(--sidebar-hover);color:#ffffffd9}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-text-active);border-left-color:var(--sidebar-active-border)}.nav-icon{flex-shrink:0;width:16px;height:16px;display:flex}.nav-icon svg{width:16px;height:16px}.sidebar-footer{border-top:1px solid #ffffff0f;padding:14px 20px}.sidebar-version{color:#fff3;font-size:11px;font-family:var(--font-mono)}.main-content{background:var(--bg);flex:1;overflow-y:auto}.page{max-width:1200px;padding:32px 36px}.page-header{justify-content:space-between;align-items:flex-start;margin-bottom:28px;display:flex}.page-title{letter-spacing:-.4px;color:var(--text);font-size:22px;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:2px;font-size:13px}.btn{border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;font-family:var(--font);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 16px;text-decoration:none;transition:background .15s,opacity .15s,transform .1s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.98)}.btn-primary{background:var(--accent);color:var(--accent-text)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-ghost{color:var(--text-muted);border:1px solid var(--border-dark);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--border);color:var(--text)}.btn-danger-ghost{color:var(--danger);background:0 0;border:1px solid #0000}.btn-danger-ghost:hover:not(:disabled){background:#fef2f2;border-color:#fecaca}.btn-sm{padding:5px 10px;font-size:12.5px}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.table{border-collapse:collapse;width:100%;font-size:13.5px}.table thead{border-bottom:2px solid var(--border);background:#fafafa}.table th{text-align:left;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);white-space:nowrap;padding:10px 16px;font-size:11px;font-weight:700}.table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:13px 16px}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:#fdfbf4}.table-empty{text-align:center;color:var(--text-muted);font-size:13px;padding:48px!important}.row-actions{justify-content:flex-end;gap:6px;display:flex}.badge{white-space:nowrap;border-radius:4px;align-items:center;gap:4px;padding:3px 8px;font-size:12px;font-weight:500;display:inline-flex}.badge-success{color:#065f46;background:#d1fae5}.badge-warn{color:#92570e;background:#fef9e7}.badge-neutral{color:var(--text-muted);background:#f1f1f1}.mono{font-family:var(--font-mono);font-size:12.5px}.mono-input{font-family:var(--font-mono)}.fw-medium{font-weight:500}.text-muted{color:var(--text-muted)}.text-success{color:var(--text-success)}.provision-url{color:var(--text-muted);word-break:break-all;font-size:11px}.user-cell{flex-direction:column;gap:2px;display:flex}.alert{border-radius:var(--radius-sm);margin-bottom:16px;padding:10px 14px;font-size:13px}.alert-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.loading{text-align:center;color:var(--text-muted);padding:64px;font-size:13px}.modal-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;background:#17171799;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-height:90vh;animation:.18s slideUp;display:flex}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-title{letter-spacing:-.2px;font-size:16px;font-weight:700}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;transition:background .12s;display:flex}.modal-close:hover{background:var(--border);color:var(--text)}.modal-body{padding:24px;overflow-y:auto}.form{flex-direction:column;gap:16px;display:flex}.form-row{gap:12px;display:flex}.form-group{flex-direction:column;flex:1;gap:5px;display:flex}.form-label{color:var(--text);font-size:12.5px;font-weight:600}.required{color:var(--danger)}.form-input{border:1px solid var(--border-dark);border-radius:var(--radius-sm);font-size:13.5px;font-family:var(--font);color:var(--text);background:var(--surface);outline:none;padding:8px 11px;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #f4b93f2e}.form-input:disabled{color:var(--text-muted);cursor:not-allowed;background:#f5f5f5}.form-hint{color:var(--text-muted);font-size:11.5px}.login-page{background:var(--sidebar-bg);background-image:radial-gradient(at 50% 0,#f4b93f1f 0%,#0000 55%),radial-gradient(at 100% 100%,#f4b93f0f 0%,#0000 50%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--surface);border-radius:12px;width:100%;max-width:380px;padding:40px;box-shadow:0 20px 60px #00000080}.login-brand{text-align:center;margin-bottom:32px}.login-brand-icon{background:var(--accent);border-radius:12px;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:12px;font-size:24px;display:inline-flex}.login-title{letter-spacing:-.4px;margin:0 0 4px;font-size:22px;font-weight:700}.login-subtitle{color:var(--text-muted);margin:0;font-size:13px}.login-submit{justify-content:center;width:100%;padding:10px;font-size:14px}.logout-btn{border-radius:var(--radius-sm);color:#fff6;width:100%;font-size:13px;font-family:var(--font);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;margin-bottom:8px;padding:8px 12px;transition:background .15s,color .15s;display:flex}.logout-btn:hover{color:#fca5a5;background:#ef44441f}.customer-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.customer-card{background:var(--surface);border:1.5px solid var(--border);box-shadow:var(--shadow);border-radius:14px;flex-direction:column;gap:14px;padding:20px;transition:box-shadow .2s,transform .15s;display:flex}.customer-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.customer-card-top{justify-content:space-between;align-items:center;display:flex}.customer-avatar{color:#888;letter-spacing:.5px;background:#e8e8e8;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:15px;font-weight:700;display:flex}.customer-avatar--active{background:var(--accent);color:var(--accent-text)}.customer-card-id{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.customer-id-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:10px;font-weight:600}.customer-id-value{font-family:var(--font-mono);color:var(--text);letter-spacing:1px;font-size:18px;font-weight:700}.customer-card-info{border-top:1px solid var(--border);flex-direction:column;gap:3px;padding-top:12px;display:flex}.customer-card-name{color:var(--text);letter-spacing:-.2px;font-size:14px;font-weight:700}.customer-card-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;overflow:hidden}.customer-card-sip{flex-direction:column;gap:5px;display:flex}.customer-sip-server{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:3px 7px;font-size:11px}.customer-card-actions{border-top:1px solid var(--border);gap:6px;padding-top:2px;display:flex}.customer-card-actions .btn:last-child{margin-left:auto}.phone-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;display:grid}.phone-grid-empty{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 0;font-size:13px;display:flex}.phone-card{background:var(--surface);border:1.5px solid var(--border);box-shadow:var(--shadow);cursor:default;border-radius:14px;flex-direction:column;align-items:center;gap:10px;padding:16px;transition:box-shadow .2s,border-color .2s,transform .15s;display:flex}.phone-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.phone-card--active{border-color:var(--accent);background:linear-gradient(160deg,#fffdf5 0%,#fff 60%)}.phone-card-header{justify-content:space-between;align-items:center;width:100%;display:flex}.phone-card-status{color:var(--text-muted);align-items:center;gap:5px;font-size:11.5px;font-weight:600;display:inline-flex}.phone-card-status--active{color:#2d7a4f}.phone-card-status-dot{background:#d0d0d0;border-radius:50%;flex-shrink:0;width:7px;height:7px}.phone-card-status--active .phone-card-status-dot{background:#22c55e;box-shadow:0 0 0 3px #22c55e33}.phone-card-model{color:var(--text-muted);background:var(--bg);border:1px solid var(--border);font-size:10.5px;font-weight:600;font-family:var(--font-mono);border-radius:4px;padding:2px 6px}.phone-card-illustration{justify-content:center;width:100%;padding:8px 0 4px;display:flex}.phone-card-svg{drop-shadow:0 4px 12px #0000001a;filter:drop-shadow(0 4px 8px #0000001f);width:140px;height:auto}.phone-card-label{color:var(--text);text-align:center;letter-spacing:-.2px;font-size:14px;font-weight:700}.phone-card-mac{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:3px 8px;font-size:11px}.phone-card-user{color:var(--text);align-items:center;gap:5px;min-height:20px;font-size:12.5px;font-weight:500;display:flex}.phone-card-user svg{color:var(--accent);flex-shrink:0}.phone-card-user-name{white-space:nowrap;text-overflow:ellipsis;max-width:160px;overflow:hidden}.phone-card-user-empty{color:var(--text-muted);font-size:12px;font-style:italic}.phone-card-url{background:var(--bg);border:1px solid var(--border);border-radius:5px;width:100%;padding:5px 8px}.phone-card-url code{font-family:var(--font-mono);color:var(--text-muted);word-break:break-all;font-size:10px;line-height:1.4}.phone-card-actions{border-top:1px solid var(--border);gap:8px;width:100%;margin-top:2px;padding-top:4px;display:flex}.phone-card-actions .btn{flex:1;justify-content:center}.confirm-modal{text-align:center;flex-direction:column;align-items:center;gap:0;max-width:420px;padding:32px 28px 24px;display:flex}.confirm-modal-icon{background:#fef2f2;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:20px;display:flex}.confirm-modal-icon svg{width:26px;height:26px;stroke:var(--danger)}.confirm-modal-content{flex-direction:column;align-items:center;gap:8px;width:100%;display:flex}.confirm-modal-title{letter-spacing:-.3px;color:var(--text);font-size:17px;font-weight:700}.confirm-modal-desc{color:var(--text-muted);font-size:13.5px;line-height:1.5}.confirm-modal-item{border:1px solid var(--border-dark);border-radius:var(--radius-sm);color:var(--text);background:#f5f5f5;width:100%;margin-top:4px;padding:8px 16px;font-size:13.5px;font-weight:600}.confirm-modal-warning{color:var(--danger);border-radius:var(--radius-sm);text-align:left;background:#fef2f2;border:1px solid #fecaca;align-items:flex-start;gap:6px;width:100%;margin-top:4px;padding:8px 12px;font-size:12px;display:flex}.confirm-modal-actions{gap:10px;width:100%;margin-top:24px;display:flex}.confirm-modal-actions .btn{flex:1;justify-content:center}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}.form-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;margin-top:4px;padding-top:8px;display:flex}
