.app-container{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary);color:var(--text-primary);font-family:Inter,system-ui,-apple-system,sans-serif}.header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);gap:10px;flex-shrink:0;z-index:10;overflow-x:auto}.header__left{display:flex;align-items:center;gap:12px}.header__title{font-size:16px;font-weight:700;margin:0;letter-spacing:-.02em;background:linear-gradient(135deg,#818cf8,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header__badge{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--bg-tertiary);color:var(--text-secondary);font-weight:500}.header__center{display:flex;gap:4px;background:var(--bg-primary);border-radius:8px;padding:3px}.header__right{display:flex;align-items:center;gap:8px;flex-shrink:0}.tab{padding:6px 16px;border-radius:6px;border:none;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.tab--active{background:var(--bg-tertiary);color:#fff;box-shadow:0 1px 3px #0000004d}.toggle{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:12px;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.toggle input{accent-color:#8b5cf6}.toggle__label{white-space:nowrap}.legend{display:flex;gap:8px}.legend__item{font-size:10px;padding:3px 10px;border-radius:999px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;border:none;cursor:pointer;transition:all .2s;font-family:inherit}.legend__item--hidden{opacity:.3;text-decoration:line-through}.legend__item--auth{background:#764ba240;color:#a78bfa}.legend__item--core{background:#f5576c33;color:#fb7185}.legend__item--messaging{background:#4facfe33;color:#7dd3fc}.legend__item--billing{background:#43e97b33;color:#6ee7b7}.legend__item--util{background:#fa709a33;color:#fda4af}.main-content{display:flex;flex:1;min-height:0;position:relative;overflow:hidden}.flow-container{flex:1;min-height:0;position:relative}.header-icon-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .15s}.header-icon-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.header-icon-btn--active{background:var(--bg-tertiary);color:#8b5cf6;border-color:#8b5cf6}.tools-panel{position:absolute;top:12px;right:12px;width:220px;max-height:calc(100% - 24px);overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:12px;z-index:20;box-shadow:0 8px 32px #0006;display:flex;flex-direction:column;gap:12px}.tools-panel__section{display:flex;flex-direction:column;gap:4px}.tools-panel__heading{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:0 4px 4px}.tools-panel__btn{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;border:none;background:transparent;color:var(--text-secondary);font-size:12px;font-family:inherit;cursor:pointer;transition:all .15s;width:100%;text-align:left}.tools-panel__btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tools-panel__btn--active{color:var(--text-primary);background:#8b5cf61a}.tools-panel__btn--danger:hover{background:#f871711a;color:#f87171}.tools-panel__btn-icon-right{margin-left:auto;opacity:.5}.tools-panel__filters{display:flex;flex-wrap:wrap;gap:4px}.tools-panel__filter{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;border:1px solid transparent;font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.tools-panel__filter:hover{opacity:.85}.tools-panel__filter--hidden{text-decoration:line-through}.tools-panel__filter-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.tools-panel__row{display:flex;gap:2px}.tools-panel__row .tools-panel__btn{flex:1}.tools-panel__search-wrap{position:relative}.tools-panel__search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#475569;pointer-events:none}.tools-panel__search{width:100%;padding:7px 10px 7px 30px;border-radius:6px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:12px;font-family:inherit;outline:none;transition:border-color .15s}.tools-panel__search:focus{border-color:#8b5cf6}.tools-panel__search-results{display:flex;flex-direction:column;gap:1px;margin-top:4px}.tools-panel__search-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:4px;border:none;background:transparent;color:#cbd5e1;font-size:12px;font-family:inherit;cursor:pointer;text-align:left;width:100%}.tools-panel__search-item:hover{background:var(--bg-tertiary)}.tools-panel__stats{display:flex;flex-direction:column;gap:2px;padding:4px 0}.tools-panel__stat-heading{font-size:10px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.05em;padding:6px 4px 2px}.tools-panel__stat-row{display:flex;align-items:center;justify-content:space-between;padding:3px 8px;font-size:11px;border-radius:4px}.tools-panel__stat-row--warn{background:#fbbf2414}.tools-panel__stat-label{color:var(--text-secondary)}.tools-panel__stat-label--mono{font-family:SF Mono,Fira Code,monospace;font-size:10px;color:#cbd5e1}.tools-panel__stat-value{font-weight:700;color:var(--text-primary);font-size:12px}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .2s}.sidebar-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar{width:0;overflow:hidden;background:var(--bg-secondary);border-left:1px solid #334155;display:flex;flex-direction:column;transition:width .3s ease;flex-shrink:0}.sidebar--open{width:420px}.sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar__title{font-size:15px;font-weight:700;margin:0;color:var(--text-primary);white-space:nowrap}.sidebar__close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s}.sidebar__close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar__content{flex:1;overflow-y:auto;padding:12px 0}.sidebar__group{margin-bottom:4px}.sidebar__connection{padding:8px 20px;cursor:pointer;border-left:3px solid transparent;transition:all .15s}.sidebar__connection:hover{background:#33415566;border-left-color:#475569}.sidebar__connection--active{background:#8b5cf61a;border-left-color:#8b5cf6}.sidebar__connection--active:hover{background:#8b5cf626;border-left-color:#8b5cf6}.sidebar__route{display:flex;align-items:center;gap:4px;margin-bottom:6px;font-size:12px;color:var(--text-secondary)}.sidebar__service{font-weight:600;color:#cbd5e1}.sidebar__arrow{color:#475569;flex-shrink:0}.sidebar__endpoints{list-style:none;padding:0;margin:0 0 0 8px}.sidebar__endpoint{font-size:12px;line-height:1.7;padding-left:8px;border-left:2px solid #334155}.sidebar__method{font-weight:700;font-size:11px;letter-spacing:.02em}.sidebar__path{color:var(--text-primary);font-family:SF Mono,Fira Code,monospace;font-size:11px}.sidebar__desc{color:var(--text-muted);font-size:11px}.service-node{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:12px;border:1.5px solid var(--node-border);color:#fff;font-size:12px;font-weight:600;box-shadow:0 4px 16px #0000004d,0 0 0 1px #ffffff0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform .2s,box-shadow .2s;cursor:grab;white-space:pre-line;text-align:center;min-width:120px;justify-content:center}.service-node:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0006,0 0 0 1px #ffffff1a,0 0 20px #8b5cf626}.service-node__icon{flex-shrink:0;opacity:.9}.service-node__label{line-height:1.3}.handle{width:8px!important;height:8px!important;border:2px solid #475569!important;background:#1e293b!important;opacity:.4;transition:opacity .2s,background .2s}.react-flow__node:hover .handle,.react-flow__node.selected .handle{opacity:1;background:#8b5cf6!important;border-color:#a78bfa!important}.edge-label{font-family:Inter,system-ui,sans-serif;font-size:10px;line-height:1.45;text-align:center;white-space:nowrap;padding:3px 6px;border-radius:4px;background:var(--bg-primary);border:1px solid transparent;transition:z-index 0s,border-color .2s,box-shadow .2s;z-index:0}.edge-label:hover{z-index:1000!important;border-color:#334155;box-shadow:0 2px 12px #00000080}.edge-label__line{display:flex;align-items:center;justify-content:center;gap:5px}.edge-label__method{font-weight:700;font-size:10px;letter-spacing:.02em}.edge-label__path{color:var(--text-primary);font-size:10px}.edge-label-wrap{display:flex;flex-direction:column;align-items:center;gap:2px}.edge-delete-btn{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border);background:var(--bg-secondary);color:var(--text-muted);font-size:13px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;padding:0;flex-shrink:0}.edge-delete-btn:hover{background:#f87171;border-color:#f87171;color:#fff;transform:scale(1.2)}.react-flow__edge:hover .react-flow__edge-path{stroke:#8b5cf6!important;stroke-width:2.5!important}.react-flow__edge.selected .react-flow__edge-path{stroke:#a78bfa!important;stroke-width:2.5!important}.controls{border-radius:8px!important;overflow:hidden;border:1px solid #334155!important;box-shadow:0 4px 16px #0000004d!important}.controls button{background:#1e293b!important;border-color:#334155!important;color:#94a3b8!important;width:28px!important;height:28px!important}.controls button:hover{background:#334155!important;color:#e2e8f0!important}.controls button svg{fill:currentColor!important}.minimap{border-radius:8px!important;border:1px solid #334155!important;background:#1e293b!important;box-shadow:0 4px 16px #0000004d!important}.header-btn{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.header-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.header-btn--ghost{border-color:transparent;background:transparent;font-size:11px}.header-btn--ghost:hover{background:#f871711a;color:#f87171}.header-btn-group{display:flex;gap:2px}.header__sep{width:1px;height:24px;background:var(--bg-tertiary);flex-shrink:0}.sidebar__actions{display:flex;gap:2px;margin-left:auto;opacity:0;transition:opacity .15s}.sidebar__connection:hover .sidebar__actions{opacity:1}.sidebar__action-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s}.sidebar__action-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar__action-btn--danger:hover{background:#f8717126;color:#f87171}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;width:560px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 24px 48px #0006}.modal--sm{width:380px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal__title{font-size:14px;font-weight:700;margin:0;color:var(--text-primary)}.modal__close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer}.modal__close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal__body{padding:16px 20px;overflow-y:auto;flex:1}.modal__field{margin-bottom:12px}.modal__label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.modal__input,.modal__select{width:100%;padding:8px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:13px;font-family:inherit;outline:none;transition:border-color .15s}.modal__input:focus,.modal__select:focus{border-color:#8b5cf6}.modal__footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid #334155}.modal__btn{padding:7px 16px;border-radius:6px;border:none;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.modal__btn--secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.modal__btn--secondary:hover{background:#475569;color:var(--text-primary)}.modal__btn--primary{background:#8b5cf6;color:#fff}.modal__btn--primary:hover{background:#7c3aed}.modal__add-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border-radius:6px;border:1px dashed #334155;background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer;margin-top:8px;transition:all .15s}.modal__add-btn:hover{border-color:#8b5cf6;color:#8b5cf6}.format-list{display:flex;flex-direction:column;gap:6px}.format-option{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:8px;border:1.5px solid #334155;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .15s;text-align:left;width:100%}.format-option:hover{border-color:#475569;background:#1a2540}.format-option--active{border-color:#8b5cf6;background:#8b5cf614}.format-option--active:hover{border-color:#8b5cf6}.format-option__icon{color:var(--text-muted);flex-shrink:0}.format-option--active .format-option__icon{color:#8b5cf6}.format-option__label{font-size:13px;font-weight:600}.format-option__desc{font-size:11px;color:var(--text-muted);margin-top:1px}.edge-route-row{display:flex;align-items:center;gap:8px}.edge-route-row .modal__select{flex:1;min-width:0}.edge-route-row__arrow{color:var(--text-muted);flex-shrink:0}.endpoint-row{display:flex;gap:6px;align-items:center;margin-bottom:6px}.endpoint-row__method{width:90px;flex-shrink:0;padding:6px 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg-primary);font-size:12px;font-weight:700;font-family:inherit;outline:none;cursor:pointer}.endpoint-row__method:focus{border-color:#8b5cf6}.endpoint-row__path{flex:1;min-width:0;padding:6px 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:12px;font-family:SF Mono,Fira Code,monospace;outline:none}.endpoint-row__path:focus{border-color:#8b5cf6}.endpoint-row__desc{flex:1;min-width:0;padding:6px 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-secondary);font-size:12px;font-family:inherit;outline:none}.endpoint-row__desc:focus{border-color:#8b5cf6}.endpoint-row__remove{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:4px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;flex-shrink:0}.endpoint-row__remove:hover{background:#f8717126;color:#f87171}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}:root,[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--border: #334155;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--text-dim: #475569;--accent: #8b5cf6;--accent-hover: #7c3aed;--accent-subtle: rgba(139, 92, 246, .1);--edge-stroke: #475569;--dot-color: #334155;--node-border: rgba(255, 255, 255, .15);--label-bg: #0f172a;--shadow: rgba(0, 0, 0, .3);--overlay: rgba(0, 0, 0, .6)}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #e2e8f0;--border: #cbd5e1;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--text-dim: #cbd5e1;--accent: #7c3aed;--accent-hover: #6d28d9;--accent-subtle: rgba(124, 58, 237, .08);--edge-stroke: #94a3b8;--dot-color: #cbd5e1;--node-border: rgba(0, 0, 0, .1);--label-bg: #ffffff;--shadow: rgba(0, 0, 0, .08);--overlay: rgba(0, 0, 0, .3)}body{font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary)}
