.react-international-phone-country-selector{position:relative}.react-international-phone-country-selector-button{display:flex;height:var(--react-international-phone-height, 36px);box-sizing:border-box;align-items:center;justify-content:center;padding:0;border:1px solid var(--react-international-phone-country-selector-border-color, var(--react-international-phone-border-color, gainsboro));margin:0;appearance:button;-webkit-appearance:button;background-color:var(--react-international-phone-country-selector-background-color, var(--react-international-phone-background-color, white));cursor:pointer;text-transform:none;user-select:none}.react-international-phone-country-selector-button:hover{background-color:var(--react-international-phone-country-selector-background-color-hover, whitesmoke)}.react-international-phone-country-selector-button--hide-dropdown{cursor:auto}.react-international-phone-country-selector-button--hide-dropdown:hover{background-color:transparent}.react-international-phone-country-selector-button__button-content{display:flex;align-items:center;justify-content:center}.react-international-phone-country-selector-button__flag-emoji{margin:0 4px}.react-international-phone-country-selector-button__flag-emoji--disabled{opacity:.75}.react-international-phone-country-selector-button__dropdown-arrow{border-top:var(--react-international-phone-country-selector-arrow-size, 4px) solid var(--react-international-phone-country-selector-arrow-color, #777);border-right:var(--react-international-phone-country-selector-arrow-size, 4px) solid transparent;border-left:var(--react-international-phone-country-selector-arrow-size, 4px) solid transparent;margin-right:4px;transition:all .1s ease-out}.react-international-phone-country-selector-button__dropdown-arrow--active{transform:rotateX(180deg)}.react-international-phone-country-selector-button__dropdown-arrow--disabled{border-top-color:var(--react-international-phone-disabled-country-selector-arrow-color, #999)}.react-international-phone-country-selector-button--disabled,.react-international-phone-country-selector-button--disabled:hover{background-color:var(--react-international-phone-disabled-country-selector-background-color, var(--react-international-phone-disabled-background-color, whitesmoke))}.react-international-phone-country-selector-button--disabled{cursor:auto}.react-international-phone-flag-emoji{width:var(--react-international-phone-flag-width, 24px);height:var(--react-international-phone-flag-height, 24px);box-sizing:border-box}.react-international-phone-country-selector-dropdown{position:absolute;z-index:1;top:var(--react-international-phone-dropdown-top, 44px);left:var(--react-international-phone-dropdown-left, 0);display:flex;width:300px;max-height:200px;flex-direction:column;padding:4px 0;margin:0;background-color:var(--react-international-phone-dropdown-item-background-color, var(--react-international-phone-background-color, white));box-shadow:var(--react-international-phone-dropdown-shadow, 2px 2px 16px rgba(0, 0, 0, .25));color:var(--react-international-phone-dropdown-item-text-color, var(--react-international-phone-text-color, #222));list-style:none;overflow-y:scroll}.react-international-phone-country-selector-dropdown__preferred-list-divider{height:1px;border:none;margin:var(--react-international-phone-dropdown-preferred-list-divider-margin, 0);background:var(--react-international-phone-dropdown-preferred-list-divider-color, var(--react-international-phone-border-color, gainsboro))}.react-international-phone-country-selector-dropdown__list-item{display:flex;min-height:var(--react-international-phone-dropdown-item-height, 28px);box-sizing:border-box;align-items:center;padding:2px 8px}.react-international-phone-country-selector-dropdown__list-item-flag-emoji{margin-right:8px}.react-international-phone-country-selector-dropdown__list-item-country-name{overflow:hidden;margin-right:8px;font-size:var(--react-international-phone-dropdown-item-font-size, 14px);text-overflow:ellipsis;white-space:nowrap}.react-international-phone-country-selector-dropdown__list-item-dial-code{color:var(--react-international-phone-dropdown-item-dial-code-color, gray);font-size:var(--react-international-phone-dropdown-item-font-size, 14px)}.react-international-phone-country-selector-dropdown__list-item:hover{background-color:var(--react-international-phone-selected-dropdown-item-background-color, var(--react-international-phone-selected-dropdown-item-background-color, whitesmoke));cursor:pointer}.react-international-phone-country-selector-dropdown__list-item--selected,.react-international-phone-country-selector-dropdown__list-item--focused{background-color:var(--react-international-phone-selected-dropdown-item-background-color, whitesmoke);color:var(--react-international-phone-selected-dropdown-item-text-color, var(--react-international-phone-text-color, #222))}.react-international-phone-country-selector-dropdown__list-item--selected .react-international-phone-country-selector-dropdown__list-item-dial-code,.react-international-phone-country-selector-dropdown__list-item--focused .react-international-phone-country-selector-dropdown__list-item-dial-code{color:var(--react-international-phone-selected-dropdown-item-dial-code-color, var(--react-international-phone-dropdown-item-dial-code-color, gray))}.react-international-phone-country-selector-dropdown__list-item--focused{background-color:var(--react-international-phone-selected-dropdown-item-background-color, var(--react-international-phone-selected-dropdown-item-background-color, whitesmoke))}.react-international-phone-dial-code-preview{display:flex;align-items:center;justify-content:center;padding:0 8px;border:1px solid var(--react-international-phone-dial-code-preview-border-color, var(--react-international-phone-border-color, gainsboro));margin-right:-1px;background-color:var(--react-international-phone-dial-code-preview-background-color, var(--react-international-phone-background-color, white));color:var(--react-international-phone-dial-code-preview-text-color, var(--react-international-phone-text-color, #222));font-size:var(--react-international-phone-dial-code-preview-font-size, var(--react-international-phone-font-size, 13px))}.react-international-phone-dial-code-preview--disabled{background-color:var(--react-international-phone-dial-code-preview-disabled-background-color, var(--react-international-phone-disabled-background-color, whitesmoke));color:var(--react-international-phone-dial-code-preview-disabled-text-color, var(--react-international-phone-disabled-text-color, #666))}.react-international-phone-input-container{display:flex}.react-international-phone-input-container .react-international-phone-country-selector-button{border-radius:var(--react-international-phone-border-radius, 4px);margin-right:-1px;border-bottom-right-radius:0;border-top-right-radius:0}.react-international-phone-input-container .react-international-phone-input{overflow:visible;height:var(--react-international-phone-height, 36px);box-sizing:border-box;padding:0 8px;border:1px solid var(--react-international-phone-border-color, gainsboro);border-radius:var(--react-international-phone-border-radius, 4px);margin:0;background-color:var(--react-international-phone-background-color, white);border-bottom-left-radius:0;border-top-left-radius:0;color:var(--react-international-phone-text-color, #222);font-family:inherit;font-size:var(--react-international-phone-font-size, 13px)}.react-international-phone-input-container .react-international-phone-input:focus{outline:none}.react-international-phone-input-container .react-international-phone-input--disabled{background-color:var(--react-international-phone-disabled-background-color, whitesmoke);color:var(--react-international-phone-disabled-text-color, #666)}
/* Copyright 2014 Mozilla Foundation
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

:root {
  --react-pdf-annotation-layer: 1;
  --annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");
  --input-focus-border-color: Highlight;
  --input-focus-outline: 1px solid Canvas;
  --input-unfocused-border-color: transparent;
  --input-disabled-border-color: transparent;
  --input-hover-border-color: black;
  --link-outline: none;
}

@media screen and (forced-colors: active) {
  :root {
    --input-focus-border-color: CanvasText;
    --input-unfocused-border-color: ActiveText;
    --input-disabled-border-color: GrayText;
    --input-hover-border-color: Highlight;
    --link-outline: 1.5px solid LinkText;
  }
  .annotationLayer .textWidgetAnnotation :is(input, textarea):required,
  .annotationLayer .choiceWidgetAnnotation select:required,
  .annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input:required {
    outline: 1.5px solid selectedItem;
  }

  .annotationLayer .linkAnnotation:hover {
    backdrop-filter: invert(100%);
  }
}

.annotationLayer {
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
  transform-origin: 0 0;
  z-index: 3;
}

.annotationLayer[data-main-rotation='90'] .norotate {
  transform: rotate(270deg) translateX(-100%);
}
.annotationLayer[data-main-rotation='180'] .norotate {
  transform: rotate(180deg) translate(-100%, -100%);
}
.annotationLayer[data-main-rotation='270'] .norotate {
  transform: rotate(90deg) translateY(-100%);
}

.annotationLayer canvas {
  position: absolute;
  width: 100%;
  height: 100%;
}

.annotationLayer section {
  position: absolute;
  text-align: initial;
  pointer-events: auto;
  box-sizing: border-box;
  margin: 0;
  transform-origin: 0 0;
}

.annotationLayer .linkAnnotation {
  outline: var(--link-outline);
}

.textLayer.selecting ~ .annotationLayer section {
  pointer-events: none;
}

.annotationLayer :is(.linkAnnotation, .buttonWidgetAnnotation.pushButton) > a {
  position: absolute;
  font-size: 1em;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.annotationLayer :is(.linkAnnotation, .buttonWidgetAnnotation.pushButton) > a:hover {
  opacity: 0.2;
  background: rgba(255, 255, 0, 1);
  box-shadow: 0 2px 10px rgba(255, 255, 0, 1);
}

.annotationLayer .textAnnotation img {
  position: absolute;
  cursor: pointer;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.annotationLayer .textWidgetAnnotation :is(input, textarea),
.annotationLayer .choiceWidgetAnnotation select,
.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input {
  background-image: var(--annotation-unfocused-field-background);
  border: 2px solid var(--input-unfocused-border-color);
  box-sizing: border-box;
  font: calc(9px * var(--total-scale-factor)) sans-serif;
  height: 100%;
  margin: 0;
  vertical-align: top;
  width: 100%;
}

.annotationLayer .textWidgetAnnotation :is(input, textarea):required,
.annotationLayer .choiceWidgetAnnotation select:required,
.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input:required {
  outline: 1.5px solid red;
}

.annotationLayer .choiceWidgetAnnotation select option {
  padding: 0;
}

.annotationLayer .buttonWidgetAnnotation.radioButton input {
  border-radius: 50%;
}

.annotationLayer .textWidgetAnnotation textarea {
  resize: none;
}

.annotationLayer .textWidgetAnnotation :is(input, textarea)[disabled],
.annotationLayer .choiceWidgetAnnotation select[disabled],
.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input[disabled] {
  background: none;
  border: 2px solid var(--input-disabled-border-color);
  cursor: not-allowed;
}

.annotationLayer .textWidgetAnnotation :is(input, textarea):hover,
.annotationLayer .choiceWidgetAnnotation select:hover,
.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input:hover {
  border: 2px solid var(--input-hover-border-color);
}
.annotationLayer .textWidgetAnnotation :is(input, textarea):hover,
.annotationLayer .choiceWidgetAnnotation select:hover,
.annotationLayer .buttonWidgetAnnotation.checkBox input:hover {
  border-radius: 2px;
}

.annotationLayer .textWidgetAnnotation :is(input, textarea):focus,
.annotationLayer .choiceWidgetAnnotation select:focus {
  background: none;
  border: 2px solid var(--input-focus-border-color);
  border-radius: 2px;
  outline: var(--input-focus-outline);
}

.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) :focus {
  background-image: none;
  background-color: transparent;
}

.annotationLayer .buttonWidgetAnnotation.checkBox :focus {
  border: 2px solid var(--input-focus-border-color);
  border-radius: 2px;
  outline: var(--input-focus-outline);
}

.annotationLayer .buttonWidgetAnnotation.radioButton :focus {
  border: 2px solid var(--input-focus-border-color);
  outline: var(--input-focus-outline);
}

.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::before,
.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::after,
.annotationLayer .buttonWidgetAnnotation.radioButton input:checked::before {
  background-color: CanvasText;
  content: '';
  display: block;
  position: absolute;
}

.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::before,
.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::after {
  height: 80%;
  left: 45%;
  width: 1px;
}

.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::before {
  transform: rotate(45deg);
}

.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::after {
  transform: rotate(-45deg);
}

.annotationLayer .buttonWidgetAnnotation.radioButton input:checked::before {
  border-radius: 50%;
  height: 50%;
  left: 30%;
  top: 20%;
  width: 50%;
}

.annotationLayer .textWidgetAnnotation input.comb {
  font-family: monospace;
  padding-left: 2px;
  padding-right: 0;
}

.annotationLayer .textWidgetAnnotation input.comb:focus {
  /*
   * Letter spacing is placed on the right side of each character. Hence, the
   * letter spacing of the last character may be placed outside the visible
   * area, causing horizontal scrolling. We avoid this by extending the width
   * when the element has focus and revert this when it loses focus.
   */
  width: 103%;
}

.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input {
  appearance: none;
}

.annotationLayer .popupTriggerArea {
  height: 100%;
  width: 100%;
}

.annotationLayer .fileAttachmentAnnotation .popupTriggerArea {
  position: absolute;
}

.annotationLayer .popupWrapper {
  position: absolute;
  font-size: calc(9px * var(--total-scale-factor));
  width: 100%;
  min-width: calc(180px * var(--total-scale-factor));
  pointer-events: none;
}

.annotationLayer .popup {
  position: absolute;
  max-width: calc(180px * var(--total-scale-factor));
  background-color: rgba(255, 255, 153, 1);
  box-shadow: 0 calc(2px * var(--total-scale-factor)) calc(5px * var(--total-scale-factor))
    rgba(136, 136, 136, 1);
  border-radius: calc(2px * var(--total-scale-factor));
  padding: calc(6px * var(--total-scale-factor));
  margin-left: calc(5px * var(--total-scale-factor));
  cursor: pointer;
  font: message-box;
  white-space: normal;
  word-wrap: break-word;
  pointer-events: auto;
}

.annotationLayer .popup > * {
  font-size: calc(9px * var(--total-scale-factor));
}

.annotationLayer .popup h1 {
  display: inline-block;
}

.annotationLayer .popupDate {
  display: inline-block;
  margin-left: calc(5px * var(--total-scale-factor));
}

.annotationLayer .popupContent {
  border-top: 1px solid rgba(51, 51, 51, 1);
  margin-top: calc(2px * var(--total-scale-factor));
  padding-top: calc(2px * var(--total-scale-factor));
}

.annotationLayer .richText > * {
  white-space: pre-wrap;
  font-size: calc(9px * var(--total-scale-factor));
}

.annotationLayer .highlightAnnotation,
.annotationLayer .underlineAnnotation,
.annotationLayer .squigglyAnnotation,
.annotationLayer .strikeoutAnnotation,
.annotationLayer .freeTextAnnotation,
.annotationLayer .lineAnnotation svg line,
.annotationLayer .squareAnnotation svg rect,
.annotationLayer .circleAnnotation svg ellipse,
.annotationLayer .polylineAnnotation svg polyline,
.annotationLayer .polygonAnnotation svg polygon,
.annotationLayer .caretAnnotation,
.annotationLayer .inkAnnotation svg polyline,
.annotationLayer .stampAnnotation,
.annotationLayer .fileAttachmentAnnotation {
  cursor: pointer;
}

.annotationLayer section svg {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.annotationLayer .annotationTextContent {
  position: absolute;
  width: 100%;
  height: 100%;
  opacity: 0;
  color: transparent;
  user-select: none;
  pointer-events: none;
}

.annotationLayer .annotationTextContent span {
  width: 100%;
  display: inline-block;
}
/* Copyright 2014 Mozilla Foundation
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

:root {
  --react-pdf-text-layer: 1;
  --highlight-bg-color: rgba(180, 0, 170, 1);
  --highlight-selected-bg-color: rgba(0, 100, 0, 1);
}

@media screen and (forced-colors: active) {
  :root {
    --highlight-bg-color: Highlight;
    --highlight-selected-bg-color: ButtonText;
  }
}

[data-main-rotation='90'] {
  transform: rotate(90deg) translateY(-100%);
}
[data-main-rotation='180'] {
  transform: rotate(180deg) translate(-100%, -100%);
}
[data-main-rotation='270'] {
  transform: rotate(270deg) translateX(-100%);
}

.textLayer {
  position: absolute;
  text-align: initial;
  inset: 0;
  overflow: hidden;
  line-height: 1;
  text-size-adjust: none;
  forced-color-adjust: none;
  transform-origin: 0 0;
  z-index: 2;
}

.textLayer :is(span, br) {
  color: transparent;
  position: absolute;
  white-space: pre;
  cursor: text;
  margin: 0;
  transform-origin: 0 0;
}

/* Only necessary in Google Chrome, see issue 14205, and most unfortunately
 * the problem doesn't show up in "text" reference tests. */
.textLayer span.markedContent {
  top: 0;
  height: 0;
}

.textLayer .highlight {
  margin: -1px;
  padding: 1px;
  background-color: var(--highlight-bg-color);
  border-radius: 4px;
}

.textLayer .highlight.appended {
  position: initial;
}

.textLayer .highlight.begin {
  border-radius: 4px 0 0 4px;
}

.textLayer .highlight.end {
  border-radius: 0 4px 4px 0;
}

.textLayer .highlight.middle {
  border-radius: 0;
}

.textLayer .highlight.selected {
  background-color: var(--highlight-selected-bg-color);
}

/* Avoids https://github.com/mozilla/pdf.js/issues/13840 in Chrome */
.textLayer br::selection {
  background: transparent;
}

.textLayer .endOfContent {
  display: block;
  position: absolute;
  inset: 100% 0 0;
  z-index: -1;
  cursor: default;
  user-select: none;
}

.textLayer.selecting .endOfContent {
  top: 0;
}

.hiddenCanvasElement {
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  display: none;
}
/* this gets exported as style.css and can be used for the default theming */
/* these are the necessary styles for React/Svelte Flow, they get used by base.css and style.css */
.react-flow {
  direction: ltr;

  --xy-edge-stroke-default: #b1b1b7;
  --xy-edge-stroke-width-default: 1;
  --xy-edge-stroke-selected-default: #555;

  --xy-connectionline-stroke-default: #b1b1b7;
  --xy-connectionline-stroke-width-default: 1;

  --xy-attribution-background-color-default: rgba(255, 255, 255, 0.5);

  --xy-minimap-background-color-default: #fff;
  --xy-minimap-mask-background-color-default: rgba(240, 240, 240, 0.6);
  --xy-minimap-mask-stroke-color-default: transparent;
  --xy-minimap-mask-stroke-width-default: 1;
  --xy-minimap-node-background-color-default: #e2e2e2;
  --xy-minimap-node-stroke-color-default: transparent;
  --xy-minimap-node-stroke-width-default: 2;

  --xy-background-color-default: transparent;
  --xy-background-pattern-dots-color-default: #91919a;
  --xy-background-pattern-lines-color-default: #eee;
  --xy-background-pattern-cross-color-default: #e2e2e2;
  background-color: var(--xy-background-color, var(--xy-background-color-default));
  --xy-node-color-default: inherit;
  --xy-node-border-default: 1px solid #1a192b;
  --xy-node-background-color-default: #fff;
  --xy-node-group-background-color-default: rgba(240, 240, 240, 0.25);
  --xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, 0.08);
  --xy-node-boxshadow-selected-default: 0 0 0 0.5px #1a192b;
  --xy-node-border-radius-default: 3px;

  --xy-handle-background-color-default: #1a192b;
  --xy-handle-border-color-default: #fff;

  --xy-selection-background-color-default: rgba(0, 89, 220, 0.08);
  --xy-selection-border-default: 1px dotted rgba(0, 89, 220, 0.8);

  --xy-controls-button-background-color-default: #fefefe;
  --xy-controls-button-background-color-hover-default: #f4f4f4;
  --xy-controls-button-color-default: inherit;
  --xy-controls-button-color-hover-default: inherit;
  --xy-controls-button-border-color-default: #eee;
  --xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, 0.08);

  --xy-edge-label-background-color-default: #ffffff;
  --xy-edge-label-color-default: inherit;
  --xy-resize-background-color-default: #3367d9;
}
.react-flow.dark {
  --xy-edge-stroke-default: #3e3e3e;
  --xy-edge-stroke-width-default: 1;
  --xy-edge-stroke-selected-default: #727272;

  --xy-connectionline-stroke-default: #b1b1b7;
  --xy-connectionline-stroke-width-default: 1;

  --xy-attribution-background-color-default: rgba(150, 150, 150, 0.25);

  --xy-minimap-background-color-default: #141414;
  --xy-minimap-mask-background-color-default: rgba(60, 60, 60, 0.6);
  --xy-minimap-mask-stroke-color-default: transparent;
  --xy-minimap-mask-stroke-width-default: 1;
  --xy-minimap-node-background-color-default: #2b2b2b;
  --xy-minimap-node-stroke-color-default: transparent;
  --xy-minimap-node-stroke-width-default: 2;

  --xy-background-color-default: #141414;
  --xy-background-pattern-dots-color-default: #777;
  --xy-background-pattern-lines-color-default: #777;
  --xy-background-pattern-cross-color-default: #777;
  --xy-node-color-default: #f8f8f8;
  --xy-node-border-default: 1px solid #3c3c3c;
  --xy-node-background-color-default: #1e1e1e;
  --xy-node-group-background-color-default: rgba(240, 240, 240, 0.25);
  --xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, 0.08);
  --xy-node-boxshadow-selected-default: 0 0 0 0.5px #999;

  --xy-handle-background-color-default: #bebebe;
  --xy-handle-border-color-default: #1e1e1e;

  --xy-selection-background-color-default: rgba(200, 200, 220, 0.08);
  --xy-selection-border-default: 1px dotted rgba(200, 200, 220, 0.8);

  --xy-controls-button-background-color-default: #2b2b2b;
  --xy-controls-button-background-color-hover-default: #3e3e3e;
  --xy-controls-button-color-default: #f8f8f8;
  --xy-controls-button-color-hover-default: #fff;
  --xy-controls-button-border-color-default: #5b5b5b;
  --xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, 0.08);

  --xy-edge-label-background-color-default: #141414;
  --xy-edge-label-color-default: #f8f8f8;
}
.react-flow__background {
  background-color: var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));
  pointer-events: none;
  z-index: -1;
}
.react-flow__container {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.react-flow__pane {
  z-index: 1;
}
.react-flow__pane.draggable {
    cursor: grab;
  }
.react-flow__pane.dragging {
    cursor: grabbing;
  }
.react-flow__pane.selection {
    cursor: pointer;
  }
.react-flow__viewport {
  transform-origin: 0 0;
  z-index: 2;
  pointer-events: none;
}
.react-flow__renderer {
  z-index: 4;
}
.react-flow__selection {
  z-index: 6;
}
.react-flow__nodesselection-rect:focus,
.react-flow__nodesselection-rect:focus-visible {
  outline: none;
}
.react-flow__edge-path {
  stroke: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
  stroke-width: var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));
  fill: none;
}
.react-flow__connection-path {
  stroke: var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));
  stroke-width: var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));
  fill: none;
}
.react-flow .react-flow__edges {
  position: absolute;
}
.react-flow .react-flow__edges svg {
    overflow: visible;
    position: absolute;
    pointer-events: none;
  }
