/* 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));
}
/**
 * Model Browser Styles
 * 
 * Styles for ModelBrowser and ModelCard components.
 * Uses glassmorphism design tokens for consistent styling.
 */

/* Model Browser Container */
.model-browser {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: rgba(15, 23, 42, var(--glass-bg-opacity, 0.7));
  backdrop-filter: blur(var(--glass-blur-lg, 12px));
  -webkit-backdrop-filter: blur(var(--glass-blur-lg, 12px));
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: var(--glass-radius, 16px);
  box-shadow: var(--glass-shadow, 0 8px 32px rgba(0, 0, 0, 0.4));
  overflow: hidden;
}

.model-browser__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  background: rgba(15, 23, 42, 0.3);
}

.model-browser__title {
  font-size: 18px;
  font-weight: 600;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  margin: 0;
}

.model-browser__close-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: none;
  background: rgba(255, 255, 255, 0.1);
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.7));
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.model-browser__close-btn:hover {
  background: rgba(255, 255, 255, 0.2);
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
}

/* Tabs */
.model-browser__tabs {
  display: flex;
  gap: 4px;
  padding: 8px 16px;
  border-bottom: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  background: rgba(15, 23, 42, 0.2);
}

.model-browser__tab {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border: 1px solid transparent;
  background: rgba(255, 255, 255, 0.05);
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.7));
  font-size: 14px;
  font-weight: 500;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.model-browser__tab:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
}

.model-browser__tab--active {
  background: rgba(59, 130, 246, 0.3);
  border-color: rgba(59, 130, 246, 0.5);
  color: #93c5fd;
  box-shadow: 0 0 20px rgba(59, 130, 246, 0.3);
}

.model-browser__tab--active:hover {
  background: rgba(59, 130, 246, 0.4);
  color: #bfdbfe;
}

.model-browser__tab-count {
  padding: 2px 8px;
  background: rgba(0, 0, 0, 0.3);
  border-radius: 10px;
  font-size: 12px;
}

/* Filters */
.model-browser__filters {
  display: flex;
  gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  background: rgba(15, 23, 42, 0.2);
}

.model-browser__search {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: rgba(15, 23, 42, 0.5);
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: 8px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.7));
  transition: all 0.2s ease;
}

.model-browser__search:focus-within {
  border-color: rgba(59, 130, 246, 0.5);
  box-shadow: 0 0 15px rgba(59, 130, 246, 0.2);
}

.model-browser__search-input {
  flex: 1;
  border: none;
  background: transparent;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  font-size: 14px;
  outline: none;
}

.model-browser__search-input::-moz-placeholder {
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
}

.model-browser__search-input::placeholder {
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
}

.model-browser__select {
  padding: 8px 12px;
  background: rgba(15, 23, 42, 0.5);
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: 8px;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  font-size: 14px;
  cursor: pointer;
  outline: none;
  transition: all 0.2s ease;
}

.model-browser__select:focus {
  border-color: rgba(59, 130, 246, 0.5);
  box-shadow: 0 0 15px rgba(59, 130, 246, 0.2);
}

.model-browser__select option {
  background: #1e1e2e;
  color: #cdd6f4;
}

/* Content */
.model-browser__content {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  background: rgba(15, 23, 42, 0.1);
}

.model-browser__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}

/* Loading State */
.model-browser__loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 48px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.7));
}

.model-browser__spinner {
  width: 40px;
  height: 40px;
  border: 3px solid rgba(255, 255, 255, 0.1);
  border-top-color: #89b4fa;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

/* Error State */
.model-browser__error {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 48px;
  color: #f38ba8;
  text-align: center;
}

.model-browser__error-detail {
  font-size: 12px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
}

.model-browser__retry-btn {
  padding: 8px 16px;
  background: rgba(59, 130, 246, 0.3);
  border: 1px solid rgba(59, 130, 246, 0.5);
  color: #93c5fd;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.model-browser__retry-btn:hover {
  background: rgba(59, 130, 246, 0.4);
  box-shadow: 0 0 20px rgba(59, 130, 246, 0.3);
}

/* Empty State */
.model-browser__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 48px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
  text-align: center;
}

/* Model Card */
.model-card {
  display: flex;
  flex-direction: column;
  padding: 16px;
  background: rgba(15, 23, 42, 0.5);
  backdrop-filter: blur(var(--glass-blur-sm, 6px));
  -webkit-backdrop-filter: blur(var(--glass-blur-sm, 6px));
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.model-card:hover {
  border-color: rgba(59, 130, 246, 0.5);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4), 0 0 30px rgba(59, 130, 246, 0.2);
}

.model-card--selected {
  border-color: rgba(59, 130, 246, 0.6);
  background: rgba(59, 130, 246, 0.15);
  box-shadow: 0 0 30px rgba(59, 130, 246, 0.3);
}

.model-card__header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}

.model-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  flex-shrink: 0;
}

.model-card__icon--ecr {
  background: linear-gradient(135deg, rgba(249, 168, 37, 0.8), rgba(255, 111, 0, 0.8));
  color: white;
  box-shadow: 0 0 20px rgba(249, 168, 37, 0.4);
}

.model-card__icon--hf {
  background: linear-gradient(135deg, rgba(255, 213, 79, 0.8), rgba(255, 179, 0, 0.8));
  color: #1e1e2e;
  box-shadow: 0 0 20px rgba(255, 213, 79, 0.4);
}

.model-card__title-group {
  flex: 1;
  min-width: 0;
}

.model-card__title {
  font-size: 14px;
  font-weight: 600;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  margin: 0 0 4px 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.model-card__author {
  font-size: 12px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
}

.model-card__badge {
  display: inline-block;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 500;
  border-radius: 6px;
  text-transform: uppercase;
}

.model-card__badge--framework {
  background: rgba(59, 130, 246, 0.2);
  border: 1px solid rgba(59, 130, 246, 0.3);
  color: #93c5fd;
}

.model-card__badge--task {
  background: rgba(16, 185, 129, 0.2);
  border: 1px solid rgba(16, 185, 129, 0.3);
  color: #6ee7b7;
}

.model-card__badge--library {
  background: rgba(139, 92, 246, 0.2);
  border: 1px solid rgba(139, 92, 246, 0.3);
  color: #c4b5fd;
}

.model-card__meta {
  display: flex;
  gap: 16px;
  margin-bottom: 12px;
}

.model-card__meta-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.model-card__meta-label {
  font-size: 10px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
  text-transform: uppercase;
}

.model-card__meta-value {
  font-size: 13px;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  font-weight: 500;
}

.model-card__task {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
}

.model-card__stats {
  display: flex;
  gap: 16px;
  margin-bottom: 12px;
}

.model-card__stat {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
}

.model-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px;
}

.model-card__tag {
  padding: 2px 8px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: 6px;
  font-size: 11px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
}

.model-card__tag--more {
  background: transparent;
  border-style: dashed;
}

.model-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
}

.model-card__date {
  font-size: 11px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
}

.model-card__action-btn {
  padding: 6px 12px;
  background: rgba(59, 130, 246, 0.3);
  border: 1px solid rgba(59, 130, 246, 0.5);
  color: #93c5fd;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.model-card__action-btn:hover {
  background: rgba(59, 130, 246, 0.4);
  box-shadow: 0 0 15px rgba(59, 130, 246, 0.3);
}
/**
 * Dataset Browser Styles
 * 
 * Styles for DatasetBrowser and DatasetPreview components.
 * Uses glassmorphism design tokens for consistent styling.
 */

/* Dataset Browser Container */
.dataset-browser {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: rgba(15, 23, 42, var(--glass-bg-opacity, 0.7));
  backdrop-filter: blur(var(--glass-blur-lg, 12px));
  -webkit-backdrop-filter: blur(var(--glass-blur-lg, 12px));
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: var(--glass-radius, 16px);
  box-shadow: var(--glass-shadow, 0 8px 32px rgba(0, 0, 0, 0.4));
  overflow: hidden;
}

.dataset-browser__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  background: rgba(15, 23, 42, 0.3);
}

.dataset-browser__title {
  font-size: 18px;
  font-weight: 600;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  margin: 0;
}

.dataset-browser__close-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: none;
  background: rgba(255, 255, 255, 0.1);
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.7));
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.dataset-browser__close-btn:hover {
  background: rgba(255, 255, 255, 0.2);
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
}

/* Breadcrumb */
.dataset-browser__breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  background: rgba(15, 23, 42, 0.3);
}

.dataset-browser__breadcrumb-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  background: rgba(255, 255, 255, 0.05);
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.7));
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.dataset-browser__breadcrumb-btn:hover:not(:disabled) {
  background: rgba(255, 255, 255, 0.1);
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
}

.dataset-browser__breadcrumb-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.dataset-browser__breadcrumb-path {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 1;
  overflow-x: auto;
}

.dataset-browser__breadcrumb-segment {
  padding: 4px 8px;
  border: none;
  background: transparent;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  font-size: 13px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.2s ease;
  white-space: nowrap;
}

.dataset-browser__breadcrumb-segment:hover {
  background: rgba(255, 255, 255, 0.1);
}

.dataset-browser__breadcrumb-separator {
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
}

/* Filters */
.dataset-browser__filters {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  background: rgba(15, 23, 42, 0.2);
}

.dataset-browser__select {
  padding: 8px 12px;
  background: rgba(15, 23, 42, 0.5);
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: 8px;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  font-size: 14px;
  cursor: pointer;
  outline: none;
  transition: all 0.2s ease;
}

.dataset-browser__select:focus {
  border-color: rgba(16, 185, 129, 0.5);
  box-shadow: 0 0 15px rgba(16, 185, 129, 0.2);
}

.dataset-browser__select option {
  background: #1e1e2e;
  color: #cdd6f4;
}

.dataset-browser__count {
  font-size: 13px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
  margin-left: auto;
}

/* Issue 33.8: Refresh button */
.dataset-browser__refresh-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  background: rgba(59, 130, 246, 0.15);
  border: 1px solid rgba(59, 130, 246, 0.3);
  border-radius: 8px;
  color: #93c5fd;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.dataset-browser__refresh-btn:hover:not(:disabled) {
  background: rgba(59, 130, 246, 0.25);
  border-color: rgba(59, 130, 246, 0.5);
}

.dataset-browser__refresh-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.dataset-browser__refresh-btn svg {
  transition: transform 0.3s ease;
}

.dataset-browser__refresh-icon--spinning {
  animation: refresh-spin 1s linear infinite;
}

@keyframes refresh-spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* Main content */
.dataset-browser__main {
  display: flex;
  flex: 1;
  overflow: hidden;
}

.dataset-browser__list-container {
  flex: 1;
  overflow-y: auto;
  border-right: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
}

.dataset-browser__preview-container {
  width: 400px;
  overflow-y: auto;
  background: rgba(15, 23, 42, 0.3);
}

/* Dataset list */
.dataset-browser__list {
  display: flex;
  flex-direction: column;
}

.dataset-browser__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.08));
  cursor: pointer;
  transition: all 0.2s ease;
}

.dataset-browser__item:hover {
  background: rgba(255, 255, 255, 0.05);
}

.dataset-browser__item--selected {
  background: rgba(16, 185, 129, 0.15);
  border-left: 3px solid rgba(16, 185, 129, 0.8);
}

.dataset-browser__item-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: 8px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
}

.dataset-browser__item-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.dataset-browser__item-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dataset-browser__item-meta {
  font-size: 12px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
}

.dataset-browser__item-format {
  padding: 2px 8px;
  background: rgba(16, 185, 129, 0.2);
  border: 1px solid rgba(16, 185, 129, 0.3);
  border-radius: 6px;
  font-size: 11px;
  font-weight: 500;
  color: #6ee7b7;
  text-transform: uppercase;
}

.dataset-browser__item-use-btn {
  padding: 6px 12px;
  background: rgba(16, 185, 129, 0.3);
  border: 1px solid rgba(16, 185, 129, 0.5);
  color: #6ee7b7;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  opacity: 0;
  transition: all 0.2s ease;
}

.dataset-browser__item:hover .dataset-browser__item-use-btn {
  opacity: 1;
}

.dataset-browser__item-use-btn:hover {
  background: rgba(16, 185, 129, 0.4);
  box-shadow: 0 0 15px rgba(16, 185, 129, 0.3);
}

/* Analyze button - purple/violet color scheme */
.dataset-browser__item-analyze-btn {
  padding: 6px 12px;
  background: rgba(168, 85, 247, 0.3);
  border: 1px solid rgba(168, 85, 247, 0.5);
  color: #c4b5fd;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  opacity: 0;
  transition: all 0.2s ease;
  margin-right: 8px;
}

.dataset-browser__item:hover .dataset-browser__item-analyze-btn {
  opacity: 1;
}

.dataset-browser__item-analyze-btn:hover {
  background: rgba(168, 85, 247, 0.4);
  box-shadow: 0 0 15px rgba(168, 85, 247, 0.3);
}

/* Loading, Error, Empty states */
.dataset-browser__loading,
.dataset-browser__error,
.dataset-browser__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 48px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
  text-align: center;
}

.dataset-browser__spinner {
  width: 40px;
  height: 40px;
  border: 3px solid rgba(255, 255, 255, 0.1);
  border-top-color: #6ee7b7;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

.dataset-browser__error {
  color: #f38ba8;
}

.dataset-browser__error-detail {
  font-size: 12px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
}

.dataset-browser__retry-btn {
  padding: 8px 16px;
  background: rgba(16, 185, 129, 0.3);
  border: 1px solid rgba(16, 185, 129, 0.5);
  color: #6ee7b7;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.dataset-browser__retry-btn:hover {
  background: rgba(16, 185, 129, 0.4);
  box-shadow: 0 0 20px rgba(16, 185, 129, 0.3);
}

/* Dataset Preview */
.dataset-preview {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 16px;
}

.dataset-preview--loading,
.dataset-preview--error,
.dataset-preview--empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  height: 100%;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
  text-align: center;
}

.dataset-preview__spinner {
  width: 32px;
  height: 32px;
  border: 3px solid rgba(255, 255, 255, 0.1);
  border-top-color: #6ee7b7;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

.dataset-preview--error {
  color: #f38ba8;
}

.dataset-preview__error-detail {
  font-size: 12px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
}

.dataset-preview__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.dataset-preview__title {
  font-size: 14px;
  font-weight: 600;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  margin: 0;
}

.dataset-preview__meta {
  display: flex;
  align-items: center;
  gap: 8px;
}

.dataset-preview__format {
  padding: 2px 6px;
  background: rgba(16, 185, 129, 0.2);
  border: 1px solid rgba(16, 185, 129, 0.3);
  color: #6ee7b7;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 600;
}

.dataset-preview__count {
  font-size: 11px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
}

.dataset-preview__schema {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: 8px;
  margin-bottom: 12px;
}

.dataset-preview__schema-label {
  font-size: 12px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
}

.dataset-preview__schema-cols {
  font-size: 12px;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
}

.dataset-preview__content {
  flex: 1;
  overflow: auto;
}

/* Table Preview */
.dataset-preview__table-container {
  overflow: auto;
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: 8px;
}

.dataset-preview__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

.dataset-preview__th {
  position: sticky;
  top: 0;
  padding: 8px 12px;
  background: rgba(15, 23, 42, 0.8);
  border-bottom: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  text-align: left;
  font-weight: 600;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
}

.dataset-preview__th-content {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.dataset-preview__col-name {
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
}

.dataset-preview__col-type {
  font-size: 10px;
  font-weight: 400;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
}

.dataset-preview__tr:nth-child(even) {
  background: rgba(255, 255, 255, 0.02);
}

.dataset-preview__td {
  padding: 8px 12px;
  border-bottom: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.08));
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Image Grid Preview */
.dataset-preview__image-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 12px;
}

.dataset-preview__image-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.dataset-preview__image {
  width: 100%;
  aspect-ratio: 1;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
}

.dataset-preview__image-placeholder {
  width: 100%;
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: 8px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
}

.dataset-preview__image-label {
  font-size: 11px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dataset-preview__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 24px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}


/* Folder Navigation Styles */
.dataset-browser__item--folder {
  cursor: pointer;
}

.dataset-browser__item--folder:hover {
  background: rgba(59, 130, 246, 0.1);
}

.dataset-browser__item--folder .dataset-browser__item-icon {
  color: #60a5fa;
  background: rgba(59, 130, 246, 0.15);
  border-color: rgba(59, 130, 246, 0.3);
}

.dataset-browser__folder-indicator {
  font-size: 12px;
  margin-left: 4px;
}

.dataset-browser__item-browse-btn {
  padding: 6px 12px;
  background: rgba(59, 130, 246, 0.3);
  border: 1px solid rgba(59, 130, 246, 0.5);
  color: #60a5fa;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  opacity: 0;
  transition: all 0.2s ease;
  margin-right: 8px;
}

.dataset-browser__item:hover .dataset-browser__item-browse-btn {
  opacity: 1;
}

.dataset-browser__item-browse-btn:hover {
  background: rgba(59, 130, 246, 0.4);
  box-shadow: 0 0 15px rgba(59, 130, 246, 0.3);
}

/* Subdatasets Panel */
.dataset-browser__subdatasets {
  padding: 16px;
  border-bottom: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  background: rgba(59, 130, 246, 0.05);
}

.dataset-browser__subdatasets-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  margin: 0 0 8px 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.dataset-browser__subdatasets-hint {
  font-size: 12px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
  margin: 0 0 12px 0;
  font-style: italic;
}

.dataset-browser__subdatasets-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dataset-browser__subdataset-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--glass-border-color, rgba(255, 255, 255, 0.12));
  border-radius: 8px;
  color: #60a5fa;
}

.dataset-browser__subdataset-item svg {
  flex-shrink: 0;
}

.dataset-browser__subdataset-name {
  flex: 1;
  font-size: 13px;
  font-weight: 500;
  color: var(--glass-text-primary, rgba(255, 255, 255, 0.9));
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dataset-browser__subdataset-meta {
  font-size: 11px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.6));
  white-space: nowrap;
}

.dataset-browser__subdataset-more {
  font-size: 12px;
  color: var(--glass-text-secondary, rgba(255, 255, 255, 0.5));
  font-style: italic;
  padding: 4px 12px;
}
/**
 * Training Metrics Panel Styles
 * 
 * Styles for the training metrics visualization component.
 */

.training-metrics-panel {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.training-metrics-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-color, #e5e7eb);
}

.training-metrics-panel__title {
  display: flex;
  align-items: center;
  gap: 12px;
}

.training-metrics-panel__actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.training-metrics-panel__action-btn {
  padding: 6px;
  border-radius: 4px;
  background: transparent;
  border: none;
  cursor: pointer;
  transition: background-color 0.15s;
}

.training-metrics-panel__action-btn:hover {
  background-color: rgba(0, 0, 0, 0.05);
}

.training-metrics-panel__action-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Metric Cards Grid */
.training-metrics-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  padding: 12px 16px;
}

@media (max-width: 768px) {
  .training-metrics-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

.training-metric-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px;
  border-radius: 8px;
  background-color: var(--bg-tertiary, #f3f4f6);
}

.training-metric-card--warning {
  border: 1px solid var(--warning-color, #f59e0b);
}

.training-metric-card__header {
  display: flex;
  align-items: center;
  gap: 8px;
}

.training-metric-card__label {
  font-size: 12px;
  color: var(--text-tertiary, #9ca3af);
}

.training-metric-card__value {
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.training-metric-card__number {
  font-size: 20px;
  font-weight: 600;
}

.training-metric-card__trend {
  display: flex;
  align-items: center;
  gap: 2px;
  font-size: 12px;
}

.training-metric-card__trend--up {
  color: var(--success-color, #10b981);
}

.training-metric-card__trend--down {
  color: var(--error-color, #ef4444);
}

/* Divergence Warning */
.divergence-warning {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  margin: 12px 16px 0;
  border-radius: 8px;
  background-color: rgba(245, 158, 11, 0.1);
  border: 1px solid var(--warning-color, #f59e0b);
}

.divergence-warning__icon {
  flex-shrink: 0;
  color: var(--warning-color, #f59e0b);
}

.divergence-warning__content {
  flex: 1;
}

.divergence-warning__title {
  font-weight: 500;
  color: var(--warning-color, #f59e0b);
}

.divergence-warning__description {
  font-size: 14px;
  color: var(--text-secondary, #6b7280);
  margin-top: 2px;
}

.divergence-warning__dismiss {
  padding: 4px;
  border-radius: 4px;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--warning-color, #f59e0b);
}

.divergence-warning__dismiss:hover {
  background-color: rgba(0, 0, 0, 0.1);
}

/* Chart Container */
.training-metrics-chart-container {
  flex: 1;
  padding: 0 16px 16px;
  min-height: 200px;
}

.training-metrics-chart {
  width: 100%;
  height: 100%;
}

/* Status Badge */
.training-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 500;
}

.training-status-badge--idle {
  background-color: rgba(156, 163, 175, 0.2);
  color: #6b7280;
}

.training-status-badge--running {
  background-color: rgba(59, 130, 246, 0.2);
  color: #3b82f6;
}

.training-status-badge--completed {
  background-color: rgba(16, 185, 129, 0.2);
  color: #10b981;
}

.training-status-badge--failed {
  background-color: rgba(239, 68, 68, 0.2);
  color: #ef4444;
}

.training-status-badge--diverging {
  background-color: rgba(245, 158, 11, 0.2);
  color: #f59e0b;
}

/* Compact View */
.training-metrics-compact {
  padding: 8px;
  border-radius: 6px;
}

.training-metrics-compact__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.training-metrics-compact__stats {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 12px;
}

.training-metrics-compact__diverging {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 4px;
  font-size: 12px;
}

/* Expanded Modal */
.training-metrics-expanded {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.5);
}

.training-metrics-expanded__content {
  width: 90vw;
  max-width: 1000px;
  height: 80vh;
  max-height: 700px;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

/* Animation for running status */
@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}

.training-status-badge--running svg {
  animation: pulse 2s ease-in-out infinite;
}
/**
 * VectorField Login Page Styles
 * 
 * Glassmorphism design with liquid glass effects
 * Based on VF Website design patterns
 * 
 * @version 1.0.0
 * @date 2026-01-29
 */

/* ============================================
   Main Container
   ============================================ */

.vf-login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.vf-login-page__background {
  position: absolute;
  inset: 0;
  background-image: url('/VF_BG_001.jpg');
  background-size: cover;
  background-position: center;
  filter: brightness(0.3);
  z-index: 0;
}

.vf-login-page__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(15, 23, 42, 0.9) 0%,
    rgba(15, 23, 42, 0.7) 50%,
    rgba(6, 182, 212, 0.1) 100%
  );
  z-index: 1;
}

.vf-login-page__container {
  position: relative;
  z-index: 10;
  width: 100%;
  max-width: 420px;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

/* ============================================
   Loading State
   ============================================ */

.vf-login-page__loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  color: rgba(255, 255, 255, 0.7);
}

.vf-login-page__spinner {
  width: 40px;
  height: 40px;
  border: 3px solid rgba(6, 182, 212, 0.2);
  border-top-color: #06b6d4;
  border-radius: 50%;
  animation: vf-spin 1s linear infinite;
}

@keyframes vf-spin {
  to {
    transform: rotate(360deg);
  }
}

/* ============================================
   Header Section
   ============================================ */

.vf-login-page__header {
  text-align: center;
  margin-bottom: 0.5rem;
}

.vf-login-page__logo-wrapper {
  display: flex;
  justify-content: center;
  margin-bottom: 1rem;
}

.vf-login-page__title {
  font-size: 1.5rem;
  font-weight: 700;
  color: white;
  margin: 0 0 0.5rem 0;
  letter-spacing: -0.02em;
}

.vf-login-page__subtitle {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.6);
  margin: 0;
}

/* ============================================
   Error Message
   ============================================ */

.vf-login-page__error {
  background: rgba(239, 68, 68, 0.15);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
}

.vf-login-page__error p {
  margin: 0;
  color: #fca5a5;
  font-size: 0.875rem;
}

/* ============================================
   Glass Card Component
   ============================================ */

.vf-glass-card {
  position: relative;
  border-radius: 0.75rem;
  padding: 1.5rem;
  transform: translate3d(0, 0, 0);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.vf-glass-card--hovered {
  transform: scale(1.01);
  box-shadow: 
    0 12px 40px 0 rgba(0, 0, 0, 0.4),
    0 0 11px rgba(6, 182, 212, 0.8),
    0 0 166px rgba(6, 182, 212, 0.4);
}

/* Layer 0: Backdrop blur */
.vf-glass-card__backdrop {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  overflow: hidden;
  backdrop-filter: blur(10px) saturate(180%);
  -webkit-backdrop-filter: blur(10px) saturate(180%);
  background-color: rgba(15, 15, 20, 0.4);
}

/* Layer 1: Tint overlay */
.vf-glass-card__tint {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  overflow: hidden;
  background: linear-gradient(
    135deg,
    rgba(52, 84, 148, 0.15) 0%,
    rgba(15, 23, 42, 0.1) 50%,
    transparent 100%
  );
}

/* Layer 2: Static border */
.vf-glass-card__border {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  border: 1px solid #345494;
}

/* Layer 2: Animated SVG border */
.vf-glass-card__border-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

/* Layer 3: Hover sheen animation */
.vf-glass-card__sheen {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  overflow: hidden;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.1),
    transparent
  );
  background-size: 200% 100%;
  animation: vf-sheen 4s linear infinite;
}

@keyframes vf-sheen {
  0% {
    background-position: -200% 0;
  }
  100% {
    background-position: 200% 0;
  }
}

/* Layer 4: Content */
.vf-glass-card__content {
  position: relative;
  z-index: 10;
}

/* ============================================
   Card Content
   ============================================ */

.vf-login-page__card-content {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.vf-login-page__form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.vf-login-page__welcome {
  text-align: center;
  margin-bottom: 0.5rem;
}

.vf-login-page__welcome h2 {
  font-size: 1.25rem;
  font-weight: 600;
  color: white;
  margin: 0 0 0.5rem 0;
}

.vf-login-page__welcome p {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.6);
  margin: 0;
}

/* ============================================
   Glass Input Component
   ============================================ */

.vf-glass-input {
  position: relative;
  display: flex;
  align-items: center;
  background: rgba(15, 23, 42, 0.5);
  border-radius: 0.5rem;
  transition: all 0.3s ease;
}

.vf-glass-input__icon {
  position: absolute;
  left: 1rem;
  color: rgba(255, 255, 255, 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  transition: color 0.3s ease;
}

.vf-glass-input--focused .vf-glass-input__icon {
  color: #06b6d4;
}

.vf-glass-input__field {
  width: 100%;
  padding: 0.875rem 1rem 0.875rem 3rem;
  font-size: 1rem;
  color: white;
  background: transparent;
  border: none;
  outline: none;
  font-family: inherit;
}

.vf-glass-input__field::-moz-placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.vf-glass-input__field::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.vf-glass-input__field:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.vf-glass-input__border {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  border: 1px solid rgba(52, 84, 148, 0.5);
  transition: border-color 0.3s ease, border-width 0.2s ease;
}

.vf-glass-input--focused .vf-glass-input__border {
  border-color: #06b6d4;
  border-width: 2px;
}

.vf-glass-input__glow {
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: 0 0 15px rgba(6, 182, 212, 0.3);
  opacity: 0;
  animation: vf-input-glow-in 0.3s ease forwards;
}

@keyframes vf-input-glow-in {
  to {
    opacity: 1;
  }
}

.vf-glass-input--disabled {
  opacity: 0.5;
}

/* ============================================
   Glass Button Component
   ============================================ */

.vf-glass-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.875rem 1.5rem;
  font-size: 1rem;
  font-weight: 600;
  color: white;
  background: transparent;
  border: none;
  border-radius: 0.75rem;
  cursor: pointer;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.vf-glass-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.vf-glass-button--primary {
  background: rgba(6, 182, 212, 0.4);
  box-shadow: 
    0 0 30px rgba(6, 182, 212, 0.4),
    0 0 60px rgba(6, 182, 212, 0.2);
}

.vf-glass-button--primary:not(:disabled):hover {
  transform: scale(1.02);
  box-shadow: 
    0 0 40px rgba(6, 182, 212, 0.6),
    0 0 80px rgba(6, 182, 212, 0.3);
}

.vf-glass-button--secondary {
  background: rgba(15, 23, 42, 0.6);
}

.vf-glass-button--secondary:not(:disabled):hover {
  transform: scale(1.02);
  box-shadow: 0 0 20px rgba(6, 182, 212, 0.3);
}

.vf-glass-button--hovered:not(:disabled) {
  transform: scale(1.02);
}

.vf-glass-button:active:not(:disabled) {
  transform: scale(0.98);
}

/* Button border layer */
.vf-glass-button__border {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  border: 1px solid rgba(6, 182, 212, 0.5);
  transition: border-width 0.2s ease;
}

.vf-glass-button--hovered .vf-glass-button__border {
  border-width: 2px;
}

/* Button specular highlight */
.vf-glass-button__highlight {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.04) 0%,
    transparent 50%
  );
}

/* Button hover sheen */
.vf-glass-button__sheen {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.15),
    transparent
  );
  background-size: 200% 100%;
  animation: vf-sheen 4s linear infinite;
}

/* Button content */
.vf-glass-button__content {
  position: relative;
  z-index: 10;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  white-space: nowrap;
}

/* Sign in button specific */
.vf-login-page__signin-button {
  width: 100%;
  margin-top: 0.5rem;
}

/* SSO button specific */
.vf-login-page__sso-button {
  width: 100%;
}

/* Button loading state */
.vf-login-page__button-loading {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.vf-login-page__button-spinner {
  width: 20px;
  height: 20px;
  animation: vf-spin 1s linear infinite;
}

.vf-login-page__spinner-track {
  opacity: 0.25;
}

.vf-login-page__spinner-head {
  opacity: 0.75;
}

/* ============================================
   Divider
   ============================================ */

.vf-login-page__divider {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.vf-login-page__divider-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.2),
    transparent
  );
}

