.flowdrawer,.flowdrawer .parent-node{position:relative}.parent-flowdrawer{display:flex;overflow:hidden;touch-action:none;outline:0}.flowdrawer{width:100%;height:100%;user-select:none;perspective:0}.flowdrawer .flowdrawer-node{align-items:center;position:absolute;min-width:100px;min-height:40px;z-index:2}.flowdrawer .flowdrawer .flowdrawer-node:hover{cursor:move}.flowdrawer .flowdrawer-node .inputs,.flowdrawer .flowdrawer-node .outputs{width:0}.flowdrawer .flowdrawer-node .flowdrawer_content_node{display:block}.flowdrawer .flowdrawer-node .input,.flowdrawer .flowdrawer-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}.flowdrawer .flowdrawer-node .input{left:-27px;top:2px;background:#ff0}.flowdrawer .flowdrawer-node .output{right:-3px;top:2px}.flowdrawer svg{z-index:0;position:absolute;overflow:visible!important}.flowdrawer .connection{position:absolute;pointer-events:none;aspect-ratio:1/1}.flowdrawer .connection .main-path{fill:none;stroke-width:5px;stroke:#4682b4;pointer-events:all}.flowdrawer .connection .main-path:hover{stroke:#1266ab;cursor:pointer}.flowdrawer .connection .main-path.selected{stroke:#43b993}.flowdrawer .connection .point{cursor:move;stroke:#000;stroke-width:2;fill:#fff;pointer-events:all}.flowdrawer .connection .point.selected,.flowdrawer .connection .point:hover{fill:#1266ab}.flowdrawer .main-path{fill:none;stroke-width:5px;stroke:#4682b4}.flowdrawer-delete{position:absolute;display:block;width:30px;height:30px;background:#000;color:#fff;z-index:4;border:2px solid #fff;line-height:30px;text-align:center;border-radius:50%;cursor:pointer}.flowdrawer>.flowdrawer-delete{margin-left:-15px;margin-top:15px}.parent-node .flowdrawer-delete{right:-15px;top:-15px}


:root {
  --dfNodeType: flex;
  --dfNodeTypeFloat: none;

  --dfNodeBackgroundColor: white;
  --dfNodeTextColor: black;
  --dfNodeBorderSize: 1px;
  --dfNodeBorderColor: #000000;
  --dfNodeBorderRadius: 8px;

  --dfNodeMinHeight: 40px;
  --dfNodeMinWidth: 160px;
  --dfNodePaddingTop: 15px;
  --dfNodePaddingBottom: 15px;
  --dfNodeBoxShadowHL: 0px;
  --dfNodeBoxShadowVL: 0px;
  --dfNodeBoxShadowBR: 0px;
  --dfNodeBoxShadowS: 0px;
  --dfNodeBoxShadowColor: #000000;

  --dfNodeSelectedBackgroundColor: white;
  --dfNodeSelectedTextColor: black;
  --dfNodeSelectedBorderSize: 2px;
  --dfNodeSelectedBorderColor: black;

	--dfOutputForeground: #ffffff;
  --dfOutputBackgroundColor: #673ab6;
  --dfOutputBorderSize: 0px;
  --dfOutputBorderColor: #000000;
  --dfOutputBorderRadius: 50px;
  --dfOutputDiameter: 15px;

  --dfLineWidth: 2px;
  --dfLineColor: black;
  --dfLineHoverColor: black;
  --dfLineSelectedColor: red;

  --dfRerouteBorderWidth: 2px;
  --dfRerouteBorderColor: rgba(169, 203, 145, 1);
  --dfRerouteBackgroundColor: rgba(169, 203, 145, 1);

  --dfDeleteDisplay: block;
  --dfDeleteColor: rgba(0, 0, 0, 1);
  --dfDeleteBackgroundColor: rgba(255, 255, 255, 1);
  --dfDeleteBorderSize: 0px;
  --dfDeleteBorderColor: #ffffff;
  --dfDeleteBorderRadius: 50px;
  --dfDeleteTop: -15px;

  --dfDeleteHoverColor: white;
  --dfDeleteHoverBackgroundColor: black;
  --dfDeleteHoverBorderSize: 0;
  --dfDeleteHoverBorderColor: #000000;
  --dfDeleteHoverBorderRadius: 50px;

}

@font-face {
    font-family: Dangrek;
    src: url('./Dangrek-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

.logicdrag-active .flowdrawer
{
	background-color: white;
	transition: background-color 0.6s;
}

.flowdrawer-zoomcontainer
{
	width: 100%;
	height: 100%;
	position: absolute;
}
.flowdrawer .flowdrawer-node
{
  background-color: var(--main-input-background-color);
  border-radius: 10px;
  box-shadow: 7px 15px 35px 5px rgba(0,0,0,0.28);
  font-size: 13px;
  min-height: 35px;
}
.flowdrawer .flowdrawer-node
{
  outline: 2px solid transparent;
}

.flowdrawer .flowdrawer-node.selected
{
  outline: 2px solid var(--app-primary-color);
}
.vcontrol[data-utalic-class="VFlowEditor"] .h-scrollbar
{
	position: absolute;
	bottom: 0;
	height: 8px;
	width: 300px;
	left: 0;
	cursor: pointer;
	z-index: 99;
	opacity: 0;
}

.vcontrol[data-utalic-class="VFlowEditor"] .h-track
{
	position: absolute !important;
	top: 0 !important;
	height: 6px;
	border-radius: 3px;
	background-color: black;
	left: 0;
	cursor: pointer;
}

.vcontrol[data-utalic-class="VFlowEditor"] .v-scrollbar
{
	position: absolute;
	right: 0;
	width: 8px;
	height: 300px;
	top: 0;
	cursor: pointer;
	z-index: 99;
	opacity: 0;
}

.vcontrol[data-utalic-class="VFlowEditor"] .v-track
{
	position: absolute !important;
	left: 0 !important;
	width: 6px;
	border-radius: 3px;
	background-color: black;
	top: 0;
	cursor: pointer;
}

.vcontrol[data-utalic-class="VFlowEditor"]:hover .h-scrollbar,
.vcontrol[data-utalic-class="VFlowEditor"]:hover .v-scrollbar
{
	opacity: 0.7;
}

.flowdrawer .flowdrawer-node .outputs {
  float: var(--dfNodeTypeFloat);
}

.flowdrawer.sketchmode .flowdrawer-node .output,
.flowdrawer.sketchmode .flowdrawer-node .input 
{
  position: static;
  background: var(--dfOutputBackgroundColor);
  border: var(--dfOutputBorderSize)  solid var(--dfOutputBorderColor);
  height: var(--dfOutputDiameter);
  font-size: 11px;
  line-height: var(--dfOutputDiameter);
  border-radius: var(--dfOutputBorderRadius);
  width: var(--dfOutputDiameter) !important;
  color: var(--dfOutputForeground);
  padding: 2px;
  margin: 0 8px;
  display: inline-block;
  vertical-align: top;
}

.flowdrawer:not(.sketchmode) .flowdrawer-node .output,
.flowdrawer:not(.sketchmode) .flowdrawer-node .input 
{
  position: static;
  background: var(--dfOutputBackgroundColor);
  border: none !important;
  height: 30px;
  font-size: 11px;
  line-height: 30px;
  border-radius: 0 !important;
  color: var(--dfOutputForeground);
  display: inline-block;
  vertical-align: top;
	overflow: hidden;
  padding: 0 5px;
  text-overflow: ellipsis;
  box-sizing: border-box;
}



.flowdrawer:not(.sketchmode) .flowdrawer-node .output:hover,
.flowdrawer:not(.sketchmode) .flowdrawer-node .input:hover
{
  background-color: var(--app-secondary-color) !important;
}


.flowdrawer .flowdrawer-node .detail-button
{
	position: absolute;
	right: 0;
	top: 8px;
	width: 30px;
	height: 30px;
	line-height: 30px;
	text-align: center;
	cursor: pointer;
}
.flowdrawer.sketchmode .flowdrawer-node .output
{
	background-color: transparent !important;
	border: none !important;
	background-image: url(sketchbullet.svg);
	background-repeat: no-repeat;
	background-position: 2px 0;
	margin-top: 9px;
	opacity: 0.6;
}
.flowdrawer.sketchmode .flowdrawer-node .input
{
	background-color: transparent !important;
	border: none !important;
	background-image: url(sketcharrow.svg);
	background-repeat: no-repeat;
	background-position: 2px 0;
	margin-top: -9px;
	opacity: 0.6;
}
.flowdrawer.sketchmode .flowdrawer-node .output.connected
{
	opacity: 1;
}
.flowdrawer.sketchmode .flowdrawer-node .input.connected
{
	background-color: transparent;
	border: none;
	background-image: url(sketcharrow.svg);
	background-repeat: no-repeat;
	background-position: 2px 0;
	opacity: 1;
}

.flowdrawer.sketchmode .flowdrawer-node .input::before,
.flowdrawer.sketchmode .flowdrawer-node .output::before
{
	content: '' !important;
}

.flowdrawer.sketchmode .flowdrawer-node .output:hover,
.flowdrawer.sketchmode .flowdrawer-node .input:hover
{
	opacity: 1;
}

.flowdrawer.sketchmode .flowdrawer-node
{
	transform: skewX(-5deg);
}



.flowdrawer .connection .main-path {
  stroke-width: var(--dfLineWidth);
  stroke: var(--content-foreground);
}

.flowdrawer .connection .main-path:hover {
  stroke: var(--dfLineHoverColor);
}

.flowdrawer .connection .main-path.selected {
  stroke: var(--dfLineSelectedColor);
}

.flowdrawer .connection .point {
  stroke: var(--dfRerouteBorderColor);
  stroke-width: var(--dfRerouteBorderWidth);
  fill: var(--dfRerouteBackgroundColor);
}

.flowdrawer-delete {
  display: var(--dfDeleteDisplay);
  color: var(--dfDeleteColor);
  background: var(--dfDeleteBackgroundColor);
  border: var(--dfDeleteBorderSize) solid var(--dfDeleteBorderColor);
  border-radius: var(--dfDeleteBorderRadius);
}

.parent-node .flowdrawer-delete {
  top: var(--dfDeleteTop);
}

.flowdrawer-delete:hover {
  color: var(--dfDeleteHoverColor);
  background: var(--dfDeleteHoverBackgroundColor);
  border: var(--dfDeleteHoverBorderSize) solid var(--dfDeleteHoverBorderColor);
  border-radius: var(--dfDeleteHoverBorderRadius);
}

.flowdrawer .flowdrawer-node .head
{
	font-size: 12px;
  border-radius: 7px;
  color: #9d7cd7;
  left: 0;
  top: 0;
  right: 0;
  text-transform: uppercase;
}
.flowdrawer .flowdrawer-node .method
{
	font-size: 15px;
	margin-bottom: 5px;
	border-radius: 7px;
	color: #c1c1c1;
	left: 0;
	top: 0;
	right: 0;
	text-transform: uppercase;
	font-weight: 900;
	overflow: hidden;
	text-overflow: ellipsis;
}
.flowdrawer .flowdrawer-node .head .id-label
{
	margin-left: 5px;
	color: #8a8a8a;
}
.flowdrawer .flowdrawer-node .head .id-label::before
{
	content: '(';
}
.flowdrawer .flowdrawer-node .head .id-label::after
{
	content: ')';
}
.flowdrawer .flowdrawer-node .flowdrawer-icon
{
	font-size: 13px;
	display: inline-block;
	vertical-align: top;
	margin-right: 5px;
}
.flowdrawer .flowdrawer-node .flowdrawer_title_node
{
	font-weight: 500;
	display: inline-block;
	overflow: hidden;
	text-overflow: ellipsis;
	width: calc(100% - 20px);
}
.flowdrawer .flowdrawer-node .flowdrawer_description_node
{
	margin-top: 8px;
	font-size: 12px;
}
.flowdrawer .flowdrawer-node.has-icon .flowdrawer_description_node
{
	padding-left: 20px;
}
.flowdrawer .flowdrawer-node .flowdrawer-content-title
{
	white-space: nowrap;
	width: 100%;
}
.flowdrawer .flowdrawer-node .flowdrawer_content_node
{
	padding: 10px;
	text-align: left;
	position: relative;
}
.flowdrawer .flowdrawer-node.has-icon .flowdrawer_content_node
{
	margin-left: 10px;
}
.flowdrawer .flowdrawer-node.has-detail-button .flowdrawer_content_node
{
	padding-right: 25px;
}
.flowdrawer .flowdrawer-node:hover .output .caption
{
	display: inline-block;
}
.flowdrawer .flowdrawer-node .output.red
{
	background-color: #b73a3a;
}
.flowdrawer .flowdrawer-node .output.green
{
	background-color: rgba(127, 188, 84, 1);
}
.flowdrawer.sketchmode .flowdrawer-node .inputs, 
.flowdrawer.sketchmode .flowdrawer-node .outputs
{
	position: static;
	left: 0;
	right: 0;
	width: 100%;
	text-align: center;
	pointer-events: none;
	white-space: nowrap;
	height: var(--dfOutputDiameter);
}
.flowdrawer:not(.sketchmode) .flowdrawer-node .inputs, 
.flowdrawer:not(.sketchmode) .flowdrawer-node .outputs
{
	position: static;
	left: 0;
	right: 0;
	width: 100%;
	text-align: center;
	pointer-events: none;
	white-space: nowrap;
	height: 30px;
	background: var(--dfOutputBackgroundColor);
}
.flowdrawer.sketchmode .flowdrawer-node .inputs
{
	margin-top: -10px;
	z-index: 99;
}
.flowdrawer.sketchmode .flowdrawer-node .outputs
{
	margin-top: 10px;
	margin-bottom: -10px;
	z-index: 99;
}
.flowdrawer:not(.sketchmode) .flowdrawer-node .inputs
{
	z-index: 99;
	border-top-left-radius: 10px;
	border-top-right-radius: 10px;	
	overflow: hidden;
}
.flowdrawer:not(.sketchmode) .flowdrawer-node .outputs
{
	z-index: 99;
	border-bottom-left-radius: 10px;
	border-bottom-right-radius: 10px;	
	overflow: hidden;
}
.flowdrawer .flowdrawer-node .input,
.flowdrawer .flowdrawer-node .output
{
	pointer-events: auto;
	border: 1px solid var(--main-border-color);
}