.react-flow__edge {
  pointer-events: visibleStroke;
}
.react-flow__edge.selectable {
    cursor: pointer;
  }
.react-flow__edge.animated path {
    stroke-dasharray: 5;
    animation: dashdraw 0.5s linear infinite;
  }
.react-flow__edge.animated path.react-flow__edge-interaction {
    stroke-dasharray: none;
    animation: none;
  }
.react-flow__edge.inactive {
    pointer-events: none;
  }
.react-flow__edge.selected,
  .react-flow__edge:focus,
  .react-flow__edge:focus-visible {
    outline: none;
  }
.react-flow__edge.selected .react-flow__edge-path,
  .react-flow__edge.selectable:focus .react-flow__edge-path,
  .react-flow__edge.selectable:focus-visible .react-flow__edge-path {
    stroke: var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default));
  }
.react-flow__edge-textwrapper {
    pointer-events: all;
  }
.react-flow__edge .react-flow__edge-text {
    pointer-events: none;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
  }
/* Arrowhead marker styles - use CSS custom properties as default */
.react-flow__arrowhead polyline {
  stroke: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
}
.react-flow__arrowhead polyline.arrowclosed {
  fill: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
}
.react-flow__connection {
  pointer-events: none;
}
.react-flow__connection .animated {
    stroke-dasharray: 5;
    animation: dashdraw 0.5s linear infinite;
  }
svg.react-flow__connectionline {
  z-index: 1001;
  overflow: visible;
  position: absolute;
}
.react-flow__nodes {
  pointer-events: none;
  transform-origin: 0 0;
}
.react-flow__node {
  position: absolute;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  pointer-events: all;
  transform-origin: 0 0;
  box-sizing: border-box;
  cursor: default;
}
.react-flow__node.selectable {
    cursor: pointer;
  }
.react-flow__node.draggable {
    cursor: grab;
    pointer-events: all;
  }
.react-flow__node.draggable.dragging {
      cursor: grabbing;
    }
.react-flow__nodesselection {
  z-index: 3;
  transform-origin: left top;
  pointer-events: none;
}
.react-flow__nodesselection-rect {
    position: absolute;
    pointer-events: all;
    cursor: grab;
  }
.react-flow__handle {
  position: absolute;
  pointer-events: none;
  min-width: 5px;
  min-height: 5px;
  width: 6px;
  height: 6px;
  background-color: var(--xy-handle-background-color, var(--xy-handle-background-color-default));
  border: 1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));
  border-radius: 100%;
}
.react-flow__handle.connectingfrom {
    pointer-events: all;
  }
.react-flow__handle.connectionindicator {
    pointer-events: all;
    cursor: crosshair;
  }
.react-flow__handle-bottom {
    top: auto;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 50%);
  }
.react-flow__handle-top {
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
  }
.react-flow__handle-left {
    top: 50%;
    left: 0;
    transform: translate(-50%, -50%);
  }
.react-flow__handle-right {
    top: 50%;
    right: 0;
    transform: translate(50%, -50%);
  }
.react-flow__edgeupdater {
  cursor: move;
  pointer-events: all;
}
.react-flow__pane.selection .react-flow__panel {
  pointer-events: none;
}
.react-flow__panel {
  position: absolute;
  z-index: 5;
  margin: 15px;
}
.react-flow__panel.top {
    top: 0;
  }
.react-flow__panel.bottom {
    bottom: 0;
  }
.react-flow__panel.top.center, .react-flow__panel.bottom.center {
      left: 50%;
      transform: translateX(-15px) translateX(-50%);
    }
.react-flow__panel.left {
    left: 0;
  }
.react-flow__panel.right {
    right: 0;
  }
.react-flow__panel.left.center, .react-flow__panel.right.center {
      top: 50%;
      transform: translateY(-15px) translateY(-50%);
    }