.vf-login-page__divider-text {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.4);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ============================================
   Terms Text
   ============================================ */

.vf-login-page__terms {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.4);
  text-align: center;
  margin: 0;
  line-height: 1.5;
}

/* ============================================
   Footer
   ============================================ */

.vf-login-page__footer {
  text-align: center;
}

.vf-login-page__footer p {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.5);
  margin: 0;
}

.vf-login-page__support-link {
  color: #06b6d4;
  text-decoration: none;
  transition: color 0.2s ease;
}

.vf-login-page__support-link:hover {
  color: #22d3ee;
  text-decoration: underline;
}

/* ============================================
   Password Requirements
   ============================================ */

.vf-login-page__requirements {
  background: rgba(6, 182, 212, 0.1);
  border: 1px solid rgba(6, 182, 212, 0.2);
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
  margin-bottom: 0.5rem;
}

.vf-login-page__requirements p {
  margin: 0 0 0.5rem 0;
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.8125rem;
  font-weight: 500;
}

.vf-login-page__requirements ul {
  margin: 0;
  padding-left: 1.25rem;
  list-style-type: disc;
}

.vf-login-page__requirements li {
  color: rgba(255, 255, 255, 0.5);
  font-size: 0.75rem;
  line-height: 1.6;
}

/* ============================================
   Logo Component
   ============================================ */

.vf-logo {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.vf-logo__icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vf-logo__svg {
  width: 100%;
  height: 100%;
}

.vf-logo__text {
  font-size: 1.5rem;
  font-weight: 700;
  color: white;
  letter-spacing: -0.02em;
}

/* ============================================
   Responsive Adjustments
   ============================================ */

@media (max-width: 480px) {
  .vf-login-page__container {
    padding: 1rem;
    max-width: 100%;
  }

  .vf-glass-card {
    padding: 1.25rem;
  }

  .vf-login-page__title {
    font-size: 1.25rem;
  }

  .vf-logo__icon {
    width: 40px;
    height: 40px;
  }

  .vf-logo__text {
    font-size: 1.25rem;
  }
}
/* Theme-aware root styles */
:root {
  /* Default dark theme colors */
  --bg-primary: #1a1a1a;
  --bg-secondary: #2a2a2a;
  --bg-tertiary: #3a3a3a;
  --text-primary: #ffffff;
  --text-secondary: #b0b0b0;
  --text-tertiary: #808080;
  --border-default: #404040;
  --border-hover: #505050;
  --border-active: #606060;
}

[data-theme="light"] {
  --bg-primary: #ffffff;
  --bg-secondary: #f5f5f5;
  --bg-tertiary: #e5e5e5;
  --text-primary: #1a1a1a;
  --text-secondary: #4a4a4a;
  --text-tertiary: #808080;
  --border-default: #d0d0d0;
  --border-hover: #b0b0b0;
  --border-active: #909090;
}

body {
  background-color: transparent;
  color: var(--text-primary);
  transition: color 300ms ease-in-out;
}

.app {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: transparent;
}

/* Circuit board style edge animations */
@keyframes dash {
  to {
    stroke-dashoffset: -12;
  }
}

.animated-edge {
  animation: dash 1s linear infinite;
}

/* Task node handle positioning - 20px from bottom */
.task-template-node .react-flow__handle-left {
  top: auto !important;
  bottom: 20px !important;
}

.task-template-node .react-flow__handle-right {
  top: auto !important;
  bottom: 20px !important;
}

/* ReactFlow Controls - white icons for dark glassmorphism background */
.react-flow__controls-button {
  background: transparent !important;
  border: none !important;
  fill: rgba(255, 255, 255, 0.9) !important;
}

.react-flow__controls-button:hover {
  background: rgba(255, 255, 255, 0.1) !important;
}

.react-flow__controls-button svg {
  fill: rgba(255, 255, 255, 0.9) !important;
}

.react-flow__controls-button svg path {
  fill: rgba(255, 255, 255, 0.9) !important;
}


/* =============================================================================
   ML Phase 5.5 Component Styles
   ============================================================================= */

/* -----------------------------------------------------------------------------
   Template Library
   ----------------------------------------------------------------------------- */
.template-library {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: var(--text-primary);
}

.template-library-header {
  padding: 1rem;
  border-bottom: 1px solid var(--border-default);
}

.template-library-header h2 {
  margin: 0 0 0.75rem 0;
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--text-primary);
}

.template-search .search-input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border-radius: 0.375rem;
  border: 1px solid var(--border-default);
  background: var(--bg-secondary);
  color: var(--text-primary);
  font-size: 0.875rem;
}

.template-search .search-input:focus {
  outline: none;
  border-color: #3b82f6;
}

.template-library-content {
  display: flex;
  flex: 1;
  overflow: hidden;
}

.template-sidebar {
  width: 200px;
  border-right: 1px solid var(--border-default);
  overflow-y: auto;
  padding: 0.5rem;
}

.category-filter-title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 0.5rem;
  margin: 0;
}

.category-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.category-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.5rem;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  font-size: 0.875rem;
  cursor: pointer;
  border-radius: 0.375rem;
  text-align: left;
}

.category-item:hover {
  background: var(--bg-tertiary);
}

.category-item.selected {
  background: rgba(59, 130, 246, 0.2);
  color: #60a5fa;
}

.category-count {
  margin-left: auto;
  font-size: 0.75rem;
  color: var(--text-tertiary);
}

.template-list {
  flex: 1;
  overflow-y: auto;
  padding: 0.5rem;
}

.template-card {
  padding: 0.75rem;
  border: 1px solid var(--border-default);
  border-radius: 0.5rem;
  margin-bottom: 0.5rem;
  cursor: pointer;
  transition: all 0.15s;
}

.template-card:hover {
  border-color: var(--border-hover);
  background: var(--bg-tertiary);
}

.template-card.selected {
  border-color: #3b82f6;
  background: rgba(59, 130, 246, 0.1);
}

.template-card-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.25rem;
}

.template-name {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-primary);
}

.template-preview-desc {
  margin: 0;
  font-size: 0.75rem;
  color: var(--text-secondary);
  line-height: 1.4;
}

.template-meta {
  display: flex;
  gap: 0.75rem;
  margin-top: 0.5rem;
  font-size: 0.75rem;
  color: var(--text-tertiary);
}

.template-preview-panel {
  width: 300px;
  border-left: 1px solid var(--border-default);
  padding: 1rem;
  overflow-y: auto;
}

.template-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.template-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
}

.version-badge {
  padding: 0.125rem 0.375rem;
  background: var(--bg-tertiary);
  border-radius: 0.25rem;
  font-size: 0.75rem;
  color: var(--text-secondary);
}

.template-description p {
  margin: 0 0 0.75rem 0;
  font-size: 0.875rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

.template-preview-graph {
  margin-bottom: 1rem;
}

.preview-placeholder {
  padding: 2rem;
  background: var(--bg-tertiary);
  border-radius: 0.5rem;
  text-align: center;
}

.preview-node-count {
  font-size: 0.875rem;
  color: var(--text-tertiary);
}

.template-interface h3 {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0 0.5rem 0;
}

.interface-section {
  margin-bottom: 1rem;
}

.interface-row {
  display: flex;
  gap: 0.5rem;
  padding: 0.25rem 0;
  font-size: 0.75rem;
}

.interface-name {
  font-weight: 500;
  color: var(--text-primary);
}

.required-marker {
  color: #ef4444;
}

.interface-kind {
  color: #60a5fa;
}

.interface-description {
  color: var(--text-tertiary);
}

.no-items {
  font-size: 0.75rem;
  color: var(--text-tertiary);
  font-style: italic;
}

.template-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  margin-bottom: 0.75rem;
}

.template-tag {
  padding: 0.125rem 0.5rem;
  background: var(--bg-tertiary);
  border-radius: 9999px;
  font-size: 0.75rem;
  color: var(--text-secondary);
}

.template-meta-info {
  display: flex;
  gap: 1rem;
  font-size: 0.75rem;
  color: var(--text-tertiary);
  margin-bottom: 1rem;
}

.template-actions {
  display: flex;
  gap: 0.5rem;
}

.template-actions .btn {
  flex: 1;
  padding: 0.5rem 1rem;
  border-radius: 0.375rem;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}

.template-actions .btn-primary {
  background: #3b82f6;
  color: white;
  border: none;
}

.template-actions .btn-primary:hover {
  background: #2563eb;
}

.template-actions .btn-secondary {
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--border-default);
}

.template-actions .btn-secondary:hover {
  background: var(--bg-tertiary);
}

.no-templates {
  padding: 2rem;
  text-align: center;
  color: var(--text-tertiary);
}

/* -----------------------------------------------------------------------------
   Cost Estimate Panel
   ----------------------------------------------------------------------------- */
.cost-estimate-panel {
  padding: 1rem;
  color: var(--text-primary);
}

.cost-estimate-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}

.cost-estimate-header h3 {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
}

.cost-estimate-header .close-button {
  background: transparent;
  border: none;
  color: var(--text-tertiary);
  font-size: 1.25rem;
  cursor: pointer;
  padding: 0.25rem;
  line-height: 1;
}

.cost-estimate-header .close-button:hover {
  color: var(--text-primary);
}

.cost-estimate-duration {
  display: flex;
  justify-content: space-between;
  padding: 0.5rem;
  background: var(--bg-tertiary);
  border-radius: 0.375rem;
  margin-bottom: 1rem;
  font-size: 0.875rem;
}

.cost-estimate-duration .label {
  color: var(--text-secondary);
}

.cost-estimate-duration .value {
  color: var(--text-primary);
  font-weight: 500;
}

.cost-estimate-empty {
  padding: 2rem;
  text-align: center;
  color: var(--text-tertiary);
}

.cost-estimate-empty .hint {
  font-size: 0.75rem;
  margin-top: 0.5rem;
}

.cost-estimate-summary {
  margin-bottom: 1rem;
}

.cost-row {
  display: flex;
  justify-content: space-between;
  padding: 0.375rem 0;
  font-size: 0.875rem;
}

.cost-row .label {
  color: var(--text-secondary);
}

.cost-row .value {
  color: var(--text-primary);
  font-weight: 500;
}

.cost-row .value.highlight {
  color: #10b981;
}

.cost-row .value.savings-value {
  color: #fbbf24;
}

.cost-estimate-hourly {
  padding: 0.75rem;
  background: var(--bg-tertiary);
  border-radius: 0.375rem;
  margin-bottom: 1rem;
}

.cost-estimate-hourly h4 {
  margin: 0 0 0.5rem 0;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-tertiary);
  text-transform: uppercase;
}

.hourly-row {
  display: flex;
  justify-content: space-between;
  font-size: 0.875rem;
  padding: 0.25rem 0;
}

.hourly-row .label {
  color: var(--text-secondary);
}

.hourly-row .value {
  color: var(--text-primary);
}

.cost-estimate-breakdown {
  margin-bottom: 1rem;
}

.cost-estimate-breakdown h4 {
  margin: 0 0 0.5rem 0;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-tertiary);
  text-transform: uppercase;
}

.breakdown-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.75rem;
}

.breakdown-table th {
  text-align: left;
  padding: 0.5rem 0.25rem;
  border-bottom: 1px solid var(--border-default);
  color: var(--text-tertiary);
  font-weight: 500;
}

.breakdown-table td {
  padding: 0.5rem 0.25rem;
  border-bottom: 1px solid var(--border-default);
  color: var(--text-primary);
}

.breakdown-table .node-name {
  max-width: 100px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.breakdown-table .gpu-info {
  color: var(--text-secondary);
}

.breakdown-table .cost.spot {
  color: #10b981;
}

.cost-estimate-recommendation {
  display: flex;
  gap: 0.75rem;
  padding: 0.75rem;
  background: rgba(251, 191, 36, 0.1);
  border: 1px solid rgba(251, 191, 36, 0.3);
  border-radius: 0.375rem;
}

.recommendation-icon {
  font-size: 1.25rem;
}

.recommendation-text {
  font-size: 0.75rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

.recommendation-text strong {
  color: var(--text-primary);
}

/* -----------------------------------------------------------------------------
   Test Workflow Panel
   ----------------------------------------------------------------------------- */
.test-workflow-panel {
  padding: 1rem;
  color: var(--text-primary);
}

.test-workflow-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}

.test-workflow-header h3 {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
}

.test-workflow-header .close-button {
  background: transparent;
  border: none;
  color: var(--text-tertiary);
  font-size: 1.25rem;
  cursor: pointer;
  padding: 0.25rem;
  line-height: 1;
}

.test-workflow-header .close-button:hover {
  color: var(--text-primary);
}

.test-workflow-config {
  margin-bottom: 1rem;
}

.test-workflow-config h4 {
  margin: 0 0 0.75rem 0;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-tertiary);
  text-transform: uppercase;
}

.config-field {
  margin-bottom: 0.75rem;
}

.config-field label {
  display: block;
  font-size: 0.875rem;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
}

.config-field input[type="number"] {
  width: 100%;
  padding: 0.5rem;
  border: 1px solid var(--border-default);
  border-radius: 0.375rem;
  background: var(--bg-secondary);
  color: var(--text-primary);
  font-size: 0.875rem;
}

.config-field input[type="number"]:focus {
  outline: none;
  border-color: #3b82f6;
}

.config-field input[type="number"]:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.config-field .hint {
  display: block;
  font-size: 0.75rem;
  color: var(--text-tertiary);
  margin-top: 0.25rem;
}

.config-field.checkbox label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
}

.config-field.checkbox input[type="checkbox"] {
  width: 1rem;
  height: 1rem;
  accent-color: #3b82f6;
}

.validation-errors {
  margin-top: 0.75rem;
}

.validation-errors .error {
  padding: 0.5rem;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: 0.375rem;
  color: #f87171;
  font-size: 0.75rem;
  margin-bottom: 0.25rem;
}

.test-workflow-actions {
  margin-bottom: 1rem;
}

.test-workflow-actions .run-button,
.test-workflow-actions .cancel-button {
  width: 100%;
  padding: 0.625rem 1rem;
  border-radius: 0.375rem;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}

.test-workflow-actions .run-button {
  background: #10b981;
  color: white;
  border: none;
}

.test-workflow-actions .run-button:hover:not(:disabled) {
  background: #059669;
}

.test-workflow-actions .run-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.test-workflow-actions .cancel-button {
  background: #ef4444;
  color: white;
  border: none;
}

.test-workflow-actions .cancel-button:hover {
  background: #dc2626;
}

.test-workflow-results {
  border-top: 1px solid var(--border-default);
  padding-top: 1rem;
}

.test-workflow-results h4 {
  margin: 0 0 0.75rem 0;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-tertiary);
  text-transform: uppercase;
}

.results-summary {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}

.status-badge {
  padding: 0.25rem 0.75rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 600;
}

.status-badge.completed {
  background: rgba(16, 185, 129, 0.2);
  color: #10b981;
}

.status-badge.failed {
  background: rgba(239, 68, 68, 0.2);
  color: #ef4444;
}

.status-badge.running {
  background: rgba(59, 130, 246, 0.2);
  color: #3b82f6;
}

.status-badge.timeout {
  background: rgba(251, 191, 36, 0.2);
  color: #fbbf24;
}

.results-summary .duration {
  font-size: 0.875rem;
  color: var(--text-secondary);
}

.results-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.results-stats .stat {
  text-align: center;
  padding: 0.5rem;
  background: var(--bg-tertiary);
  border-radius: 0.375rem;
}

.results-stats .stat .value {
  display: block;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-primary);
}

.results-stats .stat .label {
  font-size: 0.625rem;
  color: var(--text-tertiary);
  text-transform: uppercase;
}

.node-results h5 {
  margin: 0 0 0.5rem 0;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-tertiary);
}

.node-results-list {
  max-height: 200px;
  overflow-y: auto;
}

.node-result {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
  border-radius: 0.375rem;
  margin-bottom: 0.25rem;
  font-size: 0.875rem;
}

.node-result.status-completed {
  background: rgba(16, 185, 129, 0.1);
}

.node-result.status-failed {
  background: rgba(239, 68, 68, 0.1);
}

.node-result.status-running {
  background: rgba(59, 130, 246, 0.1);
}

.node-result.status-pending {
  background: var(--bg-tertiary);
}

.node-result.status-skipped {
  background: var(--bg-tertiary);
  opacity: 0.6;
}

.node-result .status-icon {
  font-size: 1rem;
}

.node-result .node-name {
  flex: 1;
  color: var(--text-primary);
}

.node-result .duration {
  font-size: 0.75rem;
  color: var(--text-tertiary);
}

.node-result .error-message {
  width: 100%;
  margin-top: 0.25rem;
  padding: 0.25rem 0.5rem;
  background: rgba(239, 68, 68, 0.1);
  border-radius: 0.25rem;
  font-size: 0.75rem;
  color: #f87171;
}

.preview-outputs {
  margin-top: 1rem;
}

.preview-outputs h5 {
  margin: 0 0 0.5rem 0;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-tertiary);
}

.preview-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
}

.preview-item {
  border: 1px solid var(--border-default);
  border-radius: 0.375rem;
  overflow: hidden;
}

.preview-item .preview-label {
  padding: 0.25rem 0.5rem;
  background: var(--bg-tertiary);
  font-size: 0.75rem;
  color: var(--text-secondary);
}

.preview-item .preview-content {
  padding: 0.5rem;
}

.preview-item .preview-content img {
  width: 100%;
  height: auto;
}

.preview-item .preview-content pre {
  margin: 0;
  font-size: 0.625rem;
  color: var(--text-primary);
  overflow-x: auto;
}

.test-workflow-empty {
  padding: 2rem;
  text-align: center;
  color: var(--text-tertiary);
}

.test-workflow-empty .hint {
  font-size: 0.75rem;
  margin-top: 0.5rem;
}
/**
 * ML Hub Components Styling
 * 
 * Styles for ExperimentBrowser, ModelRegistryBrowser, WorkflowTemplateManager
 * Uses CSS variables for theme compatibility
 */

/* =============================================================================
   Common Styles
   ============================================================================= */

.experiment-browser,
.model-registry-browser,
.workflow-template-manager {
  height: 100%;
  display: flex;
  flex-direction: column;
  color: var(--text-primary, #e2e8f0);
  background: transparent;
}

.browser-header,
.manager-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
}

.browser-header h3,
.manager-header h3 {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary, #e2e8f0);
}

.header-actions {
  display: flex;
  gap: 8px;
}

