@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg: #0d1117;--bg-card: #161b22;--bg-hover: #21262d;--border: #30363d;--text: #e6edf3;--text-muted: #8b949e;--accent: #39d353;--accent-dim: #238636;--danger: #f85149;--warning: #d29922;--radius: 8px;--font-sans: "DM Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace}*{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}code,.mono{font-family:var(--font-mono)}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-muted)}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:1rem 1.5rem}.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.logo{font-size:1.25rem;font-weight:600;margin:0;display:flex;align-items:center;gap:.5rem}.logo-icon{font-size:1.5rem}.header-right{display:flex;align-items:center;gap:1rem}.user-email{font-size:.875rem;color:var(--text-muted)}.main{flex:1;padding:2rem 1.5rem;max-width:1200px;margin:0 auto;width:100%}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem;width:100%;max-width:400px}.auth-title{font-size:1.5rem;margin:0 0 .5rem;display:flex;align-items:center;gap:.5rem}.auth-subtitle{color:var(--text-muted);margin:0 0 1.5rem;font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-footer{margin:1.5rem 0 0;text-align:center;color:var(--text-muted);font-size:.9rem}.field{display:flex;flex-direction:column;gap:.4rem}.field label{font-size:.875rem;font-weight:500;color:var(--text-muted)}.field input,.field textarea{padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:1rem}.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent)}.form-row{display:flex;gap:1rem;flex-wrap:wrap}.flex-1{flex:1;min-width:200px}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.btn{padding:.5rem 1rem;border-radius:var(--radius);font-size:.9rem;font-weight:500;border:none;transition:background .15s}.btn-primary{background:var(--accent);color:var(--bg)}.btn-primary:hover:not(:disabled){background:var(--accent-dim)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text)}.btn-danger{background:transparent;color:var(--danger)}.btn-danger:hover{background:#f8514926}.btn-success{background:#39d35333;color:var(--accent)}.btn-success:hover{background:#39d3534d}.btn-block{width:100%}.btn-sm{padding:.35rem .65rem;font-size:.8rem}.alert{padding:.75rem 1rem;border-radius:var(--radius);font-size:.9rem}.alert-error{background:#f8514926;color:var(--danger)}.page-header{margin-bottom:2rem}.page-header h2{margin:0 0 .5rem;font-size:1.5rem}.text-muted{color:var(--text-muted);font-size:.9rem;margin:0}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.card-header h3{margin:0;font-size:1.1rem}.webhook-card{margin-bottom:2rem}.webhook-card h3{margin:0 0 .5rem;font-size:1.1rem}.webhook-card .text-muted{margin-bottom:1rem}.webhook-url-box{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;background:var(--bg);padding:.75rem 1rem;border-radius:var(--radius);border:1px solid var(--border)}.webhook-url{flex:1;min-width:0;font-size:.85rem;word-break:break-all}.webhook-hint{margin-top:1rem;font-size:.85rem;color:var(--text-muted)}.webhook-hint code{font-size:.8rem;background:var(--bg);padding:.2rem .4rem;border-radius:4px}.webhook-hint .ml-1{margin-left:.5rem}.api-key{word-break:break-all}.dest-form{padding:1rem 0;border-bottom:1px solid var(--border);margin-bottom:1rem}.dest-list{list-style:none;margin:0;padding:0}.dest-item{display:flex;align-items:center;justify-content:space-between;padding:1rem;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem;flex-wrap:wrap;gap:.75rem}.dest-item.inactive{opacity:.6}.dest-info{display:flex;flex-direction:column;gap:.25rem}.dest-name{font-weight:500}.dest-url{font-size:.8rem;color:var(--text-muted);word-break:break-all}.dest-actions{display:flex;gap:.5rem;flex-wrap:wrap}.empty-state{text-align:center;padding:2rem}.empty-state p{margin:0 0 .5rem}.empty-state .btn{margin-top:1rem}.badge-admin{font-size:.7rem;background:var(--accent-dim);color:#fff;padding:.15rem .4rem;border-radius:4px;margin-left:.5rem}.badge-inactive{font-size:.7rem;background:var(--text-muted);color:var(--bg);padding:.15rem .4rem;border-radius:4px;margin-left:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.checkbox-label input[type=checkbox]{width:1rem;height:1rem;cursor:pointer}.btn:disabled{opacity:.5;cursor:not-allowed}.stats-panel .card-header h3{display:flex;align-items:center;gap:.5rem}.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:live-pulse 1.6s ease-in-out infinite}.live-dot-err{background:var(--danger);box-shadow:0 0 8px var(--danger);animation:none}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1rem}.stat-card{padding:.85rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-hover)}.stat-card.stat-ok{border-color:var(--accent-dim);background:#2386361f}.stat-card.stat-err{border-color:var(--danger);background:#f851491a}.stat-label{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:1.6rem;font-weight:600;color:var(--text);margin-top:.2rem;font-variant-numeric:tabular-nums}.stat-sub{font-size:.78rem;color:var(--text-muted);margin-top:.15rem}.stats-section{margin-top:1rem}.stats-section h4{font-size:.85rem;color:var(--text);margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.04em;opacity:.85}.sparkline{display:flex;align-items:flex-end;gap:2px;height:60px;padding:.25rem 0;border-bottom:1px solid var(--border)}.spark-col{position:relative;flex:1;display:flex;flex-direction:column;justify-content:flex-end;height:100%;min-width:4px}.spark-ok{background:var(--accent);width:100%;border-radius:1px 1px 0 0}.spark-err{background:var(--danger);width:100%}.spark-empty{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--border);border-radius:1px}.stats-list{list-style:none;padding:0;margin:0}.stats-row{display:grid;grid-template-columns:1fr auto auto auto;gap:.75rem;align-items:center;padding:.5rem .25rem;border-bottom:1px solid var(--border);font-size:.9rem;font-variant-numeric:tabular-nums}.stats-row:last-child{border-bottom:none}.stats-row-label{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-row-ok{color:var(--accent);min-width:4ch;text-align:right}.stats-row-err{color:var(--danger);min-width:4ch;text-align:right}.stats-row-rate{color:var(--text-muted);min-width:5ch;text-align:right}.stats-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}.stats-section-header h4{margin:0}.stats-row-with-action{grid-template-columns:1fr auto auto auto auto}.stats-section .stats-row-with-action:has(>.stats-row-rate:nth-child(2):last-child){grid-template-columns:1fr auto auto}.btn-reset-tiny{display:inline-flex;align-items:center;justify-content:center;width:1.4rem;height:1.4rem;padding:0;border:1px solid var(--border);background:transparent;color:var(--text-muted);border-radius:4px;cursor:pointer;font-size:.95rem;line-height:1;transition:all .15s ease}.btn-reset-tiny:hover:not(:disabled){border-color:var(--danger);color:var(--danger);background:#f8514914}.btn-reset-tiny:disabled{opacity:.4;cursor:not-allowed}.types-detected{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border)}.types-detected h4{margin:0 0 .4rem;font-size:.85rem;color:var(--warning);text-transform:uppercase;letter-spacing:.04em}.types-detected-list{list-style:none;padding:0;margin:.5rem 0 0}.types-detected-list li{display:flex;align-items:center;gap:.75rem;padding:.4rem 0;border-bottom:1px solid var(--border)}.types-detected-list li:last-child{border-bottom:none}.types-detected-list li code{flex:1;font-family:var(--font-mono);color:var(--text)}.types-picker{margin-top:.5rem;padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg)}.types-checkboxes{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.4rem .75rem}.types-checkboxes label{display:flex;align-items:center;gap:.5rem;font-size:.88rem}.types-checkboxes code{font-size:.78rem;color:var(--text-muted);margin-left:auto}.dest-types{margin-top:.4rem;display:flex;flex-wrap:wrap;gap:.3rem;align-items:center;font-size:.78rem}.dest-types-all{color:var(--text-muted);font-style:italic}.dest-types-none{color:var(--warning);font-weight:500}.dest-type-tag{padding:.1rem .5rem;background:var(--bg);border:1px solid var(--border);border-radius:999px;color:var(--text);font-family:var(--font-mono);font-size:.75rem}.dest-transform-badge{display:inline-block;margin-left:.5rem;padding:.1rem .55rem;background:#d299222e;color:var(--warning);border:1px solid var(--warning);border-radius:999px;font-size:.72rem;font-weight:500;vertical-align:middle}.devices-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.6rem;margin:.4rem 0 .8rem}.device-summary-card{padding:.7rem .9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-hover)}.device-summary-card.device-active{border-color:var(--accent-dim);background:#2386361f}.device-summary-label{font-size:.74rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.device-summary-value{font-size:1.4rem;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums;margin-top:.15rem}.devices-list{list-style:none;padding:0;margin:0}.device-item{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem;background:var(--bg-card);overflow:hidden}.device-item.device-on{border-left:3px solid var(--accent)}.device-item.device-off{border-left:3px solid var(--border);opacity:.85}.device-row{display:flex;align-items:center;gap:.75rem;padding:.6rem .85rem}.device-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.device-dot-on{background:var(--accent);box-shadow:0 0 6px var(--accent);animation:live-pulse 1.6s ease-in-out infinite}.device-dot-off{background:var(--text-muted);opacity:.5}.device-info{flex:1;min-width:0}.device-mac{font-family:var(--font-mono);font-size:.92rem;color:var(--text);display:block;margin-bottom:.2rem}.device-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;font-size:.8rem;color:var(--text-muted)}.device-meta strong{color:var(--text);font-variant-numeric:tabular-nums}.device-actions{display:flex;gap:.4rem;flex-shrink:0}.device-types{list-style:none;padding:.5rem .85rem .7rem 1.85rem;margin:0;background:var(--bg);border-top:1px solid var(--border)}.device-types li{display:flex;align-items:center;gap:.6rem;padding:.2rem 0;font-size:.85rem}.device-types code{flex:1;font-family:var(--font-mono);color:var(--text)}.device-types span{font-variant-numeric:tabular-nums}.badge-fail{display:inline-block;padding:.1rem .55rem;margin-left:.5rem;background:var(--danger);color:#fff;border-radius:999px;font-size:.78rem;font-weight:600;vertical-align:middle}.failed-list{list-style:none;padding:0;margin:0}.failed-item{border:1px solid var(--border);border-radius:var(--radius);background:#f851490f;margin-bottom:.5rem;padding:.75rem 1rem}.failed-row{display:flex;align-items:flex-start;gap:1rem}.failed-info{flex:1;min-width:0}.failed-line{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem;flex-wrap:wrap}.failed-line strong{color:var(--text)}.failed-type{font-size:.78rem;padding:.1rem .5rem;border:1px solid var(--border);border-radius:999px;color:var(--text-muted)}.failed-time{font-size:.8rem;color:var(--text-muted);margin-left:auto}.failed-error{color:var(--danger);font-size:.88rem;margin:.25rem 0;word-break:break-word}.failed-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.8rem}.failed-url{color:var(--text-muted);font-family:var(--font-mono);font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.failed-actions{display:flex;gap:.4rem;flex-shrink:0}.failed-payload{margin:.75rem 0 0;padding:.75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:.8rem;color:var(--text);max-height:300px;overflow:auto;white-space:pre-wrap;word-break:break-all}.samples-types{list-style:none;padding:0;margin:0}.samples-type{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.4rem;overflow:hidden}.samples-type-header{display:flex;align-items:center;gap:.6rem;width:100%;padding:.6rem .85rem;background:var(--bg-hover);border:none;color:var(--text);font-family:inherit;font-size:.92rem;text-align:left;cursor:pointer}.samples-type-header:hover{background:#ffffff0a}.samples-type-arrow{color:var(--text-muted);font-size:.7rem;width:.85rem;display:inline-block}.samples-type-name{flex:1;font-weight:500;font-family:var(--font-mono)}.samples-type-count{background:var(--bg);color:var(--text-muted);padding:.1rem .55rem;border-radius:999px;font-size:.78rem;font-variant-numeric:tabular-nums}.samples-list{list-style:none;padding:.4rem .6rem .6rem;margin:0;background:var(--bg)}.sample-item{border-bottom:1px solid var(--border)}.sample-item:last-child{border-bottom:none}.sample-meta{display:flex;align-items:center;gap:.75rem;width:100%;padding:.45rem .4rem;background:transparent;border:none;color:var(--text);font-family:inherit;font-size:.85rem;text-align:left;cursor:pointer}.sample-meta:hover{background:#ffffff08}.sample-time{font-family:var(--font-mono);color:var(--text);min-width:8ch}.sample-ct{color:var(--text-muted);font-family:var(--font-mono);font-size:.78rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sample-size{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.78rem}.badge-trunc{background:var(--warning);color:#000;padding:.05rem .45rem;border-radius:999px;font-size:.7rem;font-weight:600}.sample-detail{padding:.5rem .4rem .6rem}.sample-detail h5{margin:.4rem 0 .3rem;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.sample-pre{margin:0;padding:.6rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:.78rem;color:var(--text);max-height:280px;overflow:auto;white-space:pre-wrap;word-break:break-all}.sample-row{display:flex;align-items:center;gap:.4rem;padding:0 .4rem}.sample-row .sample-meta{flex:1}.trace-compare{margin:.5rem .4rem .6rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);padding:.6rem}.trace-cols{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}@media(max-width:900px){.trace-cols{grid-template-columns:1fr}}.trace-col{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.6rem;min-width:0}.trace-col-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem;border-bottom:1px solid var(--border);padding-bottom:.3rem}.trace-col-header h5{margin:0;font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.trace-col-in{border-left:3px solid var(--accent)}.trace-col-out{border-left:3px solid var(--warning)}.trace-time{color:var(--text-muted);font-family:var(--font-mono);font-size:.78rem}.trace-meta{display:flex;flex-wrap:wrap;gap:.6rem 1rem;font-size:.82rem;color:var(--text);margin-bottom:.4rem}.trace-meta strong{color:var(--text-muted);font-weight:500}.trace-col h6{font-size:.74rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:.5rem 0 .25rem;display:flex;align-items:center;gap:.4rem}.trace-pre{margin:0;padding:.5rem .65rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:.76rem;color:var(--text);max-height:240px;overflow:auto;white-space:pre-wrap;word-break:break-all}.trace-dest{border:1px solid var(--border);border-radius:var(--radius);padding:.5rem .6rem;margin-bottom:.5rem;background:var(--bg-card)}.trace-dest:last-child{margin-bottom:0}.trace-dest-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem;flex-wrap:wrap}.trace-dest-url{flex:1;font-family:var(--font-mono);font-size:.78rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.trace-status{padding:.1rem .55rem;border-radius:999px;font-weight:600;font-size:.78rem;font-variant-numeric:tabular-nums}.trace-status-ok{background:#23863640;color:var(--accent);border:1px solid var(--accent-dim)}.trace-status-err{background:#f851492e;color:var(--danger);border:1px solid var(--danger)}.trace-status-warn{background:#d299222e;color:var(--warning);border:1px solid var(--warning)}.trace-status-pending{background:var(--bg-hover);color:var(--text-muted);border:1px solid var(--border)}.trace-error{color:var(--danger);font-size:.82rem;margin:.3rem 0;word-break:break-word}.trace-dest-section{margin-top:.4rem}.trace-dest-section>summary{cursor:pointer;font-size:.78rem;color:var(--text-muted);padding:.2rem 0}.trace-dest-section[open]>summary{margin-bottom:.3rem;color:var(--text)}