.react-flow__attribution {
  font-size: 10px;
  background: var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));
  padding: 2px 3px;
  margin: 0;
}
.react-flow__attribution a {
    text-decoration: none;
    color: #999;
  }
@keyframes dashdraw {
  from {
    stroke-dashoffset: 10;
  }
}
.react-flow__edgelabel-renderer {
  position: absolute;
  width: 100%;
  height: 100%;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  left: 0;
  top: 0;
}
.react-flow__viewport-portal {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.react-flow__minimap {
  background: var(
    --xy-minimap-background-color-props,
    var(--xy-minimap-background-color, var(--xy-minimap-background-color-default))
  );
}
.react-flow__minimap-svg {
    display: block;
  }
.react-flow__minimap-mask {
    fill: var(
      --xy-minimap-mask-background-color-props,
      var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default))
    );
    stroke: var(
      --xy-minimap-mask-stroke-color-props,
      var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default))
    );
    stroke-width: var(
      --xy-minimap-mask-stroke-width-props,
      var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default))
    );
  }
.react-flow__minimap-node {
    fill: var(
      --xy-minimap-node-background-color-props,
      var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default))
    );
    stroke: var(
      --xy-minimap-node-stroke-color-props,
      var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default))
    );
    stroke-width: var(
      --xy-minimap-node-stroke-width-props,
      var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default))
    );
  }
.react-flow__background-pattern.dots {
    fill: var(
      --xy-background-pattern-color-props,
      var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default))
    );
  }
.react-flow__background-pattern.lines {
    stroke: var(
      --xy-background-pattern-color-props,
      var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default))
    );
  }
.react-flow__background-pattern.cross {
    stroke: var(
      --xy-background-pattern-color-props,
      var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default))
    );
  }
.react-flow__controls {
  display: flex;
  flex-direction: column;
  box-shadow: var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default));
}
.react-flow__controls.horizontal {
    flex-direction: row;
  }
.react-flow__controls-button {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 26px;
    width: 26px;
    padding: 4px;
    border: none;
    background: var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));
    border-bottom: 1px solid
      var(
        --xy-controls-button-border-color-props,
        var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default))
      );
    color: var(
      --xy-controls-button-color-props,
      var(--xy-controls-button-color, var(--xy-controls-button-color-default))
    );
    cursor: pointer;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
  }
.react-flow__controls-button svg {
      width: 100%;
      max-width: 12px;
      max-height: 12px;
      fill: currentColor;
    }
.react-flow__edge.updating .react-flow__edge-path {
      stroke: #777;
    }
.react-flow__edge-text {
    font-size: 10px;
  }
.react-flow__node.selectable:focus,
  .react-flow__node.selectable:focus-visible {
    outline: none;
  }
.react-flow__node-input,
.react-flow__node-default,
.react-flow__node-output,
.react-flow__node-group {
  padding: 10px;
  border-radius: var(--xy-node-border-radius, var(--xy-node-border-radius-default));
  width: 150px;
  font-size: 12px;
  color: var(--xy-node-color, var(--xy-node-color-default));
  text-align: center;
  border: var(--xy-node-border, var(--xy-node-border-default));
  background-color: var(--xy-node-background-color, var(--xy-node-background-color-default));
}
.react-flow__node-input.selectable:hover, .react-flow__node-default.selectable:hover, .react-flow__node-output.selectable:hover, .react-flow__node-group.selectable:hover {
      box-shadow: var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default));
    }
.react-flow__node-input.selectable.selected,
    .react-flow__node-input.selectable:focus,
    .react-flow__node-input.selectable:focus-visible,
    .react-flow__node-default.selectable.selected,
    .react-flow__node-default.selectable:focus,
    .react-flow__node-default.selectable:focus-visible,
    .react-flow__node-output.selectable.selected,
    .react-flow__node-output.selectable:focus,
    .react-flow__node-output.selectable:focus-visible,
    .react-flow__node-group.selectable.selected,
    .react-flow__node-group.selectable:focus,
    .react-flow__node-group.selectable:focus-visible {
      box-shadow: var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default));
    }
.react-flow__node-group {
  background-color: var(--xy-node-group-background-color, var(--xy-node-group-background-color-default));
}
.react-flow__nodesselection-rect,
.react-flow__selection {
  background: var(--xy-selection-background-color, var(--xy-selection-background-color-default));
  border: var(--xy-selection-border, var(--xy-selection-border-default));
}
.react-flow__nodesselection-rect:focus,
  .react-flow__nodesselection-rect:focus-visible,
  .react-flow__selection:focus,
  .react-flow__selection:focus-visible {
    outline: none;
  }
.react-flow__controls-button:hover {
      background: var(
        --xy-controls-button-background-color-hover-props,
        var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default))
      );
      color: var(
        --xy-controls-button-color-hover-props,
        var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default))
      );
    }
.react-flow__controls-button:disabled {
      pointer-events: none;
    }
.react-flow__controls-button:disabled svg {
        fill-opacity: 0.4;
      }
.react-flow__controls-button:last-child {
    border-bottom: none;
  }
.react-flow__controls.horizontal .react-flow__controls-button {
    border-bottom: none;
    border-right: 1px solid
      var(
        --xy-controls-button-border-color-props,
        var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default))
      );
  }
.react-flow__controls.horizontal .react-flow__controls-button:last-child {
    border-right: none;
  }
.react-flow__resize-control {
  position: absolute;
}
.react-flow__resize-control.left,
.react-flow__resize-control.right {
  cursor: ew-resize;
}
.react-flow__resize-control.top,
.react-flow__resize-control.bottom {
  cursor: ns-resize;
}
.react-flow__resize-control.top.left,
.react-flow__resize-control.bottom.right {
  cursor: nwse-resize;
}
.react-flow__resize-control.bottom.left,
.react-flow__resize-control.top.right {
  cursor: nesw-resize;
}
/* handle styles */
.react-flow__resize-control.handle {
  width: 5px;
  height: 5px;
  border: 1px solid #fff;
  border-radius: 1px;
  background-color: var(--xy-resize-background-color, var(--xy-resize-background-color-default));
  translate: -50% -50%;
}
.react-flow__resize-control.handle.left {
  left: 0;
  top: 50%;
}
.react-flow__resize-control.handle.right {
  left: 100%;
  top: 50%;
}
.react-flow__resize-control.handle.top {
  left: 50%;
  top: 0;
}
.react-flow__resize-control.handle.bottom {
  left: 50%;
  top: 100%;
}
.react-flow__resize-control.handle.top.left {
  left: 0;
}
.react-flow__resize-control.handle.bottom.left {
  left: 0;
}
.react-flow__resize-control.handle.top.right {
  left: 100%;
}
.react-flow__resize-control.handle.bottom.right {
  left: 100%;
}
/* line styles */
.react-flow__resize-control.line {
  border-color: var(--xy-resize-background-color, var(--xy-resize-background-color-default));
  border-width: 0;
  border-style: solid;
}
.react-flow__resize-control.line.left,
.react-flow__resize-control.line.right {
  width: 1px;
  transform: translate(-50%, 0);
  top: 0;
  height: 100%;
}
.react-flow__resize-control.line.left {
  left: 0;
  border-left-width: 1px;
}
.react-flow__resize-control.line.right {
  left: 100%;
  border-right-width: 1px;
}
.react-flow__resize-control.line.top,
.react-flow__resize-control.line.bottom {
  height: 1px;
  transform: translate(0, -50%);
  left: 0;
  width: 100%;
}
.react-flow__resize-control.line.top {
  top: 0;
  border-top-width: 1px;
}
.react-flow__resize-control.line.bottom {
  border-bottom-width: 1px;
  top: 100%;
}
.react-flow__edge-textbg {
  fill: var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default));
}
.react-flow__edge-text {
  fill: var(--xy-edge-label-color, var(--xy-edge-label-color-default));
}
/*
 * Quoting Tool shared styles.
 *
 * Ported from the sandbox's Sandbox.css (src/logic-portal/…/quoting-tool/Sandbox.css).
 * The original rules were scoped under `.quoting-sandbox` — that prefix is dropped here
 * because the class names are specific enough not to collide. Any consumer that imports
 * a quoting component (QualifyingPanel, ResultsToolbar, etc.) gets these styles for free.
 *
 * CSS variables are defined here at the quoting-scope root (.qq, .products, etc.) via
 * inheritance from the nearest container. To ensure they resolve, the sandbox still
 * defines them on `.quoting-sandbox` (the wrapping div), which is fine — it just means
 * the sandbox's variable declarations act as the provider. In production, input-portal
 * will provide equivalent values on its root container or :root.
 *
 * Design tokens used (must be provided by the consumer root or :root):
 *   --bg, --surface, --surface-2, --surface-3
 *   --border, --border-strong
 *   --ink, --ink-2, --ink-3, --ink-4
 *   --accent, --accent-hover, --accent-soft, --accent-soft-2, --accent-ink
 *   --good, --good-soft, --good-ink
 *   --warn, --warn-soft, --warn-ink
 *   --bad, --bad-soft, --bad-ink
 *   --radius, --radius-btn
 *   --shadow-sm, --shadow-md, --shadow-lg
 *   --font-sans, --font-mono
 *   --row-py, --row-px, --gap, --fs-body, --fs-small, --fs-num
 */

/* ── Default token values ────────────────────────────────────────────────────
 *
 * Self-contained defaults so consumers that don't define these tokens (e.g.
 * input-portal's deal detail view) still get the design intent. Sandbox
 * overrides via `.quoting-sandbox { --foo: ... }` continue to win because
 * inherited values from a nearer ancestor beat these defaults at this scope.
 * Scoped to `.quote-workspace` and the leaf class roots so the tokens don't
 * leak globally.
 */
.quote-workspace,
.qq,
.products-wrap,
.lender-card,
.matrix-wrap,
.results-toolbar,
.quote-rail {
    --bg: #f5f5f5;
    --surface: #ffffff;
    --surface-2: #fafafa;
    --surface-3: #f0f0f0;

    --border: #e0e0e0;
    --border-strong: #cfcfcf;

    --ink: rgba(0, 0, 0, 0.87);
    --ink-2: rgba(0, 0, 0, 0.72);
    --ink-3: rgba(0, 0, 0, 0.6);
    --ink-4: rgba(0, 0, 0, 0.38);

    --accent: #1976d2;
    --accent-hover: #1565c0;
    --accent-soft: #e3f2fd;
    --accent-soft-2: #d6eaf9;
    --accent-ink: #0d47a1;

    --good: #22c55e;
    --good-soft: #e7f8ee;
    --good-ink: #15803d;

    --warn: #f59e0b;
    --warn-soft: #fef3e2;
    --warn-ink: #b45309;

    --bad: #ef4444;
    --bad-soft: #fdecec;
    --bad-ink: #b91c1c;

    --info: #3b82f6;

    --radius: 8px;
    --radius-lg: 8px;
    --radius-btn: 6px;

    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.06);
    --shadow-md: 0 2px 4px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.10), 0 2px 6px rgba(0, 0, 0, 0.06);

    --font-sans: 'Inter', ui-sans-serif, system-ui, -apple-system, 'Helvetica Neue', Arial, sans-serif;
    --font-mono: 'Inter', ui-sans-serif, system-ui, -apple-system, sans-serif;

    --row-py: 16px;
    --row-px: 16px;
    --gap: 16px;
    --fs-body: 14px;
    --fs-small: 12px;
    --fs-num: 14px;

    font-family: var(--font-sans);
    color: var(--ink);
    font-size: var(--fs-body);
    line-height: 1.5;
}

/* ── QuoteWorkspace composing wrapper ────────────────────────────────────── */
.quote-workspace { display: flex; flex-direction: column; gap: 16px; }
.quote-workspace-body { display: grid; grid-template-columns: 1fr 320px; gap: 16px; }
.quote-workspace-body.rail-float .quote-workspace-results { grid-column: 1 / -1; }
.quote-workspace-body.rail-tab { grid-template-columns: 1fr; }

/*
 * When the rail is docked (position: fixed at right edge), reserve 320px on
 * the right of the entire workspace so the QualifyingPanel, results toolbar,
 * and results body are all pushed left of the rail. Without this, those
 * full-width siblings of the body grid would extend under the fixed rail.
 */
.quote-workspace:has(.rail-docked) {
    padding-right: 336px; /* 320 rail + 16 visual gap */
}
.quote-workspace:has(.rail-docked) .quote-workspace-body {
    grid-template-columns: 1fr;  /* rail no longer in flow; collapse the column */
}

/* ── Typography helpers ──────────────────────────────────────────────────── */
.mono,
.num {
    font-family: var(--font-mono);
    font-variant-numeric: tabular-nums;
    font-feature-settings: 'tnum';
}

/* ── App shell ───────────────────────────────────────────────────────────── */
.app {
    display: grid;
    grid-template-columns: 1fr;
    align-items: start;
    min-height: 100vh;
    position: relative;
}
.app[data-rail-mode="dock"] {
    grid-template-columns: 1fr 360px;
}
.main {
    min-width: 0;
    padding: 24px 32px 80px;
}