.refresh-button,
.close-button {
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
  color: var(--text-secondary, #94a3b8);
  transition: background-color 0.2s;
}

.refresh-button:hover,
.close-button:hover {
  background: rgba(255, 255, 255, 0.1);
}

/* =============================================================================
   Error and Loading States
   ============================================================================= */

.browser-error,
.manager-error {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: 6px;
  margin: 12px 16px;
  color: #fca5a5;
}

.browser-error button,
.manager-error button {
  margin-left: auto;
  padding: 4px 12px;
  background: rgba(239, 68, 68, 0.2);
  border: 1px solid rgba(239, 68, 68, 0.4);
  border-radius: 4px;
  color: #fca5a5;
  cursor: pointer;
}

.browser-loading,
.manager-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px;
  color: var(--text-secondary, #94a3b8);
}

/* =============================================================================
   Content Layout
   ============================================================================= */

.browser-content,
.manager-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* =============================================================================
   Search and Filters
   ============================================================================= */

.manager-filters,
.runs-filters {
  display: flex;
  gap: 8px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
  flex-wrap: wrap;
}

.search-input {
  flex: 1;
  min-width: 150px;
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
  border-radius: 6px;
  color: var(--text-primary, #e2e8f0);
  font-size: 13px;
}

.search-input::-moz-placeholder {
  color: var(--text-secondary, #64748b);
}

.search-input::placeholder {
  color: var(--text-secondary, #64748b);
}

.search-input:focus {
  outline: none;
  border-color: #3b82f6;
}

.status-filter,
.sort-select,
.metric-select,
.stage-filter,
.category-select {
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
  border-radius: 6px;
  color: var(--text-primary, #e2e8f0);
  font-size: 13px;
  cursor: pointer;
}

.status-filter option,
.sort-select option,
.metric-select option,
.stage-filter option,
.category-select option {
  background: #1e293b;
  color: #e2e8f0;
}

/* =============================================================================
   Experiment Browser Specific
   ============================================================================= */

.experiment-list {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
}

.experiment-list h4 {
  margin: 0 0 12px 0;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary, #94a3b8);
  text-transform: uppercase;
}

.experiments-container {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 200px;
  overflow-y: auto;
}

.experiment-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid transparent;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.2s;
}

.experiment-item:hover {
  background: rgba(255, 255, 255, 0.06);
}

.experiment-item.selected {
  background: rgba(59, 130, 246, 0.15);
  border-color: rgba(59, 130, 246, 0.3);
}

.experiment-name {
  font-size: 13px;
  color: var(--text-primary, #e2e8f0);
}

.experiment-stage {
  font-size: 11px;
  color: var(--text-secondary, #64748b);
  padding: 2px 8px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 4px;
}

/* =============================================================================
   Runs Panel
   ============================================================================= */

.runs-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.runs-header {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
}

.runs-header h4 {
  margin: 0 0 12px 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary, #e2e8f0);
}

.compare-button {
  padding: 6px 12px;
  background: #3b82f6;
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  margin-top: 8px;
}

.compare-button:hover {
  background: #2563eb;
}

.runs-loading,
.runs-empty,
.versions-loading,
.versions-empty {
  padding: 32px;
  text-align: center;
  color: var(--text-secondary, #64748b);
}

.runs-list,
.versions-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
}

.run-item,
.version-item {
  display: flex;
  gap: 12px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid transparent;
  border-radius: 8px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: all 0.2s;
}

.run-item:hover,
.version-item:hover {
  background: rgba(255, 255, 255, 0.06);
}

.run-item.selected {
  background: rgba(59, 130, 246, 0.1);
  border-color: rgba(59, 130, 246, 0.3);
}

.run-checkbox {
  display: flex;
  align-items: flex-start;
  padding-top: 2px;
}

.run-checkbox input {
  width: 16px;
  height: 16px;
  cursor: pointer;
}

.run-content {
  flex: 1;
  min-width: 0;
}

.run-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.run-status {
  font-size: 12px;
  font-weight: 500;
}

.run-id {
  font-size: 11px;
  color: var(--text-secondary, #64748b);
  font-family: monospace;
}

.run-duration {
  margin-left: auto;
  font-size: 11px;
  color: var(--text-secondary, #64748b);
}

.run-metrics,
.run-params {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}

.metric-badge,
.param-badge {
  font-size: 10px;
  padding: 2px 6px;
  background: rgba(59, 130, 246, 0.15);
  border-radius: 4px;
  color: #93c5fd;
}

.param-badge {
  background: rgba(139, 92, 246, 0.15);
  color: #c4b5fd;
}

.metric-more {
  font-size: 10px;
  color: var(--text-secondary, #64748b);
  padding: 2px 6px;
}

/* =============================================================================
   Model Registry Browser Specific
   ============================================================================= */

.model-list {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
  /* VPO 005.935: Allow model list to grow and fill available space */
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

.list-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  gap: 8px; /* VPO 005.925: Add spacing between label and search input */
}

.list-header h4 {
  margin: 0;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary, #94a3b8);
  text-transform: uppercase;
  white-space: nowrap; /* Prevent text wrapping */
}

.models-container {
  display: flex;
  flex-direction: column;
  gap: 4px;
  /* VPO 005.935: Use flex-grow to fill available space, remove fixed max-height */
  flex: 1;
  min-height: 150px;
  overflow-y: auto;
}

.model-item {
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid transparent;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.2s;
}

.model-item:hover {
  background: rgba(255, 255, 255, 0.06);
}

.model-item.selected {
  background: rgba(59, 130, 246, 0.15);
  border-color: rgba(59, 130, 246, 0.3);
}

.model-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary, #e2e8f0);
  margin-bottom: 4px;
}

.model-stages {
  display: flex;
  gap: 6px;
}

.stage-badge {
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 4px;
}

.stage-badge.production {
  background: rgba(16, 185, 129, 0.15);
  color: #6ee7b7;
}

.stage-badge.staging {
  background: rgba(245, 158, 11, 0.15);
  color: #fcd34d;
}

.model-description {
  font-size: 11px;
  color: var(--text-secondary, #64748b);
  margin-top: 4px;
}

/* =============================================================================
   Versions Panel
   ============================================================================= */

.versions-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.versions-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
}

.versions-header h4 {
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary, #e2e8f0);
}

.version-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.version-number {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary, #e2e8f0);
  margin-right: 8px; /* VPO 005.925: Add spacing between version number and stage */
}

.version-stage {
  font-size: 12px;
  font-weight: 500;
}

.version-details {
  margin-bottom: 8px;
}

.detail-row {
  display: flex;
  gap: 8px;
  font-size: 11px;
  margin-bottom: 4px;
}

.detail-label {
  color: var(--text-secondary, #64748b);
}

.detail-value {
  color: var(--text-primary, #e2e8f0);
}

.detail-value.run-id {
  font-family: monospace;
}

.version-description {
  font-size: 11px;
  color: var(--text-secondary, #64748b);
  margin-bottom: 8px;
}

.version-actions {
  display: flex;
  gap: 8px;
}

.promote-button,
.view-button {
  padding: 4px 10px;
  font-size: 11px;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s;
}

.promote-button {
  background: rgba(16, 185, 129, 0.15);
  border: 1px solid rgba(16, 185, 129, 0.3);
  color: #6ee7b7;
}

.promote-button:hover {
  background: rgba(16, 185, 129, 0.25);
}

.view-button {
  background: rgba(59, 130, 246, 0.15);
  border: 1px solid rgba(59, 130, 246, 0.3);
  color: #93c5fd;
}

.view-button:hover {
  background: rgba(59, 130, 246, 0.25);
}

/* =============================================================================
   Workflow Template Manager Specific
   ============================================================================= */

.template-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
}

.empty-state {
  padding: 32px;
  text-align: center;
  color: var(--text-secondary, #64748b);
}

.template-card {
  padding: 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid transparent;
  border-radius: 8px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: all 0.2s;
}

.template-card:hover {
  background: rgba(255, 255, 255, 0.06);
}

.template-card.selected {
  background: rgba(59, 130, 246, 0.15);
  border-color: rgba(59, 130, 246, 0.3);
}

.template-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 4px;
}

.template-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary, #e2e8f0);
}

.template-category {
  font-size: 10px;
  padding: 2px 6px;
  background: rgba(139, 92, 246, 0.15);
  border-radius: 4px;
  color: #c4b5fd;
}

.template-meta {
  display: flex;
  gap: 8px;
  font-size: 11px;
  color: var(--text-secondary, #64748b);
  margin-bottom: 4px;
}

.template-description {
  font-size: 11px;
  color: var(--text-secondary, #94a3b8);
}

.template-details {
  padding: 16px;
  border-top: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
}

.template-details h4 {
  margin: 0 0 12px 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary, #e2e8f0);
}

.template-parameters h5,
.template-steps h5,
.template-labels h5 {
  margin: 12px 0 8px 0;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary, #94a3b8);
}

.parameter-row {
  padding: 8px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 4px;
  margin-bottom: 4px;
}

.parameter-row label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary, #e2e8f0);
}

.param-description,
.param-default {
  font-size: 10px;
  color: var(--text-secondary, #64748b);
}

.template-steps ul {
  margin: 0;
  padding-left: 20px;
}

.template-steps li {
  font-size: 12px;
  color: var(--text-primary, #e2e8f0);
  margin-bottom: 4px;
}

.labels-list {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.label-badge {
  font-size: 10px;
  padding: 2px 6px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 4px;
  color: var(--text-secondary, #94a3b8);
}

.template-actions {
  margin-top: 12px;
}

.instantiate-button {
  width: 100%;
  padding: 8px 16px;
  background: #3b82f6;
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
}

.instantiate-button:hover {
  background: #2563eb;
}

/* =============================================================================
   Instantiate Dialog
   ============================================================================= */

.instantiate-dialog-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
}

.instantiate-dialog {
  width: 400px;
  max-height: 80vh;
  background: #1e293b;
  border-radius: 12px;
  overflow: hidden;
}

.instantiate-dialog h4 {
  margin: 0;
  padding: 16px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary, #e2e8f0);
  border-bottom: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
}

.parameter-form {
  padding: 16px;
  max-height: 400px;
  overflow-y: auto;
}

.form-field {
  margin-bottom: 12px;
}

.form-field label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary, #e2e8f0);
  margin-bottom: 4px;
}

.field-description {
  display: block;
  font-size: 10px;
  color: var(--text-secondary, #64748b);
  margin-bottom: 4px;
}

.form-field input,
.form-field select {
  width: 100%;
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
  border-radius: 6px;
  color: var(--text-primary, #e2e8f0);
  font-size: 13px;
}

.form-field input:focus,
.form-field select:focus {
  outline: none;
  border-color: #3b82f6;
}

.dialog-actions {
  display: flex;
  gap: 8px;
  padding: 16px;
  border-top: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
}

.confirm-button {
  flex: 1;
  padding: 8px 16px;
  background: #3b82f6;
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
}

.confirm-button:hover {
  background: #2563eb;
}

.cancel-button {
  flex: 1;
  padding: 8px 16px;
  background: transparent;
  border: 1px solid var(--border-color, rgba(255, 255, 255, 0.2));
  border-radius: 6px;
  color: var(--text-secondary, #94a3b8);
  font-size: 13px;
  cursor: pointer;
}

.cancel-button:hover {
  background: rgba(255, 255, 255, 0.05);
}

/* =============================================================================
   Slider Widget for 0-1 Range Parameters
   ============================================================================= */

.slider-field {
  display: flex;
  align-items: center;
  gap: 12px;
}

.slider-input {
  flex: 1;
  height: 6px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.1);
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
}

.slider-input::-webkit-slider-thumb {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #3b82f6;
  cursor: pointer;
  border: 2px solid #1e293b;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
  -webkit-transition: transform 0.15s ease;
  transition: transform 0.15s ease;
}

.slider-input::-webkit-slider-thumb:hover {
  transform: scale(1.1);
}

.slider-input::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #3b82f6;
  cursor: pointer;
  border: 2px solid #1e293b;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.slider-input::-webkit-slider-runnable-track {
  height: 6px;
  border-radius: 3px;
  background: linear-gradient(to right, #3b82f6 0%, #3b82f6 var(--slider-progress, 50%), rgba(255, 255, 255, 0.1) var(--slider-progress, 50%), rgba(255, 255, 255, 0.1) 100%);
}

.slider-input::-moz-range-track {
  height: 6px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.1);
}

.slider-input::-moz-range-progress {
  height: 6px;
  border-radius: 3px;
  background: #3b82f6;
}

.slider-value {
  min-width: 40px;
  font-size: 12px;
  font-family: monospace;
  color: var(--text-primary, #e2e8f0);
  text-align: right;
}

.slider-input:focus {
  outline: none;
}

.slider-input:focus::-webkit-slider-thumb {
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.3);
}


/* =============================================================================
   Add to Canvas Button (VPO 005.935 Task 3)
   ============================================================================= */

.add-to-canvas-button {
  padding: 4px 10px;
  font-size: 11px;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s;
  background: rgba(52, 211, 153, 0.15);
  border: 1px solid rgba(52, 211, 153, 0.3);
  color: #6ee7b7;
  font-weight: 500;
}

.add-to-canvas-button:hover {
  background: rgba(52, 211, 153, 0.25);
  border-color: rgba(52, 211, 153, 0.5);
}

/* Model-level actions container */
.model-item .model-actions {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.model-item .model-actions .add-to-canvas-button {
  width: 100%;
}
/**
 * Data Ingestion Wizard Styles
 * 
 * Styles for the DataIngestionWizard component
 * Uses CSS variables for theme compatibility with Liquid Glass dark mode
 * Issue 33.2: Added glassmorphism/liquid glass styling
 */

/* =============================================================================
   Container - Glassmorphism Design
   ============================================================================= */

.data-ingestion-wizard {
  display: flex;
  flex-direction: column;
  height: 100%;
  max-height: 80vh;  /* Issue 33.3: Limit height to prevent cutoff */
  color: var(--text-primary, #e2e8f0);
  padding: 20px;
  border-radius: 16px;
  position: relative;
  z-index: 99999;  /* Issue 33.2: Much higher than minimap */
  
  /* Glassmorphism background */
  background: rgba(15, 23, 42, 0.85);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  
  /* Animated border glow */
  border: 1px solid rgba(6, 182, 212, 0.4);
  box-shadow: 
    0 25px 50px -12px rgba(0, 0, 0, 0.6),
    0 0 30px rgba(6, 182, 212, 0.15),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
  
  /* Smooth transitions */
  transition: box-shadow 0.3s ease, border-color 0.3s ease;
}

/* Hover state - enhanced glow */
.data-ingestion-wizard:hover {
  border-color: rgba(6, 182, 212, 0.6);
  box-shadow: 
    0 25px 50px -12px rgba(0, 0, 0, 0.7),
    0 0 40px rgba(6, 182, 212, 0.25),
    0 0 80px rgba(6, 182, 212, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

/* Sheen animation overlay */
.data-ingestion-wizard::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.03),
    transparent
  );
  background-size: 200% 100%;
  animation: wizard-sheen 6s linear infinite;
  z-index: 0;
}

@keyframes wizard-sheen {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

/* Tint overlay for depth */
.data-ingestion-wizard::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(
    135deg,
    rgba(52, 84, 148, 0.1) 0%,
    rgba(15, 23, 42, 0.05) 50%,
    transparent 100%
  );
  z-index: 0;
}

/* Ensure content is above pseudo-elements */
.data-ingestion-wizard > * {
  position: relative;
  z-index: 1;
}

/* Issue 33.2: Ensure modal overlay is above EVERYTHING */
.data-ingestion-wizard-overlay {
  z-index: 99998 !important;
  background: rgba(0, 0, 0, 0.8) !important;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

/* =============================================================================
   Header
   ============================================================================= */

.data-ingestion-wizard .wizard-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}

.data-ingestion-wizard .wizard-header h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: #f1f5f9;
}

.data-ingestion-wizard .close-button {
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
  color: #94a3b8;
  font-size: 18px;
  transition: background-color 0.2s;
}

.data-ingestion-wizard .close-button:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #f1f5f9;
}

/* =============================================================================
   Progress Steps
   ============================================================================= */

.data-ingestion-wizard .wizard-progress {
  display: flex;
  justify-content: space-between;
  margin-bottom: 24px;
  padding: 0 16px;
}

.data-ingestion-wizard .progress-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  flex: 1;
  position: relative;
}

.data-ingestion-wizard .progress-step::after {
  content: '';
  position: absolute;
  top: 14px;
  left: 50%;
  width: 100%;
  height: 2px;
  background: rgba(255, 255, 255, 0.1);
}

.data-ingestion-wizard .progress-step:last-child::after {
  display: none;
}

.data-ingestion-wizard .progress-step.completed::after {
  background: #3b82f6;
}

.data-ingestion-wizard .step-number {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 600;
  background: rgba(255, 255, 255, 0.1);
  color: #94a3b8;
  position: relative;
  z-index: 1;
}

.data-ingestion-wizard .progress-step.active .step-number {
  background: #3b82f6;
  color: white;
}

.data-ingestion-wizard .progress-step.completed .step-number {
  background: #10b981;
  color: white;
}

.data-ingestion-wizard .step-label {
  font-size: 11px;
  color: #64748b;
  text-align: center;
}

.data-ingestion-wizard .progress-step.active .step-label {
  color: #93c5fd;
}

.data-ingestion-wizard .progress-step.completed .step-label {
  color: #6ee7b7;
}

/* =============================================================================
   Content Area
   ============================================================================= */

.data-ingestion-wizard .wizard-content {
  flex: 1;
  overflow-y: auto;
  min-height: 200px;  /* Issue 33.3: Ensure minimum content height */
  max-height: calc(80vh - 200px);  /* Issue 33.3: Leave room for header, progress, and navigation */
  padding-right: 8px;  /* Space for scrollbar */
}

/* Issue 33.3: Custom scrollbar styling */
.data-ingestion-wizard .wizard-content::-webkit-scrollbar {
  width: 6px;
}

.data-ingestion-wizard .wizard-content::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.05);
  border-radius: 3px;
}

.data-ingestion-wizard .wizard-content::-webkit-scrollbar-thumb {
  background: rgba(59, 130, 246, 0.4);
  border-radius: 3px;
}

.data-ingestion-wizard .wizard-content::-webkit-scrollbar-thumb:hover {
  background: rgba(59, 130, 246, 0.6);
}

.data-ingestion-wizard .step-content {
  padding: 8px 0;
}

.data-ingestion-wizard .step-content h4 {
  margin: 0 0 16px 0;
  font-size: 14px;
  font-weight: 600;
  color: #f1f5f9;
}

/* =============================================================================
   Source Type Selector
   ============================================================================= */

.data-ingestion-wizard .source-type-selector {
  display: flex;
  gap: 12px;
  margin-bottom: 20px;
}

.data-ingestion-wizard .source-type-button {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s;
  color: #94a3b8;
}

.data-ingestion-wizard .source-type-button:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.2);
}

.data-ingestion-wizard .source-type-button.selected {
  background: rgba(59, 130, 246, 0.15);
  border-color: rgba(59, 130, 246, 0.4);
  color: #93c5fd;
}

.data-ingestion-wizard .source-icon {
  font-size: 24px;
}

.data-ingestion-wizard .source-label {
  font-size: 12px;
  font-weight: 500;
}

/* =============================================================================
   Form Elements
   ============================================================================= */

.data-ingestion-wizard .source-path-input,
.data-ingestion-wizard .form-group {
  margin-bottom: 16px;
}

.data-ingestion-wizard .label-text {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: #e2e8f0;
  margin-bottom: 6px;
}

.data-ingestion-wizard input[type="text"],
.data-ingestion-wizard input[type="file"],
.data-ingestion-wizard select,
.data-ingestion-wizard textarea {
  width: 100%;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  color: #f1f5f9;
  font-size: 13px;
  transition: border-color 0.2s;
}

.data-ingestion-wizard input[type="text"]::-moz-placeholder, .data-ingestion-wizard textarea::-moz-placeholder {
  color: #64748b;
}

.data-ingestion-wizard input[type="text"]::placeholder,
.data-ingestion-wizard textarea::placeholder {
  color: #64748b;
}

.data-ingestion-wizard input[type="text"]:focus,
.data-ingestion-wizard select:focus,
.data-ingestion-wizard textarea:focus {
  outline: none;
  border-color: #3b82f6;
}

.data-ingestion-wizard select option {
  background: #1e293b;
  color: #e2e8f0;
}

/* =============================================================================
   Local Upload Section (Folder/File Toggle)
   ============================================================================= */

.data-ingestion-wizard .local-upload-section {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.data-ingestion-wizard .upload-mode-toggle {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  background: rgba(59, 130, 246, 0.15);
  border: 2px solid rgba(59, 130, 246, 0.4);
  border-radius: 8px;
  margin-bottom: 12px;
}

.data-ingestion-wizard .toggle-label {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: 14px;
  color: #93c5fd;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  font-weight: 600;
}

.data-ingestion-wizard .toggle-label input[type="checkbox"] {
  width: 20px;
  height: 20px;
  accent-color: #3b82f6;
  cursor: pointer;
  border: 2px solid #3b82f6;
}

.data-ingestion-wizard .toggle-label span {
  font-weight: 500;
}

.data-ingestion-wizard .folder-upload-label,
.data-ingestion-wizard .file-upload-label {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.data-ingestion-wizard .folder-input,
.data-ingestion-wizard .file-input {
  padding: 12px;
  background: rgba(255, 255, 255, 0.05);
  border: 2px dashed rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s;
}

.data-ingestion-wizard .folder-input:hover,
.data-ingestion-wizard .file-input:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(59, 130, 246, 0.4);
}

.data-ingestion-wizard .folder-input::file-selector-button,
.data-ingestion-wizard .file-input::file-selector-button {
  padding: 8px 16px;
  margin-right: 12px;
  background: rgba(59, 130, 246, 0.2);
  border: 1px solid rgba(59, 130, 246, 0.3);
  border-radius: 6px;
  color: #93c5fd;
  font-size: 12px;
  cursor: pointer;
  transition: all 0.2s;
}

.data-ingestion-wizard .folder-input::file-selector-button:hover,
.data-ingestion-wizard .file-input::file-selector-button:hover {
  background: rgba(59, 130, 246, 0.3);
}

.data-ingestion-wizard .selected-folder-info {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: rgba(16, 185, 129, 0.1);
  border: 1px solid rgba(16, 185, 129, 0.3);
  border-radius: 8px;
  margin-top: 8px;
}

.data-ingestion-wizard .folder-icon {
  font-size: 20px;
}

.data-ingestion-wizard .folder-details {
  font-size: 13px;
  color: #6ee7b7;
  font-weight: 500;
}

/* =============================================================================
   Destination Preview
   ============================================================================= */

.data-ingestion-wizard .destination-preview {
  padding: 12px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 6px;
  margin-top: 16px;
}

.data-ingestion-wizard .preview-label {
  font-size: 11px;
  color: #64748b;
  display: block;
  margin-bottom: 4px;
}

.data-ingestion-wizard .destination-preview code {
  font-size: 12px;
  color: #93c5fd;
  font-family: monospace;
  word-break: break-all;
}

/* =============================================================================
   Split Configuration
   ============================================================================= */

.data-ingestion-wizard .split-config {
  margin-top: 20px;
}

.data-ingestion-wizard .split-sliders {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 12px;
}

.data-ingestion-wizard .split-slider label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 12px;
  color: #e2e8f0;
}

.data-ingestion-wizard .split-slider input[type="range"] {
  width: 100%;
  height: 6px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 3px;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

.data-ingestion-wizard .split-slider input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  background: #3b82f6;
  border-radius: 50%;
  cursor: pointer;
}

.data-ingestion-wizard .split-total {
  margin-top: 12px;
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 4px;
  font-size: 12px;
  color: #94a3b8;
  text-align: center;
}

/* =============================================================================
   Tags
   ============================================================================= */

.data-ingestion-wizard .tags-input {
  display: flex;
  gap: 8px;
  margin-bottom: 8px;
}

.data-ingestion-wizard .tags-input input {
  flex: 1;
}

.data-ingestion-wizard .tags-input button {
  padding: 8px 16px;
  background: rgba(59, 130, 246, 0.2);
  border: 1px solid rgba(59, 130, 246, 0.3);
  border-radius: 6px;
  color: #93c5fd;
  font-size: 12px;
  cursor: pointer;
  transition: all 0.2s;
}

.data-ingestion-wizard .tags-input button:hover {
  background: rgba(59, 130, 246, 0.3);
}

.data-ingestion-wizard .tags-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.data-ingestion-wizard .tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  background: rgba(139, 92, 246, 0.15);
  border-radius: 4px;
  font-size: 11px;
  color: #c4b5fd;
}

.data-ingestion-wizard .tag button {
  background: transparent;
  border: none;
  color: #c4b5fd;
  cursor: pointer;
  padding: 0;
  font-size: 14px;
  line-height: 1;
}

.data-ingestion-wizard .tag button:hover {
  color: #f1f5f9;
}

/* =============================================================================
   Review Summary
   ============================================================================= */

.data-ingestion-wizard .review-summary {
  margin-top: 20px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.data-ingestion-wizard .review-summary h5 {
  margin: 0 0 12px 0;
  font-size: 13px;
  font-weight: 600;
  color: #f1f5f9;
}

.data-ingestion-wizard .summary-item {
  display: flex;
  gap: 8px;
  margin-bottom: 8px;
  font-size: 12px;
}

.data-ingestion-wizard .summary-label {
  color: #64748b;
  min-width: 80px;
}

.data-ingestion-wizard .summary-value {
  color: #e2e8f0;
  word-break: break-all;
}

/* =============================================================================
   Error Display
   ============================================================================= */

.data-ingestion-wizard .wizard-error {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: 6px;
  margin: 16px 0;
  color: #fca5a5;
  font-size: 13px;
}

.data-ingestion-wizard .error-icon {
  font-size: 16px;
}

/* =============================================================================
   Navigation Buttons
   ============================================================================= */

.data-ingestion-wizard .wizard-navigation {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  flex-shrink: 0;  /* Issue 33.3: Prevent navigation from shrinking */
  position: sticky;  /* Issue 33.3: Keep navigation visible */
  bottom: 0;
  background: rgba(15, 23, 42, 0.98);  /* Match container background */
  padding-bottom: 4px;
}

.data-ingestion-wizard .back-button,
.data-ingestion-wizard .next-button,
.data-ingestion-wizard .submit-button {
  padding: 10px 24px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
}

.data-ingestion-wizard .back-button {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #94a3b8;
}

.data-ingestion-wizard .back-button:hover:not(:disabled) {
  background: rgba(255, 255, 255, 0.05);
  color: #f1f5f9;
}

.data-ingestion-wizard .back-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.data-ingestion-wizard .next-button {
  background: #3b82f6;
  border: none;
  color: white;
}

.data-ingestion-wizard .next-button:hover:not(:disabled) {
  background: #2563eb;
}

.data-ingestion-wizard .submit-button {
  background: #10b981;
  border: none;
  color: white;
}

.data-ingestion-wizard .submit-button:hover:not(:disabled) {
  background: #059669;
}

.data-ingestion-wizard .submit-button:disabled,
.data-ingestion-wizard .next-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
/**
 * VPO Design System - Global Styles
 * 
 * @version 2.0.0
 * @date 2025-12-24
 */

/* Import design tokens */

/**
 * VPO Design System - Design Tokens
 * Comprehensive CSS custom properties for consistent styling
 * 
 * @version 2.0.0
 * @date 2025-12-24
 */

:root {
  /* ============================================
   * COLOR PALETTE - Light Mode (Default)
   * ============================================ */
  
  /* Primary Brand Colors */
  --color-primary-50: #eff6ff;
  --color-primary-100: #dbeafe;
  --color-primary-200: #bfdbfe;
  --color-primary-300: #93c5fd;
  --color-primary-400: #60a5fa;
  --color-primary-500: #3b82f6;
  --color-primary-600: #2563eb;
  --color-primary-700: #1d4ed8;
  --color-primary-800: #1e40af;
  --color-primary-900: #1e3a8a;
  --color-primary-950: #172554;

  /* Neutral Colors */
  --color-neutral-50: #fafafa;
  --color-neutral-100: #f5f5f5;
  --color-neutral-200: #e5e5e5;
  --color-neutral-300: #d4d4d4;
  --color-neutral-400: #a3a3a3;
  --color-neutral-500: #737373;
  --color-neutral-600: #525252;
  --color-neutral-700: #404040;
  --color-neutral-800: #262626;
  --color-neutral-900: #171717;
  --color-neutral-950: #0a0a0a;

  /* Semantic Colors */
  --color-success-50: #f0fdf4;
  --color-success-100: #dcfce7;
  --color-success-500: #22c55e;
  --color-success-600: #16a34a;
  --color-success-700: #15803d;

  --color-warning-50: #fffbeb;
  --color-warning-100: #fef3c7;
  --color-warning-500: #f59e0b;
  --color-warning-600: #d97706;
  --color-warning-700: #b45309;

  --color-error-50: #fef2f2;
  --color-error-100: #fee2e2;
  --color-error-500: #ef4444;
  --color-error-600: #dc2626;
  --color-error-700: #b91c1c;

  --color-info-50: #eff6ff;
  --color-info-100: #dbeafe;
  --color-info-500: #3b82f6;
  --color-info-600: #2563eb;
  --color-info-700: #1d4ed8;

  /* VectorField Brand Colors */
  --color-brand-primary: #3b82f6;
  --color-brand-secondary: #8b5cf6;
  --color-brand-accent: #10b981;

  /* ============================================
   * TYPOGRAPHY
   * ============================================ */
  
  /* Font Families */
  --font-family-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-family-mono: 'JetBrains Mono', 'Fira Code', 'Consolas', monospace;

  /* Font Sizes */
  --font-size-xs: 0.75rem;     /* 12px */
  --font-size-sm: 0.875rem;    /* 14px */
  --font-size-base: 1rem;      /* 16px */
  --font-size-lg: 1.125rem;    /* 18px */
  --font-size-xl: 1.25rem;     /* 20px */
  --font-size-2xl: 1.5rem;     /* 24px */
  --font-size-3xl: 1.875rem;   /* 30px */
  --font-size-4xl: 2.25rem;    /* 36px */

  /* Font Weights */
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;

  /* Line Heights */
  --line-height-tight: 1.25;
  --line-height-snug: 1.375;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.625;
  --line-height-loose: 2;

  /* Letter Spacing */
  --letter-spacing-tighter: -0.05em;
  --letter-spacing-tight: -0.025em;
  --letter-spacing-normal: 0;
  --letter-spacing-wide: 0.025em;
  --letter-spacing-wider: 0.05em;

  /* ============================================
   * SPACING (4px base unit)
   * ============================================ */
  --spacing-0: 0;
  --spacing-px: 1px;
  --spacing-0-5: 0.125rem;   /* 2px */
  --spacing-1: 0.25rem;      /* 4px */
  --spacing-1-5: 0.375rem;   /* 6px */
  --spacing-2: 0.5rem;       /* 8px */
  --spacing-2-5: 0.625rem;   /* 10px */
  --spacing-3: 0.75rem;      /* 12px */
  --spacing-3-5: 0.875rem;   /* 14px */
  --spacing-4: 1rem;         /* 16px */
  --spacing-5: 1.25rem;      /* 20px */
  --spacing-6: 1.5rem;       /* 24px */
  --spacing-7: 1.75rem;      /* 28px */
  --spacing-8: 2rem;         /* 32px */
  --spacing-9: 2.25rem;      /* 36px */
  --spacing-10: 2.5rem;      /* 40px */
  --spacing-11: 2.75rem;     /* 44px */
  --spacing-12: 3rem;        /* 48px */
  --spacing-14: 3.5rem;      /* 56px */
  --spacing-16: 4rem;        /* 64px */
  --spacing-20: 5rem;        /* 80px */
  --spacing-24: 6rem;        /* 96px */

  /* ============================================
   * BORDERS & RADIUS
   * ============================================ */
  --border-width-0: 0;
  --border-width-1: 1px;
  --border-width-2: 2px;
  --border-width-4: 4px;
  --border-width-8: 8px;

  --radius-none: 0;
  --radius-sm: 0.125rem;     /* 2px */
  --radius-default: 0.25rem; /* 4px */
  --radius-md: 0.375rem;     /* 6px */
  --radius-lg: 0.5rem;       /* 8px */
  --radius-xl: 0.75rem;      /* 12px */
  --radius-2xl: 1rem;        /* 16px */
  --radius-3xl: 1.5rem;      /* 24px */
  --radius-full: 9999px;

  /* ============================================
   * SHADOWS
   * ============================================ */
  --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
  --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
  --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / 0.05);
  --shadow-none: 0 0 #0000;

  /* Focus Ring Shadow */
  --shadow-focus: 0 0 0 3px var(--color-primary-500);
  --shadow-focus-error: 0 0 0 3px var(--color-error-500);

  /* ============================================
   * ANIMATIONS & TRANSITIONS
   * ============================================ */
  
  /* Durations */
  --duration-75: 75ms;
  --duration-100: 100ms;
  --duration-150: 150ms;
  --duration-200: 200ms;
  --duration-300: 300ms;
  --duration-500: 500ms;
  --duration-700: 700ms;
  --duration-1000: 1000ms;

  /* Easing Functions */
  --ease-linear: linear;
  --ease-in: cubic-bezier(0.4, 0, 1, 1);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);

  /* ============================================
   * Z-INDEX SCALE
   * ============================================ */
  --z-0: 0;
  --z-10: 10;
  --z-20: 20;
  --z-30: 30;
  --z-40: 40;
  --z-50: 50;
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-fixed: 300;
  --z-modal-backdrop: 400;
  --z-modal: 500;
  --z-popover: 600;
  --z-tooltip: 700;
  --z-toast: 800;

  /* ============================================
   * COMPONENT-SPECIFIC TOKENS
   * ============================================ */
  
  /* Buttons */
  --btn-height-sm: 2rem;       /* 32px */
  --btn-height-md: 2.5rem;     /* 40px */
  --btn-height-lg: 3rem;       /* 48px */
  --btn-padding-x-sm: 0.75rem;
  --btn-padding-x-md: 1rem;
  --btn-padding-x-lg: 1.5rem;

  /* Inputs */
  --input-height-sm: 2rem;
  --input-height-md: 2.5rem;
  --input-height-lg: 3rem;
  --input-padding-x: 0.75rem;

  /* Cards */
  --card-padding: 1.5rem;
  --card-radius: var(--radius-lg);

  /* Modals */
  --modal-width-sm: 24rem;     /* 384px */
  --modal-width-md: 28rem;     /* 448px */
  --modal-width-lg: 32rem;     /* 512px */
  --modal-width-xl: 36rem;     /* 576px */

  /* Canvas */
  --canvas-grid-size: 20px;
  --canvas-grid-color: var(--color-neutral-200);

  /* Nodes */
  --node-min-width: 200px;
  --node-border-radius: var(--radius-lg);
  --node-shadow: var(--shadow-md);
  --node-shadow-hover: var(--shadow-lg);
  --node-shadow-selected: var(--shadow-xl);

  /* ============================================
   * GLASSMORPHISM TOKENS - Light Mode Defaults
   * ============================================ */
  
  /* Glass Blur Effects */
  --glass-blur: 8px;
  --glass-blur-sm: 6px;
  --glass-blur-lg: 12px;
  
  /* Glass Background Opacity - Light mode uses LOW opacity (more transparent) */
  --glass-bg-opacity: 0.15;
  --glass-bg-opacity-elevated: 0.25;
  --glass-bg-opacity-critical: 0.85;
  
  /* Glass Border */
  --glass-border-opacity: 0.3;
  --glass-border-color: rgba(255, 255, 255, var(--glass-border-opacity));
  
  /* Glass Shadows */
  --glass-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
  --glass-shadow-sm: 0 4px 16px rgba(0, 0, 0, 0.08);
  --glass-shadow-lg: 0 16px 48px rgba(0, 0, 0, 0.15);
  
  /* Inner Light Effect (top edge highlight) */
  --glass-inner-light: inset 0 1px 0 rgba(255, 255, 255, 0.1);
  
  /* Glass Glow Effects (using existing brand colors) */
  --glass-glow-primary: 0 0 40px rgba(59, 130, 246, 0.3);
  --glass-glow-secondary: 0 0 40px rgba(139, 92, 246, 0.3);
  --glass-glow-accent: 0 0 40px rgba(16, 185, 129, 0.3);
  --glass-glow-cyan: 0 0 40px rgba(0, 240, 255, 0.3);
  --glass-glow-violet: 0 0 40px rgba(139, 92, 246, 0.3);
  --glass-glow-pink: 0 0 40px rgba(236, 72, 153, 0.3);
  
  /* Node-specific Glass Glows (preserving existing node colors) */
  --glass-glow-vpc: 0 0 30px rgba(16, 185, 129, 0.4);
  --glass-glow-s3: 0 0 30px rgba(249, 115, 22, 0.4);
  --glass-glow-rds: 0 0 30px rgba(59, 130, 246, 0.4);
  --glass-glow-eks: 0 0 30px rgba(255, 153, 0, 0.4);
  --glass-glow-redis: 0 0 30px rgba(239, 68, 68, 0.4);
  --glass-glow-lambda: 0 0 30px rgba(255, 153, 0, 0.4);
  --glass-glow-ec2: 0 0 30px rgba(255, 153, 0, 0.4);
  --glass-glow-cloudfront: 0 0 30px rgba(139, 92, 246, 0.4);
  --glass-glow-dynamodb: 0 0 30px rgba(59, 130, 246, 0.4);
  --glass-glow-sqs: 0 0 30px rgba(236, 72, 153, 0.4);
  --glass-glow-sns: 0 0 30px rgba(236, 72, 153, 0.4);
  
  /* Canvas Gradient (Light Mode - soft pastels) */
  --canvas-gradient-start: #f0f4ff;
  --canvas-gradient-mid: #e8f0fe;
  --canvas-gradient-end: #f5f0ff;
  
  /* Glass Radius */
  --glass-radius: var(--radius-xl);
  --glass-radius-sm: var(--radius-lg);
  --glass-radius-lg: var(--radius-2xl);
  
  /* Glass Text Colors (Light Mode) */
  --glass-text-primary: rgba(0, 0, 0, 0.8);
  --glass-text-secondary: rgba(0, 0, 0, 0.6);
}

/* ============================================
 * DARK MODE OVERRIDES
 * ============================================ */

[data-theme="dark"] {
  /* Background Colors */
  --color-neutral-50: #0a0a0a;
  --color-neutral-100: #171717;
  --color-neutral-200: #262626;
  --color-neutral-300: #404040;
  --color-neutral-400: #525252;
  --color-neutral-500: #737373;
  --color-neutral-600: #a3a3a3;
  --color-neutral-700: #d4d4d4;
  --color-neutral-800: #e5e5e5;
  --color-neutral-900: #f5f5f5;
  --color-neutral-950: #fafafa;

  /* Adjusted Shadows for Dark Mode */
  --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.3);
  --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.4), 0 1px 2px -1px rgb(0 0 0 / 0.4);
  --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.4), 0 2px 4px -2px rgb(0 0 0 / 0.4);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.4), 0 4px 6px -4px rgb(0 0 0 / 0.4);
  --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.4), 0 8px 10px -6px rgb(0 0 0 / 0.4);
  --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.5);

  /* Canvas */
  --canvas-grid-color: var(--color-neutral-300);

  /* ============================================
   * GLASSMORPHISM TOKENS - Dark Mode Overrides
   * ============================================ */
  
  /* Glass Blur Effects (same as light mode - 8px across the board) */
  --glass-blur: 8px;
  --glass-blur-sm: 6px;
  --glass-blur-lg: 12px;
  
  /* Glass Background Opacity (higher for dark mode) */
  --glass-bg-opacity: 0.7;
  --glass-bg-opacity-elevated: 0.8;
  --glass-bg-opacity-critical: 0.9;
  
  /* Glass Border (subtle white for dark mode) */
  --glass-border-opacity: 0.12;
  --glass-border-color: rgba(255, 255, 255, var(--glass-border-opacity));
  
  /* Glass Shadows (stronger for dark mode) */
  --glass-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
  --glass-shadow-sm: 0 4px 16px rgba(0, 0, 0, 0.3);
  --glass-shadow-lg: 0 16px 48px rgba(0, 0, 0, 0.5);
  
  /* Inner Light Effect (subtler for dark mode) */
  --glass-inner-light: inset 0 1px 0 rgba(255, 255, 255, 0.05);
  
  /* Glass Glow Effects (more prominent for dark mode) */
  --glass-glow-primary: 0 0 50px rgba(59, 130, 246, 0.4);
  --glass-glow-secondary: 0 0 50px rgba(139, 92, 246, 0.4);
  --glass-glow-accent: 0 0 50px rgba(16, 185, 129, 0.4);
  --glass-glow-cyan: 0 0 50px rgba(0, 240, 255, 0.4);
  --glass-glow-violet: 0 0 50px rgba(139, 92, 246, 0.4);
  --glass-glow-pink: 0 0 50px rgba(236, 72, 153, 0.4);
  
  /* Node-specific Glass Glows (more prominent for dark mode) */
  --glass-glow-vpc: 0 0 40px rgba(16, 185, 129, 0.5);
  --glass-glow-s3: 0 0 40px rgba(249, 115, 22, 0.5);
  --glass-glow-rds: 0 0 40px rgba(59, 130, 246, 0.5);
  --glass-glow-eks: 0 0 40px rgba(255, 153, 0, 0.5);
  --glass-glow-redis: 0 0 40px rgba(239, 68, 68, 0.5);
  --glass-glow-lambda: 0 0 40px rgba(255, 153, 0, 0.5);
  --glass-glow-ec2: 0 0 40px rgba(255, 153, 0, 0.5);
  --glass-glow-cloudfront: 0 0 40px rgba(139, 92, 246, 0.5);
  --glass-glow-dynamodb: 0 0 40px rgba(59, 130, 246, 0.5);
  --glass-glow-sqs: 0 0 40px rgba(236, 72, 153, 0.5);
  --glass-glow-sns: 0 0 40px rgba(236, 72, 153, 0.5);
  
  /* Canvas Gradient (Dark Mode - deep blue/purple tones) */
  --canvas-gradient-start: #0f172a;
  --canvas-gradient-mid: #1e1b4b;
  --canvas-gradient-end: #0f172a;
  
  /* Glass Text Colors (Dark Mode - high contrast) */
  --glass-text-primary: rgba(255, 255, 255, 0.9);
  --glass-text-secondary: rgba(255, 255, 255, 0.7);
}

