*{box-sizing:border-box;font-family:system-ui,-apple-system,sans-serif}html,body,#root{height:100%}body{margin:0;background:#f1f5f9;overflow:hidden}.topbar{position:fixed;top:0;left:0;right:0;z-index:1100;height:80px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid #3e4152;background:radial-gradient(circle at 20% 30%,rgba(59,130,246,.2),transparent 45%),radial-gradient(circle at 80% 60%,rgba(14,165,233,.15),transparent 45%),radial-gradient(circle at 50% 80%,rgba(99,102,241,.12),transparent 50%),#020617;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.topbar-left{display:flex;align-items:center;gap:14px}.logo{font-weight:600;font-size:18px;color:#fff}.topbar-connection{display:flex;align-items:center;gap:8px;font-size:13px;color:#ccc;padding-left:12px;border-left:1px solid #2a2a2a}.conn-dot{width:10px;height:10px;border-radius:50%;transition:background-color .3s ease}.conn-online{background:#2ecc71}.conn-offline{background:#e74c3c}.conn-checking{background:#f1c40f}.conn-latency{font-size:12px;color:#999}.topbar-right{display:flex;align-items:center;gap:16px}.topbar-user{display:flex;align-items:center;gap:8px;height:36px;padding:0 12px;border-left:1px solid #2a2a2a;color:#ccc;font-size:13px}.topbar-user .user-icon{font-size:16px;opacity:.85}.topbar-user .user-name{color:#fff;font-weight:500;white-space:nowrap}.topbar-user .user-icon.admin{color:#e74c3c}.user-role{margin-left:6px;font-size:11px;padding:2px 8px;border-radius:6px;text-transform:uppercase;font-weight:600;letter-spacing:.4px}.role-admin{background:#e74c3c26;color:#e74c3c}.role-user{background:#ffffff14;color:#ccc}.login-page{height:100vh;display:grid;grid-template-columns:1fr 460px;background:#081022;overflow:hidden}.login-hero{position:relative;display:flex;align-items:center;padding:80px;color:#fff;overflow:hidden}.hero-content{position:relative;z-index:2;max-width:520px}.hero-content h2{font-size:44px;font-weight:700;margin-bottom:18px;letter-spacing:-.5px}.hero-content h3{font-size:25px;font-weight:700;margin-bottom:10px;letter-spacing:-.5px;opacity:.3}.hero-marquee{overflow:hidden;white-space:nowrap;margin-bottom:20px}.hero-track{display:inline-block;animation:marquee 10s linear infinite;font-size:13px;color:#94a3b8;opacity:.9}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.hero-sub{font-size:15px;color:#cbd5f5;line-height:1.7;opacity:.9}.hero-particles{position:absolute;inset:0;z-index:1;background:radial-gradient(circle at 20% 30%,rgba(59,130,246,.25),transparent 45%),radial-gradient(circle at 80% 60%,rgba(14,165,233,.18),transparent 45%),radial-gradient(circle at 50% 80%,rgba(99,102,241,.15),transparent 50%);animation:floatBg 20s ease-in-out infinite alternate}@keyframes floatBg{0%{transform:translateY(0) scale(1)}to{transform:translateY(-40px) scale(1.06)}}.login-box{display:flex;flex-direction:column;justify-content:center;padding:48px 56px;background:#eff0f3f5;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-left:1px solid rgba(255,255,255,.08);box-shadow:-20px 0 60px #00000059;z-index:3}.login-box h1{font-size:22px;margin-bottom:6px;color:#111827}.login-box p{font-size:13px;color:#4b5563;margin-bottom:26px}.login-box input{width:100%;padding:12px 14px;margin-bottom:14px;background:#020617;border:1px solid #1f2933;border-radius:6px;color:#fff;font-size:14px;transition:all .2s ease}.login-box input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f640}.login-error{color:#ef4444;font-size:13px;margin-bottom:12px}.login-hint{margin-top:14px;font-size:12px;color:#9ca3af}.login-sso{margin-top:18px}.login-sso-divider{position:relative;text-align:center;font-size:12px;color:#64748b;margin:14px 0}.login-sso-divider:before{content:"";position:absolute;left:0;top:50%;width:100%;height:1px;background:#e5e7eb;z-index:0}.login-sso-divider span{position:relative;background:#eff0f3;padding:0 10px;z-index:1}.login-sso-buttons{display:flex;gap:10px}.sso-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;font-size:13px;font-weight:600;cursor:not-allowed;opacity:.6;transition:all .2s ease}.sso-btn:disabled{pointer-events:none}.layout{position:fixed;inset:80px 0 0;display:flex;overflow:hidden}.sidebar{width:210px;flex-shrink:0;height:100%;position:relative;overflow:hidden;color:#cbd5e1;display:flex;flex-direction:column;justify-content:space-between;background:radial-gradient(circle at 20% 30%,rgba(59,130,246,.2),transparent 45%),radial-gradient(circle at 80% 60%,rgba(14,165,233,.15),transparent 45%),radial-gradient(circle at 50% 80%,rgba(99,102,241,.12),transparent 50%),#020617}.sidebar-menu{padding:5px 0;overflow-y:auto;min-height:0}.content{flex:1;height:100%;min-width:0;min-height:0;padding:24px;overflow:hidden}.page{width:100%;height:100%;min-width:0;min-height:0;padding:24px 32px;overflow-y:auto;overflow-x:hidden}.page-body,.table-wrapper{min-width:0;min-height:0}.account-status{display:flex;align-items:center;gap:8px}.account-label{padding:3px 8px;border-radius:7px;font-size:12px;font-weight:700;color:#fff;white-space:nowrap}.account-label.origin{opacity:.95}.account-label.active{box-shadow:0 0 0 1px #ffffff26 inset}.bg-green{background:#258811de;color:#fff}.bg-orange{background:#c90303e5;color:#fff}.account-arrow{font-size:14px;color:#fafafa}.return-origin{background:#fff;border:none;cursor:pointer;color:#000;font-size:15px;display:flex;align-items:center}.return-origin:hover{color:#7a0404}.search-input{padding:6px 10px;width:130px;border-radius:6px;border:1px solid #cbd5e1}.search-wrapper{position:relative}.search-dropdown{position:absolute;top:38px;right:0;width:320px;background:#fff;border:1px solid #ddd;z-index:1500}.search-item{padding:10px;cursor:pointer}.search-item:hover{background:#f5f5f5}.search-name{font-weight:600}.search-realm{font-size:12px;color:#666}.account-flag{margin-left:10px;color:#2ecc71;font-weight:600}.menu-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;border-radius:6px;font-size:14px}.menu-item:hover{background:#1e293b;color:#fff}.menu-icon{font-size:16px}.menu-group{padding:12px 16px;cursor:pointer;font-weight:500;font-size:small;opacity:.85}.menu-group:hover{background:#ffffff0d}.menu-group-left{display:flex;align-items:center;gap:8px}.submenu{margin-left:15px;border-left:2px solid rgba(255,255,255,.08);font-size:14px}.submenu-item{padding-left:30px;font-size:smaller}.sidebar-footer{padding:12px 8px;border-top:1px solid #1e293b}.menu-item.logout{color:#fca5a5}.menu-item.logout:hover{background:#450a0a;color:#fecaca}table{width:100%;border-collapse:collapse;background:#fff;margin-top:2px}th{text-align:left;background:#f8fafc}th,td{padding:7px;border-bottom:1px solid #e5e7eb}.actions{text-align:right;white-space:nowrap}.table-state{text-align:center;padding:32px;color:var(--text-muted)}.table-loading{display:inline-flex;align-items:center;gap:10px;font-weight:500}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}button{padding:6px 10px;margin-right:6px;border:1px solid #5a5a5a;background:#fff;cursor:pointer;border-radius:4px}button:disabled{opacity:.4;cursor:not-allowed}button.danger{border-color:#fecaca;color:#991b1b}button.danger:hover{background:#fee2e2}.btn-primary{background:#660e0b;color:#fff}.btn-primary:hover{background:#1f1a1a;color:#fff}.btn-secondary{background:#172e6d;color:#eee}.btn-secondary:hover{background:#1f1a1a;color:#fff}.select-input{width:100px;height:25px;padding:0 10px;background:#fff;border:1px solid #2f2f2f;border-radius:6px;font-size:13px;color:#000}.select-input:focus{outline:none;border-color:#2d6cdf}.date-input{height:30px;padding:0 10px;border:1px solid #2c2f36;border-radius:6px;background-color:#fff;color:#202020;font-size:13px;outline:none;cursor:pointer;min-width:140px}.date-input:hover{border-color:#3b82f6}.date-input:focus{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f666}.date-input::-webkit-calendar-picker-indicator{filter:invert(.8);cursor:pointer}.date-input::-webkit-datetime-edit{padding:0}.date-input::-moz-focus-inner{border:0}.date-input:disabled{opacity:.5;cursor:not-allowed}.status{display:inline-flex;align-items:center;justify-content:center;border-radius:9px;font-size:9px;white-space:nowrap;padding:5px 7px;font-weight:450}.status-running{background:#dcfce7;color:#166534}.status-stopped{background:#c03f3f;color:#dfe0e2}.status-warning{background:#facc15;color:#000}.page-header-row{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.page-header-left h1{margin:0;font-size:22px;font-weight:600;color:#020617}.page-header-left p{margin:6px 0 0;font-size:14px;color:#64748b}.page-header-right{display:flex;align-items:center}.header-actions{display:flex;gap:8px;align-items:center}.page-body{display:flex;justify-content:center}.table-wrapper{width:100%;max-width:1200px}.table-search{height:30px;padding:0 10px;margin-right:10px;border:1px solid #d0d0d0;border-radius:6px;min-width:240px}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 16px;border-top:1px solid #2a2a2a;background:#ffffff05}.pagination span{font-size:13px;opacity:.8}.pagination button{padding:6px 14px;border-radius:6px;border:1px solid #2a2a2a;background:transparent;color:inherit;cursor:pointer}.pagination button:hover:not(:disabled){background:#ffffff14}.pagination button:disabled{opacity:.4;cursor:not-allowed}.modal-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:60000;padding:16px;overflow:hidden}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:60000;padding:16px}.modal{background:#fff;width:600px;max-width:95%;border-radius:8px;padding:20px 24px;box-shadow:0 10px 40px #0000004d;max-height:calc(100vh - 160px);overflow:auto}.modal-sm{width:420px}.modal-lg{width:min(950px,95vw);max-height:calc(100vh - 160px);padding:10px 20px;overflow:hidden;display:flex;flex-direction:column}.modal-header{padding:12px 16px;border-bottom:1px solid #2c2f36;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-body{padding:10px;overflow-y:auto;min-height:0}.modal-close{background:none;border:none;color:#941717;font-size:18px;cursor:pointer}.modal h2{margin:0 0 16px}.modal label{display:block;font-weight:600;margin:12px 0 6px}.modal input,.modal select{width:100%;padding:8px 10px;border-radius:4px;border:1px solid #ccc}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.modal-actions button{padding:8px 14px;border-radius:4px;border:none;cursor:pointer}.modal-actions .btn-primary{background:#2563eb;color:#fff}.modal-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}.toast-container{position:fixed;top:96px;right:20px;z-index:50000;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{padding:12px 16px;border-radius:6px;font-size:14px;color:#fff;min-width:280px;box-shadow:0 6px 20px #00000026;animation:slideIn .2s ease-out;pointer-events:auto}.toast-success{background:#16a34a}.toast-error{background:#dc2626}.toast-info{background:#2563eb}.toast-warning{background:#d97706}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.warning-page{padding:40px;text-align:center;border-radius:6px}.warning-page h2{color:#856404;margin-bottom:10px}.warning-page p{color:#856404}.detail-table{width:100%;border-collapse:collapse}.detail-table th{text-align:left;width:150px;color:#272829;font-weight:500;padding:6px 0}.detail-table td{padding:7px 15px}.json-viewer{background:#12100b;border:1px solid #2c2f36;border-radius:6px;padding:12px;font-size:12px;max-height:240px;overflow:auto;color:#fff}.auth-settings{max-width:760px;padding:8px 0;display:unset}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 0;border-bottom:1px solid #262626}.setting-row:last-child{border-bottom:none}.setting-row label{flex:0 0 280px;font-size:18px;font-weight:500;color:#050505}.switch-group{display:inline-flex;background:#141414;border:1px solid #2f2f2f;border-radius:8px;overflow:hidden}.switch-btn{min-width:96px;padding:7px 0;background:transparent;border:none;border-right:1px solid #2f2f2f;font-size:13px;font-weight:500;color:#9a9a9a;cursor:pointer;transition:all .15s ease}.switch-btn:last-child{border-right:none}.switch-btn:hover{background:#1d1d1d;color:#fff}.switch-btn.active{background:#2d6cdf;color:#fff}.setting-actions{display:flex;justify-content:flex-end;margin-top:28px}.direction-badge{display:inline-flex;align-items:center;gap:6px}.filters.stacked{display:flex;flex-direction:column;gap:8px;width:100%}.filter-label{font-size:17px;font-weight:600;color:#707586;white-space:nowrap}.filter-row{display:flex;align-items:center;justify-content:flex-end;gap:8px;width:100%;flex-wrap:nowrap}.filter-row input[type=date],.filter-row select{min-width:140px}.filter-row button{white-space:nowrap}.filter-row.secondary select{min-width:160px}.btn-sm{padding:4px 8px;font-size:12px;background-color:#153f15}.muted{color:#888;font-style:italic}.legs-container{display:flex;flex-direction:column;gap:6px;background:#fff;border:1px solid #e2e4ea;padding:10px;border-radius:6px}.leg-header{font-weight:600;font-size:11px;color:#6b7280;background:#f8f9fc;border-radius:4px;padding:6px 0}.leg-item{display:grid;grid-template-columns:90px 160px 160px 70px 70px minmax(220px,1.5fr) 140px 80px;align-items:center;gap:8px}.leg-item span{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leg-main{display:flex;gap:12px;align-items:center;font-size:12px}.resource{display:inline-flex;align-items:center;gap:6px;min-width:0}.resource span{overflow:hidden;text-overflow:ellipsis}.resource svg{opacity:.9}.resource.device svg{color:#3fdb01}.resource.campaign svg{color:#7c3aed;font-weight:600}.resource.offnet svg{color:#f5a623}.resource.muted{color:#9aa0b4}.endpoint{display:inline-flex;align-items:center;gap:6px;font-size:12px}.endpoint svg{font-size:13px;opacity:.85}.endpoint-user svg{color:#2563eb}.endpoint-device svg{color:#059669}.endpoint-carrier svg{color:#9333ea}.endpoint-campaign svg{color:#cf2d05;font-weight:600}.endpoint.muted{color:#9aa0b4}.preset-group{display:inline-flex;gap:6px;margin-right:8px}.preset-group .btn-sm{padding:4px 8px;font-size:12px}.recording-actions{display:flex;gap:12px;margin-top:12px;justify-content:center}.btn-icon{width:38px;height:38px;border-radius:50%;border:1px solid #d0d4e4;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.btn-icon:hover{background:#f3f5ff;border-color:#4f6bed;color:#4f6bed}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.details-table{width:100%;border-collapse:collapse;margin-bottom:16px}.details-table td{padding:6px 8px;border-bottom:1px solid #eee}.details-table.small td{font-size:12px}.sdp-box{background:#0f1220;color:#d6d8ff;padding:12px;border-radius:6px;font-family:monospace;font-size:12px;white-space:pre-wrap;overflow-x:auto}.summary-kpi{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px}.summary-kpi-title{font-size:12px;color:#64748b;font-weight:600;margin-bottom:6px}.summary-kpi-value{font-size:20px;font-weight:700;color:#0f172a}.summary-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px}.contact-list-page .page-body{display:block!important;width:100%;max-width:none;padding:12px}.contact-list-page .page-body>div{width:100%;max-width:none}.contact-list-page .table-wrapper{width:100%;max-width:none}.contact-list-page .contact-list-grid{width:100%}.contact-list-page .contact-list-grid>div:first-child{position:sticky;top:88px;align-self:start;max-height:calc(100vh - 140px);overflow:auto}.license-badge{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.4px}.license-active{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.35)}.license-disabled{background:#facc1526;color:#facc15;border:1px solid rgba(250,204,21,.35)}.license-missing{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.35)}.license-checking{background:#94a3b826;color:#94a3b8;border:1px solid rgba(148,163,184,.35)}.mono{font-family:ui-monospace,SFMono-Regular,monospace;font-size:13px}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