/* ── Base rail ───────────────────────────────────────────────────────────── */
.rail {
    background: var(--surface);
    display: flex;
    flex-direction: column;
}
.rail-docked {
    border-left: 1px solid var(--border);
    background: var(--surface);
    position: fixed;
    top: var(--quote-rail-top-offset, 120px);
    right: 0;
    bottom: 0;
    width: 320px;
    z-index: 30;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.rail-docked > .rail-head { flex: 0 0 auto; }
.rail-docked > .quote-list,
.rail-docked > .rail-empty { flex: 1 1 auto; overflow-y: auto; }
.rail-docked > .rail-foot {
    flex: 0 0 auto;
    border-top: 1px solid var(--border);
    background: var(--surface-2);
}

/* ── Floating quote builder ──────────────────────────────────────────────── */
/*
 * The rail is `position: fixed`, so its top offset is relative to the viewport.
 * Consumers can shift the rail down past their app header by setting
 * `--quote-rail-top-offset` on any quoting-component ancestor (e.g. the
 * `.quote-workspace` wrapper) — the rail reads it via the cascade. Default
 * 88px matches input-portal's deal-detail header; sandbox uses 16px (the
 * sandbox is full-bleed with no global app header).
 */
.qb-float-wrap {
    position: fixed;
    top: 0; right: 0; bottom: 0;
    width: 0;
    z-index: 40;
    pointer-events: none;
}
.rail-floating {
    position: fixed;
    top: var(--quote-rail-top-offset, 120px);
    right: 16px;
    bottom: 16px;
    width: 380px;
    max-height: calc(100vh - var(--quote-rail-top-offset, 120px) - 16px);
    border: 1px solid var(--border);
    border-radius: 12px;
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.04),
        0 12px 32px rgba(0, 0, 0, 0.12),
        0 24px 64px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    pointer-events: auto;
    animation: qb-slide-in 0.22s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.rail-floating > .rail-head { flex: 0 0 auto; }
.rail-floating > .quote-list,
.rail-floating > .rail-empty { flex: 1 1 auto; overflow-y: auto; }
.rail-floating > .rail-foot {
    flex: 0 0 auto;
    border-top: 1px solid var(--border);
    background: var(--surface-2);
}

@keyframes qb-slide-in {
    from { transform: translateX(16px); opacity: 0; }
    to   { transform: translateX(0);    opacity: 1; }
}

/* ── Collapsed tab ───────────────────────────────────────────────────────── */
.qb-tab {
    position: fixed;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    z-index: 35;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 14px 10px 12px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-right: none;
    border-radius: 10px 0 0 10px;
    box-shadow:
        -2px 0 8px rgba(0, 0, 0, 0.04),
        -8px 0 24px rgba(0, 0, 0, 0.06);
    cursor: pointer;
    font-family: inherit;
    color: var(--ink-2);
    transition: background 0.15s ease, color 0.15s ease, padding 0.15s ease, box-shadow 0.15s ease;
}
.qb-tab:hover {
    background: var(--surface);
    color: var(--accent);
    padding-right: 14px;
    box-shadow:
        -2px 0 8px rgba(0, 0, 0, 0.06),
        -8px 0 24px rgba(0, 0, 0, 0.10);
}
.qb-tab.has-items { border-color: var(--accent-soft-2); }
.qb-tab-icon {
    display: flex; align-items: center; justify-content: center;
    width: 28px; height: 28px;
    border-radius: 6px;
    background: var(--surface-3);
    color: var(--ink-2);
}
.qb-tab.has-items .qb-tab-icon {
    background: var(--accent-soft);
    color: var(--accent);
}
.qb-tab-label {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    font-size: 12px; font-weight: 600;
    letter-spacing: 0.02em;
    white-space: nowrap;
    padding: 4px 0;
    color: var(--ink-2);
}
.qb-tab:hover .qb-tab-label { color: var(--accent); }
.qb-tab-count {
    display: flex; align-items: center; justify-content: center;
    min-width: 22px; height: 22px;
    padding: 0 6px;
    border-radius: 999px;
    background: var(--surface-3);
    color: var(--ink-3);
    font-size: 12px; font-weight: 600;
    font-variant-numeric: tabular-nums;
}
.qb-tab-count.on { background: var(--accent); color: #fff; }

.rail-controls {
    display: flex; align-items: center; gap: 2px; flex-shrink: 0;
}
.qb-icon-btn {
    width: 28px; height: 28px;
    display: inline-flex; align-items: center; justify-content: center;
    border: 1px solid transparent;
    border-radius: 6px;
    background: transparent;
    color: var(--ink-3);
    cursor: pointer;
    transition: background 0.12s ease, color 0.12s ease, border-color 0.12s ease;
}
.qb-icon-btn:hover { background: var(--surface-3); color: var(--ink); }
.qb-icon-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }

/* ── Qualifying questions panel ──────────────────────────────────────────── */
.qq {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    margin-bottom: 24px;
}
.qq-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 24px;
    cursor: pointer;
    user-select: none;
}
.qq-head:hover { background: var(--surface-2); }
.qq-head.expanded { border-bottom: 1px solid var(--border); }
.qq-title-row { display: flex; align-items: center; gap: 16px; min-width: 0; }
.qq-title { font-size: 16px; font-weight: 600; line-height: 1.4; }
.qq-sub { font-size: 13px; color: var(--ink-3); }
.qq-chips {
    display: flex; align-items: center; gap: 8px;
    flex-wrap: wrap;
    margin-left: 8px;
}
.chip {
    display: inline-flex; align-items: center; gap: 6px;
    height: 24px; padding: 0 10px;
    background: var(--surface-3);
    border: 1px solid var(--border);
    border-radius: 4px;
    font-size: 12px;
    color: var(--ink-2);
}
.chip-key { color: var(--ink-3); }
.chip-val { color: var(--ink); font-weight: 500; }
.chip.mono .chip-val { font-variant-numeric: tabular-nums; }
.chip.accent {
    background: var(--accent-soft);
    border-color: var(--accent-soft-2);
    color: var(--accent-ink);
}
.qq-caret {
    width: 24px; height: 24px;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--ink-3);
    transition: transform 0.18s ease;
}
.qq-caret.open { transform: rotate(180deg); }
.qq-body { padding: 24px; }

/* ── Asset-type segmented switcher ───────────────────────────────────────── */
.asset-switcher {
    display: inline-flex;
    background: var(--surface-3);
    padding: 4px;
    border-radius: var(--radius-btn);
    margin-bottom: 24px;
    gap: 2px;
}
.asset-switcher button {
    appearance: none; border: 0; background: transparent;
    height: 32px; padding: 0 16px;
    border-radius: 4px;
    font-size: 13px; font-weight: 600;
    color: var(--ink-3);
    text-transform: none;
    cursor: pointer;
}
.asset-switcher button.on {
    background: var(--surface);
    color: var(--accent);
    box-shadow: var(--shadow-sm);
}
.asset-switcher button:hover:not(.on) { color: var(--ink); }

.qq-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
@media (max-width: 1100px) {
    .qq-grid { grid-template-columns: repeat(2, 1fr); }
}
.field { display: flex; flex-direction: column; gap: 8px; }
.field-wide { grid-column: span 2; }
.field-label {
    font-size: 12px; font-weight: 500; color: var(--ink-3); letter-spacing: 0;
}
.field-input,
.field-select {
    height: 40px; padding: 0 12px;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-btn);
    background: var(--surface);
    font-size: 14px; color: var(--ink);
    outline: none;
    width: 100%;
    transition: border-color 0.12s ease, box-shadow 0.12s ease;
}
.field-input:hover,
.field-select:hover { border-color: var(--ink-3); }
.field-input:focus,
.field-select:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(25, 118, 210, 0.16);
}
.field-prefix { position: relative; }
.field-prefix .pfx {
    position: absolute; left: 12px; top: 50%;
    transform: translateY(-50%);
    color: var(--ink-3);
    font-size: 13px;
    pointer-events: none;
}
.field-prefix input { padding-left: 26px; }
.field-seg {
    display: inline-flex;
    background: var(--surface-3);
    padding: 4px;
    border-radius: var(--radius-btn);
    gap: 2px;
}
.field-seg button {
    appearance: none; border: 0; background: transparent;
    height: 32px; padding: 0 14px;
    border-radius: 4px;
    font-size: 13px; font-weight: 600;
    color: var(--ink-3);
    flex: 1;
    text-transform: none;
    cursor: pointer;
}
.field-seg button.on {
    background: var(--surface);
    color: var(--accent);
    box-shadow: var(--shadow-sm);
}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    height: 36px;
    padding: 0 16px;
    border: 1px solid var(--border-strong);
    background: var(--surface);
    border-radius: var(--radius-btn);
    font-size: 14px;
    font-weight: 600;
    color: var(--ink);
    text-transform: none;
    letter-spacing: 0;
    box-shadow: none;
    white-space: nowrap;
    transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}
.btn:hover { background: var(--surface-2); border-color: var(--ink-4); }
.btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.btn-primary,
.btn-accent {
    background: var(--accent); color: #fff; border-color: var(--accent); box-shadow: var(--shadow-sm);
}
.btn-primary:hover,
.btn-accent:hover {
    background: var(--accent-hover); border-color: var(--accent-hover);
}
.btn-ghost { background: transparent; border-color: transparent; box-shadow: none; }
.btn-ghost:hover {
    background: rgba(25, 118, 210, 0.08); color: var(--accent); border-color: transparent;
}
.btn-sm { height: 32px; padding: 0 12px; font-size: 13px; }
.btn-xs { height: 28px; padding: 0 10px; font-size: 12px; }
.btn[disabled] { opacity: 0.5; cursor: not-allowed; }

.btn-active {
    background: var(--accent-soft) !important;
    border-color: var(--accent-soft-2) !important;
    color: var(--accent-ink) !important;
}

/* ── Top bar ─────────────────────────────────────────────────────────────── */
.topbar {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 24px; gap: 16px; flex-wrap: wrap;
}
.topbar-left { display: flex; align-items: center; gap: 16px; }
.crumbs { display: flex; align-items: center; gap: 8px; color: var(--ink-3); font-size: 13px; }
.crumbs .sep { color: var(--ink-4); }
.crumbs .cur { color: var(--ink); font-weight: 500; }
.deal-id {
    font-variant-numeric: tabular-nums;
    font-size: 12px; font-weight: 500; color: var(--ink-3);
    background: var(--surface-3); padding: 4px 8px; border-radius: 4px;
    letter-spacing: 0.02em;
}
.topbar-right { display: flex; align-items: center; gap: 8px; }

/* ── Applicant source picker ─────────────────────────────────────────────── */
.asp {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
    margin-bottom: 24px;
    padding: 16px 24px;
}
.asp-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.asp-title { font-size: 16px; font-weight: 600; }
.asp-sub { font-size: 12.5px; color: var(--ink-3); margin-top: 2px; }
.asp-mode {
    display: inline-flex;
    background: var(--surface-3);
    padding: 4px;
    border-radius: var(--radius-btn);
    gap: 2px;
}
.asp-mode button {
    appearance: none; border: 0; background: transparent;
    height: 32px; padding: 0 14px; border-radius: 4px;
    font-size: 13px; font-weight: 600; color: var(--ink-3);
}
.asp-mode button.on {
    background: var(--surface); color: var(--accent); box-shadow: var(--shadow-sm);
}
.asp-body { margin-top: 16px; }
.asp.collapsed { padding: 12px 24px; }
.asp.collapsed .asp-body { display: none; }
.asp-toggle {
    appearance: none; border: 1px solid var(--border-strong);
    background: var(--surface); color: var(--ink-3);
    width: 28px; height: 28px; border-radius: var(--radius-btn);
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer; flex-shrink: 0;
    transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.asp-toggle:hover { background: var(--surface-2); color: var(--accent); border-color: var(--accent-soft-2); }
.asp-toggle svg { transition: transform 0.18s ease; }
.asp.collapsed .asp-toggle svg { transform: rotate(-90deg); }
.asp-summary {
    font-size: 12.5px; color: var(--ink-3); margin-top: 4px;
    font-variant-numeric: tabular-nums;
}
.asp-summary strong { color: var(--ink); font-weight: 600; }
.asp-fixture-list {
    display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.asp-fixture-card {
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-btn);
    background: var(--surface);
    padding: 10px 12px;
    text-align: left;
    cursor: pointer;
    transition: background 0.12s, border-color 0.12s;
}
.asp-fixture-card:hover { background: var(--surface-2); }
.asp-fixture-card.on {
    border-color: var(--accent); background: var(--accent-soft); color: var(--accent-ink);
}
.asp-fixture-name { font-weight: 600; font-size: 13px; }
.asp-fixture-hint { font-size: 12px; color: var(--ink-3); margin-top: 2px; }
.asp-json {
    width: 100%; min-height: 220px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 12px;
    padding: 12px;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-btn);
    background: var(--surface);
    color: var(--ink);
    resize: vertical;
}
.asp-error {
    color: var(--bad-ink); background: var(--bad-soft);
    border: 1px solid rgba(239,68,68,0.25);
    padding: 8px 10px; border-radius: var(--radius-btn);
    font-size: 12px; margin-top: 8px;
}