/* ============================================
 * REDUCED MOTION
 * ============================================ */

@media (prefers-reduced-motion: reduce) {
  :root {
    --duration-75: 0ms;
    --duration-100: 0ms;
    --duration-150: 0ms;
    --duration-200: 0ms;
    --duration-300: 0ms;
    --duration-500: 0ms;
    --duration-700: 0ms;
    --duration-1000: 0ms;
  }
}

/* ============================================
 * GLASSMORPHISM FALLBACK SUPPORT
 * For browsers that don't support backdrop-filter
 * ============================================ */

/* Base glass class - fallback (solid semi-transparent background) */

.glass {
  background: rgba(15, 23, 42, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--glass-radius);
  box-shadow: var(--glass-shadow), var(--glass-inner-light);
}

/* Light mode fallback */

[data-theme="light"] .glass,
:root:not([data-theme="dark"]) .glass {
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(0, 0, 0, 0.1);
}

/* Enhanced glass with backdrop-filter support */

@supports (backdrop-filter: blur(10px)) {
  .glass {
    background: rgba(15, 23, 42, var(--glass-bg-opacity));
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
  }
  
  [data-theme="light"] .glass,
  :root:not([data-theme="dark"]) .glass {
    background: rgba(255, 255, 255, var(--glass-bg-opacity));
  }
}

/* Glass variants */

.glass-elevated {
  background: rgba(15, 23, 42, 0.98);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--glass-radius);
  box-shadow: var(--glass-shadow-lg), var(--glass-inner-light);
}

@supports (backdrop-filter: blur(10px)) {
  .glass-elevated {
    background: rgba(15, 23, 42, var(--glass-bg-opacity-elevated));
    backdrop-filter: blur(var(--glass-blur-lg));
    -webkit-backdrop-filter: blur(var(--glass-blur-lg));
  }
}

/* Glass with glow effect */

.glass-glow {
  box-shadow: var(--glass-shadow), var(--glass-glow-primary), var(--glass-inner-light);
}

.glass-glow-cyan {
  box-shadow: var(--glass-shadow), var(--glass-glow-cyan), var(--glass-inner-light);
}

.glass-glow-violet {
  box-shadow: var(--glass-shadow), var(--glass-glow-violet), var(--glass-inner-light);
}

.glass-glow-pink {
  box-shadow: var(--glass-shadow), var(--glass-glow-pink), var(--glass-inner-light);
}

/* Node-specific glass glows */

.glass-glow-vpc {
  box-shadow: var(--glass-shadow), var(--glass-glow-vpc), var(--glass-inner-light);
}

.glass-glow-s3 {
  box-shadow: var(--glass-shadow), var(--glass-glow-s3), var(--glass-inner-light);
}

.glass-glow-rds {
  box-shadow: var(--glass-shadow), var(--glass-glow-rds), var(--glass-inner-light);
}

.glass-glow-eks {
  box-shadow: var(--glass-shadow), var(--glass-glow-eks), var(--glass-inner-light);
}

.glass-glow-redis {
  box-shadow: var(--glass-shadow), var(--glass-glow-redis), var(--glass-inner-light);
}

.glass-glow-lambda {
  box-shadow: var(--glass-shadow), var(--glass-glow-lambda), var(--glass-inner-light);
}

/* Inner light effect utility */

.glass-inner-light {
  box-shadow: var(--glass-inner-light);
}

/* GPU acceleration for glass elements */

.glass,
.glass-elevated,
[class*="glass-glow"] {
  transform: translate3d(0, 0, 0);
  will-change: backdrop-filter, transform;
}

/* ============================================
 * TURBO EDGE ANIMATIONS
 * ============================================ */

/* Flow animation for TurboEdge */

@keyframes turboEdgeFlow {
  from {
    stroke-dashoffset: 20;
  }
  to {
    stroke-dashoffset: 0;
  }
}

/* Respect reduced motion preference */

@media (prefers-reduced-motion: reduce) {
  @keyframes turboEdgeFlow {
    from {
      stroke-dashoffset: 0;
    }
    to {
      stroke-dashoffset: 0;
    }
  }
}

/* ============================================
 * LIQUID GLASS TOKENS (VPO 005.75)
 * Advanced glassmorphism with optical composition
 * ============================================ */

:root {
  /* Liquid Glass Layer Effects */
  --liquid-glass-blur: 16px;
  --liquid-glass-saturation: 180%;
  --liquid-glass-displacement-scale: 3;
  
  /* Tint Overlay Gradients */
  --liquid-glass-tint-start: rgba(255, 255, 255, 0.05);
  --liquid-glass-tint-end: rgba(255, 255, 255, 0.01);
  --liquid-glass-tint-angle: 145deg;
  
  /* Specular Rim Effects */
  --liquid-glass-rim-highlight: rgba(255, 255, 255, 0.1);
  --liquid-glass-rim-shadow: rgba(0, 0, 0, 0.36);
  --liquid-glass-rim-width: 1px;
  
  /* Selection Glow */
  --liquid-glass-selection-glow-size: 20px;
  --liquid-glass-selection-glow-opacity: 0.6;
  
  /* ============================================
   * LOD (Level of Detail) Thresholds
   * ============================================ */
  --lod-threshold-dot: 0.5;
  --lod-threshold-icon: 1.0;
  --lod-threshold-summary: 2.0;
  --lod-transition-duration: 200ms;
  
  /* ============================================
   * Heartbeat Animation Tokens
   * ============================================ */
  --heartbeat-duration-healthy: 2s;
  --heartbeat-duration-pending: 1s;
  --heartbeat-duration-error: 0.3s;
  --heartbeat-scale-min: 0.98;
  --heartbeat-scale-max: 1.02;
  --heartbeat-glow-min: 0.3;
  --heartbeat-glow-max: 0.6;
  
  /* Status Colors for Heartbeat */
  --heartbeat-color-healthy: var(--color-success-500);
  --heartbeat-color-pending: var(--color-warning-500);
  --heartbeat-color-error: var(--color-error-500);
  --heartbeat-color-unknown: var(--color-neutral-500);
  
  /* ============================================
   * Sonar Trace Tokens
   * ============================================ */
  --sonar-dim-opacity: 0.3;
  --sonar-dim-grayscale: 100%;
  --sonar-highlight-z-boost: 100;
  --sonar-transition-duration: 200ms;
  --sonar-transition-easing: var(--ease-out);
  
  /* ============================================
   * Sparkline Tokens
   * ============================================ */
  --sparkline-stroke-width: 2px;
  --sparkline-color-low: #3b82f6;
  --sparkline-color-high: #ef4444;
  --sparkline-height: 32px;
  --sparkline-max-points: 15;
  
  /* ============================================
   * Bento Grid Tokens
   * ============================================ */
  --bento-gap: var(--spacing-2);
  --bento-cell-min: 40px;
  --bento-hero-span: 2;
  --bento-padding: var(--spacing-3);
  
  /* ============================================
   * Performance Tokens
   * ============================================ */
  --glass-debounce-delay: 150ms;
  --glass-interaction-blur: 0px;
  --glass-restore-delay: 150ms;
  
  /* ============================================
   * Particle Animation Tokens
   * ============================================ */
  --particle-size: 4px;
  --particle-base-duration: 2s;
  --particle-color: var(--color-primary-400);
  --particle-glow: 0 0 6px var(--color-primary-400);
  
  /* ============================================
   * Geometric Shape Tokens
   * ============================================ */
  --shape-indicator-size: 24px;
  --shape-indicator-stroke: 2px;
  --shape-indicator-opacity: 0.8;
  
  /* ============================================
   * Container Node Z-Index
   * ============================================ */
  --z-container-base: 1;
  --z-container-child: 10;
  --z-edge-default: 5;
  --z-node-active: 50;
  --z-node-selected: 60;
}

/* Dark Mode Liquid Glass Overrides */

[data-theme="dark"] {
  /* Tint Overlay (subtler for dark mode) */
  --liquid-glass-tint-start: rgba(255, 255, 255, 0.03);
  --liquid-glass-tint-end: rgba(255, 255, 255, 0.005);
  
  /* Specular Rim (subtler highlight) */
  --liquid-glass-rim-highlight: rgba(255, 255, 255, 0.08);
  --liquid-glass-rim-shadow: rgba(0, 0, 0, 0.5);
  
  /* Enhanced glow visibility */
  --liquid-glass-selection-glow-opacity: 0.7;
  
  /* Chromatic Grey Background (no pure black) */
  --chromatic-grey-bg: #0F1115;
  --chromatic-grey-surface: rgba(22, 27, 34, 0.7);
  --chromatic-grey-elevated: rgba(30, 35, 44, 0.8);
}

/* ============================================
 * LIQUID GLASS KEYFRAME ANIMATIONS
 * ============================================ */

/* Heartbeat - Healthy (slow breathing) */

@keyframes heartbeatHealthy {
  0%, 100% {
    transform: scale(var(--heartbeat-scale-min));
    box-shadow: 0 0 10px rgba(34, 197, 94, var(--heartbeat-glow-min));
  }
  50% {
    transform: scale(var(--heartbeat-scale-max));
    box-shadow: 0 0 20px rgba(34, 197, 94, var(--heartbeat-glow-max));
  }
}

/* Heartbeat - Pending (shimmer/rotate) */

@keyframes heartbeatPending {
  0% {
    border-color: transparent;
    border-top-color: var(--heartbeat-color-pending);
    transform: rotate(0deg);
  }
  100% {
    border-color: transparent;
    border-top-color: var(--heartbeat-color-pending);
    transform: rotate(360deg);
  }
}

/* Heartbeat - Error (rapid pulse with shake) */

@keyframes heartbeatError {
  0%, 100% {
    transform: scale(1) translateX(0);
    box-shadow: 0 0 15px rgba(239, 68, 68, 0.5);
  }
  25% {
    transform: scale(1.05) translateX(-2px);
    box-shadow: 0 0 25px rgba(239, 68, 68, 0.8);
  }
  75% {
    transform: scale(1.05) translateX(2px);
    box-shadow: 0 0 25px rgba(239, 68, 68, 0.8);
  }
}

/* Shimmer effect for pending state */

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

/* Particle flow along edge */

@keyframes particleFlow {
  0% {
    offset-distance: 0%;
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  90% {
    opacity: 1;
  }
  100% {
    offset-distance: 100%;
    opacity: 0;
  }
}

/* LOD transition fade */

@keyframes lodFadeIn {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* Sonar pulse for highlighted nodes */

@keyframes sonarPulse {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(59, 130, 246, 0.4);
  }
  50% {
    box-shadow: 0 0 0 8px rgba(59, 130, 246, 0);
  }
}

/* Reduced motion overrides for Liquid Glass animations */

@media (prefers-reduced-motion: reduce) {
  @keyframes heartbeatHealthy {
    0%, 100% {
      transform: scale(1);
      box-shadow: 0 0 15px rgba(34, 197, 94, 0.4);
    }
  }
  
  @keyframes heartbeatPending {
    0%, 100% {
      transform: rotate(0deg);
      border-color: var(--heartbeat-color-pending);
    }
  }
  
  @keyframes heartbeatError {
    0%, 100% {
      transform: scale(1) translateX(0);
      box-shadow: 0 0 20px rgba(239, 68, 68, 0.6);
    }
  }
  
  @keyframes shimmer {
    0%, 100% {
      background-position: 0 0;
    }
  }
  
  @keyframes particleFlow {
    0%, 100% {
      offset-distance: 50%;
      opacity: 0.5;
    }
  }
  
  @keyframes lodFadeIn {
    from, to {
      opacity: 1;
      transform: scale(1);
    }
  }
  
  @keyframes sonarPulse {
    0%, 100% {
      box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.2);
    }
  }
}

/* ============================================
 * LIQUID GLASS UTILITY CLASSES
 * ============================================ */

/* Base Liquid Glass container */

.liquid-glass {
  position: relative;
  border-radius: var(--glass-radius);
  overflow: hidden;
  contain: strict;
}

/* Filter Plane layer */

.liquid-glass-filter {
  position: absolute;
  inset: 0;
  z-index: 0;
  backdrop-filter: blur(var(--liquid-glass-blur)) saturate(var(--liquid-glass-saturation));
  -webkit-backdrop-filter: blur(var(--liquid-glass-blur)) saturate(var(--liquid-glass-saturation));
}

/* Tint Overlay layer */

.liquid-glass-tint {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    var(--liquid-glass-tint-angle),
    var(--liquid-glass-tint-start),
    var(--liquid-glass-tint-end)
  );
  pointer-events: none;
}

/* Specular Rim layer */

.liquid-glass-rim {
  position: absolute;
  inset: 0;
  z-index: 2;
  border-radius: inherit;
  box-shadow: 
    inset 0 1px 0 var(--liquid-glass-rim-highlight),
    inset 0 -1px 0 var(--liquid-glass-rim-shadow);
  border: var(--liquid-glass-rim-width) solid rgba(255, 255, 255, 0.1);
  pointer-events: none;
}

/* Content Plane layer */

.liquid-glass-content {
  position: relative;
  z-index: 4;
}

/* Heartbeat indicator states */

.heartbeat-healthy {
  animation: heartbeatHealthy var(--heartbeat-duration-healthy) ease-in-out infinite;
}

.heartbeat-pending {
  animation: heartbeatPending var(--heartbeat-duration-pending) linear infinite;
}

.heartbeat-error {
  animation: heartbeatError var(--heartbeat-duration-error) ease-in-out infinite;
}

/* Sonar trace states */

.sonar-dimmed {
  opacity: var(--sonar-dim-opacity);
  filter: grayscale(var(--sonar-dim-grayscale));
  transition: opacity var(--sonar-transition-duration) var(--sonar-transition-easing),
              filter var(--sonar-transition-duration) var(--sonar-transition-easing);
}

.sonar-highlighted {
  opacity: 1;
  filter: none;
  z-index: calc(var(--z-node-active) + var(--sonar-highlight-z-boost));
  animation: sonarPulse 1.5s ease-in-out infinite;
  transition: opacity var(--sonar-transition-duration) var(--sonar-transition-easing),
              filter var(--sonar-transition-duration) var(--sonar-transition-easing);
}

/* LOD transition */

.lod-transition {
  animation: lodFadeIn var(--lod-transition-duration) var(--ease-out);
}

/* Performance: disable blur during interaction */

.glass-interaction-active .liquid-glass-filter {
  backdrop-filter: blur(var(--glass-interaction-blur));
  -webkit-backdrop-filter: blur(var(--glass-interaction-blur));
}

/* Fallback for browsers without backdrop-filter */

@supports not (backdrop-filter: blur(10px)) {
  .liquid-glass-filter {
    background: rgba(15, 23, 42, 0.9);
  }
  
  [data-theme="light"] .liquid-glass-filter,
  :root:not([data-theme="dark"]) .liquid-glass-filter {
    background: rgba(255, 255, 255, 0.9);
  }
}

/* Tailwind directives */

*, ::before, ::after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

/*! tailwindcss v3.4.18 | MIT License | https://tailwindcss.com
 */

/*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}

::before,
::after {
  --tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/

html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, sans-serif; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/*
Remove the default font size and weight for headings.
*/

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

a {
  color: inherit;
  text-decoration: inherit;
}

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
  font-weight: bolder;
}

/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
  font-family: JetBrains Mono, Fira Code, Consolas, monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}

/*
Add the correct font size in all browsers.
*/

small {
  font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
  text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
  outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

:-moz-ui-invalid {
  box-shadow: none;
}

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
  vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

::-webkit-search-decoration {
  -webkit-appearance: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
  display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
}

legend {
  padding: 0;
}

ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

/*
Reset default styling for dialogs.
*/

dialog {
  padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
  resize: vertical;
}

/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
  cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/

:disabled {
  cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

img,
video {
  max-width: 100%;
  height: auto;
}

/* Make elements with the HTML hidden attribute stay hidden by default */

[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}

/* Root element */

:root {
    font-family: var(--font-family-sans);
    line-height: var(--line-height-normal);
    font-weight: var(--font-weight-normal);
    font-synthesis: none;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: 100%;
  }

/* HTML & Body */

html {
    color-scheme: light dark;
    scroll-behavior: smooth;
  }

body {
    margin: 0;
    min-width: 320px;
    min-height: 100vh;
    background-color: transparent;
    color: var(--color-neutral-900);
  }

[data-theme="dark"] body {
    background-color: transparent;
    color: var(--color-neutral-100);
  }

#root {
    width: 100%;
    height: 100vh;
    isolation: isolate;
    background-color: transparent;
  }

/* Box sizing */

*,
  *::before,
  *::after {
    box-sizing: border-box;
  }

/* Typography defaults */

h1, h2, h3, h4, h5, h6 {
    font-weight: var(--font-weight-semibold);
    line-height: var(--line-height-tight);
    color: inherit;
  }

h1 { font-size: var(--font-size-4xl); }

h2 { font-size: var(--font-size-3xl); }

h3 { font-size: var(--font-size-2xl); }

h4 { font-size: var(--font-size-xl); }

h5 { font-size: var(--font-size-lg); }

h6 { font-size: var(--font-size-base); }

p {
    line-height: var(--line-height-relaxed);
  }

/* Code elements */

code, kbd, samp, pre {
    font-family: var(--font-family-mono);
    font-size: 0.875em;
  }

pre {
    overflow-x: auto;
    padding: var(--spacing-4);
    border-radius: var(--radius-lg);
    background-color: var(--color-neutral-100);
  }

[data-theme="dark"] pre {
    background-color: var(--color-neutral-200);
  }

code {
    padding: var(--spacing-0-5) var(--spacing-1);
    border-radius: var(--radius-sm);
    background-color: var(--color-neutral-100);
  }

[data-theme="dark"] code {
    background-color: var(--color-neutral-200);
  }

/* Links */

a {
    color: var(--color-primary-600);
    text-decoration: none;
    transition: color var(--duration-150) var(--ease-in-out);
  }

a:hover {
    color: var(--color-primary-700);
    text-decoration: underline;
  }

[data-theme="dark"] a {
    color: var(--color-primary-400);
  }

[data-theme="dark"] a:hover {
    color: var(--color-primary-300);
  }

/* Images */

img, svg {
    display: block;
    max-width: 100%;
    height: auto;
  }

/* Tables */

table {
    border-collapse: collapse;
    width: 100%;
  }

th, td {
    padding: var(--spacing-2) var(--spacing-3);
    text-align: left;
    border-bottom: 1px solid var(--color-neutral-200);
  }

[data-theme="dark"] th,
  [data-theme="dark"] td {
    border-color: var(--color-neutral-300);
  }

/* Selection */

::-moz-selection {
    background-color: var(--color-primary-200);
    color: var(--color-primary-900);
  }

::selection {
    background-color: var(--color-primary-200);
    color: var(--color-primary-900);
  }

[data-theme="dark"] ::-moz-selection {
    background-color: var(--color-primary-800);
    color: var(--color-primary-100);
  }

[data-theme="dark"] ::selection {
    background-color: var(--color-primary-800);
    color: var(--color-primary-100);
  }

/* Scrollbar styling */

::-webkit-scrollbar {
    width: 8px;
    height: 8px;
  }

::-webkit-scrollbar-track {
    background: var(--color-neutral-100);
    border-radius: var(--radius-full);
  }

::-webkit-scrollbar-thumb {
    background: var(--color-neutral-400);
    border-radius: var(--radius-full);
  }

::-webkit-scrollbar-thumb:hover {
    background: var(--color-neutral-500);
  }

[data-theme="dark"] ::-webkit-scrollbar-track {
    background: var(--color-neutral-200);
  }

[data-theme="dark"] ::-webkit-scrollbar-thumb {
    background: var(--color-neutral-400);
  }

[data-theme="dark"] ::-webkit-scrollbar-thumb:hover {
    background: var(--color-neutral-500);
  }

.\!container {
  width: 100% !important;
}

.container {
  width: 100%;
}

@media (min-width: 640px) {

  .\!container {
    max-width: 640px !important;
  }

  .container {
    max-width: 640px;
  }
}

@media (min-width: 768px) {

  .\!container {
    max-width: 768px !important;
  }

  .container {
    max-width: 768px;
  }
}

@media (min-width: 1024px) {

  .\!container {
    max-width: 1024px !important;
  }

  .container {
    max-width: 1024px;
  }
}

@media (min-width: 1280px) {

  .\!container {
    max-width: 1280px !important;
  }

  .container {
    max-width: 1280px;
  }
}

@media (min-width: 1536px) {

  .\!container {
    max-width: 1536px !important;
  }

  .container {
    max-width: 1536px;
  }
}

/* ============================================
   * ICON SIZE STANDARDS
   * Standard: 16px (w-4 h-4) for all folder/path icons in config fields
   * Use .icon-folder for consistent folder icon sizing across config panels
   * ============================================ */

/* Focus indicators for accessibility */

/* Button base styles */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border-radius: 0.5rem;
  font-weight: 500;
  transition-property: all;
  transition-duration: 150ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.btn:focus {
  outline: 2px solid transparent;
  outline-offset: 2px;
}

.btn:focus-visible {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1));
  --tw-ring-offset-width: 2px;
}

.btn:disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

