:root{--bg: #060a10;--surface: #0c1219;--surface-2: #141c26;--surface-3: #1c2633;--border: #1e2a36;--border-hover: #2c3e50;--text: #dce4ec;--text-muted: #6b7f94;--accent: #38bdf8;--accent-hover: #7dd3fc;--accent-glow: rgba(56, 189, 248, .1);--accent-subtle: rgba(56, 189, 248, .05);--green: #4ade80;--green-bg: rgba(74, 222, 128, .08);--red: #fb7185;--red-bg: rgba(251, 113, 133, .08);--yellow: #fbbf24;--star: #fbbf24;--radius: 8px;--radius-sm: 5px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--transition: .15s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:Urbanist,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 50% at 15% 45%,rgba(56,189,248,.03) 0%,transparent 70%),radial-gradient(ellipse 40% 60% at 85% 25%,rgba(56,189,248,.02) 0%,transparent 60%);pointer-events:none;z-index:0}code,pre{font-family:JetBrains Mono,SF Mono,Cascadia Code,monospace}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}button:focus:not(:focus-visible),input:focus:not(:focus-visible),select:focus:not(:focus-visible),textarea:focus:not(:focus-visible){outline:none}#app{display:flex;flex-direction:column;height:100vh;overflow:hidden;position:relative;z-index:1}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg);z-index:1000}.login-overlay:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 50% 40% at 50% 50%,rgba(56,189,248,.06) 0%,transparent 70%);pointer-events:none}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px;width:380px;max-width:calc(100vw - 32px);display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-lg);position:relative;z-index:1;animation:modalSlideUp .2s ease}.login-card h2{font-size:20px;font-weight:700;text-align:center;letter-spacing:-.02em}.login-subtitle{font-size:13px;color:var(--text-muted);text-align:center;margin-top:-8px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.login-field input,.login-field select,.login-field textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:10px 12px;font-size:14px;font-family:inherit;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.login-field input:focus,.login-field select:focus,.login-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.login-error{font-size:13px;color:var(--red);text-align:center}.field-hint{font-size:11px;color:var(--text-muted);line-height:1.4}.login-btn{margin-top:4px}.form-select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:10px 32px 10px 12px;font-size:14px;font-family:inherit;outline:none;transition:border-color var(--transition),box-shadow var(--transition);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b7f94' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.btn{background:var(--surface-2);color:var(--text);border:1px solid var(--border);padding:7px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition);font-family:inherit;white-space:nowrap}.btn:hover{background:var(--surface-3);border-color:var(--border-hover)}.btn:active{transform:scale(.97)}.btn-sm{padding:5px 10px;font-size:12px}.btn-primary{background:var(--accent);color:#060a10;border:1px solid transparent;padding:10px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:700;cursor:pointer;transition:all var(--transition);font-family:inherit}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 0 16px var(--accent-glow)}.btn-primary:active{transform:scale(.97)}.btn-primary.btn-sm{padding:5px 12px;font-size:12px}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-muted)}.btn-ghost:hover{color:var(--text);background:var(--surface-2)}.btn-danger{background:var(--red-bg);border-color:#fb71854d;color:var(--red)}.btn-danger:hover{background:var(--red);border-color:var(--red);color:#fff}.btn-icon{background:none;border:none;cursor:pointer;font-size:18px;padding:4px 6px;border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition);line-height:1}.btn-icon:hover{background:var(--surface-2);color:var(--text)}.btn-icon-danger:hover{color:var(--red)}.btn-icon.starred{color:var(--star)}header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;position:relative;z-index:2}.header-left{display:flex;align-items:center;gap:12px;min-width:0}h1{font-size:17px;font-weight:700;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.badge{font-size:10px;font-weight:700;padding:3px 10px;border-radius:100px;text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;display:inline-flex;align-items:center;gap:6px}.badge:before{content:"";width:6px;height:6px;border-radius:50%;flex-shrink:0}.badge.connected{background:var(--green-bg);color:var(--green)}.badge.connected:before{background:var(--green)}.badge.disconnected{background:var(--red-bg);color:var(--red)}.badge.disconnected:before{background:var(--red)}.badge.connecting{background:#fbbf2414;color:var(--yellow)}.badge.connecting:before{background:var(--yellow);animation:badgePulse 1.2s ease-in-out infinite}@keyframes badgePulse{0%,to{opacity:1}50%{opacity:.3}}.back-btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-size:16px;width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0}.back-btn:hover{background:var(--surface-3);border-color:var(--border-hover);color:var(--accent)}#view-index{display:flex;flex-direction:column;flex:1;overflow:hidden}.index-toolbar{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.index-title{font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.01em}.endpoints-grid{overflow-y:auto;flex:1;background:var(--bg)}.endpoint-row{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid var(--border);cursor:pointer;transition:all .12s ease}.endpoint-row:hover{background:var(--surface)}.endpoint-row:active{background:var(--surface-2)}.endpoint-row-left{display:flex;align-items:center;gap:10px;min-width:0}.endpoint-row-name{font-size:14px;font-weight:700;color:var(--text);white-space:nowrap}.endpoint-row-slug{font-size:12px;color:var(--accent);font-family:JetBrains Mono,monospace;white-space:nowrap;opacity:.85}.endpoint-lock{font-size:12px;opacity:.4;flex-shrink:0}.endpoint-row-right{display:flex;align-items:center;gap:16px;flex-shrink:0}.endpoint-row-desc{font-size:12px;color:var(--text-muted);max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.endpoint-row-forwards{font-size:11px;color:var(--text-muted);white-space:nowrap;font-variant-numeric:tabular-nums}.endpoint-row-forwards.has-forwards{color:var(--accent)}.endpoint-row-count{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap}.endpoint-row-time{font-size:11px;color:var(--text-muted);white-space:nowrap;min-width:80px;text-align:right;font-variant-numeric:tabular-nums}.endpoint-row-arrow{font-size:18px;color:var(--text-muted);opacity:.3;transition:all var(--transition)}.endpoint-row:hover .endpoint-row-arrow{opacity:1;color:var(--accent);transform:translate(2px)}#view-detail{display:flex;flex-direction:column;flex:1;overflow:hidden}.url-bar{display:flex;align-items:center;gap:10px;padding:10px 24px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.url-bar .label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;flex-shrink:0}.url-bar code{font-size:12px;color:var(--accent);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-view-tabs{display:flex;gap:0;padding:0 24px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.detail-view-tab{background:none;border:none;color:var(--text-muted);font-size:13px;font-weight:700;padding:11px 20px;cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition);font-family:inherit;letter-spacing:.01em;position:relative}.detail-view-tab:hover{color:var(--text)}.detail-view-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.detail-view-panel{display:flex;flex-direction:column;flex:1;overflow:hidden}.incoming-toolbar{display:flex;align-items:center;gap:12px;padding:10px 24px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.event-count{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums;font-weight:600}.incoming-toolbar .filter-tabs{margin-left:auto}.panel-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.panel-toolbar-title{font-size:13px;font-weight:700;color:var(--text)}.panel-content{flex:1;overflow-y:auto;padding:16px 24px}.filter-tabs{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.filter-tab{background:transparent;border:none;color:var(--text-muted);font-size:11px;font-weight:600;padding:4px 12px;cursor:pointer;transition:all var(--transition);font-family:inherit}.filter-tab:hover{color:var(--text);background:var(--surface-2)}.filter-tab.active{background:var(--accent);color:var(--bg)}main{display:grid;grid-template-columns:360px 1fr;flex:1;overflow:hidden}.event-list{border-right:1px solid var(--border);overflow-y:auto;background:var(--bg)}.event-item{display:flex;align-items:center;gap:8px;padding:11px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s ease;animation:slideIn .2s ease;position:relative}@keyframes slideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.event-item:hover{background:var(--surface)}.event-item.active{background:var(--accent-glow);border-left:3px solid var(--accent);padding-left:13px}.event-item .method{font-size:10px;font-weight:800;color:var(--green);background:var(--green-bg);padding:2px 7px;border-radius:3px;letter-spacing:.04em;font-family:JetBrains Mono,monospace;flex-shrink:0}.event-item .path{font-size:12px;color:var(--text);font-family:JetBrains Mono,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.event-item .time{font-size:10px;color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-variant-numeric:tabular-nums}.event-item .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:dotPulse 1s ease-in-out}@keyframes dotPulse{0%{box-shadow:0 0 #38bdf880}70%{box-shadow:0 0 0 7px #38bdf800}to{box-shadow:0 0 #38bdf800}}.event-item .item-actions{display:flex;gap:2px;opacity:0;transition:opacity var(--transition);flex-shrink:0}.event-item:hover .item-actions{opacity:1}.event-item .item-actions .btn-icon{font-size:14px;padding:2px 4px}.event-item .item-star{flex-shrink:0;color:var(--star);font-size:12px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:48px 32px;text-align:center;color:var(--text-muted)}.empty-icon{margin-bottom:20px;opacity:.25;color:var(--accent)}.empty-state h2{font-size:15px;font-weight:700;color:var(--text);margin-bottom:8px;letter-spacing:-.01em}.empty-state p{font-size:13px;max-width:320px;line-height:1.6;margin-bottom:20px}.empty-state .example{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;font-size:11px;color:var(--text-muted);text-align:left;line-height:1.8;max-width:100%;overflow-x:auto}.event-detail{display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.detail-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:13px;font-weight:500}.detail-content{display:flex;flex-direction:column;height:100%;overflow:hidden}.detail-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.detail-header-left{display:flex;align-items:center;gap:12px;min-width:0}.detail-header h3{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-time{font-size:11px;color:var(--text-muted);flex-shrink:0}.detail-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.detail-tabs{display:flex;gap:0;padding:0 24px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}.tab{background:none;border:none;color:var(--text-muted);font-size:12px;font-weight:600;padding:10px 14px;cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition);font-family:inherit}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-panel{display:none;flex:1;overflow:auto;padding:16px 24px}.tab-panel.active{display:block}.tab-panel pre{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;overflow:auto;font-size:12px;line-height:1.7}.tab-panel pre code{color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#000000a6;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;animation:overlayFadeIn .15s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-actions{display:flex;align-items:center;gap:8px;margin-top:8px}.modal-spacer{flex:1}.modal-card-wide{width:500px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.forwards-list{display:flex;flex-direction:column;gap:8px}.forwards-empty{font-size:13px;color:var(--text-muted);text-align:center;padding:24px 0}.forward-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);gap:12px;transition:border-color var(--transition)}.forward-row:hover{border-color:var(--border-hover)}.forward-row-info{flex:1;min-width:0}.forward-row-top{display:flex;align-items:center;gap:8px;margin-bottom:4px}.toggle-switch{position:relative;width:36px;height:20px;background:var(--border);border:none;border-radius:10px;cursor:pointer;transition:background .2s ease;flex-shrink:0;padding:0}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:var(--text-muted);border-radius:50%;transition:transform .2s ease,background .2s ease}.toggle-switch.active{background:#4ade8033}.toggle-switch.active:after{transform:translate(16px);background:var(--green);box-shadow:0 0 6px #4ade8066}.toggle-switch:hover{background:var(--border-hover)}.toggle-switch.active:hover{background:#4ade804d}.forward-method-badge{font-size:10px;font-weight:800;color:var(--accent);background:var(--accent-glow);padding:1px 6px;border-radius:3px;font-family:JetBrains Mono,monospace;letter-spacing:.03em;flex-shrink:0}.forward-row-disabled{opacity:.55}.forward-row-disabled:hover{opacity:.75}.forward-row-name{font-size:13px;font-weight:700;color:var(--text)}.forward-paused{font-size:11px;color:var(--text-muted);font-style:italic}.forward-row-url{font-size:11px;color:var(--text-muted);font-family:JetBrains Mono,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.forward-row-actions{display:flex;gap:6px;flex-shrink:0}.code-textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:10px 12px;font-size:12px;font-family:JetBrains Mono,monospace;width:100%;resize:vertical;outline:none;transition:border-color var(--transition),box-shadow var(--transition);line-height:1.6}.code-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.test-panel{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.test-panel-col{display:flex;flex-direction:column;gap:6px}.test-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.test-output{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font-size:12px;font-family:JetBrains Mono,monospace;color:var(--text);min-height:120px;overflow:auto;line-height:1.6;white-space:pre-wrap;word-break:break-all}.delivery-indicator{display:flex;gap:2px;flex-shrink:0;font-size:12px}.delivery-ok{color:var(--green)}.delivery-fail{color:var(--red)}.deliveries-empty{font-size:13px;color:var(--text-muted);text-align:center;padding:24px 0}.delivery-log-item{padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;transition:border-color var(--transition)}.delivery-log-item:hover{border-color:var(--border-hover)}.delivery-log-header{display:flex;align-items:center;gap:10px;font-size:13px}.delivery-log-ok{color:var(--green);font-weight:800;font-size:14px}.delivery-log-fail{color:var(--red);font-weight:800;font-size:14px}.delivery-log-name{font-weight:700;color:var(--text)}.delivery-log-status{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:11px}.delivery-log-duration{color:var(--text-muted);font-size:11px;margin-left:auto;font-variant-numeric:tabular-nums}.delivery-log-time{font-size:11px;color:var(--text-muted)}.delivery-log-error{margin-top:8px;font-size:11px;color:var(--red);font-family:JetBrains Mono,monospace;line-height:1.5}.delivery-log-response{margin-top:8px;font-size:11px;color:var(--text-muted);font-family:JetBrains Mono,monospace;white-space:pre-wrap;word-break:break-all;line-height:1.5}.logs-list{display:flex;flex-direction:column;gap:8px}.logs-empty{display:flex;align-items:center;justify-content:center;padding:48px}.template-ref{display:flex;flex-wrap:wrap;align-items:center;gap:5px;margin-top:2px}.template-ref-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-right:2px}.template-ref code{font-size:10px;background:var(--surface-2);border:1px solid var(--border);padding:1px 6px;border-radius:3px;color:var(--accent);font-family:JetBrains Mono,monospace}.calls-list{display:flex;flex-direction:column;gap:12px}.calls-empty{display:flex;align-items:center;justify-content:center;padding:48px}.calls-count{font-size:12px;color:var(--text-muted);font-weight:600;font-variant-numeric:tabular-nums}.call-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:border-color var(--transition)}.call-card:hover{border-color:var(--border-hover)}.call-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.call-card-info{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600}.call-from{color:var(--text);font-family:JetBrains Mono,monospace;font-size:13px}.call-arrow{color:var(--text-muted);font-size:12px}.call-to{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:13px}.call-card-meta{display:flex;align-items:center;gap:10px}.call-status-badge{font-size:10px;font-weight:700;padding:3px 10px;border-radius:100px;text-transform:uppercase;letter-spacing:.06em}.call-status-badge.status-active{background:var(--green-bg);color:var(--green)}.call-status-badge.status-ringing{background:#fbbf2414;color:var(--yellow);animation:badgePulse 1.2s ease-in-out infinite}.call-status-badge.status-other{background:var(--surface-2);color:var(--text-muted)}.call-card-actions{display:flex;gap:8px;margin-bottom:4px}.call-card-actions .btn-active{background:var(--green-bg);border-color:#4ade804d;color:var(--green)}.call-dtmf-pad{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.dtmf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-width:200px}.dtmf-key{background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-size:16px;font-weight:700;font-family:JetBrains Mono,monospace;padding:10px 0;border-radius:var(--radius-sm);cursor:pointer;transition:all .1s ease;text-align:center}.dtmf-key:hover{background:var(--surface-3);border-color:var(--border-hover);color:var(--accent)}.dtmf-key:active,.dtmf-key.dtmf-pressed{background:var(--accent);color:var(--bg);border-color:var(--accent);transform:scale(.95)}@media(max-width:1024px){main{grid-template-columns:300px 1fr}.event-item{padding:10px 12px}}@media(max-width:768px){main{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.event-list{border-right:none;border-bottom:1px solid var(--border)}.endpoint-row-desc{display:none}.url-bar{padding:10px 16px;gap:8px}.url-bar .label{display:none}.incoming-toolbar{padding:10px 16px}.detail-view-tabs{padding:0 16px}header{padding:12px 16px}.index-toolbar,.endpoint-row,.panel-toolbar,.panel-content,.detail-header{padding:12px 16px}.detail-tabs{padding:0 16px}.tab-panel{padding:12px 16px}}@media(max-width:480px){.login-card{padding:28px 24px;width:100%;max-width:calc(100vw - 24px);border-radius:var(--radius)}.modal-card-wide{width:100%;max-width:calc(100vw - 24px)}.test-panel{grid-template-columns:1fr}.endpoint-row-time,.filter-tabs{display:none}main{grid-template-columns:1fr;grid-template-rows:200px 1fr}h1{font-size:15px}.detail-view-tab{padding:10px 14px;font-size:12px}}.flow-builder{display:flex;flex:1;overflow:hidden;height:100%}.flow-sidebar{width:220px;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface);flex-shrink:0}.flow-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border)}.flow-sidebar-title{font-size:13px;font-weight:700;color:var(--text)}.flow-sidebar-list{flex:1;overflow-y:auto}.flow-sidebar-empty{padding:24px 14px;font-size:12px;color:var(--text-muted);text-align:center;line-height:1.6}.flow-sidebar-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition)}.flow-sidebar-item:hover{background:var(--surface-2)}.flow-sidebar-item.active{background:var(--accent-glow);border-left:3px solid var(--accent);padding-left:11px}.flow-sidebar-item.disabled{opacity:.55}.flow-sidebar-item-info{display:flex;align-items:center;gap:6px;min-width:0;flex:1}.flow-sidebar-item-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flow-sidebar-item-badge{font-size:10px;color:var(--text-muted);font-style:italic}.flow-sidebar-item-actions{display:flex;align-items:center;gap:4px;flex-shrink:0;opacity:0;transition:opacity var(--transition)}.flow-sidebar-item:hover .flow-sidebar-item-actions{opacity:1}.flow-sidebar-item-actions .toggle-switch{width:28px;height:16px}.flow-sidebar-item-actions .toggle-switch:after{width:12px;height:12px}.flow-sidebar-item-actions .toggle-switch.active:after{transform:translate(12px)}.flow-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.flow-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;gap:8px}.flow-toolbar-left,.flow-toolbar-right{display:flex;align-items:center;gap:6px}.flow-add-node{font-size:12px;padding:5px 10px;min-width:140px}.flow-canvas-container{flex:1;position:relative;overflow:hidden}.flow-canvas{width:100%;height:100%}.flow-canvas-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:13px}.drawflow{background:var(--bg)!important;background-image:radial-gradient(circle,var(--border) 1px,transparent 1px)!important;background-size:20px 20px!important}.drawflow .drawflow-node{background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:var(--radius)!important;color:var(--text)!important;min-width:200px;padding:0!important;box-shadow:var(--shadow-sm)!important}.drawflow .drawflow-node:hover{border-color:var(--border-hover)!important}.drawflow .drawflow-node.selected{border-color:var(--accent)!important;box-shadow:0 0 0 3px var(--accent-glow)!important}.drawflow .drawflow-node .inputs .input,.drawflow .drawflow-node .outputs .output{background:var(--accent)!important;border:2px solid var(--surface)!important;width:14px!important;height:14px!important}.drawflow .drawflow-node .inputs .input:hover,.drawflow .drawflow-node .outputs .output:hover{background:var(--accent-hover)!important}.drawflow .connection .main-path{stroke:var(--border-hover)!important;stroke-width:2!important}.drawflow .connection .main-path:hover{stroke:var(--accent)!important}.drawflow .drawflow-node .drawflow_content_node{padding:0!important}.flow-node{padding:0;min-width:200px}.flow-node__header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border)}.flow-node__icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.flow-node__title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flow-node__body{padding:8px 14px;font-size:12px;color:var(--text-muted)}.flow-node__subtitle{font-size:11px;color:var(--text-muted)}.flow-node__method{font-size:10px;font-weight:800;color:var(--accent);background:var(--accent-glow);padding:1px 5px;border-radius:3px;font-family:JetBrains Mono,monospace;margin-right:6px}.flow-node__url{font-size:11px;color:var(--text-muted);font-family:JetBrains Mono,monospace}.flow-node__status{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%}.flow-node__status--running{background:var(--yellow);animation:pulse 1.2s infinite}.flow-node__status--success{background:var(--green)}.flow-node__status--error{background:var(--red)}.flow-node__status--filtered{background:var(--text-muted)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.connection.executing .main-path{stroke:var(--accent)!important;stroke-dasharray:8 4;animation:flowDash .6s linear infinite}@keyframes flowDash{to{stroke-dashoffset:-12}}.flow-editor-panel{position:absolute;right:0;top:0;bottom:0;width:340px;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:10;box-shadow:var(--shadow-lg);overflow-y:auto}.editor-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.editor-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.editor-title-group{flex:1;min-width:0}.editor-label-input{width:100%;background:transparent;border:none;color:var(--text);font-size:14px;font-weight:700;font-family:inherit;padding:0;outline:none}.editor-label-input:focus{border-bottom:1px solid var(--accent)}.editor-type{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.editor-close{font-size:20px;color:var(--text-muted);flex-shrink:0}.editor-body{padding:16px;flex:1;overflow-y:auto}.editor-field{margin-bottom:16px}.editor-field label{display:block;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.editor-field input[type=text],.editor-field input[type=number],.editor-field select,.editor-field textarea{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:8px 10px;font-size:12px;font-family:JetBrains Mono,monospace;outline:none;transition:border-color var(--transition)}.editor-field input:focus,.editor-field select:focus,.editor-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.editor-field textarea{resize:vertical;line-height:1.5}.editor-info{font-size:12px;color:var(--text-muted);line-height:1.5;padding:8px 0}.editor-footer{padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}.node-test-output{margin-top:8px;font-size:11px;font-family:JetBrains Mono,monospace;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px;max-height:150px;overflow:auto;white-space:pre-wrap;word-break:break-all;display:none}.node-test-output:not(:empty){display:block}.condition-row{display:flex;gap:4px;margin-bottom:6px;align-items:center}.condition-row input,.condition-row select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:5px 6px;font-size:11px;font-family:JetBrains Mono,monospace;outline:none}.cond-field{flex:2}.cond-op{flex:1;min-width:80px}.cond-value{flex:2}.cond-remove{flex-shrink:0;font-size:14px}.inject-field-row{display:flex;gap:4px;margin-bottom:6px;align-items:center}.inject-field-row input,.inject-field-row select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:5px 6px;font-size:11px;font-family:JetBrains Mono,monospace;outline:none}.inject-key{flex:1}.inject-type{flex:0 0 80px}.inject-value{flex:2}.branch-row{display:flex;gap:4px;margin-bottom:6px;align-items:center;flex-wrap:wrap}.branch-row input,.branch-row select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:5px 6px;font-size:11px;font-family:JetBrains Mono,monospace;outline:none}.branch-name{flex:1;min-width:80px}.branch-field{flex:1}.branch-op{flex:0 0 70px}.branch-value{flex:1}.delivery-log-filtered{color:var(--text-muted);font-weight:800;font-size:14px}@media(max-width:1024px){.flow-sidebar{width:180px}.flow-editor-panel{width:300px}}@media(max-width:768px){.flow-builder{flex-direction:column}.flow-sidebar{width:100%;max-height:150px;border-right:none;border-bottom:1px solid var(--border)}.flow-sidebar-list{display:flex;overflow-x:auto;gap:0}.flow-sidebar-item{white-space:nowrap;border-bottom:none;border-right:1px solid var(--border)}.flow-editor-panel{position:fixed;top:auto;bottom:0;left:0;right:0;width:100%;max-height:60vh;border-left:none;border-top:1px solid var(--border)}}.drawflow,.drawflow .parent-node{position:relative}.parent-drawflow{display:flex;overflow:hidden;touch-action:none;outline:0}.drawflow{width:100%;height:100%;-webkit-user-select:none;user-select:none;perspective:0}.drawflow .drawflow-node{display:flex;align-items:center;position:absolute;background:#0ff;width:160px;min-height:40px;border-radius:4px;border:2px solid #000;color:#000;z-index:2;padding:15px}.drawflow .drawflow-node.selected{background:red}.drawflow .drawflow-node:hover{cursor:move}.drawflow .drawflow-node .inputs,.drawflow .drawflow-node .outputs{width:0}.drawflow .drawflow-node .drawflow_content_node{width:100%;display:block}.drawflow .drawflow-node .input,.drawflow .drawflow-node .output{position:relative;width:20px;height:20px;background:#fff;border-radius:50%;border:2px solid #000;cursor:crosshair;z-index:1;margin-bottom:5px}.drawflow .drawflow-node .input{left:-27px;top:2px;background:#ff0}.drawflow .drawflow-node .output{right:-3px;top:2px}.drawflow svg{z-index:0;position:absolute;overflow:visible!important}.drawflow .connection{position:absolute;pointer-events:none;aspect-ratio:1/1}.drawflow .connection .main-path{fill:none;stroke-width:5px;stroke:#4682b4;pointer-events:all}.drawflow .connection .main-path:hover{stroke:#1266ab;cursor:pointer}.drawflow .connection .main-path.selected{stroke:#43b993}.drawflow .connection .point{cursor:move;stroke:#000;stroke-width:2;fill:#fff;pointer-events:all}.drawflow .connection .point.selected,.drawflow .connection .point:hover{fill:#1266ab}.drawflow .main-path{fill:none;stroke-width:5px;stroke:#4682b4}.drawflow-delete{position:absolute;display:block;width:30px;height:30px;background:#000;color:#fff;z-index:4;border:2px solid #fff;line-height:30px;font-weight:700;text-align:center;border-radius:50%;font-family:monospace;cursor:pointer}.drawflow>.drawflow-delete{margin-left:-15px;margin-top:15px}.parent-node .drawflow-delete{right:-15px;top:-15px}