/* ── Results header ──────────────────────────────────────────────────────── */
.results-head {
    display: flex; flex-direction: column; align-items: flex-start;
    margin-bottom: 16px; gap: 12px;
}
.results-title { font-size: 20px; font-weight: 600; line-height: 1.4; }
.results-meta { font-size: 13px; color: var(--ink-3); margin-top: 4px; }
.results-tools { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.filter-pill {
    display: inline-flex; align-items: center; gap: 6px;
    height: 32px; padding: 0 12px;
    background: var(--surface);
    border: 1px solid var(--border-strong);
    border-radius: 999px;
    font-size: 13px; font-weight: 500; color: var(--ink-2);
    text-transform: none;
}
.filter-pill:hover { background: var(--surface-2); }
.filter-pill.on { background: var(--accent); color: #fff; border-color: var(--accent); }
.filter-pill .count {
    background: var(--surface-3); padding: 1px 7px; border-radius: 999px;
    font-size: 11px; font-variant-numeric: tabular-nums; font-weight: 500; color: var(--ink-2);
}
.filter-pill.on .count { background: rgba(255,255,255,0.22); color: #fff; }
.filter-pill .dot { width: 6px; height: 6px; border-radius: 50%; }
.filter-pill .dot.good { background: var(--good); }
.filter-pill .dot.warn { background: var(--warn); }
.filter-pill .dot.bad { background: var(--bad); }

/* ── Layout switcher ─────────────────────────────────────────────────────── */
.layout-seg {
    display: inline-flex;
    background: var(--surface-3);
    padding: 4px;
    border-radius: var(--radius-btn);
    gap: 2px;
}
.layout-seg button {
    appearance: none; border: 0; background: transparent;
    height: 24px; padding: 0 12px;
    border-radius: 4px;
    font-size: 12px; font-weight: 600; color: var(--ink-3);
}
.layout-seg button.on {
    background: var(--surface); color: var(--accent); box-shadow: var(--shadow-sm);
}

/* ── Products table ──────────────────────────────────────────────────────── */
.products {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--radius); overflow-x: auto; box-shadow: var(--shadow-sm);
}
.ptable { width: 100%; min-width: 1100px; border-collapse: collapse; font-size: var(--fs-body); }
.ptable thead th {
    text-align: left; font-weight: 600; font-size: 12px; letter-spacing: 0; text-transform: none;
    color: var(--ink-3); padding: 12px var(--row-px);
    background: var(--surface-2); border-bottom: 1px solid var(--border);
    white-space: nowrap;
}
.ptable thead th .sortable {
    display: inline-flex; align-items: center; gap: 4px;
    cursor: pointer; user-select: none;
}
.ptable thead th .sortable:hover { color: var(--ink); }
.th-num { text-align: right !important; }

.ptable tbody tr.product-row { cursor: pointer; transition: background 0.1s ease; }
.ptable tbody tr.product-row:hover { background: var(--surface-2); }
.ptable tbody tr.product-row.expanded { background: var(--accent-soft); }
.ptable tbody tr.product-row.declined { opacity: 0.6; }
.ptable tbody td {
    padding: var(--row-py) var(--row-px); border-bottom: 1px solid var(--border); vertical-align: middle;
}
.ptable tbody tr:last-child td { border-bottom: 0; }
.td-num {
    text-align: right; font-variant-numeric: tabular-nums; font-size: var(--fs-num); font-weight: 500;
}

.lender-cell { display: flex; align-items: center; gap: 12px; min-width: 0; }
.lender-mark {
    width: 32px; height: 32px; border-radius: 6px;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 13px; font-weight: 600; flex-shrink: 0;
}
.lender-info { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.lender-name { font-size: 14px; font-weight: 600; color: var(--ink); }
.lender-tier { font-size: 12px; color: var(--ink-3); }

.status {
    display: inline-flex; align-items: center; gap: 6px;
    height: 24px; padding: 0 10px 0 8px; border-radius: 999px;
    font-size: 12px; font-weight: 500; white-space: nowrap; border: 1px solid transparent;
}
.status .dot { width: 6px; height: 6px; border-radius: 50%; }
.status.good { background: var(--good-soft); color: var(--good-ink); border-color: rgba(34,197,94,0.25); }
.status.good .dot { background: var(--good); }
.status.warn { background: var(--warn-soft); color: var(--warn-ink); border-color: rgba(245,158,11,0.25); }
.status.warn .dot { background: var(--warn); }
.status.bad { background: var(--bad-soft); color: var(--bad-ink); border-color: rgba(239,68,68,0.25); }
.status.bad .dot { background: var(--bad); }
.status .count { font-variant-numeric: tabular-nums; font-size: 11px; opacity: 0.75; margin-left: 1px; }

.serv-bar-wrap { display: inline-flex; flex-direction: column; gap: 4px; align-items: flex-end; }
.serv-bar { width: 88px; height: 6px; background: var(--surface-3); border-radius: 999px; overflow: hidden; }
.serv-bar-fill { height: 100%; border-radius: 999px; }
.serv-bar-fill.good { background: var(--good); }
.serv-bar-fill.warn { background: var(--warn); }
.serv-bar-fill.bad { background: var(--bad); }
.serv-label { font-size: 11px; color: var(--ink-3); font-variant-numeric: tabular-nums; }

.row-actions { display: flex; align-items: center; gap: 8px; justify-content: flex-end; }
.icon-btn {
    width: 32px; height: 32px; border-radius: var(--radius-btn);
    border: 1px solid var(--border-strong); background: var(--surface);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--ink-3); flex-shrink: 0;
    transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.icon-btn:hover { color: var(--accent); background: var(--accent-soft); border-color: var(--accent-soft-2); }

.add-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    height: 32px; min-width: 92px; padding: 0 14px;
    border-radius: 999px; border: 1px solid var(--border-strong);
    background: var(--surface);
    font-size: 13px; font-weight: 600; color: var(--ink);
    text-transform: none; white-space: nowrap; line-height: 1; flex-shrink: 0;
}
.add-btn:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
.add-btn.in-quote { background: var(--accent); border-color: var(--accent); color: #fff; }
.add-btn.in-quote:hover { background: var(--accent-hover); border-color: var(--accent-hover); }
.add-btn .plus { font-size: 16px; line-height: 1; }

/* ── Expanded detail row ─────────────────────────────────────────────────── */
.detail-row td { padding: 0 !important; background: var(--surface-2); border-bottom: 1px solid var(--border) !important; }
.detail-inner {
    padding: 24px var(--row-px);
    display: grid;
    grid-template-columns: minmax(280px, 1fr) minmax(280px, 1fr) minmax(280px, 1fr);
    gap: 24px;
}
.detail-inner-custom { grid-template-columns: 2fr 1fr !important; }
.detail-section h4 {
    font-size: 12px; font-weight: 600; letter-spacing: 0; text-transform: none;
    color: var(--ink-3); margin: 0 0 12px;
}
.detail-list { display: flex; flex-direction: column; gap: 8px; font-size: 13px; }
.detail-item {
    display: flex; justify-content: space-between; align-items: baseline; gap: 12px;
    padding-bottom: 8px; border-bottom: 1px dashed var(--border);
}
.detail-item:last-child { border-bottom: 0; padding-bottom: 0; }
.detail-key { color: var(--ink-3); }
.detail-val { color: var(--ink); font-variant-numeric: tabular-nums; font-weight: 500; }
.detail-val.strong { font-weight: 600; }

.gates { display: flex; flex-direction: column; gap: 8px; }
.gate {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 10px 12px; border-radius: var(--radius-btn);
    background: var(--surface); border: 1px solid var(--border); font-size: 13px;
}
.gate.fail { background: var(--bad-soft); border-color: rgba(239,68,68,0.25); }
.gate.warn { background: var(--warn-soft); border-color: rgba(245,158,11,0.25); }
.gate.pass { background: var(--surface); border-color: var(--border); }
.gate-mark {
    width: 16px; height: 16px; border-radius: 50%; flex-shrink: 0; margin-top: 1px;
    display: inline-flex; align-items: center; justify-content: center;
    color: white; font-size: 10px; font-weight: 700;
}
.gate.fail .gate-mark { background: var(--bad); }
.gate.warn .gate-mark { background: var(--warn); }
.gate.pass .gate-mark { background: var(--good); }
.gate-body { min-width: 0; }
.gate-rule { font-weight: 500; color: var(--ink); }
.gate-detail { color: var(--ink-3); margin-top: 2px; line-height: 1.5; }

.detail-section-wide { grid-column: span 2; }

/* ── Override panel + readonly summary ───────────────────────────────────── */
.ov-panel {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 16px;
}
.ov-panel-head {
    display: flex; justify-content: space-between; align-items: flex-start;
    margin-bottom: 16px; gap: 12px;
}
.ov-panel-head h4 {
    font-size: 12px; font-weight: 600; letter-spacing: 0; text-transform: none; color: var(--ink-3);
}
.ov-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.ov-grid-custom { grid-template-columns: repeat(4, 1fr); }
.ov-field {
    display: flex; flex-direction: column; gap: 4px;
    padding: 12px; border: 1px solid var(--border);
    border-radius: var(--radius-btn); background: var(--surface);
    position: relative; transition: border-color 0.12s, background 0.12s;
}
.ov-field.modified { border-color: var(--accent); background: var(--accent-soft); }
.ov-field.disabled { opacity: 0.55; }
.ov-row { display: flex; justify-content: space-between; align-items: center; height: 16px; }
.ov-label { font-size: 11px; font-weight: 500; color: var(--ink-3); letter-spacing: 0; }
.ov-field.modified .ov-label { color: var(--accent-ink); }
.ov-reset {
    appearance: none; background: transparent; border: 0;
    display: inline-flex; align-items: center; gap: 4px;
    color: var(--accent); font-size: 11px; font-weight: 600;
    cursor: pointer; padding: 0; text-transform: none;
}
.ov-reset:hover { color: var(--accent-hover); }
.ov-input-row {
    display: flex; align-items: center; background: var(--surface);
    border: 1px solid var(--border-strong); border-radius: var(--radius-btn);
    height: 36px; padding: 0 8px; gap: 4px;
    transition: border-color 0.12s, box-shadow 0.12s;
}
.ov-field.modified .ov-input-row { border-color: var(--accent); }
.ov-input-row:focus-within {
    border-color: var(--accent); box-shadow: 0 0 0 3px rgba(25,118,210,0.16);
}
.ov-input {
    appearance: none; border: 0; background: transparent; outline: none;
    flex: 1; width: 100%;
    font-variant-numeric: tabular-nums; font-size: 14px; font-weight: 600; color: var(--ink);
    -moz-appearance: textfield;
}
.ov-input::-webkit-outer-spin-button,
.ov-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.ov-input-text { font-weight: 500 !important; }
.ov-affix { font-size: 13px; color: var(--ink-3); flex-shrink: 0; font-variant-numeric: tabular-nums; }
.ov-affix-r { margin-left: auto; }
.ov-select {
    height: 36px; border: 1px solid var(--border-strong); background: var(--surface);
    border-radius: var(--radius-btn); padding: 0 8px;
    font-size: 13px; font-weight: 500; color: var(--ink); width: 100%; outline: none;
}
.ov-track {
    height: 4px; background: var(--surface-3); border-radius: 999px;
    margin-top: 4px; overflow: hidden;
}
.ov-field.modified .ov-track { background: var(--accent-soft-2); }
.ov-track-fill { height: 100%; background: var(--ink-3); border-radius: 999px; transition: width 0.18s ease; }
.ov-field.modified .ov-track-fill { background: var(--accent); }
.ov-bounds {
    display: flex; justify-content: space-between; align-items: center;
    font-variant-numeric: tabular-nums; font-size: 11px; color: var(--ink-4);
    margin-top: 2px; gap: 8px;
}
.ov-hint { color: var(--ink-3); font-style: italic; }

@media (max-width: 1200px) {
    .ov-grid,
    .ov-grid-custom { grid-template-columns: repeat(2, 1fr); }
}

.ov-plain { padding: 4px 0; }
.ov-plain-head {
    display: flex; justify-content: space-between; align-items: flex-start;
    margin-bottom: 16px; gap: 16px;
}
.ov-plain-head h4 { font-size: 14px; font-weight: 600; color: var(--ink); margin: 0; }
.ov-plain-grid {
    display: grid; grid-template-columns: repeat(2, 1fr);
    column-gap: 32px; row-gap: 0;
}
.ov-plain-row {
    display: flex; justify-content: space-between; align-items: baseline; gap: 12px;
    padding: 10px 0; border-bottom: 1px solid var(--border); font-size: 13px;
}
.ov-plain-key { color: var(--ink-3); }
.ov-plain-val { color: var(--ink); font-variant-numeric: tabular-nums; font-weight: 500; }
.ov-plain-val.strong { font-weight: 600; }
@media (max-width: 1100px) { .ov-plain-grid { grid-template-columns: 1fr; } }

/* ── Modal ───────────────────────────────────────────────────────────────── */
.quoting-modal-backdrop {
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.32);
    backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px);
    display: flex; align-items: center; justify-content: center;
    z-index: 1300; padding: 32px;
}
.quoting-modal {
    background: #ffffff; border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.10), 0 20px 50px rgba(0,0,0,0.18);
    width: min(960px, 100%);
    max-height: calc(100vh - 64px);
    display: flex; flex-direction: column; overflow: hidden;
}
.quoting-modal .modal-head {
    display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
    padding: 20px 24px 16px; border-bottom: 1px solid #e0e0e0;
}
.quoting-modal .modal-title { font-size: 18px; font-weight: 600; line-height: 1.4; }
.quoting-modal .modal-sub { font-size: 13px; color: rgba(0,0,0,0.6); margin-top: 4px; }
.quoting-modal .modal-body { padding: 20px 24px; overflow-y: auto; flex: 1; }
.quoting-modal .modal-foot {
    display: flex; justify-content: space-between; align-items: center;
    gap: 8px; padding: 16px 24px; border-top: 1px solid #e0e0e0; background: #fafafa;
}

/* ── Sort & filter popovers ──────────────────────────────────────────────── */
.popover {
    position: absolute; top: calc(100% + 8px);
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--radius); box-shadow: var(--shadow-lg);
    padding: 8px 0; z-index: 50; font-size: 13px;
}
.pop-head {
    display: flex; align-items: center; justify-content: space-between; padding: 8px 16px;
}
.pop-title { font-size: 13px; font-weight: 600; }
.pop-section { padding: 8px 16px; }
.pop-section + .pop-section { border-top: 1px solid var(--border); }
.pop-section-label {
    display: flex; align-items: baseline; justify-content: space-between;
    font-size: 11px; font-weight: 600; letter-spacing: 0; text-transform: none;
    color: var(--ink-3); padding: 8px 16px;
}
.pop-section-val {
    font-variant-numeric: tabular-nums; font-size: 12px; color: var(--ink); font-weight: 500;
}
.pop-section .pop-section-label { padding: 0 0 8px; }
.pop-divider { height: 1px; background: var(--border); margin: 8px 0; }
.pop-row {
    width: 100%; display: flex; align-items: center; justify-content: space-between;
    padding: 8px 16px; background: transparent; border: 0; text-align: left; cursor: pointer; gap: 8px;
}
.pop-row:hover { background: var(--surface-2); }
.pop-row.on { background: var(--accent-soft); color: var(--accent-ink); }
.pop-row-label { font-size: 13px; color: var(--ink); font-weight: 500; }
.pop-row-hint { font-size: 12px; color: var(--ink-3); margin-top: 2px; }