.btn-primary {
  --tw-bg-opacity: 1;
  background-color: rgb(37 99 235 / var(--tw-bg-opacity, 1));
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.btn-primary:hover {
  --tw-translate-y: -0.125rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  --tw-bg-opacity: 1;
  background-color: rgb(29 78 216 / var(--tw-bg-opacity, 1));
  --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.btn-primary:active {
  --tw-translate-y: 0px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.btn-secondary {
  --tw-bg-opacity: 1;
  background-color: rgb(229 229 229 / var(--tw-bg-opacity, 1));
  --tw-text-opacity: 1;
  color: rgb(23 23 23 / var(--tw-text-opacity, 1));
}

.btn-secondary:hover {
  --tw-translate-y: -0.125rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  --tw-bg-opacity: 1;
  background-color: rgb(212 212 212 / var(--tw-bg-opacity, 1));
}

.btn-secondary:active {
  --tw-translate-y: 0px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

[data-theme="dark"] .btn-secondary {
  --tw-bg-opacity: 1;
  background-color: rgb(64 64 64 / var(--tw-bg-opacity, 1));
  --tw-text-opacity: 1;
  color: rgb(245 245 245 / var(--tw-text-opacity, 1));
}

[data-theme="dark"] .btn-secondary:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(82 82 82 / var(--tw-bg-opacity, 1));
}

/* Input base styles */

.\!input {
  height: 2.5rem;
  width: 100%;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

.input {
  height: 2.5rem;
  width: 100%;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

.\!input {
  border-radius: 0.5rem;
  border-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(212 212 212 / var(--tw-border-opacity, 1));
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}

.input {
  border-radius: 0.5rem;
  border-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(212 212 212 / var(--tw-border-opacity, 1));
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}

.\!input {
  --tw-text-opacity: 1;
  color: rgb(23 23 23 / var(--tw-text-opacity, 1));
}

.\!input::-moz-placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(163 163 163 / var(--tw-placeholder-opacity, 1));
}

.\!input::placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(163 163 163 / var(--tw-placeholder-opacity, 1));
}

.input {
  --tw-text-opacity: 1;
  color: rgb(23 23 23 / var(--tw-text-opacity, 1));
}

.input::-moz-placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(163 163 163 / var(--tw-placeholder-opacity, 1));
}

.input::placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(163 163 163 / var(--tw-placeholder-opacity, 1));
}

.\!input {
  transition-property: all;
  transition-duration: 150ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.input {
  transition-property: all;
  transition-duration: 150ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.\!input:focus {
  border-color: transparent;
  outline: 2px solid transparent;
  outline-offset: 2px;
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1));
}

.input:focus {
  border-color: transparent;
  outline: 2px solid transparent;
  outline-offset: 2px;
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1));
}

.\!input:disabled {
  cursor: not-allowed;
  --tw-bg-opacity: 1;
  background-color: rgb(245 245 245 / var(--tw-bg-opacity, 1));
}

.input:disabled {
  cursor: not-allowed;
  --tw-bg-opacity: 1;
  background-color: rgb(245 245 245 / var(--tw-bg-opacity, 1));
}

[data-theme="dark"] .\!input {
  --tw-border-opacity: 1;
  border-color: rgb(82 82 82 / var(--tw-border-opacity, 1));
  --tw-bg-opacity: 1;
  background-color: rgb(38 38 38 / var(--tw-bg-opacity, 1));
}

[data-theme="dark"] .input {
  --tw-border-opacity: 1;
  border-color: rgb(82 82 82 / var(--tw-border-opacity, 1));
  --tw-bg-opacity: 1;
  background-color: rgb(38 38 38 / var(--tw-bg-opacity, 1));
}

[data-theme="dark"] .\!input {
  --tw-text-opacity: 1;
  color: rgb(245 245 245 / var(--tw-text-opacity, 1));
}

[data-theme="dark"] .\!input::-moz-placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(115 115 115 / var(--tw-placeholder-opacity, 1));
}

[data-theme="dark"] .\!input::placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(115 115 115 / var(--tw-placeholder-opacity, 1));
}

[data-theme="dark"] .input {
  --tw-text-opacity: 1;
  color: rgb(245 245 245 / var(--tw-text-opacity, 1));
}

[data-theme="dark"] .input::-moz-placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(115 115 115 / var(--tw-placeholder-opacity, 1));
}

[data-theme="dark"] .input::placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(115 115 115 / var(--tw-placeholder-opacity, 1));
}

[data-theme="dark"] .\!input:disabled {
  --tw-bg-opacity: 1;
  background-color: rgb(23 23 23 / var(--tw-bg-opacity, 1));
}

[data-theme="dark"] .input:disabled {
  --tw-bg-opacity: 1;
  background-color: rgb(23 23 23 / var(--tw-bg-opacity, 1));
}

/* Card styles */

.card {
  border-radius: 0.5rem;
  border-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(229 229 229 / var(--tw-border-opacity, 1));
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
  --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  transition-property: box-shadow;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 200ms;
}

[data-theme="dark"] .card {
  --tw-border-opacity: 1;
  border-color: rgb(64 64 64 / var(--tw-border-opacity, 1));
  --tw-bg-opacity: 1;
  background-color: rgb(38 38 38 / var(--tw-bg-opacity, 1));
}

/* Badge styles */

.badge {
  display: inline-flex;
  align-items: center;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  padding-top: 0.125rem;
  padding-bottom: 0.125rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 500;
}

/* Skeleton loading */

@keyframes pulse {

  50% {
    opacity: .5;
  }
}

.skeleton {
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
  border-radius: 0.25rem;
  --tw-bg-opacity: 1;
  background-color: rgb(229 229 229 / var(--tw-bg-opacity, 1));
}

[data-theme="dark"] .skeleton {
  --tw-bg-opacity: 1;
  background-color: rgb(64 64 64 / var(--tw-bg-opacity, 1));
}

/* Tooltip */

.tooltip {
  position: absolute;
  z-index: 700;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
  border-radius: 0.25rem;
  --tw-bg-opacity: 1;
  background-color: rgb(23 23 23 / var(--tw-bg-opacity, 1));
  font-size: 0.75rem;
  line-height: 1rem;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

@keyframes fadeIn {

  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

.tooltip {
  animation: fadeIn 200ms ease-out;
}

[data-theme="dark"] .tooltip {
  --tw-bg-opacity: 1;
  background-color: rgb(245 245 245 / var(--tw-bg-opacity, 1));
  --tw-text-opacity: 1;
  color: rgb(23 23 23 / var(--tw-text-opacity, 1));
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.pointer-events-none {
  pointer-events: none;
}

.\!visible {
  visibility: visible !important;
}

.visible {
  visibility: visible;
}

.invisible {
  visibility: hidden;
}

.collapse {
  visibility: collapse;
}

.static {
  position: static;
}

.fixed {
  position: fixed;
}

.absolute {
  position: absolute;
}

.relative {
  position: relative;
}

.sticky {
  position: sticky;
}

.inset-0 {
  inset: 0px;
}

.-bottom-1 {
  bottom: -0.25rem;
}

.-left-1 {
  left: -0.25rem;
}

.-right-1 {
  right: -0.25rem;
}

.-top-1 {
  top: -0.25rem;
}

.-top-10 {
  top: -2.5rem;
}

.bottom-0 {
  bottom: 0px;
}

.bottom-1 {
  bottom: 0.25rem;
}

.bottom-16 {
  bottom: 4rem;
}

.bottom-20 {
  bottom: 5rem;
}

.bottom-4 {
  bottom: 1rem;
}

.bottom-6 {
  bottom: 1.5rem;
}

.bottom-full {
  bottom: 100%;
}

.left-0 {
  left: 0px;
}

.left-0\.5 {
  left: 0.125rem;
}

.left-1 {
  left: 0.25rem;
}

.left-1\/2 {
  left: 50%;
}

.left-2 {
  left: 0.5rem;
}

.left-2\.5 {
  left: 0.625rem;
}

.left-3 {
  left: 0.75rem;
}

.left-4 {
  left: 1rem;
}

.left-full {
  left: 100%;
}

.right-0 {
  right: 0px;
}

.right-0\.5 {
  right: 0.125rem;
}

.right-1 {
  right: 0.25rem;
}

.right-2 {
  right: 0.5rem;
}

.right-20 {
  right: 5rem;
}

.right-3 {
  right: 0.75rem;
}

.right-4 {
  right: 1rem;
}

.right-6 {
  right: 1.5rem;
}

.right-full {
  right: 100%;
}

.top-0 {
  top: 0px;
}

.top-0\.5 {
  top: 0.125rem;
}

.top-1 {
  top: 0.25rem;
}

.top-1\/2 {
  top: 50%;
}

.top-16 {
  top: 4rem;
}

.top-2 {
  top: 0.5rem;
}

.top-20 {
  top: 5rem;
}

.top-24 {
  top: 6rem;
}

.top-3 {
  top: 0.75rem;
}

.top-4 {
  top: 1rem;
}

.top-full {
  top: 100%;
}

.isolate {
  isolation: isolate;
}

.-z-10 {
  z-index: -10;
}

.-z-50 {
  z-index: -50;
}

.-z-modal {
  z-index: -500;
}

.-z-tooltip {
  z-index: -700;
}

.z-10 {
  z-index: 10;
}

.z-20 {
  z-index: 20;
}

.z-40 {
  z-index: 40;
}

.z-50 {
  z-index: 50;
}

.z-\[100\] {
  z-index: 100;
}

.z-\[60\] {
  z-index: 60;
}

.z-\[9999\] {
  z-index: 9999;
}

.z-dropdown {
  z-index: 100;
}

.z-modal {
  z-index: 500;
}

.z-toast {
  z-index: 800;
}

.z-tooltip {
  z-index: 700;
}

.col-span-2 {
  grid-column: span 2 / span 2;
}

.mx-1 {
  margin-left: 0.25rem;
  margin-right: 0.25rem;
}

.mx-2 {
  margin-left: 0.5rem;
  margin-right: 0.5rem;
}

.mx-3 {
  margin-left: 0.75rem;
  margin-right: 0.75rem;
}

.mx-4 {
  margin-left: 1rem;
  margin-right: 1rem;
}

.mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.my-1 {
  margin-top: 0.25rem;
  margin-bottom: 0.25rem;
}

.my-2 {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}

.mb-0\.5 {
  margin-bottom: 0.125rem;
}

.mb-1 {
  margin-bottom: 0.25rem;
}

.mb-1\.5 {
  margin-bottom: 0.375rem;
}

.mb-2 {
  margin-bottom: 0.5rem;
}

.mb-3 {
  margin-bottom: 0.75rem;
}

.mb-4 {
  margin-bottom: 1rem;
}

.mb-6 {
  margin-bottom: 1.5rem;
}

.mb-8 {
  margin-bottom: 2rem;
}

.ml-0\.5 {
  margin-left: 0.125rem;
}

.ml-1 {
  margin-left: 0.25rem;
}

.ml-1\.5 {
  margin-left: 0.375rem;
}

.ml-2 {
  margin-left: 0.5rem;
}

.ml-3 {
  margin-left: 0.75rem;
}

.ml-4 {
  margin-left: 1rem;
}

.ml-5 {
  margin-left: 1.25rem;
}

.ml-6 {
  margin-left: 1.5rem;
}

.ml-auto {
  margin-left: auto;
}

.mr-1 {
  margin-right: 0.25rem;
}

.mr-2 {
  margin-right: 0.5rem;
}

.mt-0\.5 {
  margin-top: 0.125rem;
}

.mt-1 {
  margin-top: 0.25rem;
}

.mt-1\.5 {
  margin-top: 0.375rem;
}

.mt-2 {
  margin-top: 0.5rem;
}

.mt-3 {
  margin-top: 0.75rem;
}

.mt-4 {
  margin-top: 1rem;
}

.mt-6 {
  margin-top: 1.5rem;
}

.mt-8 {
  margin-top: 2rem;
}

.mt-px {
  margin-top: 1px;
}

.line-clamp-2 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.line-clamp-3 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.block {
  display: block;
}

.inline-block {
  display: inline-block;
}

.inline {
  display: inline;
}

.flex {
  display: flex;
}

.inline-flex {
  display: inline-flex;
}

.table {
  display: table;
}

.grid {
  display: grid;
}

.inline-grid {
  display: inline-grid;
}

.contents {
  display: contents;
}

.hidden {
  display: none;
}

.aspect-square {
  aspect-ratio: 1 / 1;
}

.\!h-3 {
  height: 0.75rem !important;
}

.h-0 {
  height: 0px;
}

.h-1 {
  height: 0.25rem;
}

.h-1\.5 {
  height: 0.375rem;
}

.h-10 {
  height: 2.5rem;
}

.h-12 {
  height: 3rem;
}

.h-14 {
  height: 3.5rem;
}

.h-16 {
  height: 4rem;
}

.h-2 {
  height: 0.5rem;
}

.h-2\.5 {
  height: 0.625rem;
}

.h-24 {
  height: 6rem;
}

.h-3 {
  height: 0.75rem;
}

.h-3\.5 {
  height: 0.875rem;
}

.h-3\/4 {
  height: 75%;
}

.h-32 {
  height: 8rem;
}

.h-4 {
  height: 1rem;
}

.h-4\/5 {
  height: 80%;
}

.h-48 {
  height: 12rem;
}

.h-5 {
  height: 1.25rem;
}

.h-6 {
  height: 1.5rem;
}

.h-7 {
  height: 1.75rem;
}

.h-8 {
  height: 2rem;
}

.h-\[120px\] {
  height: 120px;
}

.h-\[14px\] {
  height: 14px;
}

.h-\[350px\] {
  height: 350px;
}

.h-\[400px\] {
  height: 400px;
}

.h-\[600px\] {
  height: 600px;
}

.h-\[60px\] {
  height: 60px;
}

.h-\[700px\] {
  height: 700px;
}

.h-\[92vh\] {
  height: 92vh;
}

.h-\[calc\(100\%-80px\)\] {
  height: calc(100% - 80px);
}

.h-full {
  height: 100%;
}

.h-px {
  height: 1px;
}

.h-screen {
  height: 100vh;
}

.max-h-24 {
  max-height: 6rem;
}

.max-h-32 {
  max-height: 8rem;
}

.max-h-48 {
  max-height: 12rem;
}

.max-h-60 {
  max-height: 15rem;
}

.max-h-64 {
  max-height: 16rem;
}

.max-h-80 {
  max-height: 20rem;
}

.max-h-96 {
  max-height: 24rem;
}

.max-h-\[100px\] {
  max-height: 100px;
}

.max-h-\[120px\] {
  max-height: 120px;
}

.max-h-\[160px\] {
  max-height: 160px;
}

.max-h-\[380px\] {
  max-height: 380px;
}

.max-h-\[400px\] {
  max-height: 400px;
}

.max-h-\[500px\] {
  max-height: 500px;
}

.max-h-\[600px\] {
  max-height: 600px;
}

.max-h-\[60vh\] {
  max-height: 60vh;
}

.max-h-\[80px\] {
  max-height: 80px;
}

.max-h-\[80vh\] {
  max-height: 80vh;
}

.max-h-\[90px\] {
  max-height: 90px;
}

.max-h-\[90vh\] {
  max-height: 90vh;
}

.max-h-\[calc\(100\%-120px\)\] {
  max-height: calc(100% - 120px);
}

.max-h-full {
  max-height: 100%;
}

.min-h-0 {
  min-height: 0px;
}

.min-h-\[120px\] {
  min-height: 120px;
}

.min-h-\[140px\] {
  min-height: 140px;
}

.min-h-\[150px\] {
  min-height: 150px;
}

.min-h-\[200px\] {
  min-height: 200px;
}

.min-h-\[300px\] {
  min-height: 300px;
}

.min-h-\[32px\] {
  min-height: 32px;
}

.min-h-\[400px\] {
  min-height: 400px;
}

.min-h-\[40px\] {
  min-height: 40px;
}

.min-h-\[48px\] {
  min-height: 48px;
}

.min-h-\[60px\] {
  min-height: 60px;
}

.min-h-\[80px\] {
  min-height: 80px;
}

.min-h-screen {
  min-height: 100vh;
}

.\!w-3 {
  width: 0.75rem !important;
}

.w-0 {
  width: 0px;
}

.w-1 {
  width: 0.25rem;
}

.w-1\.5 {
  width: 0.375rem;
}

.w-1\/2 {
  width: 50%;
}

.w-10 {
  width: 2.5rem;
}

.w-11 {
  width: 2.75rem;
}

.w-12 {
  width: 3rem;
}

.w-14 {
  width: 3.5rem;
}

.w-16 {
  width: 4rem;
}

.w-2 {
  width: 0.5rem;
}

.w-2\.5 {
  width: 0.625rem;
}

.w-20 {
  width: 5rem;
}

.w-24 {
  width: 6rem;
}

.w-3 {
  width: 0.75rem;
}

.w-3\.5 {
  width: 0.875rem;
}

.w-3\/4 {
  width: 75%;
}

.w-32 {
  width: 8rem;
}

.w-4 {
  width: 1rem;
}

.w-4\/5 {
  width: 80%;
}

.w-48 {
  width: 12rem;
}

.w-5 {
  width: 1.25rem;
}

.w-6 {
  width: 1.5rem;
}

.w-64 {
  width: 16rem;
}

.w-7 {
  width: 1.75rem;
}

.w-72 {
  width: 18rem;
}

.w-8 {
  width: 2rem;
}

.w-80 {
  width: 20rem;
}

.w-9 {
  width: 2.25rem;
}

.w-\[400px\] {
  width: 400px;
}

.w-\[450px\] {
  width: 450px;
}

.w-\[460px\] {
  width: 460px;
}

.w-\[500px\] {
  width: 500px;
}

.w-\[550px\] {
  width: 550px;
}

.w-\[700px\] {
  width: 700px;
}

.w-\[800px\] {
  width: 800px;
}

.w-\[900px\] {
  width: 900px;
}

.w-\[95vw\] {
  width: 95vw;
}

.w-full {
  width: 100%;
}

.w-px {
  width: 1px;
}

.w-screen {
  width: 100vw;
}

.min-w-0 {
  min-width: 0px;
}

.min-w-\[14px\] {
  min-width: 14px;
}

.min-w-\[160px\] {
  min-width: 160px;
}

.min-w-\[200px\] {
  min-width: 200px;
}

.min-w-\[220px\] {
  min-width: 220px;
}

.min-w-\[240px\] {
  min-width: 240px;
}

.min-w-\[260px\] {
  min-width: 260px;
}

.min-w-\[280px\] {
  min-width: 280px;
}

.min-w-\[300px\] {
  min-width: 300px;
}

.min-w-\[32px\] {
  min-width: 32px;
}

.min-w-\[350px\] {
  min-width: 350px;
}

.min-w-\[400px\] {
  min-width: 400px;
}

.max-w-2xl {
  max-width: 42rem;
}

.max-w-3xl {
  max-width: 48rem;
}

.max-w-4xl {
  max-width: 56rem;
}

.max-w-\[100px\] {
  max-width: 100px;
}

.max-w-\[120px\] {
  max-width: 120px;
}

.max-w-\[140px\] {
  max-width: 140px;
}

.max-w-\[150px\] {
  max-width: 150px;
}

.max-w-\[180px\] {
  max-width: 180px;
}

.max-w-\[260px\] {
  max-width: 260px;
}

.max-w-\[280px\] {
  max-width: 280px;
}

.max-w-\[300px\] {
  max-width: 300px;
}

.max-w-\[320px\] {
  max-width: 320px;
}

.max-w-\[340px\] {
  max-width: 340px;
}

.max-w-\[350px\] {
  max-width: 350px;
}

.max-w-\[360px\] {
  max-width: 360px;
}

.max-w-\[400px\] {
  max-width: 400px;
}

.max-w-\[60\%\] {
  max-width: 60%;
}

.max-w-\[90vw\] {
  max-width: 90vw;
}

.max-w-full {
  max-width: 100%;
}

.max-w-lg {
  max-width: 32rem;
}

.max-w-md {
  max-width: 28rem;
}

.max-w-sm {
  max-width: 24rem;
}

.max-w-xl {
  max-width: 36rem;
}

.max-w-xs {
  max-width: 20rem;
}

.flex-1 {
  flex: 1 1 0%;
}

.flex-shrink-0 {
  flex-shrink: 0;
}

.shrink {
  flex-shrink: 1;
}

.shrink-0 {
  flex-shrink: 0;
}

.flex-grow {
  flex-grow: 1;
}

.grow {
  flex-grow: 1;
}

.-translate-x-1\/2 {
  --tw-translate-x: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-x-4 {
  --tw-translate-x: -1rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-x-full {
  --tw-translate-x: -100%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-y-1\/2 {
  --tw-translate-y: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-y-full {
  --tw-translate-y: -100%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-0 {
  --tw-translate-x: 0px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-1 {
  --tw-translate-x: 0.25rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-4 {
  --tw-translate-x: 1rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-5 {
  --tw-translate-x: 1.25rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-6 {
  --tw-translate-x: 1.5rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-8 {
  --tw-translate-x: 2rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-full {
  --tw-translate-x: 100%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-y-full {
  --tw-translate-y: 100%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-rotate-90 {
  --tw-rotate: -90deg;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.rotate-180 {
  --tw-rotate: 180deg;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.rotate-90 {
  --tw-rotate: 90deg;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-100 {
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-105 {
  --tw-scale-x: 1.05;
  --tw-scale-y: 1.05;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-75 {
  --tw-scale-x: .75;
  --tw-scale-y: .75;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-95 {
  --tw-scale-x: .95;
  --tw-scale-y: .95;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-\[1\.02\] {
  --tw-scale-x: 1.02;
  --tw-scale-y: 1.02;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.transform {
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.transform-gpu {
  transform: translate3d(var(--tw-translate-x), var(--tw-translate-y), 0) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

@keyframes bounce {

  0%, 100% {
    transform: translateY(-25%);
    animation-timing-function: cubic-bezier(0.8,0,1,1);
  }

  50% {
    transform: none;
    animation-timing-function: cubic-bezier(0,0,0.2,1);
  }
}

.animate-bounce {
  animation: bounce 1s infinite;
}

@keyframes fadeIn {

  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

.animate-fade-in {
  animation: fadeIn 200ms ease-out;
}

@keyframes fadeOut {

  0% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

.animate-fade-out {
  animation: fadeOut 200ms ease-in;
}

@keyframes pulse {

  50% {
    opacity: .5;
  }
}

.animate-pulse {
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes ripple {

  0% {
    transform: scale(0);
    opacity: 0.5;
  }

  100% {
    transform: scale(4);
    opacity: 0;
  }
}

.animate-ripple {
  animation: ripple 600ms linear;
}

@keyframes scaleIn {

  0% {
    transform: scale(0.95);
    opacity: 0;
  }

  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.animate-scale-in {
  animation: scaleIn 200ms ease-out;
}

@keyframes scaleOut {

  0% {
    transform: scale(1);
    opacity: 1;
  }

  100% {
    transform: scale(0.95);
    opacity: 0;
  }
}

.animate-scale-out {
  animation: scaleOut 200ms ease-in;
}

@keyframes slideInDown {

  0% {
    transform: translateY(-100%);
    opacity: 0;
  }

  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

.animate-slide-in-down {
  animation: slideInDown 300ms ease-out;
}

@keyframes slideInLeft {

  0% {
    transform: translateX(-100%);
    opacity: 0;
  }

  100% {
    transform: translateX(0);
    opacity: 1;
  }
}

.animate-slide-in-left {
  animation: slideInLeft 300ms ease-out;
}

@keyframes slideInRight {

  0% {
    transform: translateX(100%);
    opacity: 0;
  }

  100% {
    transform: translateX(0);
    opacity: 1;
  }
}

.animate-slide-in-right {
  animation: slideInRight 300ms ease-out;
}

@keyframes slideInUp {

  0% {
    transform: translateY(100%);
    opacity: 0;
  }

  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

.animate-slide-in-up {
  animation: slideInUp 300ms ease-out;
}

@keyframes spin {

  to {
    transform: rotate(360deg);
  }
}

.animate-spin {
  animation: spin 1s linear infinite;
}

.cursor-col-resize {
  cursor: col-resize;
}

.cursor-crosshair {
  cursor: crosshair;
}

.cursor-default {
  cursor: default;
}

.cursor-grab {
  cursor: grab;
}

.cursor-help {
  cursor: help;
}

.cursor-move {
  cursor: move;
}

.cursor-not-allowed {
  cursor: not-allowed;
}

.cursor-pointer {
  cursor: pointer;
}

.select-none {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.resize-none {
  resize: none;
}

.resize-y {
  resize: vertical;
}

.resize {
  resize: both;
}

.list-inside {
  list-style-position: inside;
}

.list-decimal {
  list-style-type: decimal;
}

.list-disc {
  list-style-type: disc;
}

.appearance-none {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

.grid-cols-1 {
  grid-template-columns: repeat(1, minmax(0, 1fr));
}

.grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.grid-cols-5 {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.grid-cols-6 {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.grid-cols-\[1fr_80px_80px_90px_100px_70px\] {
  grid-template-columns: 1fr 80px 80px 90px 100px 70px;
}

.flex-row {
  flex-direction: row;
}

.flex-col {
  flex-direction: column;
}

.flex-wrap {
  flex-wrap: wrap;
}

.items-start {
  align-items: flex-start;
}

.items-end {
  align-items: flex-end;
}

.items-center {
  align-items: center;
}

.items-baseline {
  align-items: baseline;
}

.justify-end {
  justify-content: flex-end;
}

.justify-center {
  justify-content: center;
}

.justify-between {
  justify-content: space-between;
}

.gap-0\.5 {
  gap: 0.125rem;
}

.gap-1 {
  gap: 0.25rem;
}

.gap-1\.5 {
  gap: 0.375rem;
}

.gap-2 {
  gap: 0.5rem;
}

.gap-2\.5 {
  gap: 0.625rem;
}

.gap-3 {
  gap: 0.75rem;
}

.gap-4 {
  gap: 1rem;
}

.gap-6 {
  gap: 1.5rem;
}

.space-y-0\.5 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.125rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.125rem * var(--tw-space-y-reverse));
}

.space-y-1 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.25rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.25rem * var(--tw-space-y-reverse));
}

.space-y-1\.5 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.375rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.375rem * var(--tw-space-y-reverse));
}

.space-y-2 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.5rem * var(--tw-space-y-reverse));
}

.space-y-3 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.75rem * var(--tw-space-y-reverse));
}

.space-y-4 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1rem * var(--tw-space-y-reverse));
}

.divide-y > :not([hidden]) ~ :not([hidden]) {
  --tw-divide-y-reverse: 0;
  border-top-width: calc(1px * calc(1 - var(--tw-divide-y-reverse)));
  border-bottom-width: calc(1px * var(--tw-divide-y-reverse));
}

.divide-gray-800 > :not([hidden]) ~ :not([hidden]) {
  --tw-divide-opacity: 1;
  border-color: rgb(31 41 55 / var(--tw-divide-opacity, 1));
}

.divide-gray-800\/30 > :not([hidden]) ~ :not([hidden]) {
  border-color: rgb(31 41 55 / 0.3);
}

.self-end {
  align-self: flex-end;
}

.self-center {
  align-self: center;
}

.overflow-auto {
  overflow: auto;
}

.overflow-hidden {
  overflow: hidden;
}

.overflow-x-auto {
  overflow-x: auto;
}

.overflow-y-auto {
  overflow-y: auto;
}

.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.whitespace-nowrap {
  white-space: nowrap;
}

.whitespace-pre-line {
  white-space: pre-line;
}

.whitespace-pre-wrap {
  white-space: pre-wrap;
}

.break-words {
  overflow-wrap: break-word;
}

.break-all {
  word-break: break-all;
}

.\!rounded-full {
  border-radius: 9999px !important;
}

.rounded {
  border-radius: 0.25rem;
}

.rounded-2xl {
  border-radius: 1rem;
}

.rounded-full {
  border-radius: 9999px;
}

.rounded-lg {
  border-radius: 0.5rem;
}

.rounded-md {
  border-radius: 0.375rem;
}

.rounded-sm {
  border-radius: 0.125rem;
}

.rounded-xl {
  border-radius: 0.75rem;
}

.rounded-b-md {
  border-bottom-right-radius: 0.375rem;
  border-bottom-left-radius: 0.375rem;
}

.rounded-t-lg {
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
}

.\!border-2 {
  border-width: 2px !important;
}

.border {
  border-width: 1px;
}

.border-2 {
  border-width: 2px;
}

.border-4 {
  border-width: 4px;
}

.border-b {
  border-bottom-width: 1px;
}

.border-b-2 {
  border-bottom-width: 2px;
}

.border-l {
  border-left-width: 1px;
}

.border-l-2 {
  border-left-width: 2px;
}

.border-l-4 {
  border-left-width: 4px;
}

.border-r {
  border-right-width: 1px;
}

.border-t {
  border-top-width: 1px;
}

.border-t-2 {
  border-top-width: 2px;
}

.border-dashed {
  border-style: dashed;
}

.border-none {
  border-style: none;
}

.\!border-neutral-300 {
  --tw-border-opacity: 1 !important;
  border-color: rgb(212 212 212 / var(--tw-border-opacity, 1)) !important;
}

.\!border-neutral-500 {
  --tw-border-opacity: 1 !important;
  border-color: rgb(115 115 115 / var(--tw-border-opacity, 1)) !important;
}

.border-amber-500 {
  --tw-border-opacity: 1;
  border-color: rgb(245 158 11 / var(--tw-border-opacity, 1));
}

.border-amber-500\/20 {
  border-color: rgb(245 158 11 / 0.2);
}

.border-amber-500\/30 {
  border-color: rgb(245 158 11 / 0.3);
}

.border-amber-500\/50 {
  border-color: rgb(245 158 11 / 0.5);
}

.border-black\/10 {
  border-color: rgb(0 0 0 / 0.1);
}

.border-black\/5 {
  border-color: rgb(0 0 0 / 0.05);
}

.border-blue-200 {
  --tw-border-opacity: 1;
  border-color: rgb(191 219 254 / var(--tw-border-opacity, 1));
}

.border-blue-400 {
  --tw-border-opacity: 1;
  border-color: rgb(96 165 250 / var(--tw-border-opacity, 1));
}

.border-blue-400\/30 {
  border-color: rgb(96 165 250 / 0.3);
}

.border-blue-400\/50 {
  border-color: rgb(96 165 250 / 0.5);
}

.border-blue-400\/60 {
  border-color: rgb(96 165 250 / 0.6);
}

.border-blue-500 {
  --tw-border-opacity: 1;
  border-color: rgb(59 130 246 / var(--tw-border-opacity, 1));
}

.border-blue-500\/30 {
  border-color: rgb(59 130 246 / 0.3);
}

.border-blue-500\/50 {
  border-color: rgb(59 130 246 / 0.5);
}

.border-blue-600 {
  --tw-border-opacity: 1;
  border-color: rgb(37 99 235 / var(--tw-border-opacity, 1));
}

.border-current {
  border-color: currentColor;
}

.border-cyan-400\/60 {
  border-color: rgb(34 211 238 / 0.6);
}

.border-emerald-400 {
  --tw-border-opacity: 1;
  border-color: rgb(52 211 153 / var(--tw-border-opacity, 1));
}

.border-emerald-500\/30 {
  border-color: rgb(16 185 129 / 0.3);
}

.border-error-500 {
  --tw-border-opacity: 1;
  border-color: rgb(239 68 68 / var(--tw-border-opacity, 1));
}

.border-error-500\/10 {
  border-color: rgb(239 68 68 / 0.1);
}

.border-error-500\/20 {
  border-color: rgb(239 68 68 / 0.2);
}

.border-error-500\/30 {
  border-color: rgb(239 68 68 / 0.3);
}

.border-gray-200 {
  --tw-border-opacity: 1;
  border-color: rgb(229 231 235 / var(--tw-border-opacity, 1));
}

.border-gray-300 {
  --tw-border-opacity: 1;
  border-color: rgb(209 213 219 / var(--tw-border-opacity, 1));
}

.border-gray-500 {
  --tw-border-opacity: 1;
  border-color: rgb(107 114 128 / var(--tw-border-opacity, 1));
}

.border-gray-500\/30 {
  border-color: rgb(107 114 128 / 0.3);
}

.border-gray-600 {
  --tw-border-opacity: 1;
  border-color: rgb(75 85 99 / var(--tw-border-opacity, 1));
}

.border-gray-700 {
  --tw-border-opacity: 1;
  border-color: rgb(55 65 81 / var(--tw-border-opacity, 1));
}

.border-gray-900 {
  --tw-border-opacity: 1;
  border-color: rgb(17 24 39 / var(--tw-border-opacity, 1));
}

.border-green-200 {
  --tw-border-opacity: 1;
  border-color: rgb(187 247 208 / var(--tw-border-opacity, 1));
}

.border-green-500 {
  --tw-border-opacity: 1;
  border-color: rgb(34 197 94 / var(--tw-border-opacity, 1));
}

.border-green-500\/30 {
  border-color: rgb(34 197 94 / 0.3);
}

.border-indigo-300 {
  --tw-border-opacity: 1;
  border-color: rgb(165 180 252 / var(--tw-border-opacity, 1));
}

.border-indigo-400\/30 {
  border-color: rgb(129 140 248 / 0.3);
}

.border-indigo-400\/40 {
  border-color: rgb(129 140 248 / 0.4);
}

.border-indigo-400\/60 {
  border-color: rgb(129 140 248 / 0.6);
}

.border-indigo-500 {
  --tw-border-opacity: 1;
  border-color: rgb(99 102 241 / var(--tw-border-opacity, 1));
}

.border-neutral-200 {
  --tw-border-opacity: 1;
  border-color: rgb(229 229 229 / var(--tw-border-opacity, 1));
}

.border-neutral-200\/50 {
  border-color: rgb(229 229 229 / 0.5);
}

.border-neutral-300 {
  --tw-border-opacity: 1;
  border-color: rgb(212 212 212 / var(--tw-border-opacity, 1));
}

.border-neutral-400 {
  --tw-border-opacity: 1;
  border-color: rgb(163 163 163 / var(--tw-border-opacity, 1));
}

.border-neutral-500 {
  --tw-border-opacity: 1;
  border-color: rgb(115 115 115 / var(--tw-border-opacity, 1));
}

.border-neutral-500\/30 {
  border-color: rgb(115 115 115 / 0.3);
}

.border-neutral-600 {
  --tw-border-opacity: 1;
  border-color: rgb(82 82 82 / var(--tw-border-opacity, 1));
}

.border-neutral-700 {
  --tw-border-opacity: 1;
  border-color: rgb(64 64 64 / var(--tw-border-opacity, 1));
}

.border-orange-500 {
  --tw-border-opacity: 1;
  border-color: rgb(249 115 22 / var(--tw-border-opacity, 1));
}

.border-orange-500\/30 {
  border-color: rgb(249 115 22 / 0.3);
}

.border-pink-500 {
  --tw-border-opacity: 1;
  border-color: rgb(236 72 153 / var(--tw-border-opacity, 1));
}

.border-primary-500 {
  --tw-border-opacity: 1;
  border-color: rgb(59 130 246 / var(--tw-border-opacity, 1));
}

.border-primary-500\/30 {
  border-color: rgb(59 130 246 / 0.3);
}

.border-purple-200 {
  --tw-border-opacity: 1;
  border-color: rgb(233 213 255 / var(--tw-border-opacity, 1));
}

.border-purple-400\/60 {
  border-color: rgb(192 132 252 / 0.6);
}

.border-purple-500 {
  --tw-border-opacity: 1;
  border-color: rgb(168 85 247 / var(--tw-border-opacity, 1));
}

.border-purple-500\/50 {
  border-color: rgb(168 85 247 / 0.5);
}

.border-purple-600 {
  --tw-border-opacity: 1;
  border-color: rgb(147 51 234 / var(--tw-border-opacity, 1));
}

.border-red-200 {
  --tw-border-opacity: 1;
  border-color: rgb(254 202 202 / var(--tw-border-opacity, 1));
}

.border-red-400\/30 {
  border-color: rgb(248 113 113 / 0.3);
}

.border-red-500 {
  --tw-border-opacity: 1;
  border-color: rgb(239 68 68 / var(--tw-border-opacity, 1));
}

.border-red-500\/20 {
  border-color: rgb(239 68 68 / 0.2);
}

.border-red-500\/30 {
  border-color: rgb(239 68 68 / 0.3);
}

.border-red-500\/50 {
  border-color: rgb(239 68 68 / 0.5);
}

.border-red-600 {
  --tw-border-opacity: 1;
  border-color: rgb(220 38 38 / var(--tw-border-opacity, 1));
}

.border-slate-600 {
  --tw-border-opacity: 1;
  border-color: rgb(71 85 105 / var(--tw-border-opacity, 1));
}

.border-slate-600\/50 {
  border-color: rgb(71 85 105 / 0.5);
}

.border-success-500\/30 {
  border-color: rgb(34 197 94 / 0.3);
}

.border-teal-600 {
  --tw-border-opacity: 1;
  border-color: rgb(13 148 136 / var(--tw-border-opacity, 1));
}

.border-transparent {
  border-color: transparent;
}

.border-warning-500\/30 {
  border-color: rgb(245 158 11 / 0.3);
}

.border-white {
  --tw-border-opacity: 1;
  border-color: rgb(255 255 255 / var(--tw-border-opacity, 1));
}

.border-white\/10 {
  border-color: rgb(255 255 255 / 0.1);
}

.border-white\/15 {
  border-color: rgb(255 255 255 / 0.15);
}

.border-white\/20 {
  border-color: rgb(255 255 255 / 0.2);
}

.border-white\/30 {
  border-color: rgb(255 255 255 / 0.3);
}

.border-white\/40 {
  border-color: rgb(255 255 255 / 0.4);
}

.border-white\/5 {
  border-color: rgb(255 255 255 / 0.05);
}

.border-white\/\[0\.15\] {
  border-color: rgb(255 255 255 / 0.15);
}

.border-white\/\[var\(--glass-border-opacity\)\] {
  border-color: rgb(255 255 255 / var(--glass-border-opacity));
}

.border-yellow-200 {
  --tw-border-opacity: 1;
  border-color: rgb(254 240 138 / var(--tw-border-opacity, 1));
}

.border-yellow-500 {
  --tw-border-opacity: 1;
  border-color: rgb(234 179 8 / var(--tw-border-opacity, 1));
}

.border-yellow-500\/30 {
  border-color: rgb(234 179 8 / 0.3);
}

.border-yellow-500\/50 {
  border-color: rgb(234 179 8 / 0.5);
}

.border-x-transparent {
  border-left-color: transparent;
  border-right-color: transparent;
}

.border-y-transparent {
  border-top-color: transparent;
  border-bottom-color: transparent;
}

.border-b-current {
  border-bottom-color: currentColor;
}

.border-b-transparent {
  border-bottom-color: transparent;
}

.border-l-current {
  border-left-color: currentColor;
}

.border-l-transparent {
  border-left-color: transparent;
}

.border-r-current {
  border-right-color: currentColor;
}

.border-r-transparent {
  border-right-color: transparent;
}

.border-t-blue-400 {
  --tw-border-opacity: 1;
  border-top-color: rgb(96 165 250 / var(--tw-border-opacity, 1));
}

.border-t-current {
  border-top-color: currentColor;
}

.border-t-transparent {
  border-top-color: transparent;
}

.border-t-white\/60 {
  border-top-color: rgb(255 255 255 / 0.6);
}

.\!bg-neutral-700 {
  --tw-bg-opacity: 1 !important;
  background-color: rgb(64 64 64 / var(--tw-bg-opacity, 1)) !important;
}

.\!bg-white {
  --tw-bg-opacity: 1 !important;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1)) !important;
}

.bg-amber-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(245 158 11 / var(--tw-bg-opacity, 1));
}

.bg-amber-500\/10 {
  background-color: rgb(245 158 11 / 0.1);
}

.bg-amber-500\/20 {
  background-color: rgb(245 158 11 / 0.2);
}

.bg-amber-500\/30 {
  background-color: rgb(245 158 11 / 0.3);
}

.bg-black {
  --tw-bg-opacity: 1;
  background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}

.bg-black\/0 {
  background-color: rgb(0 0 0 / 0);
}

.bg-black\/20 {
  background-color: rgb(0 0 0 / 0.2);
}

.bg-black\/30 {
  background-color: rgb(0 0 0 / 0.3);
}

.bg-black\/40 {
  background-color: rgb(0 0 0 / 0.4);
}

.bg-black\/5 {
  background-color: rgb(0 0 0 / 0.05);
}

.bg-black\/50 {
  background-color: rgb(0 0 0 / 0.5);
}

.bg-black\/60 {
  background-color: rgb(0 0 0 / 0.6);
}

.bg-black\/75 {
  background-color: rgb(0 0 0 / 0.75);
}

.bg-black\/80 {
  background-color: rgb(0 0 0 / 0.8);
}

.bg-black\/90 {
  background-color: rgb(0 0 0 / 0.9);
}

.bg-black\/\[0\.03\] {
  background-color: rgb(0 0 0 / 0.03);
}

.bg-blue-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(219 234 254 / var(--tw-bg-opacity, 1));
}

.bg-blue-400 {
  --tw-bg-opacity: 1;
  background-color: rgb(96 165 250 / var(--tw-bg-opacity, 1));
}

.bg-blue-400\/70 {
  background-color: rgb(96 165 250 / 0.7);
}

.bg-blue-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(239 246 255 / var(--tw-bg-opacity, 1));
}

.bg-blue-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1));
}

.bg-blue-500\/10 {
  background-color: rgb(59 130 246 / 0.1);
}

.bg-blue-500\/20 {
  background-color: rgb(59 130 246 / 0.2);
}

.bg-blue-500\/30 {
  background-color: rgb(59 130 246 / 0.3);
}

.bg-blue-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(37 99 235 / var(--tw-bg-opacity, 1));
}

.bg-blue-600\/20 {
  background-color: rgb(37 99 235 / 0.2);
}

.bg-cyan-500\/10 {
  background-color: rgb(6 182 212 / 0.1);
}

.bg-cyan-500\/20 {
  background-color: rgb(6 182 212 / 0.2);
}

.bg-emerald-400 {
  --tw-bg-opacity: 1;
  background-color: rgb(52 211 153 / var(--tw-bg-opacity, 1));
}

.bg-emerald-500\/10 {
  background-color: rgb(16 185 129 / 0.1);
}

.bg-emerald-500\/20 {
  background-color: rgb(16 185 129 / 0.2);
}

.bg-emerald-500\/5 {
  background-color: rgb(16 185 129 / 0.05);
}

.bg-error-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1));
}

.bg-error-500\/10 {
  background-color: rgb(239 68 68 / 0.1);
}

.bg-error-500\/20 {
  background-color: rgb(239 68 68 / 0.2);
}

.bg-error-500\/5 {
  background-color: rgb(239 68 68 / 0.05);
}

.bg-error-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(220 38 38 / var(--tw-bg-opacity, 1));
}

.bg-gray-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1));
}

.bg-gray-200 {
  --tw-bg-opacity: 1;
  background-color: rgb(229 231 235 / var(--tw-bg-opacity, 1));
}

.bg-gray-400 {
  --tw-bg-opacity: 1;
  background-color: rgb(156 163 175 / var(--tw-bg-opacity, 1));
}

.bg-gray-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1));
}

.bg-gray-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(107 114 128 / var(--tw-bg-opacity, 1));
}

.bg-gray-500\/20 {
  background-color: rgb(107 114 128 / 0.2);
}

.bg-gray-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(75 85 99 / var(--tw-bg-opacity, 1));
}

.bg-gray-600\/50 {
  background-color: rgb(75 85 99 / 0.5);
}

.bg-gray-700 {
  --tw-bg-opacity: 1;
  background-color: rgb(55 65 81 / var(--tw-bg-opacity, 1));
}

.bg-gray-700\/50 {
  background-color: rgb(55 65 81 / 0.5);
}

.bg-gray-800 {
  --tw-bg-opacity: 1;
  background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1));
}

.bg-gray-800\/30 {
  background-color: rgb(31 41 55 / 0.3);
}

.bg-gray-800\/50 {
  background-color: rgb(31 41 55 / 0.5);
}

.bg-gray-900 {
  --tw-bg-opacity: 1;
  background-color: rgb(17 24 39 / var(--tw-bg-opacity, 1));
}

.bg-gray-900\/80 {
  background-color: rgb(17 24 39 / 0.8);
}

.bg-gray-900\/90 {
  background-color: rgb(17 24 39 / 0.9);
}

.bg-green-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(220 252 231 / var(--tw-bg-opacity, 1));
}

.bg-green-400 {
  --tw-bg-opacity: 1;
  background-color: rgb(74 222 128 / var(--tw-bg-opacity, 1));
}

.bg-green-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(240 253 244 / var(--tw-bg-opacity, 1));
}

.bg-green-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(34 197 94 / var(--tw-bg-opacity, 1));
}

.bg-green-500\/20 {
  background-color: rgb(34 197 94 / 0.2);
}

.bg-green-500\/80 {
  background-color: rgb(34 197 94 / 0.8);
}

.bg-green-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(22 163 74 / var(--tw-bg-opacity, 1));
}

.bg-green-600\/20 {
  background-color: rgb(22 163 74 / 0.2);
}

.bg-indigo-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(224 231 255 / var(--tw-bg-opacity, 1));
}

.bg-indigo-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(238 242 255 / var(--tw-bg-opacity, 1));
}

.bg-indigo-500\/10 {
  background-color: rgb(99 102 241 / 0.1);
}

.bg-indigo-500\/20 {
  background-color: rgb(99 102 241 / 0.2);
}

.bg-indigo-500\/30 {
  background-color: rgb(99 102 241 / 0.3);
}

.bg-indigo-500\/80 {
  background-color: rgb(99 102 241 / 0.8);
}

.bg-indigo-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(79 70 229 / var(--tw-bg-opacity, 1));
}

.bg-indigo-600\/60 {
  background-color: rgb(79 70 229 / 0.6);
}

.bg-indigo-600\/70 {
  background-color: rgb(79 70 229 / 0.7);
}

.bg-neutral-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(245 245 245 / var(--tw-bg-opacity, 1));
}

.bg-neutral-200 {
  --tw-bg-opacity: 1;
  background-color: rgb(229 229 229 / var(--tw-bg-opacity, 1));
}

.bg-neutral-300 {
  --tw-bg-opacity: 1;
  background-color: rgb(212 212 212 / var(--tw-bg-opacity, 1));
}

.bg-neutral-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(250 250 250 / var(--tw-bg-opacity, 1));
}

.bg-neutral-500\/10 {
  background-color: rgb(115 115 115 / 0.1);
}

.bg-neutral-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(82 82 82 / var(--tw-bg-opacity, 1));
}

.bg-neutral-700 {
  --tw-bg-opacity: 1;
  background-color: rgb(64 64 64 / var(--tw-bg-opacity, 1));
}

.bg-neutral-800 {
  --tw-bg-opacity: 1;
  background-color: rgb(38 38 38 / var(--tw-bg-opacity, 1));
}

.bg-neutral-900 {
  --tw-bg-opacity: 1;
  background-color: rgb(23 23 23 / var(--tw-bg-opacity, 1));
}

.bg-neutral-900\/80 {
  background-color: rgb(23 23 23 / 0.8);
}

.bg-neutral-900\/95 {
  background-color: rgb(23 23 23 / 0.95);
}

.bg-orange-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(255 237 213 / var(--tw-bg-opacity, 1));
}

.bg-orange-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(255 247 237 / var(--tw-bg-opacity, 1));
}

.bg-orange-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(249 115 22 / var(--tw-bg-opacity, 1));
}

.bg-orange-500\/20 {
  background-color: rgb(249 115 22 / 0.2);
}

.bg-orange-500\/30 {
  background-color: rgb(249 115 22 / 0.3);
}

.bg-pink-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(252 231 243 / var(--tw-bg-opacity, 1));
}

.bg-pink-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(253 242 248 / var(--tw-bg-opacity, 1));
}

.bg-pink-500\/30 {
  background-color: rgb(236 72 153 / 0.3);
}

.bg-primary-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(219 234 254 / var(--tw-bg-opacity, 1));
}

.bg-primary-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(239 246 255 / var(--tw-bg-opacity, 1));
}

.bg-primary-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1));
}

.bg-primary-500\/10 {
  background-color: rgb(59 130 246 / 0.1);
}

.bg-primary-500\/20 {
  background-color: rgb(59 130 246 / 0.2);
}

.bg-primary-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(37 99 235 / var(--tw-bg-opacity, 1));
}

.bg-primary-900\/50 {
  background-color: rgb(30 58 138 / 0.5);
}

.bg-purple-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(243 232 255 / var(--tw-bg-opacity, 1));
}

.bg-purple-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(250 245 255 / var(--tw-bg-opacity, 1));
}

.bg-purple-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(168 85 247 / var(--tw-bg-opacity, 1));
}

.bg-purple-500\/10 {
  background-color: rgb(168 85 247 / 0.1);
}

.bg-purple-500\/20 {
  background-color: rgb(168 85 247 / 0.2);
}

.bg-purple-500\/30 {
  background-color: rgb(168 85 247 / 0.3);
}

.bg-purple-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(147 51 234 / var(--tw-bg-opacity, 1));
}

.bg-red-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 226 226 / var(--tw-bg-opacity, 1));
}

.bg-red-400 {
  --tw-bg-opacity: 1;
  background-color: rgb(248 113 113 / var(--tw-bg-opacity, 1));
}

.bg-red-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 242 242 / var(--tw-bg-opacity, 1));
}

.bg-red-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1));
}

.bg-red-500\/10 {
  background-color: rgb(239 68 68 / 0.1);
}

.bg-red-500\/20 {
  background-color: rgb(239 68 68 / 0.2);
}

.bg-red-500\/30 {
  background-color: rgb(239 68 68 / 0.3);
}

.bg-red-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(220 38 38 / var(--tw-bg-opacity, 1));
}

.bg-red-900\/50 {
  background-color: rgb(127 29 29 / 0.5);
}

.bg-sky-500\/30 {
  background-color: rgb(14 165 233 / 0.3);
}

.bg-slate-700 {
  --tw-bg-opacity: 1;
  background-color: rgb(51 65 85 / var(--tw-bg-opacity, 1));
}

.bg-slate-800 {
  --tw-bg-opacity: 1;
  background-color: rgb(30 41 59 / var(--tw-bg-opacity, 1));
}

.bg-slate-800\/50 {
  background-color: rgb(30 41 59 / 0.5);
}

.bg-slate-900 {
  --tw-bg-opacity: 1;
  background-color: rgb(15 23 42 / var(--tw-bg-opacity, 1));
}

.bg-slate-900\/\[var\(--glass-bg-opacity\)\] {
  background-color: rgb(15 23 42 / var(--glass-bg-opacity));
}

.bg-slate-900\/\[var\(--glass-bg-opacity-elevated\)\] {
  background-color: rgb(15 23 42 / var(--glass-bg-opacity-elevated));
}

.bg-success-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(34 197 94 / var(--tw-bg-opacity, 1));
}

.bg-success-500\/10 {
  background-color: rgb(34 197 94 / 0.1);
}

.bg-success-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(22 163 74 / var(--tw-bg-opacity, 1));
}

.bg-teal-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(204 251 241 / var(--tw-bg-opacity, 1));
}

.bg-teal-500\/30 {
  background-color: rgb(20 184 166 / 0.3);
}

.bg-teal-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(13 148 136 / var(--tw-bg-opacity, 1));
}

.bg-transparent {
  background-color: transparent;
}

.bg-violet-500\/30 {
  background-color: rgb(139 92 246 / 0.3);
}

.bg-warning-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(245 158 11 / var(--tw-bg-opacity, 1));
}

.bg-warning-500\/10 {
  background-color: rgb(245 158 11 / 0.1);
}

.bg-warning-500\/20 {
  background-color: rgb(245 158 11 / 0.2);
}

.bg-white {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}

.bg-white\/10 {
  background-color: rgb(255 255 255 / 0.1);
}

.bg-white\/15 {
  background-color: rgb(255 255 255 / 0.15);
}

.bg-white\/20 {
  background-color: rgb(255 255 255 / 0.2);
}

.bg-white\/30 {
  background-color: rgb(255 255 255 / 0.3);
}

.bg-white\/5 {
  background-color: rgb(255 255 255 / 0.05);
}

.bg-white\/50 {
  background-color: rgb(255 255 255 / 0.5);
}

.bg-white\/80 {
  background-color: rgb(255 255 255 / 0.8);
}

.bg-white\/90 {
  background-color: rgb(255 255 255 / 0.9);
}

.bg-white\/95 {
  background-color: rgb(255 255 255 / 0.95);
}

.bg-white\/\[var\(--glass-bg-opacity\)\] {
  background-color: rgb(255 255 255 / var(--glass-bg-opacity));
}

.bg-white\/\[var\(--glass-bg-opacity-elevated\)\] {
  background-color: rgb(255 255 255 / var(--glass-bg-opacity-elevated));
}

.bg-yellow-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 249 195 / var(--tw-bg-opacity, 1));
}

.bg-yellow-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 252 232 / var(--tw-bg-opacity, 1));
}

.bg-yellow-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(234 179 8 / var(--tw-bg-opacity, 1));
}

.bg-yellow-500\/10 {
  background-color: rgb(234 179 8 / 0.1);
}

.bg-yellow-500\/20 {
  background-color: rgb(234 179 8 / 0.2);
}

.bg-yellow-500\/30 {
  background-color: rgb(234 179 8 / 0.3);
}

.bg-opacity-20 {
  --tw-bg-opacity: 0.2;
}

.bg-opacity-50 {
  --tw-bg-opacity: 0.5;
}

.bg-opacity-90 {
  --tw-bg-opacity: 0.9;
}

.bg-gradient-to-br {
  background-image: linear-gradient(to bottom right, var(--tw-gradient-stops));
}