.pop-checks { display: flex; flex-direction: column; gap: 2px; }
.check-row {
    display: flex; align-items: center; gap: 8px; padding: 8px;
    border-radius: 4px; cursor: pointer; font-size: 13px;
}
.check-row:hover { background: var(--surface-2); }
.check-row input[type="checkbox"] {
    appearance: none; width: 16px; height: 16px;
    border: 1.5px solid var(--border-strong); border-radius: 3px; background: var(--surface);
    display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.check-row input[type="checkbox"]:checked {
    background: var(--accent); border-color: var(--accent);
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='10' viewBox='0 0 10 10' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 5l2 2 4-5' stroke='white' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: center;
}
.check-row span:nth-child(2) { flex: 1; }
.check-count {
    font-variant-numeric: tabular-nums; font-size: 11px; color: var(--ink-3);
    background: var(--surface-3); padding: 1px 7px; border-radius: 999px; font-weight: 500;
}

.range-input {
    -webkit-appearance: none; appearance: none;
    width: 100%; height: 4px; background: var(--surface-3); border-radius: 999px; outline: none;
}
.range-input::-webkit-slider-thumb {
    -webkit-appearance: none; appearance: none;
    width: 16px; height: 16px; border-radius: 50%;
    background: var(--accent); border: 2px solid #fff; box-shadow: var(--shadow-sm); cursor: pointer;
}
.range-input::-moz-range-thumb {
    width: 16px; height: 16px; border-radius: 50%;
    background: var(--accent); border: 2px solid #fff; box-shadow: var(--shadow-sm); cursor: pointer;
}

.field-seg-btn {
    flex: 1; height: 32px; border: 1px solid var(--border-strong);
    background: var(--surface); border-radius: var(--radius-btn);
    font-size: 12px; font-weight: 500; color: var(--ink-2); cursor: pointer;
}
.field-seg-btn.on { background: var(--accent); color: #fff; border-color: var(--accent); }

.filter-count-badge {
    background: var(--accent); color: white;
    font-variant-numeric: tabular-nums; font-size: 11px;
    padding: 0 6px; height: 18px;
    display: inline-flex; align-items: center; border-radius: 999px;
    margin-left: 4px; font-weight: 600;
}

/* ── Row tags ────────────────────────────────────────────────────────────── */
.row-tag {
    display: inline-flex; align-items: center; height: 20px; padding: 0 8px;
    border-radius: 4px; font-size: 11px; font-weight: 600;
    letter-spacing: 0; text-transform: none;
}
.row-tag.modified {
    background: var(--accent-soft); color: var(--accent-ink); border: 1px solid var(--accent-soft-2);
}
.row-tag.custom {
    background: #e0f2fe; color: #075985; border: 1px solid #bae6fd;
}
.product-row.custom-row {
    background: linear-gradient(to right, #f0f9ff 0%, transparent 50%);
}

/* ── Card grid layout ────────────────────────────────────────────────────── */
.card-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px;
}
.pcard {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 16px;
    display: flex; flex-direction: column; gap: 16px;
    box-shadow: var(--shadow-sm);
    transition: border-color 0.15s, box-shadow 0.15s;
}
.pcard:hover { border-color: var(--ink-4); box-shadow: var(--shadow-md); }
.pcard.declined { opacity: 0.6; }
.pcard-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.pcard-stats {
    display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
    padding: 16px; background: var(--surface-2); border-radius: var(--radius-btn);
}
.pcard-stat-key { font-size: 11px; color: var(--ink-3); font-weight: 500; }
.pcard-stat-val { font-variant-numeric: tabular-nums; font-size: 20px; font-weight: 600; margin-top: 4px; }
.pcard-stat-sub { font-size: 12px; color: var(--ink-3); font-variant-numeric: tabular-nums; margin-top: 2px; }
.pcard-gates { display: flex; flex-wrap: wrap; gap: 4px; }
.pcard-foot {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: auto; padding-top: 8px; border-top: 1px solid var(--border);
}

/* ── Matrix layout ───────────────────────────────────────────────────────── */
.matrix-wrap {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--radius); overflow: auto; box-shadow: var(--shadow-sm);
}
.matrix { display: grid; font-size: 13px; min-width: 100%; }
.mx-cell {
    padding: 12px 16px; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border);
    display: flex; align-items: center;
}
.mx-cell.row-head {
    background: var(--surface-2); font-size: 12px;
    color: var(--ink-3); font-weight: 500; position: sticky; left: 0; z-index: 1;
}
.mx-cell.col-head { background: var(--surface-2); font-weight: 600; }
.mx-cell.num { font-variant-numeric: tabular-nums; justify-content: flex-end; font-weight: 500; }

/* ── Quote rail ──────────────────────────────────────────────────────────── */
.rail-head { padding: 24px 24px 16px; border-bottom: 1px solid var(--border); }
.rail-title { font-size: 16px; font-weight: 600; line-height: 1.4; }
.rail-sub { font-size: 13px; color: var(--ink-3); margin-top: 4px; }
.rail-empty { padding: 40px 24px; text-align: center; color: var(--ink-3); font-size: 13px; }
.rail-empty .glyph {
    width: 40px; height: 40px; margin: 0 auto 12px;
    border: 1.5px dashed var(--border-strong); border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--ink-4); font-size: 20px; font-weight: 300;
}
.quote-list { padding: 16px; display: flex; flex-direction: column; gap: 8px; }
.quote-card {
    border: 1px solid var(--border); border-radius: var(--radius);
    padding: 16px; background: var(--surface);
    transition: border-color 0.15s, background 0.15s;
}
.quote-card:hover { border-color: var(--ink-4); }
.quote-card.featured { border-color: var(--accent); background: var(--accent-soft); }
.qc-head {
    display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; margin-bottom: 12px;
}
.qc-lender { display: flex; align-items: center; gap: 8px; min-width: 0; }
.qc-lender-mark {
    width: 28px; height: 28px; border-radius: 5px;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 11px; font-weight: 600;
}
.qc-name { font-size: 14px; font-weight: 600; }
.qc-tier { font-size: 12px; color: var(--ink-3); }
.qc-remove {
    appearance: none; border: 0; background: transparent;
    color: var(--ink-4); width: 24px; height: 24px; border-radius: 4px;
    font-size: 14px; display: inline-flex; align-items: center; justify-content: center;
}
.qc-remove:hover { background: var(--surface-3); color: var(--ink); }
.qc-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 16px; }
.qc-stat-key { font-size: 11px; color: var(--ink-3); font-weight: 500; }
.qc-stat-val { font-variant-numeric: tabular-nums; font-size: 14px; font-weight: 600; margin-top: 2px; }
.qc-stat-val.accent { color: var(--accent); }

.rail-foot {
    margin-top: auto; padding: 16px 24px 24px;
    border-top: 1px solid var(--border); background: var(--surface-2);
    display: flex; flex-direction: column; gap: 12px;
}
.rail-totals { display: flex; flex-direction: column; gap: 8px; }
.rail-total-row { display: flex; justify-content: space-between; align-items: baseline; }
.rt-key { font-size: 13px; color: var(--ink-3); }
.rt-val { font-variant-numeric: tabular-nums; font-size: 14px; font-weight: 600; }
.rt-val.big { font-size: 18px; }
.rail-actions { display: flex; gap: 8px; }
.rail-actions .btn { flex: 1; justify-content: center; }

.muted { color: var(--ink-3); }
/* this gets exported as style.css and can be used for the default theming */
/* these are the necessary styles for React/Svelte Flow, they get used by base.css and style.css */
.react-flow {
  direction: ltr;

  --xy-edge-stroke-default: #b1b1b7;
  --xy-edge-stroke-width-default: 1;
  --xy-edge-stroke-selected-default: #555;

  --xy-connectionline-stroke-default: #b1b1b7;
  --xy-connectionline-stroke-width-default: 1;

  --xy-attribution-background-color-default: rgba(255, 255, 255, 0.5);

  --xy-minimap-background-color-default: #fff;
  --xy-minimap-mask-background-color-default: rgba(240, 240, 240, 0.6);
  --xy-minimap-mask-stroke-color-default: transparent;
  --xy-minimap-mask-stroke-width-default: 1;
  --xy-minimap-node-background-color-default: #e2e2e2;
  --xy-minimap-node-stroke-color-default: transparent;
  --xy-minimap-node-stroke-width-default: 2;

  --xy-background-color-default: transparent;
  --xy-background-pattern-dots-color-default: #91919a;
  --xy-background-pattern-lines-color-default: #eee;
  --xy-background-pattern-cross-color-default: #e2e2e2;
  background-color: var(--xy-background-color, var(--xy-background-color-default));
  --xy-node-color-default: inherit;
  --xy-node-border-default: 1px solid #1a192b;
  --xy-node-background-color-default: #fff;
  --xy-node-group-background-color-default: rgba(240, 240, 240, 0.25);
  --xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, 0.08);
  --xy-node-boxshadow-selected-default: 0 0 0 0.5px #1a192b;
  --xy-node-border-radius-default: 3px;

  --xy-handle-background-color-default: #1a192b;
  --xy-handle-border-color-default: #fff;

  --xy-selection-background-color-default: rgba(0, 89, 220, 0.08);
  --xy-selection-border-default: 1px dotted rgba(0, 89, 220, 0.8);

  --xy-controls-button-background-color-default: #fefefe;
  --xy-controls-button-background-color-hover-default: #f4f4f4;
  --xy-controls-button-color-default: inherit;
  --xy-controls-button-color-hover-default: inherit;
  --xy-controls-button-border-color-default: #eee;
  --xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, 0.08);

  --xy-edge-label-background-color-default: #ffffff;
  --xy-edge-label-color-default: inherit;
  --xy-resize-background-color-default: #3367d9;
}
.react-flow.dark {
  --xy-edge-stroke-default: #3e3e3e;
  --xy-edge-stroke-width-default: 1;
  --xy-edge-stroke-selected-default: #727272;

  --xy-connectionline-stroke-default: #b1b1b7;
  --xy-connectionline-stroke-width-default: 1;

  --xy-attribution-background-color-default: rgba(150, 150, 150, 0.25);

  --xy-minimap-background-color-default: #141414;
  --xy-minimap-mask-background-color-default: rgba(60, 60, 60, 0.6);
  --xy-minimap-mask-stroke-color-default: transparent;
  --xy-minimap-mask-stroke-width-default: 1;
  --xy-minimap-node-background-color-default: #2b2b2b;
  --xy-minimap-node-stroke-color-default: transparent;
  --xy-minimap-node-stroke-width-default: 2;

  --xy-background-color-default: #141414;
  --xy-background-pattern-dots-color-default: #777;
  --xy-background-pattern-lines-color-default: #777;
  --xy-background-pattern-cross-color-default: #777;
  --xy-node-color-default: #f8f8f8;
  --xy-node-border-default: 1px solid #3c3c3c;
  --xy-node-background-color-default: #1e1e1e;
  --xy-node-group-background-color-default: rgba(240, 240, 240, 0.25);
  --xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, 0.08);
  --xy-node-boxshadow-selected-default: 0 0 0 0.5px #999;

  --xy-handle-background-color-default: #bebebe;
  --xy-handle-border-color-default: #1e1e1e;

  --xy-selection-background-color-default: rgba(200, 200, 220, 0.08);
  --xy-selection-border-default: 1px dotted rgba(200, 200, 220, 0.8);

  --xy-controls-button-background-color-default: #2b2b2b;
  --xy-controls-button-background-color-hover-default: #3e3e3e;
  --xy-controls-button-color-default: #f8f8f8;
  --xy-controls-button-color-hover-default: #fff;
  --xy-controls-button-border-color-default: #5b5b5b;
  --xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, 0.08);

  --xy-edge-label-background-color-default: #141414;
  --xy-edge-label-color-default: #f8f8f8;
}
.react-flow__background {
  background-color: var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));
  pointer-events: none;
  z-index: -1;
}
.react-flow__container {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.react-flow__pane {
  z-index: 1;
}
.react-flow__pane.draggable {
    cursor: grab;
  }
.react-flow__pane.dragging {
    cursor: grabbing;
  }
.react-flow__pane.selection {
    cursor: pointer;
  }
.react-flow__viewport {
  transform-origin: 0 0;
  z-index: 2;
  pointer-events: none;
}
.react-flow__renderer {
  z-index: 4;
}
.react-flow__selection {
  z-index: 6;
}
.react-flow__nodesselection-rect:focus,
.react-flow__nodesselection-rect:focus-visible {
  outline: none;
}
.react-flow__edge-path {
  stroke: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
  stroke-width: var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));
  fill: none;
}
.react-flow__connection-path {
  stroke: var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));
  stroke-width: var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));
  fill: none;
}
.react-flow .react-flow__edges {
  position: absolute;
}
.react-flow .react-flow__edges svg {
    overflow: visible;
    position: absolute;
    pointer-events: none;
  }