.bg-gradient-to-r {
  background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

.from-blue-50 {
  --tw-gradient-from: #eff6ff var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(239 246 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-blue-500 {
  --tw-gradient-from: #3b82f6 var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(59 130 246 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-gray-50 {
  --tw-gradient-from: #f9fafb var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(249 250 251 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-green-50 {
  --tw-gradient-from: #f0fdf4 var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(240 253 244 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-indigo-50 {
  --tw-gradient-from: #eef2ff var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(238 242 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-orange-50 {
  --tw-gradient-from: #fff7ed var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(255 247 237 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-pink-50 {
  --tw-gradient-from: #fdf2f8 var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(253 242 248 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-purple-50 {
  --tw-gradient-from: #faf5ff var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(250 245 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-red-50 {
  --tw-gradient-from: #fef2f2 var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(254 242 242 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-violet-500 {
  --tw-gradient-from: #8b5cf6 var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(139 92 246 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-yellow-50 {
  --tw-gradient-from: #fefce8 var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(254 252 232 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.to-blue-100 {
  --tw-gradient-to: #dbeafe var(--tw-gradient-to-position);
}

.to-blue-50 {
  --tw-gradient-to: #eff6ff var(--tw-gradient-to-position);
}

.to-blue-500 {
  --tw-gradient-to: #3b82f6 var(--tw-gradient-to-position);
}

.to-gray-100 {
  --tw-gradient-to: #f3f4f6 var(--tw-gradient-to-position);
}

.to-green-100 {
  --tw-gradient-to: #dcfce7 var(--tw-gradient-to-position);
}

.to-indigo-100 {
  --tw-gradient-to: #e0e7ff var(--tw-gradient-to-position);
}

.to-orange-100 {
  --tw-gradient-to: #ffedd5 var(--tw-gradient-to-position);
}

.to-pink-100 {
  --tw-gradient-to: #fce7f3 var(--tw-gradient-to-position);
}

.to-purple-100 {
  --tw-gradient-to: #f3e8ff var(--tw-gradient-to-position);
}

.to-purple-500 {
  --tw-gradient-to: #a855f7 var(--tw-gradient-to-position);
}

.to-red-100 {
  --tw-gradient-to: #fee2e2 var(--tw-gradient-to-position);
}

.to-yellow-100 {
  --tw-gradient-to: #fef9c3 var(--tw-gradient-to-position);
}

.bg-clip-text {
  -webkit-background-clip: text;
          background-clip: text;
}

.object-contain {
  -o-object-fit: contain;
     object-fit: contain;
}

.object-cover {
  -o-object-fit: cover;
     object-fit: cover;
}

.p-0\.5 {
  padding: 0.125rem;
}

.p-1 {
  padding: 0.25rem;
}

.p-1\.5 {
  padding: 0.375rem;
}

.p-2 {
  padding: 0.5rem;
}

.p-2\.5 {
  padding: 0.625rem;
}

.p-3 {
  padding: 0.75rem;
}

.p-4 {
  padding: 1rem;
}

.p-5 {
  padding: 1.25rem;
}

.p-6 {
  padding: 1.5rem;
}

.p-8 {
  padding: 2rem;
}

.px-1 {
  padding-left: 0.25rem;
  padding-right: 0.25rem;
}

.px-1\.5 {
  padding-left: 0.375rem;
  padding-right: 0.375rem;
}

.px-2 {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

.px-2\.5 {
  padding-left: 0.625rem;
  padding-right: 0.625rem;
}

.px-3 {
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

.px-4 {
  padding-left: 1rem;
  padding-right: 1rem;
}

.px-5 {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}

.px-6 {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

.py-0\.5 {
  padding-top: 0.125rem;
  padding-bottom: 0.125rem;
}

.py-1 {
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}

.py-1\.5 {
  padding-top: 0.375rem;
  padding-bottom: 0.375rem;
}

.py-12 {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.py-16 {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.py-2 {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.py-2\.5 {
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
}

.py-3 {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.py-4 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.py-6 {
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}

.py-8 {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.py-px {
  padding-top: 1px;
  padding-bottom: 1px;
}

.pb-2 {
  padding-bottom: 0.5rem;
}

.pb-3 {
  padding-bottom: 0.75rem;
}

.pb-4 {
  padding-bottom: 1rem;
}

.pl-10 {
  padding-left: 2.5rem;
}

.pl-11 {
  padding-left: 2.75rem;
}

.pl-12 {
  padding-left: 3rem;
}

.pl-2 {
  padding-left: 0.5rem;
}

.pl-3 {
  padding-left: 0.75rem;
}

.pl-4 {
  padding-left: 1rem;
}

.pl-5 {
  padding-left: 1.25rem;
}

.pl-7 {
  padding-left: 1.75rem;
}

.pl-8 {
  padding-left: 2rem;
}

.pl-9 {
  padding-left: 2.25rem;
}

.pr-2 {
  padding-right: 0.5rem;
}

.pr-3 {
  padding-right: 0.75rem;
}

.pr-4 {
  padding-right: 1rem;
}

.pr-6 {
  padding-right: 1.5rem;
}

.pr-8 {
  padding-right: 2rem;
}

.pt-0 {
  padding-top: 0px;
}

.pt-0\.5 {
  padding-top: 0.125rem;
}

.pt-2 {
  padding-top: 0.5rem;
}

.pt-24 {
  padding-top: 6rem;
}

.pt-3 {
  padding-top: 0.75rem;
}

.pt-4 {
  padding-top: 1rem;
}

.text-left {
  text-align: left;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

.font-mono {
  font-family: JetBrains Mono, Fira Code, Consolas, monospace;
}

.text-2xl {
  font-size: 1.5rem;
  line-height: 2rem;
}

.text-3xl {
  font-size: 1.875rem;
  line-height: 2.25rem;
}

.text-\[10px\] {
  font-size: 10px;
}

.text-\[11px\] {
  font-size: 11px;
}

.text-\[13px\] {
  font-size: 13px;
}

.text-\[8px\] {
  font-size: 8px;
}

.text-\[9px\] {
  font-size: 9px;
}

.text-base {
  font-size: 1rem;
  line-height: 1.5rem;
}

.text-lg {
  font-size: 1.125rem;
  line-height: 1.75rem;
}

.text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.text-xl {
  font-size: 1.25rem;
  line-height: 1.75rem;
}

.text-xs {
  font-size: 0.75rem;
  line-height: 1rem;
}

.font-bold {
  font-weight: 700;
}

.font-medium {
  font-weight: 500;
}

.font-normal {
  font-weight: 400;
}

.font-semibold {
  font-weight: 600;
}

.uppercase {
  text-transform: uppercase;
}

.lowercase {
  text-transform: lowercase;
}

.capitalize {
  text-transform: capitalize;
}

.italic {
  font-style: italic;
}

.tabular-nums {
  --tw-numeric-spacing: tabular-nums;
  font-variant-numeric: var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction);
}

.leading-5 {
  line-height: 1.25rem;
}

.leading-relaxed {
  line-height: 1.625;
}

.leading-tight {
  line-height: 1.25;
}

.tracking-wider {
  letter-spacing: 0.05em;
}

.text-amber-300 {
  --tw-text-opacity: 1;
  color: rgb(252 211 77 / var(--tw-text-opacity, 1));
}

.text-amber-400 {
  --tw-text-opacity: 1;
  color: rgb(251 191 36 / var(--tw-text-opacity, 1));
}

.text-amber-500 {
  --tw-text-opacity: 1;
  color: rgb(245 158 11 / var(--tw-text-opacity, 1));
}

.text-amber-500\/50 {
  color: rgb(245 158 11 / 0.5);
}

.text-black {
  --tw-text-opacity: 1;
  color: rgb(0 0 0 / var(--tw-text-opacity, 1));
}

.text-black\/40 {
  color: rgb(0 0 0 / 0.4);
}

.text-black\/50 {
  color: rgb(0 0 0 / 0.5);
}

.text-black\/80 {
  color: rgb(0 0 0 / 0.8);
}

.text-blue-300 {
  --tw-text-opacity: 1;
  color: rgb(147 197 253 / var(--tw-text-opacity, 1));
}

.text-blue-400 {
  --tw-text-opacity: 1;
  color: rgb(96 165 250 / var(--tw-text-opacity, 1));
}

.text-blue-500 {
  --tw-text-opacity: 1;
  color: rgb(59 130 246 / var(--tw-text-opacity, 1));
}

.text-blue-500\/50 {
  color: rgb(59 130 246 / 0.5);
}

.text-blue-600 {
  --tw-text-opacity: 1;
  color: rgb(37 99 235 / var(--tw-text-opacity, 1));
}

.text-blue-700 {
  --tw-text-opacity: 1;
  color: rgb(29 78 216 / var(--tw-text-opacity, 1));
}

.text-blue-800 {
  --tw-text-opacity: 1;
  color: rgb(30 64 175 / var(--tw-text-opacity, 1));
}

.text-blue-900 {
  --tw-text-opacity: 1;
  color: rgb(30 58 138 / var(--tw-text-opacity, 1));
}

.text-cyan-400 {
  --tw-text-opacity: 1;
  color: rgb(34 211 238 / var(--tw-text-opacity, 1));
}

.text-emerald-300 {
  --tw-text-opacity: 1;
  color: rgb(110 231 183 / var(--tw-text-opacity, 1));
}

.text-emerald-400 {
  --tw-text-opacity: 1;
  color: rgb(52 211 153 / var(--tw-text-opacity, 1));
}

.text-emerald-400\/50 {
  color: rgb(52 211 153 / 0.5);
}

.text-error-400 {
  --tw-text-opacity: 1;
  color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}

.text-error-500 {
  --tw-text-opacity: 1;
  color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}

.text-error-600 {
  --tw-text-opacity: 1;
  color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}

.text-error-700 {
  --tw-text-opacity: 1;
  color: rgb(185 28 28 / var(--tw-text-opacity, 1));
}

.text-gray-100 {
  --tw-text-opacity: 1;
  color: rgb(243 244 246 / var(--tw-text-opacity, 1));
}

.text-gray-200 {
  --tw-text-opacity: 1;
  color: rgb(229 231 235 / var(--tw-text-opacity, 1));
}

.text-gray-300 {
  --tw-text-opacity: 1;
  color: rgb(209 213 219 / var(--tw-text-opacity, 1));
}

.text-gray-400 {
  --tw-text-opacity: 1;
  color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}

.text-gray-500 {
  --tw-text-opacity: 1;
  color: rgb(107 114 128 / var(--tw-text-opacity, 1));
}

.text-gray-600 {
  --tw-text-opacity: 1;
  color: rgb(75 85 99 / var(--tw-text-opacity, 1));
}

.text-gray-700 {
  --tw-text-opacity: 1;
  color: rgb(55 65 81 / var(--tw-text-opacity, 1));
}

.text-gray-800 {
  --tw-text-opacity: 1;
  color: rgb(31 41 55 / var(--tw-text-opacity, 1));
}

.text-gray-900 {
  --tw-text-opacity: 1;
  color: rgb(17 24 39 / var(--tw-text-opacity, 1));
}

.text-green-300 {
  --tw-text-opacity: 1;
  color: rgb(134 239 172 / var(--tw-text-opacity, 1));
}

.text-green-400 {
  --tw-text-opacity: 1;
  color: rgb(74 222 128 / var(--tw-text-opacity, 1));
}

.text-green-500 {
  --tw-text-opacity: 1;
  color: rgb(34 197 94 / var(--tw-text-opacity, 1));
}

.text-green-600 {
  --tw-text-opacity: 1;
  color: rgb(22 163 74 / var(--tw-text-opacity, 1));
}

.text-green-700 {
  --tw-text-opacity: 1;
  color: rgb(21 128 61 / var(--tw-text-opacity, 1));
}

.text-green-800 {
  --tw-text-opacity: 1;
  color: rgb(22 101 52 / var(--tw-text-opacity, 1));
}

.text-green-900 {
  --tw-text-opacity: 1;
  color: rgb(20 83 45 / var(--tw-text-opacity, 1));
}

.text-indigo-300 {
  --tw-text-opacity: 1;
  color: rgb(165 180 252 / var(--tw-text-opacity, 1));
}

.text-indigo-300\/80 {
  color: rgb(165 180 252 / 0.8);
}

.text-indigo-400 {
  --tw-text-opacity: 1;
  color: rgb(129 140 248 / var(--tw-text-opacity, 1));
}

.text-indigo-500 {
  --tw-text-opacity: 1;
  color: rgb(99 102 241 / var(--tw-text-opacity, 1));
}

.text-indigo-900 {
  --tw-text-opacity: 1;
  color: rgb(49 46 129 / var(--tw-text-opacity, 1));
}

.text-neutral-100 {
  --tw-text-opacity: 1;
  color: rgb(245 245 245 / var(--tw-text-opacity, 1));
}

.text-neutral-200 {
  --tw-text-opacity: 1;
  color: rgb(229 229 229 / var(--tw-text-opacity, 1));
}

.text-neutral-300 {
  --tw-text-opacity: 1;
  color: rgb(212 212 212 / var(--tw-text-opacity, 1));
}

.text-neutral-400 {
  --tw-text-opacity: 1;
  color: rgb(163 163 163 / var(--tw-text-opacity, 1));
}

.text-neutral-500 {
  --tw-text-opacity: 1;
  color: rgb(115 115 115 / var(--tw-text-opacity, 1));
}

.text-neutral-600 {
  --tw-text-opacity: 1;
  color: rgb(82 82 82 / var(--tw-text-opacity, 1));
}

.text-neutral-700 {
  --tw-text-opacity: 1;
  color: rgb(64 64 64 / var(--tw-text-opacity, 1));
}

.text-neutral-800 {
  --tw-text-opacity: 1;
  color: rgb(38 38 38 / var(--tw-text-opacity, 1));
}

.text-neutral-900 {
  --tw-text-opacity: 1;
  color: rgb(23 23 23 / var(--tw-text-opacity, 1));
}

.text-orange-400 {
  --tw-text-opacity: 1;
  color: rgb(251 146 60 / var(--tw-text-opacity, 1));
}

.text-orange-500 {
  --tw-text-opacity: 1;
  color: rgb(249 115 22 / var(--tw-text-opacity, 1));
}

.text-orange-600 {
  --tw-text-opacity: 1;
  color: rgb(234 88 12 / var(--tw-text-opacity, 1));
}

.text-orange-700 {
  --tw-text-opacity: 1;
  color: rgb(194 65 12 / var(--tw-text-opacity, 1));
}

.text-orange-900 {
  --tw-text-opacity: 1;
  color: rgb(124 45 18 / var(--tw-text-opacity, 1));
}

.text-pink-900 {
  --tw-text-opacity: 1;
  color: rgb(131 24 67 / var(--tw-text-opacity, 1));
}

.text-primary-300 {
  --tw-text-opacity: 1;
  color: rgb(147 197 253 / var(--tw-text-opacity, 1));
}

.text-primary-400 {
  --tw-text-opacity: 1;
  color: rgb(96 165 250 / var(--tw-text-opacity, 1));
}

.text-primary-500 {
  --tw-text-opacity: 1;
  color: rgb(59 130 246 / var(--tw-text-opacity, 1));
}

.text-primary-600 {
  --tw-text-opacity: 1;
  color: rgb(37 99 235 / var(--tw-text-opacity, 1));
}

.text-primary-700 {
  --tw-text-opacity: 1;
  color: rgb(29 78 216 / var(--tw-text-opacity, 1));
}

.text-purple-400 {
  --tw-text-opacity: 1;
  color: rgb(192 132 252 / var(--tw-text-opacity, 1));
}

.text-purple-500 {
  --tw-text-opacity: 1;
  color: rgb(168 85 247 / var(--tw-text-opacity, 1));
}

.text-purple-600 {
  --tw-text-opacity: 1;
  color: rgb(147 51 234 / var(--tw-text-opacity, 1));
}

.text-purple-700 {
  --tw-text-opacity: 1;
  color: rgb(126 34 206 / var(--tw-text-opacity, 1));
}

.text-purple-800 {
  --tw-text-opacity: 1;
  color: rgb(107 33 168 / var(--tw-text-opacity, 1));
}

.text-purple-900 {
  --tw-text-opacity: 1;
  color: rgb(88 28 135 / var(--tw-text-opacity, 1));
}

.text-red-300 {
  --tw-text-opacity: 1;
  color: rgb(252 165 165 / var(--tw-text-opacity, 1));
}

.text-red-400 {
  --tw-text-opacity: 1;
  color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}

.text-red-500 {
  --tw-text-opacity: 1;
  color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}

.text-red-600 {
  --tw-text-opacity: 1;
  color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}

.text-red-700 {
  --tw-text-opacity: 1;
  color: rgb(185 28 28 / var(--tw-text-opacity, 1));
}

.text-red-900 {
  --tw-text-opacity: 1;
  color: rgb(127 29 29 / var(--tw-text-opacity, 1));
}

.text-slate-200 {
  --tw-text-opacity: 1;
  color: rgb(226 232 240 / var(--tw-text-opacity, 1));
}

.text-slate-300 {
  --tw-text-opacity: 1;
  color: rgb(203 213 225 / var(--tw-text-opacity, 1));
}

.text-slate-400 {
  --tw-text-opacity: 1;
  color: rgb(148 163 184 / var(--tw-text-opacity, 1));
}

.text-slate-500 {
  --tw-text-opacity: 1;
  color: rgb(100 116 139 / var(--tw-text-opacity, 1));
}

.text-slate-600 {
  --tw-text-opacity: 1;
  color: rgb(71 85 105 / var(--tw-text-opacity, 1));
}

.text-success-400 {
  --tw-text-opacity: 1;
  color: rgb(74 222 128 / var(--tw-text-opacity, 1));
}

.text-success-500 {
  --tw-text-opacity: 1;
  color: rgb(34 197 94 / var(--tw-text-opacity, 1));
}

.text-success-700 {
  --tw-text-opacity: 1;
  color: rgb(21 128 61 / var(--tw-text-opacity, 1));
}

.text-teal-700 {
  --tw-text-opacity: 1;
  color: rgb(15 118 110 / var(--tw-text-opacity, 1));
}

.text-teal-900 {
  --tw-text-opacity: 1;
  color: rgb(19 78 74 / var(--tw-text-opacity, 1));
}

.text-transparent {
  color: transparent;
}

.text-warning-400 {
  --tw-text-opacity: 1;
  color: rgb(251 191 36 / var(--tw-text-opacity, 1));
}

.text-warning-500 {
  --tw-text-opacity: 1;
  color: rgb(245 158 11 / var(--tw-text-opacity, 1));
}

.text-warning-700 {
  --tw-text-opacity: 1;
  color: rgb(180 83 9 / var(--tw-text-opacity, 1));
}

.text-white {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.text-white\/10 {
  color: rgb(255 255 255 / 0.1);
}

.text-white\/20 {
  color: rgb(255 255 255 / 0.2);
}

.text-white\/25 {
  color: rgb(255 255 255 / 0.25);
}

.text-white\/30 {
  color: rgb(255 255 255 / 0.3);
}

.text-white\/40 {
  color: rgb(255 255 255 / 0.4);
}

.text-white\/50 {
  color: rgb(255 255 255 / 0.5);
}

.text-white\/60 {
  color: rgb(255 255 255 / 0.6);
}

.text-white\/70 {
  color: rgb(255 255 255 / 0.7);
}

.text-white\/80 {
  color: rgb(255 255 255 / 0.8);
}

.text-white\/90 {
  color: rgb(255 255 255 / 0.9);
}

.text-yellow-400 {
  --tw-text-opacity: 1;
  color: rgb(250 204 21 / var(--tw-text-opacity, 1));
}

.text-yellow-500 {
  --tw-text-opacity: 1;
  color: rgb(234 179 8 / var(--tw-text-opacity, 1));
}

.text-yellow-600 {
  --tw-text-opacity: 1;
  color: rgb(202 138 4 / var(--tw-text-opacity, 1));
}

.text-yellow-700 {
  --tw-text-opacity: 1;
  color: rgb(161 98 7 / var(--tw-text-opacity, 1));
}

.text-yellow-900 {
  --tw-text-opacity: 1;
  color: rgb(113 63 18 / var(--tw-text-opacity, 1));
}

.underline {
  text-decoration-line: underline;
}

.line-through {
  text-decoration-line: line-through;
}

.placeholder-gray-400::-moz-placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(156 163 175 / var(--tw-placeholder-opacity, 1));
}

.placeholder-gray-400::placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(156 163 175 / var(--tw-placeholder-opacity, 1));
}

.placeholder-gray-500::-moz-placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(107 114 128 / var(--tw-placeholder-opacity, 1));
}

.placeholder-gray-500::placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(107 114 128 / var(--tw-placeholder-opacity, 1));
}

.placeholder-neutral-400::-moz-placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(163 163 163 / var(--tw-placeholder-opacity, 1));
}

.placeholder-neutral-400::placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(163 163 163 / var(--tw-placeholder-opacity, 1));
}

.placeholder-neutral-500::-moz-placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(115 115 115 / var(--tw-placeholder-opacity, 1));
}

.placeholder-neutral-500::placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(115 115 115 / var(--tw-placeholder-opacity, 1));
}

.placeholder-slate-500::-moz-placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(100 116 139 / var(--tw-placeholder-opacity, 1));
}

.placeholder-slate-500::placeholder {
  --tw-placeholder-opacity: 1;
  color: rgb(100 116 139 / var(--tw-placeholder-opacity, 1));
}

.placeholder-white\/30::-moz-placeholder {
  color: rgb(255 255 255 / 0.3);
}

.placeholder-white\/30::placeholder {
  color: rgb(255 255 255 / 0.3);
}

.accent-amber-400 {
  accent-color: #fbbf24;
}

.accent-blue-500 {
  accent-color: #3b82f6;
}

.accent-green-500 {
  accent-color: #22c55e;
}

.accent-indigo-400 {
  accent-color: #818cf8;
}

.accent-red-400 {
  accent-color: #f87171;
}

.accent-white {
  accent-color: #fff;
}

.\!opacity-30 {
  opacity: 0.3 !important;
}

.opacity-0 {
  opacity: 0;
}

.opacity-100 {
  opacity: 1;
}

.opacity-25 {
  opacity: 0.25;
}

.opacity-30 {
  opacity: 0.3;
}

.opacity-40 {
  opacity: 0.4;
}

.opacity-50 {
  opacity: 0.5;
}

.opacity-60 {
  opacity: 0.6;
}

.opacity-70 {
  opacity: 0.7;
}

.opacity-75 {
  opacity: 0.75;
}

.shadow {
  --tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-2xl {
  --tw-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
  --tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_30px_rgba\(239\2c 68\2c 68\2c 0\.4\)\] {
  --tw-shadow: 0 0 30px rgba(239,68,68,0.4);
  --tw-shadow-colored: 0 0 30px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_30px_rgba\(245\2c 158\2c 11\2c 0\.4\)\] {
  --tw-shadow: 0 0 30px rgba(245,158,11,0.4);
  --tw-shadow-colored: 0 0 30px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_30px_rgba\(34\2c 197\2c 94\2c 0\.4\)\] {
  --tw-shadow: 0 0 30px rgba(34,197,94,0.4);
  --tw-shadow-colored: 0 0 30px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-lg {
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-md {
  --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-sm {
  --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-xl {
  --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[var\(--glass-glow-accent\)\] {
  --tw-shadow-color: var(--glass-glow-accent);
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-\[var\(--glass-glow-primary\)\] {
  --tw-shadow-color: var(--glass-glow-primary);
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-\[var\(--glass-glow-secondary\)\] {
  --tw-shadow-color: var(--glass-glow-secondary);
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-\[var\(--glass-shadow\)\] {
  --tw-shadow-color: var(--glass-shadow);
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-\[var\(--glass-shadow-lg\)\] {
  --tw-shadow-color: var(--glass-shadow-lg);
  --tw-shadow: var(--tw-shadow-colored);
}

.outline-none {
  outline: 2px solid transparent;
  outline-offset: 2px;
}

.outline {
  outline-style: solid;
}

.ring {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.ring-0 {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.ring-1 {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.ring-2 {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.ring-4 {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.ring-inset {
  --tw-ring-inset: inset;
}

.ring-amber-400 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(251 191 36 / var(--tw-ring-opacity, 1));
}

.ring-amber-500 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(245 158 11 / var(--tw-ring-opacity, 1));
}

.ring-blue-400 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(96 165 250 / var(--tw-ring-opacity, 1));
}

.ring-blue-500 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1));
}

.ring-blue-500\/30 {
  --tw-ring-color: rgb(59 130 246 / 0.3);
}

.ring-blue-700 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(29 78 216 / var(--tw-ring-opacity, 1));
}

.ring-cyan-400 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(34 211 238 / var(--tw-ring-opacity, 1));
}

.ring-emerald-400 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(52 211 153 / var(--tw-ring-opacity, 1));
}

.ring-green-500 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(34 197 94 / var(--tw-ring-opacity, 1));
}

.ring-indigo-400 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(129 140 248 / var(--tw-ring-opacity, 1));
}

.ring-orange-600 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(234 88 12 / var(--tw-ring-opacity, 1));
}

.ring-pink-400 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(244 114 182 / var(--tw-ring-opacity, 1));
}

.ring-primary-500 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1));
}

.ring-primary-500\/20 {
  --tw-ring-color: rgb(59 130 246 / 0.2);
}

.ring-purple-400 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(192 132 252 / var(--tw-ring-opacity, 1));
}

.ring-purple-500 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(168 85 247 / var(--tw-ring-opacity, 1));
}

.ring-red-700 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(185 28 28 / var(--tw-ring-opacity, 1));
}

.ring-teal-700 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(15 118 110 / var(--tw-ring-opacity, 1));
}

.ring-white\/40 {
  --tw-ring-color: rgb(255 255 255 / 0.4);
}

.ring-yellow-400 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(250 204 21 / var(--tw-ring-opacity, 1));
}

.ring-opacity-50 {
  --tw-ring-opacity: 0.5;
}

.ring-opacity-80 {
  --tw-ring-opacity: 0.8;
}

.ring-offset-1 {
  --tw-ring-offset-width: 1px;
}

.ring-offset-2 {
  --tw-ring-offset-width: 2px;
}

.ring-offset-neutral-900 {
  --tw-ring-offset-color: #171717;
}

.ring-offset-transparent {
  --tw-ring-offset-color: transparent;
}

.ring-offset-white {
  --tw-ring-offset-color: #fff;
}

.blur {
  --tw-blur: blur(8px);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.drop-shadow {
  --tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / 0.1)) drop-shadow(0 1px 1px rgb(0 0 0 / 0.06));
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.grayscale {
  --tw-grayscale: grayscale(100%);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.invert {
  --tw-invert: invert(100%);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.\!filter {
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow) !important;
}

.filter {
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.backdrop-blur {
  --tw-backdrop-blur: blur(8px);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.backdrop-blur-\[var\(--glass-blur\)\] {
  --tw-backdrop-blur: blur(var(--glass-blur));
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.backdrop-blur-\[var\(--glass-blur-lg\)\] {
  --tw-backdrop-blur: blur(var(--glass-blur-lg));
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.backdrop-blur-md {
  --tw-backdrop-blur: blur(12px);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.backdrop-blur-sm {
  --tw-backdrop-blur: blur(4px);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.backdrop-blur-xl {
  --tw-backdrop-blur: blur(24px);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.backdrop-filter {
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.transition {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-\[width\] {
  transition-property: width;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-all {
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-colors {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-opacity {
  transition-property: opacity;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-transform {
  transition-property: transform;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.duration-100 {
  transition-duration: 100ms;
}

.duration-150 {
  transition-duration: 150ms;
}

.duration-200 {
  transition-duration: 200ms;
}

.duration-300 {
  transition-duration: 300ms;
}

.ease-in {
  transition-timing-function: cubic-bezier(0.4, 0, 1, 1);
}

.ease-in-out {
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.ease-out {
  transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}

.will-change-\[backdrop-filter\2c transform\] {
  will-change: backdrop-filter,transform;
}

.will-change-transform {
  will-change: transform;
}

/* Text utilities */

/* Truncate with ellipsis */

/* Hide scrollbar but keep functionality */

/* GPU acceleration */

.\!gpu {
    transform: translateZ(0) !important;
    will-change: transform !important;
  }

.gpu {
    transform: translateZ(0);
    will-change: transform;
  }

/* Backdrop blur fallback */

.\[box-shadow\:var\(--glass-shadow\)\2c var\(--glass-inner-light\)\] {
  box-shadow: var(--glass-shadow),var(--glass-inner-light);
}

.\[box-shadow\:var\(--glass-shadow-lg\)\2c var\(--glass-inner-light\)\] {
  box-shadow: var(--glass-shadow-lg),var(--glass-inner-light);
}

/* ============================================
 * BASE STYLES
 * ============================================ */

/* ============================================
 * COMPONENT STYLES
 * ============================================ */

/* ============================================
 * UTILITY STYLES
 * ============================================ */

/* ============================================
 * THEME TRANSITION
 * ============================================ */

.theme-transition,
.theme-transition *,
.theme-transition *::before,
.theme-transition *::after {
  transition: background-color 300ms cubic-bezier(0.4, 0, 0.2, 1),
              color 300ms cubic-bezier(0.4, 0, 0.2, 1),
              border-color 300ms cubic-bezier(0.4, 0, 0.2, 1),
              fill 300ms cubic-bezier(0.4, 0, 0.2, 1),
              stroke 300ms cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* ============================================
 * ACCESSIBILITY
 * ============================================ */

/* Focus visible for keyboard navigation */

*:focus-visible {
  outline: 3px solid var(--color-primary-500);
  outline-offset: 2px;
}

/* Skip link for screen readers */

.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--color-primary-600);
  color: white;
  padding: 8px 16px;
  z-index: 1000;
  transition: top 0.3s;
}

.skip-link:focus {
  top: 0;
}

/* Screen reader only */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* ============================================
 * REACT FLOW OVERRIDES
 * ============================================ */

/* Canvas background - transparent to show global background image */

.react-flow {
  background-color: transparent !important;
}

[data-theme="dark"] .react-flow {
  background-color: transparent !important;
}

/* Grid pattern - subtle white dots in dark mode */

.react-flow__background {
  background-color: transparent !important;
}

[data-theme="dark"] .react-flow__background {
  background-color: transparent !important;
}

/* Node performance optimization */

.react-flow__node,
.react-flow__edge {
  will-change: transform;
  transform: translateZ(0);
}

/* CRITICAL: Force edge layer ABOVE group nodes but BELOW regular nodes
 * React Flow renders edges in a separate SVG layer (.react-flow__edges)
 * universalGroupNode is at z-index 5, regular nodes at z-index 25+
 * Using z-index 15 to be between groups and nodes
 * 
 * ISSUE 12 FIX: Removed 'position: relative !important' which was breaking
 * ReactFlow's coordinate system for connection lines. The edges layer must
 * use ReactFlow's default positioning (absolute) to properly overlay nodes.
 */

.react-flow__edges {
  z-index: 15 !important;
  /* DO NOT add position: relative - it breaks connection line coordinates */
}

/* Also target the SVG element inside */

.react-flow__edges svg {
  z-index: 15 !important;
}

/* Target individual edge groups */

.react-flow__edge {
  z-index: 15 !important;
}

/* Edge styling */

.react-flow__edge-path {
  stroke-width: 2;
  transition: stroke 200ms ease, stroke-width 200ms ease;
}

.react-flow__edge:hover .react-flow__edge-path {
  stroke-width: 3;
}

/* CONNECTION LINE - Visible during drag operations */

.react-flow__connection {
  z-index: 1000 !important;
}

.react-flow__connection-path {
  stroke: #818cf8 !important;
  stroke-width: 3px !important;
  stroke-dasharray: 8 4 !important;
  fill: none !important;
  filter: drop-shadow(0 0 6px rgba(129, 140, 248, 0.8)) !important;
}

/* Ensure connection line is visible in dark mode */

[data-theme="dark"] .react-flow__connection-path {
  stroke: #a5b4fc !important;
  filter: drop-shadow(0 0 8px rgba(165, 180, 252, 0.9)) !important;
}

/* Minimap styling */

.react-flow__minimap {
  background-color: var(--color-neutral-100);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
}

[data-theme="dark"] .react-flow__minimap {
  background-color: var(--color-neutral-200);
  border-color: var(--color-neutral-300);
}

/* Controls styling */

.react-flow__controls {
  background-color: var(--color-neutral-50);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

[data-theme="dark"] .react-flow__controls {
  background-color: var(--color-neutral-200);
  border-color: var(--color-neutral-300);
}

.react-flow__controls-button {
  background-color: transparent;
  border: none;
  color: var(--color-neutral-600);
  transition: all 150ms ease;
}

.react-flow__controls-button:hover {
  background-color: var(--color-neutral-100);
  color: var(--color-neutral-900);
}

[data-theme="dark"] .react-flow__controls-button {
  color: var(--color-neutral-400);
}

[data-theme="dark"] .react-flow__controls-button:hover {
  background-color: var(--color-neutral-300);
  color: var(--color-neutral-100);
}

/* Task node handle positioning */

.react-flow .task-template-node .react-flow__handle.react-flow__handle-left {
  top: auto !important;
  bottom: 20px !important;
  left: 0 !important;
}

.react-flow .task-template-node .react-flow__handle.react-flow__handle-right {
  top: auto !important;
  bottom: 20px !important;
  right: 0 !important;
}

/* ============================================
 * ANIMATIONS
 * ============================================ */

/* Smooth hover effects for interactive elements */

button,
a,
input,
select,
textarea,
[role="button"] {
  transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* Ripple effect container */

.ripple-container {
  position: relative;
  overflow: hidden;
}

.ripple {
  position: absolute;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.3);
  transform: scale(0);
  animation: ripple 600ms linear;
  pointer-events: none;
}

/* Status indicator pulse */

.status-pulse {
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

/* Error shake animation */

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  10%, 30%, 50%, 70%, 90% { transform: translateX(-4px); }
  20%, 40%, 60%, 80% { transform: translateX(4px); }
}

.animate-shake {
  animation: shake 0.5s ease-in-out;
}

/* ============================================
 * PRINT STYLES
 * ============================================ */

@media print {
  body {
    background: white;
    color: black;
  }

  .no-print {
    display: none !important;
  }

  .react-flow__controls,
  .react-flow__minimap {
    display: none !important;
  }
}

/* ============================================
 * RICH TEXT EDITOR - Notes Field (Task 5, 005.942)
 * ============================================ */

/* Placeholder text for empty contentEditable notes field */

[contenteditable][data-placeholder]:empty::before {
  content: attr(data-placeholder);
  color: rgba(148, 163, 184, 0.6);
  pointer-events: none;
  font-style: italic;
}

/* Ensure contentEditable focus outline matches theme */

[contenteditable]:focus {
  outline: none;
}

/* Bullet list styling inside contentEditable */

[contenteditable] ul {
  margin: 4px 0;
  padding-left: 20px;
  list-style-type: disc;
}

[contenteditable] li {
  margin-bottom: 2px;
}

.placeholder\:text-white\/25::-moz-placeholder {
  color: rgb(255 255 255 / 0.25);
}

.placeholder\:text-white\/25::placeholder {
  color: rgb(255 255 255 / 0.25);
}

.placeholder\:text-white\/30::-moz-placeholder {
  color: rgb(255 255 255 / 0.3);
}

.placeholder\:text-white\/30::placeholder {
  color: rgb(255 255 255 / 0.3);
}

.focus-within\:ring-2:focus-within {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.focus-within\:ring-error-500\/20:focus-within {
  --tw-ring-color: rgb(239 68 68 / 0.2);
}

.hover\:-translate-y-0\.5:hover {
  --tw-translate-y: -0.125rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:scale-105:hover {
  --tw-scale-x: 1.05;
  --tw-scale-y: 1.05;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:scale-110:hover {
  --tw-scale-x: 1.1;
  --tw-scale-y: 1.1;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:scale-\[1\.01\]:hover {
  --tw-scale-x: 1.01;
  --tw-scale-y: 1.01;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:\!border-primary-400:hover {
  --tw-border-opacity: 1 !important;
  border-color: rgb(96 165 250 / var(--tw-border-opacity, 1)) !important;
}

.hover\:\!border-primary-500:hover {
  --tw-border-opacity: 1 !important;
  border-color: rgb(59 130 246 / var(--tw-border-opacity, 1)) !important;
}

.hover\:border-black\/20:hover {
  border-color: rgb(0 0 0 / 0.2);
}

.hover\:border-blue-500:hover {
  --tw-border-opacity: 1;
  border-color: rgb(59 130 246 / var(--tw-border-opacity, 1));
}

.hover\:border-neutral-300:hover {
  --tw-border-opacity: 1;
  border-color: rgb(212 212 212 / var(--tw-border-opacity, 1));
}

.hover\:border-neutral-400:hover {
  --tw-border-opacity: 1;
  border-color: rgb(163 163 163 / var(--tw-border-opacity, 1));
}

.hover\:border-neutral-500:hover {
  --tw-border-opacity: 1;
  border-color: rgb(115 115 115 / var(--tw-border-opacity, 1));
}

.hover\:border-neutral-600:hover {
  --tw-border-opacity: 1;
  border-color: rgb(82 82 82 / var(--tw-border-opacity, 1));
}

.hover\:border-purple-300:hover {
  --tw-border-opacity: 1;
  border-color: rgb(216 180 254 / var(--tw-border-opacity, 1));
}

.hover\:border-slate-500:hover {
  --tw-border-opacity: 1;
  border-color: rgb(100 116 139 / var(--tw-border-opacity, 1));
}

.hover\:border-white\/20:hover {
  border-color: rgb(255 255 255 / 0.2);
}

.hover\:border-white\/25:hover {
  border-color: rgb(255 255 255 / 0.25);
}

.hover\:border-white\/50:hover {
  border-color: rgb(255 255 255 / 0.5);
}

.hover\:border-opacity-50:hover {
  --tw-border-opacity: 0.5;
}

.hover\:bg-amber-500\/10:hover {
  background-color: rgb(245 158 11 / 0.1);
}

.hover\:bg-amber-500\/20:hover {
  background-color: rgb(245 158 11 / 0.2);
}

.hover\:bg-amber-500\/30:hover {
  background-color: rgb(245 158 11 / 0.3);
}

.hover\:bg-black\/10:hover {
  background-color: rgb(0 0 0 / 0.1);
}

.hover\:bg-black\/5:hover {
  background-color: rgb(0 0 0 / 0.05);
}

.hover\:bg-black\/\[0\.03\]:hover {
  background-color: rgb(0 0 0 / 0.03);
}

.hover\:bg-blue-200:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(191 219 254 / var(--tw-bg-opacity, 1));
}

.hover\:bg-blue-500:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1));
}

.hover\:bg-blue-500\/10:hover {
  background-color: rgb(59 130 246 / 0.1);
}

.hover\:bg-blue-500\/30:hover {
  background-color: rgb(59 130 246 / 0.3);
}

.hover\:bg-blue-600:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(37 99 235 / var(--tw-bg-opacity, 1));
}

.hover\:bg-blue-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(29 78 216 / var(--tw-bg-opacity, 1));
}

.hover\:bg-cyan-500\/30:hover {
  background-color: rgb(6 182 212 / 0.3);
}

.hover\:bg-error-500:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1));
}

.hover\:bg-error-500\/20:hover {
  background-color: rgb(239 68 68 / 0.2);
}

.hover\:bg-error-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(185 28 28 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-100:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-200:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(229 231 235 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-300:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(209 213 219 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-50:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-600:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(75 85 99 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(55 65 81 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-700\/30:hover {
  background-color: rgb(55 65 81 / 0.3);
}

.hover\:bg-gray-700\/50:hover {
  background-color: rgb(55 65 81 / 0.5);
}

.hover\:bg-gray-800:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-800\/50:hover {
  background-color: rgb(31 41 55 / 0.5);
}

.hover\:bg-green-200:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(187 247 208 / var(--tw-bg-opacity, 1));
}

.hover\:bg-green-500\/30:hover {
  background-color: rgb(34 197 94 / 0.3);
}

.hover\:bg-green-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(21 128 61 / var(--tw-bg-opacity, 1));
}

.hover\:bg-indigo-400\/10:hover {
  background-color: rgb(129 140 248 / 0.1);
}

.hover\:bg-indigo-600\/80:hover {
  background-color: rgb(79 70 229 / 0.8);
}

.hover\:bg-indigo-600\/90:hover {
  background-color: rgb(79 70 229 / 0.9);
}

.hover\:bg-indigo-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(67 56 202 / var(--tw-bg-opacity, 1));
}

.hover\:bg-neutral-100:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(245 245 245 / var(--tw-bg-opacity, 1));
}

.hover\:bg-neutral-200:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(229 229 229 / var(--tw-bg-opacity, 1));
}

.hover\:bg-neutral-300:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(212 212 212 / var(--tw-bg-opacity, 1));
}

.hover\:bg-neutral-50:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(250 250 250 / var(--tw-bg-opacity, 1));
}

.hover\:bg-neutral-600:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(82 82 82 / var(--tw-bg-opacity, 1));
}

.hover\:bg-neutral-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(64 64 64 / var(--tw-bg-opacity, 1));
}

.hover\:bg-neutral-800:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(38 38 38 / var(--tw-bg-opacity, 1));
}

.hover\:bg-orange-500\/30:hover {
  background-color: rgb(249 115 22 / 0.3);
}

.hover\:bg-orange-600:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(234 88 12 / var(--tw-bg-opacity, 1));
}

.hover\:bg-primary-100:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(219 234 254 / var(--tw-bg-opacity, 1));
}

.hover\:bg-primary-200:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(191 219 254 / var(--tw-bg-opacity, 1));
}

.hover\:bg-primary-500:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1));
}

.hover\:bg-primary-500\/30:hover {
  background-color: rgb(59 130 246 / 0.3);
}

.hover\:bg-primary-600:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(37 99 235 / var(--tw-bg-opacity, 1));
}

.hover\:bg-primary-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(29 78 216 / var(--tw-bg-opacity, 1));
}

.hover\:bg-purple-600:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(147 51 234 / var(--tw-bg-opacity, 1));
}

.hover\:bg-purple-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(126 34 206 / var(--tw-bg-opacity, 1));
}

.hover\:bg-red-500\/10:hover {
  background-color: rgb(239 68 68 / 0.1);
}

.hover\:bg-red-500\/20:hover {
  background-color: rgb(239 68 68 / 0.2);
}

.hover\:bg-red-500\/30:hover {
  background-color: rgb(239 68 68 / 0.3);
}

.hover\:bg-red-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(185 28 28 / var(--tw-bg-opacity, 1));
}

.hover\:bg-red-900\/30:hover {
  background-color: rgb(127 29 29 / 0.3);
}

.hover\:bg-success-500:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(34 197 94 / var(--tw-bg-opacity, 1));
}

.hover\:bg-success-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(21 128 61 / var(--tw-bg-opacity, 1));
}

.hover\:bg-transparent:hover {
  background-color: transparent;
}

.hover\:bg-white:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}

.hover\:bg-white\/10:hover {
  background-color: rgb(255 255 255 / 0.1);
}

.hover\:bg-white\/15:hover {
  background-color: rgb(255 255 255 / 0.15);
}

.hover\:bg-white\/20:hover {
  background-color: rgb(255 255 255 / 0.2);
}

.hover\:bg-white\/30:hover {
  background-color: rgb(255 255 255 / 0.3);
}

.hover\:bg-white\/5:hover {
  background-color: rgb(255 255 255 / 0.05);
}

.hover\:bg-yellow-500\/10:hover {
  background-color: rgb(234 179 8 / 0.1);
}

.hover\:bg-opacity-10:hover {
  --tw-bg-opacity: 0.1;
}

.hover\:bg-opacity-30:hover {
  --tw-bg-opacity: 0.3;
}

.hover\:bg-opacity-50:hover {
  --tw-bg-opacity: 0.5;
}

.hover\:bg-opacity-80:hover {
  --tw-bg-opacity: 0.8;
}

.hover\:text-amber-400:hover {
  --tw-text-opacity: 1;
  color: rgb(251 191 36 / var(--tw-text-opacity, 1));
}

.hover\:text-black\/70:hover {
  color: rgb(0 0 0 / 0.7);
}

.hover\:text-blue-300:hover {
  --tw-text-opacity: 1;
  color: rgb(147 197 253 / var(--tw-text-opacity, 1));
}

.hover\:text-error-400:hover {
  --tw-text-opacity: 1;
  color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}

.hover\:text-gray-300:hover {
  --tw-text-opacity: 1;
  color: rgb(209 213 219 / var(--tw-text-opacity, 1));
}

.hover\:text-gray-700:hover {
  --tw-text-opacity: 1;
  color: rgb(55 65 81 / var(--tw-text-opacity, 1));
}

.hover\:text-gray-900:hover {
  --tw-text-opacity: 1;
  color: rgb(17 24 39 / var(--tw-text-opacity, 1));
}

.hover\:text-inherit:hover {
  color: inherit;
}

.hover\:text-neutral-100:hover {
  --tw-text-opacity: 1;
  color: rgb(245 245 245 / var(--tw-text-opacity, 1));
}

.hover\:text-neutral-200:hover {
  --tw-text-opacity: 1;
  color: rgb(229 229 229 / var(--tw-text-opacity, 1));
}

.hover\:text-neutral-300:hover {
  --tw-text-opacity: 1;
  color: rgb(212 212 212 / var(--tw-text-opacity, 1));
}

.hover\:text-neutral-400:hover {
  --tw-text-opacity: 1;
  color: rgb(163 163 163 / var(--tw-text-opacity, 1));
}

.hover\:text-neutral-500:hover {
  --tw-text-opacity: 1;
  color: rgb(115 115 115 / var(--tw-text-opacity, 1));
}

.hover\:text-neutral-600:hover {
  --tw-text-opacity: 1;
  color: rgb(82 82 82 / var(--tw-text-opacity, 1));
}

.hover\:text-neutral-700:hover {
  --tw-text-opacity: 1;
  color: rgb(64 64 64 / var(--tw-text-opacity, 1));
}

.hover\:text-neutral-900:hover {
  --tw-text-opacity: 1;
  color: rgb(23 23 23 / var(--tw-text-opacity, 1));
}

.hover\:text-primary-400:hover {
  --tw-text-opacity: 1;
  color: rgb(96 165 250 / var(--tw-text-opacity, 1));
}

.hover\:text-red-300:hover {
  --tw-text-opacity: 1;
  color: rgb(252 165 165 / var(--tw-text-opacity, 1));
}

.hover\:text-red-400:hover {
  --tw-text-opacity: 1;
  color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}

.hover\:text-slate-400:hover {
  --tw-text-opacity: 1;
  color: rgb(148 163 184 / var(--tw-text-opacity, 1));
}

.hover\:text-white:hover {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.hover\:text-white\/60:hover {
  color: rgb(255 255 255 / 0.6);
}

.hover\:text-white\/80:hover {
  color: rgb(255 255 255 / 0.8);
}

.hover\:text-yellow-300:hover {
  --tw-text-opacity: 1;
  color: rgb(253 224 71 / var(--tw-text-opacity, 1));
}

.hover\:underline:hover {
  text-decoration-line: underline;
}

.hover\:no-underline:hover {
  text-decoration-line: none;
}

.hover\:opacity-100:hover {
  opacity: 1;
}

.hover\:opacity-80:hover {
  opacity: 0.8;
}

.hover\:opacity-90:hover {
  opacity: 0.9;
}

.hover\:shadow-glass-lg:hover {
  --tw-shadow: var(--glass-shadow-lg);
  --tw-shadow-colored: var(--glass-shadow-lg);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-md:hover {
  --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-xl:hover {
  --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-\[var\(--glass-shadow-lg\)\]:hover {
  --tw-shadow-color: var(--glass-shadow-lg);
  --tw-shadow: var(--tw-shadow-colored);
}

.hover\:ring-1:hover {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.hover\:ring-white\/30:hover {
  --tw-ring-color: rgb(255 255 255 / 0.3);
}

.hover\:brightness-110:hover {
  --tw-brightness: brightness(1.1);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.focus\:not-sr-only:focus {
  position: static;
  width: auto;
  height: auto;
  padding: 0;
  margin: 0;
  overflow: visible;
  clip: auto;
  white-space: normal;
}

.focus\:absolute:focus {
  position: absolute;
}

.focus\:left-4:focus {
  left: 1rem;
}

.focus\:top-4:focus {
  top: 1rem;
}

.focus\:z-50:focus {
  z-index: 50;
}

.focus\:rounded-lg:focus {
  border-radius: 0.5rem;
}

.focus\:border-blue-400:focus {
  --tw-border-opacity: 1;
  border-color: rgb(96 165 250 / var(--tw-border-opacity, 1));
}

.focus\:border-blue-400\/50:focus {
  border-color: rgb(96 165 250 / 0.5);
}

.focus\:border-blue-500:focus {
  --tw-border-opacity: 1;
  border-color: rgb(59 130 246 / var(--tw-border-opacity, 1));
}

.focus\:border-blue-500\/50:focus {
  border-color: rgb(59 130 246 / 0.5);
}

.focus\:border-indigo-400\/30:focus {
  border-color: rgb(129 140 248 / 0.3);
}

.focus\:border-indigo-500\/50:focus {
  border-color: rgb(99 102 241 / 0.5);
}

.focus\:border-primary-500:focus {
  --tw-border-opacity: 1;
  border-color: rgb(59 130 246 / var(--tw-border-opacity, 1));
}

.focus\:border-white\/30:focus {
  border-color: rgb(255 255 255 / 0.3);
}

.focus\:bg-primary-500:focus {
  --tw-bg-opacity: 1;
  background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1));
}

.focus\:px-4:focus {
  padding-left: 1rem;
  padding-right: 1rem;
}

.focus\:py-2:focus {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.focus\:text-white:focus {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.focus\:outline-none:focus {
  outline: 2px solid transparent;
  outline-offset: 2px;
}

.focus\:ring-1:focus {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.focus\:ring-2:focus {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.focus\:ring-blue-400\/30:focus {
  --tw-ring-color: rgb(96 165 250 / 0.3);
}

.focus\:ring-blue-500:focus {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1));
}

.focus\:ring-blue-500\/50:focus {
  --tw-ring-color: rgb(59 130 246 / 0.5);
}

.focus\:ring-emerald-400\/50:focus {
  --tw-ring-color: rgb(52 211 153 / 0.5);
}

.focus\:ring-green-500:focus {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(34 197 94 / var(--tw-ring-opacity, 1));
}

.focus\:ring-indigo-400\/50:focus {
  --tw-ring-color: rgb(129 140 248 / 0.5);
}

.focus\:ring-indigo-500:focus {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(99 102 241 / var(--tw-ring-opacity, 1));
}

.focus\:ring-primary-300:focus {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(147 197 253 / var(--tw-ring-opacity, 1));
}

.focus\:ring-primary-500\/50:focus {
  --tw-ring-color: rgb(59 130 246 / 0.5);
}

.focus\:ring-white\/20:focus {
  --tw-ring-color: rgb(255 255 255 / 0.2);
}

.focus\:ring-yellow-500\/50:focus {
  --tw-ring-color: rgb(234 179 8 / 0.5);
}

.focus\:ring-offset-2:focus {
  --tw-ring-offset-width: 2px;
}

.focus\:ring-offset-gray-900:focus {
  --tw-ring-offset-color: #111827;
}

.focus\:ring-offset-neutral-900:focus {
  --tw-ring-offset-color: #171717;
}

.focus\:ring-offset-white:focus {
  --tw-ring-offset-color: #fff;
}

.focus-visible\:ring-2:focus-visible {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.focus-visible\:ring-primary-500:focus-visible {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1));
}

.focus-visible\:ring-offset-2:focus-visible {
  --tw-ring-offset-width: 2px;
}

.active\:translate-y-0:active {
  --tw-translate-y: 0px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.active\:scale-\[0\.99\]:active {
  --tw-scale-x: 0.99;
  --tw-scale-y: 0.99;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.active\:bg-error-700:active {
  --tw-bg-opacity: 1;
  background-color: rgb(185 28 28 / var(--tw-bg-opacity, 1));
}

.active\:bg-error-800:active {
  --tw-bg-opacity: 1;
  background-color: rgb(153 27 27 / var(--tw-bg-opacity, 1));
}

.active\:bg-neutral-200:active {
  --tw-bg-opacity: 1;
  background-color: rgb(229 229 229 / var(--tw-bg-opacity, 1));
}

.active\:bg-neutral-400:active {
  --tw-bg-opacity: 1;
  background-color: rgb(163 163 163 / var(--tw-bg-opacity, 1));
}

.active\:bg-neutral-700:active {
  --tw-bg-opacity: 1;
  background-color: rgb(64 64 64 / var(--tw-bg-opacity, 1));
}

.active\:bg-neutral-800:active {
  --tw-bg-opacity: 1;
  background-color: rgb(38 38 38 / var(--tw-bg-opacity, 1));
}

.active\:bg-primary-700:active {
  --tw-bg-opacity: 1;
  background-color: rgb(29 78 216 / var(--tw-bg-opacity, 1));
}

.active\:bg-primary-800:active {
  --tw-bg-opacity: 1;
  background-color: rgb(30 64 175 / var(--tw-bg-opacity, 1));
}

.active\:bg-success-700:active {
  --tw-bg-opacity: 1;
  background-color: rgb(21 128 61 / var(--tw-bg-opacity, 1));
}

.active\:bg-success-800:active {
  --tw-bg-opacity: 1;
  background-color: rgb(22 101 52 / var(--tw-bg-opacity, 1));
}

.active\:shadow-sm:active {
  --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.disabled\:transform-none:disabled {
  transform: none;
}

.disabled\:cursor-not-allowed:disabled {
  cursor: not-allowed;
}

.disabled\:opacity-30:disabled {
  opacity: 0.3;
}

.disabled\:opacity-50:disabled {
  opacity: 0.5;
}

.disabled\:hover\:scale-100:hover:disabled {
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.group\/volume:hover .group-hover\/volume\:w-20 {
  width: 5rem;
}

.group:hover .group-hover\:bg-black\/10 {
  background-color: rgb(0 0 0 / 0.1);
}

.group:hover .group-hover\:bg-black\/20 {
  background-color: rgb(0 0 0 / 0.2);
}

.group\/progress:hover .group-hover\/progress\:opacity-100 {
  opacity: 1;
}

.group:hover .group-hover\:opacity-100 {
  opacity: 1;
}

.group:hover .group-hover\:opacity-50 {
  opacity: 0.5;
}

.peer:checked ~ .peer-checked\:translate-x-5 {
  --tw-translate-x: 1.25rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.peer:checked ~ .peer-checked\:bg-blue-500\/60 {
  background-color: rgb(59 130 246 / 0.6);
}

.peer:focus ~ .peer-focus\:ring-2 {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.peer:focus ~ .peer-focus\:ring-blue-400\/30 {
  --tw-ring-color: rgb(96 165 250 / 0.3);
}

body[data-engine="blink"] .chrome\:visible {
  visibility: visible;
}

body[data-engine="blink"] .chrome\:isolate {
  isolation: isolate;
}

body[data-engine="blink"] .chrome\:-translate-x-4 {
  --tw-translate-x: -1rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

body[data-engine="blink"] .chrome\:transform-gpu {
  transform: translate3d(var(--tw-translate-x), var(--tw-translate-y), 0) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

body[data-engine="blink"] .chrome\:p-\[13px\] {
  padding: 13px;
}

body[data-engine="blink"] .chrome\:\!opacity-100 {
  opacity: 1 !important;
}

body[data-engine="blink"] .chrome\:opacity-100 {
  opacity: 1;
}

body[data-engine="blink"] .chrome\:opacity-50 {
  opacity: 0.5;
}

body[data-engine="blink"] .chrome\:will-change-\[backdrop-filter\2c transform\] {
  will-change: backdrop-filter,transform;
}

body[data-engine="blink"] .chrome\:will-change-transform {
  will-change: transform;
}

body[data-engine="blink"] .chrome\:\[backface-visibility\:hidden\] {
  backface-visibility: hidden;
}

body[data-engine="blink"] .chrome\:\[perspective\:1000px\] {
  perspective: 1000px;
}

body[data-engine="gecko"] .firefox\:transform-gpu {
  transform: translate3d(var(--tw-translate-x), var(--tw-translate-y), 0) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

body[data-engine="gecko"] .firefox\:bg-opacity-50 {
  --tw-bg-opacity: 0.5;
}

body[data-engine="gecko"] .firefox\:opacity-100 {
  opacity: 1;
}

body[data-engine="gecko"] .firefox\:backdrop-blur-xl {
  --tw-backdrop-blur: blur(24px);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

body[data-engine="webkit"] .safari\:transform-gpu {
  transform: translate3d(var(--tw-translate-x), var(--tw-translate-y), 0) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

body[data-engine="webkit"] .safari\:backdrop-blur-xl {
  --tw-backdrop-blur: blur(24px);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

body[data-engine="webkit"] .safari\:will-change-transform {
  will-change: transform;
}

.dark\:text-error-400:is([data-theme="dark"] *) {
  --tw-text-opacity: 1;
  color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}

.dark\:text-primary-400:is([data-theme="dark"] *) {
  --tw-text-opacity: 1;
  color: rgb(96 165 250 / var(--tw-text-opacity, 1));
}

.dark\:text-success-400:is([data-theme="dark"] *) {
  --tw-text-opacity: 1;
  color: rgb(74 222 128 / var(--tw-text-opacity, 1));
}

.dark\:text-warning-400:is([data-theme="dark"] *) {
  --tw-text-opacity: 1;
  color: rgb(251 191 36 / var(--tw-text-opacity, 1));
}

.dark\:opacity-100:is([data-theme="dark"] *) {
  opacity: 1;
}

@media (min-width: 640px) {

  .sm\:col-span-2 {
    grid-column: span 2 / span 2;
  }

  .sm\:inline {
    display: inline;
  }

  .sm\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sm\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 768px) {

  .md\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .md\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  body[data-engine="blink"] .md\:chrome\:transform-gpu {
    transform: translate3d(var(--tw-translate-x), var(--tw-translate-y), 0) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  }
}

@media (min-width: 1024px) {

  .lg\:col-span-4 {
    grid-column: span 4 / span 4;
  }

  .lg\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .lg\:grid-cols-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}