.react-flow__edge {
  pointer-events: visibleStroke;
}
.react-flow__edge.selectable {
    cursor: pointer;
  }
.react-flow__edge.animated path {
    stroke-dasharray: 5;
    animation: dashdraw 0.5s linear infinite;
  }
.react-flow__edge.animated path.react-flow__edge-interaction {
    stroke-dasharray: none;
    animation: none;
  }
.react-flow__edge.inactive {
    pointer-events: none;
  }
.react-flow__edge.selected,
  .react-flow__edge:focus,
  .react-flow__edge:focus-visible {
    outline: none;
  }
.react-flow__edge.selected .react-flow__edge-path,
  .react-flow__edge.selectable:focus .react-flow__edge-path,
  .react-flow__edge.selectable:focus-visible .react-flow__edge-path {
    stroke: var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default));
  }
.react-flow__edge-textwrapper {
    pointer-events: all;
  }
.react-flow__edge .react-flow__edge-text {
    pointer-events: none;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
  }
/* Arrowhead marker styles - use CSS custom properties as default */
.react-flow__arrowhead polyline {
  stroke: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
}
.react-flow__arrowhead polyline.arrowclosed {
  fill: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
}
.react-flow__connection {
  pointer-events: none;
}
.react-flow__connection .animated {
    stroke-dasharray: 5;
    animation: dashdraw 0.5s linear infinite;
  }
svg.react-flow__connectionline {
  z-index: 1001;
  overflow: visible;
  position: absolute;
}
.react-flow__nodes {
  pointer-events: none;
  transform-origin: 0 0;
}
.react-flow__node {
  position: absolute;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  pointer-events: all;
  transform-origin: 0 0;
  box-sizing: border-box;
  cursor: default;
}
.react-flow__node.selectable {
    cursor: pointer;
  }
.react-flow__node.draggable {
    cursor: grab;
    pointer-events: all;
  }
.react-flow__node.draggable.dragging {
      cursor: grabbing;
    }
.react-flow__nodesselection {
  z-index: 3;
  transform-origin: left top;
  pointer-events: none;
}
.react-flow__nodesselection-rect {
    position: absolute;
    pointer-events: all;
    cursor: grab;
  }
.react-flow__handle {
  position: absolute;
  pointer-events: none;
  min-width: 5px;
  min-height: 5px;
  width: 6px;
  height: 6px;
  background-color: var(--xy-handle-background-color, var(--xy-handle-background-color-default));
  border: 1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));
  border-radius: 100%;
}
.react-flow__handle.connectingfrom {
    pointer-events: all;
  }
.react-flow__handle.connectionindicator {
    pointer-events: all;
    cursor: crosshair;
  }
.react-flow__handle-bottom {
    top: auto;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 50%);
  }
.react-flow__handle-top {
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
  }
.react-flow__handle-left {
    top: 50%;
    left: 0;
    transform: translate(-50%, -50%);
  }
.react-flow__handle-right {
    top: 50%;
    right: 0;
    transform: translate(50%, -50%);
  }
.react-flow__edgeupdater {
  cursor: move;
  pointer-events: all;
}
.react-flow__pane.selection .react-flow__panel {
  pointer-events: none;
}
.react-flow__panel {
  position: absolute;
  z-index: 5;
  margin: 15px;
}
.react-flow__panel.top {
    top: 0;
  }
.react-flow__panel.bottom {
    bottom: 0;
  }
.react-flow__panel.top.center, .react-flow__panel.bottom.center {
      left: 50%;
      transform: translateX(-15px) translateX(-50%);
    }
.react-flow__panel.left {
    left: 0;
  }
.react-flow__panel.right {
    right: 0;
  }
.react-flow__panel.left.center, .react-flow__panel.right.center {
      top: 50%;
      transform: translateY(-15px) translateY(-50%);
    }
.react-flow__attribution {
  font-size: 10px;
  background: var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));
  padding: 2px 3px;
  margin: 0;
}
.react-flow__attribution a {
    text-decoration: none;
    color: #999;
  }
@keyframes dashdraw {
  from {
    stroke-dashoffset: 10;
  }
}
.react-flow__edgelabel-renderer {
  position: absolute;
  width: 100%;
  height: 100%;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  left: 0;
  top: 0;
}
.react-flow__viewport-portal {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.react-flow__minimap {
  background: var(
    --xy-minimap-background-color-props,
    var(--xy-minimap-background-color, var(--xy-minimap-background-color-default))
  );
}
.react-flow__minimap-svg {
    display: block;
  }
.react-flow__minimap-mask {
    fill: var(
      --xy-minimap-mask-background-color-props,
      var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default))
    );
    stroke: var(
      --xy-minimap-mask-stroke-color-props,
      var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default))
    );
    stroke-width: var(
      --xy-minimap-mask-stroke-width-props,
      var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default))
    );
  }
.react-flow__minimap-node {
    fill: var(
      --xy-minimap-node-background-color-props,
      var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default))
    );
    stroke: var(
      --xy-minimap-node-stroke-color-props,
      var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default))
    );
    stroke-width: var(
      --xy-minimap-node-stroke-width-props,
      var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default))
    );
  }
.react-flow__background-pattern.dots {
    fill: var(
      --xy-background-pattern-color-props,
      var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default))
    );
  }
.react-flow__background-pattern.lines {
    stroke: var(
      --xy-background-pattern-color-props,
      var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default))
    );
  }
.react-flow__background-pattern.cross {
    stroke: var(
      --xy-background-pattern-color-props,
      var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default))
    );
  }
.react-flow__controls {
  display: flex;
  flex-direction: column;
  box-shadow: var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default));
}
.react-flow__controls.horizontal {
    flex-direction: row;
  }
.react-flow__controls-button {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 26px;
    width: 26px;
    padding: 4px;
    border: none;
    background: var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));
    border-bottom: 1px solid
      var(
        --xy-controls-button-border-color-props,
        var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default))
      );
    color: var(
      --xy-controls-button-color-props,
      var(--xy-controls-button-color, var(--xy-controls-button-color-default))
    );
    cursor: pointer;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
  }
.react-flow__controls-button svg {
      width: 100%;
      max-width: 12px;
      max-height: 12px;
      fill: currentColor;
    }
.react-flow__edge.updating .react-flow__edge-path {
      stroke: #777;
    }
.react-flow__edge-text {
    font-size: 10px;
  }
.react-flow__node.selectable:focus,
  .react-flow__node.selectable:focus-visible {
    outline: none;
  }
.react-flow__node-input,
.react-flow__node-default,
.react-flow__node-output,
.react-flow__node-group {
  padding: 10px;
  border-radius: var(--xy-node-border-radius, var(--xy-node-border-radius-default));
  width: 150px;
  font-size: 12px;
  color: var(--xy-node-color, var(--xy-node-color-default));
  text-align: center;
  border: var(--xy-node-border, var(--xy-node-border-default));
  background-color: var(--xy-node-background-color, var(--xy-node-background-color-default));
}
.react-flow__node-input.selectable:hover, .react-flow__node-default.selectable:hover, .react-flow__node-output.selectable:hover, .react-flow__node-group.selectable:hover {
      box-shadow: var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default));
    }
.react-flow__node-input.selectable.selected,
    .react-flow__node-input.selectable:focus,
    .react-flow__node-input.selectable:focus-visible,
    .react-flow__node-default.selectable.selected,
    .react-flow__node-default.selectable:focus,
    .react-flow__node-default.selectable:focus-visible,
    .react-flow__node-output.selectable.selected,
    .react-flow__node-output.selectable:focus,
    .react-flow__node-output.selectable:focus-visible,
    .react-flow__node-group.selectable.selected,
    .react-flow__node-group.selectable:focus,
    .react-flow__node-group.selectable:focus-visible {
      box-shadow: var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default));
    }
.react-flow__node-group {
  background-color: var(--xy-node-group-background-color, var(--xy-node-group-background-color-default));
}
.react-flow__nodesselection-rect,
.react-flow__selection {
  background: var(--xy-selection-background-color, var(--xy-selection-background-color-default));
  border: var(--xy-selection-border, var(--xy-selection-border-default));
}
.react-flow__nodesselection-rect:focus,
  .react-flow__nodesselection-rect:focus-visible,
  .react-flow__selection:focus,
  .react-flow__selection:focus-visible {
    outline: none;
  }
.react-flow__controls-button:hover {
      background: var(
        --xy-controls-button-background-color-hover-props,
        var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default))
      );
      color: var(
        --xy-controls-button-color-hover-props,
        var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default))
      );
    }
.react-flow__controls-button:disabled {
      pointer-events: none;
    }
.react-flow__controls-button:disabled svg {
        fill-opacity: 0.4;
      }
.react-flow__controls-button:last-child {
    border-bottom: none;
  }
.react-flow__controls.horizontal .react-flow__controls-button {
    border-bottom: none;
    border-right: 1px solid
      var(
        --xy-controls-button-border-color-props,
        var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default))
      );
  }
.react-flow__controls.horizontal .react-flow__controls-button:last-child {
    border-right: none;
  }
.react-flow__resize-control {
  position: absolute;
}
.react-flow__resize-control.left,
.react-flow__resize-control.right {
  cursor: ew-resize;
}
.react-flow__resize-control.top,
.react-flow__resize-control.bottom {
  cursor: ns-resize;
}
.react-flow__resize-control.top.left,
.react-flow__resize-control.bottom.right {
  cursor: nwse-resize;
}
.react-flow__resize-control.bottom.left,
.react-flow__resize-control.top.right {
  cursor: nesw-resize;
}
/* handle styles */
.react-flow__resize-control.handle {
  width: 5px;
  height: 5px;
  border: 1px solid #fff;
  border-radius: 1px;
  background-color: var(--xy-resize-background-color, var(--xy-resize-background-color-default));
  translate: -50% -50%;
}
.react-flow__resize-control.handle.left {
  left: 0;
  top: 50%;
}
.react-flow__resize-control.handle.right {
  left: 100%;
  top: 50%;
}
.react-flow__resize-control.handle.top {
  left: 50%;
  top: 0;
}
.react-flow__resize-control.handle.bottom {
  left: 50%;
  top: 100%;
}
.react-flow__resize-control.handle.top.left {
  left: 0;
}
.react-flow__resize-control.handle.bottom.left {
  left: 0;
}
.react-flow__resize-control.handle.top.right {
  left: 100%;
}
.react-flow__resize-control.handle.bottom.right {
  left: 100%;
}
/* line styles */
.react-flow__resize-control.line {
  border-color: var(--xy-resize-background-color, var(--xy-resize-background-color-default));
  border-width: 0;
  border-style: solid;
}
.react-flow__resize-control.line.left,
.react-flow__resize-control.line.right {
  width: 1px;
  transform: translate(-50%, 0);
  top: 0;
  height: 100%;
}
.react-flow__resize-control.line.left {
  left: 0;
  border-left-width: 1px;
}
.react-flow__resize-control.line.right {
  left: 100%;
  border-right-width: 1px;
}
.react-flow__resize-control.line.top,
.react-flow__resize-control.line.bottom {
  height: 1px;
  transform: translate(0, -50%);
  left: 0;
  width: 100%;
}
.react-flow__resize-control.line.top {
  top: 0;
  border-top-width: 1px;
}
.react-flow__resize-control.line.bottom {
  border-bottom-width: 1px;
  top: 100%;
}
.react-flow__edge-textbg {
  fill: var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default));
}
.react-flow__edge-text {
  fill: var(--xy-edge-label-color, var(--xy-edge-label-color-default));
}
._node_glaop_1 {
  background: #ffffff;
  border: 1px solid #e0e0e0;
  border-radius: 10px;
  padding: 12px 16px;
  min-width: 200px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
  position: relative;
  overflow: visible;
  transition: box-shadow 0.15s ease, border-color 0.15s ease;
  cursor: grab;
}

._node_glaop_1:hover {
  box-shadow: 0 2px 12px rgba(59, 130, 246, 0.2);
  border-color: #93c5fd;
}

._node_glaop_1:active {
  cursor: grabbing;
}

._inactive_glaop_23 {
  opacity: 0.5;
}

._header_glaop_27 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}

._name_glaop_35 {
  font-weight: 600;
  font-size: 13px;
  color: #1a1a1a;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

._code_glaop_44 {
  font-size: 11px;
  color: #888;
  background: #f5f5f5;
  padding: 1px 6px;
  border-radius: 4px;
  flex-shrink: 0;
}

._meta_glaop_53 {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: #666;
}

._depth_glaop_61 {
  color: #999;
}

._count_glaop_65 {
  color: #555;
}

._colorBar_glaop_69 {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  border-radius: 0 0 10px 10px;
}

._handle_glaop_78 {
  width: 14px !important;
  height: 14px !important;
  background: #94a3b8 !important;
  border: 2px solid #fff !important;
  border-radius: 50% !important;
  transition: all 0.15s ease;
  cursor: crosshair !important;
  z-index: 10;
}

._handle_glaop_78:hover {
  background: #3b82f6 !important;
  width: 16px !important;
  height: 16px !important;
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.2);
}
._cell_9evk3_1 {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    font-size: 0.875rem;
}

._cell_9evk3_1 fieldset {
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    padding: 0.5rem 0.75rem;
    margin: 0;
}

._cell_9evk3_1 legend {
    padding: 0 0.25rem;
    font-weight: 600;
    color: #555;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

._cell_9evk3_1 label {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    margin-right: 0.75rem;
    cursor: pointer;
}

._cell_9evk3_1 label input[type='radio'],
._cell_9evk3_1 label input[type='checkbox'] {
    margin: 0;
}

._cell_9evk3_1 fieldset[disabled] label,
._cell_9evk3_1 label input[disabled] + * {
    cursor: not-allowed;
    opacity: 0.6;
}
.app {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}/* inter-cyrillic-ext-400-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/assets/inter-cyrillic-ext-400-normal-BQZuk6qB.woff2) format('woff2'), url(/assets/inter-cyrillic-ext-400-normal-DQukG94-.woff) format('woff');
  unicode-range: U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F;
}

/* inter-cyrillic-400-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/assets/inter-cyrillic-400-normal-obahsSVq.woff2) format('woff2'), url(/assets/inter-cyrillic-400-normal-HOLc17fK.woff) format('woff');
  unicode-range: U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;
}

/* inter-greek-ext-400-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/assets/inter-greek-ext-400-normal-DGGRlc-M.woff2) format('woff2'), url(/assets/inter-greek-ext-400-normal-KugGGMne.woff) format('woff');
  unicode-range: U+1F00-1FFF;
}

/* inter-greek-400-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/assets/inter-greek-400-normal-B4URO6DV.woff2) format('woff2'), url(/assets/inter-greek-400-normal-q2sYcFCs.woff) format('woff');
  unicode-range: U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF;
}

/* inter-vietnamese-400-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/assets/inter-vietnamese-400-normal-DMkecbls.woff2) format('woff2'), url(/assets/inter-vietnamese-400-normal-Bbgyi5SW.woff) format('woff');
  unicode-range: U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB;
}

/* inter-latin-ext-400-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/assets/inter-latin-ext-400-normal-C1nco2VV.woff2) format('woff2'), url(/assets/inter-latin-ext-400-normal-77YHD8bZ.woff) format('woff');
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* inter-latin-400-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url(/assets/inter-latin-400-normal-C38fXH4l.woff2) format('woff2'), url(/assets/inter-latin-400-normal-CyCys3Eg.woff) format('woff');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}/* inter-cyrillic-ext-500-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url(/assets/inter-cyrillic-ext-500-normal-B0yAr1jD.woff2) format('woff2'), url(/assets/inter-cyrillic-ext-500-normal-BmqWE9Dz.woff) format('woff');
  unicode-range: U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F;
}

/* inter-cyrillic-500-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url(/assets/inter-cyrillic-500-normal-BasfLYem.woff2) format('woff2'), url(/assets/inter-cyrillic-500-normal-CxZf_p3X.woff) format('woff');
  unicode-range: U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;
}

/* inter-greek-ext-500-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url(/assets/inter-greek-ext-500-normal-C4iEst2y.woff2) format('woff2'), url(/assets/inter-greek-ext-500-normal-2j5mBUwD.woff) format('woff');
  unicode-range: U+1F00-1FFF;
}

/* inter-greek-500-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url(/assets/inter-greek-500-normal-BIZE56-Y.woff2) format('woff2'), url(/assets/inter-greek-500-normal-Xzm54t5V.woff) format('woff');
  unicode-range: U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF;
}

/* inter-vietnamese-500-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url(/assets/inter-vietnamese-500-normal-DOriooB6.woff2) format('woff2'), url(/assets/inter-vietnamese-500-normal-mJboJaSs.woff) format('woff');
  unicode-range: U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB;
}

/* inter-latin-ext-500-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url(/assets/inter-latin-ext-500-normal-CV4jyFjo.woff2) format('woff2'), url(/assets/inter-latin-ext-500-normal-BxGbmqWO.woff) format('woff');
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* inter-latin-500-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url(/assets/inter-latin-500-normal-Cerq10X2.woff2) format('woff2'), url(/assets/inter-latin-500-normal-BL9OpVg8.woff) format('woff');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}/* inter-cyrillic-ext-600-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url(/assets/inter-cyrillic-ext-600-normal-Dfes3d0z.woff2) format('woff2'), url(/assets/inter-cyrillic-ext-600-normal-Bcila6Z-.woff) format('woff');
  unicode-range: U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F;
}

/* inter-cyrillic-600-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url(/assets/inter-cyrillic-600-normal-CWCymEST.woff2) format('woff2'), url(/assets/inter-cyrillic-600-normal-4D_pXhcN.woff) format('woff');
  unicode-range: U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;
}

/* inter-greek-ext-600-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url(/assets/inter-greek-ext-600-normal-DRtmH8MT.woff2) format('woff2'), url(/assets/inter-greek-ext-600-normal-B8X0CLgF.woff) format('woff');
  unicode-range: U+1F00-1FFF;
}

/* inter-greek-600-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url(/assets/inter-greek-600-normal-plRanbMR.woff2) format('woff2'), url(/assets/inter-greek-600-normal-BZpKdvQh.woff) format('woff');
  unicode-range: U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF;
}

/* inter-vietnamese-600-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url(/assets/inter-vietnamese-600-normal-Cc8MFFhd.woff2) format('woff2'), url(/assets/inter-vietnamese-600-normal-BuLX-rYi.woff) format('woff');
  unicode-range: U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB;
}

/* inter-latin-ext-600-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url(/assets/inter-latin-ext-600-normal-D2bJ5OIk.woff2) format('woff2'), url(/assets/inter-latin-ext-600-normal-CIVaiw4L.woff) format('woff');
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* inter-latin-600-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url(/assets/inter-latin-600-normal-LgqL8muc.woff2) format('woff2'), url(/assets/inter-latin-600-normal-CiBQ2DWP.woff) format('woff');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}/* inter-cyrillic-ext-700-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url(/assets/inter-cyrillic-ext-700-normal-BjwYoWNd.woff2) format('woff2'), url(/assets/inter-cyrillic-ext-700-normal-LO58E6JB.woff) format('woff');
  unicode-range: U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F;
}

/* inter-cyrillic-700-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url(/assets/inter-cyrillic-700-normal-CjBOestx.woff2) format('woff2'), url(/assets/inter-cyrillic-700-normal-DrXBdSj3.woff) format('woff');
  unicode-range: U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;
}

/* inter-greek-ext-700-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url(/assets/inter-greek-ext-700-normal-qfdV9bQt.woff2) format('woff2'), url(/assets/inter-greek-ext-700-normal-BoQ6DsYi.woff) format('woff');
  unicode-range: U+1F00-1FFF;
}

/* inter-greek-700-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url(/assets/inter-greek-700-normal-C3JjAnD8.woff2) format('woff2'), url(/assets/inter-greek-700-normal-BUv2fZ6O.woff) format('woff');
  unicode-range: U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF;
}

/* inter-vietnamese-700-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url(/assets/inter-vietnamese-700-normal-DlLaEgI2.woff2) format('woff2'), url(/assets/inter-vietnamese-700-normal-BZaoP0fm.woff) format('woff');
  unicode-range: U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB;
}

/* inter-latin-ext-700-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url(/assets/inter-latin-ext-700-normal-Ca8adRJv.woff2) format('woff2'), url(/assets/inter-latin-ext-700-normal-TidjK2hL.woff) format('woff');
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* inter-latin-700-normal */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url(/assets/inter-latin-700-normal-Yt3aPRUw.woff2) format('woff2'), url(/assets/inter-latin-700-normal-BLAVimhd.woff) format('woff');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}/**
 * Identity Portal Animation Utilities
 * Subtle, professional animations with reduced-motion support
 * Ported from Broadcast portal for cross-portal consistency
 */

/* ===== CSS Custom Properties ===== */
:root {
    /* Timing */
    --m-transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --m-transition-medium: 250ms cubic-bezier(0.4, 0, 0.2, 1);
    --m-transition-slow: 350ms cubic-bezier(0.4, 0, 0.2, 1);

    /* Easing */
    --m-ease-out: cubic-bezier(0, 0, 0.2, 1);
    --m-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);

    /* Colors (matches identity theme) */
    --m-brand-500: #0891b2;
    --m-brand-600: #0e7490;
    --m-slate-100: #f1f5f9;
    --m-slate-200: #e2e8f0;
}

/* ===== Reduced Motion Support ===== */
@media (prefers-reduced-motion: reduce) {

    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* ===== Fade In Animations ===== */
.m-fade-in {
    animation: mFadeIn 250ms cubic-bezier(0, 0, 0.2, 1) forwards;
    animation: mFadeIn var(--m-transition-medium, 250ms) var(--m-ease-out, cubic-bezier(0, 0, 0.2, 1)) forwards;
}

@keyframes mFadeIn {
    from {
        opacity: 0;
        transform: translateY(8px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Staggered children - apply to parent */
.m-stagger-children>* {
    animation: mFadeIn 250ms cubic-bezier(0, 0, 0.2, 1) forwards;
    animation: mFadeIn var(--m-transition-medium, 250ms) var(--m-ease-out, cubic-bezier(0, 0, 0.2, 1)) forwards;
}

.m-stagger-children>*:nth-child(1) {
    animation-delay: 50ms;
}

.m-stagger-children>*:nth-child(2) {
    animation-delay: 100ms;
}

.m-stagger-children>*:nth-child(3) {
    animation-delay: 150ms;
}

.m-stagger-children>*:nth-child(4) {
    animation-delay: 200ms;
}

.m-stagger-children>*:nth-child(5) {
    animation-delay: 250ms;
}

.m-stagger-children>*:nth-child(6) {
    animation-delay: 300ms;
}

/* ===== Hover Effects ===== */
.m-hover-lift {
    transition: transform var(--m-transition-fast), box-shadow var(--m-transition-fast);
}

.m-hover-lift:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Subtle scale on hover */
.m-hover-scale {
    transition: transform var(--m-transition-fast);
}

.m-hover-scale:hover {
    transform: scale(1.02);
}

/* Left accent bar reveal */
.m-hover-accent {
    position: relative;
    transition: background-color var(--m-transition-fast);
}

.m-hover-accent::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--m-brand-600);
    transform: scaleY(0);
    transition: transform var(--m-transition-fast);
}

.m-hover-accent:hover::before {
    transform: scaleY(1);
}

/* ===== Focus States ===== */
.m-focus-ring:focus-visible {
    outline: 2px solid var(--m-brand-500);
    outline-offset: 2px;
}

/* ===== Loading States ===== */
.m-pulse {
    animation: mPulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes mPulse {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.5;
    }
}

/* Skeleton loading shimmer */
.m-shimmer {
    background: linear-gradient(90deg,
            var(--m-slate-100) 0%,
            var(--m-slate-200) 50%,
            var(--m-slate-100) 100%);
    background-size: 200% 100%;
    animation: mShimmer 1.5s infinite;
}

@keyframes mShimmer {
    0% {
        background-position: 200% 0;
    }

    100% {
        background-position: -200% 0;
    }
}

/* ===== Status Indicators ===== */
.m-status-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-right: 8px;
}

.m-status-dot--active {
    background: var(--m-brand-500);
    animation: mStatusPulse 2s infinite;
}

@keyframes mStatusPulse {

    0%,
    100% {
        box-shadow: 0 0 0 0 rgba(8, 145, 178, 0.4);
    }

    50% {
        box-shadow: 0 0 0 4px rgba(8, 145, 178, 0);
    }
}

/* ===== Card Enhancements ===== */
.m-card-interactive {
    transition:
        transform var(--m-transition-fast),
        box-shadow var(--m-transition-fast),
        border-color var(--m-transition-fast);
    cursor: pointer;
}

.m-card-interactive:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.08);
    border-color: var(--m-brand-500);
}

/* ===== Page Transitions ===== */
.m-page-enter {
    opacity: 0;
    transform: translateX(10px);
}

.m-page-enter-active {
    opacity: 1;
    transform: translateX(0);
    transition: opacity var(--m-transition-medium), transform var(--m-transition-medium);
}

/* ===== Number Counter Animation ===== */
.m-counter {
    display: inline-block;
    transition: transform var(--m-transition-fast);
}

.m-counter--updated {
    animation: mCounterBump var(--m-transition-fast);
}

@keyframes mCounterBump {

    0%,
    100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.05);
    }
}* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html,
body,
#root {
  height: 100%;
  width: 100%;
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Scrollbar styling */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: #94a3b8;
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: #64748b;
}


/* Focus outline for accessibility */
:focus-visible {
  outline: 2px solid #0891b2;
  outline-offset: 2px;
}